From fbaff068eaf96b779b3f68da73dd0d0ef56ba4ce Mon Sep 17 00:00:00 2001 From: doncr Date: Sun, 25 Dec 2016 15:30:53 +0000 Subject: [PATCH] Implemented conjugation type options. --- conjugation/drill.css | 16 +++++ conjugation/drill.html | 59 ++++++++------- conjugation/drill.js | 158 ++++++++++++++++++++++++----------------- 3 files changed, 137 insertions(+), 96 deletions(-) diff --git a/conjugation/drill.css b/conjugation/drill.css index 308bd15..5607f30 100644 --- a/conjugation/drill.css +++ b/conjugation/drill.css @@ -139,6 +139,22 @@ div#history table th { text-align: left; } +div.options > * { + display: inline-block; + vertical-align: top; + margin: 20px; +} + +div#splash > * { + margin-left: auto; + margin-right: auto; + display: table; +} + +input#numQuestions { + width: 60px; +} + /* Tooltip from http://jsfiddle.net/AndreaLigios/jtLbpy62/ */ [tooltip]:before { diff --git a/conjugation/drill.html b/conjugation/drill.html index 63ce783..bd441fa 100644 --- a/conjugation/drill.html +++ b/conjugation/drill.html @@ -10,45 +10,44 @@
+

Don's Japanese Conjugation Drill

+
Number of Questions +
-
-

Conjugation types

-
    -
  • -
  • -
  • - -
+
+
+

Conjugation types

+
    +
  • +
  • +
  • +
  • +
  • +
  • +
  • +
  • +
+
+ +
+

Verb classes

+
    +
  • +
  • +
  • +
  • +
  • +
+
-
-

Verb classes

-
    -
  • -
  • -
  • -
  • -
  • -
  • -
  • -
  • -
-
- - -
- The quiz refers to negative て forms. In this test, they are assumed to be ~なくて and not ~ないで . + When the test refers to negative て forms, they are assumed to be ~なくて and not ~ないで .
diff --git a/conjugation/drill.js b/conjugation/drill.js index 549142f..6a37632 100644 --- a/conjugation/drill.js +++ b/conjugation/drill.js @@ -470,6 +470,8 @@ var conjugations = { }, }; + + var log; Array.prototype.randomElement = function () { @@ -649,71 +651,71 @@ var verb_relative_form = { "negative" : "て", }, -// "potential" : { -// -// "plain" : "potential", -// "potential negative" : "affirmative", -// }, -// -// "potential negative" : { -// -// "potential" : "negative", -// "negative" : "potential", -// }, -// -// "imperative" : { -// -// "plain" : "imperative", -// "imperative negative" : "affirmative", -// }, -// -// "imperative negative" : { -// -// "imperative" : "negative", -// "negative" : "imperative", -// }, -// -// "causative" : { -// -// "plain" : "causative", -// "causative negative" : "affirmative", -// "causative passive" : "active", -// }, -// -// "causative negative" : { -// -// "causative" : "negative", -// "negative" : "causative", -// "causative passive negative" : "active", -// }, -// -// "passive" : { -// -// "plain" : "passive", -// "passive negative" : "affirmative", -// "causative passive" : "non-causative", -// }, -// -// "passive negative" : { -// -// "passive" : "negative", -// "negative" : "passive", -// "causative passive negative" : "non-causative" -// }, -// -// "causative passive" : { -// -// "causative" : "passive", -// "passive" : "causative", -// "causative passive negative" : "affirmative", -// }, -// -// "causative passive negative" : { -// -// "causative negative" : "passive", -// "passive negative" : "causative", -// "causative passive" : "negative", -// }, + "potential" : { + + "plain" : "potential", + "potential negative" : "affirmative", + }, + + "potential negative" : { + + "potential" : "negative", + "negative" : "potential", + }, + + "imperative" : { + + "plain" : "imperative", + "imperative negative" : "affirmative", + }, + + "imperative negative" : { + + "imperative" : "negative", + "negative" : "imperative", + }, + + "causative" : { + + "plain" : "causative", + "causative negative" : "affirmative", + "causative passive" : "active", + }, + + "causative negative" : { + + "causative" : "negative", + "negative" : "causative", + "causative passive negative" : "active", + }, + + "passive" : { + + "plain" : "passive", + "passive negative" : "affirmative", + "causative passive" : "non-causative", + }, + + "passive negative" : { + + "passive" : "negative", + "negative" : "passive", + "causative passive negative" : "non-causative" + }, + + "causative passive" : { + + "causative" : "passive", + "passive" : "causative", + "causative passive negative" : "affirmative", + }, + + "causative passive negative" : { + + "causative negative" : "passive", + "passive negative" : "causative", + "causative passive" : "negative", + }, }; function wordWithFurigana(word) { @@ -861,15 +863,39 @@ function generateVerbQuestion() { var from_form; var forms; + var count = 0; + while (true) { + if (count++ == 100) { + showSplash(); + return; + } + entry = Object.keys(conjugations).randomElement(); to_form = Object.keys(verb_relative_form).randomElement(); from_form = Object.keys(verb_relative_form[to_form]).randomElement(); forms = getVerbForms(entry); - if ((forms["furigana"][from_form]) && (forms["furigana"][to_form])) { + var valid = true; + var types = from_form.split(" ").concat(to_form.split(" ")); + + types.forEach(function (type) { + if (type != 'plain') { + if ($('#' + type).is(':checked') == false) { + valid = false; + } + } + }); + + if (!forms["furigana"][from_form]) + valid = false; + + if (!forms["furigana"][to_form]) + valid = false; + + if (valid) { break; } }