@ngrx/store-devtools 6.1.2 → 7.0.0-beta.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (57) hide show
  1. package/bundles/store-devtools.umd.js +511 -309
  2. package/bundles/store-devtools.umd.js.map +1 -1
  3. package/bundles/store-devtools.umd.min.js +2 -2
  4. package/bundles/store-devtools.umd.min.js.map +1 -1
  5. package/esm2015/index.js +3 -3
  6. package/esm2015/public_api.js +3 -3
  7. package/esm2015/src/actions.js +72 -24
  8. package/esm2015/src/config.js +89 -5
  9. package/esm2015/src/devtools-dispatcher.js +13 -0
  10. package/esm2015/src/devtools.js +56 -45
  11. package/esm2015/src/extension.js +95 -77
  12. package/esm2015/src/index.js +3 -2
  13. package/esm2015/src/instrument.js +9 -48
  14. package/esm2015/src/reducer.js +190 -107
  15. package/esm2015/src/utils.js +56 -3
  16. package/esm2015/store-devtools.js +5 -5
  17. package/esm5/index.js +1 -1
  18. package/esm5/src/actions.js +19 -1
  19. package/esm5/src/config.js +40 -1
  20. package/esm5/src/devtools-dispatcher.js +34 -0
  21. package/esm5/src/devtools.js +39 -38
  22. package/esm5/src/extension.js +68 -31
  23. package/esm5/src/index.js +2 -1
  24. package/esm5/src/instrument.js +16 -33
  25. package/esm5/src/reducer.js +259 -196
  26. package/esm5/src/utils.js +50 -14
  27. package/esm5/store-devtools.js +5 -5
  28. package/fesm2015/store-devtools.js +443 -181
  29. package/fesm2015/store-devtools.js.map +1 -1
  30. package/fesm5/store-devtools.js +504 -303
  31. package/fesm5/store-devtools.js.map +1 -1
  32. package/migrations/6_0_0/index.js +1 -1
  33. package/package.json +3 -3
  34. package/schematics/ng-add/index.js +4 -4
  35. package/schematics-core/index.d.ts +4 -4
  36. package/schematics-core/utility/ast-utils.js +12 -10
  37. package/schematics-core/utility/change.js +1 -1
  38. package/schematics-core/utility/config.js +1 -1
  39. package/schematics-core/utility/find-module.js +1 -1
  40. package/schematics-core/utility/ngrx-utils.js +6 -6
  41. package/schematics-core/utility/package.js +1 -1
  42. package/schematics-core/utility/parse-name.js +1 -1
  43. package/schematics-core/utility/project.js +1 -1
  44. package/schematics-core/utility/route-utils.js +1 -1
  45. package/schematics-core/utility/strings.js +1 -1
  46. package/schematics-core/utility/update.js +1 -1
  47. package/src/actions.d.ts +24 -12
  48. package/src/config.d.ts +7 -0
  49. package/src/devtools-dispatcher.d.ts +3 -0
  50. package/src/devtools.d.ts +3 -2
  51. package/src/extension.d.ts +8 -8
  52. package/src/index.d.ts +1 -1
  53. package/src/instrument.d.ts +1 -4
  54. package/src/reducer.d.ts +8 -2
  55. package/src/utils.d.ts +13 -1
  56. package/store-devtools.d.ts +4 -4
  57. package/store-devtools.metadata.json +1 -1
@@ -1,10 +1,13 @@
1
- var __assign = (this && this.__assign) || Object.assign || function(t) {
2
- for (var s, i = 1, n = arguments.length; i < n; i++) {
3
- s = arguments[i];
4
- for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
5
- t[p] = s[p];
6
- }
7
- return t;
1
+ var __assign = (this && this.__assign) || function () {
2
+ __assign = Object.assign || function(t) {
3
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
4
+ s = arguments[i];
5
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
6
+ t[p] = s[p];
7
+ }
8
+ return t;
9
+ };
10
+ return __assign.apply(this, arguments);
8
11
  };
9
12
  var __read = (this && this.__read) || function (o, n) {
10
13
  var m = typeof Symbol === "function" && o[Symbol.iterator];
@@ -28,9 +31,11 @@ var __spread = (this && this.__spread) || function () {
28
31
  };
29
32
  import { UPDATE, INIT, } from '@ngrx/store';
30
33
  import { difference, liftAction } from './utils';
31
- import * as Actions from './actions';
34
+ import * as DevtoolsActions from './actions';
32
35
  import { PerformAction } from './actions';
33
36
  export var INIT_ACTION = { type: INIT };
37
+ export var RECOMPUTE = '@ngrx/store-devtools/recompute';
38
+ export var RECOMPUTE_ACTION = { type: RECOMPUTE };
34
39
  /**
35
40
  * Computes the next entry in the log by applying an action.
36
41
  */
@@ -58,7 +63,7 @@ function computeNextEntry(reducer, action, state, error, errorHandler) {
58
63
  /**
59
64
  * Runs the reducer on invalidated actions to get a fresh computation log.
60
65
  */
61
- function recomputeStates(computedStates, minInvalidatedStateIndex, reducer, committedState, actionsById, stagedActionIds, skippedActionIds, errorHandler) {
66
+ function recomputeStates(computedStates, minInvalidatedStateIndex, reducer, committedState, actionsById, stagedActionIds, skippedActionIds, errorHandler, isPaused) {
62
67
  // Optimization: exit early and return the same reference
63
68
  // if we know nothing could have changed.
64
69
  if (minInvalidatedStateIndex >= computedStates.length &&
@@ -66,7 +71,10 @@ function recomputeStates(computedStates, minInvalidatedStateIndex, reducer, comm
66
71
  return computedStates;
67
72
  }
68
73
  var nextComputedStates = computedStates.slice(0, minInvalidatedStateIndex);
69
- for (var i = minInvalidatedStateIndex; i < stagedActionIds.length; i++) {
74
+ // If the recording is paused, recompute all states up until the pause state,
75
+ // else recompute all states.
76
+ var lastIncludedActionId = stagedActionIds.length - (isPaused ? 1 : 0);
77
+ for (var i = minInvalidatedStateIndex; i < lastIncludedActionId; i++) {
70
78
  var actionId = stagedActionIds[i];
71
79
  var action = actionsById[actionId].action;
72
80
  var previousEntry = nextComputedStates[i - 1];
@@ -78,6 +86,11 @@ function recomputeStates(computedStates, minInvalidatedStateIndex, reducer, comm
78
86
  : computeNextEntry(reducer, action, previousState, previousError, errorHandler);
79
87
  nextComputedStates.push(entry);
80
88
  }
89
+ // If the recording is paused, the last state will not be recomputed,
90
+ // because it's essentially not part of the state history.
91
+ if (isPaused) {
92
+ nextComputedStates.push(computedStates[computedStates.length - 1]);
93
+ }
81
94
  return nextComputedStates;
82
95
  }
83
96
  export function liftInitialState(initialCommittedState, monitorReducer) {
@@ -90,6 +103,8 @@ export function liftInitialState(initialCommittedState, monitorReducer) {
90
103
  committedState: initialCommittedState,
91
104
  currentStateIndex: 0,
92
105
  computedStates: [],
106
+ isLocked: false,
107
+ isPaused: false,
93
108
  };
94
109
  }
95
110
  /**
@@ -98,182 +113,232 @@ export function liftInitialState(initialCommittedState, monitorReducer) {
98
113
  export function liftReducerWith(initialCommittedState, initialLiftedState, errorHandler, monitorReducer, options) {
99
114
  if (options === void 0) { options = {}; }
100
115
  /**
101
- * Manages how the history actions modify the history state.
102
- */
103
- return function (reducer) {
104
- return function (liftedState, liftedAction) {
105
- var _a = liftedState || initialLiftedState, monitorState = _a.monitorState, actionsById = _a.actionsById, nextActionId = _a.nextActionId, stagedActionIds = _a.stagedActionIds, skippedActionIds = _a.skippedActionIds, committedState = _a.committedState, currentStateIndex = _a.currentStateIndex, computedStates = _a.computedStates;
106
- if (!liftedState) {
107
- // Prevent mutating initialLiftedState
108
- actionsById = Object.create(actionsById);
116
+ * Manages how the history actions modify the history state.
117
+ */
118
+ return function (reducer) { return function (liftedState, liftedAction) {
119
+ var _a;
120
+ var _b = liftedState || initialLiftedState, monitorState = _b.monitorState, actionsById = _b.actionsById, nextActionId = _b.nextActionId, stagedActionIds = _b.stagedActionIds, skippedActionIds = _b.skippedActionIds, committedState = _b.committedState, currentStateIndex = _b.currentStateIndex, computedStates = _b.computedStates, isLocked = _b.isLocked, isPaused = _b.isPaused;
121
+ if (!liftedState) {
122
+ // Prevent mutating initialLiftedState
123
+ actionsById = Object.create(actionsById);
124
+ }
125
+ function commitExcessActions(n) {
126
+ // Auto-commits n-number of excess actions.
127
+ var excess = n;
128
+ var idsToDelete = stagedActionIds.slice(1, excess + 1);
129
+ for (var i = 0; i < idsToDelete.length; i++) {
130
+ if (computedStates[i + 1].error) {
131
+ // Stop if error is found. Commit actions up to error.
132
+ excess = i;
133
+ idsToDelete = stagedActionIds.slice(1, excess + 1);
134
+ break;
135
+ }
136
+ else {
137
+ delete actionsById[idsToDelete[i]];
138
+ }
109
139
  }
110
- function commitExcessActions(n) {
111
- // Auto-commits n-number of excess actions.
112
- var excess = n;
113
- var idsToDelete = stagedActionIds.slice(1, excess + 1);
114
- for (var i = 0; i < idsToDelete.length; i++) {
115
- if (computedStates[i + 1].error) {
116
- // Stop if error is found. Commit actions up to error.
117
- excess = i;
118
- idsToDelete = stagedActionIds.slice(1, excess + 1);
119
- break;
120
- }
121
- else {
122
- delete actionsById[idsToDelete[i]];
140
+ skippedActionIds = skippedActionIds.filter(function (id) { return idsToDelete.indexOf(id) === -1; });
141
+ stagedActionIds = __spread([0], stagedActionIds.slice(excess + 1));
142
+ committedState = computedStates[excess].state;
143
+ computedStates = computedStates.slice(excess);
144
+ currentStateIndex =
145
+ currentStateIndex > excess ? currentStateIndex - excess : 0;
146
+ }
147
+ function commitChanges() {
148
+ // Consider the last committed state the new starting point.
149
+ // Squash any staged actions into a single committed state.
150
+ actionsById = { 0: liftAction(INIT_ACTION) };
151
+ nextActionId = 1;
152
+ stagedActionIds = [0];
153
+ skippedActionIds = [];
154
+ committedState = computedStates[currentStateIndex].state;
155
+ currentStateIndex = 0;
156
+ computedStates = [];
157
+ }
158
+ // By default, aggressively recompute every state whatever happens.
159
+ // This has O(n) performance, so we'll override this to a sensible
160
+ // value whenever we feel like we don't have to recompute the states.
161
+ var minInvalidatedStateIndex = 0;
162
+ switch (liftedAction.type) {
163
+ case DevtoolsActions.LOCK_CHANGES: {
164
+ isLocked = liftedAction.status;
165
+ minInvalidatedStateIndex = Infinity;
166
+ break;
167
+ }
168
+ case DevtoolsActions.PAUSE_RECORDING: {
169
+ isPaused = liftedAction.status;
170
+ if (isPaused) {
171
+ // Add a pause action to signal the devtools-user the recording is paused.
172
+ // The corresponding state will be overwritten on each update to always contain
173
+ // the latest state (see Actions.PERFORM_ACTION).
174
+ stagedActionIds = __spread(stagedActionIds, [nextActionId]);
175
+ actionsById[nextActionId] = new PerformAction({
176
+ type: '@ngrx/devtools/pause',
177
+ }, +Date.now());
178
+ nextActionId++;
179
+ minInvalidatedStateIndex = stagedActionIds.length - 1;
180
+ computedStates = computedStates.concat(computedStates[computedStates.length - 1]);
181
+ if (currentStateIndex === stagedActionIds.length - 2) {
182
+ currentStateIndex++;
123
183
  }
184
+ minInvalidatedStateIndex = Infinity;
124
185
  }
125
- skippedActionIds = skippedActionIds.filter(function (id) { return idsToDelete.indexOf(id) === -1; });
126
- stagedActionIds = __spread([0], stagedActionIds.slice(excess + 1));
127
- committedState = computedStates[excess].state;
128
- computedStates = computedStates.slice(excess);
129
- currentStateIndex =
130
- currentStateIndex > excess ? currentStateIndex - excess : 0;
131
- }
132
- // By default, aggressively recompute every state whatever happens.
133
- // This has O(n) performance, so we'll override this to a sensible
134
- // value whenever we feel like we don't have to recompute the states.
135
- var minInvalidatedStateIndex = 0;
136
- switch (liftedAction.type) {
137
- case Actions.RESET: {
138
- // Get back to the state the store was created with.
139
- actionsById = { 0: liftAction(INIT_ACTION) };
140
- nextActionId = 1;
141
- stagedActionIds = [0];
142
- skippedActionIds = [];
143
- committedState = initialCommittedState;
144
- currentStateIndex = 0;
145
- computedStates = [];
146
- break;
186
+ else {
187
+ commitChanges();
147
188
  }
148
- case Actions.COMMIT: {
149
- // Consider the last committed state the new starting point.
150
- // Squash any staged actions into a single committed state.
151
- actionsById = { 0: liftAction(INIT_ACTION) };
152
- nextActionId = 1;
153
- stagedActionIds = [0];
154
- skippedActionIds = [];
155
- committedState = computedStates[currentStateIndex].state;
156
- currentStateIndex = 0;
157
- computedStates = [];
158
- break;
189
+ break;
190
+ }
191
+ case DevtoolsActions.RESET: {
192
+ // Get back to the state the store was created with.
193
+ actionsById = { 0: liftAction(INIT_ACTION) };
194
+ nextActionId = 1;
195
+ stagedActionIds = [0];
196
+ skippedActionIds = [];
197
+ committedState = initialCommittedState;
198
+ currentStateIndex = 0;
199
+ computedStates = [];
200
+ break;
201
+ }
202
+ case DevtoolsActions.COMMIT: {
203
+ commitChanges();
204
+ break;
205
+ }
206
+ case DevtoolsActions.ROLLBACK: {
207
+ // Forget about any staged actions.
208
+ // Start again from the last committed state.
209
+ actionsById = { 0: liftAction(INIT_ACTION) };
210
+ nextActionId = 1;
211
+ stagedActionIds = [0];
212
+ skippedActionIds = [];
213
+ currentStateIndex = 0;
214
+ computedStates = [];
215
+ break;
216
+ }
217
+ case DevtoolsActions.TOGGLE_ACTION: {
218
+ // Toggle whether an action with given ID is skipped.
219
+ // Being skipped means it is a no-op during the computation.
220
+ var actionId_1 = liftedAction.id;
221
+ var index = skippedActionIds.indexOf(actionId_1);
222
+ if (index === -1) {
223
+ skippedActionIds = __spread([actionId_1], skippedActionIds);
159
224
  }
160
- case Actions.ROLLBACK: {
161
- // Forget about any staged actions.
162
- // Start again from the last committed state.
163
- actionsById = { 0: liftAction(INIT_ACTION) };
164
- nextActionId = 1;
165
- stagedActionIds = [0];
166
- skippedActionIds = [];
167
- currentStateIndex = 0;
168
- computedStates = [];
169
- break;
225
+ else {
226
+ skippedActionIds = skippedActionIds.filter(function (id) { return id !== actionId_1; });
170
227
  }
171
- case Actions.TOGGLE_ACTION: {
172
- // Toggle whether an action with given ID is skipped.
173
- // Being skipped means it is a no-op during the computation.
174
- var actionId_1 = liftedAction.id;
175
- var index = skippedActionIds.indexOf(actionId_1);
176
- if (index === -1) {
177
- skippedActionIds = __spread([actionId_1], skippedActionIds);
178
- }
179
- else {
180
- skippedActionIds = skippedActionIds.filter(function (id) { return id !== actionId_1; });
181
- }
182
- // Optimization: we know history before this action hasn't changed
183
- minInvalidatedStateIndex = stagedActionIds.indexOf(actionId_1);
184
- break;
228
+ // Optimization: we know history before this action hasn't changed
229
+ minInvalidatedStateIndex = stagedActionIds.indexOf(actionId_1);
230
+ break;
231
+ }
232
+ case DevtoolsActions.SET_ACTIONS_ACTIVE: {
233
+ // Toggle whether an action with given ID is skipped.
234
+ // Being skipped means it is a no-op during the computation.
235
+ var start = liftedAction.start, end = liftedAction.end, active = liftedAction.active;
236
+ var actionIds = [];
237
+ for (var i = start; i < end; i++)
238
+ actionIds.push(i);
239
+ if (active) {
240
+ skippedActionIds = difference(skippedActionIds, actionIds);
185
241
  }
186
- case Actions.SET_ACTIONS_ACTIVE: {
187
- // Toggle whether an action with given ID is skipped.
188
- // Being skipped means it is a no-op during the computation.
189
- var start = liftedAction.start, end = liftedAction.end, active = liftedAction.active;
190
- var actionIds = [];
191
- for (var i = start; i < end; i++)
192
- actionIds.push(i);
193
- if (active) {
194
- skippedActionIds = difference(skippedActionIds, actionIds);
195
- }
196
- else {
197
- skippedActionIds = __spread(skippedActionIds, actionIds);
198
- }
199
- // Optimization: we know history before this action hasn't changed
200
- minInvalidatedStateIndex = stagedActionIds.indexOf(start);
201
- break;
242
+ else {
243
+ skippedActionIds = __spread(skippedActionIds, actionIds);
202
244
  }
203
- case Actions.JUMP_TO_STATE: {
204
- // Without recomputing anything, move the pointer that tell us
205
- // which state is considered the current one. Useful for sliders.
206
- currentStateIndex = liftedAction.index;
207
- // Optimization: we know the history has not changed.
208
- minInvalidatedStateIndex = Infinity;
209
- break;
245
+ // Optimization: we know history before this action hasn't changed
246
+ minInvalidatedStateIndex = stagedActionIds.indexOf(start);
247
+ break;
248
+ }
249
+ case DevtoolsActions.JUMP_TO_STATE: {
250
+ // Without recomputing anything, move the pointer that tell us
251
+ // which state is considered the current one. Useful for sliders.
252
+ currentStateIndex = liftedAction.index;
253
+ // Optimization: we know the history has not changed.
254
+ minInvalidatedStateIndex = Infinity;
255
+ break;
256
+ }
257
+ case DevtoolsActions.JUMP_TO_ACTION: {
258
+ // Jumps to a corresponding state to a specific action.
259
+ // Useful when filtering actions.
260
+ var index = stagedActionIds.indexOf(liftedAction.actionId);
261
+ if (index !== -1)
262
+ currentStateIndex = index;
263
+ minInvalidatedStateIndex = Infinity;
264
+ break;
265
+ }
266
+ case DevtoolsActions.SWEEP: {
267
+ // Forget any actions that are currently being skipped.
268
+ stagedActionIds = difference(stagedActionIds, skippedActionIds);
269
+ skippedActionIds = [];
270
+ currentStateIndex = Math.min(currentStateIndex, stagedActionIds.length - 1);
271
+ break;
272
+ }
273
+ case DevtoolsActions.PERFORM_ACTION: {
274
+ // Ignore action and return state as is if recording is locked
275
+ if (isLocked) {
276
+ return liftedState || initialLiftedState;
210
277
  }
211
- case Actions.JUMP_TO_ACTION: {
212
- // Jumps to a corresponding state to a specific action.
213
- // Useful when filtering actions.
214
- var index = stagedActionIds.indexOf(liftedAction.actionId);
215
- if (index !== -1)
216
- currentStateIndex = index;
278
+ if (isPaused) {
279
+ // If recording is paused, overwrite the last state
280
+ // (corresponds to the pause action) and keep everything else as is.
281
+ // This way, the app gets the new current state while the devtools
282
+ // do not record another action.
283
+ var lastState = computedStates[computedStates.length - 1];
284
+ computedStates = __spread(computedStates.slice(0, -1), [
285
+ computeNextEntry(reducer, liftedAction.action, lastState.state, lastState.error, errorHandler),
286
+ ]);
217
287
  minInvalidatedStateIndex = Infinity;
218
288
  break;
219
289
  }
220
- case Actions.SWEEP: {
221
- // Forget any actions that are currently being skipped.
222
- stagedActionIds = difference(stagedActionIds, skippedActionIds);
223
- skippedActionIds = [];
224
- currentStateIndex = Math.min(currentStateIndex, stagedActionIds.length - 1);
225
- break;
290
+ // Auto-commit as new actions come in.
291
+ if (options.maxAge && stagedActionIds.length === options.maxAge) {
292
+ commitExcessActions(1);
226
293
  }
227
- case Actions.PERFORM_ACTION: {
228
- // Auto-commit as new actions come in.
229
- if (options.maxAge && stagedActionIds.length === options.maxAge) {
230
- commitExcessActions(1);
231
- }
232
- if (currentStateIndex === stagedActionIds.length - 1) {
233
- currentStateIndex++;
234
- }
235
- var actionId = nextActionId++;
236
- // Mutation! This is the hottest path, and we optimize on purpose.
237
- // It is safe because we set a new key in a cache dictionary.
238
- actionsById[actionId] = liftedAction;
239
- stagedActionIds = __spread(stagedActionIds, [actionId]);
240
- // Optimization: we know that only the new action needs computing.
241
- minInvalidatedStateIndex = stagedActionIds.length - 1;
242
- break;
294
+ if (currentStateIndex === stagedActionIds.length - 1) {
295
+ currentStateIndex++;
243
296
  }
244
- case Actions.IMPORT_STATE: {
245
- // Completely replace everything.
246
- (_b = liftedAction.nextLiftedState, monitorState = _b.monitorState, actionsById = _b.actionsById, nextActionId = _b.nextActionId, stagedActionIds = _b.stagedActionIds, skippedActionIds = _b.skippedActionIds, committedState = _b.committedState, currentStateIndex = _b.currentStateIndex,
247
- // prettier-ignore
248
- computedStates = _b.computedStates);
249
- break;
297
+ var actionId = nextActionId++;
298
+ // Mutation! This is the hottest path, and we optimize on purpose.
299
+ // It is safe because we set a new key in a cache dictionary.
300
+ actionsById[actionId] = liftedAction;
301
+ stagedActionIds = __spread(stagedActionIds, [actionId]);
302
+ // Optimization: we know that only the new action needs computing.
303
+ minInvalidatedStateIndex = stagedActionIds.length - 1;
304
+ break;
305
+ }
306
+ case DevtoolsActions.IMPORT_STATE: {
307
+ // Completely replace everything.
308
+ (_a = liftedAction.nextLiftedState, monitorState = _a.monitorState, actionsById = _a.actionsById, nextActionId = _a.nextActionId, stagedActionIds = _a.stagedActionIds, skippedActionIds = _a.skippedActionIds, committedState = _a.committedState, currentStateIndex = _a.currentStateIndex, computedStates = _a.computedStates, isLocked = _a.isLocked,
309
+ // prettier-ignore
310
+ isPaused = _a.isPaused);
311
+ break;
312
+ }
313
+ case INIT: {
314
+ // Always recompute states on hot reload and init.
315
+ minInvalidatedStateIndex = 0;
316
+ if (options.maxAge && stagedActionIds.length > options.maxAge) {
317
+ // States must be recomputed before committing excess.
318
+ computedStates = recomputeStates(computedStates, minInvalidatedStateIndex, reducer, committedState, actionsById, stagedActionIds, skippedActionIds, errorHandler, isPaused);
319
+ commitExcessActions(stagedActionIds.length - options.maxAge);
320
+ // Avoid double computation.
321
+ minInvalidatedStateIndex = Infinity;
250
322
  }
251
- case INIT: {
252
- // Always recompute states on hot reload and init.
323
+ break;
324
+ }
325
+ case UPDATE: {
326
+ var stateHasErrors = computedStates.filter(function (state) { return state.error; }).length > 0;
327
+ if (stateHasErrors) {
328
+ // Recompute all states
253
329
  minInvalidatedStateIndex = 0;
254
330
  if (options.maxAge && stagedActionIds.length > options.maxAge) {
255
331
  // States must be recomputed before committing excess.
256
- computedStates = recomputeStates(computedStates, minInvalidatedStateIndex, reducer, committedState, actionsById, stagedActionIds, skippedActionIds, errorHandler);
332
+ computedStates = recomputeStates(computedStates, minInvalidatedStateIndex, reducer, committedState, actionsById, stagedActionIds, skippedActionIds, errorHandler, isPaused);
257
333
  commitExcessActions(stagedActionIds.length - options.maxAge);
258
334
  // Avoid double computation.
259
335
  minInvalidatedStateIndex = Infinity;
260
336
  }
261
- break;
262
337
  }
263
- case UPDATE: {
264
- var stateHasErrors = computedStates.filter(function (state) { return state.error; }).length > 0;
265
- if (stateHasErrors) {
266
- // Recompute all states
267
- minInvalidatedStateIndex = 0;
268
- if (options.maxAge && stagedActionIds.length > options.maxAge) {
269
- // States must be recomputed before committing excess.
270
- computedStates = recomputeStates(computedStates, minInvalidatedStateIndex, reducer, committedState, actionsById, stagedActionIds, skippedActionIds, errorHandler);
271
- commitExcessActions(stagedActionIds.length - options.maxAge);
272
- // Avoid double computation.
273
- minInvalidatedStateIndex = Infinity;
274
- }
275
- }
276
- else {
338
+ else {
339
+ // If not paused/locked, add a new action to signal devtools-user
340
+ // that there was a reducer update.
341
+ if (!isPaused && !isLocked) {
277
342
  if (currentStateIndex === stagedActionIds.length - 1) {
278
343
  currentStateIndex++;
279
344
  }
@@ -282,43 +347,41 @@ export function liftReducerWith(initialCommittedState, initialLiftedState, error
282
347
  actionsById[actionId] = new PerformAction(liftedAction, +Date.now());
283
348
  stagedActionIds = __spread(stagedActionIds, [actionId]);
284
349
  minInvalidatedStateIndex = stagedActionIds.length - 1;
285
- // States must be recomputed before committing excess.
286
- computedStates = recomputeStates(computedStates, minInvalidatedStateIndex, reducer, committedState, actionsById, stagedActionIds, skippedActionIds, errorHandler);
287
- // Recompute state history with latest reducer and update action
288
- computedStates = computedStates.map(function (cmp) {
289
- return (__assign({}, cmp, { state: reducer(cmp.state, liftedAction) }));
290
- });
291
- currentStateIndex = minInvalidatedStateIndex;
292
- if (options.maxAge && stagedActionIds.length > options.maxAge) {
293
- commitExcessActions(stagedActionIds.length - options.maxAge);
294
- }
295
- // Avoid double computation.
296
- minInvalidatedStateIndex = Infinity;
350
+ computedStates = recomputeStates(computedStates, minInvalidatedStateIndex, reducer, committedState, actionsById, stagedActionIds, skippedActionIds, errorHandler, isPaused);
297
351
  }
298
- break;
299
- }
300
- default: {
301
- // If the action is not recognized, it's a monitor action.
302
- // Optimization: a monitor action can't change history.
352
+ // Recompute state history with latest reducer and update action
353
+ computedStates = computedStates.map(function (cmp) { return (__assign({}, cmp, { state: reducer(cmp.state, RECOMPUTE_ACTION) })); });
354
+ currentStateIndex = stagedActionIds.length - 1;
355
+ if (options.maxAge && stagedActionIds.length > options.maxAge) {
356
+ commitExcessActions(stagedActionIds.length - options.maxAge);
357
+ }
358
+ // Avoid double computation.
303
359
  minInvalidatedStateIndex = Infinity;
304
- break;
305
360
  }
361
+ break;
306
362
  }
307
- computedStates = recomputeStates(computedStates, minInvalidatedStateIndex, reducer, committedState, actionsById, stagedActionIds, skippedActionIds, errorHandler);
308
- monitorState = monitorReducer(monitorState, liftedAction);
309
- return {
310
- monitorState: monitorState,
311
- actionsById: actionsById,
312
- nextActionId: nextActionId,
313
- stagedActionIds: stagedActionIds,
314
- skippedActionIds: skippedActionIds,
315
- committedState: committedState,
316
- currentStateIndex: currentStateIndex,
317
- computedStates: computedStates,
318
- };
319
- var _b;
363
+ default: {
364
+ // If the action is not recognized, it's a monitor action.
365
+ // Optimization: a monitor action can't change history.
366
+ minInvalidatedStateIndex = Infinity;
367
+ break;
368
+ }
369
+ }
370
+ computedStates = recomputeStates(computedStates, minInvalidatedStateIndex, reducer, committedState, actionsById, stagedActionIds, skippedActionIds, errorHandler, isPaused);
371
+ monitorState = monitorReducer(monitorState, liftedAction);
372
+ return {
373
+ monitorState: monitorState,
374
+ actionsById: actionsById,
375
+ nextActionId: nextActionId,
376
+ stagedActionIds: stagedActionIds,
377
+ skippedActionIds: skippedActionIds,
378
+ committedState: committedState,
379
+ currentStateIndex: currentStateIndex,
380
+ computedStates: computedStates,
381
+ isLocked: isLocked,
382
+ isPaused: isPaused,
320
383
  };
321
- };
384
+ }; };
322
385
  }
323
386
 
324
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"reducer.js","sourceRoot":"","sources":["../../../../../../../../../modules/store-devtools/src/reducer.ts"],"names":[],"mappings":"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","sourcesContent":["import { ErrorHandler } from '@angular/core';\nimport {\n  Action,\n  ActionReducer,\n  ActionsSubject,\n  ReducerManager,\n  UPDATE,\n  INIT,\n} from '@ngrx/store';\nimport { difference, liftAction } from './utils';\nimport * as Actions from './actions';\nimport { StoreDevtoolsConfig, StateSanitizer } from './config';\nimport { PerformAction } from './actions';\n\nexport type InitAction = {\n  readonly type: typeof INIT;\n};\n\nexport type UpdateReducerAction = {\n  readonly type: typeof UPDATE;\n};\n\nexport type CoreActions = InitAction | UpdateReducerAction;\nexport type Actions = Actions.All | CoreActions;\n\nexport const INIT_ACTION = { type: INIT };\n\nexport interface ComputedState {\n  state: any;\n  error: any;\n}\n\nexport interface LiftedAction {\n  type: string;\n  action: Action;\n}\n\nexport interface LiftedActions {\n  [id: number]: LiftedAction;\n}\n\nexport interface LiftedState {\n  monitorState: any;\n  nextActionId: number;\n  actionsById: LiftedActions;\n  stagedActionIds: number[];\n  skippedActionIds: number[];\n  committedState: any;\n  currentStateIndex: number;\n  computedStates: ComputedState[];\n}\n\n/**\n * Computes the next entry in the log by applying an action.\n */\nfunction computeNextEntry(\n  reducer: ActionReducer<any, any>,\n  action: Action,\n  state: any,\n  error: any,\n  errorHandler: ErrorHandler\n) {\n  if (error) {\n    return {\n      state,\n      error: 'Interrupted by an error up the chain',\n    };\n  }\n\n  let nextState = state;\n  let nextError;\n  try {\n    nextState = reducer(state, action);\n  } catch (err) {\n    nextError = err.toString();\n    errorHandler.handleError(err.stack || err);\n  }\n\n  return {\n    state: nextState,\n    error: nextError,\n  };\n}\n\n/**\n * Runs the reducer on invalidated actions to get a fresh computation log.\n */\nfunction recomputeStates(\n  computedStates: ComputedState[],\n  minInvalidatedStateIndex: number,\n  reducer: ActionReducer<any, any>,\n  committedState: any,\n  actionsById: LiftedActions,\n  stagedActionIds: number[],\n  skippedActionIds: number[],\n  errorHandler: ErrorHandler\n) {\n  // Optimization: exit early and return the same reference\n  // if we know nothing could have changed.\n  if (\n    minInvalidatedStateIndex >= computedStates.length &&\n    computedStates.length === stagedActionIds.length\n  ) {\n    return computedStates;\n  }\n\n  const nextComputedStates = computedStates.slice(0, minInvalidatedStateIndex);\n  for (let i = minInvalidatedStateIndex; i < stagedActionIds.length; i++) {\n    const actionId = stagedActionIds[i];\n    const action = actionsById[actionId].action;\n\n    const previousEntry = nextComputedStates[i - 1];\n    const previousState = previousEntry ? previousEntry.state : committedState;\n    const previousError = previousEntry ? previousEntry.error : undefined;\n\n    const shouldSkip = skippedActionIds.indexOf(actionId) > -1;\n    const entry: ComputedState = shouldSkip\n      ? previousEntry\n      : computeNextEntry(\n          reducer,\n          action,\n          previousState,\n          previousError,\n          errorHandler\n        );\n\n    nextComputedStates.push(entry);\n  }\n\n  return nextComputedStates;\n}\n\nexport function liftInitialState(\n  initialCommittedState?: any,\n  monitorReducer?: any\n): LiftedState {\n  return {\n    monitorState: monitorReducer(undefined, {}),\n    nextActionId: 1,\n    actionsById: { 0: liftAction(INIT_ACTION) },\n    stagedActionIds: [0],\n    skippedActionIds: [],\n    committedState: initialCommittedState,\n    currentStateIndex: 0,\n    computedStates: [],\n  };\n}\n\n/**\n * Creates a history state reducer from an app's reducer.\n */\nexport function liftReducerWith(\n  initialCommittedState: any,\n  initialLiftedState: LiftedState,\n  errorHandler: ErrorHandler,\n  monitorReducer?: any,\n  options: Partial<StoreDevtoolsConfig> = {}\n) {\n  /**\n   * Manages how the history actions modify the history state.\n   */\n  return (\n    reducer: ActionReducer<any, any>\n  ): ActionReducer<LiftedState, Actions> => (liftedState, liftedAction) => {\n    let {\n      monitorState,\n      actionsById,\n      nextActionId,\n      stagedActionIds,\n      skippedActionIds,\n      committedState,\n      currentStateIndex,\n      computedStates,\n    } =\n      liftedState || initialLiftedState;\n\n    if (!liftedState) {\n      // Prevent mutating initialLiftedState\n      actionsById = Object.create(actionsById);\n    }\n\n    function commitExcessActions(n: number) {\n      // Auto-commits n-number of excess actions.\n      let excess = n;\n      let idsToDelete = stagedActionIds.slice(1, excess + 1);\n\n      for (let i = 0; i < idsToDelete.length; i++) {\n        if (computedStates[i + 1].error) {\n          // Stop if error is found. Commit actions up to error.\n          excess = i;\n          idsToDelete = stagedActionIds.slice(1, excess + 1);\n          break;\n        } else {\n          delete actionsById[idsToDelete[i]];\n        }\n      }\n\n      skippedActionIds = skippedActionIds.filter(\n        id => idsToDelete.indexOf(id) === -1\n      );\n      stagedActionIds = [0, ...stagedActionIds.slice(excess + 1)];\n      committedState = computedStates[excess].state;\n      computedStates = computedStates.slice(excess);\n      currentStateIndex =\n        currentStateIndex > excess ? currentStateIndex - excess : 0;\n    }\n\n    // By default, aggressively recompute every state whatever happens.\n    // This has O(n) performance, so we'll override this to a sensible\n    // value whenever we feel like we don't have to recompute the states.\n    let minInvalidatedStateIndex = 0;\n\n    switch (liftedAction.type) {\n      case Actions.RESET: {\n        // Get back to the state the store was created with.\n        actionsById = { 0: liftAction(INIT_ACTION) };\n        nextActionId = 1;\n        stagedActionIds = [0];\n        skippedActionIds = [];\n        committedState = initialCommittedState;\n        currentStateIndex = 0;\n        computedStates = [];\n        break;\n      }\n      case Actions.COMMIT: {\n        // Consider the last committed state the new starting point.\n        // Squash any staged actions into a single committed state.\n        actionsById = { 0: liftAction(INIT_ACTION) };\n        nextActionId = 1;\n        stagedActionIds = [0];\n        skippedActionIds = [];\n        committedState = computedStates[currentStateIndex].state;\n        currentStateIndex = 0;\n        computedStates = [];\n        break;\n      }\n      case Actions.ROLLBACK: {\n        // Forget about any staged actions.\n        // Start again from the last committed state.\n        actionsById = { 0: liftAction(INIT_ACTION) };\n        nextActionId = 1;\n        stagedActionIds = [0];\n        skippedActionIds = [];\n        currentStateIndex = 0;\n        computedStates = [];\n        break;\n      }\n      case Actions.TOGGLE_ACTION: {\n        // Toggle whether an action with given ID is skipped.\n        // Being skipped means it is a no-op during the computation.\n        const { id: actionId } = liftedAction;\n        const index = skippedActionIds.indexOf(actionId);\n        if (index === -1) {\n          skippedActionIds = [actionId, ...skippedActionIds];\n        } else {\n          skippedActionIds = skippedActionIds.filter(id => id !== actionId);\n        }\n        // Optimization: we know history before this action hasn't changed\n        minInvalidatedStateIndex = stagedActionIds.indexOf(actionId);\n        break;\n      }\n      case Actions.SET_ACTIONS_ACTIVE: {\n        // Toggle whether an action with given ID is skipped.\n        // Being skipped means it is a no-op during the computation.\n        const { start, end, active } = liftedAction;\n        const actionIds = [];\n        for (let i = start; i < end; i++) actionIds.push(i);\n        if (active) {\n          skippedActionIds = difference(skippedActionIds, actionIds);\n        } else {\n          skippedActionIds = [...skippedActionIds, ...actionIds];\n        }\n\n        // Optimization: we know history before this action hasn't changed\n        minInvalidatedStateIndex = stagedActionIds.indexOf(start);\n        break;\n      }\n      case Actions.JUMP_TO_STATE: {\n        // Without recomputing anything, move the pointer that tell us\n        // which state is considered the current one. Useful for sliders.\n        currentStateIndex = liftedAction.index;\n        // Optimization: we know the history has not changed.\n        minInvalidatedStateIndex = Infinity;\n        break;\n      }\n      case Actions.JUMP_TO_ACTION: {\n        // Jumps to a corresponding state to a specific action.\n        // Useful when filtering actions.\n        const index = stagedActionIds.indexOf(liftedAction.actionId);\n        if (index !== -1) currentStateIndex = index;\n        minInvalidatedStateIndex = Infinity;\n        break;\n      }\n      case Actions.SWEEP: {\n        // Forget any actions that are currently being skipped.\n        stagedActionIds = difference(stagedActionIds, skippedActionIds);\n        skippedActionIds = [];\n        currentStateIndex = Math.min(\n          currentStateIndex,\n          stagedActionIds.length - 1\n        );\n        break;\n      }\n      case Actions.PERFORM_ACTION: {\n        // Auto-commit as new actions come in.\n        if (options.maxAge && stagedActionIds.length === options.maxAge) {\n          commitExcessActions(1);\n        }\n\n        if (currentStateIndex === stagedActionIds.length - 1) {\n          currentStateIndex++;\n        }\n        const actionId = nextActionId++;\n        // Mutation! This is the hottest path, and we optimize on purpose.\n        // It is safe because we set a new key in a cache dictionary.\n        actionsById[actionId] = liftedAction;\n\n        stagedActionIds = [...stagedActionIds, actionId];\n        // Optimization: we know that only the new action needs computing.\n        minInvalidatedStateIndex = stagedActionIds.length - 1;\n        break;\n      }\n      case Actions.IMPORT_STATE: {\n        // Completely replace everything.\n        ({\n          monitorState,\n          actionsById,\n          nextActionId,\n          stagedActionIds,\n          skippedActionIds,\n          committedState,\n          currentStateIndex,\n          // prettier-ignore\n          computedStates\n        } = liftedAction.nextLiftedState);\n        break;\n      }\n      case INIT: {\n        // Always recompute states on hot reload and init.\n        minInvalidatedStateIndex = 0;\n\n        if (options.maxAge && stagedActionIds.length > options.maxAge) {\n          // States must be recomputed before committing excess.\n          computedStates = recomputeStates(\n            computedStates,\n            minInvalidatedStateIndex,\n            reducer,\n            committedState,\n            actionsById,\n            stagedActionIds,\n            skippedActionIds,\n            errorHandler\n          );\n\n          commitExcessActions(stagedActionIds.length - options.maxAge);\n\n          // Avoid double computation.\n          minInvalidatedStateIndex = Infinity;\n        }\n\n        break;\n      }\n      case UPDATE: {\n        const stateHasErrors =\n          computedStates.filter(state => state.error).length > 0;\n\n        if (stateHasErrors) {\n          // Recompute all states\n          minInvalidatedStateIndex = 0;\n\n          if (options.maxAge && stagedActionIds.length > options.maxAge) {\n            // States must be recomputed before committing excess.\n            computedStates = recomputeStates(\n              computedStates,\n              minInvalidatedStateIndex,\n              reducer,\n              committedState,\n              actionsById,\n              stagedActionIds,\n              skippedActionIds,\n              errorHandler\n            );\n\n            commitExcessActions(stagedActionIds.length - options.maxAge);\n\n            // Avoid double computation.\n            minInvalidatedStateIndex = Infinity;\n          }\n        } else {\n          if (currentStateIndex === stagedActionIds.length - 1) {\n            currentStateIndex++;\n          }\n\n          // Add a new action to only recompute state\n          const actionId = nextActionId++;\n          actionsById[actionId] = new PerformAction(liftedAction, +Date.now());\n          stagedActionIds = [...stagedActionIds, actionId];\n\n          minInvalidatedStateIndex = stagedActionIds.length - 1;\n\n          // States must be recomputed before committing excess.\n          computedStates = recomputeStates(\n            computedStates,\n            minInvalidatedStateIndex,\n            reducer,\n            committedState,\n            actionsById,\n            stagedActionIds,\n            skippedActionIds,\n            errorHandler\n          );\n\n          // Recompute state history with latest reducer and update action\n          computedStates = computedStates.map(cmp => ({\n            ...cmp,\n            state: reducer(cmp.state, liftedAction),\n          }));\n\n          currentStateIndex = minInvalidatedStateIndex;\n\n          if (options.maxAge && stagedActionIds.length > options.maxAge) {\n            commitExcessActions(stagedActionIds.length - options.maxAge);\n          }\n\n          // Avoid double computation.\n          minInvalidatedStateIndex = Infinity;\n        }\n\n        break;\n      }\n      default: {\n        // If the action is not recognized, it's a monitor action.\n        // Optimization: a monitor action can't change history.\n        minInvalidatedStateIndex = Infinity;\n        break;\n      }\n    }\n\n    computedStates = recomputeStates(\n      computedStates,\n      minInvalidatedStateIndex,\n      reducer,\n      committedState,\n      actionsById,\n      stagedActionIds,\n      skippedActionIds,\n      errorHandler\n    );\n    monitorState = monitorReducer(monitorState, liftedAction);\n\n    return {\n      monitorState,\n      actionsById,\n      nextActionId,\n      stagedActionIds,\n      skippedActionIds,\n      committedState,\n      currentStateIndex,\n      computedStates,\n    };\n  };\n}\n"]}
387
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"reducer.js","sourceRoot":"","sources":["../../../../../../../../../modules/store-devtools/src/reducer.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AACA,OAAO,EAKL,MAAM,EACN,IAAI,GACL,MAAM,aAAa,CAAC;AACrB,OAAO,EAAE,UAAU,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AACjD,OAAO,KAAK,eAAe,MAAM,WAAW,CAAC;AAE7C,OAAO,EAAE,aAAa,EAAE,MAAM,WAAW,CAAC;AAa1C,MAAM,CAAC,IAAM,WAAW,GAAG,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC;AAE1C,MAAM,CAAC,IAAM,SAAS,GAAG,gCAAoE,CAAC;AAC9F,MAAM,CAAC,IAAM,gBAAgB,GAAG,EAAE,IAAI,EAAE,SAAS,EAAE,CAAC;AA6BpD;;GAEG;AACH,SAAS,gBAAgB,CACvB,OAAgC,EAChC,MAAc,EACd,KAAU,EACV,KAAU,EACV,YAA0B;IAE1B,IAAI,KAAK,EAAE;QACT,OAAO;YACL,KAAK,OAAA;YACL,KAAK,EAAE,sCAAsC;SAC9C,CAAC;KACH;IAED,IAAI,SAAS,GAAG,KAAK,CAAC;IACtB,IAAI,SAAS,CAAC;IACd,IAAI;QACF,SAAS,GAAG,OAAO,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;KACpC;IAAC,OAAO,GAAG,EAAE;QACZ,SAAS,GAAG,GAAG,CAAC,QAAQ,EAAE,CAAC;QAC3B,YAAY,CAAC,WAAW,CAAC,GAAG,CAAC,KAAK,IAAI,GAAG,CAAC,CAAC;KAC5C;IAED,OAAO;QACL,KAAK,EAAE,SAAS;QAChB,KAAK,EAAE,SAAS;KACjB,CAAC;AACJ,CAAC;AAED;;GAEG;AACH,SAAS,eAAe,CACtB,cAA+B,EAC/B,wBAAgC,EAChC,OAAgC,EAChC,cAAmB,EACnB,WAA0B,EAC1B,eAAyB,EACzB,gBAA0B,EAC1B,YAA0B,EAC1B,QAAiB;IAEjB,yDAAyD;IACzD,yCAAyC;IACzC,IACE,wBAAwB,IAAI,cAAc,CAAC,MAAM;QACjD,cAAc,CAAC,MAAM,KAAK,eAAe,CAAC,MAAM,EAChD;QACA,OAAO,cAAc,CAAC;KACvB;IAED,IAAM,kBAAkB,GAAG,cAAc,CAAC,KAAK,CAAC,CAAC,EAAE,wBAAwB,CAAC,CAAC;IAC7E,6EAA6E;IAC7E,6BAA6B;IAC7B,IAAM,oBAAoB,GAAG,eAAe,CAAC,MAAM,GAAG,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IACzE,KAAK,IAAI,CAAC,GAAG,wBAAwB,EAAE,CAAC,GAAG,oBAAoB,EAAE,CAAC,EAAE,EAAE;QACpE,IAAM,QAAQ,GAAG,eAAe,CAAC,CAAC,CAAC,CAAC;QACpC,IAAM,MAAM,GAAG,WAAW,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC;QAE5C,IAAM,aAAa,GAAG,kBAAkB,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;QAChD,IAAM,aAAa,GAAG,aAAa,CAAC,CAAC,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC,CAAC,cAAc,CAAC;QAC3E,IAAM,aAAa,GAAG,aAAa,CAAC,CAAC,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC,CAAC,SAAS,CAAC;QAEtE,IAAM,UAAU,GAAG,gBAAgB,CAAC,OAAO,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC;QAC3D,IAAM,KAAK,GAAkB,UAAU;YACrC,CAAC,CAAC,aAAa;YACf,CAAC,CAAC,gBAAgB,CACd,OAAO,EACP,MAAM,EACN,aAAa,EACb,aAAa,EACb,YAAY,CACb,CAAC;QAEN,kBAAkB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;KAChC;IACD,qEAAqE;IACrE,0DAA0D;IAC1D,IAAI,QAAQ,EAAE;QACZ,kBAAkB,CAAC,IAAI,CAAC,cAAc,CAAC,cAAc,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC;KACpE;IAED,OAAO,kBAAkB,CAAC;AAC5B,CAAC;AAED,MAAM,UAAU,gBAAgB,CAC9B,qBAA2B,EAC3B,cAAoB;IAEpB,OAAO;QACL,YAAY,EAAE,cAAc,CAAC,SAAS,EAAE,EAAE,CAAC;QAC3C,YAAY,EAAE,CAAC;QACf,WAAW,EAAE,EAAE,CAAC,EAAE,UAAU,CAAC,WAAW,CAAC,EAAE;QAC3C,eAAe,EAAE,CAAC,CAAC,CAAC;QACpB,gBAAgB,EAAE,EAAE;QACpB,cAAc,EAAE,qBAAqB;QACrC,iBAAiB,EAAE,CAAC;QACpB,cAAc,EAAE,EAAE;QAClB,QAAQ,EAAE,KAAK;QACf,QAAQ,EAAE,KAAK;KAChB,CAAC;AACJ,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,eAAe,CAC7B,qBAA0B,EAC1B,kBAA+B,EAC/B,YAA0B,EAC1B,cAAoB,EACpB,OAA0C;IAA1C,wBAAA,EAAA,YAA0C;IAE1C;;OAEG;IACH,OAAO,UACL,OAAgC,IACQ,OAAA,UAAC,WAAW,EAAE,YAAY;;QAC9D,IAAA,sCAY+B,EAXjC,8BAAY,EACZ,4BAAW,EACX,8BAAY,EACZ,oCAAe,EACf,sCAAgB,EAChB,kCAAc,EACd,wCAAiB,EACjB,kCAAc,EACd,sBAAQ,EACR,sBAEiC,CAAC;QAEpC,IAAI,CAAC,WAAW,EAAE;YAChB,sCAAsC;YACtC,WAAW,GAAG,MAAM,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC;SAC1C;QAED,SAAS,mBAAmB,CAAC,CAAS;YACpC,2CAA2C;YAC3C,IAAI,MAAM,GAAG,CAAC,CAAC;YACf,IAAI,WAAW,GAAG,eAAe,CAAC,KAAK,CAAC,CAAC,EAAE,MAAM,GAAG,CAAC,CAAC,CAAC;YAEvD,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,WAAW,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;gBAC3C,IAAI,cAAc,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,KAAK,EAAE;oBAC/B,sDAAsD;oBACtD,MAAM,GAAG,CAAC,CAAC;oBACX,WAAW,GAAG,eAAe,CAAC,KAAK,CAAC,CAAC,EAAE,MAAM,GAAG,CAAC,CAAC,CAAC;oBACnD,MAAM;iBACP;qBAAM;oBACL,OAAO,WAAW,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC;iBACpC;aACF;YAED,gBAAgB,GAAG,gBAAgB,CAAC,MAAM,CACxC,UAAA,EAAE,IAAI,OAAA,WAAW,CAAC,OAAO,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,EAA9B,CAA8B,CACrC,CAAC;YACF,eAAe,aAAI,CAAC,GAAK,eAAe,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC;YAC5D,cAAc,GAAG,cAAc,CAAC,MAAM,CAAC,CAAC,KAAK,CAAC;YAC9C,cAAc,GAAG,cAAc,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;YAC9C,iBAAiB;gBACf,iBAAiB,GAAG,MAAM,CAAC,CAAC,CAAC,iBAAiB,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;QAChE,CAAC;QAED,SAAS,aAAa;YACpB,4DAA4D;YAC5D,2DAA2D;YAC3D,WAAW,GAAG,EAAE,CAAC,EAAE,UAAU,CAAC,WAAW,CAAC,EAAE,CAAC;YAC7C,YAAY,GAAG,CAAC,CAAC;YACjB,eAAe,GAAG,CAAC,CAAC,CAAC,CAAC;YACtB,gBAAgB,GAAG,EAAE,CAAC;YACtB,cAAc,GAAG,cAAc,CAAC,iBAAiB,CAAC,CAAC,KAAK,CAAC;YACzD,iBAAiB,GAAG,CAAC,CAAC;YACtB,cAAc,GAAG,EAAE,CAAC;QACtB,CAAC;QAED,mEAAmE;QACnE,kEAAkE;QAClE,qEAAqE;QACrE,IAAI,wBAAwB,GAAG,CAAC,CAAC;QAEjC,QAAQ,YAAY,CAAC,IAAI,EAAE;YACzB,KAAK,eAAe,CAAC,YAAY,CAAC,CAAC;gBACjC,QAAQ,GAAG,YAAY,CAAC,MAAM,CAAC;gBAC/B,wBAAwB,GAAG,QAAQ,CAAC;gBACpC,MAAM;aACP;YACD,KAAK,eAAe,CAAC,eAAe,CAAC,CAAC;gBACpC,QAAQ,GAAG,YAAY,CAAC,MAAM,CAAC;gBAC/B,IAAI,QAAQ,EAAE;oBACZ,0EAA0E;oBAC1E,+EAA+E;oBAC/E,iDAAiD;oBACjD,eAAe,YAAO,eAAe,GAAE,YAAY,EAAC,CAAC;oBACrD,WAAW,CAAC,YAAY,CAAC,GAAG,IAAI,aAAa,CAC3C;wBACE,IAAI,EAAE,sBAAsB;qBAC7B,EACD,CAAC,IAAI,CAAC,GAAG,EAAE,CACZ,CAAC;oBACF,YAAY,EAAE,CAAC;oBACf,wBAAwB,GAAG,eAAe,CAAC,MAAM,GAAG,CAAC,CAAC;oBACtD,cAAc,GAAG,cAAc,CAAC,MAAM,CACpC,cAAc,CAAC,cAAc,CAAC,MAAM,GAAG,CAAC,CAAC,CAC1C,CAAC;oBAEF,IAAI,iBAAiB,KAAK,eAAe,CAAC,MAAM,GAAG,CAAC,EAAE;wBACpD,iBAAiB,EAAE,CAAC;qBACrB;oBACD,wBAAwB,GAAG,QAAQ,CAAC;iBACrC;qBAAM;oBACL,aAAa,EAAE,CAAC;iBACjB;gBACD,MAAM;aACP;YACD,KAAK,eAAe,CAAC,KAAK,CAAC,CAAC;gBAC1B,oDAAoD;gBACpD,WAAW,GAAG,EAAE,CAAC,EAAE,UAAU,CAAC,WAAW,CAAC,EAAE,CAAC;gBAC7C,YAAY,GAAG,CAAC,CAAC;gBACjB,eAAe,GAAG,CAAC,CAAC,CAAC,CAAC;gBACtB,gBAAgB,GAAG,EAAE,CAAC;gBACtB,cAAc,GAAG,qBAAqB,CAAC;gBACvC,iBAAiB,GAAG,CAAC,CAAC;gBACtB,cAAc,GAAG,EAAE,CAAC;gBACpB,MAAM;aACP;YACD,KAAK,eAAe,CAAC,MAAM,CAAC,CAAC;gBAC3B,aAAa,EAAE,CAAC;gBAChB,MAAM;aACP;YACD,KAAK,eAAe,CAAC,QAAQ,CAAC,CAAC;gBAC7B,mCAAmC;gBACnC,6CAA6C;gBAC7C,WAAW,GAAG,EAAE,CAAC,EAAE,UAAU,CAAC,WAAW,CAAC,EAAE,CAAC;gBAC7C,YAAY,GAAG,CAAC,CAAC;gBACjB,eAAe,GAAG,CAAC,CAAC,CAAC,CAAC;gBACtB,gBAAgB,GAAG,EAAE,CAAC;gBACtB,iBAAiB,GAAG,CAAC,CAAC;gBACtB,cAAc,GAAG,EAAE,CAAC;gBACpB,MAAM;aACP;YACD,KAAK,eAAe,CAAC,aAAa,CAAC,CAAC;gBAClC,qDAAqD;gBACrD,4DAA4D;gBACpD,IAAA,4BAAY,CAAkB;gBACtC,IAAM,KAAK,GAAG,gBAAgB,CAAC,OAAO,CAAC,UAAQ,CAAC,CAAC;gBACjD,IAAI,KAAK,KAAK,CAAC,CAAC,EAAE;oBAChB,gBAAgB,aAAI,UAAQ,GAAK,gBAAgB,CAAC,CAAC;iBACpD;qBAAM;oBACL,gBAAgB,GAAG,gBAAgB,CAAC,MAAM,CAAC,UAAA,EAAE,IAAI,OAAA,EAAE,KAAK,UAAQ,EAAf,CAAe,CAAC,CAAC;iBACnE;gBACD,kEAAkE;gBAClE,wBAAwB,GAAG,eAAe,CAAC,OAAO,CAAC,UAAQ,CAAC,CAAC;gBAC7D,MAAM;aACP;YACD,KAAK,eAAe,CAAC,kBAAkB,CAAC,CAAC;gBACvC,qDAAqD;gBACrD,4DAA4D;gBACpD,IAAA,0BAAK,EAAE,sBAAG,EAAE,4BAAM,CAAkB;gBAC5C,IAAM,SAAS,GAAG,EAAE,CAAC;gBACrB,KAAK,IAAI,CAAC,GAAG,KAAK,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,EAAE;oBAAE,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;gBACpD,IAAI,MAAM,EAAE;oBACV,gBAAgB,GAAG,UAAU,CAAC,gBAAgB,EAAE,SAAS,CAAC,CAAC;iBAC5D;qBAAM;oBACL,gBAAgB,YAAO,gBAAgB,EAAK,SAAS,CAAC,CAAC;iBACxD;gBAED,kEAAkE;gBAClE,wBAAwB,GAAG,eAAe,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;gBAC1D,MAAM;aACP;YACD,KAAK,eAAe,CAAC,aAAa,CAAC,CAAC;gBAClC,8DAA8D;gBAC9D,iEAAiE;gBACjE,iBAAiB,GAAG,YAAY,CAAC,KAAK,CAAC;gBACvC,qDAAqD;gBACrD,wBAAwB,GAAG,QAAQ,CAAC;gBACpC,MAAM;aACP;YACD,KAAK,eAAe,CAAC,cAAc,CAAC,CAAC;gBACnC,uDAAuD;gBACvD,iCAAiC;gBACjC,IAAM,KAAK,GAAG,eAAe,CAAC,OAAO,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC;gBAC7D,IAAI,KAAK,KAAK,CAAC,CAAC;oBAAE,iBAAiB,GAAG,KAAK,CAAC;gBAC5C,wBAAwB,GAAG,QAAQ,CAAC;gBACpC,MAAM;aACP;YACD,KAAK,eAAe,CAAC,KAAK,CAAC,CAAC;gBAC1B,uDAAuD;gBACvD,eAAe,GAAG,UAAU,CAAC,eAAe,EAAE,gBAAgB,CAAC,CAAC;gBAChE,gBAAgB,GAAG,EAAE,CAAC;gBACtB,iBAAiB,GAAG,IAAI,CAAC,GAAG,CAC1B,iBAAiB,EACjB,eAAe,CAAC,MAAM,GAAG,CAAC,CAC3B,CAAC;gBACF,MAAM;aACP;YACD,KAAK,eAAe,CAAC,cAAc,CAAC,CAAC;gBACnC,8DAA8D;gBAC9D,IAAI,QAAQ,EAAE;oBACZ,OAAO,WAAW,IAAI,kBAAkB,CAAC;iBAC1C;gBAED,IAAI,QAAQ,EAAE;oBACZ,mDAAmD;oBACnD,oEAAoE;oBACpE,kEAAkE;oBAClE,gCAAgC;oBAChC,IAAM,SAAS,GAAG,cAAc,CAAC,cAAc,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;oBAC5D,cAAc,YACT,cAAc,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;wBAC9B,gBAAgB,CACd,OAAO,EACP,YAAY,CAAC,MAAM,EACnB,SAAS,CAAC,KAAK,EACf,SAAS,CAAC,KAAK,EACf,YAAY,CACb;sBACF,CAAC;oBACF,wBAAwB,GAAG,QAAQ,CAAC;oBACpC,MAAM;iBACP;gBAED,sCAAsC;gBACtC,IAAI,OAAO,CAAC,MAAM,IAAI,eAAe,CAAC,MAAM,KAAK,OAAO,CAAC,MAAM,EAAE;oBAC/D,mBAAmB,CAAC,CAAC,CAAC,CAAC;iBACxB;gBAED,IAAI,iBAAiB,KAAK,eAAe,CAAC,MAAM,GAAG,CAAC,EAAE;oBACpD,iBAAiB,EAAE,CAAC;iBACrB;gBACD,IAAM,QAAQ,GAAG,YAAY,EAAE,CAAC;gBAChC,kEAAkE;gBAClE,6DAA6D;gBAC7D,WAAW,CAAC,QAAQ,CAAC,GAAG,YAAY,CAAC;gBAErC,eAAe,YAAO,eAAe,GAAE,QAAQ,EAAC,CAAC;gBACjD,kEAAkE;gBAClE,wBAAwB,GAAG,eAAe,CAAC,MAAM,GAAG,CAAC,CAAC;gBACtD,MAAM;aACP;YACD,KAAK,eAAe,CAAC,YAAY,CAAC,CAAC;gBACjC,iCAAiC;gBACjC,CAAC,iCAY+B,EAX9B,8BAAY,EACZ,4BAAW,EACX,8BAAY,EACZ,oCAAe,EACf,sCAAgB,EAChB,kCAAc,EACd,wCAAiB,EACjB,kCAAc,EACd,sBAAQ;gBACR,kBAAkB;gBAClB,sBAAQ,CACuB,CAAC;gBAClC,MAAM;aACP;YACD,KAAK,IAAI,CAAC,CAAC;gBACT,kDAAkD;gBAClD,wBAAwB,GAAG,CAAC,CAAC;gBAE7B,IAAI,OAAO,CAAC,MAAM,IAAI,eAAe,CAAC,MAAM,GAAG,OAAO,CAAC,MAAM,EAAE;oBAC7D,sDAAsD;oBACtD,cAAc,GAAG,eAAe,CAC9B,cAAc,EACd,wBAAwB,EACxB,OAAO,EACP,cAAc,EACd,WAAW,EACX,eAAe,EACf,gBAAgB,EAChB,YAAY,EACZ,QAAQ,CACT,CAAC;oBAEF,mBAAmB,CAAC,eAAe,CAAC,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;oBAE7D,4BAA4B;oBAC5B,wBAAwB,GAAG,QAAQ,CAAC;iBACrC;gBAED,MAAM;aACP;YACD,KAAK,MAAM,CAAC,CAAC;gBACX,IAAM,cAAc,GAClB,cAAc,CAAC,MAAM,CAAC,UAAA,KAAK,IAAI,OAAA,KAAK,CAAC,KAAK,EAAX,CAAW,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC;gBAEzD,IAAI,cAAc,EAAE;oBAClB,uBAAuB;oBACvB,wBAAwB,GAAG,CAAC,CAAC;oBAE7B,IAAI,OAAO,CAAC,MAAM,IAAI,eAAe,CAAC,MAAM,GAAG,OAAO,CAAC,MAAM,EAAE;wBAC7D,sDAAsD;wBACtD,cAAc,GAAG,eAAe,CAC9B,cAAc,EACd,wBAAwB,EACxB,OAAO,EACP,cAAc,EACd,WAAW,EACX,eAAe,EACf,gBAAgB,EAChB,YAAY,EACZ,QAAQ,CACT,CAAC;wBAEF,mBAAmB,CAAC,eAAe,CAAC,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;wBAE7D,4BAA4B;wBAC5B,wBAAwB,GAAG,QAAQ,CAAC;qBACrC;iBACF;qBAAM;oBACL,iEAAiE;oBACjE,mCAAmC;oBACnC,IAAI,CAAC,QAAQ,IAAI,CAAC,QAAQ,EAAE;wBAC1B,IAAI,iBAAiB,KAAK,eAAe,CAAC,MAAM,GAAG,CAAC,EAAE;4BACpD,iBAAiB,EAAE,CAAC;yBACrB;wBAED,2CAA2C;wBAC3C,IAAM,QAAQ,GAAG,YAAY,EAAE,CAAC;wBAChC,WAAW,CAAC,QAAQ,CAAC,GAAG,IAAI,aAAa,CACvC,YAAY,EACZ,CAAC,IAAI,CAAC,GAAG,EAAE,CACZ,CAAC;wBACF,eAAe,YAAO,eAAe,GAAE,QAAQ,EAAC,CAAC;wBAEjD,wBAAwB,GAAG,eAAe,CAAC,MAAM,GAAG,CAAC,CAAC;wBAEtD,cAAc,GAAG,eAAe,CAC9B,cAAc,EACd,wBAAwB,EACxB,OAAO,EACP,cAAc,EACd,WAAW,EACX,eAAe,EACf,gBAAgB,EAChB,YAAY,EACZ,QAAQ,CACT,CAAC;qBACH;oBAED,gEAAgE;oBAChE,cAAc,GAAG,cAAc,CAAC,GAAG,CAAC,UAAA,GAAG,IAAI,OAAA,cACtC,GAAG,IACN,KAAK,EAAE,OAAO,CAAC,GAAG,CAAC,KAAK,EAAE,gBAAgB,CAAC,IAC3C,EAHyC,CAGzC,CAAC,CAAC;oBAEJ,iBAAiB,GAAG,eAAe,CAAC,MAAM,GAAG,CAAC,CAAC;oBAE/C,IAAI,OAAO,CAAC,MAAM,IAAI,eAAe,CAAC,MAAM,GAAG,OAAO,CAAC,MAAM,EAAE;wBAC7D,mBAAmB,CAAC,eAAe,CAAC,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;qBAC9D;oBAED,4BAA4B;oBAC5B,wBAAwB,GAAG,QAAQ,CAAC;iBACrC;gBAED,MAAM;aACP;YACD,OAAO,CAAC,CAAC;gBACP,0DAA0D;gBAC1D,uDAAuD;gBACvD,wBAAwB,GAAG,QAAQ,CAAC;gBACpC,MAAM;aACP;SACF;QAED,cAAc,GAAG,eAAe,CAC9B,cAAc,EACd,wBAAwB,EACxB,OAAO,EACP,cAAc,EACd,WAAW,EACX,eAAe,EACf,gBAAgB,EAChB,YAAY,EACZ,QAAQ,CACT,CAAC;QACF,YAAY,GAAG,cAAc,CAAC,YAAY,EAAE,YAAY,CAAC,CAAC;QAE1D,OAAO;YACL,YAAY,cAAA;YACZ,WAAW,aAAA;YACX,YAAY,cAAA;YACZ,eAAe,iBAAA;YACf,gBAAgB,kBAAA;YAChB,cAAc,gBAAA;YACd,iBAAiB,mBAAA;YACjB,cAAc,gBAAA;YACd,QAAQ,UAAA;YACR,QAAQ,UAAA;SACT,CAAC;IACJ,CAAC,EAvXyC,CAuXzC,CAAC;AACJ,CAAC","sourcesContent":["import { ErrorHandler } from '@angular/core';\nimport {\n  Action,\n  ActionReducer,\n  ActionsSubject,\n  ReducerManager,\n  UPDATE,\n  INIT,\n} from '@ngrx/store';\nimport { difference, liftAction } from './utils';\nimport * as DevtoolsActions from './actions';\nimport { StoreDevtoolsConfig, StateSanitizer } from './config';\nimport { PerformAction } from './actions';\n\nexport type InitAction = {\n  readonly type: typeof INIT;\n};\n\nexport type UpdateReducerAction = {\n  readonly type: typeof UPDATE;\n};\n\nexport type CoreActions = InitAction | UpdateReducerAction;\nexport type Actions = DevtoolsActions.All | CoreActions;\n\nexport const INIT_ACTION = { type: INIT };\n\nexport const RECOMPUTE = '@ngrx/store-devtools/recompute' as '@ngrx/store-devtools/recompute';\nexport const RECOMPUTE_ACTION = { type: RECOMPUTE };\n\nexport interface ComputedState {\n  state: any;\n  error: any;\n}\n\nexport interface LiftedAction {\n  type: string;\n  action: Action;\n}\n\nexport interface LiftedActions {\n  [id: number]: LiftedAction;\n}\n\nexport interface LiftedState {\n  monitorState: any;\n  nextActionId: number;\n  actionsById: LiftedActions;\n  stagedActionIds: number[];\n  skippedActionIds: number[];\n  committedState: any;\n  currentStateIndex: number;\n  computedStates: ComputedState[];\n  isLocked: boolean;\n  isPaused: boolean;\n}\n\n/**\n * Computes the next entry in the log by applying an action.\n */\nfunction computeNextEntry(\n  reducer: ActionReducer<any, any>,\n  action: Action,\n  state: any,\n  error: any,\n  errorHandler: ErrorHandler\n) {\n  if (error) {\n    return {\n      state,\n      error: 'Interrupted by an error up the chain',\n    };\n  }\n\n  let nextState = state;\n  let nextError;\n  try {\n    nextState = reducer(state, action);\n  } catch (err) {\n    nextError = err.toString();\n    errorHandler.handleError(err.stack || err);\n  }\n\n  return {\n    state: nextState,\n    error: nextError,\n  };\n}\n\n/**\n * Runs the reducer on invalidated actions to get a fresh computation log.\n */\nfunction recomputeStates(\n  computedStates: ComputedState[],\n  minInvalidatedStateIndex: number,\n  reducer: ActionReducer<any, any>,\n  committedState: any,\n  actionsById: LiftedActions,\n  stagedActionIds: number[],\n  skippedActionIds: number[],\n  errorHandler: ErrorHandler,\n  isPaused: boolean\n) {\n  // Optimization: exit early and return the same reference\n  // if we know nothing could have changed.\n  if (\n    minInvalidatedStateIndex >= computedStates.length &&\n    computedStates.length === stagedActionIds.length\n  ) {\n    return computedStates;\n  }\n\n  const nextComputedStates = computedStates.slice(0, minInvalidatedStateIndex);\n  // If the recording is paused, recompute all states up until the pause state,\n  // else recompute all states.\n  const lastIncludedActionId = stagedActionIds.length - (isPaused ? 1 : 0);\n  for (let i = minInvalidatedStateIndex; i < lastIncludedActionId; i++) {\n    const actionId = stagedActionIds[i];\n    const action = actionsById[actionId].action;\n\n    const previousEntry = nextComputedStates[i - 1];\n    const previousState = previousEntry ? previousEntry.state : committedState;\n    const previousError = previousEntry ? previousEntry.error : undefined;\n\n    const shouldSkip = skippedActionIds.indexOf(actionId) > -1;\n    const entry: ComputedState = shouldSkip\n      ? previousEntry\n      : computeNextEntry(\n          reducer,\n          action,\n          previousState,\n          previousError,\n          errorHandler\n        );\n\n    nextComputedStates.push(entry);\n  }\n  // If the recording is paused, the last state will not be recomputed,\n  // because it's essentially not part of the state history.\n  if (isPaused) {\n    nextComputedStates.push(computedStates[computedStates.length - 1]);\n  }\n\n  return nextComputedStates;\n}\n\nexport function liftInitialState(\n  initialCommittedState?: any,\n  monitorReducer?: any\n): LiftedState {\n  return {\n    monitorState: monitorReducer(undefined, {}),\n    nextActionId: 1,\n    actionsById: { 0: liftAction(INIT_ACTION) },\n    stagedActionIds: [0],\n    skippedActionIds: [],\n    committedState: initialCommittedState,\n    currentStateIndex: 0,\n    computedStates: [],\n    isLocked: false,\n    isPaused: false,\n  };\n}\n\n/**\n * Creates a history state reducer from an app's reducer.\n */\nexport function liftReducerWith(\n  initialCommittedState: any,\n  initialLiftedState: LiftedState,\n  errorHandler: ErrorHandler,\n  monitorReducer?: any,\n  options: Partial<StoreDevtoolsConfig> = {}\n) {\n  /**\n   * Manages how the history actions modify the history state.\n   */\n  return (\n    reducer: ActionReducer<any, any>\n  ): ActionReducer<LiftedState, Actions> => (liftedState, liftedAction) => {\n    let {\n      monitorState,\n      actionsById,\n      nextActionId,\n      stagedActionIds,\n      skippedActionIds,\n      committedState,\n      currentStateIndex,\n      computedStates,\n      isLocked,\n      isPaused,\n    } =\n      liftedState || initialLiftedState;\n\n    if (!liftedState) {\n      // Prevent mutating initialLiftedState\n      actionsById = Object.create(actionsById);\n    }\n\n    function commitExcessActions(n: number) {\n      // Auto-commits n-number of excess actions.\n      let excess = n;\n      let idsToDelete = stagedActionIds.slice(1, excess + 1);\n\n      for (let i = 0; i < idsToDelete.length; i++) {\n        if (computedStates[i + 1].error) {\n          // Stop if error is found. Commit actions up to error.\n          excess = i;\n          idsToDelete = stagedActionIds.slice(1, excess + 1);\n          break;\n        } else {\n          delete actionsById[idsToDelete[i]];\n        }\n      }\n\n      skippedActionIds = skippedActionIds.filter(\n        id => idsToDelete.indexOf(id) === -1\n      );\n      stagedActionIds = [0, ...stagedActionIds.slice(excess + 1)];\n      committedState = computedStates[excess].state;\n      computedStates = computedStates.slice(excess);\n      currentStateIndex =\n        currentStateIndex > excess ? currentStateIndex - excess : 0;\n    }\n\n    function commitChanges() {\n      // Consider the last committed state the new starting point.\n      // Squash any staged actions into a single committed state.\n      actionsById = { 0: liftAction(INIT_ACTION) };\n      nextActionId = 1;\n      stagedActionIds = [0];\n      skippedActionIds = [];\n      committedState = computedStates[currentStateIndex].state;\n      currentStateIndex = 0;\n      computedStates = [];\n    }\n\n    // By default, aggressively recompute every state whatever happens.\n    // This has O(n) performance, so we'll override this to a sensible\n    // value whenever we feel like we don't have to recompute the states.\n    let minInvalidatedStateIndex = 0;\n\n    switch (liftedAction.type) {\n      case DevtoolsActions.LOCK_CHANGES: {\n        isLocked = liftedAction.status;\n        minInvalidatedStateIndex = Infinity;\n        break;\n      }\n      case DevtoolsActions.PAUSE_RECORDING: {\n        isPaused = liftedAction.status;\n        if (isPaused) {\n          // Add a pause action to signal the devtools-user the recording is paused.\n          // The corresponding state will be overwritten on each update to always contain\n          // the latest state (see Actions.PERFORM_ACTION).\n          stagedActionIds = [...stagedActionIds, nextActionId];\n          actionsById[nextActionId] = new PerformAction(\n            {\n              type: '@ngrx/devtools/pause',\n            },\n            +Date.now()\n          );\n          nextActionId++;\n          minInvalidatedStateIndex = stagedActionIds.length - 1;\n          computedStates = computedStates.concat(\n            computedStates[computedStates.length - 1]\n          );\n\n          if (currentStateIndex === stagedActionIds.length - 2) {\n            currentStateIndex++;\n          }\n          minInvalidatedStateIndex = Infinity;\n        } else {\n          commitChanges();\n        }\n        break;\n      }\n      case DevtoolsActions.RESET: {\n        // Get back to the state the store was created with.\n        actionsById = { 0: liftAction(INIT_ACTION) };\n        nextActionId = 1;\n        stagedActionIds = [0];\n        skippedActionIds = [];\n        committedState = initialCommittedState;\n        currentStateIndex = 0;\n        computedStates = [];\n        break;\n      }\n      case DevtoolsActions.COMMIT: {\n        commitChanges();\n        break;\n      }\n      case DevtoolsActions.ROLLBACK: {\n        // Forget about any staged actions.\n        // Start again from the last committed state.\n        actionsById = { 0: liftAction(INIT_ACTION) };\n        nextActionId = 1;\n        stagedActionIds = [0];\n        skippedActionIds = [];\n        currentStateIndex = 0;\n        computedStates = [];\n        break;\n      }\n      case DevtoolsActions.TOGGLE_ACTION: {\n        // Toggle whether an action with given ID is skipped.\n        // Being skipped means it is a no-op during the computation.\n        const { id: actionId } = liftedAction;\n        const index = skippedActionIds.indexOf(actionId);\n        if (index === -1) {\n          skippedActionIds = [actionId, ...skippedActionIds];\n        } else {\n          skippedActionIds = skippedActionIds.filter(id => id !== actionId);\n        }\n        // Optimization: we know history before this action hasn't changed\n        minInvalidatedStateIndex = stagedActionIds.indexOf(actionId);\n        break;\n      }\n      case DevtoolsActions.SET_ACTIONS_ACTIVE: {\n        // Toggle whether an action with given ID is skipped.\n        // Being skipped means it is a no-op during the computation.\n        const { start, end, active } = liftedAction;\n        const actionIds = [];\n        for (let i = start; i < end; i++) actionIds.push(i);\n        if (active) {\n          skippedActionIds = difference(skippedActionIds, actionIds);\n        } else {\n          skippedActionIds = [...skippedActionIds, ...actionIds];\n        }\n\n        // Optimization: we know history before this action hasn't changed\n        minInvalidatedStateIndex = stagedActionIds.indexOf(start);\n        break;\n      }\n      case DevtoolsActions.JUMP_TO_STATE: {\n        // Without recomputing anything, move the pointer that tell us\n        // which state is considered the current one. Useful for sliders.\n        currentStateIndex = liftedAction.index;\n        // Optimization: we know the history has not changed.\n        minInvalidatedStateIndex = Infinity;\n        break;\n      }\n      case DevtoolsActions.JUMP_TO_ACTION: {\n        // Jumps to a corresponding state to a specific action.\n        // Useful when filtering actions.\n        const index = stagedActionIds.indexOf(liftedAction.actionId);\n        if (index !== -1) currentStateIndex = index;\n        minInvalidatedStateIndex = Infinity;\n        break;\n      }\n      case DevtoolsActions.SWEEP: {\n        // Forget any actions that are currently being skipped.\n        stagedActionIds = difference(stagedActionIds, skippedActionIds);\n        skippedActionIds = [];\n        currentStateIndex = Math.min(\n          currentStateIndex,\n          stagedActionIds.length - 1\n        );\n        break;\n      }\n      case DevtoolsActions.PERFORM_ACTION: {\n        // Ignore action and return state as is if recording is locked\n        if (isLocked) {\n          return liftedState || initialLiftedState;\n        }\n\n        if (isPaused) {\n          // If recording is paused, overwrite the last state\n          // (corresponds to the pause action) and keep everything else as is.\n          // This way, the app gets the new current state while the devtools\n          // do not record another action.\n          const lastState = computedStates[computedStates.length - 1];\n          computedStates = [\n            ...computedStates.slice(0, -1),\n            computeNextEntry(\n              reducer,\n              liftedAction.action,\n              lastState.state,\n              lastState.error,\n              errorHandler\n            ),\n          ];\n          minInvalidatedStateIndex = Infinity;\n          break;\n        }\n\n        // Auto-commit as new actions come in.\n        if (options.maxAge && stagedActionIds.length === options.maxAge) {\n          commitExcessActions(1);\n        }\n\n        if (currentStateIndex === stagedActionIds.length - 1) {\n          currentStateIndex++;\n        }\n        const actionId = nextActionId++;\n        // Mutation! This is the hottest path, and we optimize on purpose.\n        // It is safe because we set a new key in a cache dictionary.\n        actionsById[actionId] = liftedAction;\n\n        stagedActionIds = [...stagedActionIds, actionId];\n        // Optimization: we know that only the new action needs computing.\n        minInvalidatedStateIndex = stagedActionIds.length - 1;\n        break;\n      }\n      case DevtoolsActions.IMPORT_STATE: {\n        // Completely replace everything.\n        ({\n          monitorState,\n          actionsById,\n          nextActionId,\n          stagedActionIds,\n          skippedActionIds,\n          committedState,\n          currentStateIndex,\n          computedStates,\n          isLocked,\n          // prettier-ignore\n          isPaused\n        } = liftedAction.nextLiftedState);\n        break;\n      }\n      case INIT: {\n        // Always recompute states on hot reload and init.\n        minInvalidatedStateIndex = 0;\n\n        if (options.maxAge && stagedActionIds.length > options.maxAge) {\n          // States must be recomputed before committing excess.\n          computedStates = recomputeStates(\n            computedStates,\n            minInvalidatedStateIndex,\n            reducer,\n            committedState,\n            actionsById,\n            stagedActionIds,\n            skippedActionIds,\n            errorHandler,\n            isPaused\n          );\n\n          commitExcessActions(stagedActionIds.length - options.maxAge);\n\n          // Avoid double computation.\n          minInvalidatedStateIndex = Infinity;\n        }\n\n        break;\n      }\n      case UPDATE: {\n        const stateHasErrors =\n          computedStates.filter(state => state.error).length > 0;\n\n        if (stateHasErrors) {\n          // Recompute all states\n          minInvalidatedStateIndex = 0;\n\n          if (options.maxAge && stagedActionIds.length > options.maxAge) {\n            // States must be recomputed before committing excess.\n            computedStates = recomputeStates(\n              computedStates,\n              minInvalidatedStateIndex,\n              reducer,\n              committedState,\n              actionsById,\n              stagedActionIds,\n              skippedActionIds,\n              errorHandler,\n              isPaused\n            );\n\n            commitExcessActions(stagedActionIds.length - options.maxAge);\n\n            // Avoid double computation.\n            minInvalidatedStateIndex = Infinity;\n          }\n        } else {\n          // If not paused/locked, add a new action to signal devtools-user\n          // that there was a reducer update.\n          if (!isPaused && !isLocked) {\n            if (currentStateIndex === stagedActionIds.length - 1) {\n              currentStateIndex++;\n            }\n\n            // Add a new action to only recompute state\n            const actionId = nextActionId++;\n            actionsById[actionId] = new PerformAction(\n              liftedAction,\n              +Date.now()\n            );\n            stagedActionIds = [...stagedActionIds, actionId];\n\n            minInvalidatedStateIndex = stagedActionIds.length - 1;\n\n            computedStates = recomputeStates(\n              computedStates,\n              minInvalidatedStateIndex,\n              reducer,\n              committedState,\n              actionsById,\n              stagedActionIds,\n              skippedActionIds,\n              errorHandler,\n              isPaused\n            );\n          }\n\n          // Recompute state history with latest reducer and update action\n          computedStates = computedStates.map(cmp => ({\n            ...cmp,\n            state: reducer(cmp.state, RECOMPUTE_ACTION),\n          }));\n\n          currentStateIndex = stagedActionIds.length - 1;\n\n          if (options.maxAge && stagedActionIds.length > options.maxAge) {\n            commitExcessActions(stagedActionIds.length - options.maxAge);\n          }\n\n          // Avoid double computation.\n          minInvalidatedStateIndex = Infinity;\n        }\n\n        break;\n      }\n      default: {\n        // If the action is not recognized, it's a monitor action.\n        // Optimization: a monitor action can't change history.\n        minInvalidatedStateIndex = Infinity;\n        break;\n      }\n    }\n\n    computedStates = recomputeStates(\n      computedStates,\n      minInvalidatedStateIndex,\n      reducer,\n      committedState,\n      actionsById,\n      stagedActionIds,\n      skippedActionIds,\n      errorHandler,\n      isPaused\n    );\n    monitorState = monitorReducer(monitorState, liftedAction);\n\n    return {\n      monitorState,\n      actionsById,\n      nextActionId,\n      stagedActionIds,\n      skippedActionIds,\n      committedState,\n      currentStateIndex,\n      computedStates,\n      isLocked,\n      isPaused,\n    };\n  };\n}\n"]}