From 60172140424966c1dcb51642f1dba1f25df610f5 Mon Sep 17 00:00:00 2001 From: Henrik Giesel Date: Tue, 19 Apr 2022 08:08:32 +0200 Subject: [PATCH] Fix resetting of formatting modes when pressing modifer or dead keys (#1811) * Fix shift removing bold formatting * Remove input handler on selection change We listened to "non-input events" mostly to catch events that change the selection (like Ctrl-a, or arrow keys) anyway --- ts/lib/keys.ts | 13 +++++++++---- ts/lib/shortcuts.ts | 4 ++-- ts/sveltelib/input-handler.ts | 12 ++---------- 3 files changed, 13 insertions(+), 16 deletions(-) diff --git a/ts/lib/keys.ts b/ts/lib/keys.ts index 7beda3508..f7302dc84 100644 --- a/ts/lib/keys.ts +++ b/ts/lib/keys.ts @@ -16,11 +16,16 @@ function translateModifierToPlatform(modifier: Modifier): string { return platformModifiers[allModifiers.indexOf(modifier)]; } -const GENERAL_KEY = 0; -const NUMPAD_KEY = 3; +export function checkIfModifierKey(event: KeyboardEvent): boolean { + // At least the web view on Desktop Anki gives out the wrong values for + // `event.location`, which is why we do it like this. + let isInputKey = false; -export function checkIfInputKey(event: KeyboardEvent): boolean { - return event.location === GENERAL_KEY || event.location === NUMPAD_KEY; + for (const modifier of allModifiers) { + isInputKey ||= event.code.startsWith(modifier); + } + + return isInputKey; } export function keyboardEventIsPrintableKey(event: KeyboardEvent): boolean { diff --git a/ts/lib/shortcuts.ts b/ts/lib/shortcuts.ts index e4da2732d..7dab8e947 100644 --- a/ts/lib/shortcuts.ts +++ b/ts/lib/shortcuts.ts @@ -4,7 +4,7 @@ import { on } from "./events"; import type { Modifier } from "./keys"; import { - checkIfInputKey, + checkIfModifierKey, checkModifiers, keyToPlatformString, modifiersToPlatformString, @@ -135,7 +135,7 @@ function innerShortcut( function handler(event: KeyboardEvent): void { if (nextCheck(event)) { innerShortcut(target, event, callback, ...restChecks); - } else if (checkIfInputKey(event)) { + } else if (!checkIfModifierKey(event)) { // Any non-modifier key will cancel the shortcut sequence remove(); } diff --git a/ts/sveltelib/input-handler.ts b/ts/sveltelib/input-handler.ts index c91bc286f..ff0ec573b 100644 --- a/ts/sveltelib/input-handler.ts +++ b/ts/sveltelib/input-handler.ts @@ -3,7 +3,6 @@ import { getRange, getSelection } from "../lib/cross-browser"; import { on } from "../lib/events"; -import { keyboardEventIsPrintableKey } from "../lib/keys"; import { HandlerList } from "./handler-list"; const nbsp = "\xa0"; @@ -62,13 +61,6 @@ function useInputHandler(): [InputHandlerAPI, SetupInputHandlerAction] { insertText.clear(); } - function onKeydown(event: KeyboardEvent): void { - /* using arrow keys should cancel */ - if (!keyboardEventIsPrintableKey(event)) { - clearInsertText(); - } - } - function onInput(this: HTMLElement, event: InputEvent): void { // prevent unwanted
from being left behind when clearing field contents if ( @@ -87,7 +79,7 @@ function useInputHandler(): [InputHandlerAPI, SetupInputHandlerAction] { const blurOff = on(element, "blur", clearInsertText); const pointerDownOff = on(element, "pointerdown", clearInsertText); - const keyDownOff = on(element, "keydown", onKeydown); + const selectionChangeOff = on(document, "selectionchange", clearInsertText); return { destroy() { @@ -95,7 +87,7 @@ function useInputHandler(): [InputHandlerAPI, SetupInputHandlerAction] { inputOff(); blurOff(); pointerDownOff(); - keyDownOff(); + selectionChangeOff(); }, }; }