2018-01-29 11:47:12 -08:00
|
|
|
import React from 'react';
|
2018-02-21 13:42:41 -08:00
|
|
|
import { hydrate } from 'react-dom';
|
2018-02-20 14:31:05 -08:00
|
|
|
import { Provider } from 'react-redux';
|
2018-02-06 19:00:52 -08:00
|
|
|
import { createStore, applyMiddleware, compose } from 'redux';
|
2018-02-20 14:31:05 -08:00
|
|
|
import { BrowserRouter } from 'react-router-dom';
|
2018-01-29 11:47:12 -08:00
|
|
|
import Reducer from 'reducers';
|
2018-02-06 19:00:52 -08:00
|
|
|
import createSagaMiddleware from 'redux-saga';
|
|
|
|
import rootSaga from 'sagas';
|
2018-02-20 14:31:05 -08:00
|
|
|
|
|
|
|
import GAListener from 'components/GAListener';
|
|
|
|
import App from './app';
|
2018-01-29 11:47:12 -08:00
|
|
|
|
2018-02-21 08:05:41 -08:00
|
|
|
// get the state from a global variable injected into the server-generated HTML
|
|
|
|
const preloadedState = window.__PRELOADED_STATE__ || null;
|
|
|
|
|
|
|
|
// Allow the passed state to be garbage-collected
|
2018-02-21 17:02:57 -08:00
|
|
|
delete window.__PRELOADED_STATE__;
|
2018-02-21 08:05:41 -08:00
|
|
|
|
|
|
|
// create and apply middleware
|
2018-02-06 19:00:52 -08:00
|
|
|
const sagaMiddleware = createSagaMiddleware();
|
|
|
|
const middleware = applyMiddleware(sagaMiddleware);
|
2018-02-21 08:05:41 -08:00
|
|
|
const reduxMiddleware = window.__REDUX_DEVTOOLS_EXTENSION__ ? compose(middleware, window.__REDUX_DEVTOOLS_EXTENSION__()) : middleware;
|
2018-02-06 19:00:52 -08:00
|
|
|
|
2018-02-21 08:05:41 -08:00
|
|
|
// create teh store
|
2018-02-21 10:53:36 -08:00
|
|
|
let store;
|
|
|
|
if (preloadedState) {
|
|
|
|
store = createStore(Reducer, preloadedState, reduxMiddleware);
|
|
|
|
} else {
|
|
|
|
store = createStore(Reducer, reduxMiddleware);
|
|
|
|
}
|
2018-01-29 11:47:12 -08:00
|
|
|
|
2018-02-21 08:05:41 -08:00
|
|
|
// run the saga middlweare
|
2018-02-06 19:00:52 -08:00
|
|
|
sagaMiddleware.run(rootSaga);
|
|
|
|
|
2018-02-21 08:05:41 -08:00
|
|
|
// render the app
|
2018-02-21 13:42:41 -08:00
|
|
|
hydrate(
|
2018-02-20 14:31:05 -08:00
|
|
|
<Provider store={store}>
|
|
|
|
<BrowserRouter>
|
|
|
|
<GAListener>
|
|
|
|
<App />
|
|
|
|
</GAListener>
|
|
|
|
</BrowserRouter>
|
|
|
|
</Provider>,
|
2018-01-29 11:47:12 -08:00
|
|
|
document.getElementById('react-app')
|
2018-01-29 12:49:01 -08:00
|
|
|
);
|