mirror of
https://github.com/ZetaKebab/japanese-conjugation-drill.git
synced 2025-01-14 22:08:44 +00:00
Added "Reset" button and added the number of questions to the config.
This commit is contained in:
parent
61ec40fb15
commit
bca0348dd4
@ -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">
|
||||||
|
@ -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];
|
|
||||||
});
|
|
||||||
|
|
||||||
selects.forEach(function (select) {
|
if (storedOptionsText) {
|
||||||
$('#' + select).value = storedOptions[select];
|
|
||||||
});
|
var storedOptions = JSON.parse(storedOptionsText);
|
||||||
|
|
||||||
|
configOptions.options.forEach(function (option) {
|
||||||
|
if (storedOptions[option] != undefined) {
|
||||||
|
$(`#${option}`).prop('checked', storedOptions[option]);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
configOptions.selects.forEach(function (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();
|
||||||
|
Loading…
Reference in New Issue
Block a user