anki/ts/editor/cloze.ts

55 lines
1.7 KiB
TypeScript
Raw Normal View History

2021-04-15 15:59:52 +02:00
// Copyright: Ankitects Pty Ltd and contributors
// License: GNU AGPL, version 3 or later; http://www.gnu.org/licenses/agpl.html
2021-04-22 03:25:31 +02:00
import type WithShortcuts from "editor-toolbar/WithShortcuts.svelte";
import type { WithShortcutsProps } from "editor-toolbar/WithShortcuts";
import type { DynamicSvelteComponent } from "sveltelib/dynamicComponent";
import * as tr from "anki/i18n";
2021-04-22 03:25:31 +02:00
import { iconButton, withShortcuts } from "editor-toolbar/dynamicComponents";
import bracketsIcon from "./code-brackets.svg";
import { forEditorField } from ".";
2021-04-20 15:41:26 +02:00
import { wrap } from "./wrap";
const clozePattern = /\{\{c(\d+)::/gu;
function getCurrentHighestCloze(increment: boolean): number {
let highest = 0;
forEditorField([], (field) => {
2021-04-21 14:18:44 +02:00
const fieldHTML = field.editingArea.editable.fieldHTML;
const matches: number[] = [];
let match: RegExpMatchArray | null = null;
while ((match = clozePattern.exec(fieldHTML))) {
matches.push(Number(match[1]));
}
highest = Math.max(highest, ...matches);
});
if (increment) {
highest++;
}
return Math.max(1, highest);
}
function onCloze(event: MouseEvent): void {
const highestCloze = getCurrentHighestCloze(!event.altKey);
wrap(`{{c${highestCloze}::`, "}}");
}
2021-04-22 03:25:31 +02:00
export function getClozeButton(): DynamicSvelteComponent<typeof WithShortcuts> &
WithShortcutsProps {
return withShortcuts({
2021-04-22 03:37:01 +02:00
id: "cloze",
2021-04-22 03:25:31 +02:00
shortcuts: ["Control+Shift+KeyC", "Control+Alt+Shift+KeyC"],
button: iconButton({
icon: bracketsIcon,
onClick: onCloze,
tooltip: tr.editingClozeDeletionCtrlandshiftandc(),
}),
});
}