1
0
mirror of https://github.com/trezor/trezor-wallet synced 2025-01-25 23:41:07 +00:00
trezor-wallet/src/store.js
2018-10-11 18:04:25 +02:00

70 lines
1.9 KiB
JavaScript

/* @flow */
import { createStore, applyMiddleware, compose } from 'redux';
import { routerMiddleware } from 'react-router-redux';
import thunk from 'redux-thunk';
import createHistory from 'history/createHashHistory';
import { createLogger } from 'redux-logger';
import reducers from 'reducers';
import services from 'services';
import Raven from 'raven-js';
import RavenMiddleware from 'redux-raven-middleware';
import * as buildUtils from 'utils/build';
import type { Action, GetState } from 'flowtype';
export const history: History = createHistory({ queryKey: false });
const initialState: any = {};
const enhancers = [];
const middlewares = [
thunk,
routerMiddleware(history),
];
// sentry io middleware only in dev and beta build
if (buildUtils.isDev() || buildUtils.isBeta()) {
const RAVEN_KEY = 'https://34b8c09deb6c4cd2a4dc3f0029cd02d8@sentry.io/1279550';
const ravenMiddleware = RavenMiddleware(RAVEN_KEY);
Raven.config(RAVEN_KEY).install();
middlewares.push(ravenMiddleware);
}
let composedEnhancers: any;
if (buildUtils.isDev()) {
const excludeLogger = (getState: GetState, action: Action): boolean => {
//'@@router/LOCATION_CHANGE'
const excluded: Array<?string> = ['LOG_TO_EXCLUDE', 'log__add', undefined];
const pass: Array<?string> = excluded.filter(act => action.type === act);
return pass.length === 0;
};
const logger = createLogger({
level: 'info',
predicate: excludeLogger,
collapsed: true,
});
if (window && typeof window.devToolsExtension === 'function') {
enhancers.push(window.devToolsExtension());
}
composedEnhancers = compose(
applyMiddleware(logger, ...middlewares, ...services),
...enhancers,
);
} else {
composedEnhancers = compose(
applyMiddleware(...middlewares, ...services),
...enhancers,
);
}
export default createStore(
reducers,
initialState,
composedEnhancers,
);