2022-03-14 16:01:09 -07:00
|
|
|
import { composeWithDevTools } from '@redux-devtools/extension';
|
2022-03-18 14:04:08 -07:00
|
|
|
import { createStore, applyMiddleware, AnyAction } from 'redux';
|
|
|
|
import thunk, { ThunkDispatch } from 'redux-thunk';
|
2022-03-14 16:01:09 -07:00
|
|
|
|
|
|
|
import errorsMiddleware from './middleware/errors';
|
|
|
|
import soundsMiddleware from './middleware/sounds';
|
|
|
|
import appReducer from './reducers';
|
|
|
|
|
|
|
|
export const store = createStore(
|
|
|
|
appReducer,
|
|
|
|
composeWithDevTools(
|
|
|
|
applyMiddleware(
|
|
|
|
thunk,
|
|
|
|
errorsMiddleware(),
|
|
|
|
soundsMiddleware(),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
);
|
|
|
|
|
|
|
|
// Infer the `RootState` and `AppDispatch` types from the store itself
|
|
|
|
// https://redux.js.org/usage/usage-with-typescript
|
|
|
|
export type RootState = ReturnType<typeof store.getState>;
|
2022-03-18 14:04:08 -07:00
|
|
|
export type AppDispatch = ThunkDispatch<{}, {}, AnyAction>;
|