454 lines
22 KiB
HTML
454 lines
22 KiB
HTML
<!DOCTYPE html>
|
|
<html lang="en">
|
|
<head>
|
|
<meta charset="UTF-8">
|
|
<meta name="viewport" content="width=device-width,initial-scale=1" />
|
|
<title>Yomichan Options</title>
|
|
<link rel="stylesheet" type="text/css" href="/mixed/lib/bootstrap/css/bootstrap.min.css">
|
|
<link rel="stylesheet" type="text/css" href="/mixed/lib/bootstrap/css/bootstrap-theme.min.css">
|
|
<style>
|
|
#anki-spinner, #anki-general, #anki-error,
|
|
#dict-spinner, #dict-error, #dict-warning, #dict-purge, #dict-import-progress,
|
|
#debug, .options-advanced, .storage-hidden, #storage-spinner {
|
|
display: none;
|
|
}
|
|
|
|
.tab-content {
|
|
border-bottom: 1px #ddd solid;
|
|
border-left: 1px #ddd solid;
|
|
border-right: 1px #ddd solid;
|
|
padding: 10px;
|
|
}
|
|
|
|
#field-templates {
|
|
font-family: monospace;
|
|
overflow-x: hidden;
|
|
white-space: pre;
|
|
}
|
|
|
|
.bottom-links {
|
|
padding-bottom: 1em;
|
|
}
|
|
|
|
#custom-popup-css {
|
|
width: 100%;
|
|
min-height: 34px;
|
|
height: 96px;
|
|
resize: vertical;
|
|
font-family: 'Courier New', Courier, monospace;
|
|
white-space: pre;
|
|
}
|
|
|
|
[data-show-for-browser] {
|
|
display: none;
|
|
}
|
|
|
|
[data-browser=edge] [data-show-for-browser~=edge],
|
|
[data-browser=chrome] [data-show-for-browser~=chrome],
|
|
[data-browser=firefox] [data-show-for-browser~=firefox],
|
|
[data-browser=firefox-mobile] [data-show-for-browser~=firefox-mobile] {
|
|
display: initial;
|
|
}
|
|
</style>
|
|
</head>
|
|
<body>
|
|
<div class="container-fluid">
|
|
<div>
|
|
<h3>General Options</h3>
|
|
|
|
<div class="checkbox">
|
|
<label><input type="checkbox" id="show-usage-guide"> Show usage guide on startup</label>
|
|
</div>
|
|
|
|
<div class="checkbox">
|
|
<label><input type="checkbox" id="compact-tags"> Compact tags</label>
|
|
</div>
|
|
|
|
<div class="checkbox">
|
|
<label><input type="checkbox" id="compact-glossaries"> Compact glossaries</label>
|
|
</div>
|
|
|
|
<div class="checkbox">
|
|
<label><input type="checkbox" id="auto-play-audio"> Play audio automatically</label>
|
|
</div>
|
|
|
|
<div class="checkbox">
|
|
<label><input type="checkbox" id="show-advanced-options"> Show advanced options</label>
|
|
</div>
|
|
|
|
<div class="checkbox options-advanced">
|
|
<label><input type="checkbox" id="show-debug-info"> Show debug information</label>
|
|
</div>
|
|
|
|
<div class="form-group">
|
|
<label for="result-output-mode">Result grouping</label>
|
|
<select class="form-control" id="result-output-mode">
|
|
<option value="group">Group results by term-reading pairs</option>
|
|
<option value="merge">Group results by main dictionary entry</option>
|
|
<option value="split">Split definitions to their own results</option>
|
|
</select>
|
|
</div>
|
|
|
|
<div class="form-group">
|
|
<label for="audio-playback-source">Audio playback source</label>
|
|
<select class="form-control" id="audio-playback-source">
|
|
<option value="disabled">Disabled</option>
|
|
<option value="jpod101">JapanesePod101</option>
|
|
<option value="jpod101-alternate">JapanesePod101 (alternate)</option>
|
|
<option value="jisho">Jisho.org</option>
|
|
</select>
|
|
</div>
|
|
|
|
<div class="form-group">
|
|
<label for="popup-display-mode">Popup display mode</label>
|
|
<select class="form-control" id="popup-display-mode">
|
|
<option value="default">Default</option>
|
|
<option value="full-width">Full width</option>
|
|
</select>
|
|
</div>
|
|
|
|
<div class="form-group">
|
|
<div class="row">
|
|
<div class="col-xs-6">
|
|
<label for="popup-display-mode">Popup position for horizontal text</label>
|
|
<select class="form-control" id="popup-horizontal-text-position">
|
|
<option value="below">Below text</option>
|
|
<option value="above">Above text</option>
|
|
</select>
|
|
</div>
|
|
<div class="col-xs-6">
|
|
<label for="popup-display-mode">Popup position for vertical text</label>
|
|
<select class="form-control" id="popup-vertical-text-position">
|
|
<option value="default">Same as for horizontal text</option>
|
|
<option value="before">Before text reading direction</option>
|
|
<option value="after">After text reading direction</option>
|
|
<option value="left">Left of text</option>
|
|
<option value="right">Right of text</option>
|
|
</select>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="form-group options-advanced">
|
|
<label for="audio-playback-volume">Audio playback volume (percent)</label>
|
|
<input type="number" min="0" max="100" id="audio-playback-volume" class="form-control">
|
|
</div>
|
|
|
|
<div class="form-group options-advanced">
|
|
<label for="max-displayed-results">Maximum displayed results</label>
|
|
<input type="number" min="1" id="max-displayed-results" class="form-control">
|
|
</div>
|
|
|
|
<div class="form-group options-advanced">
|
|
<label>Popup size (width × height, in pixels)</label>
|
|
<div class="row">
|
|
<div class="col-xs-6"><input type="number" min="1" id="popup-width" class="form-control"></div>
|
|
<div class="col-xs-6"><input type="number" min="1" id="popup-height" class="form-control"></div>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="form-group options-advanced">
|
|
<label>Popup offset (horizontal, vertical; in pixels)</label>
|
|
<div class="row">
|
|
<div class="col-xs-6"><input type="number" min="0" id="popup-horizontal-offset" class="form-control"></div>
|
|
<div class="col-xs-6"><input type="number" min="0" id="popup-vertical-offset" class="form-control"></div>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="form-group options-advanced">
|
|
<label>Popup offset for vertical text (horizontal, vertical; in pixels)</label>
|
|
<div class="row">
|
|
<div class="col-xs-6"><input type="number" min="0" id="popup-horizontal-offset2" class="form-control"></div>
|
|
<div class="col-xs-6"><input type="number" min="0" id="popup-vertical-offset2" class="form-control"></div>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="form-group options-advanced">
|
|
<label for="custom-popup-css">Custom popup CSS</label>
|
|
<div><textarea autocomplete="off" spellcheck="false" wrap="soft" id="custom-popup-css" class="form-control"></textarea></div>
|
|
</div>
|
|
</div>
|
|
|
|
<div>
|
|
<h3>Scanning Options</h3>
|
|
|
|
<div class="checkbox">
|
|
<label><input type="checkbox" id="middle-mouse-button-scan"> Middle mouse button scans</label>
|
|
</div>
|
|
|
|
<div class="checkbox">
|
|
<label><input type="checkbox" id="touch-input-enabled"> Touch input enabled</label>
|
|
</div>
|
|
|
|
<div class="checkbox">
|
|
<label><input type="checkbox" id="select-matched-text"> Select matched text</label>
|
|
</div>
|
|
|
|
<div class="checkbox">
|
|
<label><input type="checkbox" id="search-alphanumeric"> Search alphanumeric text</label>
|
|
</div>
|
|
|
|
<div class="checkbox">
|
|
<label><input type="checkbox" id="auto-hide-results"> Automatically hide results</label>
|
|
</div>
|
|
|
|
<div class="checkbox options-advanced">
|
|
<label><input type="checkbox" id="deep-dom-scan"> Deep DOM scan</label>
|
|
</div>
|
|
|
|
<div class="form-group options-advanced">
|
|
<label for="scan-delay">Scan delay (in milliseconds)</label>
|
|
<input type="number" min="1" id="scan-delay" class="form-control">
|
|
</div>
|
|
|
|
<div class="form-group options-advanced">
|
|
<label for="scan-length">Scan length (in characters)</label>
|
|
<input type="number" min="1" id="scan-length" class="form-control">
|
|
</div>
|
|
|
|
<div class="form-group">
|
|
<label for="scan-modifier-key">Scan modifier key</label>
|
|
<select class="form-control" id="scan-modifier-key">
|
|
<option value="none">None</option>
|
|
<option value="alt">Alt</option>
|
|
<option value="ctrl">Ctrl</option>
|
|
<option value="shift">Shift</option>
|
|
</select>
|
|
</div>
|
|
|
|
<div class="form-group options-advanced">
|
|
<label for="popup-nesting-max-depth">Maximum nested popup depth</label>
|
|
<input type="number" min="0" id="popup-nesting-max-depth" class="form-control">
|
|
</div>
|
|
</div>
|
|
|
|
<div>
|
|
<div>
|
|
<img src="/mixed/img/spinner.gif" class="pull-right" id="dict-spinner" alt>
|
|
<h3>Dictionaries</h3>
|
|
</div>
|
|
|
|
<p class="help-block">
|
|
Yomichan can import and use a variety of dictionary formats. Unneeded dictionaries can be disabled,
|
|
or you can simply <a href="#" id="dict-purge-link">purge the database</a> to delete everything.
|
|
</p>
|
|
<p class="help-block">
|
|
Deleting individual dictionaries is not currently feasible due to limitations of browser database technology.
|
|
</p>
|
|
|
|
<div class="form-group" id="dict-main-group">
|
|
<label for="dict-main">Main dictionary for merged mode</label>
|
|
<select class="form-control" id="dict-main"></select>
|
|
</div>
|
|
|
|
<div class="text-danger" id="dict-purge">Dictionary data is being purged, please be patient...</div>
|
|
<div class="alert alert-warning" id="dict-warning">No dictionaries have been installed</div>
|
|
<div class="alert alert-danger" id="dict-error"></div>
|
|
|
|
<div id="dict-groups"></div>
|
|
|
|
<div id="dict-import-progress">
|
|
Dictionary data is being imported, please be patient...
|
|
<div class="progress">
|
|
<div class="progress-bar progress-bar-striped" style="width: 0%"></div>
|
|
</div>
|
|
</div>
|
|
|
|
<div id="dict-importer">
|
|
<p class="help-block">
|
|
Select a dictionary to import for use below. Please visit the Yomichan homepage to
|
|
<a href="https://foosoft.net/projects/yomichan" target="_blank">download free dictionaries</a>
|
|
for use with this extension and to learn about importing proprietary EPWING dictionaries.
|
|
</p>
|
|
<input type="file" id="dict-file">
|
|
</div>
|
|
</div>
|
|
|
|
<div id="storage-info" class="storage-hidden">
|
|
<div>
|
|
<img src="/mixed/img/spinner.gif" class="pull-right" id="storage-spinner" />
|
|
<h3>Storage</h3>
|
|
</div>
|
|
|
|
<div id="storage-use" class="storage-hidden">
|
|
<p class="help-block">
|
|
Yomichan is using approximately <strong id="storage-usage"></strong> of <strong id="storage-quota"></strong>.
|
|
</p>
|
|
</div>
|
|
|
|
<div id="storage-error" class="storage-hidden">
|
|
<p class="help-block">
|
|
Could not detect how much storage Yomichan is using.
|
|
</p>
|
|
<div data-show-for-browser="firefox firefox-mobile"><div class="alert alert-danger options-advanced">
|
|
On Firefox and Firefox for Android, the storage information feature may be hidden behind a browser flag.
|
|
|
|
If you would like to enable this flag, open <a href="about:config" target="_blank">about:config</a> and search for the
|
|
<strong>dom.storageManager.enabled</strong> option. If this option has a value of <strong>false</strong>, toggling it to
|
|
<strong>true</strong> may allow storage information to be calculated.
|
|
</div></div>
|
|
</div>
|
|
|
|
<div data-show-for-browser="firefox-mobile"><div class="alert alert-warning">
|
|
If you are using Firefox for Android, you will have to make sure you have enough free space on your device to install dictionaries.
|
|
</div></div>
|
|
|
|
<div>
|
|
<input type="button" value="Refresh" id="storage-refresh" />
|
|
</div>
|
|
</div>
|
|
|
|
<div>
|
|
<div>
|
|
<img src="/mixed/img/spinner.gif" class="pull-right" id="anki-spinner" alt>
|
|
<h3>Anki Options</h3>
|
|
</div>
|
|
|
|
<p class="help-block">
|
|
Yomichan supports automatic flashcard creation for <a href="http://ankisrs.net/" target="_blank">Anki</a>, a free application
|
|
designed to help you remember. This feature requires installation of the
|
|
<a href="https://foosoft.net/projects/anki-connect/" target="_blank">AnkiConnect</a> plugin.
|
|
</p>
|
|
|
|
<div class="alert alert-danger" id="anki-error"></div>
|
|
|
|
<div class="checkbox">
|
|
<label><input type="checkbox" id="anki-enable"> Enable Anki integration</label>
|
|
</div>
|
|
|
|
<div id="anki-general">
|
|
<div class="form-group">
|
|
<label for="card-tags">Card tags (comma or space separated)</label>
|
|
<input type="text" id="card-tags" class="form-control">
|
|
</div>
|
|
|
|
<div class="form-group options-advanced">
|
|
<label for="sentence-detection-extent">Sentence detection extent (in characters)</label>
|
|
<input type="number" min="1" id="sentence-detection-extent" class="form-control">
|
|
</div>
|
|
|
|
<div class="form-group options-advanced">
|
|
<label for="interface-server">Interface server</label>
|
|
<input type="text" id="interface-server" class="form-control">
|
|
</div>
|
|
|
|
<div class="form-group options-advanced">
|
|
<label for="screenshot-format">Screenshot format</label>
|
|
<select class="form-control" id="screenshot-format">
|
|
<option value="png">PNG</option>
|
|
<option value="jpeg">JPEG</option>
|
|
</select>
|
|
</div>
|
|
|
|
<div class="form-group options-advanced">
|
|
<label for="screenshot-quality">Screenshot quality (JPEG only)</label>
|
|
<input type="number" min="0" max="100" step="1" id="screenshot-quality" class="form-control">
|
|
</div>
|
|
|
|
<div id="anki-format">
|
|
<p class="help-block">
|
|
Specify the information you would like included in your flashcards in the field editor below.
|
|
As Anki requires the first field in the model to be unique, it is recommended
|
|
that you set it to <code>{expression}</code> for term flashcards and <code>{character}</code> for
|
|
Kanji flashcards. You can use multiple markers per field by typing them in directly.
|
|
</p>
|
|
|
|
<ul class="nav nav-tabs">
|
|
<li class="active"><a href="#terms" data-toggle="tab">Terms</a></li>
|
|
<li><a href="#kanji" data-toggle="tab">Kanji</a></li>
|
|
</ul>
|
|
|
|
<div class="tab-content">
|
|
<div id="terms" class="tab-pane fade in active">
|
|
<div class="row">
|
|
<div class="form-group col-xs-6">
|
|
<label for="anki-terms-deck">Deck</label>
|
|
<select class="form-control anki-deck" id="anki-terms-deck"></select>
|
|
</div>
|
|
|
|
<div class="form-group col-xs-6">
|
|
<label for="anki-terms-model">Model</label>
|
|
<select class="form-control anki-model" id="anki-terms-model"></select>
|
|
</div>
|
|
</div>
|
|
|
|
<table class="table table-bordered anki-fields">
|
|
<thead><tr><th>Field</th><th>Value</th></tr></thead>
|
|
<tbody></tbody>
|
|
</table>
|
|
</div>
|
|
|
|
<div id="kanji" class="tab-pane fade">
|
|
<div class="row">
|
|
<div class="form-group col-xs-6">
|
|
<label for="anki-kanji-deck">Deck</label>
|
|
<select class="form-control anki-deck" id="anki-kanji-deck"></select>
|
|
</div>
|
|
|
|
<div class="form-group col-xs-6">
|
|
<label for="anki-kanji-model">Model</label>
|
|
<select class="form-control anki-model" id="anki-kanji-model"></select>
|
|
</div>
|
|
</div>
|
|
|
|
<table class="table table-bordered anki-fields">
|
|
<thead><tr><th>Field</th><th>Value</th></tr></thead>
|
|
<tbody></tbody>
|
|
</table>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="options-advanced">
|
|
<p class="help-block">
|
|
Fields are formatted using the <a href="http://handlebarsjs.com/">Handlebars.js</a> template rendering
|
|
engine. Advanced users can modify these templates for ultimate control of what information gets included in
|
|
their Anki cards. If you encounter problems with your changes you can always <a href="#" id="field-templates-reset">reset to default</a>
|
|
template settings.
|
|
</p>
|
|
<textarea class="form-control" rows="10" id="field-templates"></textarea>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<div>
|
|
<h3>Support Development</h3>
|
|
|
|
<p class="help-block">
|
|
Yomichan is provided to you <em>completely free</em> of charge. Unlike numerous other "free" services, you are not
|
|
shown ads, pestered with "offers", or have your browser usage information analyzed and sold to third parties.
|
|
</p>
|
|
<p class="help-block">
|
|
If you find Yomichan useful, please consider making a small donation as a way to show your appreciation for the
|
|
countless hours that I have devoted to this extension.
|
|
</p>
|
|
<p>
|
|
<a href="https://www.paypal.com/cgi-bin/webscr?cmd=_s-xclick&hosted_button_id=4DBTN9A3CUAFN" target="_blank"><img src="/bg/img/paypal.gif" alt></a>
|
|
</p>
|
|
</div>
|
|
|
|
<pre id="debug"></pre>
|
|
|
|
<div class="pull-right bottom-links">
|
|
<small><a href="search.html">Search</a> • <a href="https://foosoft.net/projects/yomichan/" target="_blank">Homepage</a> • <a href="legal.html">Legal</a></small>
|
|
</div>
|
|
</div>
|
|
|
|
<script src="/mixed/lib/jquery.min.js"></script>
|
|
<script src="/mixed/lib/bootstrap/js/bootstrap.min.js"></script>
|
|
<script src="/mixed/lib/handlebars.min.js"></script>
|
|
|
|
<script src="/mixed/js/extension.js"></script>
|
|
|
|
<script src="/bg/js/anki.js"></script>
|
|
<script src="/bg/js/api.js"></script>
|
|
<script src="/bg/js/dictionary.js"></script>
|
|
<script src="/bg/js/handlebars.js"></script>
|
|
<script src="/bg/js/options.js"></script>
|
|
<script src="/bg/js/templates.js"></script>
|
|
<script src="/bg/js/util.js"></script>
|
|
|
|
<script src="/bg/js/settings.js"></script>
|
|
</body>
|
|
</html>
|