2022-06-09 11:34:55 +02:00
|
|
|
import { basePath } from './formatPath';
|
|
|
|
import { getLocalStorageItem, setLocalStorageItem } from './storage';
|
|
|
|
|
2024-05-24 13:21:12 +02:00
|
|
|
export const createLocalStorage = <T extends object | string>(
|
2022-06-09 11:34:55 +02:00
|
|
|
key: string,
|
2023-10-02 14:25:46 +02:00
|
|
|
initialValue: T,
|
2022-06-09 11:34:55 +02:00
|
|
|
) => {
|
|
|
|
const internalKey = `${basePath}:${key}:localStorage:v2`;
|
|
|
|
const value = (() => {
|
|
|
|
const state = getLocalStorageItem<T>(internalKey);
|
|
|
|
if (state === undefined) {
|
|
|
|
return initialValue;
|
|
|
|
}
|
|
|
|
return state;
|
|
|
|
})();
|
|
|
|
|
|
|
|
const onUpdate = (newValue: T | ((prev: T) => T)): T => {
|
|
|
|
if (newValue instanceof Function) {
|
|
|
|
const previousValue = getLocalStorageItem<T>(internalKey);
|
|
|
|
const output = newValue(previousValue ?? initialValue);
|
|
|
|
setLocalStorageItem(internalKey, output);
|
|
|
|
return output;
|
|
|
|
}
|
|
|
|
|
|
|
|
setLocalStorageItem(internalKey, newValue);
|
|
|
|
return newValue;
|
|
|
|
};
|
|
|
|
|
|
|
|
return { value, setValue: onUpdate };
|
|
|
|
};
|