From 487d0feaccd57a21789bae6737256eb63a23167a Mon Sep 17 00:00:00 2001 From: Miodec Date: Mon, 22 Jan 2024 14:48:44 +0100 Subject: [PATCH] impr(typing): remember lazy mode choice when typing arabic in local storage closes #4948 --- frontend/src/ts/states/arabic-lazy-mode.ts | 10 ++++++++++ frontend/src/ts/test/test-logic.ts | 15 ++++++++++++--- 2 files changed, 22 insertions(+), 3 deletions(-) create mode 100644 frontend/src/ts/states/arabic-lazy-mode.ts diff --git a/frontend/src/ts/states/arabic-lazy-mode.ts b/frontend/src/ts/states/arabic-lazy-mode.ts new file mode 100644 index 000000000000..e213d6fa56b5 --- /dev/null +++ b/frontend/src/ts/states/arabic-lazy-mode.ts @@ -0,0 +1,10 @@ +export function get(): boolean { + return (localStorage.getItem("prefersArabicLazyMode") ?? "true") === "true"; +} + +export function set(value: boolean): void { + localStorage.setItem( + "prefersArabicLazyMode", + value === true ? "true" : "false" + ); +} diff --git a/frontend/src/ts/test/test-logic.ts b/frontend/src/ts/test/test-logic.ts index 476b96794806..982052964401 100644 --- a/frontend/src/ts/test/test-logic.ts +++ b/frontend/src/ts/test/test-logic.ts @@ -55,6 +55,7 @@ import * as MemoryFunboxTimer from "./funbox/memory-funbox-timer"; import * as KeymapEvent from "../observables/keymap-event"; import * as LayoutfluidFunboxTimer from "../test/funbox/layoutfluid-funbox-timer"; import * as Wordset from "./wordset"; +import * as ArabicLazyMode from "../states/arabic-lazy-mode"; let failReason = ""; const koInputVisual = document.getElementById("koInputVisual") as HTMLElement; @@ -1521,7 +1522,10 @@ ConfigEvent.subscribe((eventKey, eventValue, nosave) => { if (ActivePage.get() === "test") { if (eventKey === "language") { //automatically enable lazy mode for arabic - if ((eventValue as string)?.startsWith("arabic")) { + if ( + (eventValue as string)?.startsWith("arabic") && + ArabicLazyMode.get() + ) { UpdateConfig.setLazyMode(true, true); } restart(); @@ -1551,8 +1555,13 @@ ConfigEvent.subscribe((eventKey, eventValue, nosave) => { }, 0); } } - if (eventKey === "lazyMode" && eventValue === false && !nosave) { - rememberLazyMode = false; + if (eventKey === "lazyMode" && !nosave) { + if (Config.language.startsWith("arabic")) { + ArabicLazyMode.set(eventValue as boolean); + } + if (eventValue === false) { + rememberLazyMode = false; + } } });