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 17:52:27 +02:00
|
|
|
import type WithShortcut from "editor-toolbar/WithShortcut.svelte";
|
|
|
|
import type { WithShortcutProps } from "editor-toolbar/WithShortcut";
|
2021-04-20 14:23:28 +02:00
|
|
|
import type { DynamicSvelteComponent } from "sveltelib/dynamicComponent";
|
2021-04-08 23:08:36 +02:00
|
|
|
|
2021-04-22 19:55:26 +02:00
|
|
|
import * as tr from "lib/i18n";
|
2021-04-22 17:52:27 +02:00
|
|
|
import { iconButton, withShortcut } from "editor-toolbar/dynamicComponents";
|
2021-04-08 23:08:36 +02:00
|
|
|
|
|
|
|
import bracketsIcon from "./code-brackets.svg";
|
|
|
|
|
2021-04-20 14:23:28 +02:00
|
|
|
import { forEditorField } from ".";
|
2021-04-20 15:41:26 +02:00
|
|
|
import { wrap } from "./wrap";
|
2021-04-20 14:23:28 +02:00
|
|
|
|
2021-04-08 23:08:36 +02:00
|
|
|
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);
|
2021-04-08 23:08:36 +02:00
|
|
|
});
|
|
|
|
|
|
|
|
if (increment) {
|
|
|
|
highest++;
|
|
|
|
}
|
|
|
|
|
|
|
|
return Math.max(1, highest);
|
|
|
|
}
|
|
|
|
|
2021-04-22 17:52:27 +02:00
|
|
|
function onCloze(event: KeyboardEvent | MouseEvent): void {
|
|
|
|
const highestCloze = getCurrentHighestCloze(!event.getModifierState("Alt"));
|
2021-04-08 23:08:36 +02:00
|
|
|
wrap(`{{c${highestCloze}::`, "}}");
|
|
|
|
}
|
|
|
|
|
2021-04-22 17:52:27 +02:00
|
|
|
export function getClozeButton(): DynamicSvelteComponent<typeof WithShortcut> &
|
|
|
|
WithShortcutProps {
|
|
|
|
return withShortcut({
|
2021-04-22 03:37:01 +02:00
|
|
|
id: "cloze",
|
2021-04-22 17:52:27 +02:00
|
|
|
shortcut: "Control+Shift+KeyC",
|
|
|
|
optionalModifiers: ["Alt"],
|
2021-04-22 03:25:31 +02:00
|
|
|
button: iconButton({
|
|
|
|
icon: bracketsIcon,
|
|
|
|
onClick: onCloze,
|
2021-04-22 13:38:37 +02:00
|
|
|
tooltip: tr.editingClozeDeletion(),
|
2021-04-22 03:25:31 +02:00
|
|
|
}),
|
2021-04-09 18:42:41 +02:00
|
|
|
});
|
|
|
|
}
|