33 lines
907 B
TypeScript
33 lines
907 B
TypeScript
import thunk from "redux-thunk";
|
|
import { applyMiddleware, compose, Middleware } from "redux";
|
|
import { EnvName } from "./interfaces";
|
|
|
|
interface MiddlewareConfig {
|
|
fn: Middleware;
|
|
env: EnvName;
|
|
}
|
|
|
|
/** To make it easier to manage all things watching the state tree,
|
|
* we keep subscriber functions in this array. */
|
|
export let mwConfig: MiddlewareConfig[] = [
|
|
{
|
|
env: "*",
|
|
fn: thunk
|
|
}
|
|
, {
|
|
env: "development",
|
|
fn: require("redux-immutable-state-invariant").default()
|
|
}
|
|
];
|
|
|
|
export function getMiddleware(env: EnvName) {
|
|
const middlewareFns = mwConfig
|
|
.filter(function (mwc) { return (mwc.env === env) || (mwc.env === "*"); })
|
|
.map((mwc) => mwc.fn);
|
|
const dtCompose = (window as any).__REDUX_DEVTOOLS_EXTENSION_COMPOSE__;
|
|
const composeEnhancers = dtCompose || compose;
|
|
const middlewares = applyMiddleware(...middlewareFns);
|
|
|
|
return composeEnhancers(middlewares);
|
|
}
|