diff options
| author | Fuwn <[email protected]> | 2026-03-28 06:09:40 +0000 |
|---|---|---|
| committer | Fuwn <[email protected]> | 2026-03-28 06:09:40 +0000 |
| commit | b48a27fe04d893c92b28c97d3f78357ce67bb419 (patch) | |
| tree | 89f568bfbd26b404bbb3e09fb29e3af50890be46 /src/stores | |
| parent | fix(preferences): preserve partial preference updates (diff) | |
| download | due.moe-b48a27fe04d893c92b28c97d3f78357ce67bb419.tar.xz due.moe-b48a27fe04d893c92b28c97d3f78357ce67bb419.zip | |
fix(cache): preserve hydrated client state
Diffstat (limited to 'src/stores')
| -rw-r--r-- | src/stores/identity.ts | 19 | ||||
| -rw-r--r-- | src/stores/stateBin.ts | 10 |
2 files changed, 21 insertions, 8 deletions
diff --git a/src/stores/identity.ts b/src/stores/identity.ts index b78dd519..52e0cba7 100644 --- a/src/stores/identity.ts +++ b/src/stores/identity.ts @@ -12,18 +12,23 @@ export const defaultIdentity: UserIdentity = { const createStore = () => { const store = writable<UserIdentity>(defaultIdentity); let state: UserIdentity = defaultIdentity; - - if (browser) - localforage.getItem<UserIdentity>("identity").then((value) => { - if (value && typeof value === "object") store.set(value); - }); + let hydrated = !browser; store.subscribe((value) => { state = value; - if (browser) localforage.setItem("identity", value); + if (browser && hydrated) localforage.setItem("identity", value); }); + if (browser) + localforage.getItem<UserIdentity>("identity").then(async (value) => { + if (value && typeof value === "object") store.set(value); + + hydrated = true; + + await localforage.setItem("identity", state); + }); + return { subscribe: store.subscribe, set: store.set, @@ -41,7 +46,7 @@ const createStore = () => { defaultIdentity as unknown as Record<string, unknown> )[key]; - if (browser) localforage.setItem("identity", updatedIdentity); + if (browser && hydrated) localforage.setItem("identity", updatedIdentity); return updatedIdentity; }, diff --git a/src/stores/stateBin.ts b/src/stores/stateBin.ts index 06d34bef..1d3f5dee 100644 --- a/src/stores/stateBin.ts +++ b/src/stores/stateBin.ts @@ -13,14 +13,22 @@ interface StateBin { const STORAGE_KEY = "stateBin"; const baseStore = writable<StateBin>({}); +let hydrated = !browser; +let state: StateBin = {}; if (browser) { localforage.getItem<StateBin>(STORAGE_KEY).then((value) => { if (value && typeof value === "object") baseStore.set(value); + + hydrated = true; + + localforage.setItem(STORAGE_KEY, state); }); baseStore.subscribe((value) => { - localforage.setItem(STORAGE_KEY, value); + state = value; + + if (hydrated) localforage.setItem(STORAGE_KEY, value); }); } |