signal-desktop/ts/state/createStore.ts

60 lines
1.4 KiB
TypeScript
Raw Normal View History

// Copyright 2019-2021 Signal Messenger, LLC
2020-10-30 20:34:04 +00:00
// SPDX-License-Identifier: AGPL-3.0-only
/* eslint-disable no-console */
import {
applyMiddleware,
createStore as reduxCreateStore,
DeepPartial,
Store,
} from 'redux';
2019-01-14 21:49:58 +00:00
import promise from 'redux-promise-middleware';
import thunk from 'redux-thunk';
2019-01-14 21:49:58 +00:00
import { createLogger } from 'redux-logger';
import { reducer, StateType } from './reducer';
declare global {
// We want to extend `window`'s properties, so we need an interface.
// eslint-disable-next-line no-restricted-syntax, @typescript-eslint/no-unused-vars
interface Console {
_log: Console['log'];
}
}
2019-01-14 21:49:58 +00:00
const env = window.getEnvironment();
// So Redux logging doesn't go to disk, and so we can get colors/styles
const directConsole = {
log: console._log,
groupCollapsed: console.groupCollapsed,
group: console.group,
groupEnd: console.groupEnd,
warn: console.warn,
error: console.error,
};
const logger = createLogger({
logger: directConsole,
predicate: (_getState, action) => {
if (action.type === 'network/CHECK_NETWORK_STATUS') {
return false;
}
return true;
},
2019-01-14 21:49:58 +00:00
});
const middlewareList = [
promise,
thunk,
...(env === 'production' ? [] : [logger]),
];
2019-01-14 21:49:58 +00:00
const enhancer = applyMiddleware(...middlewareList);
2019-01-14 21:49:58 +00:00
export const createStore = (
initialState: DeepPartial<StateType>
): Store<StateType> => reduxCreateStore(reducer, initialState, enhancer);