// ==UserScript== // @name 袋鼠快跳 // @namespace https://chensuiyi.me // @version 1.1.4 // @author 陈随易 // @description 浏览器快捷跳转 // @license MIT // @icon https://static.yicode.tech/logo/kuaitiao2.png // @homepage https://chensuiyi.me // @homepageURL https://chensuiyi.me // @source https://github.com/chenbimo/kangaroo-jump // @match *://*/* // @grant GM_addStyle // @grant GM_deleteValue // @grant GM_getValue // @grant GM_listValues // @grant GM_setValue // @downloadURL https://update.greasyfork.icu/scripts/499217/%E8%A2%8B%E9%BC%A0%E5%BF%AB%E8%B7%B3.user.js // @updateURL https://update.greasyfork.icu/scripts/499217/%E8%A2%8B%E9%BC%A0%E5%BF%AB%E8%B7%B3.meta.js // ==/UserScript== (o=>{if(typeof GM_addStyle=="function"){GM_addStyle(o);return}const i=document.createElement("style");i.textContent=o,document.head.append(i)})(" :root{font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%}.kuaitiao{position:fixed;top:50vh;left:50vw;height:600px;width:1000px;margin-top:-300px;margin-left:-500px;z-index:999999999;display:none;background-color:#333;border:2px solid #999;border-radius:10px;font-size:14px}.kuaitiao a{text-decoration:none!important;color:inherit!important}.kuaitiao a:hover{text-decoration:none!important}.kuaitiao *{box-sizing:border-box;padding:0;border:0;margin:0;outline:0}.kuaitiao.active{display:block}.kuaitiao .logo{position:absolute;top:-30px;left:50%;margin-left:-30px;height:60px;width:60px;border:2px solid #999;background-repeat:no-repeat;background-position:center center;background-size:cover;border-radius:20px}.kuaitiao .panel{position:absolute;left:15px;right:0;bottom:41px;top:40px}.kuaitiao .panel .group .grid{display:flex;flex-wrap:wrap}.kuaitiao .panel .group .box{padding-right:15px;flex:0 0 16.6666666667%;margin-bottom:15px}.kuaitiao .panel .group .box .inner{position:relative;height:40px;background-color:#555;border-radius:20px;padding:0 10px;transition:all .2s;display:flex;justify-content:space-between;align-items:center}.kuaitiao .panel .group .box .inner.move .pointer .shou{fill:#e33}.kuaitiao .panel .group .box .inner .pointer{position:absolute;height:100%;width:14px;left:-13px;font-size:14px;display:flex;flex-direction:column;justify-content:flex-end}.kuaitiao .panel .group .box .inner .link{flex:1 1 100%;display:flex;align-items:center;color:#fff}.kuaitiao .panel .group .box .inner .close{flex:0 0 auto;font-size:18px;cursor:pointer;display:flex;align-items:center}.kuaitiao .panel .group .box .inner .close .close-icon{fill:#666;transition:all .2s}.kuaitiao .panel .group .box .inner .close:hover .close-icon{fill:#e33}.kuaitiao .panel .group .box .inner:hover{box-shadow:0 2px #888}.kuaitiao .panel .group .box .inner:hover .dot{background-color:#3fed2d}.kuaitiao .panel .group .box .inner .dot{flex:0 0 12px;height:12px;background-color:#999;margin-right:6px;border-radius:6px;transition:all .2s}.kuaitiao .panel .group .box .inner .text{flex:1 1 100%;word-break:keep-all;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#eee!important;text-decoration:none!important}.kuaitiao .foot{position:absolute;bottom:0;left:15px;right:15px;height:26px;border-top:1px solid #444;display:flex;justify-content:space-between;align-items:center}.kuaitiao .foot .left{flex:0 0 45%;font-size:12px;color:#666;cursor:pointer;transition:all .2s}.kuaitiao .foot .left:hover{color:#999}.kuaitiao .foot .right{flex:0 0 45%;display:flex;justify-content:flex-end;font-size:16px}.kuaitiao .foot .right .icon{cursor:pointer}.kuaitiao .foot .right .icon svg{transition:all .2s;fill:#666}.kuaitiao .foot .right .icon:hover svg{fill:#999}.kuaitiao .foot .center{flex:0 0 10%;display:flex;justify-content:center;align-items:center;font-size:24px}.kuaitiao .foot .center .icon{cursor:pointer}.kuaitiao .foot .center .icon .plus{fill:#ccc;transition:all .2s}.kuaitiao .foot .center .icon:hover .plus{fill:#fff}.kuaitiao .dialog.add{position:absolute;bottom:35px;width:200px;height:52px;border:2px solid #999;background-color:#fff;left:50%;margin-left:-100px;border-radius:6px;display:none}.kuaitiao .dialog.add.active{display:block}.kuaitiao .dialog.add .info{position:absolute;left:0;top:0;bottom:0;width:160px}.kuaitiao .dialog.add .info .input:first-of-type{border-bottom:1px solid #ccc}.kuaitiao .dialog.add .info input{height:24px;background-color:transparent;padding:0 6px}.kuaitiao .dialog.add .info input::placeholder{font-size:12px}.kuaitiao .dialog.add .send{position:absolute;right:0;top:0;bottom:0;width:40px;display:flex;justify-content:center;align-items:center;font-size:20px;cursor:pointer}.kuaitiao .dialog.add .send .gou{fill:#666;transition:all .2s}.kuaitiao .dialog.add .send:hover .gou{fill:#00b42a} "); (function () { 'use strict'; var __defProp = Object.defineProperty; var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value; var __publicField = (obj, key, value) => __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value); function noop() { } function run(fn) { return fn(); } function blank_object() { return /* @__PURE__ */ Object.create(null); } function run_all(fns) { fns.forEach(run); } function is_function(thing) { return typeof thing === "function"; } function safe_not_equal(a2, b) { return a2 != a2 ? b == b : a2 !== b || a2 && typeof a2 === "object" || typeof a2 === "function"; } function is_empty(obj) { return Object.keys(obj).length === 0; } function append(target, node) { target.appendChild(node); } function insert(target, node, anchor) { target.insertBefore(node, anchor || null); } function detach(node) { if (node.parentNode) { node.parentNode.removeChild(node); } } function element(name) { return document.createElement(name); } function text(data) { return document.createTextNode(data); } function space() { return text(" "); } function listen(node, event, handler, options) { node.addEventListener(event, handler, options); return () => node.removeEventListener(event, handler, options); } function attr(node, attribute, value) { if (value == null) node.removeAttribute(attribute); else if (node.getAttribute(attribute) !== value) node.setAttribute(attribute, value); } function children(element2) { return Array.from(element2.childNodes); } function set_data(text2, data) { data = "" + data; if (text2.data === data) return; text2.data = /** @type {string} */ data; } function set_input_value(input, value) { input.value = value == null ? "" : value; } function set_style(node, key, value, important) { { node.style.setProperty(key, value, ""); } } function toggle_class(element2, name, toggle) { element2.classList.toggle(name, !!toggle); } let current_component; function set_current_component(component) { current_component = component; } const dirty_components = []; const binding_callbacks = []; let render_callbacks = []; const flush_callbacks = []; const resolved_promise = /* @__PURE__ */ Promise.resolve(); let update_scheduled = false; function schedule_update() { if (!update_scheduled) { update_scheduled = true; resolved_promise.then(flush); } } function add_render_callback(fn) { render_callbacks.push(fn); } const seen_callbacks = /* @__PURE__ */ new Set(); let flushidx = 0; function flush() { if (flushidx !== 0) { return; } const saved_component = current_component; do { try { while (flushidx < dirty_components.length) { const component = dirty_components[flushidx]; flushidx++; set_current_component(component); update(component.$$); } } catch (e2) { dirty_components.length = 0; flushidx = 0; throw e2; } set_current_component(null); dirty_components.length = 0; flushidx = 0; while (binding_callbacks.length) binding_callbacks.pop()(); for (let i2 = 0; i2 < render_callbacks.length; i2 += 1) { const callback = render_callbacks[i2]; if (!seen_callbacks.has(callback)) { seen_callbacks.add(callback); callback(); } } render_callbacks.length = 0; } while (dirty_components.length); while (flush_callbacks.length) { flush_callbacks.pop()(); } update_scheduled = false; seen_callbacks.clear(); set_current_component(saved_component); } function update($$) { if ($$.fragment !== null) { $$.update(); run_all($$.before_update); const dirty = $$.dirty; $$.dirty = [-1]; $$.fragment && $$.fragment.p($$.ctx, dirty); $$.after_update.forEach(add_render_callback); } } function flush_render_callbacks(fns) { const filtered = []; const targets = []; render_callbacks.forEach((c) => fns.indexOf(c) === -1 ? filtered.push(c) : targets.push(c)); targets.forEach((c) => c()); render_callbacks = filtered; } const outroing = /* @__PURE__ */ new Set(); function transition_in(block, local) { if (block && block.i) { outroing.delete(block); block.i(local); } } function ensure_array_like(array_like_or_iterator) { return (array_like_or_iterator == null ? void 0 : array_like_or_iterator.length) !== void 0 ? array_like_or_iterator : Array.from(array_like_or_iterator); } function destroy_block(block, lookup) { block.d(1); lookup.delete(block.key); } function update_keyed_each(old_blocks, dirty, get_key, dynamic, ctx, list, lookup, node, destroy, create_each_block2, next, get_context) { let o2 = old_blocks.length; let n2 = list.length; let i2 = o2; const old_indexes = {}; while (i2--) old_indexes[old_blocks[i2].key] = i2; const new_blocks = []; const new_lookup = /* @__PURE__ */ new Map(); const deltas = /* @__PURE__ */ new Map(); const updates = []; i2 = n2; while (i2--) { const child_ctx = get_context(ctx, list, i2); const key = get_key(child_ctx); let block = lookup.get(key); if (!block) { block = create_each_block2(key, child_ctx); block.c(); } else { updates.push(() => block.p(child_ctx, dirty)); } new_lookup.set(key, new_blocks[i2] = block); if (key in old_indexes) deltas.set(key, Math.abs(i2 - old_indexes[key])); } const will_move = /* @__PURE__ */ new Set(); const did_move = /* @__PURE__ */ new Set(); function insert2(block) { transition_in(block, 1); block.m(node, next); lookup.set(block.key, block); next = block.first; n2--; } while (o2 && n2) { const new_block = new_blocks[n2 - 1]; const old_block = old_blocks[o2 - 1]; const new_key = new_block.key; const old_key = old_block.key; if (new_block === old_block) { next = new_block.first; o2--; n2--; } else if (!new_lookup.has(old_key)) { destroy(old_block, lookup); o2--; } else if (!lookup.has(new_key) || will_move.has(new_key)) { insert2(new_block); } else if (did_move.has(old_key)) { o2--; } else if (deltas.get(new_key) > deltas.get(old_key)) { did_move.add(new_key); insert2(new_block); } else { will_move.add(old_key); o2--; } } while (o2--) { const old_block = old_blocks[o2]; if (!new_lookup.has(old_block.key)) destroy(old_block, lookup); } while (n2) insert2(new_blocks[n2 - 1]); run_all(updates); return new_blocks; } function mount_component(component, target, anchor) { const { fragment, after_update } = component.$$; fragment && fragment.m(target, anchor); add_render_callback(() => { const new_on_destroy = component.$$.on_mount.map(run).filter(is_function); if (component.$$.on_destroy) { component.$$.on_destroy.push(...new_on_destroy); } else { run_all(new_on_destroy); } component.$$.on_mount = []; }); after_update.forEach(add_render_callback); } function destroy_component(component, detaching) { const $$ = component.$$; if ($$.fragment !== null) { flush_render_callbacks($$.after_update); run_all($$.on_destroy); $$.fragment && $$.fragment.d(detaching); $$.on_destroy = $$.fragment = null; $$.ctx = []; } } function make_dirty(component, i2) { if (component.$$.dirty[0] === -1) { dirty_components.push(component); schedule_update(); component.$$.dirty.fill(0); } component.$$.dirty[i2 / 31 | 0] |= 1 << i2 % 31; } function init(component, options, instance2, create_fragment2, not_equal, props, append_styles = null, dirty = [-1]) { const parent_component = current_component; set_current_component(component); const $$ = component.$$ = { fragment: null, ctx: [], // state props, update: noop, not_equal, bound: blank_object(), // lifecycle on_mount: [], on_destroy: [], on_disconnect: [], before_update: [], after_update: [], context: new Map(options.context || (parent_component ? parent_component.$$.context : [])), // everything else callbacks: blank_object(), dirty, skip_bound: false, root: options.target || parent_component.$$.root }; append_styles && append_styles($$.root); let ready = false; $$.ctx = instance2 ? instance2(component, options.props || {}, (i2, ret, ...rest) => { const value = rest.length ? rest[0] : ret; if ($$.ctx && not_equal($$.ctx[i2], $$.ctx[i2] = value)) { if (!$$.skip_bound && $$.bound[i2]) $$.bound[i2](value); if (ready) make_dirty(component, i2); } return ret; }) : []; $$.update(); ready = true; run_all($$.before_update); $$.fragment = create_fragment2 ? create_fragment2($$.ctx) : false; if (options.target) { if (options.hydrate) { const nodes = children(options.target); $$.fragment && $$.fragment.l(nodes); nodes.forEach(detach); } else { $$.fragment && $$.fragment.c(); } if (options.intro) transition_in(component.$$.fragment); mount_component(component, options.target, options.anchor); flush(); } set_current_component(parent_component); } class SvelteComponent { constructor() { /** * ### PRIVATE API * * Do not use, may change at any time * * @type {any} */ __publicField(this, "$$"); /** * ### PRIVATE API * * Do not use, may change at any time * * @type {any} */ __publicField(this, "$$set"); } /** @returns {void} */ $destroy() { destroy_component(this, 1); this.$destroy = noop; } /** * @template {Extract} K * @param {K} type * @param {((e: Events[K]) => void) | null | undefined} callback * @returns {() => void} */ $on(type, callback) { if (!is_function(callback)) { return noop; } const callbacks = this.$$.callbacks[type] || (this.$$.callbacks[type] = []); callbacks.push(callback); return () => { const index = callbacks.indexOf(callback); if (index !== -1) callbacks.splice(index, 1); }; } /** * @param {Partial} props * @returns {void} */ $set(props) { if (this.$$set && !is_empty(props)) { this.$$.skip_bound = true; this.$$set(props); this.$$.skip_bound = false; } } } const PUBLIC_VERSION = "4"; if (typeof window !== "undefined") (window.__svelte || (window.__svelte = { v: /* @__PURE__ */ new Set() })).v.add(PUBLIC_VERSION); var t = ["Shift", "Meta", "Alt", "Control"], e = "object" == typeof navigator ? navigator.platform : "", n = /Mac|iPod|iPhone|iPad/.test(e), r = n ? "Meta" : "Control", o = "Win32" === e ? ["Control", "Alt"] : n ? ["Alt"] : []; function i(t2, e2) { return "function" == typeof t2.getModifierState && (t2.getModifierState(e2) || o.includes(e2) && t2.getModifierState("AltGraph")); } function a(t2) { return t2.trim().split(" ").map(function(t3) { var e2 = t3.split(/\b\+/), n2 = e2.pop(); return [e2 = e2.map(function(t4) { return "$mod" === t4 ? r : t4; }), n2]; }); } function u(e2, n2) { var r2; void 0 === n2 && (n2 = {}); var o2 = null != (r2 = n2.timeout) ? r2 : 1e3, u2 = Object.keys(e2).map(function(t2) { return [a(t2), e2[t2]]; }), c = /* @__PURE__ */ new Map(), f = null; return function(e3) { e3 instanceof KeyboardEvent && (u2.forEach(function(n3) { var r3 = n3[0], o3 = n3[1], a2 = c.get(r3) || r3; !function(e4, n4) { return !(n4[1].toUpperCase() !== e4.key.toUpperCase() && n4[1] !== e4.code || n4[0].find(function(t2) { return !i(e4, t2); }) || t.find(function(t2) { return !n4[0].includes(t2) && n4[1] !== t2 && i(e4, t2); })); }(e3, a2[0]) ? i(e3, e3.key) || c.delete(r3) : a2.length > 1 ? c.set(r3, a2.slice(1)) : (c.delete(r3), o3(e3)); }), f && clearTimeout(f), f = setTimeout(c.clear.bind(c), o2)); }; } var _GM_deleteValue = /* @__PURE__ */ (() => typeof GM_deleteValue != "undefined" ? GM_deleteValue : void 0)(); var _GM_getValue = /* @__PURE__ */ (() => typeof GM_getValue != "undefined" ? GM_getValue : void 0)(); var _GM_listValues = /* @__PURE__ */ (() => typeof GM_listValues != "undefined" ? GM_listValues : void 0)(); var _GM_setValue = /* @__PURE__ */ (() => typeof GM_setValue != "undefined" ? GM_setValue : void 0)(); const logoSvg = ""; const addSvg = '\r\n \r\n'; const githubSvg = '\r\n \r\n'; const gouSvg = '\r\n \r\n'; const closeSvg = '\r\n \r\n'; const pointerSvg = '\r\n \r\n \r\n \r\n \r\n'; function get_each_context(ctx, list, i2) { const child_ctx = ctx.slice(); child_ctx[18] = list[i2]; child_ctx[20] = i2; return child_ctx; } function create_each_block(key_1, ctx) { let div5; let div4; let div0; let raw0_value = ( /*getSvgCode*/ ctx[5](pointerSvg) + "" ); let t0; let a2; let div1; let t1; let div2; let t2_value = ( /*item*/ ctx[18].name + "" ); let t2; let a_href_value; let t3; let div3; let raw1_value = ( /*getSvgCode*/ ctx[5](closeSvg) + "" ); let t4; let div5_data_key_value; let div5_data_index_value; let mounted; let dispose; return { key: key_1, first: null, c() { div5 = element("div"); div4 = element("div"); div0 = element("div"); t0 = space(); a2 = element("a"); div1 = element("div"); t1 = space(); div2 = element("div"); t2 = text(t2_value); t3 = space(); div3 = element("div"); t4 = space(); attr(div0, "class", "pointer"); attr(div1, "class", "dot"); attr(div2, "class", "text"); attr(a2, "class", "link"); attr(a2, "target", "_blank"); attr(a2, "href", a_href_value = /*item*/ ctx[18].link); attr(div3, "class", "close"); attr(div3, "aria-hidden", "true"); attr(div4, "class", "inner"); attr(div5, "class", "box"); attr(div5, "data-key", div5_data_key_value = /*item*/ ctx[18].key); attr(div5, "data-index", div5_data_index_value = /*index*/ ctx[20]); attr(div5, "draggable", "true"); this.first = div5; }, m(target, anchor) { insert(target, div5, anchor); append(div5, div4); append(div4, div0); div0.innerHTML = raw0_value; append(div4, t0); append(div4, a2); append(a2, div1); append(a2, t1); append(a2, div2); append(div2, t2); append(div4, t3); append(div4, div3); div3.innerHTML = raw1_value; append(div5, t4); if (!mounted) { dispose = [ listen( a2, "click", /*click_handler*/ ctx[8] ), listen(div3, "click", function() { if (is_function( /*fnDelSite*/ ctx[7]( /*item*/ ctx[18].key ) )) ctx[7]( /*item*/ ctx[18].key ).apply(this, arguments); }) ]; mounted = true; } }, p(new_ctx, dirty) { ctx = new_ctx; if (dirty & /*sitesGrid*/ 16 && t2_value !== (t2_value = /*item*/ ctx[18].name + "")) set_data(t2, t2_value); if (dirty & /*sitesGrid*/ 16 && a_href_value !== (a_href_value = /*item*/ ctx[18].link)) { attr(a2, "href", a_href_value); } if (dirty & /*sitesGrid*/ 16 && div5_data_key_value !== (div5_data_key_value = /*item*/ ctx[18].key)) { attr(div5, "data-key", div5_data_key_value); } if (dirty & /*sitesGrid*/ 16 && div5_data_index_value !== (div5_data_index_value = /*index*/ ctx[20])) { attr(div5, "data-index", div5_data_index_value); } }, d(detaching) { if (detaching) { detach(div5); } mounted = false; run_all(dispose); } }; } function create_fragment(ctx) { let div14; let div0; let t0; let div3; let div2; let div1; let each_blocks = []; let each_1_lookup = /* @__PURE__ */ new Map(); let t1; let div8; let div4; let t3; let div6; let div5; let raw0_value = ( /*getSvgCode*/ ctx[5](addSvg) + "" ); let t4; let div7; let a1; let raw1_value = ( /*getSvgCode*/ ctx[5](githubSvg) + "" ); let t5; let div13; let div11; let div9; let input0; let t6; let div10; let input1; let t7; let div12; let raw2_value = ( /*getSvgCode*/ ctx[5](gouSvg) + "" ); let mounted; let dispose; let each_value = ensure_array_like( /*sitesGrid*/ ctx[4] ); const get_key = (ctx2) => ( /*item*/ ctx2[18].key ); for (let i2 = 0; i2 < each_value.length; i2 += 1) { let child_ctx = get_each_context(ctx, each_value, i2); let key = get_key(child_ctx); each_1_lookup.set(key, each_blocks[i2] = create_each_block(key, child_ctx)); } return { c() { div14 = element("div"); div0 = element("div"); t0 = space(); div3 = element("div"); div2 = element("div"); div1 = element("div"); for (let i2 = 0; i2 < each_blocks.length; i2 += 1) { each_blocks[i2].c(); } t1 = space(); div8 = element("div"); div4 = element("div"); div4.innerHTML = `作者:陈随易`; t3 = space(); div6 = element("div"); div5 = element("div"); t4 = space(); div7 = element("div"); a1 = element("a"); t5 = space(); div13 = element("div"); div11 = element("div"); div9 = element("div"); input0 = element("input"); t6 = space(); div10 = element("div"); input1 = element("input"); t7 = space(); div12 = element("div"); attr(div0, "class", "logo"); set_style(div0, "background-image", "url('" + logoSvg + "')"); attr(div1, "class", "grid"); attr(div1, "id", "grid"); attr(div2, "class", "group"); attr(div3, "class", "panel"); attr(div4, "class", "left"); attr(div5, "class", "icon add-site"); attr(div5, "aria-hidden", "true"); attr(div6, "class", "center"); attr(a1, "class", "icon"); attr(a1, "target", "_blank"); attr(a1, "href", "https://github.com/chenbimo/kangaroo-jump"); attr(div7, "class", "right"); attr(div8, "class", "foot"); attr(input0, "placeholder", "请输入名称"); attr(div9, "class", "input"); attr(input1, "placeholder", "请输入网址"); attr(div10, "class", "input"); attr(div11, "class", "info"); attr(div12, "class", "send"); attr(div12, "aria-hidden", "true"); attr(div13, "class", "dialog add"); toggle_class( div13, "active", /*isActiveAddDialog*/ ctx[1] ); attr(div14, "class", "kuaitiao"); toggle_class( div14, "active", /*isActiveKuaiTiao*/ ctx[0] ); }, m(target, anchor) { insert(target, div14, anchor); append(div14, div0); append(div14, t0); append(div14, div3); append(div3, div2); append(div2, div1); for (let i2 = 0; i2 < each_blocks.length; i2 += 1) { if (each_blocks[i2]) { each_blocks[i2].m(div1, null); } } append(div14, t1); append(div14, div8); append(div8, div4); append(div8, t3); append(div8, div6); append(div6, div5); div5.innerHTML = raw0_value; append(div8, t4); append(div8, div7); append(div7, a1); a1.innerHTML = raw1_value; append(div14, t5); append(div14, div13); append(div13, div11); append(div11, div9); append(div9, input0); set_input_value( input0, /*siteName*/ ctx[2] ); append(div11, t6); append(div11, div10); append(div10, input1); set_input_value( input1, /*siteLink*/ ctx[3] ); append(div13, t7); append(div13, div12); div12.innerHTML = raw2_value; if (!mounted) { dispose = [ listen( div5, "click", /*click_handler_1*/ ctx[9] ), listen( input0, "input", /*input0_input_handler*/ ctx[10] ), listen( input1, "input", /*input1_input_handler*/ ctx[11] ), listen( div12, "click", /*fnAddSite*/ ctx[6] ) ]; mounted = true; } }, p(ctx2, [dirty]) { if (dirty & /*sitesGrid, fnDelSite, getSvgCode, isActiveKuaiTiao*/ 177) { each_value = ensure_array_like( /*sitesGrid*/ ctx2[4] ); each_blocks = update_keyed_each(each_blocks, dirty, get_key, 1, ctx2, each_value, each_1_lookup, div1, destroy_block, create_each_block, null, get_each_context); } if (dirty & /*siteName*/ 4 && input0.value !== /*siteName*/ ctx2[2]) { set_input_value( input0, /*siteName*/ ctx2[2] ); } if (dirty & /*siteLink*/ 8 && input1.value !== /*siteLink*/ ctx2[3]) { set_input_value( input1, /*siteLink*/ ctx2[3] ); } if (dirty & /*isActiveAddDialog*/ 2) { toggle_class( div13, "active", /*isActiveAddDialog*/ ctx2[1] ); } if (dirty & /*isActiveKuaiTiao*/ 1) { toggle_class( div14, "active", /*isActiveKuaiTiao*/ ctx2[0] ); } }, i: noop, o: noop, d(detaching) { if (detaching) { detach(div14); } for (let i2 = 0; i2 < each_blocks.length; i2 += 1) { each_blocks[i2].d(); } mounted = false; run_all(dispose); } }; } function instance($$self, $$props, $$invalidate) { const generateRandomString = (length) => { let result = ""; let characters = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789"; let charactersLength = characters.length; for (var i2 = 0; i2 < length; i2++) { result += characters.charAt(Math.floor(Math.random() * charactersLength)); } return result; }; let isActiveKuaiTiao = false; let isActiveAddDialog = false; let siteName = ""; let siteLink = ""; let sitesGrid = []; let sitesMap = {}; let dragoverTime = 0; const handlerKeydown = u({ "Control+q": () => { $$invalidate(0, isActiveKuaiTiao = !isActiveKuaiTiao); } }); window.addEventListener("keydown", handlerKeydown); const getSvgCode = (data) => { return decodeURIComponent(data).replace(/https?\:\/\/.+\/assets\//, ""); }; const renderSiteGrids = () => { $$invalidate(4, sitesGrid = _GM_listValues().map((key, index) => { const group = _GM_getValue(key); const data = { name: group.name, link: group.link, key: group.key }; sitesMap[key] = data; return data; })); }; const fnAddSite = () => { if (sitesGrid.length < 100) { const siteKey = generateRandomString(10); _GM_setValue(siteKey, { name: siteName, link: siteLink, key: siteKey }); $$invalidate(2, siteName = ""); $$invalidate(3, siteLink = ""); $$invalidate(1, isActiveAddDialog = false); renderSiteGrids(); } else { alert("常用导航熟练不能超过100个"); } }; const fnDelSite = (siteKey) => { _GM_deleteValue(siteKey); renderSiteGrids(); }; let draggedElement = null; document.addEventListener("click", function(e2) { const kuaitiaoElement = e2.target.closest(".kuaitiao"); if (!kuaitiaoElement) { $$invalidate(0, isActiveKuaiTiao = false); } }); document.addEventListener("dragstart", function(e2) { draggedElement = e2.target.closest(".box"); }); document.addEventListener("dragover", function(e2) { e2.preventDefault(); const nowMs = Date.now(); if (nowMs - dragoverTime > 100) { dragoverTime = nowMs; document.querySelectorAll(".box .inner").forEach((el) => { el.closest(".inner").classList.remove("move"); }); const boxInnerEl = e2.target.closest(".inner"); if (boxInnerEl) { boxInnerEl.classList.add("move"); } } }); document.addEventListener("drop", function(e2) { e2.preventDefault(); const boxEl = e2.target.closest(".box"); if (boxEl) { document.querySelectorAll(".box .inner").forEach((el) => { el.closest(".inner").classList.remove("move"); }); const siteKeyOld = draggedElement.dataset.key; const siteKeyNew = boxEl.dataset.key; if (siteKeyOld === siteKeyNew) return; const siteIndexOld = Number(draggedElement.dataset.index); const siteIndexNew = Number(boxEl.dataset.index); const siteItemOld = sitesMap[siteKeyOld]; const siteItemNew = sitesMap[siteKeyNew]; const sitesGrid2 = []; for (let item of sitesGrid) { if (item.key !== siteKeyOld) { if (siteIndexOld > siteIndexNew) { if (item.key !== siteKeyNew) { sitesGrid2.push(item); } else { sitesGrid2.push(siteItemOld); sitesGrid2.push(siteItemNew); } } else { if (item.key !== siteKeyOld) { sitesGrid2.push(item); if (item.key === siteKeyNew) { sitesGrid2.push(siteItemOld); } } } } } sitesGrid2.map((item) => { _GM_deleteValue(item.key); }); sitesGrid2.map((item) => { _GM_setValue(item.key, item); }); $$invalidate(4, sitesGrid = sitesGrid2); } }); renderSiteGrids(); const click_handler = () => $$invalidate(0, isActiveKuaiTiao = false); const click_handler_1 = () => $$invalidate(1, isActiveAddDialog = !isActiveAddDialog); function input0_input_handler() { siteName = this.value; $$invalidate(2, siteName); } function input1_input_handler() { siteLink = this.value; $$invalidate(3, siteLink); } return [ isActiveKuaiTiao, isActiveAddDialog, siteName, siteLink, sitesGrid, getSvgCode, fnAddSite, fnDelSite, click_handler, click_handler_1, input0_input_handler, input1_input_handler ]; } class App extends SvelteComponent { constructor(options) { super(); init(this, options, instance, create_fragment, safe_not_equal, {}); } } new App({ target: (() => { const app = document.createElement("div"); document.body.append(app); return app; })() }); })();