mirror of
https://github.com/mountain-loop/yaak.git
synced 2026-04-23 09:08:32 +02:00
Generalized frontend model store (#193)
This commit is contained in:
25
src-web/lib/atoms/atomWithKVStorage.ts
Normal file
25
src-web/lib/atoms/atomWithKVStorage.ts
Normal file
@@ -0,0 +1,25 @@
|
||||
import { atom } from 'jotai/index';
|
||||
import { getKeyValue, setKeyValue } from '../keyValueStore';
|
||||
|
||||
export function atomWithKVStorage<T extends object | boolean | number | string | null>(
|
||||
key: string,
|
||||
fallback: T,
|
||||
namespace = 'global',
|
||||
) {
|
||||
const baseAtom = atom<T>(fallback);
|
||||
|
||||
baseAtom.onMount = (setValue) => {
|
||||
setValue(getKeyValue<T>({ namespace, key, fallback }));
|
||||
};
|
||||
|
||||
const derivedAtom = atom<T, [T | ((prev: T) => T)], void>(
|
||||
(get) => get(baseAtom),
|
||||
(get, set, update) => {
|
||||
const nextValue = typeof update === 'function' ? update(get(baseAtom)) : update;
|
||||
set(baseAtom, nextValue);
|
||||
setKeyValue({ namespace, key, value: nextValue }).catch(console.error);
|
||||
},
|
||||
);
|
||||
|
||||
return derivedAtom;
|
||||
}
|
||||
Reference in New Issue
Block a user