UNPKG

102 kBJavaScriptView Raw
1"use strict";
2
3Object.defineProperty(exports, "__esModule", {
4 value: true
5});
6exports.liftAction = liftAction;
7exports.liftReducerWith = liftReducerWith;
8exports.unliftState = unliftState;
9exports.unliftStore = unliftStore;
10exports["default"] = instrument;
11exports.INIT_ACTION = exports.ActionCreators = exports.ActionTypes = void 0;
12
13var _difference = _interopRequireDefault(require("lodash/difference"));
14
15var _union = _interopRequireDefault(require("lodash/union"));
16
17var _isPlainObject = _interopRequireDefault(require("lodash/isPlainObject"));
18
19var _symbolObservable = _interopRequireDefault(require("symbol-observable"));
20
21function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
22
23function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }
24
25function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
26
27function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
28
29function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && Symbol.iterator in Object(iter)) return Array.from(iter); }
30
31function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }
32
33function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
34
35function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
36
37function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
38
39function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
40
41function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
42
43var ActionTypes = {
44 PERFORM_ACTION: 'PERFORM_ACTION',
45 RESET: 'RESET',
46 ROLLBACK: 'ROLLBACK',
47 COMMIT: 'COMMIT',
48 SWEEP: 'SWEEP',
49 TOGGLE_ACTION: 'TOGGLE_ACTION',
50 SET_ACTIONS_ACTIVE: 'SET_ACTIONS_ACTIVE',
51 JUMP_TO_STATE: 'JUMP_TO_STATE',
52 JUMP_TO_ACTION: 'JUMP_TO_ACTION',
53 REORDER_ACTION: 'REORDER_ACTION',
54 IMPORT_STATE: 'IMPORT_STATE',
55 LOCK_CHANGES: 'LOCK_CHANGES',
56 PAUSE_RECORDING: 'PAUSE_RECORDING'
57};
58exports.ActionTypes = ActionTypes;
59var isChrome = (typeof window === "undefined" ? "undefined" : _typeof(window)) === 'object' && (typeof window.chrome !== 'undefined' || typeof window.process !== 'undefined' && window.process.type === 'renderer');
60var isChromeOrNode = isChrome || typeof process !== 'undefined' && process.release && process.release.name === 'node';
61
62/**
63 * Action creators to change the History state.
64 */
65var ActionCreators = {
66 performAction: function performAction(action, trace, traceLimit, // eslint-disable-next-line @typescript-eslint/ban-types
67 toExcludeFromTrace) {
68 if (!(0, _isPlainObject["default"])(action)) {
69 throw new Error('Actions must be plain objects. ' + 'Use custom middleware for async actions.');
70 }
71
72 if (typeof action.type === 'undefined') {
73 throw new Error('Actions may not have an undefined "type" property. ' + 'Have you misspelled a constant?');
74 }
75
76 var stack;
77
78 if (trace) {
79 var extraFrames = 0;
80
81 if (typeof trace === 'function') {
82 stack = trace(action);
83 } else {
84 var error = Error();
85 var prevStackTraceLimit;
86
87 if (Error.captureStackTrace && isChromeOrNode) {
88 // avoid error-polyfill
89 if (traceLimit && Error.stackTraceLimit < traceLimit) {
90 prevStackTraceLimit = Error.stackTraceLimit;
91 Error.stackTraceLimit = traceLimit;
92 }
93
94 Error.captureStackTrace(error, toExcludeFromTrace);
95 } else {
96 extraFrames = 3;
97 }
98
99 stack = error.stack;
100 if (prevStackTraceLimit) Error.stackTraceLimit = prevStackTraceLimit;
101
102 if (extraFrames || typeof Error.stackTraceLimit !== 'number' || traceLimit && Error.stackTraceLimit > traceLimit) {
103 if (stack != null) {
104 var frames = stack.split('\n');
105
106 if (traceLimit && frames.length > traceLimit) {
107 stack = frames.slice(0, traceLimit + extraFrames + (frames[0].startsWith('Error') ? 1 : 0)).join('\n');
108 }
109 }
110 }
111 }
112 }
113
114 return {
115 type: ActionTypes.PERFORM_ACTION,
116 action: action,
117 timestamp: Date.now(),
118 stack: stack
119 };
120 },
121 reset: function reset() {
122 return {
123 type: ActionTypes.RESET,
124 timestamp: Date.now()
125 };
126 },
127 rollback: function rollback() {
128 return {
129 type: ActionTypes.ROLLBACK,
130 timestamp: Date.now()
131 };
132 },
133 commit: function commit() {
134 return {
135 type: ActionTypes.COMMIT,
136 timestamp: Date.now()
137 };
138 },
139 sweep: function sweep() {
140 return {
141 type: ActionTypes.SWEEP
142 };
143 },
144 toggleAction: function toggleAction(id) {
145 return {
146 type: ActionTypes.TOGGLE_ACTION,
147 id: id
148 };
149 },
150 setActionsActive: function setActionsActive(start, end) {
151 var active = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : true;
152 return {
153 type: ActionTypes.SET_ACTIONS_ACTIVE,
154 start: start,
155 end: end,
156 active: active
157 };
158 },
159 reorderAction: function reorderAction(actionId, beforeActionId) {
160 return {
161 type: ActionTypes.REORDER_ACTION,
162 actionId: actionId,
163 beforeActionId: beforeActionId
164 };
165 },
166 jumpToState: function jumpToState(index) {
167 return {
168 type: ActionTypes.JUMP_TO_STATE,
169 index: index
170 };
171 },
172 jumpToAction: function jumpToAction(actionId) {
173 return {
174 type: ActionTypes.JUMP_TO_ACTION,
175 actionId: actionId
176 };
177 },
178 importState: function importState(nextLiftedState, noRecompute) {
179 return {
180 type: ActionTypes.IMPORT_STATE,
181 nextLiftedState: nextLiftedState,
182 noRecompute: noRecompute
183 };
184 },
185 lockChanges: function lockChanges(status) {
186 return {
187 type: ActionTypes.LOCK_CHANGES,
188 status: status
189 };
190 },
191 pauseRecording: function pauseRecording(status) {
192 return {
193 type: ActionTypes.PAUSE_RECORDING,
194 status: status
195 };
196 }
197};
198exports.ActionCreators = ActionCreators;
199var INIT_ACTION = {
200 type: '@@INIT'
201};
202/**
203 * Computes the next entry with exceptions catching.
204 */
205
206exports.INIT_ACTION = INIT_ACTION;
207
208function computeWithTryCatch(reducer, action, state) {
209 var nextState = state;
210 var nextError;
211
212 try {
213 nextState = reducer(state, action);
214 } catch (err) {
215 nextError = err.toString();
216
217 if (isChrome) {
218 // In Chrome, rethrowing provides better source map support
219 setTimeout(function () {
220 throw err;
221 });
222 } else {
223 console.error(err); // eslint-disable-line no-console
224 }
225 }
226
227 return {
228 state: nextState,
229 error: nextError
230 };
231}
232/**
233 * Computes the next entry in the log by applying an action.
234 */
235
236
237function computeNextEntry(reducer, action, state, shouldCatchErrors) {
238 if (!shouldCatchErrors) {
239 return {
240 state: reducer(state, action)
241 };
242 }
243
244 return computeWithTryCatch(reducer, action, state);
245}
246/**
247 * Runs the reducer on invalidated actions to get a fresh computation log.
248 */
249
250
251function recomputeStates(computedStates, minInvalidatedStateIndex, reducer, committedState, actionsById, stagedActionIds, skippedActionIds, shouldCatchErrors) {
252 // Optimization: exit early and return the same reference
253 // if we know nothing could have changed.
254 if (!computedStates || minInvalidatedStateIndex === -1 || minInvalidatedStateIndex >= computedStates.length && computedStates.length === stagedActionIds.length) {
255 return computedStates;
256 }
257
258 var nextComputedStates = computedStates.slice(0, minInvalidatedStateIndex);
259
260 for (var i = minInvalidatedStateIndex; i < stagedActionIds.length; i++) {
261 var _actionId = stagedActionIds[i];
262 var _action = actionsById[_actionId].action;
263 var previousEntry = nextComputedStates[i - 1];
264 var previousState = previousEntry ? previousEntry.state : committedState;
265 var shouldSkip = skippedActionIds.indexOf(_actionId) > -1;
266 var entry = void 0;
267
268 if (shouldSkip) {
269 entry = previousEntry;
270 } else {
271 if (shouldCatchErrors && previousEntry && previousEntry.error) {
272 entry = {
273 state: previousState,
274 error: 'Interrupted by an error up the chain'
275 };
276 } else {
277 entry = computeNextEntry(reducer, _action, previousState, shouldCatchErrors);
278 }
279 }
280
281 nextComputedStates.push(entry);
282 }
283
284 return nextComputedStates;
285}
286/**
287 * Lifts an app's action into an action on the lifted store.
288 */
289
290
291function liftAction(action, trace, traceLimit, // eslint-disable-next-line @typescript-eslint/ban-types
292toExcludeFromTrace) {
293 return ActionCreators.performAction(action, trace, traceLimit, toExcludeFromTrace);
294}
295
296function isArray(nextLiftedState) {
297 return Array.isArray(nextLiftedState);
298}
299
300/**
301 * Creates a history state reducer from an app's reducer.
302 */
303function liftReducerWith(reducer, initialCommittedState, monitorReducer, options) {
304 var initialLiftedState = {
305 monitorState: monitorReducer(undefined, {}),
306 nextActionId: 1,
307 actionsById: {
308 0: liftAction(INIT_ACTION)
309 },
310 stagedActionIds: [0],
311 skippedActionIds: [],
312 committedState: initialCommittedState,
313 currentStateIndex: 0,
314 computedStates: [],
315 isLocked: options.shouldStartLocked === true,
316 isPaused: options.shouldRecordChanges === false
317 };
318 /**
319 * Manages how the history actions modify the history state.
320 */
321
322 return function (liftedState, liftedAction) {
323 var _ref = liftedState || initialLiftedState,
324 monitorState = _ref.monitorState,
325 actionsById = _ref.actionsById,
326 nextActionId = _ref.nextActionId,
327 stagedActionIds = _ref.stagedActionIds,
328 skippedActionIds = _ref.skippedActionIds,
329 committedState = _ref.committedState,
330 currentStateIndex = _ref.currentStateIndex,
331 computedStates = _ref.computedStates,
332 isLocked = _ref.isLocked,
333 isPaused = _ref.isPaused;
334
335 if (!liftedState) {
336 // Prevent mutating initialLiftedState
337 actionsById = _objectSpread({}, actionsById);
338 }
339
340 function commitExcessActions(n) {
341 // Auto-commits n-number of excess actions.
342 var excess = n;
343 var idsToDelete = stagedActionIds.slice(1, excess + 1);
344
345 for (var i = 0; i < idsToDelete.length; i++) {
346 if (computedStates[i + 1].error) {
347 // Stop if error is found. Commit actions up to error.
348 excess = i;
349 idsToDelete = stagedActionIds.slice(1, excess + 1);
350 break;
351 } else {
352 delete actionsById[idsToDelete[i]];
353 }
354 }
355
356 skippedActionIds = skippedActionIds.filter(function (id) {
357 return idsToDelete.indexOf(id) === -1;
358 });
359 stagedActionIds = [0].concat(_toConsumableArray(stagedActionIds.slice(excess + 1)));
360 committedState = computedStates[excess].state;
361 computedStates = computedStates.slice(excess);
362 currentStateIndex = currentStateIndex > excess ? currentStateIndex - excess : 0;
363 }
364
365 function computePausedAction(shouldInit) {
366 var computedState;
367
368 if (shouldInit) {
369 computedState = computedStates[currentStateIndex];
370 monitorState = monitorReducer(monitorState, liftedAction);
371 } else {
372 computedState = computeNextEntry(reducer, liftedAction.action, computedStates[currentStateIndex].state, false);
373 }
374
375 if (!options.pauseActionType || nextActionId === 1) {
376 return {
377 monitorState: monitorState,
378 actionsById: {
379 0: liftAction(INIT_ACTION)
380 },
381 nextActionId: 1,
382 stagedActionIds: [0],
383 skippedActionIds: [],
384 committedState: computedState.state,
385 currentStateIndex: 0,
386 computedStates: [computedState],
387 isLocked: isLocked,
388 isPaused: true
389 };
390 }
391
392 if (shouldInit) {
393 if (currentStateIndex === stagedActionIds.length - 1) {
394 currentStateIndex++;
395 }
396
397 stagedActionIds = [].concat(_toConsumableArray(stagedActionIds), [nextActionId]);
398 nextActionId++;
399 }
400
401 return {
402 monitorState: monitorState,
403 actionsById: _objectSpread(_objectSpread({}, actionsById), {}, _defineProperty({}, nextActionId - 1, liftAction({
404 type: options.pauseActionType
405 }))),
406 nextActionId: nextActionId,
407 stagedActionIds: stagedActionIds,
408 skippedActionIds: skippedActionIds,
409 committedState: committedState,
410 currentStateIndex: currentStateIndex,
411 computedStates: [].concat(_toConsumableArray(computedStates.slice(0, stagedActionIds.length - 1)), [computedState]),
412 isLocked: isLocked,
413 isPaused: true
414 };
415 } // By default, aggressively recompute every state whatever happens.
416 // This has O(n) performance, so we'll override this to a sensible
417 // value whenever we feel like we don't have to recompute the states.
418
419
420 var minInvalidatedStateIndex = 0; // maxAge number can be changed dynamically
421
422 var maxAge = options.maxAge;
423 if (typeof maxAge === 'function') maxAge = maxAge(liftedAction, liftedState);
424
425 if (/^@@redux\/(INIT|REPLACE)/.test(liftedAction.type)) {
426 if (options.shouldHotReload === false) {
427 actionsById = {
428 0: liftAction(INIT_ACTION)
429 };
430 nextActionId = 1;
431 stagedActionIds = [0];
432 skippedActionIds = [];
433 committedState = computedStates.length === 0 ? initialCommittedState : computedStates[currentStateIndex].state;
434 currentStateIndex = 0;
435 computedStates = [];
436 } // Recompute states on hot reload and init.
437
438
439 minInvalidatedStateIndex = 0;
440
441 if (maxAge && stagedActionIds.length > maxAge) {
442 // States must be recomputed before committing excess.
443 computedStates = recomputeStates(computedStates, minInvalidatedStateIndex, reducer, committedState, actionsById, stagedActionIds, skippedActionIds, options.shouldCatchErrors);
444 commitExcessActions(stagedActionIds.length - maxAge); // Avoid double computation.
445
446 minInvalidatedStateIndex = Infinity;
447 }
448 } else {
449 switch (liftedAction.type) {
450 case ActionTypes.PERFORM_ACTION:
451 {
452 if (isLocked) return liftedState || initialLiftedState;
453 if (isPaused) return computePausedAction(); // Auto-commit as new actions come in.
454
455 if (maxAge && stagedActionIds.length >= maxAge) {
456 commitExcessActions(stagedActionIds.length - maxAge + 1);
457 }
458
459 if (currentStateIndex === stagedActionIds.length - 1) {
460 currentStateIndex++;
461 }
462
463 var _actionId2 = nextActionId++; // Mutation! This is the hottest path, and we optimize on purpose.
464 // It is safe because we set a new key in a cache dictionary.
465
466
467 actionsById[_actionId2] = liftedAction;
468 stagedActionIds = [].concat(_toConsumableArray(stagedActionIds), [_actionId2]); // Optimization: we know that only the new action needs computing.
469
470 minInvalidatedStateIndex = stagedActionIds.length - 1;
471 break;
472 }
473
474 case ActionTypes.RESET:
475 {
476 // Get back to the state the store was created with.
477 actionsById = {
478 0: liftAction(INIT_ACTION)
479 };
480 nextActionId = 1;
481 stagedActionIds = [0];
482 skippedActionIds = [];
483 committedState = initialCommittedState;
484 currentStateIndex = 0;
485 computedStates = [];
486 break;
487 }
488
489 case ActionTypes.COMMIT:
490 {
491 // Consider the last committed state the new starting point.
492 // Squash any staged actions into a single committed state.
493 actionsById = {
494 0: liftAction(INIT_ACTION)
495 };
496 nextActionId = 1;
497 stagedActionIds = [0];
498 skippedActionIds = [];
499 committedState = computedStates[currentStateIndex].state;
500 currentStateIndex = 0;
501 computedStates = [];
502 break;
503 }
504
505 case ActionTypes.ROLLBACK:
506 {
507 // Forget about any staged actions.
508 // Start again from the last committed state.
509 actionsById = {
510 0: liftAction(INIT_ACTION)
511 };
512 nextActionId = 1;
513 stagedActionIds = [0];
514 skippedActionIds = [];
515 currentStateIndex = 0;
516 computedStates = [];
517 break;
518 }
519
520 case ActionTypes.TOGGLE_ACTION:
521 {
522 // Toggle whether an action with given ID is skipped.
523 // Being skipped means it is a no-op during the computation.
524 var _actionId3 = liftedAction.id;
525 var index = skippedActionIds.indexOf(_actionId3);
526
527 if (index === -1) {
528 skippedActionIds = [_actionId3].concat(_toConsumableArray(skippedActionIds));
529 } else {
530 skippedActionIds = skippedActionIds.filter(function (id) {
531 return id !== _actionId3;
532 });
533 } // Optimization: we know history before this action hasn't changed
534
535
536 minInvalidatedStateIndex = stagedActionIds.indexOf(_actionId3);
537 break;
538 }
539
540 case ActionTypes.SET_ACTIONS_ACTIVE:
541 {
542 // Toggle whether an action with given ID is skipped.
543 // Being skipped means it is a no-op during the computation.
544 var start = liftedAction.start,
545 end = liftedAction.end,
546 active = liftedAction.active;
547 var actionIds = [];
548
549 for (var i = start; i < end; i++) {
550 actionIds.push(i);
551 }
552
553 if (active) {
554 skippedActionIds = (0, _difference["default"])(skippedActionIds, actionIds);
555 } else {
556 skippedActionIds = (0, _union["default"])(skippedActionIds, actionIds);
557 } // Optimization: we know history before this action hasn't changed
558
559
560 minInvalidatedStateIndex = stagedActionIds.indexOf(start);
561 break;
562 }
563
564 case ActionTypes.JUMP_TO_STATE:
565 {
566 // Without recomputing anything, move the pointer that tell us
567 // which state is considered the current one. Useful for sliders.
568 currentStateIndex = liftedAction.index; // Optimization: we know the history has not changed.
569
570 minInvalidatedStateIndex = Infinity;
571 break;
572 }
573
574 case ActionTypes.JUMP_TO_ACTION:
575 {
576 // Jumps to a corresponding state to a specific action.
577 // Useful when filtering actions.
578 var _index = stagedActionIds.indexOf(liftedAction.actionId);
579
580 if (_index !== -1) currentStateIndex = _index;
581 minInvalidatedStateIndex = Infinity;
582 break;
583 }
584
585 case ActionTypes.SWEEP:
586 {
587 // Forget any actions that are currently being skipped.
588 stagedActionIds = (0, _difference["default"])(stagedActionIds, skippedActionIds);
589 skippedActionIds = [];
590 currentStateIndex = Math.min(currentStateIndex, stagedActionIds.length - 1);
591 break;
592 }
593
594 case ActionTypes.REORDER_ACTION:
595 {
596 // Recompute actions in a new order.
597 var _actionId4 = liftedAction.actionId;
598 var idx = stagedActionIds.indexOf(_actionId4); // do nothing in case the action is already removed or trying to move the first action
599
600 if (idx < 1) break;
601 var beforeActionId = liftedAction.beforeActionId;
602 var newIdx = stagedActionIds.indexOf(beforeActionId);
603
604 if (newIdx < 1) {
605 // move to the beginning or to the end
606 var count = stagedActionIds.length;
607 newIdx = beforeActionId > stagedActionIds[count - 1] ? count : 1;
608 }
609
610 var diff = idx - newIdx;
611
612 if (diff > 0) {
613 // move left
614 stagedActionIds = [].concat(_toConsumableArray(stagedActionIds.slice(0, newIdx)), [_actionId4], _toConsumableArray(stagedActionIds.slice(newIdx, idx)), _toConsumableArray(stagedActionIds.slice(idx + 1)));
615 minInvalidatedStateIndex = newIdx;
616 } else if (diff < 0) {
617 // move right
618 stagedActionIds = [].concat(_toConsumableArray(stagedActionIds.slice(0, idx)), _toConsumableArray(stagedActionIds.slice(idx + 1, newIdx)), [_actionId4], _toConsumableArray(stagedActionIds.slice(newIdx)));
619 minInvalidatedStateIndex = idx;
620 }
621
622 break;
623 }
624
625 case ActionTypes.IMPORT_STATE:
626 {
627 if (isArray(liftedAction.nextLiftedState)) {
628 // recompute array of actions
629 actionsById = {
630 0: liftAction(INIT_ACTION)
631 };
632 nextActionId = 1;
633 stagedActionIds = [0];
634 skippedActionIds = [];
635 currentStateIndex = liftedAction.nextLiftedState.length;
636 computedStates = [];
637 committedState = liftedAction.preloadedState;
638 minInvalidatedStateIndex = 0; // iterate through actions
639
640 liftedAction.nextLiftedState.forEach(function (action) {
641 actionsById[nextActionId] = liftAction(action, options.trace || options.shouldIncludeCallstack);
642 stagedActionIds.push(nextActionId);
643 nextActionId++;
644 });
645 } else {
646 // Completely replace everything.
647 var _liftedAction$nextLif = liftedAction.nextLiftedState;
648 monitorState = _liftedAction$nextLif.monitorState;
649 actionsById = _liftedAction$nextLif.actionsById;
650 nextActionId = _liftedAction$nextLif.nextActionId;
651 stagedActionIds = _liftedAction$nextLif.stagedActionIds;
652 skippedActionIds = _liftedAction$nextLif.skippedActionIds;
653 committedState = _liftedAction$nextLif.committedState;
654 currentStateIndex = _liftedAction$nextLif.currentStateIndex;
655 computedStates = _liftedAction$nextLif.computedStates;
656
657 if (liftedAction.noRecompute) {
658 minInvalidatedStateIndex = Infinity;
659 }
660 }
661
662 break;
663 }
664
665 case ActionTypes.LOCK_CHANGES:
666 {
667 isLocked = liftedAction.status;
668 minInvalidatedStateIndex = Infinity;
669 break;
670 }
671
672 case ActionTypes.PAUSE_RECORDING:
673 {
674 isPaused = liftedAction.status;
675
676 if (isPaused) {
677 return computePausedAction(true);
678 } // Commit when unpausing
679
680
681 actionsById = {
682 0: liftAction(INIT_ACTION)
683 };
684 nextActionId = 1;
685 stagedActionIds = [0];
686 skippedActionIds = [];
687 committedState = computedStates[currentStateIndex].state;
688 currentStateIndex = 0;
689 computedStates = [];
690 break;
691 }
692
693 default:
694 {
695 // If the action is not recognized, it's a monitor action.
696 // Optimization: a monitor action can't change history.
697 minInvalidatedStateIndex = Infinity;
698 break;
699 }
700 }
701 }
702
703 computedStates = recomputeStates(computedStates, minInvalidatedStateIndex, reducer, committedState, actionsById, stagedActionIds, skippedActionIds, options.shouldCatchErrors);
704 monitorState = monitorReducer(monitorState, liftedAction);
705 return {
706 monitorState: monitorState,
707 actionsById: actionsById,
708 nextActionId: nextActionId,
709 stagedActionIds: stagedActionIds,
710 skippedActionIds: skippedActionIds,
711 committedState: committedState,
712 currentStateIndex: currentStateIndex,
713 computedStates: computedStates,
714 isLocked: isLocked,
715 isPaused: isPaused
716 };
717 };
718}
719/**
720 * Provides an app's view into the state of the lifted store.
721 */
722
723
724function unliftState(liftedState) {
725 var computedStates = liftedState.computedStates,
726 currentStateIndex = liftedState.currentStateIndex;
727 var state = computedStates[currentStateIndex].state;
728 return state;
729}
730
731/**
732 * Provides an app's view into the lifted store.
733 */
734function unliftStore(liftedStore, liftReducer, options) {
735 var lastDefinedState;
736 var trace = options.trace || options.shouldIncludeCallstack;
737 var traceLimit = options.traceLimit || 10;
738
739 function getState() {
740 var state = unliftState(liftedStore.getState());
741
742 if (state !== undefined) {
743 lastDefinedState = state;
744 }
745
746 return lastDefinedState;
747 }
748
749 function dispatch(action) {
750 liftedStore.dispatch(liftAction(action, trace, traceLimit, dispatch));
751 return action;
752 }
753
754 return _objectSpread(_objectSpread({}, liftedStore), {}, _defineProperty({
755 liftedStore: liftedStore,
756 dispatch: dispatch,
757 getState: getState,
758 replaceReducer: function replaceReducer(nextReducer) {
759 liftedStore.replaceReducer(liftReducer(nextReducer));
760 }
761 }, _symbolObservable["default"], function () {
762 return _objectSpread(_objectSpread({}, liftedStore[_symbolObservable["default"]]()), {}, _defineProperty({
763 subscribe: function subscribe(observer) {
764 if (_typeof(observer) !== 'object') {
765 throw new TypeError('Expected the observer to be an object.');
766 }
767
768 function observeState() {
769 if (observer.next) {
770 observer.next(getState());
771 }
772 }
773
774 observeState();
775 var unsubscribe = liftedStore.subscribe(observeState);
776 return {
777 unsubscribe: unsubscribe
778 };
779 }
780 }, _symbolObservable["default"], function () {
781 return this;
782 }));
783 }));
784}
785
786/**
787 * Redux instrumentation store enhancer.
788 */
789function instrument() {
790 var monitorReducer = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : function () {
791 return null;
792 };
793 var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
794
795 if (typeof options.maxAge === 'number' && options.maxAge < 2) {
796 throw new Error('DevTools.instrument({ maxAge }) option, if specified, ' + 'may not be less than 2.');
797 }
798
799 return function (createStore) {
800 return function (reducer, initialState) {
801 function liftReducer(r) {
802 if (typeof r !== 'function') {
803 if (r && typeof r["default"] === 'function') {
804 throw new Error('Expected the reducer to be a function. ' + 'Instead got an object with a "default" field. ' + 'Did you pass a module instead of the default export? ' + 'Try passing require(...).default instead.');
805 }
806
807 throw new Error('Expected the reducer to be a function.');
808 }
809
810 return liftReducerWith(r, initialState, monitorReducer, options);
811 }
812
813 var liftedStore = createStore(liftReducer(reducer));
814
815 if (liftedStore.liftedStore) {
816 throw new Error('DevTools instrumentation should not be applied more than once. ' + 'Check your store configuration.');
817 }
818
819 return unliftStore(liftedStore, liftReducer, options);
820 };
821 };
822}
823//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/instrument.ts"],"names":["ActionTypes","PERFORM_ACTION","RESET","ROLLBACK","COMMIT","SWEEP","TOGGLE_ACTION","SET_ACTIONS_ACTIVE","JUMP_TO_STATE","JUMP_TO_ACTION","REORDER_ACTION","IMPORT_STATE","LOCK_CHANGES","PAUSE_RECORDING","isChrome","window","chrome","process","type","isChromeOrNode","release","name","ActionCreators","performAction","action","trace","traceLimit","toExcludeFromTrace","Error","stack","extraFrames","error","prevStackTraceLimit","captureStackTrace","stackTraceLimit","frames","split","length","slice","startsWith","join","timestamp","Date","now","reset","rollback","commit","sweep","toggleAction","id","setActionsActive","start","end","active","reorderAction","actionId","beforeActionId","jumpToState","index","jumpToAction","importState","nextLiftedState","noRecompute","lockChanges","status","pauseRecording","INIT_ACTION","computeWithTryCatch","reducer","state","nextState","nextError","err","toString","setTimeout","console","computeNextEntry","shouldCatchErrors","recomputeStates","computedStates","minInvalidatedStateIndex","committedState","actionsById","stagedActionIds","skippedActionIds","nextComputedStates","i","previousEntry","previousState","shouldSkip","indexOf","entry","push","liftAction","isArray","Array","liftReducerWith","initialCommittedState","monitorReducer","options","initialLiftedState","monitorState","undefined","nextActionId","currentStateIndex","isLocked","shouldStartLocked","isPaused","shouldRecordChanges","liftedState","liftedAction","commitExcessActions","n","excess","idsToDelete","filter","computePausedAction","shouldInit","computedState","pauseActionType","maxAge","test","shouldHotReload","Infinity","actionIds","Math","min","idx","newIdx","count","diff","preloadedState","forEach","shouldIncludeCallstack","unliftState","unliftStore","liftedStore","liftReducer","lastDefinedState","getState","dispatch","replaceReducer","nextReducer","$$observable","subscribe","observer","TypeError","observeState","next","unsubscribe","instrument","createStore","initialState","r"],"mappings":"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","sourcesContent":["import difference from 'lodash/difference';\nimport union from 'lodash/union';\nimport isPlainObject from 'lodash/isPlainObject';\nimport $$observable from 'symbol-observable';\nimport {\n  Action,\n  Observable,\n  PreloadedState,\n  Reducer,\n  Store,\n  StoreEnhancer,\n  StoreEnhancerStoreCreator,\n} from 'redux';\n\nexport const ActionTypes = {\n  PERFORM_ACTION: 'PERFORM_ACTION',\n  RESET: 'RESET',\n  ROLLBACK: 'ROLLBACK',\n  COMMIT: 'COMMIT',\n  SWEEP: 'SWEEP',\n  TOGGLE_ACTION: 'TOGGLE_ACTION',\n  SET_ACTIONS_ACTIVE: 'SET_ACTIONS_ACTIVE',\n  JUMP_TO_STATE: 'JUMP_TO_STATE',\n  JUMP_TO_ACTION: 'JUMP_TO_ACTION',\n  REORDER_ACTION: 'REORDER_ACTION',\n  IMPORT_STATE: 'IMPORT_STATE',\n  LOCK_CHANGES: 'LOCK_CHANGES',\n  PAUSE_RECORDING: 'PAUSE_RECORDING',\n} as const;\n\nconst isChrome =\n  typeof window === 'object' &&\n  (typeof (window as typeof window & { chrome: unknown }).chrome !==\n    'undefined' ||\n    (typeof window.process !== 'undefined' &&\n      (window.process as typeof window.process & { type: unknown }).type ===\n        'renderer'));\n\nconst isChromeOrNode =\n  isChrome ||\n  (typeof process !== 'undefined' &&\n    process.release &&\n    process.release.name === 'node');\n\nexport interface PerformAction<A extends Action<unknown>> {\n  type: typeof ActionTypes.PERFORM_ACTION;\n  action: A;\n  timestamp: number;\n  stack: string | undefined;\n}\n\ninterface ResetAction {\n  type: typeof ActionTypes.RESET;\n  timestamp: number;\n}\n\ninterface RollbackAction {\n  type: typeof ActionTypes.ROLLBACK;\n  timestamp: number;\n}\n\ninterface CommitAction {\n  type: typeof ActionTypes.COMMIT;\n  timestamp: number;\n}\n\ninterface SweepAction {\n  type: typeof ActionTypes.SWEEP;\n}\n\ninterface ToggleAction {\n  type: typeof ActionTypes.TOGGLE_ACTION;\n  id: number;\n}\n\ninterface SetActionsActiveAction {\n  type: typeof ActionTypes.SET_ACTIONS_ACTIVE;\n  start: number;\n  end: number;\n  active: boolean;\n}\n\ninterface ReorderAction {\n  type: typeof ActionTypes.REORDER_ACTION;\n  actionId: number;\n  beforeActionId: number;\n}\n\ninterface JumpToStateAction {\n  type: typeof ActionTypes.JUMP_TO_STATE;\n  index: number;\n}\n\ninterface JumpToActionAction {\n  type: typeof ActionTypes.JUMP_TO_ACTION;\n  actionId: number;\n}\n\ninterface ImportStateAction<S, A extends Action<unknown>, MonitorState> {\n  type: typeof ActionTypes.IMPORT_STATE;\n  nextLiftedState: LiftedState<S, A, MonitorState> | readonly A[];\n  preloadedState?: S;\n  noRecompute: boolean | undefined;\n}\n\ninterface LockChangesAction {\n  type: typeof ActionTypes.LOCK_CHANGES;\n  status: boolean;\n}\n\ninterface PauseRecordingAction {\n  type: typeof ActionTypes.PAUSE_RECORDING;\n  status: boolean;\n}\n\nexport type LiftedAction<S, A extends Action<unknown>, MonitorState> =\n  | PerformAction<A>\n  | ResetAction\n  | RollbackAction\n  | CommitAction\n  | SweepAction\n  | ToggleAction\n  | SetActionsActiveAction\n  | ReorderAction\n  | JumpToStateAction\n  | JumpToActionAction\n  | ImportStateAction<S, A, MonitorState>\n  | LockChangesAction\n  | PauseRecordingAction;\n\n/**\n * Action creators to change the History state.\n */\nexport const ActionCreators = {\n  performAction<A extends Action<unknown>>(\n    action: A,\n    trace?: ((action: A) => string | undefined) | boolean,\n    traceLimit?: number,\n    // eslint-disable-next-line @typescript-eslint/ban-types\n    toExcludeFromTrace?: Function\n  ) {\n    if (!isPlainObject(action)) {\n      throw new Error(\n        'Actions must be plain objects. ' +\n          'Use custom middleware for async actions.'\n      );\n    }\n\n    if (typeof action.type === 'undefined') {\n      throw new Error(\n        'Actions may not have an undefined \"type\" property. ' +\n          'Have you misspelled a constant?'\n      );\n    }\n\n    let stack;\n    if (trace) {\n      let extraFrames = 0;\n      if (typeof trace === 'function') {\n        stack = trace(action);\n      } else {\n        const error = Error();\n        let prevStackTraceLimit;\n        if (Error.captureStackTrace && isChromeOrNode) {\n          // avoid error-polyfill\n          if (traceLimit && Error.stackTraceLimit < traceLimit) {\n            prevStackTraceLimit = Error.stackTraceLimit;\n            Error.stackTraceLimit = traceLimit;\n          }\n          Error.captureStackTrace(error, toExcludeFromTrace);\n        } else {\n          extraFrames = 3;\n        }\n        stack = error.stack;\n        if (prevStackTraceLimit) Error.stackTraceLimit = prevStackTraceLimit;\n        if (\n          extraFrames ||\n          typeof Error.stackTraceLimit !== 'number' ||\n          (traceLimit && Error.stackTraceLimit > traceLimit)\n        ) {\n          if (stack != null) {\n            const frames = stack.split('\\n');\n            if (traceLimit && frames.length > traceLimit) {\n              stack = frames\n                .slice(\n                  0,\n                  traceLimit +\n                    extraFrames +\n                    (frames[0].startsWith('Error') ? 1 : 0)\n                )\n                .join('\\n');\n            }\n          }\n        }\n      }\n    }\n\n    return {\n      type: ActionTypes.PERFORM_ACTION,\n      action,\n      timestamp: Date.now(),\n      stack,\n    };\n  },\n\n  reset(): ResetAction {\n    return { type: ActionTypes.RESET, timestamp: Date.now() };\n  },\n\n  rollback(): RollbackAction {\n    return { type: ActionTypes.ROLLBACK, timestamp: Date.now() };\n  },\n\n  commit(): CommitAction {\n    return { type: ActionTypes.COMMIT, timestamp: Date.now() };\n  },\n\n  sweep(): SweepAction {\n    return { type: ActionTypes.SWEEP };\n  },\n\n  toggleAction(id: number): ToggleAction {\n    return { type: ActionTypes.TOGGLE_ACTION, id };\n  },\n\n  setActionsActive(\n    start: number,\n    end: number,\n    active = true\n  ): SetActionsActiveAction {\n    return { type: ActionTypes.SET_ACTIONS_ACTIVE, start, end, active };\n  },\n\n  reorderAction(actionId: number, beforeActionId: number): ReorderAction {\n    return { type: ActionTypes.REORDER_ACTION, actionId, beforeActionId };\n  },\n\n  jumpToState(index: number): JumpToStateAction {\n    return { type: ActionTypes.JUMP_TO_STATE, index };\n  },\n\n  jumpToAction(actionId: number): JumpToActionAction {\n    return { type: ActionTypes.JUMP_TO_ACTION, actionId };\n  },\n\n  importState<S, A extends Action<unknown>, MonitorState = null>(\n    nextLiftedState: LiftedState<S, A, MonitorState> | readonly A[],\n    noRecompute?: boolean\n  ): ImportStateAction<S, A, MonitorState> {\n    return { type: ActionTypes.IMPORT_STATE, nextLiftedState, noRecompute };\n  },\n\n  lockChanges(status: boolean): LockChangesAction {\n    return { type: ActionTypes.LOCK_CHANGES, status };\n  },\n\n  pauseRecording(status: boolean): PauseRecordingAction {\n    return { type: ActionTypes.PAUSE_RECORDING, status };\n  },\n};\n\nexport const INIT_ACTION = { type: '@@INIT' };\n\n/**\n * Computes the next entry with exceptions catching.\n */\nfunction computeWithTryCatch<S, A extends Action<unknown>>(\n  reducer: Reducer<S, A>,\n  action: A,\n  state: S\n) {\n  let nextState = state;\n  let nextError;\n  try {\n    nextState = reducer(state, action);\n  } catch (err) {\n    nextError = err.toString();\n    if (isChrome) {\n      // In Chrome, rethrowing provides better source map support\n      setTimeout(() => {\n        throw err;\n      });\n    } else {\n      console.error(err); // eslint-disable-line no-console\n    }\n  }\n\n  return {\n    state: nextState,\n    error: nextError,\n  };\n}\n\n/**\n * Computes the next entry in the log by applying an action.\n */\nfunction computeNextEntry<S, A extends Action<unknown>>(\n  reducer: Reducer<S, A>,\n  action: A,\n  state: S,\n  shouldCatchErrors: boolean | undefined\n) {\n  if (!shouldCatchErrors) {\n    return { state: reducer(state, action) };\n  }\n  return computeWithTryCatch(reducer, action, state);\n}\n\n/**\n * Runs the reducer on invalidated actions to get a fresh computation log.\n */\nfunction recomputeStates<S, A extends Action<unknown>>(\n  computedStates: { state: S; error?: string }[],\n  minInvalidatedStateIndex: number,\n  reducer: Reducer<S, A>,\n  committedState: S,\n  actionsById: { [actionId: number]: PerformAction<A> },\n  stagedActionIds: number[],\n  skippedActionIds: number[],\n  shouldCatchErrors: boolean | undefined\n) {\n  // Optimization: exit early and return the same reference\n  // if we know nothing could have changed.\n  if (\n    !computedStates ||\n    minInvalidatedStateIndex === -1 ||\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\n    const shouldSkip = skippedActionIds.indexOf(actionId) > -1;\n    let entry;\n    if (shouldSkip) {\n      entry = previousEntry;\n    } else {\n      if (shouldCatchErrors && previousEntry && previousEntry.error) {\n        entry = {\n          state: previousState,\n          error: 'Interrupted by an error up the chain',\n        };\n      } else {\n        entry = computeNextEntry(\n          reducer,\n          action,\n          previousState,\n          shouldCatchErrors\n        );\n      }\n    }\n    nextComputedStates.push(entry);\n  }\n\n  return nextComputedStates;\n}\n\n/**\n * Lifts an app's action into an action on the lifted store.\n */\nexport function liftAction<A extends Action<unknown>>(\n  action: A,\n  trace?: ((action: A) => string | undefined) | boolean,\n  traceLimit?: number,\n  // eslint-disable-next-line @typescript-eslint/ban-types\n  toExcludeFromTrace?: Function\n) {\n  return ActionCreators.performAction(\n    action,\n    trace,\n    traceLimit,\n    toExcludeFromTrace\n  );\n}\n\nfunction isArray<S, A extends Action<unknown>, MonitorState>(\n  nextLiftedState: LiftedState<S, A, MonitorState> | readonly A[]\n): nextLiftedState is readonly A[] {\n  return Array.isArray(nextLiftedState);\n}\n\nexport interface LiftedState<S, A extends Action<unknown>, MonitorState> {\n  monitorState: MonitorState;\n  nextActionId: number;\n  actionsById: { [actionId: number]: PerformAction<A> };\n  stagedActionIds: number[];\n  skippedActionIds: number[];\n  committedState: S;\n  currentStateIndex: number;\n  computedStates: { state: S; error?: string }[];\n  isLocked: boolean;\n  isPaused: boolean;\n}\n\n/**\n * Creates a history state reducer from an app's reducer.\n */\nexport function liftReducerWith<\n  S,\n  A extends Action<unknown>,\n  MonitorState,\n  MonitorAction extends Action<unknown>\n>(\n  reducer: Reducer<S, A>,\n  initialCommittedState: PreloadedState<S> | undefined,\n  monitorReducer: Reducer<MonitorState, MonitorAction>,\n  options: Options<S, A, MonitorState, MonitorAction>\n): Reducer<LiftedState<S, A, MonitorState>, LiftedAction<S, A, MonitorState>> {\n  const initialLiftedState: LiftedState<S, A, MonitorState> = {\n    monitorState: monitorReducer(undefined, {} as MonitorAction),\n    nextActionId: 1,\n    actionsById: { 0: liftAction(INIT_ACTION as A) },\n    stagedActionIds: [0],\n    skippedActionIds: [],\n    committedState: initialCommittedState as S,\n    currentStateIndex: 0,\n    computedStates: [],\n    isLocked: options.shouldStartLocked === true,\n    isPaused: options.shouldRecordChanges === false,\n  };\n\n  /**\n   * Manages how the history actions modify the history state.\n   */\n  return (\n    liftedState: LiftedState<S, A, MonitorState> | undefined,\n    liftedAction: LiftedAction<S, A, MonitorState>\n  ): LiftedState<S, A, MonitorState> => {\n    let {\n      monitorState,\n      actionsById,\n      nextActionId,\n      stagedActionIds,\n      skippedActionIds,\n      committedState,\n      currentStateIndex,\n      computedStates,\n      isLocked,\n      isPaused,\n    } = liftedState || initialLiftedState;\n\n    if (!liftedState) {\n      // Prevent mutating initialLiftedState\n      actionsById = { ...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 computePausedAction(\n      shouldInit?: boolean\n    ): LiftedState<S, A, MonitorState> {\n      let computedState;\n      if (shouldInit) {\n        computedState = computedStates[currentStateIndex];\n        monitorState = monitorReducer(\n          monitorState,\n          liftedAction as MonitorAction\n        );\n      } else {\n        computedState = computeNextEntry(\n          reducer,\n          (liftedAction as PerformAction<A>).action,\n          computedStates[currentStateIndex].state,\n          false\n        );\n      }\n      if (!options.pauseActionType || nextActionId === 1) {\n        return {\n          monitorState,\n          actionsById: { 0: liftAction(INIT_ACTION as A) },\n          nextActionId: 1,\n          stagedActionIds: [0],\n          skippedActionIds: [],\n          committedState: computedState.state,\n          currentStateIndex: 0,\n          computedStates: [computedState],\n          isLocked,\n          isPaused: true,\n        };\n      }\n      if (shouldInit) {\n        if (currentStateIndex === stagedActionIds.length - 1) {\n          currentStateIndex++;\n        }\n        stagedActionIds = [...stagedActionIds, nextActionId];\n        nextActionId++;\n      }\n      return {\n        monitorState,\n        actionsById: {\n          ...actionsById,\n          [nextActionId - 1]: liftAction({\n            type: options.pauseActionType,\n          } as A),\n        },\n        nextActionId,\n        stagedActionIds,\n        skippedActionIds,\n        committedState,\n        currentStateIndex,\n        computedStates: [\n          ...computedStates.slice(0, stagedActionIds.length - 1),\n          computedState,\n        ],\n        isLocked,\n        isPaused: true,\n      };\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    // maxAge number can be changed dynamically\n    let maxAge = options.maxAge;\n    if (typeof maxAge === 'function')\n      maxAge = maxAge(liftedAction, liftedState);\n\n    if (/^@@redux\\/(INIT|REPLACE)/.test(liftedAction.type)) {\n      if (options.shouldHotReload === false) {\n        actionsById = { 0: liftAction(INIT_ACTION as A) };\n        nextActionId = 1;\n        stagedActionIds = [0];\n        skippedActionIds = [];\n        committedState =\n          computedStates.length === 0\n            ? (initialCommittedState as S)\n            : computedStates[currentStateIndex].state;\n        currentStateIndex = 0;\n        computedStates = [];\n      }\n\n      // Recompute states on hot reload and init.\n      minInvalidatedStateIndex = 0;\n\n      if (maxAge && stagedActionIds.length > maxAge) {\n        // States must be recomputed before committing excess.\n        computedStates = recomputeStates<S, A>(\n          computedStates,\n          minInvalidatedStateIndex,\n          reducer,\n          committedState,\n          actionsById,\n          stagedActionIds,\n          skippedActionIds,\n          options.shouldCatchErrors\n        );\n\n        commitExcessActions(stagedActionIds.length - maxAge);\n\n        // Avoid double computation.\n        minInvalidatedStateIndex = Infinity;\n      }\n    } else {\n      switch (liftedAction.type) {\n        case ActionTypes.PERFORM_ACTION: {\n          if (isLocked) return liftedState || initialLiftedState;\n          if (isPaused) return computePausedAction();\n\n          // Auto-commit as new actions come in.\n          if (maxAge && stagedActionIds.length >= maxAge) {\n            commitExcessActions(stagedActionIds.length - maxAge + 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          stagedActionIds = [...stagedActionIds, actionId];\n          // Optimization: we know that only the new action needs computing.\n          minInvalidatedStateIndex = stagedActionIds.length - 1;\n          break;\n        }\n        case ActionTypes.RESET: {\n          // Get back to the state the store was created with.\n          actionsById = { 0: liftAction(INIT_ACTION as A) };\n          nextActionId = 1;\n          stagedActionIds = [0];\n          skippedActionIds = [];\n          committedState = initialCommittedState as S;\n          currentStateIndex = 0;\n          computedStates = [];\n          break;\n        }\n        case ActionTypes.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 as A) };\n          nextActionId = 1;\n          stagedActionIds = [0];\n          skippedActionIds = [];\n          committedState = computedStates[currentStateIndex].state;\n          currentStateIndex = 0;\n          computedStates = [];\n          break;\n        }\n        case ActionTypes.ROLLBACK: {\n          // Forget about any staged actions.\n          // Start again from the last committed state.\n          actionsById = { 0: liftAction(INIT_ACTION as A) };\n          nextActionId = 1;\n          stagedActionIds = [0];\n          skippedActionIds = [];\n          currentStateIndex = 0;\n          computedStates = [];\n          break;\n        }\n        case ActionTypes.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 ActionTypes.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 = union(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 ActionTypes.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 ActionTypes.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 ActionTypes.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 ActionTypes.REORDER_ACTION: {\n          // Recompute actions in a new order.\n          const actionId = liftedAction.actionId;\n          const idx = stagedActionIds.indexOf(actionId);\n          // do nothing in case the action is already removed or trying to move the first action\n          if (idx < 1) break;\n          const beforeActionId = liftedAction.beforeActionId;\n          let newIdx = stagedActionIds.indexOf(beforeActionId);\n          if (newIdx < 1) {\n            // move to the beginning or to the end\n            const count = stagedActionIds.length;\n            newIdx = beforeActionId > stagedActionIds[count - 1] ? count : 1;\n          }\n          const diff = idx - newIdx;\n\n          if (diff > 0) {\n            // move left\n            stagedActionIds = [\n              ...stagedActionIds.slice(0, newIdx),\n              actionId,\n              ...stagedActionIds.slice(newIdx, idx),\n              ...stagedActionIds.slice(idx + 1),\n            ];\n            minInvalidatedStateIndex = newIdx;\n          } else if (diff < 0) {\n            // move right\n            stagedActionIds = [\n              ...stagedActionIds.slice(0, idx),\n              ...stagedActionIds.slice(idx + 1, newIdx),\n              actionId,\n              ...stagedActionIds.slice(newIdx),\n            ];\n            minInvalidatedStateIndex = idx;\n          }\n          break;\n        }\n        case ActionTypes.IMPORT_STATE: {\n          if (isArray(liftedAction.nextLiftedState)) {\n            // recompute array of actions\n            actionsById = { 0: liftAction(INIT_ACTION as A) };\n            nextActionId = 1;\n            stagedActionIds = [0];\n            skippedActionIds = [];\n            currentStateIndex = liftedAction.nextLiftedState.length;\n            computedStates = [];\n            committedState = liftedAction.preloadedState as S;\n            minInvalidatedStateIndex = 0;\n            // iterate through actions\n            liftedAction.nextLiftedState.forEach((action) => {\n              actionsById[nextActionId] = liftAction(\n                action,\n                options.trace || options.shouldIncludeCallstack\n              );\n              stagedActionIds.push(nextActionId);\n              nextActionId++;\n            });\n          } else {\n            // Completely replace everything.\n            ({\n              monitorState,\n              actionsById,\n              nextActionId,\n              stagedActionIds,\n              skippedActionIds,\n              committedState,\n              currentStateIndex,\n              computedStates,\n            } = liftedAction.nextLiftedState);\n\n            if (liftedAction.noRecompute) {\n              minInvalidatedStateIndex = Infinity;\n            }\n          }\n\n          break;\n        }\n        case ActionTypes.LOCK_CHANGES: {\n          isLocked = liftedAction.status;\n          minInvalidatedStateIndex = Infinity;\n          break;\n        }\n        case ActionTypes.PAUSE_RECORDING: {\n          isPaused = liftedAction.status;\n          if (isPaused) {\n            return computePausedAction(true);\n          }\n          // Commit when unpausing\n          actionsById = { 0: liftAction(INIT_ACTION as A) };\n          nextActionId = 1;\n          stagedActionIds = [0];\n          skippedActionIds = [];\n          committedState = computedStates[currentStateIndex].state;\n          currentStateIndex = 0;\n          computedStates = [];\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\n    computedStates = recomputeStates(\n      computedStates,\n      minInvalidatedStateIndex,\n      reducer,\n      committedState,\n      actionsById,\n      stagedActionIds,\n      skippedActionIds,\n      options.shouldCatchErrors\n    );\n    monitorState = monitorReducer(monitorState, liftedAction as MonitorAction);\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\n/**\n * Provides an app's view into the state of the lifted store.\n */\nexport function unliftState<\n  S,\n  A extends Action<unknown>,\n  MonitorState,\n  NextStateExt\n>(\n  liftedState: LiftedState<S, A, MonitorState> & NextStateExt\n): S & NextStateExt {\n  const { computedStates, currentStateIndex } = liftedState;\n  const { state } = computedStates[currentStateIndex];\n  return state as S & NextStateExt;\n}\n\nexport type LiftedReducer<S, A extends Action<unknown>, MonitorState> = Reducer<\n  LiftedState<S, A, MonitorState>,\n  LiftedAction<S, A, MonitorState>\n>;\n\nexport type LiftedStore<S, A extends Action<unknown>, MonitorState> = Store<\n  LiftedState<S, A, MonitorState>,\n  LiftedAction<S, A, MonitorState>\n>;\n\nexport type InstrumentExt<S, A extends Action<unknown>, MonitorState> = {\n  liftedStore: LiftedStore<S, A, MonitorState>;\n};\n\nexport type EnhancedStore<S, A extends Action<unknown>, MonitorState> = Store<\n  S,\n  A\n> &\n  InstrumentExt<S, A, MonitorState>;\n\n/**\n * Provides an app's view into the lifted store.\n */\nexport function unliftStore<\n  S,\n  A extends Action<unknown>,\n  MonitorState,\n  MonitorAction extends Action<unknown>,\n  NextExt,\n  NextStateExt\n>(\n  liftedStore: Store<\n    LiftedState<S, A, MonitorState> & NextStateExt,\n    LiftedAction<S, A, MonitorState>\n  > &\n    NextExt,\n  liftReducer: (r: Reducer<S, A>) => LiftedReducer<S, A, MonitorState>,\n  options: Options<S, A, MonitorState, MonitorAction>\n) {\n  let lastDefinedState: S & NextStateExt;\n  const trace = options.trace || options.shouldIncludeCallstack;\n  const traceLimit = options.traceLimit || 10;\n\n  function getState(): S & NextStateExt {\n    const state = unliftState<S, A, MonitorState, NextStateExt>(\n      liftedStore.getState()\n    );\n    if (state !== undefined) {\n      lastDefinedState = state;\n    }\n    return lastDefinedState;\n  }\n\n  function dispatch<T extends A>(action: T): T {\n    liftedStore.dispatch(liftAction<A>(action, trace, traceLimit, dispatch));\n    return action;\n  }\n\n  return ({\n    ...liftedStore,\n\n    liftedStore,\n\n    dispatch,\n\n    getState,\n\n    replaceReducer(nextReducer: Reducer<S & NextStateExt, A>) {\n      liftedStore.replaceReducer(\n        (liftReducer(\n          (nextReducer as unknown) as Reducer<S, A>\n        ) as unknown) as Reducer<\n          LiftedState<S, A, MonitorState> & NextStateExt,\n          LiftedAction<S, A, MonitorState>\n        >\n      );\n    },\n\n    [$$observable](): Observable<S> {\n      return {\n        ...(liftedStore as any)[$$observable](),\n        subscribe(observer) {\n          if (typeof observer !== 'object') {\n            throw new TypeError('Expected the observer to be an object.');\n          }\n\n          function observeState() {\n            if (observer.next) {\n              observer.next(getState());\n            }\n          }\n\n          observeState();\n          const unsubscribe = liftedStore.subscribe(observeState);\n          return { unsubscribe };\n        },\n\n        [$$observable]() {\n          return this;\n        },\n      };\n    },\n  } as unknown) as Store<S & NextStateExt, A> &\n    NextExt & {\n      liftedStore: Store<\n        LiftedState<S, A, MonitorState> & NextStateExt,\n        LiftedAction<S, A, MonitorState>\n      >;\n    };\n}\n\nexport interface Options<\n  S,\n  A extends Action<unknown>,\n  MonitorState,\n  MonitorAction extends Action<unknown>\n> {\n  maxAge?:\n    | number\n    | ((\n        currentLiftedAction: LiftedAction<S, A, MonitorState>,\n        previousLiftedState: LiftedState<S, A, MonitorState> | undefined\n      ) => number);\n  shouldCatchErrors?: boolean;\n  shouldRecordChanges?: boolean;\n  pauseActionType?: unknown;\n  shouldStartLocked?: boolean;\n  shouldHotReload?: boolean;\n  trace?: boolean | ((action: A) => string | undefined);\n  traceLimit?: number;\n  shouldIncludeCallstack?: boolean;\n}\n\n/**\n * Redux instrumentation store enhancer.\n */\nexport default function instrument<\n  OptionsS,\n  OptionsA extends Action<unknown>,\n  MonitorState = null,\n  MonitorAction extends Action<unknown> = never\n>(\n  monitorReducer: Reducer<MonitorState, MonitorAction> = ((() =>\n    null) as unknown) as Reducer<MonitorState, MonitorAction>,\n  options: Options<OptionsS, OptionsA, MonitorState, MonitorAction> = {}\n): StoreEnhancer<InstrumentExt<any, any, MonitorState>> {\n  if (typeof options.maxAge === 'number' && options.maxAge < 2) {\n    throw new Error(\n      'DevTools.instrument({ maxAge }) option, if specified, ' +\n        'may not be less than 2.'\n    );\n  }\n\n  return <NextExt, NextStateExt>(\n    createStore: StoreEnhancerStoreCreator<NextExt, NextStateExt>\n  ) => <S, A extends Action<unknown>>(\n    reducer: Reducer<S, A>,\n    initialState?: PreloadedState<S>\n  ) => {\n    function liftReducer(r: Reducer<S, A>) {\n      if (typeof r !== 'function') {\n        if (r && typeof (r as { default: unknown }).default === 'function') {\n          throw new Error(\n            'Expected the reducer to be a function. ' +\n              'Instead got an object with a \"default\" field. ' +\n              'Did you pass a module instead of the default export? ' +\n              'Try passing require(...).default instead.'\n          );\n        }\n        throw new Error('Expected the reducer to be a function.');\n      }\n      return liftReducerWith<S, A, MonitorState, MonitorAction>(\n        r,\n        initialState,\n        monitorReducer,\n        (options as unknown) as Options<S, A, MonitorState, MonitorAction>\n      );\n    }\n\n    const liftedStore = createStore(liftReducer(reducer));\n    if (\n      (liftedStore as Store<\n        LiftedState<S, A, MonitorState> & NextStateExt,\n        LiftedAction<S, A, MonitorState>\n      > &\n        NextExt & {\n          liftedStore: Store<\n            LiftedState<S, A, MonitorState>,\n            LiftedAction<S, A, MonitorState>\n          >;\n        }).liftedStore\n    ) {\n      throw new Error(\n        'DevTools instrumentation should not be applied more than once. ' +\n          'Check your store configuration.'\n      );\n    }\n\n    return unliftStore<\n      S,\n      A,\n      MonitorState,\n      MonitorAction,\n      NextExt,\n      NextStateExt\n    >(\n      liftedStore,\n      liftReducer,\n      (options as unknown) as Options<S, A, MonitorState, MonitorAction>\n    );\n  };\n}\n"]}
\No newline at end of file