1 | ;
|
2 |
|
3 | Object.defineProperty(exports, "__esModule", {
|
4 | value: true
|
5 | });
|
6 | exports.liftAction = liftAction;
|
7 | exports.liftReducerWith = liftReducerWith;
|
8 | exports.unliftState = unliftState;
|
9 | exports.unliftStore = unliftStore;
|
10 | exports["default"] = instrument;
|
11 | exports.INIT_ACTION = exports.ActionCreators = exports.ActionTypes = void 0;
|
12 |
|
13 | var _difference = _interopRequireDefault(require("lodash/difference"));
|
14 |
|
15 | var _union = _interopRequireDefault(require("lodash/union"));
|
16 |
|
17 | var _isPlainObject = _interopRequireDefault(require("lodash/isPlainObject"));
|
18 |
|
19 | var _symbolObservable = _interopRequireDefault(require("symbol-observable"));
|
20 |
|
21 | function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
22 |
|
23 | function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }
|
24 |
|
25 | function _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 |
|
27 | function _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 |
|
29 | function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && Symbol.iterator in Object(iter)) return Array.from(iter); }
|
30 |
|
31 | function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }
|
32 |
|
33 | function _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 |
|
35 | function 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 |
|
37 | function _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 |
|
39 | function _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 |
|
41 | function _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 |
|
43 | var 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 | };
|
58 | exports.ActionTypes = ActionTypes;
|
59 | var isChrome = (typeof window === "undefined" ? "undefined" : _typeof(window)) === 'object' && (typeof window.chrome !== 'undefined' || typeof window.process !== 'undefined' && window.process.type === 'renderer');
|
60 | var isChromeOrNode = isChrome || typeof process !== 'undefined' && process.release && process.release.name === 'node';
|
61 |
|
62 | /**
|
63 | * Action creators to change the History state.
|
64 | */
|
65 | var 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 | };
|
198 | exports.ActionCreators = ActionCreators;
|
199 | var INIT_ACTION = {
|
200 | type: '@@INIT'
|
201 | };
|
202 | /**
|
203 | * Computes the next entry with exceptions catching.
|
204 | */
|
205 |
|
206 | exports.INIT_ACTION = INIT_ACTION;
|
207 |
|
208 | function 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 |
|
237 | function 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 |
|
251 | function 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 |
|
291 | function liftAction(action, trace, traceLimit, // eslint-disable-next-line @typescript-eslint/ban-types
|
292 | toExcludeFromTrace) {
|
293 | return ActionCreators.performAction(action, trace, traceLimit, toExcludeFromTrace);
|
294 | }
|
295 |
|
296 | function isArray(nextLiftedState) {
|
297 | return Array.isArray(nextLiftedState);
|
298 | }
|
299 |
|
300 | /**
|
301 | * Creates a history state reducer from an app's reducer.
|
302 | */
|
303 | function 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 |
|
724 | function 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 | */
|
734 | function 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 | */
|
789 | function 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 |