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