1
0
mirror of https://github.com/Unleash/unleash.git synced 2025-01-01 00:08:27 +01:00
unleash.unleash/frontend/src/utils/createLocalStorage.ts

31 lines
937 B
TypeScript
Raw Normal View History

import { basePath } from './formatPath';
import { getLocalStorageItem, setLocalStorageItem } from './storage';
export const createLocalStorage = <T extends object>(
key: string,
initialValue: T,
) => {
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 };
};