summaryrefslogtreecommitdiff
path: root/ext/bg/js/settings.js
diff options
context:
space:
mode:
authorsiikamiika <siikamiika@users.noreply.github.com>2017-10-05 05:21:07 +0300
committersiikamiika <siikamiika@users.noreply.github.com>2017-10-05 05:21:07 +0300
commitcfad3b309976213c45f99bef3b8fad072c6bb9ec (patch)
treee2e92586367c5be0bfaaebe179bd407cadb471ad /ext/bg/js/settings.js
parent03fd9dcdb451ad55b9b2d2b5bd489e6ca3ba648a (diff)
merged mode: add main dictionary selection
Diffstat (limited to 'ext/bg/js/settings.js')
-rw-r--r--ext/bg/js/settings.js30
1 files changed, 26 insertions, 4 deletions
diff --git a/ext/bg/js/settings.js b/ext/bg/js/settings.js
index c5a28a45..4d248304 100644
--- a/ext/bg/js/settings.js
+++ b/ext/bg/js/settings.js
@@ -60,7 +60,11 @@ async function formRead() {
const title = dictionary.data('title');
const priority = parseInt(dictionary.find('.dict-priority').val(), 10);
const enabled = dictionary.find('.dict-enabled').prop('checked');
- optionsNew.dictionaries[title] = {priority, enabled};
+ const main = dictionary.find('.dict-main').prop('checked');
+ if (main) {
+ optionsNew.dictionary.main = title;
+ }
+ optionsNew.dictionaries[title] = {priority, enabled, main};
});
return {optionsNew, optionsOld};
@@ -237,6 +241,18 @@ function dictionaryGroupsSort() {
dictGroups.append(dictGroupChildren);
}
+function dictionarySetMain(e) {
+ const mainDictionary = $(e.target).closest('.dict-group');
+ const mainDictionaryTitle = mainDictionary.data('title');
+
+ $('.dict-group').each((index, element) => {
+ const dictionary = $(element);
+ if (dictionary.data('title') !== mainDictionaryTitle) {
+ dictionary.find('.dict-main').prop('checked', false);
+ }
+ });
+}
+
async function dictionaryGroupsPopulate(options) {
const dictGroups = $('#dict-groups').empty();
const dictWarning = $('#dict-warning').hide();
@@ -247,13 +263,14 @@ async function dictionaryGroupsPopulate(options) {
}
for (const dictRow of dictRowsSort(dictRows, options)) {
- const dictOptions = options.dictionaries[dictRow.title] || {enabled: false, priority: 0};
+ const dictOptions = options.dictionaries[dictRow.title] || {enabled: false, priority: 0, main: false};
const dictHtml = await apiTemplateRender('dictionary.html', {
title: dictRow.title,
version: dictRow.version,
revision: dictRow.revision,
priority: dictOptions.priority,
- enabled: dictOptions.enabled
+ enabled: dictOptions.enabled,
+ main: dictOptions.main
});
dictGroups.append($(dictHtml));
@@ -265,6 +282,11 @@ async function dictionaryGroupsPopulate(options) {
dictionaryGroupsSort();
onFormOptionsChanged(e);
});
+
+ $('.dict-main').change(e => {
+ dictionarySetMain(e);
+ onFormOptionsChanged(e);
+ });
}
async function onDictionaryPurge(e) {
@@ -308,7 +330,7 @@ async function onDictionaryImport(e) {
const options = await optionsLoad();
const summary = await utilDatabaseImport(e.target.files[0], updateProgress);
- options.dictionaries[summary.title] = {enabled: true, priority: 0};
+ options.dictionaries[summary.title] = {enabled: true, priority: 0, main: false};
await optionsSave(options);
await dictionaryGroupsPopulate(options);