2018-11-23 10:41:50 -08:00
|
|
|
// @flow
|
|
|
|
|
|
|
|
import { createStore, applyMiddleware, compose } from 'redux';
|
2018-11-23 15:23:41 -08:00
|
|
|
import { routerMiddleware } from 'connected-react-router';
|
|
|
|
import { createBrowserHistory } from 'history';
|
2018-11-23 10:41:50 -08:00
|
|
|
import thunk from 'redux-thunk';
|
2018-11-23 15:23:41 -08:00
|
|
|
import { createRootReducer } from '../reducers';
|
2018-11-23 10:41:50 -08:00
|
|
|
|
2018-11-23 15:23:41 -08:00
|
|
|
export const history = createBrowserHistory();
|
|
|
|
|
|
|
|
export const configureStore = (initialState: Object) => {
|
2018-11-23 10:41:50 -08:00
|
|
|
let enhancer;
|
2018-11-23 15:23:41 -08:00
|
|
|
const middleware = applyMiddleware(
|
|
|
|
thunk,
|
|
|
|
routerMiddleware(history),
|
|
|
|
);
|
2018-11-23 10:41:50 -08:00
|
|
|
|
|
|
|
if (
|
|
|
|
process.env.NODE_ENV !== 'production'
|
|
|
|
|| process.env.NODE_ENV !== 'staging'
|
|
|
|
) {
|
|
|
|
enhancer = compose(
|
|
|
|
middleware,
|
|
|
|
window.devToolsExtension ? window.devToolsExtension() : f => f,
|
|
|
|
);
|
|
|
|
} else {
|
|
|
|
enhancer = compose(middleware);
|
|
|
|
}
|
|
|
|
|
2018-11-23 15:23:41 -08:00
|
|
|
return createStore(
|
|
|
|
createRootReducer(history),
|
|
|
|
initialState,
|
|
|
|
enhancer,
|
|
|
|
);
|
|
|
|
};
|