Skip to content

Commit

Permalink
compose reducer on the fly instead of storing reducer array
Browse files Browse the repository at this point in the history
  • Loading branch information
zhaosiyang committed Sep 24, 2019
1 parent dcc72ee commit 685cb32
Showing 1 changed file with 7 additions and 4 deletions.
11 changes: 7 additions & 4 deletions modules/store/src/reducer_creator.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
import { ActionCreator, ActionReducer, ActionType, Action } from './models';
import { compose } from './utils';

// Return type of the `on` fn.
export interface On<S> {
Expand Down Expand Up @@ -229,14 +230,16 @@ export function createReducer<S, A extends Action = Action>(
initialState: S,
...ons: On<S>[]
): ActionReducer<S, A> {
const map = new Map<string, ActionReducer<S, A>[]>();
const map = new Map<string, ActionReducer<S, A>>();
for (let on of ons) {
for (let type of on.types) {
if (map.has(type)) {
const existingReducers = map.get(type) as ActionReducer<S, A>[];
map.set(type, [...existingReducers, on.reducer]);
const existingReducer = map.get(type) as ActionReducer<S, A>;
const newReducer: ActionReducer<S, A> = (state, action) =>
on.reducer(existingReducer(state, action), action);
map.set(type, newReducer);
} else {
map.set(type, [on.reducer]);
map.set(type, on.reducer);
}
}
}
Expand Down

0 comments on commit 685cb32

Please sign in to comment.