orchidmap-front/src/redux/store.js
muerwre 7cdc1f4f95 save: fixed dialog
backend: fixed provider storing
2018-12-11 15:30:22 +07:00

52 lines
1.5 KiB
JavaScript

import { createStore, applyMiddleware, combineReducers, compose } from 'redux';
import { persistStore, persistReducer } from 'redux-persist';
import storage from 'redux-persist/lib/storage';
import createSagaMiddleware from 'redux-saga';
import { userReducer } from '$redux/user/reducer';
import { userSaga } from '$redux/user/sagas';
import { createBrowserHistory } from 'history';
import { locationChanged } from '$redux/user/actions';
const userPersistConfig = {
key: 'user',
whitelist: ['user', 'logo', 'provider'],
storage,
};
// create the saga middleware
export const sagaMiddleware = createSagaMiddleware();
// redux extension composer
/* eslint-disable no-underscore-dangle */
const composeEnhancers =
typeof window === 'object' &&
window.__REDUX_DEVTOOLS_EXTENSION_COMPOSE__
? window.__REDUX_DEVTOOLS_EXTENSION_COMPOSE__({})
: compose;
/* eslint-enable no-underscore-dangle */
// export const history = createHistory();
export const store = createStore(
combineReducers({
user: persistReducer(userPersistConfig, userReducer),
// routing: routerReducer
}),
composeEnhancers(applyMiddleware(/* routerMiddleware(history), */ sagaMiddleware))
);
export function configureStore() {
sagaMiddleware.run(userSaga);
const persistor = persistStore(store);
return { store, persistor };
}
export const history = createBrowserHistory();
export const historyListener = history.listen((location, action) => {
if (action === 'REPLACE') return;
store.dispatch(locationChanged(location.pathname));
});