Skip to content

Instantly share code, notes, and snippets.

@xiongemi
Last active April 10, 2023 16:45
Show Gist options
  • Save xiongemi/5f364d84f89b647dcaaf7e5437ea789c to your computer and use it in GitHub Desktop.
Save xiongemi/5f364d84f89b647dcaaf7e5437ea789c to your computer and use it in GitHub Desktop.
redux root state setup to track user likes
import { EntityState } from '@reduxjs/toolkit';
import { createTransform } from 'redux-persist';
import { LIKES_FEATURE_KEY } from '../likes/likes.slice';
const transformEntityStateToPersist = createTransform(
// transform state on its way to being serialized and persisted.
(
entityState: EntityState<any>
): {
ids: string;
entities: any;
} => {
return {
...entityState,
ids: JSON.stringify(entityState.ids),
entities: JSON.stringify(entityState.entities),
};
},
// transform state being rehydrated
(entityState: { ids: string; entities: string }): EntityState<any> => {
return {
...entityState,
ids: JSON.parse(entityState.ids),
entities: JSON.parse(entityState.entities),
};
},
// define which reducers this transform gets called for.
{ whitelist: [LIKES_FEATURE_KEY] }
);
export { transformEntityStateToPersist };
import { initialLikesState } from '../likes/likes.slice';
import { RootState } from './root-state.interface';
export const initialRootState: RootState = {
likes: initialLikesState
};
import { LikesState } from '../likes/likes.slice';
export interface RootState {
likes: LikesState;
}
import { combineReducers } from '@reduxjs/toolkit';
import { likesReducer } from '../likes/likes.slice';
import { RootState } from './root-state.interface';
export const createRootReducer = combineReducers<RootState>({
likes: likesReducer
});
import { configureStore } from '@reduxjs/toolkit';
import logger from 'redux-logger';
import { persistStore, persistReducer, PersistConfig } from 'redux-persist';
import { initialRootState } from './root-state.initial';
import { RootState } from './root-state.interface';
import { createRootReducer } from './root.reducer';
declare const process: any;
export const createRootStore = (persistConfig: PersistConfig<RootState>) => {
const isDevelopment = process.env.NODE_ENV === 'development';
const rootReducer = createRootReducer;
const persistedReducer = persistReducer(persistConfig, rootReducer);
const store = configureStore({
reducer: persistedReducer,
middleware: (getDefaultMiddleware) => {
const defaultMiddleware = getDefaultMiddleware({
serializableCheck: false,
});
return isDevelopment
? defaultMiddleware.concat(logger)
: defaultMiddleware;
},
devTools: isDevelopment,
preloadedState: initialRootState,
});
const persistor = persistStore(store);
return { store, persistor };
};
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment