Files
kiss-translator/src/hooks/Setting.js

80 lines
1.7 KiB
JavaScript
Raw Normal View History

2023-08-30 18:05:37 +08:00
import { STOKEY_SETTING, DEFAULT_SETTING } from "../config";
import { useStorage } from "./Storage";
2023-07-31 15:08:51 +08:00
import { useSync } from "./Sync";
2023-08-26 14:31:13 +08:00
import { trySyncSetting } from "../libs/sync";
2023-08-30 18:05:37 +08:00
import { createContext, useCallback, useContext } from "react";
2023-07-20 13:45:41 +08:00
2023-08-30 18:05:37 +08:00
const SettingContext = createContext({
setting: null,
updateSetting: async () => {},
});
export function SettingProvider({ children }) {
const { data, update } = useStorage(STOKEY_SETTING, DEFAULT_SETTING);
const {
sync: { settingUpdateAt },
updateSync,
} = useSync();
const updateSetting = useCallback(
async (obj) => {
const updateAt = settingUpdateAt ? Date.now() : 0;
await update(obj);
await updateSync({ settingUpdateAt: updateAt });
trySyncSetting();
},
[settingUpdateAt]
);
return (
<SettingContext.Provider
value={{
setting: data,
updateSetting,
}}
>
{children}
</SettingContext.Provider>
);
2023-07-20 13:45:41 +08:00
}
/**
2023-08-30 18:05:37 +08:00
* 设置 hook
2023-07-20 13:45:41 +08:00
* @returns
*/
2023-08-30 18:05:37 +08:00
export function useSetting() {
return useContext(SettingContext);
2023-07-20 13:45:41 +08:00
}
2023-08-30 18:05:37 +08:00
// export function useSetting() {
// const [setting,setSeting]= useState(null);
// useEffect(()=>{
// (async ()=>{
// const
// })()
// },[])
// }
// /**
// * 设置hook
// * @returns
// */
// export function useSetting() {
// const storages = useStorages();
// return storages?.[STOKEY_SETTING];
// }
// /**
// * 更新设置
// * @returns
// */
// export function useSettingUpdate() {
// const sync = useSync();
// return async (obj) => {
// const updateAt = sync.opt?.settingUpdateAt ? Date.now() : 0;
// await storage.putObj(STOKEY_SETTING, obj);
// await sync.update({ settingUpdateAt: updateAt });
// trySyncSetting();
// };
// }