summaryrefslogtreecommitdiffstatshomepage
path: root/frontend/src/lib/Shortcuts.ts
diff options
context:
space:
mode:
Diffstat (limited to 'frontend/src/lib/Shortcuts.ts')
-rw-r--r--frontend/src/lib/Shortcuts.ts15
1 files changed, 7 insertions, 8 deletions
diff --git a/frontend/src/lib/Shortcuts.ts b/frontend/src/lib/Shortcuts.ts
index 063bd40..259500c 100644
--- a/frontend/src/lib/Shortcuts.ts
+++ b/frontend/src/lib/Shortcuts.ts
@@ -1,5 +1,4 @@
-import { closeModal, modals } from 'svelte-modals';
-import { get } from 'svelte/store';
+import { modals } from 'svelte-modals';
type LowercaseLetter =
| 'a'
@@ -32,12 +31,12 @@ type UppercaseLetter = Uppercase<LowercaseLetter>;
type Letter = LowercaseLetter | UppercaseLetter;
type Special = '?' | 'Enter' | 'Escape' | 'Delete';
-const modeSwitches = ['n', 'g', 'i'] as const;
+const modeSwitches = ['n', 'g', 'i', 'e'] as const;
type ModeSwitch = (typeof modeSwitches)[number];
function isModeSwitch(s: string): s is ModeSwitch {
- // eslint-disable-next-line @typescript-eslint/no-explicit-any, @typescript-eslint/no-unsafe-argument
- return modeSwitches.indexOf(s as any) !== -1;
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
+ return modeSwitches.includes(s as any);
}
type Key = Letter | Special;
@@ -68,8 +67,8 @@ export function handleShortcuts(event: KeyboardEvent) {
}
if (event.key === 'Escape') {
- if (get(modals).length > 0) {
- closeModal();
+ if (modals.stack.length > 0) {
+ modals.close();
event.preventDefault();
event.stopImmediatePropagation();
return;
@@ -84,7 +83,7 @@ export function handleShortcuts(event: KeyboardEvent) {
const handler = handlers.get(mode === undefined ? event.key : `${mode}${event.key}`);
- if (!handler || get(modals).length > 0) {
+ if (!handler || modals.stack.length > 0) {
mode = undefined;
return;
}