useLocalState.tsx 615 B

123456789101112131415161718192021222324
  1. import { LS_KEYS, getData, setData } from "@ente/shared/storage/localStorage";
  2. import { useEffect, useState } from "react";
  3. export function useLocalState<T>(
  4. key: LS_KEYS,
  5. initialValue: T,
  6. ): [T, (newValue: T) => void] {
  7. const [value, setValue] = useState<T>(initialValue);
  8. useEffect(() => {
  9. const { value } = getData(key) ?? {};
  10. if (typeof value !== "undefined") {
  11. setValue(value);
  12. }
  13. }, []);
  14. useEffect(() => {
  15. if (typeof value !== "undefined") {
  16. setData(key, { value });
  17. }
  18. }, [value]);
  19. return [value, setValue];
  20. }