add fav words page

This commit is contained in:
Gabe Yuan
2023-10-26 17:32:55 +08:00
parent d7eaac5aca
commit 15367bd117
10 changed files with 224 additions and 5 deletions

40
src/hooks/FavWords.js Normal file
View File

@@ -0,0 +1,40 @@
import { KV_WORDS_KEY } from "../config";
import { useCallback, useEffect, useState } from "react";
import { trySyncWords } from "../libs/sync";
import { getWordsWithDefault, setWords } from "../libs/storage";
import { useSyncMeta } from "./Sync";
export function useFavWords() {
const [favWords, setFavWords] = useState({});
const { updateSyncMeta } = useSyncMeta();
const toggleFav = useCallback(
async (word) => {
const favs = { ...favWords };
if (favs[word]) {
delete favs[word];
} else {
favs[word] = { createdAt: Date.now() };
}
await setWords(favs);
await updateSyncMeta(KV_WORDS_KEY);
await trySyncWords();
setFavWords(favs);
},
[updateSyncMeta, favWords]
);
useEffect(() => {
(async () => {
try {
await trySyncWords();
const favWords = await getWordsWithDefault();
setFavWords(favWords);
} catch (err) {
console.log("[query fav]", err);
}
})();
}, []);
return { favWords, toggleFav };
}