@ngrx/store-devtools 18.1.0 → 19.0.0-beta.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/fesm2022/ngrx-store-devtools.mjs +13 -13
- package/fesm2022/ngrx-store-devtools.mjs.map +1 -1
- package/package.json +3 -5
- package/schematics-core/utility/libs-version.js +1 -1
- package/schematics-core/utility/libs-version.js.map +1 -1
- package/schematics-core/utility/visitors.js +2 -2
- package/esm2022/index.mjs +0 -7
- package/esm2022/ngrx-store-devtools.mjs +0 -5
- package/esm2022/public_api.mjs +0 -2
- package/esm2022/src/actions.mjs +0 -97
- package/esm2022/src/config.mjs +0 -69
- package/esm2022/src/devtools-dispatcher.mjs +0 -11
- package/esm2022/src/devtools.mjs +0 -143
- package/esm2022/src/extension.mjs +0 -172
- package/esm2022/src/index.mjs +0 -7
- package/esm2022/src/instrument.mjs +0 -22
- package/esm2022/src/provide-store-devtools.mjs +0 -72
- package/esm2022/src/reducer.mjs +0 -368
- package/esm2022/src/utils.mjs +0 -114
- package/esm2022/src/zone-config.mjs +0 -6
package/esm2022/src/utils.mjs
DELETED
|
@@ -1,114 +0,0 @@
|
|
|
1
|
-
import * as Actions from './actions';
|
|
2
|
-
export function difference(first, second) {
|
|
3
|
-
return first.filter((item) => second.indexOf(item) < 0);
|
|
4
|
-
}
|
|
5
|
-
/**
|
|
6
|
-
* Provides an app's view into the state of the lifted store.
|
|
7
|
-
*/
|
|
8
|
-
export function unliftState(liftedState) {
|
|
9
|
-
const { computedStates, currentStateIndex } = liftedState;
|
|
10
|
-
// At start up NgRx dispatches init actions,
|
|
11
|
-
// When these init actions are being filtered out by the predicate or safe/block list options
|
|
12
|
-
// we don't have a complete computed states yet.
|
|
13
|
-
// At this point it could happen that we're out of bounds, when this happens we fall back to the last known state
|
|
14
|
-
if (currentStateIndex >= computedStates.length) {
|
|
15
|
-
const { state } = computedStates[computedStates.length - 1];
|
|
16
|
-
return state;
|
|
17
|
-
}
|
|
18
|
-
const { state } = computedStates[currentStateIndex];
|
|
19
|
-
return state;
|
|
20
|
-
}
|
|
21
|
-
export function unliftAction(liftedState) {
|
|
22
|
-
return liftedState.actionsById[liftedState.nextActionId - 1];
|
|
23
|
-
}
|
|
24
|
-
/**
|
|
25
|
-
* Lifts an app's action into an action on the lifted store.
|
|
26
|
-
*/
|
|
27
|
-
export function liftAction(action) {
|
|
28
|
-
return new Actions.PerformAction(action, +Date.now());
|
|
29
|
-
}
|
|
30
|
-
/**
|
|
31
|
-
* Sanitizes given actions with given function.
|
|
32
|
-
*/
|
|
33
|
-
export function sanitizeActions(actionSanitizer, actions) {
|
|
34
|
-
return Object.keys(actions).reduce((sanitizedActions, actionIdx) => {
|
|
35
|
-
const idx = Number(actionIdx);
|
|
36
|
-
sanitizedActions[idx] = sanitizeAction(actionSanitizer, actions[idx], idx);
|
|
37
|
-
return sanitizedActions;
|
|
38
|
-
}, {});
|
|
39
|
-
}
|
|
40
|
-
/**
|
|
41
|
-
* Sanitizes given action with given function.
|
|
42
|
-
*/
|
|
43
|
-
export function sanitizeAction(actionSanitizer, action, actionIdx) {
|
|
44
|
-
return {
|
|
45
|
-
...action,
|
|
46
|
-
action: actionSanitizer(action.action, actionIdx),
|
|
47
|
-
};
|
|
48
|
-
}
|
|
49
|
-
/**
|
|
50
|
-
* Sanitizes given states with given function.
|
|
51
|
-
*/
|
|
52
|
-
export function sanitizeStates(stateSanitizer, states) {
|
|
53
|
-
return states.map((computedState, idx) => ({
|
|
54
|
-
state: sanitizeState(stateSanitizer, computedState.state, idx),
|
|
55
|
-
error: computedState.error,
|
|
56
|
-
}));
|
|
57
|
-
}
|
|
58
|
-
/**
|
|
59
|
-
* Sanitizes given state with given function.
|
|
60
|
-
*/
|
|
61
|
-
export function sanitizeState(stateSanitizer, state, stateIdx) {
|
|
62
|
-
return stateSanitizer(state, stateIdx);
|
|
63
|
-
}
|
|
64
|
-
/**
|
|
65
|
-
* Read the config and tell if actions should be filtered
|
|
66
|
-
*/
|
|
67
|
-
export function shouldFilterActions(config) {
|
|
68
|
-
return config.predicate || config.actionsSafelist || config.actionsBlocklist;
|
|
69
|
-
}
|
|
70
|
-
/**
|
|
71
|
-
* Return a full filtered lifted state
|
|
72
|
-
*/
|
|
73
|
-
export function filterLiftedState(liftedState, predicate, safelist, blocklist) {
|
|
74
|
-
const filteredStagedActionIds = [];
|
|
75
|
-
const filteredActionsById = {};
|
|
76
|
-
const filteredComputedStates = [];
|
|
77
|
-
liftedState.stagedActionIds.forEach((id, idx) => {
|
|
78
|
-
const liftedAction = liftedState.actionsById[id];
|
|
79
|
-
if (!liftedAction)
|
|
80
|
-
return;
|
|
81
|
-
if (idx &&
|
|
82
|
-
isActionFiltered(liftedState.computedStates[idx], liftedAction, predicate, safelist, blocklist)) {
|
|
83
|
-
return;
|
|
84
|
-
}
|
|
85
|
-
filteredActionsById[id] = liftedAction;
|
|
86
|
-
filteredStagedActionIds.push(id);
|
|
87
|
-
filteredComputedStates.push(liftedState.computedStates[idx]);
|
|
88
|
-
});
|
|
89
|
-
return {
|
|
90
|
-
...liftedState,
|
|
91
|
-
stagedActionIds: filteredStagedActionIds,
|
|
92
|
-
actionsById: filteredActionsById,
|
|
93
|
-
computedStates: filteredComputedStates,
|
|
94
|
-
};
|
|
95
|
-
}
|
|
96
|
-
/**
|
|
97
|
-
* Return true is the action should be ignored
|
|
98
|
-
*/
|
|
99
|
-
export function isActionFiltered(state, action, predicate, safelist, blockedlist) {
|
|
100
|
-
const predicateMatch = predicate && !predicate(state, action.action);
|
|
101
|
-
const safelistMatch = safelist &&
|
|
102
|
-
!action.action.type.match(safelist.map((s) => escapeRegExp(s)).join('|'));
|
|
103
|
-
const blocklistMatch = blockedlist &&
|
|
104
|
-
action.action.type.match(blockedlist.map((s) => escapeRegExp(s)).join('|'));
|
|
105
|
-
return predicateMatch || safelistMatch || blocklistMatch;
|
|
106
|
-
}
|
|
107
|
-
/**
|
|
108
|
-
* Return string with escaped RegExp special characters
|
|
109
|
-
* https://stackoverflow.com/a/6969486/1337347
|
|
110
|
-
*/
|
|
111
|
-
function escapeRegExp(s) {
|
|
112
|
-
return s.replace(/[.*+?^${}()|[\]\\]/g, '\\$&');
|
|
113
|
-
}
|
|
114
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../../../modules/store-devtools/src/utils.ts"],"names":[],"mappings":"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","sourcesContent":["import { Action } from '@ngrx/store';\n\nimport * as Actions from './actions';\nimport {\n  ActionSanitizer,\n  StateSanitizer,\n  Predicate,\n  StoreDevtoolsConfig,\n} from './config';\nimport {\n  ComputedState,\n  LiftedAction,\n  LiftedActions,\n  LiftedState,\n} from './reducer';\n\nexport function difference(first: any[], second: any[]) {\n  return first.filter((item) => second.indexOf(item) < 0);\n}\n\n/**\n * Provides an app's view into the state of the lifted store.\n */\nexport function unliftState(liftedState: LiftedState) {\n  const { computedStates, currentStateIndex } = liftedState;\n\n  // At start up NgRx dispatches init actions,\n  // When these init actions are being filtered out by the predicate or safe/block list options\n  // we don't have a complete computed states yet.\n  // At this point it could happen that we're out of bounds, when this happens we fall back to the last known state\n  if (currentStateIndex >= computedStates.length) {\n    const { state } = computedStates[computedStates.length - 1];\n    return state;\n  }\n\n  const { state } = computedStates[currentStateIndex];\n  return state;\n}\n\nexport function unliftAction(liftedState: LiftedState): LiftedAction {\n  return liftedState.actionsById[liftedState.nextActionId - 1];\n}\n\n/**\n * Lifts an app's action into an action on the lifted store.\n */\nexport function liftAction(action: Action) {\n  return new Actions.PerformAction(action, +Date.now());\n}\n\n/**\n * Sanitizes given actions with given function.\n */\nexport function sanitizeActions(\n  actionSanitizer: ActionSanitizer,\n  actions: LiftedActions\n): LiftedActions {\n  return Object.keys(actions).reduce((sanitizedActions, actionIdx) => {\n    const idx = Number(actionIdx);\n    sanitizedActions[idx] = sanitizeAction(actionSanitizer, actions[idx], idx);\n    return sanitizedActions;\n  }, <LiftedActions>{});\n}\n\n/**\n * Sanitizes given action with given function.\n */\nexport function sanitizeAction(\n  actionSanitizer: ActionSanitizer,\n  action: LiftedAction,\n  actionIdx: number\n): LiftedAction {\n  return {\n    ...action,\n    action: actionSanitizer(action.action, actionIdx),\n  };\n}\n\n/**\n * Sanitizes given states with given function.\n */\nexport function sanitizeStates(\n  stateSanitizer: StateSanitizer,\n  states: ComputedState[]\n): ComputedState[] {\n  return states.map((computedState, idx) => ({\n    state: sanitizeState(stateSanitizer, computedState.state, idx),\n    error: computedState.error,\n  }));\n}\n\n/**\n * Sanitizes given state with given function.\n */\nexport function sanitizeState(\n  stateSanitizer: StateSanitizer,\n  state: any,\n  stateIdx: number\n) {\n  return stateSanitizer(state, stateIdx);\n}\n\n/**\n * Read the config and tell if actions should be filtered\n */\nexport function shouldFilterActions(config: StoreDevtoolsConfig) {\n  return config.predicate || config.actionsSafelist || config.actionsBlocklist;\n}\n\n/**\n * Return a full filtered lifted state\n */\nexport function filterLiftedState(\n  liftedState: LiftedState,\n  predicate?: Predicate,\n  safelist?: string[],\n  blocklist?: string[]\n): LiftedState {\n  const filteredStagedActionIds: number[] = [];\n  const filteredActionsById: LiftedActions = {};\n  const filteredComputedStates: ComputedState[] = [];\n  liftedState.stagedActionIds.forEach((id, idx) => {\n    const liftedAction = liftedState.actionsById[id];\n    if (!liftedAction) return;\n    if (\n      idx &&\n      isActionFiltered(\n        liftedState.computedStates[idx],\n        liftedAction,\n        predicate,\n        safelist,\n        blocklist\n      )\n    ) {\n      return;\n    }\n    filteredActionsById[id] = liftedAction;\n    filteredStagedActionIds.push(id);\n    filteredComputedStates.push(liftedState.computedStates[idx]);\n  });\n  return {\n    ...liftedState,\n    stagedActionIds: filteredStagedActionIds,\n    actionsById: filteredActionsById,\n    computedStates: filteredComputedStates,\n  };\n}\n\n/**\n * Return true is the action should be ignored\n */\nexport function isActionFiltered(\n  state: any,\n  action: LiftedAction,\n  predicate?: Predicate,\n  safelist?: string[],\n  blockedlist?: string[]\n) {\n  const predicateMatch = predicate && !predicate(state, action.action);\n  const safelistMatch =\n    safelist &&\n    !action.action.type.match(safelist.map((s) => escapeRegExp(s)).join('|'));\n  const blocklistMatch =\n    blockedlist &&\n    action.action.type.match(blockedlist.map((s) => escapeRegExp(s)).join('|'));\n  return predicateMatch || safelistMatch || blocklistMatch;\n}\n\n/**\n * Return string with escaped RegExp special characters\n * https://stackoverflow.com/a/6969486/1337347\n */\nfunction escapeRegExp(s: string): string {\n  return s.replace(/[.*+?^${}()|[\\]\\\\]/g, '\\\\$&');\n}\n"]}
|
|
@@ -1,6 +0,0 @@
|
|
|
1
|
-
import { NgZone, inject } from '@angular/core';
|
|
2
|
-
export function injectZoneConfig(connectInZone) {
|
|
3
|
-
const ngZone = connectInZone ? inject(NgZone) : null;
|
|
4
|
-
return { ngZone, connectInZone };
|
|
5
|
-
}
|
|
6
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiem9uZS1jb25maWcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9tb2R1bGVzL3N0b3JlLWRldnRvb2xzL3NyYy96b25lLWNvbmZpZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsTUFBTSxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQU0vQyxNQUFNLFVBQVUsZ0JBQWdCLENBQUMsYUFBc0I7SUFDckQsTUFBTSxNQUFNLEdBQUcsYUFBYSxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQztJQUNyRCxPQUFPLEVBQUUsTUFBTSxFQUFFLGFBQWEsRUFBZ0IsQ0FBQztBQUNqRCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdab25lLCBpbmplY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuZXhwb3J0IHR5cGUgWm9uZUNvbmZpZyA9XG4gIHwgeyBjb25uZWN0SW5ab25lOiB0cnVlOyBuZ1pvbmU6IE5nWm9uZSB9XG4gIHwgeyBjb25uZWN0SW5ab25lOiBmYWxzZTsgbmdab25lOiBudWxsIH07XG5cbmV4cG9ydCBmdW5jdGlvbiBpbmplY3Rab25lQ29uZmlnKGNvbm5lY3RJblpvbmU6IGJvb2xlYW4pIHtcbiAgY29uc3Qgbmdab25lID0gY29ubmVjdEluWm9uZSA/IGluamVjdChOZ1pvbmUpIDogbnVsbDtcbiAgcmV0dXJuIHsgbmdab25lLCBjb25uZWN0SW5ab25lIH0gYXMgWm9uZUNvbmZpZztcbn1cbiJdfQ==
|