Added "Reset" button and added the number of questions to the config.

This commit is contained in:
doncr 2021-09-29 17:57:47 +01:00
parent 61ec40fb15
commit bca0348dd4
2 changed files with 91 additions and 18 deletions

View File

@ -57,10 +57,13 @@
</dl> </dl>
</div> </div>
<div class="row"> <div class="row justify-content-center mb-4 mt-4">
<div class="col-4 mb-4 mt-4 mx-auto"> <div class="col-4">
<button class="btn btn-primary col-12" type="button" id="go">Go</button> <button class="btn btn-primary col-12" type="button" id="go">Go</button>
</div> </div>
<div class="col-4">
<button class="btn btn-secondary col-12" type="button" id="defaults">Reset</button>
</div>
</div> </div>
<div id="voiceSelectError" style="display: none"> <div id="voiceSelectError" style="display: none">

View File

@ -4,13 +4,48 @@ var transformations = [];
var log; var log;
var options = ["plain", "polite", "negative", "past", "te-form", const configOptions = {
"progressive", "potential", "imperative", "passive", "causative",
"godan", "ichidan", "iku", "kuru", "suru", "i-adjective", "na-adjective",
"ii", "desire", "volitional", "trick", "kana", "furigana_always",
"use_voice"];
var selects = ["questionFocus"]; options: ["plain", "polite", "negative", "past", "te-form", "progressive",
"potential", "imperative", "passive", "causative", "godan", "ichidan",
"iku", "kuru", "suru", "i-adjective", "na-adjective", "ii", "desire",
"volitional", "trick", "kana", "furigana_always", "use_voice"],
selects: ["questionFocus"],
inputs: ["numQuestions"]
}
const defaultConfig = {
"plain": true,
"polite": true,
"negative": true,
"past": true,
"te-form": false,
"progressive": false,
"potential": false,
"imperative": false,
"passive": false,
"causative": false,
"godan": true,
"ichidan": true,
"iku": true,
"kuru": true,
"suru": true,
"i-adjective": false,
"na-adjective": false,
"ii": false,
"desire": false,
"volitional": false,
"trick": true,
"kana": false,
"furigana_always": true,
"use_voice": false,
"questionFocus": "none",
"numQuestions": "10"
}
const localStorageOptionsKey = "conjugationDrillOptions";
Array.prototype.randomElement = function () { Array.prototype.randomElement = function () {
return this[Math.floor(Math.random() * this.length)] return this[Math.floor(Math.random() * this.length)]
@ -636,7 +671,6 @@ function showSplash() {
function startQuiz() { function startQuiz() {
var options = getOptions(); var options = getOptions();
localStorage.setItem('options', JSON.stringify(options));
const voiceSelectError = document.querySelector('#voiceSelectError'); const voiceSelectError = document.querySelector('#voiceSelectError');
@ -949,6 +983,16 @@ function updateOptionSummary() {
} }
} }
function saveOptions() {
localStorage.setItem(localStorageOptionsKey, JSON.stringify(getOptions()));
}
function restoreDefaults() {
localStorage.setItem(localStorageOptionsKey, JSON.stringify(defaultConfig));
loadOptions();
updateOptionSummary();
}
function updateVoiceSelect() { function updateVoiceSelect() {
const options = getOptions(); const options = getOptions();
@ -981,29 +1025,51 @@ function explain() {
} }
function getOptions() { function getOptions() {
var result = {}; var result = {};
options.forEach(function (option) { configOptions.options.forEach(function (option) {
result[option] = $('#' + option).is(':checked') != false; result[option] = $('#' + option).is(':checked') != false;
}); });
selects.forEach(function (select) { configOptions.selects.forEach(function (select) {
result[select] = $('#' + select).val(); result[select] = $('#' + select).val();
}); });
configOptions.inputs.forEach(function (input) {
result[input] = $('#' + input).val();
});
return result; return result;
} }
function loadOptions() { function loadOptions() {
var storedOptions = JSON.parse(localStorage.getItem('options'));
options.forEach(function (option) { var storedOptionsText = localStorage.getItem(localStorageOptionsKey);
($('#' + option)).checked = storedOptions[option];
if (storedOptionsText) {
var storedOptions = JSON.parse(storedOptionsText);
configOptions.options.forEach(function (option) {
if (storedOptions[option] != undefined) {
$(`#${option}`).prop('checked', storedOptions[option]);
}
}); });
selects.forEach(function (select) { configOptions.selects.forEach(function (select) {
$('#' + select).value = storedOptions[select]; if (storedOptions[select] != undefined) {
$(`#${select} [value=${storedOptions[select]}]`).attr('selected', false)
$(`#${select} [value=${storedOptions[select]}]`).attr('selected', 'selected')
}
}); });
configOptions.inputs.forEach(function (input) {
if (storedOptions[input] != undefined) {
$(`#${input}`).val(storedOptions[input]);
}
});
}
} }
$('window').ready(function () { $('window').ready(function () {
@ -1020,6 +1086,7 @@ $('window').ready(function () {
loadOptions(); loadOptions();
$('#go').click(startQuiz); $('#go').click(startQuiz);
$('#defaults').click(restoreDefaults);
$('#backToStart').click(showSplash); $('#backToStart').click(showSplash);
$('div.options input').click(updateOptionSummary); $('div.options input').click(updateOptionSummary);
@ -1027,6 +1094,9 @@ $('window').ready(function () {
$('input#trick').click(updateOptionSummary); $('input#trick').click(updateOptionSummary);
$('input#focus_mode').click(updateOptionSummary); $('input#focus_mode').click(updateOptionSummary);
$('select').change(saveOptions);
$('input').change(saveOptions);
updateOptionSummary(); updateOptionSummary();
showSplash(); showSplash();