2020-02-18 20:23:31 +01:00
|
|
|
import EmbarkJS from 'Embark/EmbarkJS';
|
2020-02-19 17:35:22 +01:00
|
|
|
import React, { useEffect } from 'react';
|
|
|
|
import ReactDOM from 'react-dom';
|
|
|
|
import thunkMiddleware from 'redux-thunk';
|
|
|
|
import { Provider } from 'react-redux';
|
|
|
|
import { createStore, applyMiddleware } from 'redux';
|
|
|
|
import createRootReducer from './reducers';
|
|
|
|
import { initWeb3 } from './actions/web3';
|
|
|
|
import App from './containers/App';
|
2020-02-18 20:23:31 +01:00
|
|
|
|
2020-02-19 17:35:22 +01:00
|
|
|
const logger = (store) => {
|
|
|
|
return (next) => {
|
|
|
|
return (action) => {
|
|
|
|
console.log('dispatching\n', action);
|
|
|
|
const result = next(action);
|
|
|
|
console.log('next state\n', store.getState());
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
2020-02-18 20:23:31 +01:00
|
|
|
|
2020-02-19 17:35:22 +01:00
|
|
|
let middlewares = [
|
|
|
|
thunkMiddleware,
|
|
|
|
];
|
|
|
|
|
|
|
|
if (true || process.env.NODE_ENV !== 'production') {
|
|
|
|
middlewares = [
|
|
|
|
...middlewares,
|
|
|
|
logger
|
|
|
|
];
|
|
|
|
}
|
|
|
|
|
|
|
|
const store = createStore(
|
|
|
|
createRootReducer(),
|
|
|
|
applyMiddleware(...middlewares),
|
|
|
|
);
|
2020-02-18 20:23:31 +01:00
|
|
|
|
|
|
|
EmbarkJS.onReady((err) => {
|
2020-02-19 17:35:22 +01:00
|
|
|
store.dispatch(initWeb3());
|
|
|
|
|
|
|
|
ReactDOM.render(
|
|
|
|
<Provider store={store}>
|
|
|
|
<App />
|
|
|
|
</Provider>,
|
|
|
|
document.getElementById("root")
|
|
|
|
);
|
2020-02-18 20:23:31 +01:00
|
|
|
});
|