2017-07-13 18:55:29 +00:00
|
|
|
import {createStore, applyMiddleware} from 'redux'
|
|
|
|
import withRedux from 'next-redux-wrapper'
|
|
|
|
import nextReduxSaga from 'next-redux-saga'
|
|
|
|
import createSagaMiddleware from 'redux-saga'
|
|
|
|
|
|
|
|
import rootReducer, {exampleInitialState} from './reducer'
|
|
|
|
import rootSaga from './saga'
|
|
|
|
|
|
|
|
const sagaMiddleware = createSagaMiddleware()
|
|
|
|
|
2018-01-26 16:09:49 +00:00
|
|
|
const bindMiddleware = (middleware) => {
|
|
|
|
if (process.env.NODE_ENV !== 'production') {
|
|
|
|
const { composeWithDevTools } = require('redux-devtools-extension')
|
|
|
|
return composeWithDevTools(applyMiddleware(...middleware))
|
|
|
|
}
|
|
|
|
return applyMiddleware(...middleware)
|
|
|
|
}
|
|
|
|
|
2017-07-13 18:55:29 +00:00
|
|
|
export function configureStore (initialState = exampleInitialState) {
|
|
|
|
const store = createStore(
|
|
|
|
rootReducer,
|
|
|
|
initialState,
|
2018-01-26 16:09:49 +00:00
|
|
|
bindMiddleware([sagaMiddleware])
|
2017-07-13 18:55:29 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
store.sagaTask = sagaMiddleware.run(rootSaga)
|
|
|
|
return store
|
|
|
|
}
|
|
|
|
|
|
|
|
export function withReduxSaga (BaseComponent) {
|
|
|
|
return withRedux(configureStore)(nextReduxSaga(BaseComponent))
|
|
|
|
}
|