From ceac84d51f85492ce4e6a263c583521ceebadd64 Mon Sep 17 00:00:00 2001 From: Eric Wei Date: Wed, 2 Nov 2022 09:56:26 -0700 Subject: [PATCH] Persist redux state in browser (#1178) * persist redux state Signed-off-by: Eric Wei * switch to session storage Signed-off-by: Eric Wei Signed-off-by: Eric Wei --- dashboards-observability/package.json | 3 +- .../public/framework/redux/store/index.ts | 32 ++++++++++++++++--- dashboards-observability/yarn.lock | 5 +++ 3 files changed, 35 insertions(+), 5 deletions(-) diff --git a/dashboards-observability/package.json b/dashboards-observability/package.json index 173f4b567..7626c0681 100644 --- a/dashboards-observability/package.json +++ b/dashboards-observability/package.json @@ -26,7 +26,8 @@ "postinstall": "^0.7.4", "react-graph-vis": "^1.0.5", "react-paginate": "^8.1.3", - "react-plotly.js": "^2.5.1" + "react-plotly.js": "^2.5.1", + "redux-persist": "^6.0.0" }, "devDependencies": { "@cypress/skip-test": "^2.6.1", diff --git a/dashboards-observability/public/framework/redux/store/index.ts b/dashboards-observability/public/framework/redux/store/index.ts index 7efcf287d..181d1edb2 100644 --- a/dashboards-observability/public/framework/redux/store/index.ts +++ b/dashboards-observability/public/framework/redux/store/index.ts @@ -5,21 +5,45 @@ import { configureStore } from '@reduxjs/toolkit'; import rootReducer from '../reducers'; +import storage from 'redux-persist/lib/storage/session'; +import { + persistStore, + persistReducer, + FLUSH, + REHYDRATE, + PAUSE, + PERSIST, + PURGE, + REGISTER, +} from 'redux-persist'; + +const persistConfig = { + key: 'root', + storage, +}; + +const persistedReducer = persistReducer(persistConfig, rootReducer); const store = configureStore({ - reducer: rootReducer, - middleware: (getDefaultMiddleware) => getDefaultMiddleware(), + reducer: persistedReducer, + middleware: (getDefaultMiddleware) => + getDefaultMiddleware({ + serializableCheck: { + ignoredActions: [FLUSH, REHYDRATE, PAUSE, PERSIST, PURGE, REGISTER], + }, + }), devTools: process.env.NODE_ENV !== 'production', enhancers: [], }); if (process.env.NODE_ENV === 'development' && module.hot) { module.hot.accept('./rootReducer', () => { - const newRootReducer = require('./rootReducer').default; - store.replaceReducer(newRootReducer); + store.replaceReducer(persistReducer(persistConfig, require('./rootReducer').default)); }); } export type AppDispatch = typeof store.dispatch; +export const persistor = persistStore(store); + export default store; diff --git a/dashboards-observability/yarn.lock b/dashboards-observability/yarn.lock index 24d2a17b4..c4f5768fa 100644 --- a/dashboards-observability/yarn.lock +++ b/dashboards-observability/yarn.lock @@ -2387,6 +2387,11 @@ readable-stream@^2.2.2: string_decoder "~1.1.1" util-deprecate "~1.0.1" +redux-persist@^6.0.0: + version "6.0.0" + resolved "https://registry.yarnpkg.com/redux-persist/-/redux-persist-6.0.0.tgz#b4d2972f9859597c130d40d4b146fecdab51b3a8" + integrity sha512-71LLMbUq2r02ng2We9S215LtPu3fY0KgaGE0k8WRgl6RkqxtGfl7HUozz1Dftwsb0D/5mZ8dwAaPbtnzfvbEwQ== + redux-thunk@^2.3.0: version "2.3.0" resolved "https://registry.yarnpkg.com/redux-thunk/-/redux-thunk-2.3.0.tgz#51c2c19a185ed5187aaa9a2d08b666d0d6467622"