feishin/src/renderer/main.tsx

59 lines
1.8 KiB
TypeScript
Raw Normal View History

2023-08-04 01:41:45 -07:00
import {
PersistedClient,
Persister,
PersistQueryClientProvider,
} from '@tanstack/react-query-persist-client';
import { del, get, set } from 'idb-keyval';
2022-12-19 15:59:14 -08:00
import { createRoot } from 'react-dom/client';
2023-08-04 01:41:45 -07:00
import { App } from '/@/renderer/app';
2025-05-20 19:23:36 -07:00
import { queryClient } from '/@/renderer/lib/react-query';
2022-12-19 15:59:14 -08:00
function createIDBPersister(idbValidKey: IDBValidKey = 'reactQuery') {
2023-08-04 01:41:45 -07:00
return {
persistClient: async (client: PersistedClient) => {
set(idbValidKey, client);
},
removeClient: async () => {
await del(idbValidKey);
},
restoreClient: async () => {
return await get<PersistedClient>(idbValidKey);
},
} as Persister;
}
const indexedDbPersister = createIDBPersister('feishin');
createRoot(document.getElementById('root')!).render(
2023-08-04 01:41:45 -07:00
<PersistQueryClientProvider
client={queryClient}
persistOptions={{
buster: 'feishin',
dehydrateOptions: {
dehydrateQueries: true,
shouldDehydrateQuery: (query) => {
const isSuccess = query.state.status === 'success';
const isLyricsQueryKey =
query.queryKey.includes('song') &&
query.queryKey.includes('lyrics') &&
query.queryKey.includes('select');
return isSuccess && isLyricsQueryKey;
},
},
hydrateOptions: {
defaultOptions: {
queries: {
cacheTime: Infinity,
},
},
},
maxAge: Infinity,
persister: indexedDbPersister,
}}
>
2023-07-01 19:10:05 -07:00
<App />
2023-08-04 01:41:45 -07:00
</PersistQueryClientProvider>,
2022-12-31 19:26:58 -08:00
);