summaryrefslogtreecommitdiff
path: root/frontend/src/utils/hooks/useSetting.ts
blob: afed52390ea0ae33126abae9590d414646ce7a92 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
import { useEffect, useState } from 'react';

import { getSetting, setSetting } from '../settings';

export function useSetting<T>(key: string, def: T): [value: T, setValue: (value: T) => Promise<void>] {
  const [value, setValue] = useState(def);

  useEffect(() => {
    (async () => {
      const res = await getSetting<T>(key, def);
      setValue(res);
    })();
  }, []);

  return [
    value,
    async (val: T) => {
      setValue(val);
      await setSetting(key, val);
    },
  ];
}