12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061 |
- /* @flow */
-
- import { applyMiddleware } from 'redux';
- import type { Middleware } from 'redux';
-
- /**
- * A registry for Redux middleware, allowing features to register their
- * middleware without needing to create additional inter-feature dependencies.
- */
- class MiddlewareRegistry {
- _elements: Array<Middleware<*, *>>;
-
- /**
- * Creates a MiddlewareRegistry instance.
- */
- constructor() {
- /**
- * The set of registered middleware.
- *
- * @private
- * @type {Middleware[]}
- */
- this._elements = [];
- }
-
- /**
- * Applies all registered middleware into a store enhancer.
- * (@link http://redux.js.org/docs/api/applyMiddleware.html).
- *
- * @param {Middleware[]} additional - Any additional middleware that need to
- * be included (such as middleware from third-party modules).
- * @returns {Middleware}
- */
- applyMiddleware(...additional: Array<Middleware<*, *>>) {
- // XXX The explicit definition of the local variable middlewares is to
- // satisfy flow.
- const middlewares = [
- ...this._elements,
- ...additional
- ];
-
- return applyMiddleware(...middlewares);
- }
-
- /**
- * Adds a middleware to the registry.
- *
- * The method is to be invoked only before {@link #applyMiddleware()}.
- *
- * @param {Middleware} middleware - A Redux middleware.
- * @returns {void}
- */
- register(middleware: Middleware<*, *>) {
- this._elements.push(middleware);
- }
- }
-
- /**
- * The public singleton instance of the MiddlewareRegistry class.
- */
- export default new MiddlewareRegistry();
|