Compare commits
1 Commits
f5a6b919aa
...
master
| Author | SHA1 | Date | |
|---|---|---|---|
| 89cf66f28a |
@@ -5,6 +5,15 @@ import { REHYDRATE_API, type RehydrateApiPayload } from './rehydrate';
|
||||
export const api = createApi({
|
||||
reducerPath: 'api',
|
||||
baseQuery: baseQueryWithReauth,
|
||||
// Stale-while-revalidate. The Tier-2 rehydrated cache (below) seeds fulfilled
|
||||
// entries at startup, which would otherwise make RTKQ serve stale data and
|
||||
// never hit the network. These flags keep showing the cached snapshot
|
||||
// instantly but silently refetch from the server whenever it's reachable —
|
||||
// on mount/arg change, on reconnect, and on window refocus. The result: the
|
||||
// server is the source of truth when online; the cache is only a fallback.
|
||||
refetchOnMountOrArgChange: true,
|
||||
refetchOnReconnect: true,
|
||||
refetchOnFocus: true,
|
||||
tagTypes: [
|
||||
'Track',
|
||||
'Album',
|
||||
|
||||
@@ -1,4 +1,5 @@
|
||||
import { configureStore } from '@reduxjs/toolkit';
|
||||
import { setupListeners } from '@reduxjs/toolkit/query';
|
||||
import { api } from '../api';
|
||||
import authReducer from './slices/auth';
|
||||
import connectionReducer from './slices/connection';
|
||||
@@ -27,6 +28,10 @@ export const store = configureStore({
|
||||
getDefaultMiddleware().concat(api.middleware),
|
||||
});
|
||||
|
||||
// Enable refetchOnReconnect / refetchOnFocus by dispatching the browser's
|
||||
// online + focus events into RTKQ (no-op without the api flags set in api/index).
|
||||
setupListeners(store.dispatch);
|
||||
|
||||
// Flush queue/player changes back to localStorage (throttled).
|
||||
startPersistence(store);
|
||||
|
||||
|
||||
Reference in New Issue
Block a user