// ==UserScript== // @name 多语言划词翻译 // @description 支持英、法、日、韩、泰、越、他加禄语和印尼语,部分语言的翻译结果为英语 // @version 2.6.0 // @match *://*/* // @allFrames true // @grant GM_xmlhttpRequest // @run-at document-end // @license MIT // @namespace KiohPun // @downloadURL https://update.greasyfork.icu/scripts/373345/%E5%A4%9A%E8%AF%AD%E8%A8%80%E5%88%92%E8%AF%8D%E7%BF%BB%E8%AF%91.user.js // @updateURL https://update.greasyfork.icu/scripts/373345/%E5%A4%9A%E8%AF%AD%E8%A8%80%E5%88%92%E8%AF%8D%E7%BF%BB%E8%AF%91.meta.js // ==/UserScript== (function () { 'use strict'; function noop() { } function is_promise(value) { return value && typeof value === 'object' && typeof value.then === 'function'; } function run(fn) { return fn(); } function blank_object() { return Object.create(null); } function run_all(fns) { fns.forEach(run); } function is_function(thing) { return typeof thing === 'function'; } function safe_not_equal(a, b) { return a != a ? b == b : a !== b || ((a && typeof a === 'object') || typeof a === 'function'); } let src_url_equal_anchor; function src_url_equal(element_src, url) { if (!src_url_equal_anchor) { src_url_equal_anchor = document.createElement('a'); } src_url_equal_anchor.href = url; return element_src === src_url_equal_anchor.href; } function is_empty(obj) { return Object.keys(obj).length === 0; } function append(target, node) { target.appendChild(node); } function append_styles(target, style_sheet_id, styles) { const append_styles_to = get_root_for_style(target); if (!append_styles_to.getElementById(style_sheet_id)) { const style = element('style'); style.id = style_sheet_id; style.textContent = styles; append_stylesheet(append_styles_to, style); } } function get_root_for_style(node) { if (!node) return document; const root = node.getRootNode ? node.getRootNode() : node.ownerDocument; if (root && root.host) { return root; } return node.ownerDocument; } function append_stylesheet(node, style) { append(node.head || node, style); } function insert(target, node, anchor) { target.insertBefore(node, anchor || null); } function detach(node) { node.parentNode.removeChild(node); } function destroy_each(iterations, detaching) { for (let i = 0; i < iterations.length; i += 1) { if (iterations[i]) iterations[i].d(detaching); } } function element(name) { return document.createElement(name); } function svg_element(name) { return document.createElementNS('http://www.w3.org/2000/svg', name); } function text(data) { return document.createTextNode(data); } function space() { return text(' '); } function empty() { return text(''); } function listen(node, event, handler, options) { node.addEventListener(event, handler, options); return () => node.removeEventListener(event, handler, options); } function stop_propagation(fn) { return function (event) { event.stopPropagation(); // @ts-ignore return fn.call(this, event); }; } function attr(node, attribute, value) { if (value == null) node.removeAttribute(attribute); else if (node.getAttribute(attribute) !== value) node.setAttribute(attribute, value); } function children(element) { return Array.from(element.childNodes); } function set_data(text, data) { data = '' + data; if (text.wholeText !== data) text.data = data; } function toggle_class(element, name, toggle) { element.classList[toggle ? 'add' : 'remove'](name); } class HtmlTag { constructor() { this.e = this.n = null; } c(html) { this.h(html); } m(html, target, anchor = null) { if (!this.e) { this.e = element(target.nodeName); this.t = target; this.c(html); } this.i(anchor); } h(html) { this.e.innerHTML = html; this.n = Array.from(this.e.childNodes); } i(anchor) { for (let i = 0; i < this.n.length; i += 1) { insert(this.t, this.n[i], anchor); } } p(html) { this.d(); this.h(html); this.i(this.a); } d() { this.n.forEach(detach); } } let current_component; function set_current_component(component) { current_component = component; } function get_current_component() { if (!current_component) throw new Error('Function called outside component initialization'); return current_component; } // TODO figure out if we still want to support // shorthand events, or if we want to implement // a real bubbling mechanism function bubble(component, event) { const callbacks = component.$$.callbacks[event.type]; if (callbacks) { // @ts-ignore callbacks.slice().forEach(fn => fn.call(this, event)); } } const dirty_components = []; const binding_callbacks = []; const render_callbacks = []; const flush_callbacks = []; const resolved_promise = 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); } // flush() calls callbacks in this order: // 1. All beforeUpdate callbacks, in order: parents before children // 2. All bind:this callbacks, in reverse order: children before parents. // 3. All afterUpdate callbacks, in order: parents before children. EXCEPT // for afterUpdates called during the initial onMount, which are called in // reverse order: children before parents. // Since callbacks might update component values, which could trigger another // call to flush(), the following steps guard against this: // 1. During beforeUpdate, any updated components will be added to the // dirty_components array and will cause a reentrant call to flush(). Because // the flush index is kept outside the function, the reentrant call will pick // up where the earlier call left off and go through all dirty components. The // current_component value is saved and restored so that the reentrant call will // not interfere with the "parent" flush() call. // 2. bind:this callbacks cannot trigger new flush() calls. // 3. During afterUpdate, any updated components will NOT have their afterUpdate // callback called a second time; the seen_callbacks set, outside the flush() // function, guarantees this behavior. const seen_callbacks = new Set(); let flushidx = 0; // Do *not* move this inside the flush() function function flush() { const saved_component = current_component; do { // first, call beforeUpdate functions // and update components while (flushidx < dirty_components.length) { const component = dirty_components[flushidx]; flushidx++; set_current_component(component); update(component.$$); } set_current_component(null); dirty_components.length = 0; flushidx = 0; while (binding_callbacks.length) binding_callbacks.pop()(); // then, once components are updated, call // afterUpdate functions. This may cause // subsequent updates... for (let i = 0; i < render_callbacks.length; i += 1) { const callback = render_callbacks[i]; if (!seen_callbacks.has(callback)) { // ...so guard against infinite loops 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); } } const outroing = new Set(); let outros; function group_outros() { outros = { r: 0, c: [], p: outros // parent group }; } function check_outros() { if (!outros.r) { run_all(outros.c); } outros = outros.p; } function transition_in(block, local) { if (block && block.i) { outroing.delete(block); block.i(local); } } function transition_out(block, local, detach, callback) { if (block && block.o) { if (outroing.has(block)) return; outroing.add(block); outros.c.push(() => { outroing.delete(block); if (callback) { if (detach) block.d(1); callback(); } }); block.o(local); } } function handle_promise(promise, info) { const token = info.token = {}; function update(type, index, key, value) { if (info.token !== token) return; info.resolved = value; let child_ctx = info.ctx; if (key !== undefined) { child_ctx = child_ctx.slice(); child_ctx[key] = value; } const block = type && (info.current = type)(child_ctx); let needs_flush = false; if (info.block) { if (info.blocks) { info.blocks.forEach((block, i) => { if (i !== index && block) { group_outros(); transition_out(block, 1, 1, () => { if (info.blocks[i] === block) { info.blocks[i] = null; } }); check_outros(); } }); } else { info.block.d(1); } block.c(); transition_in(block, 1); block.m(info.mount(), info.anchor); needs_flush = true; } info.block = block; if (info.blocks) info.blocks[index] = block; if (needs_flush) { flush(); } } if (is_promise(promise)) { const current_component = get_current_component(); promise.then(value => { set_current_component(current_component); update(info.then, 1, info.value, value); set_current_component(null); }, error => { set_current_component(current_component); update(info.catch, 2, info.error, error); set_current_component(null); if (!info.hasCatch) { throw error; } }); // if we previously had a then/catch block, destroy it if (info.current !== info.pending) { update(info.pending, 0); return true; } } else { if (info.current !== info.then) { update(info.then, 1, info.value, promise); return true; } info.resolved = promise; } } function update_await_block_branch(info, ctx, dirty) { const child_ctx = ctx.slice(); const { resolved } = info; if (info.current === info.then) { child_ctx[info.value] = resolved; } if (info.current === info.catch) { child_ctx[info.error] = resolved; } info.block.p(child_ctx, dirty); } function create_component(block) { block && block.c(); } function mount_component(component, target, anchor, customElement) { const { fragment, on_mount, on_destroy, after_update } = component.$$; fragment && fragment.m(target, anchor); if (!customElement) { // onMount happens before the initial afterUpdate add_render_callback(() => { const new_on_destroy = on_mount.map(run).filter(is_function); if (on_destroy) { on_destroy.push(...new_on_destroy); } else { // Edge case - component was destroyed immediately, // most likely as a result of a binding initialising run_all(new_on_destroy); } component.$$.on_mount = []; }); } after_update.forEach(add_render_callback); } function destroy_component(component, detaching) { const $$ = component.$$; if ($$.fragment !== null) { run_all($$.on_destroy); $$.fragment && $$.fragment.d(detaching); // TODO null out other refs, including component.$$ (but need to // preserve final state?) $$.on_destroy = $$.fragment = null; $$.ctx = []; } } function make_dirty(component, i) { if (component.$$.dirty[0] === -1) { dirty_components.push(component); schedule_update(); component.$$.dirty.fill(0); } component.$$.dirty[(i / 31) | 0] |= (1 << (i % 31)); } function init(component, options, instance, create_fragment, not_equal, props, append_styles, dirty = [-1]) { const parent_component = current_component; set_current_component(component); const $$ = component.$$ = { fragment: null, ctx: null, // 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 = instance ? instance(component, options.props || {}, (i, ret, ...rest) => { const value = rest.length ? rest[0] : ret; if ($$.ctx && not_equal($$.ctx[i], $$.ctx[i] = value)) { if (!$$.skip_bound && $$.bound[i]) $$.bound[i](value); if (ready) make_dirty(component, i); } return ret; }) : []; $$.update(); ready = true; run_all($$.before_update); // `false` as a special case of no DOM component $$.fragment = create_fragment ? create_fragment($$.ctx) : false; if (options.target) { if (options.hydrate) { const nodes = children(options.target); // eslint-disable-next-line @typescript-eslint/no-non-null-assertion $$.fragment && $$.fragment.l(nodes); nodes.forEach(detach); } else { // eslint-disable-next-line @typescript-eslint/no-non-null-assertion $$.fragment && $$.fragment.c(); } if (options.intro) transition_in(component.$$.fragment); mount_component(component, options.target, options.anchor, options.customElement); flush(); } set_current_component(parent_component); } /** * Base class for Svelte components. Used when dev=false. */ class SvelteComponent { $destroy() { destroy_component(this, 1); this.$destroy = noop; } $on(type, callback) { const callbacks = (this.$$.callbacks[type] || (this.$$.callbacks[type] = [])); callbacks.push(callback); return () => { const index = callbacks.indexOf(callback); if (index !== -1) callbacks.splice(index, 1); }; } $set($$props) { if (this.$$set && !is_empty($$props)) { this.$$.skip_bound = true; this.$$set($$props); this.$$.skip_bound = false; } } } const getYoudaoApi = (le, dict) => (`http://dict.youdao.com/jsonapi?le=${le}&dicts=${encodeURIComponent(`{"count": 1, dicts: [["${dict}"]]}`)}&jsonversion=2&q=`); const getYoudaoVoice = (audio) => `https://dict.youdao.com/dictvoice?audio=${audio}`; function get(url, responseType) { return new Promise((resolve, reject) => { GM_xmlhttpRequest({ method: 'GET', url, responseType, onload: (res) => resolve(res.response), onerror: reject, }); }); } function setPosition(el, rect) { const { innerWidth, innerHeight } = window; let left = rect.right; let top = rect.bottom; const { clientWidth, clientHeight } = el; if (left + clientWidth > innerWidth) { left -= clientWidth; } if (top + clientHeight > innerHeight) { top -= clientHeight; } if (left < 0) { left = 0; } if (top < 0) { top = 0; } /* eslint-disable no-param-reassign */ el.style.left = `${left}px`; el.style.top = `${top}px`; } /* src/components/ResultEntry.svelte generated by Svelte v3.46.4 */ function add_css$2(target) { append_styles(target, "svelte-i1rcat", ".info.svelte-i1rcat{display:flex;align-items:baseline;margin:0.5em 0}.word.svelte-i1rcat{margin:0}.phonetic.svelte-i1rcat{margin-left:0.5em;color:#a2a5a6}.sound.svelte-i1rcat{all:unset;align-self:center;width:1.5em;height:1.5em;padding:0.1em;margin-left:auto;color:var(--main-color);cursor:pointer}.sound.svelte-i1rcat:disabled{opacity:0.3}.meanings.svelte-i1rcat{all:unset;display:block}.meaning.svelte-i1rcat{list-style:none;margin:0.4em 0}.meaning-type.svelte-i1rcat{margin-right:0.5em;color:var(--main-color);font-weight:500}.meaning-content.svelte-i1rcat{all:unset;display:block}.en .meaning-type.svelte-i1rcat,.fr .meaning-type.svelte-i1rcat,.th .meaning-type.svelte-i1rcat{float:left}"); } function get_each_context$2(ctx, list, i) { const child_ctx = ctx.slice(); child_ctx[4] = list[i]; return child_ctx; } function get_each_context_1$1(ctx, list, i) { const child_ctx = ctx.slice(); child_ctx[7] = list[i]; return child_ctx; } // (22:2) {#if entry.word} function create_if_block_1$1(ctx) { let div; let h2; let raw_value = /*entry*/ ctx[0].word + ""; let t0; let t1; let if_block0 = /*entry*/ ctx[0].phonetic && create_if_block_3(ctx); let if_block1 = /*entry*/ ctx[0].sound && create_if_block_2(ctx); return { c() { div = element("div"); h2 = element("h2"); t0 = space(); if (if_block0) if_block0.c(); t1 = space(); if (if_block1) if_block1.c(); attr(h2, "class", "word svelte-i1rcat"); attr(div, "class", "info svelte-i1rcat"); }, m(target, anchor) { insert(target, div, anchor); append(div, h2); h2.innerHTML = raw_value; append(div, t0); if (if_block0) if_block0.m(div, null); append(div, t1); if (if_block1) if_block1.m(div, null); }, p(ctx, dirty) { if (dirty & /*entry*/ 1 && raw_value !== (raw_value = /*entry*/ ctx[0].word + "")) h2.innerHTML = raw_value; if (/*entry*/ ctx[0].phonetic) { if (if_block0) { if_block0.p(ctx, dirty); } else { if_block0 = create_if_block_3(ctx); if_block0.c(); if_block0.m(div, t1); } } else if (if_block0) { if_block0.d(1); if_block0 = null; } if (/*entry*/ ctx[0].sound) { if (if_block1) { if_block1.p(ctx, dirty); } else { if_block1 = create_if_block_2(ctx); if_block1.c(); if_block1.m(div, null); } } else if (if_block1) { if_block1.d(1); if_block1 = null; } }, d(detaching) { if (detaching) detach(div); if (if_block0) if_block0.d(); if (if_block1) if_block1.d(); } }; } // (25:6) {#if entry.phonetic} function create_if_block_3(ctx) { let span; let t0; let html_tag; let raw_value = /*entry*/ ctx[0].phonetic + ""; let t1; return { c() { span = element("span"); t0 = text("["); html_tag = new HtmlTag(); t1 = text("]"); html_tag.a = t1; attr(span, "class", "phonetic svelte-i1rcat"); }, m(target, anchor) { insert(target, span, anchor); append(span, t0); html_tag.m(raw_value, span); append(span, t1); }, p(ctx, dirty) { if (dirty & /*entry*/ 1 && raw_value !== (raw_value = /*entry*/ ctx[0].phonetic + "")) html_tag.p(raw_value); }, d(detaching) { if (detaching) detach(span); } }; } // (28:6) {#if entry.sound} function create_if_block_2(ctx) { let button; let svg; let path; let mounted; let dispose; return { c() { button = element("button"); svg = svg_element("svg"); path = svg_element("path"); attr(path, "stroke-linecap", "round"); attr(path, "stroke-linejoin", "round"); attr(path, "d", "M15.536 8.464a5 5 0 010 7.072m2.828-9.9a9 9 0 010 12.728M5.586 15H4a1 1 0 01-1-1v-4a1 1 0 011-1h1.586l4.707-4.707C10.923 3.663 12 4.109 12 5v14c0 .891-1.077 1.337-1.707.707L5.586 15z"); attr(svg, "xmlns", "http://www.w3.org/2000/svg"); attr(svg, "fill", "none"); attr(svg, "viewBox", "0 0 24 24"); attr(svg, "stroke", "currentColor"); attr(svg, "stroke-width", "2"); attr(button, "class", "sound svelte-i1rcat"); attr(button, "aria-label", "播放"); button.disabled = /*isPlaying*/ ctx[1]; }, m(target, anchor) { insert(target, button, anchor); append(button, svg); append(svg, path); if (!mounted) { dispose = listen(button, "click", /*play*/ ctx[2]); mounted = true; } }, p(ctx, dirty) { if (dirty & /*isPlaying*/ 2) { button.disabled = /*isPlaying*/ ctx[1]; } }, d(detaching) { if (detaching) detach(button); mounted = false; dispose(); } }; } // (46:8) {#if meaning.type} function create_if_block$2(ctx) { let div; let t_value = /*meaning*/ ctx[4].type + ""; let t; return { c() { div = element("div"); t = text(t_value); attr(div, "class", "meaning-type svelte-i1rcat"); }, m(target, anchor) { insert(target, div, anchor); append(div, t); }, p(ctx, dirty) { if (dirty & /*entry*/ 1 && t_value !== (t_value = /*meaning*/ ctx[4].type + "")) set_data(t, t_value); }, d(detaching) { if (detaching) detach(div); } }; } // (50:10) {#each meaning.items as item} function create_each_block_1$1(ctx) { let li; let raw_value = /*item*/ ctx[7] + ""; return { c() { li = element("li"); }, m(target, anchor) { insert(target, li, anchor); li.innerHTML = raw_value; }, p(ctx, dirty) { if (dirty & /*entry*/ 1 && raw_value !== (raw_value = /*item*/ ctx[7] + "")) li.innerHTML = raw_value; }, d(detaching) { if (detaching) detach(li); } }; } // (44:4) {#each entry.meanings as meaning} function create_each_block$2(ctx) { let li; let t0; let ol; let t1; let if_block = /*meaning*/ ctx[4].type && create_if_block$2(ctx); let each_value_1 = /*meaning*/ ctx[4].items; let each_blocks = []; for (let i = 0; i < each_value_1.length; i += 1) { each_blocks[i] = create_each_block_1$1(get_each_context_1$1(ctx, each_value_1, i)); } return { c() { li = element("li"); if (if_block) if_block.c(); t0 = space(); ol = element("ol"); for (let i = 0; i < each_blocks.length; i += 1) { each_blocks[i].c(); } t1 = space(); attr(ol, "class", "meaning-content svelte-i1rcat"); attr(li, "class", "meaning svelte-i1rcat"); }, m(target, anchor) { insert(target, li, anchor); if (if_block) if_block.m(li, null); append(li, t0); append(li, ol); for (let i = 0; i < each_blocks.length; i += 1) { each_blocks[i].m(ol, null); } append(li, t1); }, p(ctx, dirty) { if (/*meaning*/ ctx[4].type) { if (if_block) { if_block.p(ctx, dirty); } else { if_block = create_if_block$2(ctx); if_block.c(); if_block.m(li, t0); } } else if (if_block) { if_block.d(1); if_block = null; } if (dirty & /*entry*/ 1) { each_value_1 = /*meaning*/ ctx[4].items; let i; for (i = 0; i < each_value_1.length; i += 1) { const child_ctx = get_each_context_1$1(ctx, each_value_1, i); if (each_blocks[i]) { each_blocks[i].p(child_ctx, dirty); } else { each_blocks[i] = create_each_block_1$1(child_ctx); each_blocks[i].c(); each_blocks[i].m(ol, null); } } for (; i < each_blocks.length; i += 1) { each_blocks[i].d(1); } each_blocks.length = each_value_1.length; } }, d(detaching) { if (detaching) detach(li); if (if_block) if_block.d(); destroy_each(each_blocks, detaching); } }; } function create_fragment$2(ctx) { let div; let t; let ul; let if_block = /*entry*/ ctx[0].word && create_if_block_1$1(ctx); let each_value = /*entry*/ ctx[0].meanings; let each_blocks = []; for (let i = 0; i < each_value.length; i += 1) { each_blocks[i] = create_each_block$2(get_each_context$2(ctx, each_value, i)); } return { c() { div = element("div"); if (if_block) if_block.c(); t = space(); ul = element("ul"); for (let i = 0; i < each_blocks.length; i += 1) { each_blocks[i].c(); } attr(ul, "class", "meanings svelte-i1rcat"); attr(div, "class", "entry"); }, m(target, anchor) { insert(target, div, anchor); if (if_block) if_block.m(div, null); append(div, t); append(div, ul); for (let i = 0; i < each_blocks.length; i += 1) { each_blocks[i].m(ul, null); } }, p(ctx, [dirty]) { if (/*entry*/ ctx[0].word) { if (if_block) { if_block.p(ctx, dirty); } else { if_block = create_if_block_1$1(ctx); if_block.c(); if_block.m(div, t); } } else if (if_block) { if_block.d(1); if_block = null; } if (dirty & /*entry*/ 1) { each_value = /*entry*/ ctx[0].meanings; let i; for (i = 0; i < each_value.length; i += 1) { const child_ctx = get_each_context$2(ctx, each_value, i); if (each_blocks[i]) { each_blocks[i].p(child_ctx, dirty); } else { each_blocks[i] = create_each_block$2(child_ctx); each_blocks[i].c(); each_blocks[i].m(ul, null); } } for (; i < each_blocks.length; i += 1) { each_blocks[i].d(1); } each_blocks.length = each_value.length; } }, i: noop, o: noop, d(detaching) { if (detaching) detach(div); if (if_block) if_block.d(); destroy_each(each_blocks, detaching); } }; } function instance$2($$self, $$props, $$invalidate) { let { entry } = $$props; let isPlaying = false; const audio = new Audio(); audio.addEventListener('ended', () => { $$invalidate(1, isPlaying = false); }); async function play() { $$invalidate(1, isPlaying = true); if (audio.src) { audio.play(); return; } const res = await get(entry.sound, 'blob'); const blob = res.slice(0, res.size, 'audio/mpeg'); audio.src = URL.createObjectURL(blob); audio.play(); } $$self.$$set = $$props => { if ('entry' in $$props) $$invalidate(0, entry = $$props.entry); }; return [entry, isPlaying, play]; } class ResultEntry extends SvelteComponent { constructor(options) { super(); init(this, options, instance$2, create_fragment$2, safe_not_equal, { entry: 0 }, add_css$2); } } /* src/components/LangSection.svelte generated by Svelte v3.46.4 */ function add_css$1(target) { append_styles(target, "svelte-u1xzce", ".content.svelte-u1xzce.svelte-u1xzce{flex:auto;padding:0 1em;overflow:auto;overscroll-behavior:contain;scrollbar-width:thin;scrollbar-gutter:stable;background:linear-gradient(#fff 33%, rgba(255,255,255, 0)),\n linear-gradient(rgba(255,255,255, 0), #fff 66%) 0 100%,\n radial-gradient(farthest-side at 50% 0, rgba(200,200,200, 0.5), rgba(0,0,0,0)),\n radial-gradient(farthest-side at 50% 100%, rgba(200,200,200, 0.5), rgba(0,0,0,0)) 0 100%;background-color:#fff;background-repeat:no-repeat;background-attachment:local, local, scroll, scroll;background-size:100% 12px, 100% 12px, 100% 4px, 100% 4px}.content.svelte-u1xzce a.svelte-u1xzce{color:var(--main-color)}.content.svelte-u1xzce.svelte-u1xzce:has(> .tip, > .loading){display:flex;justify-content:center;align-items:center}.tip.svelte-u1xzce.svelte-u1xzce{display:flex;flex-direction:column;justify-content:center;align-items:center;gap:1em;width:100%;color:#666}.tip.svelte-u1xzce p.svelte-u1xzce{margin:0}.alternatives.svelte-u1xzce.svelte-u1xzce{display:flex;gap:0.4em}.alternatives.svelte-u1xzce a.svelte-u1xzce{padding:0.5em;border-radius:3px;background-color:#eee}.alternatives.svelte-u1xzce img.svelte-u1xzce{display:block}.loading.svelte-u1xzce.svelte-u1xzce{box-sizing:border-box;display:block;margin:0 auto;height:4em;fill:var(--main-color);opacity:0.75}"); } function get_each_context_1(ctx, list, i) { const child_ctx = ctx.slice(); child_ctx[6] = list[i]; return child_ctx; } function get_each_context$1(ctx, list, i) { const child_ctx = ctx.slice(); child_ctx[3] = list[i]; return child_ctx; } // (41:2) {:catch} function create_catch_block(ctx) { let div; let p0; let t2; let p1; let t3; let each_value_1 = /*lang*/ ctx[0].alternatives.concat([ { name: '维基词典', url: 'https://zh.wiktionary.org/wiki/', icon: '' }, { name: 'Wiktionary', url: 'https://en.wiktionary.org/wiki/', icon: '' } ]); let each_blocks = []; for (let i = 0; i < each_value_1.length; i += 1) { each_blocks[i] = create_each_block_1(get_each_context_1(ctx, each_value_1, i)); } let if_block = /*lang*/ ctx[0].type === 'en' && create_if_block$1(); return { c() { div = element("div"); p0 = element("p"); p0.textContent = `${'查无结果'},点击右上箭头,或试试这些词典:`; t2 = space(); p1 = element("p"); for (let i = 0; i < each_blocks.length; i += 1) { each_blocks[i].c(); } t3 = space(); if (if_block) if_block.c(); attr(p0, "class", "svelte-u1xzce"); attr(p1, "class", "alternatives svelte-u1xzce"); attr(div, "class", "tip svelte-u1xzce"); }, m(target, anchor) { insert(target, div, anchor); append(div, p0); append(div, t2); append(div, p1); for (let i = 0; i < each_blocks.length; i += 1) { each_blocks[i].m(p1, null); } append(div, t3); if (if_block) if_block.m(div, null); }, p(ctx, dirty) { if (dirty & /*lang, text*/ 3) { each_value_1 = /*lang*/ ctx[0].alternatives.concat([ { name: '维基词典', url: 'https://zh.wiktionary.org/wiki/', icon: '' }, { name: 'Wiktionary', url: 'https://en.wiktionary.org/wiki/', icon: '' } ]); let i; for (i = 0; i < each_value_1.length; i += 1) { const child_ctx = get_each_context_1(ctx, each_value_1, i); if (each_blocks[i]) { each_blocks[i].p(child_ctx, dirty); } else { each_blocks[i] = create_each_block_1(child_ctx); each_blocks[i].c(); each_blocks[i].m(p1, null); } } for (; i < each_blocks.length; i += 1) { each_blocks[i].d(1); } each_blocks.length = each_value_1.length; } if (/*lang*/ ctx[0].type === 'en') { if (if_block) ; else { if_block = create_if_block$1(); if_block.c(); if_block.m(div, null); } } else if (if_block) { if_block.d(1); if_block = null; } }, i: noop, o: noop, d(detaching) { if (detaching) detach(div); destroy_each(each_blocks, detaching); if (if_block) if_block.d(); } }; } // (45:8) {#each lang.alternatives.concat([ { name: '维基词典', url: 'https://zh.wiktionary.org/wiki/', icon: '', }, { name: 'Wiktionary', url: 'https://en.wiktionary.org/wiki/', icon: '', }, ]) as item } function create_each_block_1(ctx) { let a; let img; let img_src_value; let img_alt_value; let t; let a_href_value; let a_title_value; return { c() { a = element("a"); img = element("img"); t = space(); if (!src_url_equal(img.src, img_src_value = /*item*/ ctx[6].icon)) attr(img, "src", img_src_value); attr(img, "alt", img_alt_value = /*item*/ ctx[6].name); attr(img, "width", "20"); attr(img, "height", "20"); attr(img, "class", "svelte-u1xzce"); attr(a, "href", a_href_value = /*item*/ ctx[6].url + /*text*/ ctx[1]); attr(a, "target", "_blank"); attr(a, "title", a_title_value = "去" + /*item*/ ctx[6].name + "查询“" + /*text*/ ctx[1] + "”"); attr(a, "class", "svelte-u1xzce"); }, m(target, anchor) { insert(target, a, anchor); append(a, img); append(a, t); }, p(ctx, dirty) { if (dirty & /*lang*/ 1 && !src_url_equal(img.src, img_src_value = /*item*/ ctx[6].icon)) { attr(img, "src", img_src_value); } if (dirty & /*lang*/ 1 && img_alt_value !== (img_alt_value = /*item*/ ctx[6].name)) { attr(img, "alt", img_alt_value); } if (dirty & /*lang, text*/ 3 && a_href_value !== (a_href_value = /*item*/ ctx[6].url + /*text*/ ctx[1])) { attr(a, "href", a_href_value); } if (dirty & /*lang, text*/ 3 && a_title_value !== (a_title_value = "去" + /*item*/ ctx[6].name + "查询“" + /*text*/ ctx[1] + "”")) { attr(a, "title", a_title_value); } }, d(detaching) { if (detaching) detach(a); } }; } // (62:6) {#if lang.type === 'en'} function create_if_block$1(ctx) { let p; return { c() { p = element("p"); p.textContent = "(所查若非英语,请手动切换语言)"; attr(p, "class", "svelte-u1xzce"); }, m(target, anchor) { insert(target, p, anchor); }, d(detaching) { if (detaching) detach(p); } }; } // (37:2) {:then results} function create_then_block(ctx) { let each_1_anchor; let current; let each_value = /*results*/ ctx[2]; let each_blocks = []; for (let i = 0; i < each_value.length; i += 1) { each_blocks[i] = create_each_block$1(get_each_context$1(ctx, each_value, i)); } const out = i => transition_out(each_blocks[i], 1, 1, () => { each_blocks[i] = null; }); return { c() { for (let i = 0; i < each_blocks.length; i += 1) { each_blocks[i].c(); } each_1_anchor = empty(); }, m(target, anchor) { for (let i = 0; i < each_blocks.length; i += 1) { each_blocks[i].m(target, anchor); } insert(target, each_1_anchor, anchor); current = true; }, p(ctx, dirty) { if (dirty & /*lang, text*/ 3) { each_value = /*results*/ ctx[2]; let i; for (i = 0; i < each_value.length; i += 1) { const child_ctx = get_each_context$1(ctx, each_value, i); if (each_blocks[i]) { each_blocks[i].p(child_ctx, dirty); transition_in(each_blocks[i], 1); } else { each_blocks[i] = create_each_block$1(child_ctx); each_blocks[i].c(); transition_in(each_blocks[i], 1); each_blocks[i].m(each_1_anchor.parentNode, each_1_anchor); } } group_outros(); for (i = each_value.length; i < each_blocks.length; i += 1) { out(i); } check_outros(); } }, i(local) { if (current) return; for (let i = 0; i < each_value.length; i += 1) { transition_in(each_blocks[i]); } current = true; }, o(local) { each_blocks = each_blocks.filter(Boolean); for (let i = 0; i < each_blocks.length; i += 1) { transition_out(each_blocks[i]); } current = false; }, d(detaching) { destroy_each(each_blocks, detaching); if (detaching) detach(each_1_anchor); } }; } // (38:4) {#each results as entry} function create_each_block$1(ctx) { let resultentry; let current; resultentry = new ResultEntry({ props: { entry: /*entry*/ ctx[3] } }); return { c() { create_component(resultentry.$$.fragment); }, m(target, anchor) { mount_component(resultentry, target, anchor); current = true; }, p(ctx, dirty) { const resultentry_changes = {}; if (dirty & /*lang, text*/ 3) resultentry_changes.entry = /*entry*/ ctx[3]; resultentry.$set(resultentry_changes); }, i(local) { if (current) return; transition_in(resultentry.$$.fragment, local); current = true; }, o(local) { transition_out(resultentry.$$.fragment, local); current = false; }, d(detaching) { destroy_component(resultentry, detaching); } }; } // (7:29) {:then results} function create_pending_block(ctx) { let svg; let circle0; let animateTransform0; let circle1; let animateTransform1; let circle2; let animateTransform2; return { c() { svg = svg_element("svg"); circle0 = svg_element("circle"); animateTransform0 = svg_element("animateTransform"); circle1 = svg_element("circle"); animateTransform1 = svg_element("animateTransform"); circle2 = svg_element("circle"); animateTransform2 = svg_element("animateTransform"); attr(animateTransform0, "attributeName", "transform"); attr(animateTransform0, "dur", "1s"); attr(animateTransform0, "type", "translate"); attr(animateTransform0, "values", "0 15 ; 0 -15; 0 15"); attr(animateTransform0, "repeatCount", "indefinite"); attr(animateTransform0, "begin", "0.1"); attr(circle0, "cx", "6"); attr(circle0, "cy", "50"); attr(circle0, "r", "6"); attr(animateTransform1, "attributeName", "transform"); attr(animateTransform1, "dur", "1s"); attr(animateTransform1, "type", "translate"); attr(animateTransform1, "values", "0 10 ; 0 -10; 0 10"); attr(animateTransform1, "repeatCount", "indefinite"); attr(animateTransform1, "begin", "0.2"); attr(circle1, "cx", "30"); attr(circle1, "cy", "50"); attr(circle1, "r", "6"); attr(animateTransform2, "attributeName", "transform"); attr(animateTransform2, "dur", "1s"); attr(animateTransform2, "type", "translate"); attr(animateTransform2, "values", "0 5 ; 0 -5; 0 5"); attr(animateTransform2, "repeatCount", "indefinite"); attr(animateTransform2, "begin", "0.3"); attr(circle2, "cx", "54"); attr(circle2, "cy", "50"); attr(circle2, "r", "6"); attr(svg, "aria-hidden", "true"); attr(svg, "class", "loading svelte-u1xzce"); attr(svg, "xmlns", "http://www.w3.org/2000/svg"); attr(svg, "viewBox", "0 0 60 100"); }, m(target, anchor) { insert(target, svg, anchor); append(svg, circle0); append(circle0, animateTransform0); append(svg, circle1); append(circle1, animateTransform1); append(svg, circle2); append(circle2, animateTransform2); }, p: noop, i: noop, o: noop, d(detaching) { if (detaching) detach(svg); } }; } function create_fragment$1(ctx) { let div; let promise; let current; let info = { ctx, current: null, token: null, hasCatch: true, pending: create_pending_block, then: create_then_block, catch: create_catch_block, value: 2, blocks: [,,,] }; handle_promise(promise = /*lang*/ ctx[0].request(/*text*/ ctx[1]), info); return { c() { div = element("div"); info.block.c(); attr(div, "class", "content svelte-u1xzce"); }, m(target, anchor) { insert(target, div, anchor); info.block.m(div, info.anchor = null); info.mount = () => div; info.anchor = null; current = true; }, p(new_ctx, [dirty]) { ctx = new_ctx; info.ctx = ctx; if (dirty & /*lang, text*/ 3 && promise !== (promise = /*lang*/ ctx[0].request(/*text*/ ctx[1])) && handle_promise(promise, info)) ; else { update_await_block_branch(info, ctx, dirty); } }, i(local) { if (current) return; transition_in(info.block); current = true; }, o(local) { for (let i = 0; i < 3; i += 1) { const block = info.blocks[i]; transition_out(block); } current = false; }, d(detaching) { if (detaching) detach(div); info.block.d(); info.token = null; info = null; } }; } function instance$1($$self, $$props, $$invalidate) { let { lang } = $$props; let { text } = $$props; $$self.$$set = $$props => { if ('lang' in $$props) $$invalidate(0, lang = $$props.lang); if ('text' in $$props) $$invalidate(1, text = $$props.text); }; return [lang, text]; } class LangSection extends SvelteComponent { constructor(options) { super(); init(this, options, instance$1, create_fragment$1, safe_not_equal, { lang: 0, text: 1 }, add_css$1); } } const langs = [ { type: 'en', name: '英语', api: getYoudaoApi('eng', 'ec'), url: 'https://dict.cn/', alternatives: [ { name: '金山词霸', url: 'https://www.iciba.com/word?w=', icon: '' }, { name: 'Urban Dictionary', url: 'https://www.urbandictionary.com/define.php?term=', icon: '' }, ], is(text) { return /^(\p{sc=Latin}|-|\s)+$/u.test(text); }, async request(text) { const res = await get(this.api + text); const { ec } = JSON.parse(res); if (!ec) throw new Error('查无结果'); return ec.word.map((word) => ({ word: word['return-phrase'].l.i, phonetic: word.ukphone, sound: word.ukspeech && getYoudaoVoice(word.ukspeech), meanings: word.trs.map((tr) => { let [type, items] = tr.tr[0].l.i[0].split('.'); if (!items) { items = type; type = ''; } return { type: type.trim(), items: [items.trim()], }; }), })); }, }, { type: 'fr', name: '法语', api: getYoudaoApi('fr', 'fc'), url: 'https://www.frdic.com/dicts/fr/', alternatives: [], is(text) { return /^(\p{sc=Latin}|-|\s)+$/u.test(text); }, async request(text) { const res = await get(this.api + text); const { fc } = JSON.parse(res); if (!fc) throw new Error('查无结果'); return fc.word.map((word) => ({ word: word['return-phrase'].l.i, phonetic: word.phone.replace(/\s/g, ''), sound: word.speech && getYoudaoVoice(word.speech), meanings: word.trs.map((tr) => ({ type: tr.pos, items: tr.tr[0].l.i, })), })); }, }, { type: 'ja', name: '日语', api: getYoudaoApi('ja', 'newjc'), url: 'http://dict.asia/jc/', alternatives: [ { name: '沪江小D', url: 'https://dict.hjenglish.com/jp/jc/', icon: '' }, { name: 'JapanDict', url: 'https://www.japandict.com/?s=', icon: '' }, ], is(text) { return /^(\p{sc=Han}|\p{sc=Hira}|\p{scx=Kana})+$/u.test(text); }, async request(text) { const res = await get(this.api + text); const { newjc } = JSON.parse(res); if (!newjc) throw new Error('查无结果'); const { word: data } = newjc; const { mPhonicD, homonymD = [] } = data; const words = mPhonicD || [data]; words.push(...homonymD.filter((part) => part.head.pjm)); return words.map((word) => ({ word: word.head.hw, phonetic: `${word.head.pjm} ${word.head.tone || ''}`, sound: getYoudaoVoice(`${word.head.hw}&le=jap`), meanings: word.sense.map((sensePart) => ({ type: sensePart.cx, items: sensePart.phrList.map(({ jmsy }) => jmsy), })), })); }, }, { type: 'kr', name: '韩语', api: 'https://ac-dict.naver.com/kozh/ac?st=11&r_lt=11&q=', url: 'https://korean.dict.naver.com/kozhdict/#/search?query=', alternatives: [], is(text) { return /^\p{sc=Hangul}+$/u.test(text); }, async request(text) { const res = await get(this.api + text); const jsonResult = JSON.parse(res); const { query: [word], items } = jsonResult; if (!jsonResult.items[0].length) throw new Error('查无结果'); return [{ word, meanings: [{ items: items.flat().map((item) => `[${item[0]}] ${item[3]}`), }], }]; }, }, { type: 'th', name: '泰语', api: 'https://api.thai2english.com/translations?q=', url: 'https://www.thai2english.com/search?q=', alternatives: [], is(text) { return /^(\p{sc=Thai}|\s)+$/u.test(text); }, async request(text) { const res = await get(this.api + text); const [{ wordObjects }] = JSON.parse(res); return wordObjects.map((item) => ({ word: item.word, phonetic: item.phonetic, meanings: [{ items: item.meanings.map(({ meaning }) => meaning), }], })); }, }, { type: 'vt', name: '越南语', api: 'https://vtudien.com/viet-trung/dictionary/nghia-cua-tu-', url: 'https://vtudien.com/viet-trung/dictionary/nghia-cua-tu-', alternatives: [], is(text) { return /^(\p{sc=Latin}|-|\s)+$/u.test(text); }, async request(text) { const res = await get(this.api + text); const doc = new DOMParser().parseFromString(res, 'text/html'); const div = doc.getElementById('idnghia'); const word = div?.querySelector('h2')?.textContent?.trim(); if (!word) throw new Error('查无结果'); const tds = div?.querySelectorAll('td[colspan="2"]') || []; const items = Array.from(tds).map((td) => td.textContent); return [{ word, sound: `https://vtudien.com/doc/viet/${word}.mp3`, meanings: [{ items, }], }]; }, }, { type: 'tl', name: '他加禄语(菲律宾语)', api: 'https://www.tagalog.com/ajax/reference_guide_search_results.php?json=1&num_results=5&keyword=', url: 'https://www.tagalog.com/dictionary/#', alternatives: [], is(text) { return /^(\p{sc=Latin}|-|\s)+$/u.test(text); }, async request(text) { const res = await get(this.api + text); const entries = JSON.parse(res); if (!entries.length) throw new Error('查无结果'); return entries.map((entry) => { const { content, english, has_conjugations: hasConjugations, conjugations, } = entry; const meanings = english.split('[').slice(1) .map((segment) => segment.split(']')) .map(([type, meaning]) => ({ type, items: [ ...(type === 'verb' && hasConjugations === 1 ? [`( ${conjugations} )`] : []), meaning.trim(), ], })); return { word: content.replaceAll('***', '').replaceAll('^^^', ''), meanings, }; }); }, }, { type: 'in', name: '印尼语(马来语)', api: 'https://www.ekamus.info/index.php/term/%E9%A9%AC%E6%9D%A5%E6%96%87-%E5%8D%8E%E6%96%87%E5%AD%97%E5%85%B8,', url: 'https://www.ekamus.info/index.php/term/%E9%A9%AC%E6%9D%A5%E6%96%87-%E5%8D%8E%E6%96%87%E5%AD%97%E5%85%B8,', alternatives: [], is(text) { return /^(\p{sc=Latin}|-|\s)+$/u.test(text); }, async request(text) { const res = await get(this.api + text); const domparser = new DOMParser(); const dom = domparser.parseFromString(res, 'text/html'); const card = dom.querySelector('.row > .col-xs-12 .card'); const cardHeader = card.querySelector('.card-header'); const cardDefn = card.querySelector('.defn'); const cardDefnChildNodes = Array.from(cardDefn.childNodes); const meanings = []; const mainMeaning = cardDefnChildNodes .filter((childNode) => childNode.nodeName === '#text') .map((childNode) => childNode.textContent || ''); meanings.push({ items: mainMeaning }); const otherMeanings = cardDefnChildNodes .filter((childNode) => childNode.nodeName === 'P') .map((paragrahpNode) => { const meaning = { type: '', items: [] }; paragrahpNode.childNodes.forEach((childNode) => { if (childNode.nodeName === 'STRONG') { meaning.type = childNode.textContent || ''; } if (childNode.nodeName === '#text') { meaning.items.push(childNode.textContent || ''); } }); return meaning; }); meanings.push(...otherMeanings); return [{ word: cardHeader.textContent || '', meanings, }]; }, }, { type: 'all', name: 'Google 翻译', api: 'https://translate.google.com/translate_a/single?client=gtx&dt=t&dt=bd&dj=1&source=input&sl=auto&tl=zh-CN&q=', url: 'https://translate.google.com/?sl=auto&tl=zh-CN&op=translate&text=', alternatives: [], is() { return true; }, async request(text) { const res = await get(this.api + text); const result = JSON.parse(res); return [{ meanings: [{ items: [result.sentences.map((sentence) => sentence.trans).join('')], }], }]; }, }, ]; /* src/components/App.svelte generated by Svelte v3.46.4 */ function add_css(target) { append_styles(target, "svelte-13eu1t3", ".app.svelte-13eu1t3.svelte-13eu1t3{--main-color:#0C9553;font-size:16px;color:#000}.trigger.svelte-13eu1t3.svelte-13eu1t3{position:fixed;top:0;left:0;z-index:9999;display:block;width:24px;height:24px;padding:4px;border:0;border-radius:15%;background-color:var(--main-color);color:#fff;transition:visibility 0.3s, opcacity 0.3s;cursor:pointer}.trigger.svelte-13eu1t3.svelte-13eu1t3:hover{opacity:0.85}.panel.svelte-13eu1t3.svelte-13eu1t3{position:fixed;top:0;left:0;z-index:9999;display:flex;flex-direction:column;justify-content:center;height:16em;width:24em;max-width:100vw;max-height:100vh;padding-bottom:0.5em;border:1px solid #eee;background-color:#fff;box-shadow:3px 2.8px 4.2px -5px rgba(0, 0, 0, 0.07),\n 7.3px 6.7px 10px -5px rgba(0, 0, 0, 0.05),\n 13.8px 12.5px 18.8px -5px rgba(0, 0, 0, 0.042),\n 24.6px 22.3px 33.5px -5px rgba(0, 0, 0, 0.035),\n 46px 41.8px 62.7px -5px rgba(0, 0, 0, 0.028),\n 110px 100px 150px -5px rgba(0, 0, 0, 0.02)\n ;font-family:\"Segoe UI\", \"Microsoft Yahei\", meiryo, sans-serif;font-size:13px;line-height:1.5;transition:visibility 0.2s, opacity 0.2s;transition-timing-function:ease-in}.trigger.svelte-13eu1t3.svelte-13eu1t3:not(.is-show),.panel.svelte-13eu1t3.svelte-13eu1t3:not(.is-show){visibility:hidden;opacity:0;transition:none}.tabs.svelte-13eu1t3.svelte-13eu1t3{list-style:none;display:flex;padding:0;border-bottom:1px solid #f5f5f5;margin:0;background-color:#fcfcfc;user-select:none}.tab.svelte-13eu1t3.svelte-13eu1t3{flex:none;padding:0.5em 1em;border-right:1px solid #f5f5f5;border-bottom:1px solid #f5f5f5;margin-bottom:-1px;color:#666;cursor:pointer;transition:0.2s}.tab.active.svelte-13eu1t3.svelte-13eu1t3{padding-inline:1.25em;background-color:#fff;color:var(--main-color);border-bottom-color:#fff;font-weight:bold}.more.svelte-13eu1t3.svelte-13eu1t3{box-sizing:border-box;;;height:100%;margin-left:auto;aspect-ratio:1}.more.svelte-13eu1t3 a.svelte-13eu1t3{display:block;padding:0.65em;color:#a2a5a6;line-height:0;transition:0.3s}.more.svelte-13eu1t3 a.svelte-13eu1t3:hover{color:#000}"); } function get_each_context(ctx, list, i) { const child_ctx = ctx.slice(); child_ctx[16] = list[i]; return child_ctx; } // (66:6) {#each matchedLangs as lang} function create_each_block(ctx) { let li; let t_value = /*lang*/ ctx[16].name.split('')[0] + ""; let t; let li_class_value; let li_title_value; let li_aria_selected_value; let mounted; let dispose; function click_handler_1() { return /*click_handler_1*/ ctx[13](/*lang*/ ctx[16]); } return { c() { li = element("li"); t = text(t_value); attr(li, "class", li_class_value = "tab" + (/*lang*/ ctx[16] === /*activeLang*/ ctx[6] ? ' active' : '') + " svelte-13eu1t3"); attr(li, "title", li_title_value = /*lang*/ ctx[16].name); attr(li, "role", "tab"); attr(li, "aria-selected", li_aria_selected_value = /*lang*/ ctx[16] === /*activeLang*/ ctx[6]); }, m(target, anchor) { insert(target, li, anchor); append(li, t); if (!mounted) { dispose = listen(li, "click", click_handler_1); mounted = true; } }, p(new_ctx, dirty) { ctx = new_ctx; if (dirty & /*matchedLangs*/ 32 && t_value !== (t_value = /*lang*/ ctx[16].name.split('')[0] + "")) set_data(t, t_value); if (dirty & /*matchedLangs, activeLang*/ 96 && li_class_value !== (li_class_value = "tab" + (/*lang*/ ctx[16] === /*activeLang*/ ctx[6] ? ' active' : '') + " svelte-13eu1t3")) { attr(li, "class", li_class_value); } if (dirty & /*matchedLangs*/ 32 && li_title_value !== (li_title_value = /*lang*/ ctx[16].name)) { attr(li, "title", li_title_value); } if (dirty & /*matchedLangs, activeLang*/ 96 && li_aria_selected_value !== (li_aria_selected_value = /*lang*/ ctx[16] === /*activeLang*/ ctx[6])) { attr(li, "aria-selected", li_aria_selected_value); } }, d(detaching) { if (detaching) detach(li); mounted = false; dispose(); } }; } // (77:6) {#if activeLang} function create_if_block_1(ctx) { let li; let a; let svg; let path0; let path1; let a_href_value; let mounted; let dispose; return { c() { li = element("li"); a = element("a"); svg = svg_element("svg"); path0 = svg_element("path"); path1 = svg_element("path"); attr(path0, "d", "M11 3a1 1 0 100 2h2.586l-6.293 6.293a1 1 0 101.414 1.414L15 6.414V9a1 1 0 102 0V4a1 1 0 00-1-1h-5z"); attr(path1, "d", "M5 5a2 2 0 00-2 2v8a2 2 0 002 2h8a2 2 0 002-2v-3a1 1 0 10-2 0v3H5V7h3a1 1 0 000-2H5z"); attr(svg, "aria-hidden", "true"); attr(svg, "xmlns", "http://www.w3.org/2000/svg"); attr(svg, "viewBox", "0 0 20 20"); attr(svg, "fill", "currentColor"); attr(a, "target", "_blank"); attr(a, "rel", "noopener noreferrer"); attr(a, "href", a_href_value = "" + (/*activeLang*/ ctx[6].url + /*text*/ ctx[0])); attr(a, "title", "详细释义"); attr(a, "class", "svelte-13eu1t3"); attr(li, "class", "more svelte-13eu1t3"); }, m(target, anchor) { insert(target, li, anchor); append(li, a); append(a, svg); append(svg, path0); append(svg, path1); if (!mounted) { dispose = listen(a, "click", stop_propagation(/*click_handler*/ ctx[11])); mounted = true; } }, p(ctx, dirty) { if (dirty & /*activeLang, text*/ 65 && a_href_value !== (a_href_value = "" + (/*activeLang*/ ctx[6].url + /*text*/ ctx[0]))) { attr(a, "href", a_href_value); } }, d(detaching) { if (detaching) detach(li); mounted = false; dispose(); } }; } // (95:4) {#if activeLang} function create_if_block(ctx) { let langsection; let current; langsection = new LangSection({ props: { lang: /*activeLang*/ ctx[6], text: /*text*/ ctx[0] } }); return { c() { create_component(langsection.$$.fragment); }, m(target, anchor) { mount_component(langsection, target, anchor); current = true; }, p(ctx, dirty) { const langsection_changes = {}; if (dirty & /*activeLang*/ 64) langsection_changes.lang = /*activeLang*/ ctx[6]; if (dirty & /*text*/ 1) langsection_changes.text = /*text*/ ctx[0]; langsection.$set(langsection_changes); }, i(local) { if (current) return; transition_in(langsection.$$.fragment, local); current = true; }, o(local) { transition_out(langsection.$$.fragment, local); current = false; }, d(detaching) { destroy_component(langsection, detaching); } }; } function create_fragment(ctx) { let div1; let button; let t0; let div0; let ul; let t1; let t2; let current; let mounted; let dispose; let each_value = /*matchedLangs*/ ctx[5]; let each_blocks = []; for (let i = 0; i < each_value.length; i += 1) { each_blocks[i] = create_each_block(get_each_context(ctx, each_value, i)); } let if_block0 = /*activeLang*/ ctx[6] && create_if_block_1(ctx); let if_block1 = /*activeLang*/ ctx[6] && create_if_block(ctx); return { c() { div1 = element("div"); button = element("button"); button.innerHTML = ``; t0 = space(); div0 = element("div"); ul = element("ul"); for (let i = 0; i < each_blocks.length; i += 1) { each_blocks[i].c(); } t1 = space(); if (if_block0) if_block0.c(); t2 = space(); if (if_block1) if_block1.c(); attr(button, "class", "trigger svelte-13eu1t3"); attr(button, "aria-label", "开始翻译"); toggle_class(button, "is-show", /*showTrigger*/ ctx[3]); attr(ul, "class", "tabs svelte-13eu1t3"); attr(ul, "role", "tablist"); attr(div0, "class", "panel svelte-13eu1t3"); toggle_class(div0, "is-show", /*showPanel*/ ctx[4]); attr(div1, "class", "app svelte-13eu1t3"); }, m(target, anchor) { insert(target, div1, anchor); append(div1, button); /*button_binding*/ ctx[12](button); append(div1, t0); append(div1, div0); append(div0, ul); for (let i = 0; i < each_blocks.length; i += 1) { each_blocks[i].m(ul, null); } append(ul, t1); if (if_block0) if_block0.m(ul, null); append(div0, t2); if (if_block1) if_block1.m(div0, null); /*div0_binding*/ ctx[14](div0); current = true; if (!mounted) { dispose = [ listen(button, "click", /*onTranslate*/ ctx[7]), listen(div1, "mousedown", stop_propagation(/*mousedown_handler*/ ctx[9])), listen(div1, "mouseup", stop_propagation(/*mouseup_handler*/ ctx[10])) ]; mounted = true; } }, p(ctx, [dirty]) { if (dirty & /*showTrigger*/ 8) { toggle_class(button, "is-show", /*showTrigger*/ ctx[3]); } if (dirty & /*matchedLangs, activeLang, onToggleLanguage*/ 352) { each_value = /*matchedLangs*/ ctx[5]; let i; for (i = 0; i < each_value.length; i += 1) { const child_ctx = get_each_context(ctx, each_value, i); if (each_blocks[i]) { each_blocks[i].p(child_ctx, dirty); } else { each_blocks[i] = create_each_block(child_ctx); each_blocks[i].c(); each_blocks[i].m(ul, t1); } } for (; i < each_blocks.length; i += 1) { each_blocks[i].d(1); } each_blocks.length = each_value.length; } if (/*activeLang*/ ctx[6]) { if (if_block0) { if_block0.p(ctx, dirty); } else { if_block0 = create_if_block_1(ctx); if_block0.c(); if_block0.m(ul, null); } } else if (if_block0) { if_block0.d(1); if_block0 = null; } if (/*activeLang*/ ctx[6]) { if (if_block1) { if_block1.p(ctx, dirty); if (dirty & /*activeLang*/ 64) { transition_in(if_block1, 1); } } else { if_block1 = create_if_block(ctx); if_block1.c(); transition_in(if_block1, 1); if_block1.m(div0, null); } } else if (if_block1) { group_outros(); transition_out(if_block1, 1, 1, () => { if_block1 = null; }); check_outros(); } if (dirty & /*showPanel*/ 16) { toggle_class(div0, "is-show", /*showPanel*/ ctx[4]); } }, i(local) { if (current) return; transition_in(if_block1); current = true; }, o(local) { transition_out(if_block1); current = false; }, d(detaching) { if (detaching) detach(div1); /*button_binding*/ ctx[12](null); destroy_each(each_blocks, detaching); if (if_block0) if_block0.d(); if (if_block1) if_block1.d(); /*div0_binding*/ ctx[14](null); mounted = false; run_all(dispose); } }; } function instance($$self, $$props, $$invalidate) { let text = ''; let rect; let trigger; let panel; let showTrigger = false; let showPanel = false; let matchedLangs = []; let activeLang; window.addEventListener('mouseup', () => { const selection = window.getSelection(); $$invalidate(0, text = selection.toString().trim().toLowerCase()); if (text) { const rects = selection.getRangeAt(0).getClientRects(); rect = rects[rects.length - 1]; setPosition(trigger, rect); $$invalidate(3, showTrigger = true); } }); window.addEventListener('mousedown', () => { $$invalidate(3, showTrigger = false); $$invalidate(4, showPanel = false); $$invalidate(5, matchedLangs = []); }); function onTranslate() { $$invalidate(5, matchedLangs = Object.values(langs).filter(lang => lang.is(text))); if (!activeLang || !matchedLangs.find(lang => lang === activeLang)) { $$invalidate(6, [activeLang] = matchedLangs, activeLang); } setTimeout(() => { setPosition(panel, rect); $$invalidate(3, showTrigger = false); $$invalidate(4, showPanel = true); }); } function onToggleLanguage(targetLang) { $$invalidate(6, activeLang = targetLang); } function mousedown_handler(event) { bubble.call(this, $$self, event); } function mouseup_handler(event) { bubble.call(this, $$self, event); } function click_handler(event) { bubble.call(this, $$self, event); } function button_binding($$value) { binding_callbacks[$$value ? 'unshift' : 'push'](() => { trigger = $$value; $$invalidate(1, trigger); }); } const click_handler_1 = lang => onToggleLanguage(lang); function div0_binding($$value) { binding_callbacks[$$value ? 'unshift' : 'push'](() => { panel = $$value; $$invalidate(2, panel); }); } return [ text, trigger, panel, showTrigger, showPanel, matchedLangs, activeLang, onTranslate, onToggleLanguage, mousedown_handler, mouseup_handler, click_handler, button_binding, click_handler_1, div0_binding ]; } class App extends SvelteComponent { constructor(options) { super(); init(this, options, instance, create_fragment, safe_not_equal, {}, add_css); } } const wrapper = document.createElement('div'); document.body.append(wrapper); wrapper.attachShadow({ mode: 'open' }); if (wrapper.shadowRoot) { // eslint-disable-next-line no-new new App({ target: wrapper.shadowRoot, }); } })();