123456789101112131415161718192021222324 |
- import { LS_KEYS, getData, setData } from "@ente/shared/storage/localStorage";
- import { useEffect, useState } from "react";
- export function useLocalState<T>(
- key: LS_KEYS,
- initialValue: T,
- ): [T, (newValue: T) => void] {
- const [value, setValue] = useState<T>(initialValue);
- useEffect(() => {
- const { value } = getData(key) ?? {};
- if (typeof value !== "undefined") {
- setValue(value);
- }
- }, []);
- useEffect(() => {
- if (typeof value !== "undefined") {
- setData(key, { value });
- }
- }, [value]);
- return [value, setValue];
- }
|