aboutsummaryrefslogtreecommitdiff
path: root/ext/bg/settings2.html
diff options
context:
space:
mode:
Diffstat (limited to 'ext/bg/settings2.html')
-rw-r--r--ext/bg/settings2.html3260
1 files changed, 0 insertions, 3260 deletions
diff --git a/ext/bg/settings2.html b/ext/bg/settings2.html
deleted file mode 100644
index d0ba0b3c..00000000
--- a/ext/bg/settings2.html
+++ /dev/null
@@ -1,3260 +0,0 @@
-<!DOCTYPE html>
-<html lang="en">
-<head>
- <meta charset="UTF-8">
- <meta name="viewport" content="width=device-width,initial-scale=1">
- <title>Yomichan Settings</title>
- <link rel="icon" type="image/png" href="/images/icon16.png" sizes="16x16">
- <link rel="icon" type="image/png" href="/images/icon19.png" sizes="19x19">
- <link rel="icon" type="image/png" href="/images/icon32.png" sizes="32x32">
- <link rel="icon" type="image/png" href="/images/icon38.png" sizes="38x38">
- <link rel="icon" type="image/png" href="/images/icon48.png" sizes="48x48">
- <link rel="icon" type="image/png" href="/images/icon64.png" sizes="64x64">
- <link rel="icon" type="image/png" href="/images/icon128.png" sizes="128x128">
- <link rel="stylesheet" type="text/css" href="/css/material.css">
- <link rel="stylesheet" type="text/css" href="/css/settings2.css">
-</head>
-<body>
-
-<!-- Main content -->
-<div class="content-outer"><div class="content">
-<div class="content-left">
- <div class="sidebar"><div class="sidebar-inner">
- <div class="sidebar-body">
- <a href="#!profile" class="outline-item"><span class="outline-item-left"><span class="outline-item-icon icon" data-icon="profile"></span></span><span class="outline-item-label">Profile</span></a>
- <a href="#!dictionaries" class="outline-item"><span class="outline-item-left"><span class="outline-item-icon icon" data-icon="book"></span><span class="outline-item-left-warning-badge no-dictionaries-enabled-warning" hidden><div class="warning-badge"><span class="icon" data-icon="exclamation-point-short"></span></div></span></span><span class="outline-item-label">Dictionaries</span></a>
- <a href="#!general" class="outline-item"><span class="outline-item-left"><span class="outline-item-icon icon" data-icon="cog"></span></span><span class="outline-item-label">General</span></a>
- <a href="#!scanning" class="outline-item"><span class="outline-item-left"><span class="outline-item-icon icon" data-icon="scanning"></span></span><span class="outline-item-label">Scanning</span></a>
- <a href="#!popup" class="outline-item"><span class="outline-item-left"><span class="outline-item-icon icon" data-icon="popup"></span></span><span class="outline-item-label">Popup</span></a>
- <a href="#!popup-appearance" class="outline-item"><span class="outline-item-left"><span class="outline-item-icon icon" data-icon="palette"></span></span><span class="outline-item-label">Appearance</span></a>
- <a href="#!popup-size" class="outline-item"><span class="outline-item-left"><span class="outline-item-icon icon" data-icon="popup-size"></span></span><span class="outline-item-label">Position &amp; Size</span></a>
- <a href="#!window" class="outline-item advanced-only"><span class="outline-item-left"><span class="outline-item-icon icon" data-icon="window"></span></span><span class="outline-item-label">Window</span></a>
- <a href="#!audio" class="outline-item"><span class="outline-item-left"><span class="outline-item-icon icon" data-icon="speaker"></span></span><span class="outline-item-label">Audio</span></a>
- <a href="#!text-parsing" class="outline-item"><span class="outline-item-left"><span class="outline-item-icon icon" data-icon="text-parsing"></span></span><span class="outline-item-label">Text Parsing</span></a>
- <a href="#!sentence-parsing" class="outline-item advanced-only"><span class="outline-item-left"><span class="outline-item-icon icon" data-icon="sentence-parsing"></span></span><span class="outline-item-label">Sentence Parsing</span></a>
- <a href="#!translation" class="outline-item advanced-only"><span class="outline-item-left"><span class="outline-item-icon icon" data-icon="translation"></span></span><span class="outline-item-label">Translation</span></a>
- <a href="#!anki" class="outline-item"><span class="outline-item-left"><span class="outline-item-icon icon" data-icon="note-card"></span></span><span class="outline-item-label">Anki</span></a>
- <a href="#!clipboard" class="outline-item"><span class="outline-item-left"><span class="outline-item-icon icon" data-icon="clipboard"></span></span><span class="outline-item-label">Clipboard</span></a>
- <a href="#!shortcuts" class="outline-item"><span class="outline-item-left"><span class="outline-item-icon icon" data-icon="keyboard"></span></span><span class="outline-item-label">Shortcuts</span></a>
- <a href="#!backup" class="outline-item"><span class="outline-item-left"><span class="outline-item-icon icon" data-icon="backup"></span></span><span class="outline-item-label">Backup</span></a>
- <a href="#!security" class="outline-item advanced-only"><span class="outline-item-left"><span class="outline-item-icon icon" data-icon="lock"></span></span><span class="outline-item-label">Security</span></a>
- </div>
- <div class="sidebar-bottom">
- <label class="outline-item"><span class="outline-item-left">
- <label class="toggle"><input id="advanced-checkbox" type="checkbox" data-setting="general.showAdvanced"
- data-transform='{
- "type": "setAttribute",
- "selector": ":root",
- "attribute": "data-advanced"
- }'
- ><span class="toggle-body"><span class="toggle-track"></span><span class="toggle-knob"></span></span></label>
- </span><span class="outline-item-label">Advanced</span></label>
- <a href="/bg/info.html" class="outline-item"><span class="outline-item-left"><span class="outline-item-icon icon" data-icon="question-mark"></span></span><span class="outline-item-label">About Yomichan</span></a>
- </div>
- </div></div>
-</div>
-<div class="content-center">
-
- <span tabindex="-1" id="content-scroll-focus"></span>
-
- <h1>Yomichan Settings</h1>
-
- <!-- Beta notice -->
- <h2></h2>
- <div class="settings-group" style="border: 1px solid var(--accent-color);">
- <div class="settings-item"><div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-label">
- <strong>Notice:</strong>
- This settings page is planned to replace
- <a href="/bg/settings.html">the old settings page</a>.<br>
- Questions, comments, and other feedback is welcome and can be shared
- <a href="https://github.com/FooSoft/yomichan/issues/1000" target="_blank" rel="noopener noreferrer">on Github</a>.
- </div>
- </div>
- </div></div>
- <div class="settings-item"><div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-label">Use this new settings page by default</div>
- </div>
- <div class="settings-item-right">
- <label class="toggle"><input type="checkbox" data-setting="global.useSettingsV2" data-scope="global"><span class="toggle-body"><span class="toggle-track"></span><span class="toggle-knob"></span></span></label>
- </div>
- </div></div>
- </div>
-
- <!-- Profile -->
- <div class="heading-container">
- <div class="heading-container-icon"><span class="icon" data-icon="profile"></span></div>
- <div class="heading-container-left"><h2 id="profile"><a href="#!profile">Profile</a></h2></div>
- </div>
- <div class="settings-group">
- <div class="settings-item"><div class="settings-item-inner settings-item-inner-wrappable">
- <div class="settings-item-left">
- <div class="settings-item-label">Default profile</div>
- <div class="settings-item-description">Switch the primary profile that is used for scanning.</div>
- </div>
- <div class="settings-item-right">
- <select id="profile-active-select"></select>
- </div>
- </div></div>
- <div class="settings-item"><div class="settings-item-inner settings-item-inner-wrappable">
- <div class="settings-item-left">
- <div class="settings-item-label">Editing profile</div>
- <div class="settings-item-description">Change which profile is being modified on this page.</div>
- </div>
- <div class="settings-item-right">
- <select id="profile-target-select"></select>
- </div>
- </div></div>
- <div class="settings-item settings-item-button" data-modal-action="show,profiles"><div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-label">Configure profiles&hellip;</div>
- </div>
- <div class="settings-item-right open-panel-button-container">
- <button class="icon-button"><span class="icon-button-inner"><span class="icon" data-icon="material-right-arrow"></span></span></button>
- </div>
- </div></div>
- </div>
-
- <!-- Dictionaries -->
- <div class="heading-container">
- <div class="heading-container-icon"><span class="icon" data-icon="book"></span></div>
- <div class="heading-container-left"><h2 id="dictionaries"><a href="#!dictionaries">Dictionaries</a> <span class="heading-sub-text no-wrap" data-modal-action="show,dictionaries">(<span id="dictionary-install-count">#</span> installed, <span id="dictionary-enabled-count">#</span> enabled)</span></h2></div>
- </div>
- <div class="settings-group">
- <div class="settings-item settings-item-button" data-modal-action="show,dictionaries"><div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-label">
- <div class="flex-row-nowrap">
- <div>Configure installed and enabled dictionaries&hellip;</div>
- <div class="flex-margin-left warning-badge no-dictionaries-enabled-warning" hidden><span class="icon" data-icon="exclamation-point-short"></span></div>
- </div>
- </div>
- </div>
- <div class="settings-item-right open-panel-button-container">
- <button class="icon-button"><span class="icon-button-inner"><span class="icon" data-icon="material-right-arrow"></span></span></button>
- </div>
- </div></div>
- <div class="settings-item">
- <div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-label">Storage</div>
- <div class="settings-item-description">
- <span class="storage-use-invalid">
- Yomichan is using an indeterminate amount of storage.
- </span>
- <span class="storage-use-finite" hidden>
- Yomichan is using approximately <span class="storage-usage">?</span> of <span class="storage-quota">?</span>.
- </span>
- <span class="storage-use-infinite" hidden>
- Yomichan is permitted unlimited storage.
- </span>
- </div>
- </div>
- <div class="settings-item-right">
- <button id="storage-refresh" class="low-emphasis">Refresh</button>
- </div>
- </div>
- </div>
- <div class="settings-item">
- <div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-label">Persistent storage</div>
- <div class="settings-item-description">
- Enable to help prevent the browser from unexpectedly clearing the database.
- <a class="more-toggle more-only" data-parent-distance="4">More&hellip;</a>
- </div>
- </div>
- <div class="settings-item-right">
- <label class="toggle"><input type="checkbox" id="storage-persistent-checkbox"><span class="toggle-body"><span class="toggle-track"></span><span class="toggle-knob"></span></span></label>
- </div>
- </div>
- <div class="settings-item-children more" hidden>
- <p>
- Web browsers will sometimes clear stored data if the device is running low on storage space.
- This can result in the imported dictionaries being deleted unexpectedly, causing Yomichan to stop functioning.
- Enabling persistent storage tells the browser that the data should not be deleted in those circumstances.
- </p>
- <p data-show-for-browser="firefox firefox-mobile" class="storage-use-invalid" hidden>
- On Firefox and Firefox for Android, the storage information feature may be hidden behind a browser flag.
-
- To enable this flag, open <a href="about:config" target="_blank" rel="noopener">about:config</a> and search for
- <strong>dom.storageManager.enabled</strong>.
-
- Setting its value to <strong>true</strong> should allow storage information to be calculated.
- </p>
- <p data-show-for-browser="firefox-mobile">
- It may not be possible to enable Persistent Storage on Firefox for Android.
- </p>
- <p data-show-for-browser="chrome edge">
- Chromium-based browsers should not need to enable this setting since the Yomichan extension has
- the <code>unlimitedStorage</code> permission, which should prevent data deletion.<sup><a href="https://bugs.chromium.org/p/chromium/issues/detail?id=680392#c15" target="_blank" rel="noopener">[1]</a></sup>
- </p>
- <p>
- <a class="more-toggle" data-parent-distance="3">Less&hellip;</a>
- </p>
- </div>
- </div>
- </div>
-
- <!-- General -->
- <div class="heading-container">
- <div class="heading-container-icon"><span class="icon" data-icon="cog"></span></div>
- <div class="heading-container-left"><h2 id="general"><a href="#!general">General</a></h2></div>
- </div>
- <div class="settings-group">
- <div class="settings-item"><div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-label">Enable content scanning</div>
- </div>
- <div class="settings-item-right">
- <label class="toggle"><input type="checkbox" data-setting="general.enable"><span class="toggle-body"><span class="toggle-track"></span><span class="toggle-knob"></span></span></label>
- </div>
- </div></div>
- <div class="settings-item"><div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-label">Show the <a href="welcome.html" target="_blank" rel="noopener">welcome guide</a> on browser startup</div>
- </div>
- <div class="settings-item-right">
- <label class="toggle"><input type="checkbox" data-setting="general.showGuide"><span class="toggle-body"><span class="toggle-track"></span><span class="toggle-knob"></span></span></label>
- </div>
- </div></div>
- <div class="settings-item">
- <div class="settings-item-inner settings-item-inner-wrappable">
- <div class="settings-item-left">
- <div class="settings-item-label">Result grouping mode</div>
- <div class="settings-item-description">
- Change how related results are grouped.
- <a class="more-toggle more-only" data-parent-distance="4">More...</a>
- </div>
- </div>
- <div class="settings-item-right">
- <select data-setting="general.resultOutputMode"
- data-transform='{
- "type": "setVisibility",
- "selector": "#main-dictionary-container",
- "condition": {"op": "===", "value": "merge"}
- }'
- >
- <option value="split">No grouping</option>
- <option value="group">Group term-reading pairs</option>
- <option value="merge">Group related terms</option>
- </select>
- </div>
- </div>
- <div class="settings-item-children more" hidden>
- <ul>
- <li>
- <strong>No grouping</strong> -
- Every definition will be listed as a separate entry.
- </li>
- <li>
- <strong>Group term-reading pairs</strong> -
- Definitions for the same term with the same reading will be grouped together.
- </li>
- <li>
- <p>
- <strong>Group related terms</strong> -
- Related terms that share the same definitions will be grouped together.
- </p>
- <p>
- The <em>Primary dictionary</em> option should be assigned to a dictionary which contains related term information,
- and configuring the <em>Secondary dictionaries</em> will allow definitions for the related terms to be
- included from other dictionaries.
- </p>
- <p class="warning-text">
- Not all dictionaries are able to be selected as the <em>Primary dictionary</em>.
- </p>
- </li>
- </ul>
- <p>
- <a class="more-toggle" data-parent-distance="3">Less&hellip;</a>
- </p>
- </div>
- <div class="settings-item-children settings-item-children-group" id="main-dictionary-container" hidden>
- <div class="settings-item"><div class="settings-item-inner settings-item-inner-wrappable">
- <div class="settings-item-left">
- <div class="settings-item-label">Primary dictionary</div>
- </div>
- <div class="settings-item-right">
- <select data-setting="general.mainDictionary"></select>
- </div>
- </div></div>
- <div class="settings-item settings-item-button" data-modal-action="show,secondary-search-dictionaries"><div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-label">Secondary dictionaries&hellip;</div>
- </div>
- <div class="settings-item-right open-panel-button-container">
- <button class="icon-button"><span class="icon-button-inner"><span class="icon" data-icon="material-right-arrow"></span></span></button>
- </div>
- </div></div>
- </div>
- </div>
- <div class="settings-item advanced-only"><div class="settings-item-inner settings-item-inner-wrappable">
- <div class="settings-item-left">
- <div class="settings-item-label">Maximum number of results</div>
- <div class="settings-item-description">Adjust the maximum number of results shown for lookups.</div>
- </div>
- <div class="settings-item-right">
- <input type="number" min="1" data-setting="general.maxResults">
- </div>
- </div></div>
- </div>
-
- <!-- Scanning -->
- <div class="heading-container">
- <div class="heading-container-icon"><span class="icon" data-icon="scanning"></span></div>
- <div class="heading-container-left"><h2 id="scanning"><a href="#!scanning">Scanning</a></h2></div>
- </div>
- <div class="settings-group">
- <div class="settings-item">
- <div class="settings-item-inner settings-item-inner-wrappable">
- <div class="settings-item-left">
- <div class="settings-item-label">Scan modifier key</div>
- <div class="settings-item-description">
- Hold a key while moving the cursor to scan text.
- <a class="more-toggle more-only" data-parent-distance="4">More&hellip;</a>
- </div>
- </div>
- <div class="settings-item-right">
- <select id="main-scan-modifier-key"></select>
- </div>
- </div>
- <div class="settings-item-children more" hidden>
- <p>
- A keyboard modifier key can be used to activate text scanning when the cursor is moved.
- Alternatively, the <em>No key</em> option can be used to scan text whenever the cursor is moved,
- without requiring any key to be held.
- </p>
- <p>
- More advanced scanning input customization can be set up by enabling the <em>Advanced</em> option
- and clicking <em data-modal-action="show,scanning-inputs">Configure advanced scanning inputs</em>.
- </p>
- <p>
- <a class="more-toggle" data-parent-distance="3">Less&hellip;</a>
- </p>
- </div>
- </div>
- <div class="settings-item"><div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-label">Scan using middle mouse button</div>
- <div class="settings-item-description">Hold the middle mouse button while moving the cursor to scan text.</div>
- </div>
- <div class="settings-item-right">
- <label class="toggle"><input type="checkbox" id="middle-mouse-button-scan"><span class="toggle-body"><span class="toggle-track"></span><span class="toggle-knob"></span></span></label>
- </div>
- </div></div>
- <div class="settings-item settings-item-button advanced-only" data-modal-action="show,scanning-inputs"><div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-label">Configure advanced scanning inputs&hellip; <span class="light no-wrap">(<span class="scanning-input-count">#</span> defined)</span></div>
- </div>
- <div class="settings-item-right open-panel-button-container">
- <button class="icon-button"><span class="icon-button-inner"><span class="icon" data-icon="material-right-arrow"></span></span></button>
- </div>
- </div></div>
- <div class="settings-item">
- <div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-label">Auto-hide search popup</div>
- <div class="settings-item-description">When no definitions are found after scanning text, the popup will automatically hide.</div>
- </div>
- <div class="settings-item-right">
- <label class="toggle"><input type="checkbox" data-setting="scanning.autoHideResults"
- data-transform='{
- "type": "setVisibility",
- "selector": "#auto-hide-search-popup-options",
- "condition": {"op": "===", "value": true}
- }'
- ><span class="toggle-body"><span class="toggle-track"></span><span class="toggle-knob"></span></span></label>
- </div>
- </div>
- <div class="settings-item-children settings-item-children-group" id="auto-hide-search-popup-options" hidden>
- <div class="settings-item"><div class="settings-item-inner settings-item-inner-wrappable">
- <div class="settings-item-left">
- <div class="settings-item-label">Auto-hide delay <span class="light">(in milliseconds)</span></div>
- </div>
- <div class="settings-item-right">
- <input type="number" data-setting="scanning.hideDelay" min="0">
- </div>
- </div></div>
- </div>
- </div>
- <div class="settings-item"><div class="settings-item-inner settings-item-inner-wrappable">
- <div class="settings-item-left">
- <div class="settings-item-label">Scan delay <span class="light">(in milliseconds)</span></div>
- <div class="settings-item-description">Change the delay before scanning occurs when no modifier key is required.</div>
- </div>
- <div class="settings-item-right">
- <input type="number" data-setting="scanning.delay" min="0">
- </div>
- </div></div>
- <div class="settings-item"><div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-label">Select matched text</div>
- </div>
- <div class="settings-item-right">
- <label class="toggle"><input type="checkbox" data-setting="scanning.selectText"><span class="toggle-body"><span class="toggle-track"></span><span class="toggle-knob"></span></span></label>
- </div>
- </div></div>
- <div class="settings-item"><div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-label">Search text with non-Japanese characters</div>
- </div>
- <div class="settings-item-right">
- <label class="toggle"><input type="checkbox" data-setting="scanning.alphanumeric"><span class="toggle-body"><span class="toggle-track"></span><span class="toggle-knob"></span></span></label>
- </div>
- </div></div>
- <div class="settings-item advanced-only"><div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-label">Layout-aware scanning</div>
- <div class="settings-item-description">Use webpage styling information to determine where line breaks are likely to be.</div>
- </div>
- <div class="settings-item-right">
- <label class="toggle"><input type="checkbox" data-setting="scanning.layoutAwareScan"><span class="toggle-body"><span class="toggle-track"></span><span class="toggle-knob"></span></span></label>
- </div>
- </div></div>
- <div class="settings-item advanced-only"><div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-label">Deep content scanning</div>
- <div class="settings-item-description">Enable scanning text that is covered by other layers.</div>
- </div>
- <div class="settings-item-right">
- <label class="toggle"><input type="checkbox" data-setting="scanning.deepDomScan"><span class="toggle-body"><span class="toggle-track"></span><span class="toggle-knob"></span></span></label>
- </div>
- </div></div>
- <div class="settings-item advanced-only"><div class="settings-item-inner settings-item-inner-wrappable">
- <div class="settings-item-left">
- <div class="settings-item-label">Text scan length</div>
- <div class="settings-item-description">Change how many characters are read when scanning for terms.</div>
- </div>
- <div class="settings-item-right">
- <input type="number" data-setting="scanning.length" min="1" step="1">
- </div>
- </div></div>
- <div class="settings-item advanced-only">
- <div class="settings-item-inner settings-item-inner-wrappable">
- <div class="settings-item-left">
- <div class="settings-item-label">
- Support inputs for devices with touch screens
- <a class="more-toggle more-only" data-parent-distance="4">(?)</a>
- </div>
- </div>
- <div class="settings-item-right flex-row-wrap">
- <div class="settings-item-group settings-item-group-wrap">
- <label class="settings-item-group-item flex-label no-wrap">
- <label class="checkbox"><input type="checkbox" data-setting="scanning.touchInputEnabled"><span class="checkbox-body"><span class="checkbox-fill"></span><span class="checkbox-border"></span><span class="checkbox-check"></span></span></label>
- <span>Touch inputs</span>
- </label>
- <label class="settings-item-group-item flex-label no-wrap">
- <label class="checkbox"><input type="checkbox" data-setting="scanning.pointerEventsEnabled"><span class="checkbox-body"><span class="checkbox-fill"></span><span class="checkbox-border"></span><span class="checkbox-check"></span></span></label>
- <span>Pointer inputs</span>
- </label>
- </div>
- </div>
- </div>
- <div class="settings-item-children more" hidden>
- <p>
- To enable text scanning when using devices with a touch screen, either the <em>Touch inputs</em> or the <em>Pointer inputs</em> option must be enabled.
- <em>Touch inputs</em> supports generic touches on a touch screen device, but do not distinguish between touch and pen inputs.
- <em>Pointer inputs</em> supports supports the detection pen devices, but may not work on all devices.
- If both options are enabled, <em>Pointer inputs</em> takes precedence.
- </p>
- <p>
- The <em>Pointer inputs</em> option is only visible when the <em>Advanced</em> option is enabled.
- </p>
- <p>
- <a class="more-toggle" data-parent-distance="3">Less&hellip;</a>
- </p>
- </div>
- </div>
- <div class="settings-item settings-item-button advanced-only" data-modal-action="show,input-action-prevention"><div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-label">Configure input action prevention&hellip;</div>
- </div>
- <div class="settings-item-right open-panel-button-container">
- <button class="icon-button"><span class="icon-button-inner"><span class="icon" data-icon="material-right-arrow"></span></span></button>
- </div>
- </div></div>
- </div>
-
- <!-- Popup -->
- <div class="heading-container">
- <div class="heading-container-icon"><span class="icon" data-icon="popup"></span></div>
- <div class="heading-container-left"><h2 id="popup"><a href="#!popup">Popup</a></h2></div>
- </div>
- <div class="settings-group">
- <div class="settings-item"><div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-label">Allow scanning search page content</div>
- <div class="settings-item-description">Text on the search page can be scanned for definitions, which will open a popup.</div>
- </div>
- <div class="settings-item-right">
- <label class="toggle"><input type="checkbox" data-setting="scanning.enableOnSearchPage"><span class="toggle-body"><span class="toggle-track"></span><span class="toggle-knob"></span></span></label>
- </div>
- </div></div>
- <div class="settings-item">
- <div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-label">Allow scanning popup content</div>
- <div class="settings-item-description">Text inside of popups can be scanned for definitions, which will open a new popup.</div>
- </div>
- <div class="settings-item-right">
- <label class="toggle"><input type="checkbox" id="nested-popups-enabled"><span class="toggle-body"><span class="toggle-track"></span><span class="toggle-knob"></span></span></label>
- </div>
- </div>
- <div class="settings-item-children settings-item-children-group" id="nested-popups-enabled-more-options" hidden>
- <div class="settings-item"><div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-label">Maximum number of child popups</div>
- <div class="settings-item-description">Change the limit on the number of popups that may be generated.</div>
- </div>
- <div class="settings-item-right">
- <input type="number" min="0" step="1" id="nested-popups-count">
- </div>
- </div></div>
- <div class="settings-item advanced-only"><div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-label">Allow scanning popup source terms</div>
- </div>
- <div class="settings-item-right">
- <label class="toggle"><input type="checkbox" data-setting="scanning.enableOnPopupExpressions"><span class="toggle-body"><span class="toggle-track"></span><span class="toggle-knob"></span></span></label>
- </div>
- </div></div>
- </div>
- </div>
- <div class="settings-item advanced-only"><div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-label">Search terms when clicking text from the results list</div>
- </div>
- <div class="settings-item-right">
- <label class="toggle"><input type="checkbox" data-setting="scanning.enablePopupSearch"><span class="toggle-body"><span class="toggle-track"></span><span class="toggle-knob"></span></span></label>
- </div>
- </div></div>
- <div class="settings-item advanced-only">
- <div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-label">
- Show iframe popups in the root frame
- <a class="more-toggle more-only" data-parent-distance="4">(?)</a>
- </div>
- </div>
- <div class="settings-item-right">
- <label class="toggle"><input type="checkbox" data-setting="general.showIframePopupsInRootFrame"><span class="toggle-body"><span class="toggle-track"></span><span class="toggle-knob"></span></span></label>
- </div>
- </div>
- <div class="settings-item-children more" hidden>
- <p>
- By default, scanning text inside of an embeded <code>&lt;iframe&gt;</code> element will open
- a new popup inside of that frame, which can sometimes be limiting due to the frame's size.
- When this option is enabled, the popup will be created in the root of the page, if possible.
- </p>
- <p>
- Note that when this option is enabled, there is a possibility that the extension can interfere with the underlying webpage,
- since it must send messages to the webpage in order to determine the correct position of the popup.
- This typically does not cause issues, but if anything unexpected happens, this option could be the cause.
- </p>
- <p>
- <a class="more-toggle" data-parent-distance="3">Less&hellip;</a>
- </p>
- </div>
- </div>
- </div>
-
- <!-- Popup Appearance -->
- <div class="heading-container">
- <div class="heading-container-icon"><span class="icon" data-icon="palette"></span></div>
- <div class="heading-container-left"><h2 id="popup-appearance"><a href="#!popup-appearance">Popup Appearance</a></h2></div>
- </div>
- <div class="settings-group">
- <div class="settings-item"><div class="settings-item-inner settings-item-inner-wrappable">
- <div class="settings-item-left">
- <div class="settings-item-label">Theme</div>
- <div class="settings-item-description">Adjust the style of the popup.</div>
- </div>
- <div class="settings-item-right">
- <div class="settings-item-group">
- <div class="settings-item-group-item">
- <div class="settings-item-group-item-label">Body</div>
- <select data-setting="general.popupTheme" class="short-width short-height">
- <option value="default">Light</option>
- <option value="dark">Dark</option>
- </select>
- </div>
- <div class="settings-item-group-item">
- <div class="settings-item-group-item-label">Shadow</div>
- <select data-setting="general.popupOuterTheme" class="short-width short-height">
- <option value="auto">Auto</option>
- <option value="default">Light</option>
- <option value="dark">Dark</option>
- </select>
- </div>
- </div>
- </div>
- </div></div>
- <div class="settings-item">
- <div class="settings-item-inner settings-item-inner-wrappable">
- <div class="settings-item-left">
- <div class="settings-item-label">Action bar appearance</div>
- <div class="settings-item-description">Control when and where the action bar is visible.</div>
- </div>
- <div class="settings-item-right">
- <div class="settings-item-group">
- <div class="settings-item-group-item">
- <div class="settings-item-group-item-label">Visibility</div>
- <select data-setting="general.popupActionBarVisibility" class="short-width short-height">
- <option value="auto">Auto</option>
- <option value="always">Always</option>
- </select>
- </div>
- <div class="settings-item-group-item">
- <div class="settings-item-group-item-label">Location</div>
- <select data-setting="general.popupActionBarLocation" class="short-width short-height">
- <option value="left">Left</option>
- <option value="right">Right</option>
- <option value="top">Top</option>
- <option value="bottom">Bottom</option>
- </select>
- </div>
- </div>
- </div>
- </div>
- </div>
- <div class="settings-item"><div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-label">Compact glossaries</div>
- <div class="settings-item-description">Display term glossaries using a more compact layout.</div>
- </div>
- <div class="settings-item-right">
- <label class="toggle"><input type="checkbox" data-setting="general.glossaryLayoutMode"
- data-transform='[
- {
- "step": "pre",
- "type": "conditionalConvert",
- "cases": [
- {"op": "===", "value": false, "result": "default"},
- {"op": "===", "value": true, "result": "compact"},
- {"default": true, "result": "default"}
- ]
- },
- {
- "step": "post",
- "type": "conditionalConvert",
- "cases": [
- {"op": "===", "value": "default", "result": false},
- {"op": "===", "value": "compact", "result": true},
- {"default": true, "result": false}
- ]
- }
- ]'
- ><span class="toggle-body"><span class="toggle-track"></span><span class="toggle-knob"></span></span></label>
- </div>
- </div></div>
- <div class="settings-item"><div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-label">Compact tags</div>
- <div class="settings-item-description">Show fewer repeated tags for term glossaries.</div>
- </div>
- <div class="settings-item-right">
- <label class="toggle"><input type="checkbox" data-setting="general.compactTags"><span class="toggle-body"><span class="toggle-track"></span><span class="toggle-knob"></span></span></label>
- </div>
- </div></div>
- <div class="settings-item advanced-only"><div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-label">Show tags for expressions and their readings</div>
- <div class="settings-item-description">These tags can be scanned if the options for popup content scanning are enabled.</div>
- </div>
- <div class="settings-item-right">
- <label class="toggle"><input type="checkbox" data-setting="scanning.enableSearchTags"><span class="toggle-body"><span class="toggle-track"></span><span class="toggle-knob"></span></span></label>
- </div>
- </div></div>
- <div class="settings-item advanced-only"><div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-label">Show debug information</div>
- <div class="settings-item-description">A link to log debugging information will be shown in the search results.</div>
- </div>
- <div class="settings-item-right">
- <label class="toggle"><input type="checkbox" data-setting="general.debugInfo"><span class="toggle-body"><span class="toggle-track"></span><span class="toggle-knob"></span></span></label>
- </div>
- </div></div>
- <div class="settings-item advanced-only">
- <div class="settings-item-inner settings-item-inner-wrappable">
- <div class="settings-item-left">
- <div class="settings-item-label">Selection indicator style</div>
- <div class="settings-item-description">Change how the selected definition entry is visually indicated.</div>
- </div>
- <div class="settings-item-right">
- <select data-setting="general.popupCurrentIndicatorMode">
- <option value="none">None</option>
- <option value="asterisk">Asterisk</option>
- <option value="triangle">Triangle</option>
- <option value="bar-left">Vertical bar (left)</option>
- <option value="bar-right">Vertical bar (right)</option>
- <option value="dot-left">Small dot (left)</option>
- <option value="dot-right">Small dot (right)</option>
- </select>
- </div>
- </div>
- </div>
- <div class="settings-item advanced-only">
- <div class="settings-item-inner settings-item-inner-wrappable">
- <div class="settings-item-left">
- <div class="settings-item-label">
- Pitch accent display styles
- <a class="more-toggle more-only" data-parent-distance="4">(?)</a>
- </div>
- </div>
- <div class="settings-item-right flex-row-wrap">
- <div class="settings-item-group settings-item-group-wrap">
- <label class="settings-item-group-item flex-label no-wrap">
- <label class="checkbox"><input type="checkbox" data-setting="general.showPitchAccentDownstepNotation"><span class="checkbox-body"><span class="checkbox-fill"></span><span class="checkbox-border"></span><span class="checkbox-check"></span></span></label>
- <span>Downstep notation</span>
- </label>
- <label class="settings-item-group-item flex-label no-wrap">
- <label class="checkbox"><input type="checkbox" data-setting="general.showPitchAccentPositionNotation"><span class="checkbox-body"><span class="checkbox-fill"></span><span class="checkbox-border"></span><span class="checkbox-check"></span></span></label>
- <span>Downstep position</span>
- </label>
- <label class="settings-item-group-item flex-label no-wrap">
- <label class="checkbox"><input type="checkbox" data-setting="general.showPitchAccentGraph"><span class="checkbox-body"><span class="checkbox-fill"></span><span class="checkbox-border"></span><span class="checkbox-check"></span></span></label>
- <span>Graph</span>
- </label>
- </div>
- </div>
- </div>
- <div class="settings-item-children more" hidden>
- <p>
- Pitch accents for terms and expressions can be shown if a dictionary supporting pitch accents is installed.
- There are currently three different ways that pitch accents can be presented:
- </p>
- <iframe data-src="/bg/pitch-accents-preview.html" id="pitch-accents-preview-frame" class="defer-load-iframe" data-parent-distance="1"></iframe>
- <p>
- <a class="more-toggle" data-parent-distance="3">Less&hellip;</a>
- </p>
- </div>
- </div>
- <div class="settings-item settings-item-button" data-modal-action="show,custom-css"><div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-label">Configure custom CSS&hellip;</div>
- </div>
- <div class="settings-item-right open-panel-button-container">
- <button class="icon-button"><span class="icon-button-inner"><span class="icon" data-icon="material-right-arrow"></span></span></button>
- </div>
- </div></div>
- </div>
-
- <!-- Popup Position & Size -->
- <div class="heading-container">
- <div class="heading-container-icon"><span class="icon" data-icon="popup-size"></span></div>
- <div class="heading-container-left"><h2 id="popup-size"><a href="#!popup-size">Popup Position &amp; Size</a></h2></div>
- </div>
- <div class="settings-group">
- <div class="settings-item">
- <div class="settings-item-inner settings-item-inner-wrappable">
- <div class="settings-item-left">
- <div class="settings-item-label">Display mode</div>
- <div class="settings-item-description">
- Change the layout of the popup.
- <a class="more-toggle more-only" data-parent-distance="4">More&hellip;</a>
- </div>
- </div>
- <div class="settings-item-right">
- <select data-setting="general.popupDisplayMode">
- <option value="default">Default</option>
- <option value="full-width">Full width</option>
- </select>
- </div>
- </div>
- <div class="settings-item-children more" hidden>
- <p>
- The <em>Default</em> mode will position the popup relative to the scanned text.
- The <em>Full Width</em> mode will anchor the popup to the top or bottom of the screen and take up
- the full width of the screen, which can be useful on devices with touch screens.
- </p>
- <p>
- <a class="more-toggle" data-parent-distance="3">Less&hellip;</a>
- </p>
- </div>
- </div>
- <div class="settings-item">
- <div class="settings-item-inner settings-item-inner-wrappable">
- <div class="settings-item-left">
- <div class="settings-item-label">Scale</div>
- <div class="settings-item-description">Control the scaling factor of the popup.</div>
- </div>
- <div class="settings-item-right">
- <select data-setting="general.popupScalingFactor"
- data-transform='[
- {"type": "toNumber", "step": "pre", "constraints": {"min": 0.25}},
- {"type": "toString", "step": "post"}
- ]'
- >
- <option value="0.25">25%</option>
- <option value="0.33">33%</option>
- <option value="0.5">50%</option>
- <option value="0.67">67%</option>
- <option value="0.75">75%</option>
- <option value="0.8">80%</option>
- <option value="0.9">90%</option>
- <option value="1">100%</option>
- <option value="1.1">110%</option>
- <option value="1.25">125%</option>
- <option value="1.5">150%</option>
- <option value="1.75">175%</option>
- <option value="2">200%</option>
- <option value="2.5">250%</option>
- <option value="3">300%</option>
- <option value="4">400%</option>
- <option value="5">500%</option>
- </select>
- </div>
- </div>
- <div class="settings-item-children settings-item-children-group advanced-only">
- <div class="settings-item">
- <div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-label">
- Auto-scale
- <a class="more-toggle more-only" data-parent-distance="4">(?)</a>
- </div>
- </div>
- <div class="settings-item-right flex-row-wrap">
- <div class="settings-item-group settings-item-group-wrap">
- <label class="settings-item-group-item flex-label no-wrap">
- <label class="checkbox"><input type="checkbox" data-setting="general.popupScaleRelativeToPageZoom"><span class="checkbox-body"><span class="checkbox-fill"></span><span class="checkbox-border"></span><span class="checkbox-check"></span></span></label>
- <span>Zoom level</span>
- </label>
- <label class="settings-item-group-item flex-label no-wrap">
- <label class="checkbox"><input type="checkbox" data-setting="general.popupScaleRelativeToVisualViewport"><span class="checkbox-body"><span class="checkbox-fill"></span><span class="checkbox-border"></span><span class="checkbox-check"></span></span></label>
- <span>Viewport</span>
- </label>
- </div>
- </div>
- </div>
- <div class="settings-item-children more" hidden>
- <p>
- Auto-scaling will scale the popup automatically based on the browser's zoom levels
- in order to keep the popup at a constant physical size, regardless of the zoom level.
- <em>Zoom level</em> uses the zoom level that is typically used on desktop browsers,
- and <em>Viewport</em> uses the zoom level that is typically used on mobile browsers.
- </p>
- <p>
- <a class="more-toggle" data-parent-distance="3">Less&hellip;</a>
- </p>
- </div>
- </div>
- </div>
- </div>
- <div class="settings-item"><div class="settings-item-inner settings-item-inner-wrappable">
- <div class="settings-item-left">
- <div class="settings-item-label">Size</div>
- <div class="settings-item-description">Control the size of the popup, in pixels.</div>
- </div>
- <div class="settings-item-right">
- <div class="settings-item-group">
- <div class="settings-item-group-item">
- <div class="settings-item-group-item-label">Width</div>
- <input type="number" class="short-width short-height" min="1" data-setting="general.popupWidth">
- </div>
- <div class="settings-item-group-item">
- <div class="settings-item-group-item-label">Height</div>
- <input type="number" class="short-width short-height" min="1" data-setting="general.popupHeight">
- </div>
- </div>
- </div>
- </div></div>
- <div class="settings-item advanced-only"><div class="settings-item-inner settings-item-inner-wrappable">
- <div class="settings-item-left">
- <div class="settings-item-label">Horizontal text positioning</div>
- <div class="settings-item-description">Change where the popup is positioned relative to horizontal text.</div>
- </div>
- <div class="settings-item-right">
- <select data-setting="general.popupHorizontalTextPosition">
- <option value="below">Below text</option>
- <option value="above">Above text</option>
- </select>
- </div>
- </div></div>
- <div class="settings-item advanced-only"><div class="settings-item-inner settings-item-inner-wrappable">
- <div class="settings-item-left">
- <div class="settings-item-label">Vertical text positioning</div>
- <div class="settings-item-description">Change where the popup is positioned relative to vertical text.</div>
- </div>
- <div class="settings-item-right">
- <select data-setting="general.popupVerticalTextPosition">
- <option value="default">Same as horizontal text</option>
- <option value="before">Before reading direction</option>
- <option value="after">After reading direction</option>
- <option value="left">Left of text</option>
- <option value="right">Right of text</option>
- </select>
- </div>
- </div></div>
- <div class="settings-item advanced-only"><div class="settings-item-inner settings-item-inner-wrappable">
- <div class="settings-item-left">
- <div class="settings-item-label">Horizontal text offset</div>
- <div class="settings-item-description">Change the distance the popup is placed relative to horizontal text.</div>
- </div>
- <div class="settings-item-right">
- <div class="settings-item-group">
- <div class="settings-item-group-item">
- <div class="settings-item-group-item-label">x</div>
- <input type="number" class="short-width short-height" data-setting="general.popupHorizontalOffset">
- </div>
- <div class="settings-item-group-item">
- <div class="settings-item-group-item-label">y</div>
- <input type="number" class="short-width short-height" data-setting="general.popupVerticalOffset">
- </div>
- </div>
- </div>
- </div></div>
- <div class="settings-item advanced-only"><div class="settings-item-inner settings-item-inner-wrappable">
- <div class="settings-item-left">
- <div class="settings-item-label">Vertical text offset</div>
- <div class="settings-item-description">Change the distance the popup is placed relative to vertical text.</div>
- </div>
- <div class="settings-item-right">
- <div class="settings-item-group">
- <div class="settings-item-group-item">
- <div class="settings-item-group-item-label">x</div>
- <input type="number" class="short-width short-height" data-setting="general.popupHorizontalOffset2">
- </div>
- <div class="settings-item-group-item">
- <div class="settings-item-group-item-label">y</div>
- <input type="number" class="short-width short-height" data-setting="general.popupVerticalOffset2">
- </div>
- </div>
- </div>
- </div></div>
- </div>
-
- <!-- Window -->
- <div class="heading-container advanced-only">
- <div class="heading-container-icon"><span class="icon" data-icon="window"></span></div>
- <div class="heading-container-left"><h2 id="window"><a href="#!window">Window</a></h2></div>
- <div class="heading-container-right"><a class="heading-link-light" id="test-window-open-link">Open&hellip;</a></div>
- </div>
- <div class="settings-group advanced-only">
- <div class="settings-item">
- <div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-label">
- Use a native browser window instead of an embedded popup
- <a class="more-toggle more-only" data-parent-distance="4">(?)</a>
- </div>
- </div>
- <div class="settings-item-right">
- <label class="toggle"><input type="checkbox" data-setting="general.usePopupWindow"><span class="toggle-body"><span class="toggle-track"></span><span class="toggle-knob"></span></span></label>
- </div>
- </div>
- <div class="settings-item-children more" hidden>
- <p>
- Instead of showing definitions in a popup embedded into the webpage,
- a native browser window containing the popup content will be opened instead.
- This window will be shared across all tabs.
- </p>
- <p>
- <a class="more-toggle" data-parent-distance="3">Less&hellip;</a>
- </p>
- </div>
- </div>
- <div class="settings-item"><div class="settings-item-inner settings-item-inner-wrappable">
- <div class="settings-item-left">
- <div class="settings-item-label">Size</div>
- <div class="settings-item-description">Control the size of the window, in pixels.</div>
- </div>
- <div class="settings-item-right">
- <div class="settings-item-group">
- <div class="settings-item-group-item">
- <div class="settings-item-group-item-label">Width</div>
- <input type="number" class="short-width short-height" min="0" step="1" data-setting="popupWindow.width">
- </div>
- <div class="settings-item-group-item">
- <div class="settings-item-group-item-label">Height</div>
- <input type="number" class="short-width short-height" min="0" step="1" data-setting="popupWindow.height">
- </div>
- </div>
- </div>
- </div></div>
- <div class="settings-item"><div class="settings-item-inner settings-item-inner-wrappable">
- <div class="settings-item-left">
- <div class="settings-item-label">Left position</div>
- <div class="settings-item-description">Control the left position of the window, in pixels.</div>
- </div>
- <div class="settings-item-right">
- <div class="settings-item-group">
- <div class="settings-item-group-item" id="popup-window-left-container" hidden>
- <div class="settings-item-group-item-label">x</div>
- <input type="number" class="short-width short-height" step="1" data-setting="popupWindow.left">
- </div>
- <div class="settings-item-group-item">
- <div class="settings-item-group-item-label">Mode</div>
- <select class="short-width short-height" data-setting="popupWindow.useLeft"
- data-transform='[
- {
- "step": "pre",
- "type": "toBoolean"
- },
- {
- "type": "setVisibility",
- "selector": "#popup-window-left-container",
- "condition": {"op": "===", "value": true}
- },
- {
- "step": "post",
- "type": "toString"
- }
- ]'
- >
- <option value="false">Auto</option>
- <option value="true">Manual</option>
- </select>
- </div>
- </div>
- </div>
- </div></div>
- <div class="settings-item"><div class="settings-item-inner settings-item-inner-wrappable">
- <div class="settings-item-left">
- <div class="settings-item-label">Top position</div>
- <div class="settings-item-description">Control the top position of the window, in pixels.</div>
- </div>
- <div class="settings-item-right">
- <div class="settings-item-group">
- <div class="settings-item-group-item" id="popup-window-top-container" hidden>
- <div class="settings-item-group-item-label">y</div>
- <input type="number" class="short-width short-height" step="1" data-setting="popupWindow.top">
- </div>
- <div class="settings-item-group-item">
- <div class="settings-item-group-item-label">Mode</div>
- <select class="short-width short-height" data-setting="popupWindow.useTop"
- data-transform='[
- {
- "step": "pre",
- "type": "toBoolean"
- },
- {
- "type": "setVisibility",
- "selector": "#popup-window-top-container",
- "condition": {"op": "===", "value": true}
- },
- {
- "step": "post",
- "type": "toString"
- }
- ]'
- >
- <option value="false">Auto</option>
- <option value="true">Manual</option>
- </select>
- </div>
- </div>
- </div>
- </div></div>
- <div class="settings-item"><div class="settings-item-inner settings-item-inner-wrappable">
- <div class="settings-item-left">
- <div class="settings-item-label">Window style</div>
- <div class="settings-item-description">Change the appearance of the window.</div>
- </div>
- <div class="settings-item-right">
- <div class="settings-item-group">
- <div class="settings-item-group-item">
- <div class="settings-item-group-item-label">Type</div>
- <select class="short-width short-height" data-setting="popupWindow.windowType">
- <option value="normal">Normal</option>
- <option value="popup">Popup</option>
- </select>
- </div>
- <div class="settings-item-group-item">
- <div class="settings-item-group-item-label">State</div>
- <select class="short-width short-height" data-setting="popupWindow.windowState">
- <option value="normal">Normal</option>
- <option value="maximized">Maximized</option>
- <option value="fullscreen">Fullscreen</option>
- </select>
- </div>
- </div>
- </div>
- </div></div>
- </div>
-
- <!-- Audio -->
- <div class="heading-container">
- <div class="heading-container-icon"><span class="icon" data-icon="speaker"></span></div>
- <div class="heading-container-left"><h2 id="audio"><a href="#!audio">Audio</a></h2></div>
- </div>
- <div class="settings-group">
- <div class="settings-item"><div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-label">Enable audio playback for terms</div>
- <div class="settings-item-description">Show a clickable speaker icon next to search results.</div>
- </div>
- <div class="settings-item-right">
- <label class="toggle"><input type="checkbox" data-setting="audio.enabled"><span class="toggle-body"><span class="toggle-track"></span><span class="toggle-knob"></span></span></label>
- </div>
- </div></div>
- <div class="settings-item"><div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-label">Auto-play search result audio</div>
- <div class="settings-item-description">The audio for the first result will be played automatically.</div>
- </div>
- <div class="settings-item-right">
- <label class="toggle"><input type="checkbox" data-setting="audio.autoPlay"><span class="toggle-body"><span class="toggle-track"></span><span class="toggle-knob"></span></span></label>
- </div>
- </div></div>
- <div class="settings-item"><div class="settings-item-inner settings-item-inner-wrappable">
- <div class="settings-item-left">
- <div class="settings-item-label">Audio volume</div>
- <div class="settings-item-description">Adjust the volume audio is played at, in percent.</div>
- </div>
- <div class="settings-item-right">
- <input type="number" data-setting="audio.volume" min="0" max="100">
- </div>
- </div></div>
- <div class="settings-item settings-item-button" data-modal-action="show,audio-sources"><div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-label">Configure audio playback sources&hellip;</div>
- </div>
- <div class="settings-item-right open-panel-button-container">
- <button class="icon-button"><span class="icon-button-inner"><span class="icon" data-icon="material-right-arrow"></span></span></button>
- </div>
- </div></div>
- </div>
-
- <!-- Text Parsing -->
- <div>
- <div class="heading-container">
- <div class="heading-container-icon"><span class="icon" data-icon="text-parsing"></span></div>
- <div class="heading-container-left"><h2 id="text-parsing"><a href="#!text-parsing">Text Parsing</a></h2></div>
- <div class="heading-container-right"><a class="more-toggle more-only heading-link-light" data-parent-distance="3">Info&hellip;</a></div>
- </div>
- <div class="heading-description more" hidden>
- <p>
- Yomichan can attempt to parse entire sentences or longer text blocks on the search page,
- adding furigana above words and optional space between words.
- </p>
- <p>
- <a class="more-toggle" data-parent-distance="3">Less&hellip;</a>
- </p>
- </div>
- </div>
- <div class="settings-group">
- <div class="settings-item"><div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-label">Parse text using installed dictionaries</div>
- <div class="settings-item-description">Words are scanned by automatically advancing in the sentence after a matching word.</div>
- </div>
- <div class="settings-item-right">
- <label class="toggle"><input type="checkbox" data-setting="parsing.enableScanningParser"><span class="toggle-body"><span class="toggle-track"></span><span class="toggle-knob"></span></span></label>
- </div>
- </div></div>
- <div class="settings-item advanced-only">
- <div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-invalid-indicator"></div>
- <div class="settings-item-label">Parse text using <a href="https://en.wikipedia.org/wiki/MeCab" target="_blank" rel="noopener noreferrer">MeCab</a></div>
- <div class="settings-item-description">
- Requires a native component to be installed that Yomichan will connect to.
- <a class="more-toggle more-only" data-parent-distance="4">More&hellip;</a>
- </div>
- </div>
- <div class="settings-item-right">
- <label class="toggle"><input type="checkbox" class="permissions-toggle" data-permissions-setting="parsing.enableMecabParser" data-required-permissions="nativeMessaging"><span class="toggle-body"><span class="toggle-track"></span><span class="toggle-knob"></span></span></label>
- </div>
- </div>
- <div class="settings-item-children more" hidden>
- <p>
- MeCab is a third-party program which uses its own dictionaries and parsing algorithm to decompose sentences into individual words.
- In order for Yomichan to use it, both MeCab and a native messaging component must be installed.
- A setup guide can be found <a href="https://github.com/siikamiika/yomichan-mecab-installer/blob/master/README.md" target="_blank" rel="noopener noreferrer">here</a>.
- </p>
- <div class="margin-above flex-row-nowrap">
- <button id="test-mecab-button">Test</button>
- <div id="test-mecab-results" class="flex-margin-left" hidden></div>
- </div>
- <p class="margin-above">
- <a class="more-toggle" data-parent-distance="3">Less&hellip;</a>
- </p>
- </div>
- </div>
- <div class="settings-item"><div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-label">Show space between parsed words</div>
- </div>
- <div class="settings-item-right">
- <label class="toggle"><input type="checkbox" data-setting="parsing.termSpacing"><span class="toggle-body"><span class="toggle-track"></span><span class="toggle-knob"></span></span></label>
- </div>
- </div></div>
- <div class="settings-item"><div class="settings-item-inner settings-item-inner-wrappable">
- <div class="settings-item-left">
- <div class="settings-item-label">Reading mode</div>
- <div class="settings-item-description">Change what type of furigana is displayed for parsed text.</div>
- </div>
- <div class="settings-item-right">
- <select data-setting="parsing.readingMode" lang="ja">
- <option value="none">None</option>
- <option value="hiragana">ひらがな</option>
- <option value="katakana">カタカナ</option>
- <option value="romaji">Romaji</option>
- </select>
- </div>
- </div></div>
- </div>
-
- <!-- Text Parsing -->
- <div class="advanced-only">
- <div class="heading-container">
- <div class="heading-container-icon"><span class="icon" data-icon="sentence-parsing"></span></div>
- <div class="heading-container-left"><h2 id="sentence-parsing"><a href="#!sentence-parsing">Sentence Parsing</a></h2></div>
- <div class="heading-container-right"><a class="more-toggle more-only heading-link-light" data-parent-distance="3">Info&hellip;</a></div>
- </div>
- <div class="heading-description more" hidden>
- <p>
- Yomichan can scan and parse sentences which can be used as contextual information for Anki cards.
- </p>
- <p>
- <a class="more-toggle" data-parent-distance="3">Less&hellip;</a>
- </p>
- </div>
- </div>
- <div class="settings-group advanced-only">
- <div class="settings-item"><div class="settings-item-inner settings-item-inner-wrappable">
- <div class="settings-item-left">
- <div class="settings-item-label">Sentence scanning extent</div>
- <div class="settings-item-description">Adjust how many characters are bidirectionally scanned to form a sentence.</div>
- </div>
- <div class="settings-item-right">
- <input type="number" data-setting="sentenceParsing.scanExtent" min="0" step="1">
- </div>
- </div></div>
- <div class="settings-item"><div class="settings-item-inner settings-item-inner-wrappable">
- <div class="settings-item-left">
- <div class="settings-item-label">Enable sentence termination characters</div>
- </div>
- <div class="settings-item-right">
- <label class="toggle"><input type="checkbox" data-setting="sentenceParsing.enableTerminationCharacters"><span class="toggle-body"><span class="toggle-track"></span><span class="toggle-knob"></span></span></label>
- </div>
- </div></div>
- <div class="settings-item settings-item-button" data-modal-action="show,sentence-termination-characters"><div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-label">Configure sentence termination characters&hellip;</div>
- </div>
- <div class="settings-item-right open-panel-button-container">
- <button class="icon-button"><span class="icon-button-inner"><span class="icon" data-icon="material-right-arrow"></span></span></button>
- </div>
- </div></div>
- </div>
-
- <!-- Translation -->
- <div class="advanced-only">
- <div class="heading-container">
- <div class="heading-container-icon"><span class="icon" data-icon="translation"></span></div>
- <div class="heading-container-left"><h2 id="translation"><a href="#!translation">Translation</a></h2></div>
- <div class="heading-container-right"><a class="more-toggle more-only heading-link-light" data-parent-distance="3">Info&hellip;</a></div>
- </div>
- <div class="heading-description more" hidden>
- <p>
- The following options are used during the translation process to create alternate versions of the input text to search for.
- This can be helpful when the input text doesn't exactly match the term or expression found in the database.
- </p>
- <p>
- The conversion options below are listed in the order that the conversions are applied to the input text.
- Most of the conversions have three possible values:
- </p>
- <ul>
- <li>
- <strong>Disabled</strong> -
- This conversion will never be applied to the input text.
- </li>
- <li>
- <strong>Enabled</strong> -
- This conversion will always be applied to the input text.
- </li>
- <li>
- <strong>Use both variants</strong> -
- The translator will check the database for two variations: the raw input text and the converted input text.
- When multiple options use variants, the translator will search for combinations of the converted text.
- </li>
- </ul>
- <p>
- <a class="more-toggle" data-parent-distance="3">Less&hellip;</a>
- </p>
- </div>
- </div>
- <div class="settings-group advanced-only">
- <div class="settings-item settings-item-button" data-modal-action="show,translation-text-replacement-patterns"><div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-label">Configure custom text replacement patterns&hellip;</div>
- </div>
- <div class="settings-item-right open-panel-button-container">
- <button class="icon-button"><span class="icon-button-inner"><span class="icon" data-icon="material-right-arrow"></span></span></button>
- </div>
- </div></div>
- <div class="settings-item"><div class="settings-item-inner settings-item-inner-wrappable">
- <div class="settings-item-left">
- <div class="settings-item-label">Convert half width characters to full width</div>
- <div class="settings-item-description" lang="ja">ヨミチャン&#x3000;&rarr;&#x3000;ヨミチャン</div>
- </div>
- <div class="settings-item-right">
- <select data-setting="translation.convertHalfWidthCharacters">
- <option value="false">Disabled</option>
- <option value="true">Enabled</option>
- <option value="variant">Use both variants</option>
- </select>
- </div>
- </div></div>
- <div class="settings-item"><div class="settings-item-inner settings-item-inner-wrappable">
- <div class="settings-item-left">
- <div class="settings-item-label">Convert numeric characters to full width</div>
- <div class="settings-item-description" lang="ja">1234&#x3000;&rarr;&#x3000;1234</div>
- </div>
- <div class="settings-item-right">
- <select data-setting="translation.convertNumericCharacters">
- <option value="false">Disabled</option>
- <option value="true">Enabled</option>
- <option value="variant">Use both variants</option>
- </select>
- </div>
- </div></div>
- <div class="settings-item"><div class="settings-item-inner settings-item-inner-wrappable">
- <div class="settings-item-left">
- <div class="settings-item-label">Convert alphabetic characters to hiragana</div>
- <div class="settings-item-description" lang="ja">yomichan&#x3000;&rarr;&#x3000;よみちゃん</div>
- </div>
- <div class="settings-item-right">
- <select data-setting="translation.convertAlphabeticCharacters">
- <option value="false">Disabled</option>
- <option value="true">Enabled</option>
- <option value="variant">Use both variants</option>
- </select>
- </div>
- </div></div>
- <div class="settings-item"><div class="settings-item-inner settings-item-inner-wrappable">
- <div class="settings-item-left">
- <div class="settings-item-label">Convert hiragana to katakana</div>
- <div class="settings-item-description" lang="ja">よみちゃん&#x3000;&rarr;&#x3000;ヨミチャン</div>
- </div>
- <div class="settings-item-right">
- <select data-setting="translation.convertHiraganaToKatakana">
- <option value="false">Disabled</option>
- <option value="true">Enabled</option>
- <option value="variant">Use both variants</option>
- </select>
- </div>
- </div></div>
- <div class="settings-item"><div class="settings-item-inner settings-item-inner-wrappable">
- <div class="settings-item-left">
- <div class="settings-item-label">Convert katakana to hiragana</div>
- <div class="settings-item-description" lang="ja">ヨミチャン&#x3000;&rarr;&#x3000;よみちゃん</div>
- </div>
- <div class="settings-item-right">
- <select data-setting="translation.convertKatakanaToHiragana">
- <option value="false">Disabled</option>
- <option value="true">Enabled</option>
- <option value="variant">Use both variants</option>
- </select>
- </div>
- </div></div>
- <div class="settings-item"><div class="settings-item-inner settings-item-inner-wrappable">
- <div class="settings-item-left">
- <div class="settings-item-label">Collapse emphatic character sequences</div>
- <div class="settings-item-description" lang="ja">すっっごーーい&#x3000;&rarr;&#x3000;すっごーい / すごい</div>
- </div>
- <div class="settings-item-right">
- <select data-setting="translation.collapseEmphaticSequences">
- <option value="false">Disabled</option>
- <option value="true">Collapse into single character</option>
- <option value="full">Remove all characters</option>
- </select>
- </div>
- </div></div>
- </div>
-
- <!-- Anki -->
- <div>
- <div class="heading-container">
- <div class="heading-container-icon"><span class="icon" data-icon="note-card"></span></div>
- <div class="heading-container-left"><h2 id="anki"><a href="#!anki">Anki</a></h2></div>
- <div class="heading-container-right"><a class="more-toggle more-only heading-link-light" data-parent-distance="3">Info&hellip;</a></div>
- </div>
- <div class="heading-description more" hidden>
- <p>
- Yomichan supports automatic flashcard creation for <a href="https://apps.ankiweb.net/" target="_blank" rel="noopener noreferrer">Anki</a>,
- a free application designed to assist in remembering information.
- This feature requires installation of the <a href="https://foosoft.net/projects/anki-connect/" target="_blank" rel="noopener noreferrer">AnkiConnect</a> plugin.
- </p>
- <p>
- <a class="more-toggle" data-parent-distance="3">Less&hellip;</a>
- </p>
- </div>
- </div>
- <div class="settings-group">
- <div class="settings-item">
- <div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-label">Enable Anki integration</div>
- <div class="settings-item-description">
- <span>Connection status:</span>
- <span id="anki-error-message">&hellip;</span> <a id="anki-error-message-details-toggle" hidden>Details&hellip;</a>
- </div>
- </div>
- <div class="settings-item-right">
- <label class="toggle"><input type="checkbox" data-setting="anki.enable"><span class="toggle-body"><span class="toggle-track"></span><span class="toggle-knob"></span></span></label>
- </div>
- </div>
- <div class="settings-item-children" id="anki-error-message-details-container" hidden>
- <p class="danger-text" id="anki-error-invalid-response-info" hidden>
- Attempting to connect to Anki can sometimes return an error message which includes "Invalid response",
- which may indicate that the value of the <em>AnkiConnect server address</em> option is incorrect.
- Resetting it to the default value may fix issues that are occurring.
- </p>
- <div class="danger-text" id="anki-error-message-details"></div>
- </div>
- </div>
- <div class="settings-item">
- <div class="settings-item-inner settings-item-inner-wrappable">
- <div class="settings-item-left">
- <div class="settings-item-label">AnkiConnect server address</div>
- <div class="settings-item-description">
- Change the URL of the AnkiConnect server.
- <a class="more-toggle more-only" data-parent-distance="4">More&hellip;</a>
- </div>
- </div>
- <div class="settings-item-right">
- <input type="text" placeholder="http://127.0.0.1:8765" spellcheck="false" autocomplete="off" data-setting="anki.server">
- </div>
- </div>
- <div class="settings-item-children more" hidden>
- <p>
- The default address for a server on the same device is <a href="http://127.0.0.1:8765" target="_blank" rel="noopener noreferrer">http://127.0.0.1:8765</a>.
- If Anki is running and AnkiConnect is installed, clicking this URL should open a page showing the current version of AnkiConnect.
- </p>
- <p>
- <a class="more-toggle" data-parent-distance="3">Less&hellip;</a>
- </p>
- </div>
- </div>
- <div class="settings-item"><div class="settings-item-inner settings-item-inner-wrappable">
- <div class="settings-item-left">
- <div class="settings-item-label">Card tags</div>
- <div class="settings-item-description">List of space or comma separated tags to add to the card.</div>
- </div>
- <div class="settings-item-right">
- <input type="text" spellcheck="false" autocomplete="off" data-setting="anki.tags"
- data-transform='[
- {"type": "splitTags", "step": "pre"},
- {"type": "joinTags", "step": "post"}
- ]'
- >
- </div>
- </div></div>
- <div class="settings-item advanced-only">
- <div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-label">Check for card duplicates</div>
- <div class="settings-item-description">When a card is detected as a duplicate, the add buttons will be disabled.</div>
- </div>
- <div class="settings-item-right">
- <label class="toggle"><input type="checkbox" data-setting="anki.checkForDuplicates"
- data-transform='{
- "type": "setVisibility",
- "selector": "#anki-card-duplicate-options",
- "condition": {"op": "===", "value": true}
- }'
- ><span class="toggle-body"><span class="toggle-track"></span><span class="toggle-knob"></span></span></label>
- </div>
- </div>
- <div class="settings-item-children settings-item-children-group" id="anki-card-duplicate-options" hidden>
- <div class="settings-item">
- <div class="settings-item-inner settings-item-inner-wrappable">
- <div class="settings-item-left">
- <div class="settings-item-label">
- Duplicate card scope
- <a class="more-toggle more-only" data-parent-distance="4">(?)</a>
- </div>
- </div>
- <div class="settings-item-right">
- <select data-setting="anki.duplicateScope">
- <option value="collection">Collection</option>
- <option value="deck">Deck</option>
- <option value="deck-root">Deck root</option>
- </select>
- </div>
- </div>
- <div class="settings-item-children more" hidden>
- <p>
- A card is considered a duplicate if the value of the first field matches that of any other card.
- By default, this check will include cards across all decks in a collection, but this constraint can be relaxed
- by using either the <em>Deck</em> or <em>Deck root</em> option.
- </p>
- <p>
- The <em>Deck</em> option will only check for duplicates in the target deck.
- The <em>Deck root</em> option will additionally check for duplicates in all child decks of the root deck.
- This allows adding cards that are unique for decks including a subdeck structure.
- For decks which don't have any parent-child hierarchy, both options function the same.
- </p>
- <p>
- <a class="more-toggle" data-parent-distance="3">Less&hellip;</a>
- </p>
- </div>
- </div>
- </div>
- </div>
- <div class="settings-item advanced-only"><div class="settings-item-inner settings-item-inner-wrappable">
- <div class="settings-item-left">
- <div class="settings-item-label">Screenshot format</div>
- <div class="settings-item-description">Adjust the format and quality of screenshots created for cards.</div>
- </div>
- <div class="settings-item-right">
- <div class="settings-item-group">
- <div class="settings-item-group-item" id="anki-screenshot-quality" hidden>
- <div class="settings-item-group-item-label">Quality (%)</div>
- <input type="number" class="short-width short-height" data-setting="anki.screenshot.quality" min="0" max="100" step="1">
- </div>
- <div class="settings-item-group-item">
- <div class="settings-item-group-item-label">Format</div>
- <select class="short-width short-height" data-setting="anki.screenshot.format"
- data-transform='{
- "type": "setVisibility",
- "selector": "#anki-screenshot-quality",
- "condition": {"op": "===", "value": "jpeg"}
- }'
- >
- <option value="png">PNG</option>
- <option value="jpeg">JPEG</option>
- </select>
- </div>
- </div>
- </div>
- </div></div>
-
- <div class="settings-item advanced-only"><div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-label">Suspend new cards</div>
- <div class="settings-item-description">New cards will be suspended when a note is added.</div>
- </div>
- <div class="settings-item-right">
- <label class="toggle"><input type="checkbox" data-setting="anki.suspendNewCards"><span class="toggle-body"><span class="toggle-track"></span><span class="toggle-knob"></span></span></label>
- </div>
- </div></div>
- <div class="settings-item settings-item-button" data-modal-action="show,anki-cards"><div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-label">Configure Anki card format&hellip;</div>
- </div>
- <div class="settings-item-right open-panel-button-container">
- <button class="icon-button"><span class="icon-button-inner"><span class="icon" data-icon="material-right-arrow"></span></span></button>
- </div>
- </div></div>
- <div class="settings-item settings-item-button advanced-only" data-modal-action="show,anki-card-templates"><div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-label">Configure Anki card templates&hellip;</div>
- </div>
- <div class="settings-item-right open-panel-button-container">
- <button class="icon-button"><span class="icon-button-inner"><span class="icon" data-icon="material-right-arrow"></span></span></button>
- </div>
- </div></div>
- </div>
-
- <!-- Clipboard -->
- <div>
- <div class="heading-container">
- <div class="heading-container-icon"><span class="icon" data-icon="clipboard"></span></div>
- <div class="heading-container-left"><h2 id="clipboard"><a href="#!clipboard">Clipboard</a></h2></div>
- <div class="heading-container-right"><a class="more-toggle more-only heading-link-light" data-parent-distance="3">Info&hellip;</a></div>
- </div>
- <div class="heading-description more" hidden>
- <p>
- Yomichan can watch the system copy clipboard for Japanese text and automatically search the
- text on the search page.
- This can be useful for using Yomichan to scan text from external applications.
- </p>
- <p>
- This feature requires Yomichan to have clipboard reading permissions, and when this option is enabled,
- the clipboard will be frequently checked for new text.
- </p>
- <p>
- <a class="more-toggle" data-parent-distance="3">Less&hellip;</a>
- </p>
- </div>
- </div>
- <div class="settings-group">
- <div class="settings-item"><div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-invalid-indicator"></div>
- <div class="settings-item-label">Enable background clipboard text monitoring</div>
- <div class="settings-item-description">Open the search page in a new window when the clipboard contains Japanese text.</div>
- </div>
- <div class="settings-item-right">
- <label class="toggle"><input type="checkbox" class="permissions-toggle" data-permissions-setting="clipboard.enableBackgroundMonitor" data-required-permissions="clipboardRead"><span class="toggle-body"><span class="toggle-track"></span><span class="toggle-knob"></span></span></label>
- </div>
- </div></div>
- <div class="settings-item"><div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-invalid-indicator"></div>
- <div class="settings-item-label">Enable search page clipboard text monitoring</div>
- <div class="settings-item-description">The query on the search page will be automatically updated with text in the clipboard.</div>
- </div>
- <div class="settings-item-right">
- <label class="toggle"><input type="checkbox" class="permissions-toggle" data-permissions-setting="clipboard.enableSearchPageMonitor" data-required-permissions="clipboardRead"><span class="toggle-body"><span class="toggle-track"></span><span class="toggle-knob"></span></span></label>
- </div>
- </div></div>
- <div class="settings-item"><div class="settings-item-inner settings-item-inner-wrappable">
- <div class="settings-item-left">
- <div class="settings-item-label">Maximum clipboard text search length</div>
- <div class="settings-item-description">Limit the number of characters used when searching clipboard text.</div>
- </div>
- <div class="settings-item-right">
- <input type="number" min="0" step="1" data-setting="clipboard.maximumSearchLength">
- </div>
- </div></div>
- <div class="settings-item"><div class="settings-item-inner settings-item-inner-wrappable">
- <div class="settings-item-left">
- <div class="settings-item-label">Clipboard text search mode</div>
- <div class="settings-item-description">Change how the search page reacts to new text in the clipboard.</div>
- </div>
- <div class="settings-item-right">
- <select data-setting="clipboard.autoSearchContent"
- data-transform='[
- {
- "step": "pre",
- "type": "toBoolean"
- },
- {
- "step": "post",
- "type": "toString"
- }
- ]'
- >
- <option value="true">Search for definitions</option>
- <option value="false">Update query only</option>
- </select>
- </div>
- </div></div>
- </div>
-
- <!-- Shortcuts -->
- <div class="heading-container">
- <div class="heading-container-icon"><span class="icon" data-icon="keyboard"></span></div>
- <div class="heading-container-left"><h2 id="shortcuts"><a href="#!shortcuts">Shortcuts</a></h2></div>
- </div>
- <div class="settings-group">
- <div class="settings-item"><div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-label">
- <p>
- Yomichan has two categories of keyboard shortcuts:
- </p>
- <ul>
- <li>
- <strong>Standard</strong> keyboard shortcuts are controlled by the extension, and can be added, removed,
- and configured to work on webpages that Yomichan functions on.
- </li>
- <li>
- <strong>Native</strong> keyboard shortcuts are controlled by the web browser, and function globally
- within the web browser<span data-show-for-browser="chrome edge"> or system-wide</span>.
- </li>
- </ul>
- </div>
- </div>
- </div></div>
- <div class="settings-item settings-item-button" data-modal-action="show,keyboard-shortcuts"><div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-label">Configure standard keyboard shortcuts&hellip;</div>
- </div>
- <div class="settings-item-right open-panel-button-container">
- <button class="icon-button"><span class="icon-button-inner"><span class="icon" data-icon="material-right-arrow"></span></span></button>
- </div>
- </div></div>
- <div class="settings-item settings-item-button" data-modal-action="show,extension-keyboard-shortcuts"><div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-label">Configure native keyboard shortcuts&hellip;</div>
- </div>
- <div class="settings-item-right open-panel-button-container">
- <button class="icon-button"><span class="icon-button-inner"><span class="icon" data-icon="material-right-arrow"></span></span></button>
- </div>
- </div></div>
- </div>
-
- <!-- Backup -->
- <div class="heading-container">
- <div class="heading-container-icon"><span class="icon" data-icon="backup"></span></div>
- <div class="heading-container-left"><h2 id="backup"><a href="#!backup">Backup</a></h2></div>
- </div>
- <div class="settings-group">
- <div class="settings-item"><div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-label">
- Yomichan can import and export settings files which can be used to restore settings, share settings across devices, and to help to debug problems.
- These files will only contain settings and will not contain dictionaries.
- Dictionaries must be imported separately.
- </div>
- </div>
- </div></div>
- <div class="settings-item"><div class="settings-item-inner">
- <div class="settings-item-right settings-item-button-group-container">
- <div class="settings-item-button-group">
- <div class="settings-item-button-group-item">
- <button class="low-emphasis" id="settings-import-button">Import Settings</button>
- <div hidden><input type="file" id="settings-import-file" accept=".json,application/json"></div>
- </div>
- <div class="settings-item-button-group-item">
- <button class="low-emphasis" id="settings-export-button">Export Settings</button>
- </div>
- <div class="settings-item-button-group-item">
- <button class="low-emphasis danger" id="settings-reset-button">Reset Settings</button>
- </div>
- </div>
- </div>
- </div></div>
- </div>
-
- <!-- Security -->
- <div class="heading-container advanced-only">
- <div class="heading-container-icon"><span class="icon" data-icon="lock"></span></div>
- <div class="heading-container-left"><h2 id="security"><a href="#!security">Security</a></h2></div>
- </div>
- <div class="settings-group advanced-only">
- <div class="settings-item">
- <div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-label">
- Use a secure container around popups
- <a class="more-toggle more-only" data-parent-distance="4">(?)</a>
- </div>
- </div>
- <div class="settings-item-right">
- <label class="toggle"><input type="checkbox" data-setting="general.usePopupShadowDom"><span class="toggle-body"><span class="toggle-track"></span><span class="toggle-knob"></span></span></label>
- </div>
- </div>
- <div class="settings-item-children more" hidden>
- <p>
- On <a href="https://caniuse.com/shadowdomv1" target="_blank" rel="noopener noreferrer">supported browsers</a>,
- a popup's <code>iframe</code> element will be embeded inside of a container with a closed <a href="https://developer.mozilla.org/en-US/docs/Web/Web_Components/Using_shadow_DOM" target="_blank" rel="noopener noreferrer">shadow DOM</a>.
- This container prevents scripts running on the underlying web page from being able to discover the <code>iframe</code>,
- which helps avoid situations where the web page might try to modify or use the Yomichan popup for an unintended purpose.
- </p>
- <p>
- <a class="more-toggle" data-parent-distance="3">Less&hellip;</a>
- </p>
- </div>
- </div>
- <div class="settings-item">
- <div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-label">
- Use secure popup frame URL
- <a class="more-toggle more-only" data-parent-distance="4">(?)</a>
- </div>
- </div>
- <div class="settings-item-right">
- <label class="toggle"><input type="checkbox" data-setting="general.useSecurePopupFrameUrl"><span class="toggle-body"><span class="toggle-track"></span><span class="toggle-knob"></span></span></label>
- </div>
- </div>
- <div class="settings-item-children more" hidden>
- <p>
- When this option is enabled, the URL of the <code>iframe</code> element will be assigned by
- directly changing the location of the <code>iframe</code>'s internal document, rather than using
- the <code>iframe</code>'s <a href="https://developer.mozilla.org/en-US/docs/Web/HTML/Element/iframe#attr-src" target="_blank" rel="noopener noreferrer"><code>src</code></a>
- attribute. This results in the extension URL not being exposed to the underling web page, and thus making it harder
- to detect the presence of Yomichan.
- </p>
- <p>
- <a class="more-toggle" data-parent-distance="3">Less&hellip;</a>
- </p>
- </div>
- </div>
- </div>
-
- <div class="footer-padding"></div>
-
-</div>
-<div class="content-right">
- <div class="preview-sidebar"><div class="preview-sidebar-inner">
- <div class="preview-frame-container">
- <iframe src="/bg/popup-preview.html" class="preview-frame" id="popup-preview-frame"></iframe>
- </div>
- </div></div>
-</div>
-</div></div>
-
-
-<!-- Auxiliary content -->
-<div class="content-dimmer"></div>
-
-<div class="fab-container">
- <div class="fab-container-left"></div>
- <div class="fab-container-center"></div>
- <div class="fab-container-right">
- <div class="fab-container-right-inner1"><div class="fab-container-right-inner2">
- <div class="fab-container-item fab-container-item-popup-preview">
- <button class="fab-button icon-button" data-action="toggle-preview-sidebar"><span class="icon-button-inner"><span class="fab-button-background"></span><span class="icon" data-icon="popup"></span></span></button>
- </div>
- <div class="fab-container-item">
- <button class="fab-button icon-button" data-action="toggle-sidebar"><span class="icon-button-inner"><span class="fab-button-background"></span><span class="icon" data-icon="hamburger-menu"></span></span></button>
- </div>
- </div></div>
- </div>
-</div>
-
-<div class="status-footer-container" hidden><div class="status-footer-container2">
- <div class="status-footer">
- <div class="status-footer-header"><div class="status-footer-header-label">Tasks in progress:</div><a class="status-footer-header-close">Close</a></div>
- <div class="status-footer-item dictionary-delete-progress" hidden>
- <div class="progress-labels"><div class="progress-info"></div><div class="progress-status"></div></div>
- <div class="progress-bar-track"><div class="progress-bar danger"></div></div>
- </div>
- <div class="status-footer-item dictionary-import-progress" hidden>
- <div class="progress-labels"><div class="progress-info"></div><div class="progress-status"></div></div>
- <div class="progress-bar-track"><div class="progress-bar"></div></div>
- </div>
- </div>
-</div></div>
-
-<div id="popup-menus"></div>
-
-
-<!-- Profile modals -->
-<div id="profiles-modal" class="modal" tabindex="-1" role="dialog" hidden><div class="modal-content">
- <div class="modal-header">
- <div class="modal-title">Profiles</div>
- <div class="modal-header-button-container">
- <div class="modal-header-button-group">
- <button class="icon-button modal-header-button" data-modal-action="expand"><span class="icon-button-inner"><span class="icon" data-icon="expand"></span></span></button>
- <button class="icon-button modal-header-button" data-modal-action="collapse"><span class="icon-button-inner"><span class="icon" data-icon="collapse"></span></span></button>
- </div>
- </div>
- </div>
- <div class="modal-body">
- <div class="profile-entry-header">
- <div class="profile-entry-cell"></div>
- <div class="profile-entry-cell"><span class="profile-entry-header-text">Default</span></div>
- <div class="profile-entry-cell"><span class="profile-entry-header-text">Name</span></div>
- <div class="profile-entry-cell"><span class="profile-entry-header-text">Conditions</span></div>
- <div class="profile-entry-cell"></div>
- </div>
- <div class="profile-entry-list generic-list" id="profile-entry-list"></div>
- <div class="profile-add-button-container">
- <button class="low-emphasis" id="profile-add-button">Add</button>
- </div>
- </div>
- <div class="modal-footer">
- <button data-modal-action="hide">Close</button>
- </div>
-</div></div>
-
-<div id="profile-conditions-modal" class="modal" tabindex="-1" role="dialog" hidden><div class="modal-content">
- <div class="modal-header">
- <div class="modal-title">Profile Conditions</div>
- <div class="modal-header-button-container">
- <div class="modal-header-button-group">
- <button class="icon-button modal-header-button" data-modal-action="expand"><span class="icon-button-inner"><span class="icon" data-icon="expand"></span></span></button>
- <button class="icon-button modal-header-button" data-modal-action="collapse"><span class="icon-button-inner"><span class="icon" data-icon="collapse"></span></span></button>
- </div>
- </div>
- </div>
- <div class="modal-body">
- <div class="settings-item">
- <div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-label">
- Conditions for profile <em id="profile-conditions-profile-name"></em>:
- </div>
- </div>
- <div class="settings-item-right">
- <a class="more-toggle more-only" data-parent-distance="3">Info&hellip;</a>
- </div>
- </div>
- <div class="settings-item-children more" hidden>
- <p>
- Profile usage conditions are used to automatically select certain profiles based on context.
- For example, different profiles can be used depending on the nested level of the popup, or based on the website's URL.
- </p>
- <p>
- Conditions are organized into groups corresponding to the order in which they are checked.
- If all of the conditions in any group of a profile are met, then that profile will be used for that context.
- </p>
- <p>
- If no conditions are specified, the profile will only be used if it is selected as the default profile.
- </p>
- <p>
- <a class="more-toggle" data-parent-distance="3">Hide&hellip;</a>
- </p>
- </div>
- </div>
- <div class="profile-condition-groups" id="profile-condition-groups"></div>
- <div class="profile-condition-group-list-info">
- <div class="profile-condition-groups-empty-info"><em>No conditions set up.</em></div>
- <div class="profile-condition-group-list-info-space"></div>
- <button class="low-emphasis" id="profile-add-condition-group">Add Group</button>
- </div>
- </div>
- <div class="modal-footer">
- <button data-modal-action="hide">Close</button>
- </div>
-</div></div>
-
-<div id="profile-copy-modal" class="modal" tabindex="-1" role="dialog" hidden><div class="modal-content modal-content-small">
- <div class="modal-header">
- <div class="modal-title">Copy Profile</div>
- <div class="modal-header-button-container">
- <div class="modal-header-button-group">
- <button class="icon-button modal-header-button" data-modal-action="expand"><span class="icon-button-inner"><span class="icon" data-icon="expand"></span></span></button>
- <button class="icon-button modal-header-button" data-modal-action="collapse"><span class="icon-button-inner"><span class="icon" data-icon="collapse"></span></span></button>
- </div>
- </div>
- </div>
- <div class="modal-body">
- <p>Select which profile to copy options from:</p>
- <select class="form-control" id="profile-copy-source-select"></select>
- </div>
- <div class="modal-footer">
- <button class="low-emphasis" data-modal-action="hide">Cancel</button>
- <button id="profile-copy-confirm-button">Copy Profile</button>
- </div>
-</div></div>
-
-<div id="profile-remove-modal" class="modal" tabindex="-1" role="dialog" hidden><div class="modal-content modal-content-small">
- <div class="modal-header"><div class="modal-title">Confirm Profile Deletion</div></div>
- <div class="modal-body">
- <p>
- Are you sure you want to delete the profile <em id="profile-remove-name"></em>?
- </p>
- </div>
- <div class="modal-footer">
- <button class="low-emphasis" data-modal-action="hide">Cancel</button>
- <button class="danger" id="profile-remove-confirm-button">Remove Profile</button>
- </div>
-</div></div>
-
-
-<!-- Profile templates -->
-<template id="profile-entry-template"><div class="profile-entry generic-list-entry">
- <div class="profile-entry-cell generic-list-index-prefix"></div>
- <div class="profile-entry-cell"><label class="radio"><input type="radio" class="profile-entry-is-default-radio" name="profile-entry-default-radio"><span class="radio-body"><span class="radio-border"></span><span class="radio-dot"></span></span></label></div>
- <div class="profile-entry-cell"><input class="profile-entry-name-input" type="text" autocomplete="off" placeholder="Profile name"></div>
- <div class="profile-entry-cell"><a class="profile-entry-condition-count-link"><span class="profile-entry-condition-count">0</span></a></div>
- <div class="profile-entry-cell input-height-icon-button-container"><button class="icon-button profile-entry-menu-button" data-menu="profile-menu" data-menu-position="below left"><span class="icon-button-inner"><span class="icon" data-icon="kebab-menu"></span></span></button></div>
-</div></template>
-
-<template id="profile-condition-group-template"><div class="profile-condition-group">
- <div class="profile-condition-list"></div>
- <div class="profile-condition-list-info">
- <div class="profile-condition-group-separator-label">or</div>
- <div class="profile-condition-list-info-space"></div>
- <button class="profile-condition-add-button low-emphasis">Add</button>
- </div>
-</div></template>
-
-<template id="profile-condition-template"><div class="profile-condition">
- <div class="profile-condition-prefix"></div>
- <div class="profile-condition-inner">
- <select class="profile-condition-type"><optgroup label="Type"></optgroup></select>
- <select class="profile-condition-operator"><optgroup label="Operator"></optgroup></select>
- <div class="profile-condition-input-container">
- <input type="text" class="profile-condition-input" autocomplete="off" spellcheck="false">
- <div class="input-height-icon-button-container mouse-button-container" hidden>
- <button class="icon-button profile-condition-mouse-button mouse-button"><span class="icon-button-inner"><span class="icon" data-icon="mouse"></span></span></button>
- </div>
- </div>
- </div>
- <div class="profile-condition-menu-button-container input-height-icon-button-container">
- <button class="icon-button profile-condition-menu-button" data-menu="profile-condition-menu" data-menu-position="below left"><span class="icon-button-inner"><span class="icon" data-icon="kebab-menu"></span></span></button>
- </div>
-</div></template>
-
-<template id="profile-menu-template"><div class="popup-menu-container" tabindex="-1" role="dialog"><div class="popup-menu"><div class="popup-menu-body">
- <button class="popup-menu-item" data-menu-action="moveUp">Move up</button>
- <button class="popup-menu-item" data-menu-action="moveDown">Move down</button>
- <button class="popup-menu-item" data-menu-action="copyFrom">Copy from...</button>
- <button class="popup-menu-item" data-menu-action="editConditions">Edit conditions...</button>
- <button class="popup-menu-item" data-menu-action="duplicate">Duplicate</button>
- <button class="popup-menu-item" data-menu-action="delete">Delete</button>
-</div></div></div></template>
-
-<template id="profile-condition-menu-template"><div class="popup-menu-container" tabindex="-1" role="dialog"><div class="popup-menu"><div class="popup-menu-body">
- <button class="popup-menu-item" data-menu-action="resetValue">Reset value</button>
- <button class="popup-menu-item" data-menu-action="delete">Delete</button>
- <button class="popup-menu-item" data-menu-action="deleteGroup">Delete group</button>
-</div></div></div></template>
-
-
-<!-- Dictionary modals -->
-<div id="dictionaries-modal" class="modal" tabindex="-1" role="dialog" hidden><div class="modal-content">
- <div class="modal-header">
- <div class="modal-title">Dictionaries</div>
- <div class="modal-header-button-container">
- <div class="modal-header-button-group">
- <button class="icon-button modal-header-button" data-modal-action="expand"><span class="icon-button-inner"><span class="icon" data-icon="expand"></span></span></button>
- <button class="icon-button modal-header-button" data-modal-action="collapse"><span class="icon-button-inner"><span class="icon" data-icon="collapse"></span></span></button>
- </div>
- </div>
- </div>
- <div class="modal-body">
- <div class="settings-item">
- <div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-label">
- Enable support for prefix wildcard searches
- <a class="more-toggle more-only" data-parent-distance="4">(?)</a>
- </div>
- </div>
- <div class="settings-item-right">
- <label class="toggle"><input type="checkbox" data-setting="global.database.prefixWildcardsSupported" data-scope="global"><span class="toggle-body"><span class="toggle-track"></span><span class="toggle-knob"></span></span></label>
- </div>
- </div>
- <div class="settings-item-children more" hidden>
- <p>
- In order for dictionaries to support searches using prefix wildcards on the search page,
- some additional data must be stored in the database.
- Enabling this option will include this extra data for any new dictionaries that are imported.
- </p>
- <p class="warning-text">
- This option will not change any dictionaries that are already imported;
- they must be re-imported for the option to take effect.
- </p>
- <p>
- <a class="more-toggle" data-parent-distance="3">Hide&hellip;</a>
- </p>
- </div>
- </div>
-
- <div class="warning-text margin-above no-dictionaries-installed-warning" hidden>
- No dictionaries have been installed yet.
- Visit the <a href="https://foosoft.net/projects/yomichan/#dictionaries" target="_blank" rel="noopener noreferrer">Yomichan homepage</a>
- for a list free dictionaries or click the <em>Import</em> button below to select a dictionary file to import.
- </div>
- <div id="dictionary-error" class="danger-text margin-above" hidden></div>
- <div id="dictionary-list" class="dictionary-list"></div>
- <div id="dictionary-list-extra" class="dictionary-list"></div>
-
- <div hidden><input type="file" id="dictionary-import-file-input" accept=".zip,application/zip" multiple></div>
- </div>
- <div class="modal-body-addon dictionary-delete-progress" hidden>
- <div class="progress-labels"><div class="progress-info"></div><div class="progress-status"></div></div>
- <div class="progress-bar-track"><div class="progress-bar danger"></div></div>
- </div>
- <div class="modal-body-addon dictionary-import-progress" hidden>
- <div class="progress-labels"><div class="progress-info"></div><div class="progress-status"></div></div>
- <div class="progress-bar-track"><div class="progress-bar"></div></div>
- </div>
- <div class="modal-footer">
- <button class="low-emphasis danger dictionary-database-mutating-input" id="dictionary-delete-all-button">Delete All</button>
- <button class="low-emphasis dictionary-database-mutating-input" id="dictionary-check-integrity">Check Integrity</button>
- <button class="low-emphasis dictionary-database-mutating-input" id="dictionary-import-file-button">Import</button>
- <button data-modal-action="hide">Close</button>
- </div>
-</div></div>
-
-<div id="dictionary-confirm-delete-modal" class="modal" tabindex="-1" role="dialog" hidden><div class="modal-content modal-content-small">
- <div class="modal-header"><div class="modal-title">Confirm Dictionary Deletion</div></div>
- <div class="modal-body">
- <p>Are you sure you want to delete the dictionary:</p>
- <p><strong id="dictionary-confirm-delete-name"></strong>?</p>
- <p class="danger-text">This action cannot be undone.</p>
- </div>
- <div class="modal-footer">
- <button class="low-emphasis" data-modal-action="hide">Cancel</button>
- <button class="danger" data-modal-action="hide" id="dictionary-confirm-delete-button">Delete</button>
- </div>
-</div></div>
-
-<div id="dictionary-confirm-delete-all-modal" class="modal" tabindex="-1" role="dialog" hidden><div class="modal-content modal-content-small">
- <div class="modal-header"><div class="modal-title">Confirm Dictionary Deletion</div></div>
- <div class="modal-body">
- <p>Are you sure you want to delete <strong>all dictionaries</strong>?</p>
- <p class="danger-text">This action cannot be undone.</p>
- </div>
- <div class="modal-footer">
- <button class="low-emphasis" data-modal-action="hide">Cancel</button>
- <button class="danger" data-modal-action="hide" id="dictionary-confirm-delete-all-button">Delete</button>
- </div>
-</div></div>
-
-<div id="secondary-search-dictionaries-modal" class="modal" tabindex="-1" role="dialog" hidden><div class="modal-content">
- <div class="modal-header">
- <div class="modal-title">Secondary Search Dictionaries</div>
- <div class="modal-header-button-container">
- <div class="modal-header-button-group">
- <button class="icon-button modal-header-button" data-modal-action="expand"><span class="icon-button-inner"><span class="icon" data-icon="expand"></span></span></button>
- <button class="icon-button modal-header-button" data-modal-action="collapse"><span class="icon-button-inner"><span class="icon" data-icon="collapse"></span></span></button>
- </div>
- </div>
- </div>
- <div class="modal-body">
- <p>
- These dictionaries will be used to search for definitions of the related terms when the grouping mode is
- <em>Group related terms</em>.
- </p>
- <div id="secondary-search-dictionary-list" class="dictionary-list margin-above"></div>
- </div>
- <div class="modal-footer">
- <button data-modal-action="hide">Close</button>
- </div>
-</div></div>
-
-
-<!-- Dictionary templates -->
-<template id="dictionary-template"><div class="settings-item dictionary-item">
- <div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-label dictionary-info">
- <label class="toggle"><input type="checkbox" class="dictionary-enabled"><span class="toggle-body"><span class="toggle-track"></span><span class="toggle-knob"></span></span></label>
- <span class="dictionary-info-label"><strong class="dictionary-title"></strong> <span class="light dictionary-version"></span></span>
- </div>
- </div>
- <div class="settings-item-right">
- <button class="icon-button dictionary-menu-button" data-menu="dictionary-menu" data-menu-position="below left"><span class="icon-button-inner"><span class="icon" data-icon="kebab-menu"></span></span></button>
- </div>
- </div>
- <div class="settings-item-children">
-
- <div class="settings-item dictionary-outdated-notification" hidden><div class="settings-item-children danger-text">
- This dictionary is outdated and may not support new extension features.
- Re-import the dictionary to enable support for the latest features.
- </div></div>
- <div class="settings-item"><div class="settings-item-inner settings-item-inner-wrappable">
- <div class="settings-item-left">
- <div class="settings-item-label">Priority</div>
- </div>
- <div class="settings-item-right">
- <input type="number" step="1" class="short-height dictionary-priority">
- </div>
- </div></div>
- <div class="dictionary-details" hidden>
- <div class="settings-item">
- <div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-label">
- Prefix wildcard searches supported
- <a class="more-toggle more-only" data-parent-distance="4">(?)</a>
- </div>
- </div>
- <div class="settings-item-right">
- <label class="toggle"><input type="checkbox" class="dictionary-prefix-wildcard-searches-supported" disabled readonly><span class="toggle-body"><span class="toggle-track"></span><span class="toggle-knob"></span></span></label>
- </div>
- </div>
- <div class="settings-item-children more" hidden>
- <p class="warning-text">
- Changing this value requires the dictionary to be re-imported.
- </p>
- <p><a class="more-toggle" data-parent-distance="3">Hide&hellip;</a></p>
- </div>
- </div>
- <div class="settings-item"><div class="settings-item-children">
- <div class="dictionary-details-table"></div>
- <div class="dictionary-counts"></div>
- </div></div>
- </div>
-
- </div>
-</div></template>
-
-<template id="dictionary-details-entry-template"><div class="dictionary-details-entry">
- <span class="dictionary-details-entry-label"></span>
- <span class="dictionary-details-entry-info"></span>
-</div></template>
-
-<template id="dictionary-extra-template"><div class="settings-item">
- <div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-label"><strong class="dictionary-title">Unassociated Data</strong> <span class="light dictionary-total-count"></span></div>
- </div>
- </div>
- <div class="settings-item-children">
- <p class="warning-text">
- The database contains extra data which is not associated with any installed dictionary.
- Purging the database can fix this issue.
- </p>
- <div class="dictionary-counts"></div>
- </div>
-</div></template>
-
-<template id="dictionary-menu-template"><div class="popup-menu-container" tabindex="-1" role="dialog"><div class="popup-menu"><div class="popup-menu-body">
- <button class="popup-menu-item" data-menu-action="showDetails">Show details</button>
- <button class="popup-menu-item" data-menu-action="hideDetails" hidden>Hide details</button>
- <button class="popup-menu-item" data-menu-action="delete">Delete</button>
-</div></div></div></template>
-
-<template id="secondary-search-dictionary-template"><div class="settings-item dictionary-item"><div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-label dictionary-info">
- <label class="toggle"><input type="checkbox" class="dictionary-allow-secondary-searches"><span class="toggle-body"><span class="toggle-track"></span><span class="toggle-knob"></span></span></label>
- <span class="dictionary-info-label"><strong class="dictionary-title"></strong> <span class="light dictionary-version"></span></span>
- </div>
- </div>
-</div></div></template>
-
-
-<!-- Custom CSS modal -->
-<div id="custom-css-modal" class="modal modal-left" tabindex="-1" role="dialog" hidden><div class="modal-content-container1">
- <div class="modal-content-container2 modal-content-dimmer"><div class="modal-content">
- <div class="modal-header">
- <div class="modal-title">Custom CSS</div>
- <div class="modal-header-button-container">
- <div class="modal-header-button-group">
- <button class="icon-button modal-header-button" data-modal-action="expand"><span class="icon-button-inner"><span class="icon" data-icon="expand"></span></span></button>
- <button class="icon-button modal-header-button" data-modal-action="collapse"><span class="icon-button-inner"><span class="icon" data-icon="collapse"></span></span></button>
- </div>
- </div>
- </div>
- <div class="modal-body custom-popup-css-container">
- <div class="custom-popup-css-header">Popup CSS</div>
- <textarea autocomplete="off" spellcheck="false" id="custom-popup-css" data-setting="general.customPopupCss" data-tab-action="indent,4"></textarea>
- <div class="custom-popup-css-header margin-above">Popup outer CSS</div>
- <textarea autocomplete="off" spellcheck="false" id="custom-popup-outer-css" data-setting="general.customPopupOuterCss" data-tab-action="indent,4"></textarea>
- </div>
- <div class="modal-footer">
- <button data-modal-action="hide">Close</button>
- </div>
- </div></div>
- <div class="modal-content-container1-fade"></div>
-</div></div>
-
-
-<!-- Audio sources modal -->
-<div id="audio-sources-modal" class="modal" tabindex="-1" role="dialog" hidden><div class="modal-content">
- <div class="modal-header">
- <div class="modal-title">Audio Sources</div>
- <div class="modal-header-button-container">
- <div class="modal-header-button-group">
- <button class="icon-button modal-header-button" data-modal-action="expand"><span class="icon-button-inner"><span class="icon" data-icon="expand"></span></span></button>
- <button class="icon-button modal-header-button" data-modal-action="collapse"><span class="icon-button-inner"><span class="icon" data-icon="collapse"></span></span></button>
- </div>
- </div>
- </div>
- <div class="modal-body">
- <div class="settings-item">
- <div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-label">
- Text-to-speech voice
- <a class="more-toggle more-only" data-parent-distance="4">(?)</a>
- </div>
- </div>
- <div class="settings-item-right">
- <select data-setting="audio.textToSpeechVoice" id="text-to-speech-voice"></select>
- </div>
- </div>
- <div class="settings-item-children more" hidden>
- <p>
- Change which voice is used for text-to-speech audio playback.
- </p>
- <div class="horizontal-flex">
- <input type="text" value="よみちゃん" id="text-to-speech-voice-test-text" autocomplete="off" lang="ja">
- <button id="text-to-speech-voice-test">Test</button>
- <a class="more-toggle" data-parent-distance="3">Hide&hellip;</a>
- </div>
- </div>
- </div>
- <div class="settings-item">
- <div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-label">
- Custom audio source
- <a class="more-toggle more-only" data-parent-distance="4">(?)</a>
- </div>
- </div>
- <div class="settings-item-right">
- <div class="settings-item-group">
- <div class="settings-item-group-item">
- <div class="settings-item-group-item-label">Type</div>
- <select class="short-width short-height" data-setting="audio.customSourceType">
- <option value="audio">Audio</option>
- <option value="json">JSON</option>
- </select>
- </div>
- <div class="settings-item-group-item">
- <div class="settings-item-group-item-label">URL</div>
- <input class="short-height" type="text" spellcheck="false" autocomplete="off" data-setting="audio.customSourceUrl" placeholder="None">
- </div>
- </div>
- </div>
- </div>
- <div class="settings-item-children more" hidden>
- <p>
- The <em>URL</em> property specifies the URL format used for fetching audio clips in <em>Custom</em> mode.
- The replacement tags <code data-select-on-click="">{expression}</code> and <code data-select-on-click="">{reading}</code> can be used to specify which
- expression and reading is being looked up.<br>
- </p>
- <p>
- The <em>Type</em> property specifies how the URL is handled when looking up audio:
- </p>
- <ul>
- <li>
- <strong>Audio</strong> - The link is treated as a direct link to an audio file that the browser can play.
- </li>
- <li>
- <strong>JSON</strong> - The link is interpreted as a link to a JSON file, which is downloaded and parsed for audio URLs.
- The format of the JSON file is specified in <a href="/data/schemas/custom-audio-list-schema.json" target="_blank" rel="noopener noreferrer">this schema file</a>.
- </li>
- </ul>
- <p>
- Example URL: <a data-select-on-click="">http://localhost/audio.mp3?expression={expression}&amp;reading={reading}</a>
- </p>
- <p>
- <a class="more-toggle" data-parent-distance="3">Less&hellip;</a>
- </p>
- </div>
- </div>
- <div class="settings-item">
- <div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-label">
- Audio sources
- <a class="more-toggle more-only" data-parent-distance="4">(?)</a>
- </div>
- </div>
- <div class="settings-item-right">
- <button id="audio-source-add" class="low-emphasis">Add</button>
- </div>
- </div>
- <div class="settings-item-children more" hidden>
- <p>
- When searching for audio, the sources are checked in order until the first
- valid source is found. This allows for selecting a fallback source if the
- first choice is not available.
- </p>
- <p>
- <a class="more-toggle" data-parent-distance="3">Less&hellip;</a>
- </p>
- </div>
- <div class="settings-item-children">
- <div id="audio-source-list" class="generic-list"></div>
- <div id="audio-source-list-empty">
- No audio sources enabled
- </div>
- </div>
- </div>
- </div>
- <div class="modal-footer">
- <button data-modal-action="hide">Close</button>
- </div>
-</div></div>
-
-
-<!-- Audio templates -->
-<template id="audio-source-template"><div class="audio-source horizontal-flex">
- <div class="generic-list-index-prefix"></div>
- <select class="audio-source-select">
- <option value="jpod101">JapanesePod101</option>
- <option value="jpod101-alternate">JapanesePod101 (Alternate)</option>
- <option value="jisho">Jisho.org</option>
- <option value="text-to-speech">Text-to-speech</option>
- <option value="text-to-speech-reading">Text-to-speech (Kana reading)</option>
- <option value="custom">Custom</option>
- </select>
- <div class="horizontal-flex-fill"></div>
- <button class="icon-button audio-source-menu-button" data-menu="audio-source-menu" data-menu-position="below left"><span class="icon-button-inner"><span class="icon" data-icon="kebab-menu"></span></span></button>
-</div></template>
-
-<template id="audio-source-menu-template"><div class="popup-menu-container" tabindex="-1" role="dialog"><div class="popup-menu"><div class="popup-menu-body">
- <button class="popup-menu-item" data-menu-action="remove">Remove</button>
-</div></div></div></template>
-
-
-<!-- Scanning inputs modal -->
-<div id="scanning-inputs-modal" class="modal" tabindex="-1" role="dialog" hidden><div class="modal-content">
- <div class="modal-header">
- <div class="modal-title">Scanning Inputs</div>
- <div class="modal-header-button-container">
- <div class="modal-header-button-group">
- <button class="icon-button modal-header-button" data-modal-action="expand"><span class="icon-button-inner"><span class="icon" data-icon="expand"></span></span></button>
- <button class="icon-button modal-header-button" data-modal-action="collapse"><span class="icon-button-inner"><span class="icon" data-icon="collapse"></span></span></button>
- </div>
- </div>
- </div>
- <div class="modal-body">
- <div>
- <p>
- Scanning inputs are used to define when text scanning should occur.
- <a class="more-toggle more-only" data-parent-distance="2">More&hellip;</a>
- </p>
- <div class="margin-above more" hidden>
- <p>
- Text scanning is performed when a pointer is moved and certain inputs are either pressed or not pressed.
- The <em>Required inputs</em> field is used to define which inputs <em>must</em> be pressed, and
- the <em>Excluded inputs</em> field is used to define which inputs <em>must not</em> be pressed.
- If the <em>Required inputs</em> field is empty, text will be scanned whenever the pointer is moved.
- </p>
- <p>
- The <em>Input types</em> group is used to define which types of pointer input that the
- keyboard and button inputs are applied to.
- Supported pointer types include the mouse cursor, touchscreen touches, and pen devices.
- When using the <em>Pen</em> option, the defined inputs will correspond to buttons on the pen device.
- </p>
- <p>
- Some additional scanning and search options can be configured by clicking the menu button and selecting
- <em>Show advanced options</em>.
- </p>
- <ul>
- <li>To assign keyboard keys, select the input field and press modifier keys on the keyboard.</li>
- <li>To assign mouse or pen buttons, click on the button with the mouse icon using the desired button.</li>
- <li>
- To clear inputs, select the input field and press the <em>Escape</em> button,
- or use the <em>Clear inputs</em> menu option.
- </li>
- </ul>
- <p><a class="more-toggle" data-parent-distance="3">Less&hellip;</a></p>
- </div>
- </div>
- <div class="scan-input-list generic-list margin-above" id="scan-input-list"></div>
- <div class="scan-input-list-empty-info warning-text margin-above">
- No scanning inputs have been defined yet.
- Click the <em>Add</em> button to add a new input.
- </div>
- <div class="flex-row-nowrap right"><button class="low-emphasis" id="scan-input-add">Add</button></div>
- </div>
- <div class="modal-footer">
- <button data-modal-action="hide">Close</button>
- </div>
-</div></div>
-
-
-<!-- Scanning inputs templates -->
-<template id="scan-input-template"><div class="scan-input" data-show-advanced="false">
- <div class="scan-input-grid">
- <div class="scan-input-index-cell generic-list-index-prefix"></div>
- <div class="scan-input-suffix-cell">
- <div class="input-height-icon-button-container">
- <button class="icon-button scanning-input-menu-button" data-menu="scanning-inputs-menu" data-menu-position="below left"><span class="icon-button-inner"><span class="icon" data-icon="kebab-menu"></span></span></button>
- </div>
- </div>
-
- <div class="scan-input-prefix-cell" data-property="include"><span>Required inputs:</span></div>
- <div class="scan-input-content-cell" data-property="include">
- <input type="text" class="input-with-suffix-button scan-input-field" autocomplete="off" spellcheck="false" placeholder="No inputs" data-property="include">
- <button class="input-suffix-button input-suffix-icon-button mouse-button" data-property="include"><span class="icon icon-button-icon-light" data-icon="mouse"></span></button>
- </div>
-
- <div class="scan-input-prefix-cell" data-property="exclude"><span>Excluded inputs:</span></div>
- <div class="scan-input-content-cell" data-property="exclude">
- <input type="text" class="input-with-suffix-button scan-input-field" autocomplete="off" spellcheck="false" placeholder="No inputs" data-property="exclude">
- <button class="input-suffix-button input-suffix-icon-button mouse-button" data-property="exclude"><span class="icon icon-button-icon-light" data-icon="mouse"></span></button>
- </div>
-
- <div class="scan-input-prefix-cell scan-input-options-cell" data-property="types"><span>Input types:</span></div>
- <div class="scan-input-content-cell scan-input-options-cell" data-property="types">
- <label class="scan-input-checkbox-item">
- <label class="checkbox"><input type="checkbox" class="scan-input-settings-checkbox" data-property="types.mouse"><span class="checkbox-body"><span class="checkbox-fill"></span><span class="checkbox-border"></span><span class="checkbox-check"></span></span></label>
- <span>Mouse</span>
- </label>
- <label class="scan-input-checkbox-item">
- <label class="checkbox"><input type="checkbox" class="scan-input-settings-checkbox" data-property="types.touch"><span class="checkbox-body"><span class="checkbox-fill"></span><span class="checkbox-border"></span><span class="checkbox-check"></span></span></label>
- <span>Touch</span>
- </label>
- <label class="scan-input-checkbox-item">
- <label class="checkbox"><input type="checkbox" class="scan-input-settings-checkbox" data-property="types.pen"><span class="checkbox-body"><span class="checkbox-fill"></span><span class="checkbox-border"></span><span class="checkbox-check"></span></span></label>
- <span>Pen</span>
- </label>
- </div>
-
- <div class="scan-input-prefix-cell scan-input-options-cell scan-input-advanced-only" data-property="search-options"><span>Search types:</span></div>
- <div class="scan-input-content-cell scan-input-options-cell scan-input-advanced-only" data-property="search-options">
- <label class="scan-input-checkbox-item">
- <label class="checkbox"><input type="checkbox" class="scan-input-settings-checkbox" data-property="options.searchTerms"><span class="checkbox-body"><span class="checkbox-fill"></span><span class="checkbox-border"></span><span class="checkbox-check"></span></span></label>
- <span>Search for terms</span>
- </label>
- <label class="scan-input-checkbox-item">
- <label class="checkbox"><input type="checkbox" class="scan-input-settings-checkbox" data-property="options.searchKanji"><span class="checkbox-body"><span class="checkbox-fill"></span><span class="checkbox-border"></span><span class="checkbox-check"></span></span></label>
- <span>Search for kanji</span>
- </label>
- </div>
-
- <div class="scan-input-prefix-cell scan-input-options-cell scan-input-advanced-only" data-property="touch-pen-options"><span>Touch &amp; pen:</span></div>
- <div class="scan-input-content-cell scan-input-options-cell scan-input-advanced-only" data-property="touch-pen-options">
- <label class="scan-input-checkbox-item">
- <label class="checkbox"><input type="checkbox" class="scan-input-settings-checkbox" data-property="options.scanOnTouchMove"><span class="checkbox-body"><span class="checkbox-fill"></span><span class="checkbox-border"></span><span class="checkbox-check"></span></span></label>
- <span>Scan on touch move</span>
- </label>
- <label class="scan-input-checkbox-item">
- <label class="checkbox"><input type="checkbox" class="scan-input-settings-checkbox" data-property="options.scanOnPenHover"><span class="checkbox-body"><span class="checkbox-fill"></span><span class="checkbox-border"></span><span class="checkbox-check"></span></span></label>
- <span>Scan on pen hover</span>
- </label>
- <label class="scan-input-checkbox-item">
- <label class="checkbox"><input type="checkbox" class="scan-input-settings-checkbox" data-property="options.scanOnPenPress"><span class="checkbox-body"><span class="checkbox-fill"></span><span class="checkbox-border"></span><span class="checkbox-check"></span></span></label>
- <span>Scan on pen press</span>
- </label>
- <label class="scan-input-checkbox-item">
- <label class="checkbox"><input type="checkbox" class="scan-input-settings-checkbox" data-property="options.scanOnPenRelease"><span class="checkbox-body"><span class="checkbox-fill"></span><span class="checkbox-border"></span><span class="checkbox-check"></span></span></label>
- <span>Scan on pen release</span>
- </label>
- <label class="scan-input-checkbox-item">
- <label class="checkbox"><input type="checkbox" class="scan-input-settings-checkbox" data-property="options.preventTouchScrolling"><span class="checkbox-body"><span class="checkbox-fill"></span><span class="checkbox-border"></span><span class="checkbox-check"></span></span></label>
- <span>Prevent touch/pen scrolling</span>
- </label>
- </div>
- </div>
-</div></template>
-
-<template id="scanning-inputs-menu-template"><div class="popup-menu-container" tabindex="-1" role="dialog"><div class="popup-menu"><div class="popup-menu-body">
- <button class="popup-menu-item" data-menu-action="showAdvanced">Show advanced options</button>
- <button class="popup-menu-item" data-menu-action="hideAdvanced">Hide advanced options</button>
- <button class="popup-menu-item" data-menu-action="clearInputs">Clear inputs</button>
- <button class="popup-menu-item" data-menu-action="remove">Remove</button>
-</div></div></div></template>
-
-
-<!-- Input action prevention modal -->
-<div id="input-action-prevention-modal" class="modal" tabindex="-1" role="dialog" hidden><div class="modal-content modal-content-small">
- <div class="modal-header"><div class="modal-title">Input Action Prevention</div></div>
- <div class="modal-body">
- <strong>Prevent middle mouse button actions on:</strong>
- <div class="flex-column-nowrap flex-column-nowrap-spaced margin-left">
- <label class="flex-label">
- <label class="checkbox"><input type="checkbox" data-setting="scanning.preventMiddleMouse.onWebPages"><span class="checkbox-body"><span class="checkbox-fill"></span><span class="checkbox-border"></span><span class="checkbox-check"></span></span></label>
- <span>Webpages</span>
- </label>
- <label class="flex-label">
- <label class="checkbox"><input type="checkbox" data-setting="scanning.preventMiddleMouse.onPopupPages"><span class="checkbox-body"><span class="checkbox-fill"></span><span class="checkbox-border"></span><span class="checkbox-check"></span></span></label>
- <span>Popups</span>
- </label>
- <label class="flex-label">
- <label class="checkbox"><input type="checkbox" data-setting="scanning.preventMiddleMouse.onSearchPages"><span class="checkbox-body"><span class="checkbox-fill"></span><span class="checkbox-border"></span><span class="checkbox-check"></span></span></label>
- <span>Search page</span>
- </label>
- <label class="flex-label">
- <label class="checkbox"><input type="checkbox" data-setting="scanning.preventMiddleMouse.onSearchQuery"><span class="checkbox-body"><span class="checkbox-fill"></span><span class="checkbox-border"></span><span class="checkbox-check"></span></span></label>
- <span>Search query</span>
- </label>
- </div>
- </div>
- <div class="modal-footer">
- <button data-modal-action="hide">Close</button>
- </div>
-</div></div>
-
-
-<!-- Anki cards modal -->
-<div id="anki-cards-modal" class="modal" tabindex="-1" role="dialog" hidden><div class="modal-content">
- <div class="modal-header">
- <div class="modal-title">Anki Cards</div>
- <div class="modal-header-button-container">
- <div class="modal-header-button-group">
- <button class="icon-button modal-header-button" data-modal-action="expand"><span class="icon-button-inner"><span class="icon" data-icon="expand"></span></span></button>
- <button class="icon-button modal-header-button" data-modal-action="collapse"><span class="icon-button-inner"><span class="icon" data-icon="collapse"></span></span></button>
- </div>
- </div>
- </div>
- <div class="modal-body anki-card" id="anki-card-primary" data-anki-card-type="terms" data-anki-card-menu="anki-card-terms-field-menu">
- <div class="settings-item"><div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-label">Card type</div>
- <div class="settings-item-description">Different types of definition can have separate settings.</div>
- </div>
- <div class="settings-item-right">
- <select id="anki-card-primary-type">
- <option value="terms" data-anki-card-menu="anki-card-terms-field-menu" selected>Terms</option>
- <option value="kanji" data-anki-card-menu="anki-card-kanji-field-menu">Kanji</option>
- </select>
- </div>
- </div></div>
- <div class="modal-separator-line"></div>
- <div class="settings-item"><div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-label">Deck</div>
- </div>
- <div class="settings-item-right">
- <select class="anki-card-deck"></select>
- </div>
- </div></div>
- <div class="settings-item"><div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-label">Model</div>
- </div>
- <div class="settings-item-right">
- <select class="anki-card-model"></select>
- </div>
- </div></div>
- <div class="anki-card-fields">
- <div class="anki-card-field-name-header" data-persistent="true">Field</div>
- <div class="anki-card-field-input-header" data-persistent="true">Value</div>
- </div>
- </div>
- <div class="modal-footer">
- <button class="low-emphasis" data-modal-action="show,anki-cards-info">Help</button>
- <button data-modal-action="hide">Close</button>
- </div>
-</div></div>
-
-<div id="anki-cards-info-modal" class="modal" tabindex="-1" role="dialog" hidden><div class="modal-content modal-content-full">
- <div class="modal-header">
- <div class="modal-title">Anki Card Information</div>
- <div class="modal-header-button-container">
- <div class="modal-header-button-group">
- <button class="icon-button modal-header-button" data-modal-action="expand"><span class="icon-button-inner"><span class="icon" data-icon="expand"></span></span></button>
- <button class="icon-button modal-header-button" data-modal-action="collapse"><span class="icon-button-inner"><span class="icon" data-icon="collapse"></span></span></button>
- </div>
- </div>
- </div>
- <div class="modal-body">
- <p>
- Anki card fields can be populated with information about a term or kanji character by using field markers.
- When a card is being generated, field markers are replaced with information about the term or kanji by using the installed dictionaries.
- Several preset markers are available, which are described below.
- Markers can be customized by adjusting the <a data-modal-action="show,anki-card-templates">Anki card templates</a>.
- </p>
- <p>
- Anki requires the first field in a model to be unique for a card;
- therefore, it is recommended to use <code class="anki-field-marker">{expression}</code> as the marker for the first field of term cards,
- or <code class="anki-field-marker">{character}</code> for kanji cards.
- </p>
- <table class="anki-field-marker-info-table margin-above">
- <tbody>
- <tr class="anki-field-marker-info-table-heading">
- <td>Marker (for terms)</td>
- <td>Description</td>
- </tr>
-
- <tr>
- <td><code class="anki-field-marker">{audio}</code></td>
- <td>Audio sample of a native speaker's pronunciation in MP3 format, if available.</td>
- </tr>
- <tr>
- <td><code class="anki-field-marker">{conjugation}</code></td>
- <td>Conjugation path from the raw inflected term to the source term.</td>
- </tr>
- <tr>
- <td><code class="anki-field-marker">{expression}</code></td>
- <td>Term expressed using kanji. If kanji expression is not available, kana is used.</td>
- </tr>
- <tr>
- <td><code class="anki-field-marker">{furigana}</code></td>
- <td>
- Term expressed as kanji with furigana displayed above it.
- Example: <ruby>日本語<rt>にほんご</rt></ruby>.
- </td>
- </tr>
- <tr>
- <td><code class="anki-field-marker">{furigana-plain}</code></td>
- <td>
- Term expressed as kanji with furigana displayed next to it in brackets.
- Example: 日本語[にほんご].
- </td>
- </tr>
- <tr>
- <td><code class="anki-field-marker">{glossary}</code></td>
- <td>List of definitions for the term.</td>
- </tr>
- <tr>
- <td><code class="anki-field-marker">{glossary-brief}</code></td>
- <td>List of definitions for the term in a more compact format.</td>
- </tr>
- <tr>
- <td><code class="anki-field-marker">{glossary-no-dictionary}</code></td>
- <td>List of definitions for the term, except the dictionary tag is omitted.</td>
- </tr>
- <tr>
- <td><code class="anki-field-marker">{pitch-accents}</code></td>
- <td>List of pitch accent downstep notations for the term.</td>
- </tr>
- <tr>
- <td><code class="anki-field-marker">{pitch-accent-graphs}</code></td>
- <td>List of pitch accent graphs for the term.</td>
- </tr>
- <tr>
- <td><code class="anki-field-marker">{pitch-accent-positions}</code></td>
- <td>List of accent downstep positions for the term as a number.</td>
- </tr>
- <tr>
- <td><code class="anki-field-marker">{reading}</code></td>
- <td>Kana reading for the term, or empty for terms where the expression is the reading.</td>
- </tr>
- <tr>
- <td><code class="anki-field-marker">{tags}</code></td>
- <td>Grammar and usage tags providing information about the term.</td>
- </tr>
-
- <tr class="anki-field-marker-info-table-heading">
- <td>Marker (for kanji)</td>
- <td>Description</td>
- </tr>
-
- <tr>
- <td><code class="anki-field-marker">{character}</code></td>
- <td>Unicode glyph representing the current kanji.</td>
- </tr>
- <tr>
- <td><code class="anki-field-marker">{glossary}</code></td>
- <td>List of definitions for the kanji.</td>
- </tr>
- <tr>
- <td><code class="anki-field-marker">{kunyomi}</code></td>
- <td>Kunyomi (Japanese reading) for the kanji, expressed as katakana.</td>
- </tr>
- <tr>
- <td><code class="anki-field-marker">{onyomi}</code></td>
- <td>Onyomi (Chinese reading) for the kanji, expressed as hiragana.</td>
- </tr>
- <tr>
- <td><code class="anki-field-marker">{stroke-count}</code></td>
- <td>Number of strokes that the kanji character has.</td>
- </tr>
-
- <tr class="anki-field-marker-info-table-heading">
- <td>Marker (for both)</td>
- <td>Description</td>
- </tr>
-
- <tr>
- <td><code class="anki-field-marker">{clipboard-image}</code></td>
- <td>An image which is stored in the system clipboard, if available.</td>
- </tr>
- <tr>
- <td><code class="anki-field-marker">{clipboard-text}</code></td>
- <td>Text which is stored in the system clipboard, if available.</td>
- </tr>
- <tr>
- <td><code class="anki-field-marker">{cloze-body}</code></td>
- <td>Original inflected term as it appeared before being reduced to dictionary form by Yomichan.</td>
- </tr>
- <tr>
- <td><code class="anki-field-marker">{cloze-prefix}</code></td>
- <td>Fragment of the containing <code class="anki-field-marker">{sentence}</code> starting at the beginning of <code class="anki-field-marker">{sentence}</code> until the beginning of <code class="anki-field-marker">{cloze-body}</code>.</td>
- </tr>
- <tr>
- <td><code class="anki-field-marker">{cloze-suffix}</code></td>
- <td>Fragment of the containing <code class="anki-field-marker">{sentence}</code> starting at the end of <code class="anki-field-marker">{cloze-body}</code> until the end of <code class="anki-field-marker">{sentence}</code>.</td>
- </tr>
- <tr>
- <td><code class="anki-field-marker">{dictionary}</code></td>
- <td>Name of the dictionary from which the card is being created.</td>
- </tr>
- <tr>
- <td><code class="anki-field-marker">{document-title}</code></td>
- <td>Title of the web page that the term or kanji appeared in.</td>
- </tr>
- <tr>
- <td><code class="anki-field-marker">{screenshot}</code></td>
- <td>Screenshot of the web page taken at the time the term or kanji was added.</td>
- </tr>
- <tr>
- <td><code class="anki-field-marker">{sentence}</code></td>
- <td>Sentence, quote, or phrase that the term or kanji appears in from the source content.</td>
- </tr>
- <tr>
- <td><code class="anki-field-marker">{url}</code></td>
- <td>Address of the web page in which the term or kanji appeared in.</td>
- </tr>
- </tbody>
- </table>
- </div>
- <div class="modal-footer">
- <button data-modal-action="hide">Close</button>
- </div>
-</div></div>
-
-
-<!-- Anki card templates -->
-<template id="anki-card-field-template"><div class="anki-card-field-name-container"><span class="anki-card-field-name"></span></div>
-<div class="anki-card-field-value-container">
- <input type="text" class="anki-card-field-value input-with-suffix-button" autocomplete="off">
- <button class="anki-card-field-value-menu-button input-suffix-button input-suffix-icon-button" data-menu-position="below left"><span class="icon icon-button-icon-light" data-icon="material-down-arrow"></span></button>
-</div></template>
-
-<template id="anki-card-terms-field-menu-template"><div class="popup-menu-container" tabindex="-1" role="dialog"><div class="popup-menu"><div class="popup-menu-body"></div></div></div></template>
-
-<template id="anki-card-kanji-field-menu-template"><div class="popup-menu-container" tabindex="-1" role="dialog"><div class="popup-menu"><div class="popup-menu-body"></div></div></div></template>
-
-<template id="anki-card-all-field-menu-template"><div class="popup-menu-container" tabindex="-1" role="dialog"><div class="popup-menu"><div class="popup-menu-body"></div></div></div></template>
-
-
-<!-- Anki field template modals -->
-<div id="anki-card-templates-modal" class="modal" tabindex="-1" role="dialog" hidden><div class="modal-content modal-content-full">
- <div class="modal-header"><div class="modal-title">Anki Card Templates</div></div>
- <div class="modal-body anki-card-templates-layout">
- <div class="anki-card-templates-info">
- <p>
- Anki card fields are formatted using the <a href="https://handlebarsjs.com/" target="_blank" rel="noopener noreferrer">Handlebars.js</a>
- template rendering engine.
- Advanced users can modify these templates for full control over what information is included in Anki cards.
- </p>
- <p>
- Consider copy-pasting the source into a code editor that supports syntax highlighting for easier editing.
- </p>
- </div>
- <textarea autocomplete="off" spellcheck="false" id="anki-card-templates-textarea" class="margin-above" data-tab-action="indent,4"></textarea>
- <div id="anki-card-templates-compile-result" class="danger-text margin-above" hidden></div>
- <div class="anki-card-templates-test-container margin-above">
- <p>
- Card templates can be tested using the inputs below.
- </p>
- <div class="anki-card-templates-test-table margin-above">
- <div class="anki-card-templates-test-table-header">Scanned text</div>
- <div class="anki-card-templates-test-table-header">Card field</div>
- <div></div>
- <input type="text" id="anki-card-templates-test-text-input" class="form-control" value="読め" placeholder="Preview text" autocomplete="off" lang="ja">
- <div class="anki-card-templates-test-input-container">
- <input type="text" class="input-with-suffix-button" id="anki-card-templates-test-field-input" value="{expression}" placeholder="{marker}" autocomplete="off" spellcheck="false">
- <button class="input-suffix-button input-suffix-icon-button" id="anki-card-templates-test-field-menu-button" data-menu="anki-card-all-field-menu" data-menu-position="below left"><span class="icon icon-button-icon-light" data-icon="material-down-arrow"></span></button>
- </div>
- <button id="anki-card-templates-test-render-button">Test</button>
- </div>
- </div>
- <div class="margin-above" id="anki-card-templates-render-result"><em>Card render result</em></div>
- </div>
- <div class="modal-footer">
- <button class="danger" id="anki-card-templates-reset-button">Reset Templates</button>
- <button data-modal-action="hide">Close</button>
- </div>
-</div></div>
-
-<div id="anki-card-templates-reset-modal" class="modal" tabindex="-1" role="dialog" hidden><div class="modal-content modal-content-small">
- <div class="modal-header"><div class="modal-title">Reset Anki Card Templates</div></div>
- <div class="modal-body">
- <p class="danger-text">
- Are you sure you want to reset the card templates to their default value?
- Any changes you made will be lost.
- </p>
- </div>
- <div class="modal-footer">
- <button class="low-emphasis" data-modal-action="hide">Cancel</button>
- <button class="danger" id="anki-card-templates-reset-button-confirm">Reset Templates</button>
- </div>
-</div></div>
-
-
-<!-- Import/export modals -->
-<div id="settings-import-error-modal" class="modal" tabindex="-1" role="dialog" hidden><div class="modal-content modal-content-small">
- <div class="modal-header"><div class="modal-title">Import Error</div></div>
- <div class="modal-body">
- <p>An error occurred while trying to import the settings file:</p>
- <p class="danger-text" id="settings-import-error-message"></p>
- <p>Additional info can be found in the developer console.</p>
- </div>
- <div class="modal-footer">
- <button class="low-emphasis" data-modal-action="hide">Close</button>
- </div>
-</div></div>
-
-<div id="settings-import-warning-modal" class="modal" tabindex="-1" role="dialog" hidden><div class="modal-content modal-content-small">
- <div class="modal-header"><div class="modal-title">Import Security Warning</div></div>
- <div class="modal-body">
- <p>
- Settings file contains settings which may pose a security risk.
- Only import settings from sources you trust.
- </p>
- <ul class="danger-text" id="settings-import-warning-message"></ul>
- </div>
- <div class="modal-footer">
- <button class="low-emphasis" data-modal-action="hide">Cancel</button>
- <button class="danger settings-import-warning-import-button">Import</button>
- <button class="settings-import-warning-import-button" data-import-sanitize="true">Sanitize and Import</button>
- </div>
-</div></div>
-
-<div id="settings-reset-modal" class="modal" tabindex="-1" role="dialog" hidden><div class="modal-content modal-content-small">
- <div class="modal-header"><div class="modal-title">Reset Settings</div></div>
- <div class="modal-body">
- <p class="danger-text">
- You are about to reset all Yomichan settings back to their default values.
- This will delete all custom profiles you may have created.
- <strong>This action cannot be undone.</strong>
- </p>
- <p>
- Consider making a backup using the <em>Export Settings</em> button before resetting
- if you want to be able to revert.
- </p>
- <p>
- Dictionary data will not be deleted, but any installed dictionaries
- will need to be re-enabled.
- </p>
- </div>
- <div class="modal-footer">
- <button class="low-emphasis" data-modal-action="hide">Cancel</button>
- <button class="danger" id="settings-reset-confirm-button">Reset All Settings</button>
- </div>
-</div></div>
-
-
-<!-- Translation modals -->
-<div id="translation-text-replacement-patterns-modal" class="modal" tabindex="-1" role="dialog" hidden><div class="modal-content">
- <div class="modal-header">
- <div class="modal-title">Custom Text Replacement Patterns</div>
- <div class="modal-header-button-container">
- <div class="modal-header-button-group">
- <button class="icon-button modal-header-button" data-modal-action="expand"><span class="icon-button-inner"><span class="icon" data-icon="expand"></span></span></button>
- <button class="icon-button modal-header-button" data-modal-action="collapse"><span class="icon-button-inner"><span class="icon" data-icon="collapse"></span></span></button>
- </div>
- </div>
- </div>
- <div class="modal-body">
- <div class="settings-item"><div class="settings-item-inner"><div class="settings-item-left"><div class="settings-item-label">
- Text replacement patterns are used to modify or remove text that matches certain patterns.
- Patterns are defined using
- <a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Guide/Regular_Expressions" target="_blank" rel="noreferrer noopener">regular expression syntax</a>,
- and the replacement text can use certain
- <a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/replace#Specifying_a_string_as_a_parameter" target="_blank" rel="noreferrer noopener">special replacement patterns</a>.
- </div></div></div></div>
- <div class="settings-item"><div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-label">
- Search original text
- </div>
- <div class="settings-item-description">
- The original unmodified text will also be searched for definitions.
- </div>
- </div>
- <div class="settings-item-right">
- <label class="toggle"><input type="checkbox" data-setting="translation.textReplacements.searchOriginal"><span class="toggle-body"><span class="toggle-track"></span><span class="toggle-knob"></span></span></label>
- </div>
- </div></div>
- <div class="settings-item">
- <div class="settings-item-inner">
- <div class="settings-item-left">
- <div class="settings-item-label">Text replacement patterns</div>
- </div>
- <div class="settings-item-right">
- <button id="translation-text-replacement-add" class="low-emphasis">Add</button>
- </div>
- </div>
- <div class="settings-item-children">
- <div id="translation-text-replacement-list" class="generic-list"></div>
- <div id="translation-text-replacement-list-empty"><em>None defined</em></div>
- </div>
- </div>
- </div>
- <div class="modal-footer">
- <button data-modal-action="hide">Close</button>
- </div>
-</div></div>
-
-
-<!-- Translation templates -->
-<template id="translation-text-replacement-entry-template"><div class="translation-text-replacement-entry">
- <div class="translation-text-replacement-index generic-list-index-prefix"></div>
- <div class="translation-text-replacement-pattern-label">Pattern:</div>
- <div class="translation-text-replacement-replacement-label">Replacement:</div>
- <div class="translation-text-replacement-pattern-container">
- <input type="text" class="translation-text-replacement-pattern code">
- <label class="translation-text-replacement-checkbox-container">
- <label class="checkbox"><input type="checkbox" class="translation-text-replacement-checkbox translation-text-replacement-pattern-ignore-case"><span class="checkbox-body"><span class="checkbox-fill"></span><span class="checkbox-border"></span><span class="checkbox-check"></span></span></label>
- <span class="translation-text-replacement-checkbox-label">Ignore case</span>
- </label>
- </div>
- <div class="translation-text-replacement-replacement-container">
- <input type="text" class="translation-text-replacement-replacement code">
- </div>
- <button class="icon-button translation-text-replacement-button" data-menu="translation-text-replacement-entry-menu" data-menu-position="below left"><span class="icon-button-inner"><span class="icon" data-icon="kebab-menu"></span></span></button>
-
- <div class="translation-text-replacement-test-label translation-text-replacement-test-node">Test Input:</div>
- <div class="translation-text-replacement-test-container translation-text-replacement-test-node">
- <input type="text" class="translation-text-replacement-test-input" lang="ja">
- <div class="translation-text-replacement-test-label-inner">Output:</div>
- <input type="text" class="translation-text-replacement-test-output" lang="ja" readonly>
- </div>
-</div></template>
-
-<template id="translation-text-replacement-entry-menu-template"><div class="popup-menu-container" tabindex="-1" role="dialog"><div class="popup-menu"><div class="popup-menu-body">
- <button class="popup-menu-item" data-menu-action="showTest">Test</button>
- <button class="popup-menu-item" data-menu-action="hideTest">Hide test</button>
- <button class="popup-menu-item" data-menu-action="remove">Remove</button>
-</div></div></div></template>
-
-
-<!-- Sentence parsing modal -->
-<div id="sentence-termination-characters-modal" class="modal" tabindex="-1" role="dialog" hidden><div class="modal-content">
- <div class="modal-header">
- <div class="modal-title">Sentence Termination Characters</div>
- <div class="modal-header-button-container">
- <div class="modal-header-button-group">
- <button class="icon-button modal-header-button" data-modal-action="expand"><span class="icon-button-inner"><span class="icon" data-icon="expand"></span></span></button>
- <button class="icon-button modal-header-button" data-modal-action="collapse"><span class="icon-button-inner"><span class="icon" data-icon="collapse"></span></span></button>
- </div>
- </div>
- </div>
- <div class="modal-body">
- <p>
- Sentences are terminated by punctuation and quotation marks, which can both be configured below.
- </p>
- <table class="sentence-termination-character-list-table" id="sentence-termination-character-list-table" hidden>
- <thead><tr>
- <td>#</td>
- <td>Enabled</td>
- <td>Type</td>
- <td>Character 1</td>
- <td>Character 2</td>
- <td>Include character in sentence</td>
- <td></td>
- </tr></thead>
- <tbody class="sentence-termination-character-list generic-list" id="sentence-termination-character-list"></tbody>
- </table>
- <div id="sentence-termination-character-list-empty" hidden>
- No terminators defined.
- </div>
- </div>
- <div class="modal-footer">
- <button class="low-emphasis danger" id="sentence-termination-character-list-reset">Reset</button>
- <button class="low-emphasis" id="sentence-termination-character-list-add">Add</button>
- <button data-modal-action="hide">Close</button>
- </div>
-</div></div>
-
-
-<!-- Sentence parsing templates -->
-<template id="sentence-termination-character-entry-template"><tr class="sentence-termination-character-entry">
- <td class="generic-list-index-prefix"></td>
- <td>
- <label class="toggle"><input type="checkbox" class="sentence-termination-character-enabled"><span class="toggle-body"><span class="toggle-track"></span><span class="toggle-knob"></span></span></label>
- </td>
- <td>
- <select class="sentence-termination-character-type">
- <option value="terminator">Terminator</option>
- <option value="quote">Quote</option>
- </select>
- </td>
- <td>
- <input type="text" class="sentence-termination-character-input1" maxlength="1" lang="ja">
- </td>
- <td>
- <input type="text" class="sentence-termination-character-input2" maxlength="1" lang="ja">
- <div class="sentence-termination-character-input2-alt">&mdash;</div>
- </td>
- <td>
- <div class="sentence-termination-character-include-list">
- <label class="sentence-termination-character-include">
- <label class="checkbox"><input type="checkbox" class="sentence-termination-character-include-at-start"><span class="checkbox-body"><span class="checkbox-fill"></span><span class="checkbox-border"></span><span class="checkbox-check"></span></span></label>
- <span>At start</span>
- </label>
- <label class="sentence-termination-character-include">
- <label class="checkbox"><input type="checkbox" class="sentence-termination-character-include-at-end"><span class="checkbox-body"><span class="checkbox-fill"></span><span class="checkbox-border"></span><span class="checkbox-check"></span></span></label>
- <span>At end</span>
- </label>
- </div>
- </td>
- <td>
- <button class="icon-button sentence-termination-character-entry-button" data-menu="sentence-termination-character-entry-menu" data-menu-position="below left"><span class="icon-button-inner"><span class="icon" data-icon="kebab-menu"></span></span></button>
- </td>
-</tr></template>
-
-<template id="sentence-termination-character-entry-menu-template"><div class="popup-menu-container" tabindex="-1" role="dialog"><div class="popup-menu"><div class="popup-menu-body">
- <button class="popup-menu-item" data-menu-action="delete">Delete</button>
-</div></div></div></template>
-
-
-<!-- Keyboard shortcuts modal -->
-<div id="keyboard-shortcuts-modal" class="modal" tabindex="-1" role="dialog" hidden><div class="modal-content modal-content-full">
- <div class="modal-header">
- <div class="modal-title">Keyboard Shortcuts</div>
- <div class="modal-header-button-container">
- <div class="modal-header-button-group">
- <button class="icon-button modal-header-button" data-modal-action="expand"><span class="icon-button-inner"><span class="icon" data-icon="expand"></span></span></button>
- <button class="icon-button modal-header-button" data-modal-action="collapse"><span class="icon-button-inner"><span class="icon" data-icon="collapse"></span></span></button>
- </div>
- </div>
- </div>
- <div class="modal-body">
- <div class="hotkey-list generic-list" id="hotkey-list"></div>
- <div class="hotkey-list-empty" id="hotkey-list-empty" hidden>
- No keyboard shortcuts defined.
- </div>
- </div>
- <div class="modal-footer">
- <button class="low-emphasis danger" id="hotkey-list-reset">Reset</button>
- <button class="low-emphasis" id="hotkey-list-add">Add</button>
- <button data-modal-action="hide">Close</button>
- </div>
-</div></div>
-
-<div id="extension-keyboard-shortcuts-modal" class="modal" tabindex="-1" role="dialog" hidden><div class="modal-content">
- <div class="modal-header">
- <div class="modal-title">Native Keyboard Shortcuts</div>
- <div class="modal-header-button-container">
- <div class="modal-header-button-group">
- <button class="icon-button modal-header-button" data-modal-action="expand"><span class="icon-button-inner"><span class="icon" data-icon="expand"></span></span></button>
- <button class="icon-button modal-header-button" data-modal-action="collapse"><span class="icon-button-inner"><span class="icon" data-icon="collapse"></span></span></button>
- </div>
- </div>
- </div>
- <div class="modal-body">
- <div>
- <p data-show-for-browser="chrome edge">
- The native keyboard shortcuts are listed below,
- but cannot be configured from within the extension on this browser.
- To configure these shortcuts:
- </p>
-
- <p data-show-for-browser="firefox">
- The native keyboard shortcuts can be configured below on this browser,
- or by doing the following:
- </p>
-
- <ul data-show-for-browser="chrome">
- <li>Open <a data-special-url="chrome://extensions/shortcuts">chrome://extensions/shortcuts</a> in a new tab.</li>
- <li>Find the <em>Yomichan</em> section and configure the shortcuts.</li>
- </ul>
-
- <ul data-show-for-browser="edge">
- <li>Open <a data-special-url="edge://extensions/shortcuts">edge://extensions/shortcuts</a> in a new tab.</li>
- <li>Find the <em>Yomichan</em> section and configure the shortcuts.</li>
- </ul>
-
- <ul data-show-for-browser="firefox">
- <li>Open the extensions page (<a data-select-on-click="">about:addons</a>)</li>
- <li>Click the button on the right with the gear icon, then click <em>Manage Extension Shortcuts</em>.</li>
- <li>Find the <em>Yomichan</em> section and configure the shortcuts.</li>
- </ul>
- </div>
- <div class="modal-separator-line"></div>
- <div class="modal-settings-group" id="extension-hotkey-list"></div>
- </div>
- <div class="modal-footer">
- <button class="low-emphasis danger" id="extension-hotkey-list-reset-all">Reset All</button>
- <button class="low-emphasis danger" id="extension-hotkey-list-clear-all">Clear All</button>
- <button data-modal-action="hide">Close</button>
- </div>
-</div></div>
-
-<!-- Keyboard shortcuts templates -->
-<template id="hotkey-list-item-template"><div class="hotkey-list-item"><div class="hotkey-list-item-grid">
- <div class="hotkey-list-item-index-cell generic-list-index-prefix"></div>
- <div class="hotkey-list-item-button-cell">
- <div class="input-height-icon-button-container">
- <button class="icon-button hotkey-list-item-button" data-menu="hotkey-list-item-menu" data-menu-position="below left"><span class="icon-button-inner"><span class="icon" data-icon="kebab-menu"></span></span></button>
- </div>
- </div>
-
- <div class="hotkey-list-item-input-label-cell">Input:</div>
- <div class="hotkey-list-item-input-cell">
- <input type="text" class="hotkey-list-item-input" autocomplete="off" spellcheck="false" placeholder="No input" data-property="include">
- <label class="toggle hotkey-list-item-enabled-label"><input type="checkbox" class="hotkey-list-item-enabled"><span class="toggle-body"><span class="toggle-track"></span><span class="toggle-knob"></span></span></label>
- </div>
-
- <div class="hotkey-list-item-action-label-cell">Action:</div>
- <div class="hotkey-list-item-action-cell">
- <select class="hotkey-list-item-action">
- <option value="" data-scopes="popup search">None</option>
- <option value="close" data-scopes="popup search">Close</option>
- <option value="focusSearchBox" data-scopes="search">Focus search box</option>
- <option value="nextEntry" data-scopes="popup search">Go to next entry</option>
- <option value="nextEntry3" data-scopes="popup search">Go to next entry (x3)</option>
- <option value="previousEntry" data-scopes="popup search">Go to previous entry</option>
- <option value="previousEntry3" data-scopes="popup search">Go to previous entry (x3)</option>
- <option value="lastEntry" data-scopes="popup search">Go to last entry</option>
- <option value="firstEntry" data-scopes="popup search">Go to first entry</option>
- <option value="nextEntryDifferentDictionary" data-scopes="popup search">Go to next dictionary</option>
- <option value="previousEntryDifferentDictionary" data-scopes="popup search">Go to previous dictionary</option>
- <option value="historyBackward" data-scopes="popup search">Navigate backward in history</option>
- <option value="historyForward" data-scopes="popup search">Navigate forward in history</option>
- <option value="addNoteKanji" data-scopes="popup search">Add kanji note</option>
- <option value="addNoteTermKanji" data-scopes="popup search">Add term note</option>
- <option value="addNoteTermKana" data-scopes="popup search">Add term note (reading)</option>
- <option value="viewNote" data-scopes="popup search">View note</option>
- <option value="playAudio" data-scopes="popup search">Play audio</option>
- <option value="copyHostSelection" data-scopes="popup">Copy host window selection</option>
- <option value="scanSelectedText" data-scopes="web">Scan selected text</option>
- </select>
- <div class="hotkey-list-item-flex-row">
- <div class="hotkey-list-item-flex-row-label">Scopes:</div>
- <div class="hotkey-list-item-flex-row">
- <label class="hotkey-scope-checkbox-container" data-scope="web">
- <label class="checkbox"><input type="checkbox" class="hotkey-scope-checkbox" data-scope="web"><span class="checkbox-body"><span class="checkbox-fill"></span><span class="checkbox-border"></span><span class="checkbox-check"></span></span></label>
- <span>Web</span>
- </label>
- <label class="hotkey-scope-checkbox-container" data-scope="popup">
- <label class="checkbox"><input type="checkbox" class="hotkey-scope-checkbox" data-scope="popup"><span class="checkbox-body"><span class="checkbox-fill"></span><span class="checkbox-border"></span><span class="checkbox-check"></span></span></label>
- <span>Popup</span>
- </label>
- <label class="hotkey-scope-checkbox-container" data-scope="search">
- <label class="checkbox"><input type="checkbox" class="hotkey-scope-checkbox" data-scope="search"><span class="checkbox-body"><span class="checkbox-fill"></span><span class="checkbox-border"></span><span class="checkbox-check"></span></span></label>
- <span>Search</span>
- </label>
- </div>
- </div>
- </div>
-</div></div></template>
-
-<template id="extension-hotkey-list-item-template"><div class="settings-item"><div class="settings-item-inner settings-item-inner-wrappable">
- <div class="settings-item-left">
- <div class="settings-item-label"></div>
- </div>
- <div class="settings-item-right">
- <div class="flex-row-nowrap">
- <input type="text">
- <button class="icon-button extension-hotkey-list-item-button" data-menu="extension-hotkey-list-item-menu" data-menu-position="below left"><span class="icon-button-inner"><span class="icon" data-icon="kebab-menu"></span></span></button>
- </div>
- </div>
-</div></div></template>
-
-<template id="hotkey-list-item-menu-template"><div class="popup-menu-container" tabindex="-1" role="dialog"><div class="popup-menu"><div class="popup-menu-body">
- <button class="popup-menu-item" data-menu-action="clearInputs">Clear input</button>
- <button class="popup-menu-item" data-menu-action="resetInput">Reset input</button>
- <button class="popup-menu-item" data-menu-action="delete">Delete</button>
-</div></div></div></template>
-
-<template id="extension-hotkey-list-item-menu-template"><div class="popup-menu-container" tabindex="-1" role="dialog"><div class="popup-menu"><div class="popup-menu-body">
- <button class="popup-menu-item" data-menu-action="clearInput">Clear input</button>
- <button class="popup-menu-item" data-menu-action="resetInput">Reset input</button>
-</div></div></div></template>
-
-
-<!-- Scripts -->
-<script src="/mixed/lib/jszip.min.js"></script>
-<script src="/mixed/lib/wanakana.min.js"></script>
-
-<script src="/mixed/js/core.js"></script>
-<script src="/mixed/js/yomichan.js"></script>
-<script src="/mixed/js/comm.js"></script>
-<script src="/mixed/js/environment.js"></script>
-<script src="/mixed/js/api.js"></script>
-<script src="/mixed/js/japanese.js"></script>
-
-<script src="/mixed/js/audio-system.js"></script>
-<script src="/mixed/js/cache-map.js"></script>
-<script src="/mixed/js/dictionary-data-util.js"></script>
-<script src="/mixed/js/document-focus-controller.js"></script>
-<script src="/mixed/js/document-util.js"></script>
-<script src="/mixed/js/dom-data-binder.js"></script>
-<script src="/mixed/js/hotkey-util.js"></script>
-<script src="/mixed/js/html-template-collection.js"></script>
-<script src="/mixed/js/object-property-accessor.js"></script>
-<script src="/mixed/js/panel-element.js"></script>
-<script src="/mixed/js/popup-menu.js"></script>
-<script src="/mixed/js/selector-observer.js"></script>
-<script src="/mixed/js/task-accumulator.js"></script>
-<script src="/mixed/js/text-to-speech-audio.js"></script>
-
-<script src="/bg/js/anki.js"></script>
-<script src="/bg/js/anki-note-builder.js"></script>
-<script src="/bg/js/options.js"></script>
-<script src="/bg/js/database.js"></script>
-<script src="/bg/js/dictionary-database.js"></script>
-<script src="/bg/js/dictionary-importer.js"></script>
-<script src="/bg/js/json-schema.js"></script>
-<script src="/bg/js/media-utility.js"></script>
-<script src="/bg/js/permissions-util.js"></script>
-<script src="/bg/js/template-patcher.js"></script>
-<script src="/bg/js/template-renderer-proxy.js"></script>
-
-<script src="/bg/js/settings/keyboard-mouse-input-field.js"></script>
-<script src="/bg/js/settings/profile-conditions-ui.js"></script>
-
-<script src="/bg/js/settings/anki-controller.js"></script>
-<script src="/bg/js/settings/anki-templates-controller.js"></script>
-<script src="/bg/js/settings/audio-controller.js"></script>
-<script src="/bg/js/settings/backup-controller.js"></script>
-<script src="/bg/js/settings/permissions-toggle-controller.js"></script>
-<script src="/bg/js/settings/dictionary-controller.js"></script>
-<script src="/bg/js/settings/dictionary-import-controller.js"></script>
-<script src="/bg/js/settings/generic-setting-controller.js"></script>
-<script src="/bg/js/settings/modal.js"></script>
-<script src="/bg/js/settings/modal-controller.js"></script>
-<script src="/bg/js/settings/popup-preview-controller.js"></script>
-<script src="/bg/js/settings/profile-controller.js"></script>
-<script src="/bg/js/settings/scan-inputs-controller.js"></script>
-<script src="/bg/js/settings/scan-inputs-simple-controller.js"></script>
-<script src="/bg/js/settings/settings-controller.js"></script>
-<script src="/bg/js/settings/status-footer.js"></script>
-<script src="/bg/js/settings/storage-controller.js"></script>
-
-<script src="/bg/js/settings2/extension-keyboard-shortcuts-controller.js"></script>
-<script src="/bg/js/settings2/keyboard-shortcuts-controller.js"></script>
-<script src="/bg/js/settings2/mecab-controller.js"></script>
-<script src="/bg/js/settings2/nested-popups-controller.js"></script>
-<script src="/bg/js/settings2/popup-window-controller.js"></script>
-<script src="/bg/js/settings2/secondary-search-dictionary-controller.js"></script>
-<script src="/bg/js/settings2/sentence-termination-characters-controller.js"></script>
-<script src="/bg/js/settings2/settings-display-controller.js"></script>
-<script src="/bg/js/settings2/translation-text-replacements-controller.js"></script>
-
-<script src="/bg/js/settings2/settings-main.js"></script>
-
-</body>
-</html>