summaryrefslogtreecommitdiff
path: root/ext/js/data
diff options
context:
space:
mode:
Diffstat (limited to 'ext/js/data')
-rw-r--r--ext/js/data/anki-template-util.js1
-rw-r--r--ext/js/data/sandbox/anki-note-data-creator.js12
2 files changed, 12 insertions, 1 deletions
diff --git a/ext/js/data/anki-template-util.js b/ext/js/data/anki-template-util.js
index 686b4af8..446c0c71 100644
--- a/ext/js/data/anki-template-util.js
+++ b/ext/js/data/anki-template-util.js
@@ -29,6 +29,7 @@ export function getStandardFieldMarkers(type) {
'clipboard-image',
'clipboard-text',
'cloze-body',
+ 'cloze-body-kana',
'cloze-prefix',
'cloze-suffix',
'conjugation',
diff --git a/ext/js/data/sandbox/anki-note-data-creator.js b/ext/js/data/sandbox/anki-note-data-creator.js
index f43595b6..d0456b0f 100644
--- a/ext/js/data/sandbox/anki-note-data-creator.js
+++ b/ext/js/data/sandbox/anki-note-data-creator.js
@@ -17,7 +17,7 @@
*/
import {getDisambiguations, getGroupedPronunciations, getPronunciationsOfType, getTermFrequency, groupTermTags} from '../../dictionary/dictionary-data-util.js';
-import {distributeFurigana} from '../../language/ja/japanese.js';
+import {distributeFurigana, distributeFuriganaInflected} from '../../language/ja/japanese.js';
/**
* Creates a compatibility representation of the specified data.
@@ -846,9 +846,13 @@ function convertPitchTag({name, category, content, order, score, dictionaries, r
*/
function getCloze(dictionaryEntry, context) {
let originalText = '';
+ let term = '';
+ let reading = '';
switch (dictionaryEntry.type) {
case 'term':
{
+ term = dictionaryEntry.headwords[0].term;
+ reading = dictionaryEntry.headwords[0].reading;
const primarySource = getPrimarySource(dictionaryEntry);
if (primarySource !== null) { originalText = primarySource.originalText; }
}
@@ -867,10 +871,16 @@ function getCloze(dictionaryEntry, context) {
if (typeof text !== 'string') { text = ''; }
if (typeof offset !== 'number') { offset = 0; }
+ const textSegments = [];
+ for (const {text: text2, reading: reading2} of distributeFuriganaInflected(term, reading, text.substring(offset, offset + originalText.length))) {
+ textSegments.push(reading2.length > 0 ? reading2 : text2);
+ }
+
return {
sentence: text,
prefix: text.substring(0, offset),
body: text.substring(offset, offset + originalText.length),
+ bodyKana: textSegments.join(''),
suffix: text.substring(offset + originalText.length)
};
}