@ngrx/data 11.0.0-rc.0 → 11.1.1
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/bundles/ngrx-data.umd.js +902 -4475
- package/bundles/ngrx-data.umd.js.map +1 -1
- package/bundles/ngrx-data.umd.min.js +15 -1
- package/bundles/ngrx-data.umd.min.js.map +1 -1
- package/esm2015/index.js +2 -7
- package/esm2015/ngrx-data.js +2 -7
- package/esm2015/public_api.js +2 -7
- package/esm2015/src/actions/entity-action-factory.js +6 -31
- package/esm2015/src/actions/entity-action-guard.js +23 -130
- package/esm2015/src/actions/entity-action-operators.js +11 -64
- package/esm2015/src/actions/entity-action.js +2 -68
- package/esm2015/src/actions/entity-cache-action.js +14 -125
- package/esm2015/src/actions/entity-cache-change-set.js +15 -126
- package/esm2015/src/actions/entity-op.js +70 -89
- package/esm2015/src/actions/merge-strategy.js +8 -16
- package/esm2015/src/actions/update-response-data.js +2 -36
- package/esm2015/src/dataservices/data-service-error.js +1 -34
- package/esm2015/src/dataservices/default-data-service-config.js +1 -41
- package/esm2015/src/dataservices/default-data.service.js +5 -163
- package/esm2015/src/dataservices/entity-cache-data.service.js +17 -103
- package/esm2015/src/dataservices/entity-data.service.js +5 -31
- package/esm2015/src/dataservices/http-url-generator.js +11 -97
- package/esm2015/src/dataservices/interfaces.js +2 -71
- package/esm2015/src/dataservices/persistence-result-handler.service.js +7 -66
- package/esm2015/src/dispatchers/entity-cache-dispatcher.js +40 -97
- package/esm2015/src/dispatchers/entity-commands.js +2 -247
- package/esm2015/src/dispatchers/entity-dispatcher-base.js +65 -287
- package/esm2015/src/dispatchers/entity-dispatcher-default-options.js +6 -48
- package/esm2015/src/dispatchers/entity-dispatcher-factory.js +2 -64
- package/esm2015/src/dispatchers/entity-dispatcher.js +1 -74
- package/esm2015/src/effects/entity-cache-effects.js +21 -135
- package/esm2015/src/effects/entity-effects-scheduler.js +2 -10
- package/esm2015/src/effects/entity-effects.js +18 -128
- package/esm2015/src/entity-data-without-effects.module.js +7 -79
- package/esm2015/src/entity-data.module.js +3 -25
- package/esm2015/src/entity-metadata/entity-definition.js +2 -42
- package/esm2015/src/entity-metadata/entity-definition.service.js +14 -52
- package/esm2015/src/entity-metadata/entity-filters.js +5 -33
- package/esm2015/src/entity-metadata/entity-metadata.js +1 -34
- package/esm2015/src/entity-services/entity-collection-service-base.js +56 -208
- package/esm2015/src/entity-services/entity-collection-service-elements-factory.js +3 -60
- package/esm2015/src/entity-services/entity-collection-service-factory.js +5 -20
- package/esm2015/src/entity-services/entity-collection-service.js +2 -53
- package/esm2015/src/entity-services/entity-services-base.js +18 -78
- package/esm2015/src/entity-services/entity-services-elements.js +9 -44
- package/esm2015/src/entity-services/entity-services.js +1 -70
- package/esm2015/src/index.js +1 -6
- package/esm2015/src/reducers/constants.js +1 -11
- package/esm2015/src/reducers/entity-cache-reducer.js +33 -175
- package/esm2015/src/reducers/entity-cache.js +2 -10
- package/esm2015/src/reducers/entity-change-tracker-base.js +115 -262
- package/esm2015/src/reducers/entity-change-tracker.js +2 -179
- package/esm2015/src/reducers/entity-collection-creator.js +5 -29
- package/esm2015/src/reducers/entity-collection-reducer-methods.js +44 -503
- package/esm2015/src/reducers/entity-collection-reducer-registry.js +8 -50
- package/esm2015/src/reducers/entity-collection-reducer.js +5 -34
- package/esm2015/src/reducers/entity-collection.js +9 -65
- package/esm2015/src/selectors/entity-cache-selector.js +1 -12
- package/esm2015/src/selectors/entity-selectors$.js +11 -137
- package/esm2015/src/selectors/entity-selectors.js +23 -262
- package/esm2015/src/utils/correlation-id-generator.js +4 -30
- package/esm2015/src/utils/default-logger.js +1 -21
- package/esm2015/src/utils/default-pluralizer.js +3 -24
- package/esm2015/src/utils/guid-fns.js +9 -41
- package/esm2015/src/utils/interfaces.js +1 -49
- package/esm2015/src/utils/utilities.js +6 -25
- package/fesm2015/ngrx-data.js +721 -4410
- package/fesm2015/ngrx-data.js.map +1 -1
- package/package.json +5 -5
- package/schematics-core/index.js +4 -1
- package/schematics-core/index.js.map +1 -1
- package/schematics-core/utility/ast-utils.js +127 -1
- package/schematics-core/utility/ast-utils.js.map +1 -1
- package/schematics-core/utility/config.js +1 -1
- package/schematics-core/utility/config.js.map +1 -1
- package/schematics-core/utility/find-component.js +101 -0
- package/schematics-core/utility/find-component.js.map +1 -0
- package/schematics-core/utility/libs-version.js +1 -1
- package/schematics-core/utility/libs-version.js.map +1 -1
- package/schematics-core/utility/project.js +4 -2
- package/schematics-core/utility/project.js.map +1 -1
- package/CHANGELOG.md +0 -3
- package/esm2015/index.ngsummary.json +0 -1
- package/esm2015/ngrx-data.ngsummary.json +0 -1
- package/esm2015/public_api.ngsummary.json +0 -1
- package/esm2015/src/actions/entity-action-factory.ngsummary.json +0 -1
- package/esm2015/src/actions/entity-action-guard.ngsummary.json +0 -1
- package/esm2015/src/actions/entity-action-operators.ngsummary.json +0 -1
- package/esm2015/src/actions/entity-action.ngsummary.json +0 -1
- package/esm2015/src/actions/entity-cache-action.ngsummary.json +0 -1
- package/esm2015/src/actions/entity-cache-change-set.ngsummary.json +0 -1
- package/esm2015/src/actions/entity-op.ngsummary.json +0 -1
- package/esm2015/src/actions/merge-strategy.ngsummary.json +0 -1
- package/esm2015/src/actions/update-response-data.ngsummary.json +0 -1
- package/esm2015/src/dataservices/data-service-error.ngsummary.json +0 -1
- package/esm2015/src/dataservices/default-data-service-config.ngsummary.json +0 -1
- package/esm2015/src/dataservices/default-data.service.ngsummary.json +0 -1
- package/esm2015/src/dataservices/entity-cache-data.service.ngsummary.json +0 -1
- package/esm2015/src/dataservices/entity-data.service.ngsummary.json +0 -1
- package/esm2015/src/dataservices/http-url-generator.ngsummary.json +0 -1
- package/esm2015/src/dataservices/interfaces.ngsummary.json +0 -1
- package/esm2015/src/dataservices/persistence-result-handler.service.ngsummary.json +0 -1
- package/esm2015/src/dispatchers/entity-cache-dispatcher.ngsummary.json +0 -1
- package/esm2015/src/dispatchers/entity-commands.ngsummary.json +0 -1
- package/esm2015/src/dispatchers/entity-dispatcher-base.ngsummary.json +0 -1
- package/esm2015/src/dispatchers/entity-dispatcher-default-options.ngsummary.json +0 -1
- package/esm2015/src/dispatchers/entity-dispatcher-factory.ngsummary.json +0 -1
- package/esm2015/src/dispatchers/entity-dispatcher.ngsummary.json +0 -1
- package/esm2015/src/effects/entity-cache-effects.ngsummary.json +0 -1
- package/esm2015/src/effects/entity-effects-scheduler.ngsummary.json +0 -1
- package/esm2015/src/effects/entity-effects.ngsummary.json +0 -1
- package/esm2015/src/entity-data-without-effects.module.ngfactory.js +0 -36
- package/esm2015/src/entity-data-without-effects.module.ngsummary.json +0 -1
- package/esm2015/src/entity-data.module.ngfactory.js +0 -48
- package/esm2015/src/entity-data.module.ngsummary.json +0 -1
- package/esm2015/src/entity-metadata/entity-definition.ngsummary.json +0 -1
- package/esm2015/src/entity-metadata/entity-definition.service.ngsummary.json +0 -1
- package/esm2015/src/entity-metadata/entity-filters.ngsummary.json +0 -1
- package/esm2015/src/entity-metadata/entity-metadata.ngsummary.json +0 -1
- package/esm2015/src/entity-services/entity-collection-service-base.ngsummary.json +0 -1
- package/esm2015/src/entity-services/entity-collection-service-elements-factory.ngsummary.json +0 -1
- package/esm2015/src/entity-services/entity-collection-service-factory.ngsummary.json +0 -1
- package/esm2015/src/entity-services/entity-collection-service.ngsummary.json +0 -1
- package/esm2015/src/entity-services/entity-services-base.ngsummary.json +0 -1
- package/esm2015/src/entity-services/entity-services-elements.ngsummary.json +0 -1
- package/esm2015/src/entity-services/entity-services.ngsummary.json +0 -1
- package/esm2015/src/index.ngsummary.json +0 -1
- package/esm2015/src/reducers/constants.ngsummary.json +0 -1
- package/esm2015/src/reducers/entity-cache-reducer.ngsummary.json +0 -1
- package/esm2015/src/reducers/entity-cache.ngsummary.json +0 -1
- package/esm2015/src/reducers/entity-change-tracker-base.ngsummary.json +0 -1
- package/esm2015/src/reducers/entity-change-tracker.ngsummary.json +0 -1
- package/esm2015/src/reducers/entity-collection-creator.ngsummary.json +0 -1
- package/esm2015/src/reducers/entity-collection-reducer-methods.ngsummary.json +0 -1
- package/esm2015/src/reducers/entity-collection-reducer-registry.ngsummary.json +0 -1
- package/esm2015/src/reducers/entity-collection-reducer.ngsummary.json +0 -1
- package/esm2015/src/reducers/entity-collection.ngsummary.json +0 -1
- package/esm2015/src/selectors/entity-cache-selector.ngsummary.json +0 -1
- package/esm2015/src/selectors/entity-selectors$.ngsummary.json +0 -1
- package/esm2015/src/selectors/entity-selectors.ngsummary.json +0 -1
- package/esm2015/src/utils/correlation-id-generator.ngsummary.json +0 -1
- package/esm2015/src/utils/default-logger.ngsummary.json +0 -1
- package/esm2015/src/utils/default-pluralizer.ngsummary.json +0 -1
- package/esm2015/src/utils/guid-fns.ngsummary.json +0 -1
- package/esm2015/src/utils/interfaces.ngsummary.json +0 -1
- package/esm2015/src/utils/utilities.ngsummary.json +0 -1
- package/schematics/ng-add/files/entity-metadata.ts.template +0 -10
- package/src/entity-data-without-effects.module.ngfactory.d.ts +0 -3
- package/src/entity-data.module.ngfactory.d.ts +0 -3
|
@@ -1,8 +1,3 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @fileoverview added by tsickle
|
|
3
|
-
* Generated from: src/reducers/entity-change-tracker-base.ts
|
|
4
|
-
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
|
|
5
|
-
*/
|
|
6
1
|
import { ChangeType } from './entity-collection';
|
|
7
2
|
import { defaultSelectId } from '../utils/utilities';
|
|
8
3
|
import { MergeStrategy } from '../actions/merge-strategy';
|
|
@@ -11,13 +6,8 @@ import { MergeStrategy } from '../actions/merge-strategy';
|
|
|
11
6
|
* methods for tracking, committing, and reverting/undoing unsaved entity changes.
|
|
12
7
|
* Used by EntityCollectionReducerMethods which should call tracker methods BEFORE modifying the collection.
|
|
13
8
|
* See EntityChangeTracker docs.
|
|
14
|
-
* @template T
|
|
15
9
|
*/
|
|
16
10
|
export class EntityChangeTrackerBase {
|
|
17
|
-
/**
|
|
18
|
-
* @param {?} adapter
|
|
19
|
-
* @param {?} selectId
|
|
20
|
-
*/
|
|
21
11
|
constructor(adapter, selectId) {
|
|
22
12
|
this.adapter = adapter;
|
|
23
13
|
this.selectId = selectId;
|
|
@@ -28,8 +18,7 @@ export class EntityChangeTrackerBase {
|
|
|
28
18
|
/**
|
|
29
19
|
* Commit all changes as when the collection has been completely reloaded from the server.
|
|
30
20
|
* Harmless when there are no entity changes to commit.
|
|
31
|
-
* @param
|
|
32
|
-
* @return {?}
|
|
21
|
+
* @param collection The entity collection
|
|
33
22
|
*/
|
|
34
23
|
commitAll(collection) {
|
|
35
24
|
return Object.keys(collection.changeState).length === 0
|
|
@@ -39,27 +28,18 @@ export class EntityChangeTrackerBase {
|
|
|
39
28
|
/**
|
|
40
29
|
* Commit changes for the given entities as when they have been refreshed from the server.
|
|
41
30
|
* Harmless when there are no entity changes to commit.
|
|
42
|
-
* @param
|
|
43
|
-
* @param
|
|
44
|
-
* @return {?}
|
|
31
|
+
* @param entityOrIdList The entities to clear tracking or their ids.
|
|
32
|
+
* @param collection The entity collection
|
|
45
33
|
*/
|
|
46
34
|
commitMany(entityOrIdList, collection) {
|
|
47
35
|
if (entityOrIdList == null || entityOrIdList.length === 0) {
|
|
48
36
|
return collection; // nothing to commit
|
|
49
37
|
}
|
|
50
|
-
/** @type {?} */
|
|
51
38
|
let didMutate = false;
|
|
52
|
-
|
|
53
|
-
const changeState = entityOrIdList.reduce((/**
|
|
54
|
-
* @param {?} chgState
|
|
55
|
-
* @param {?} entityOrId
|
|
56
|
-
* @return {?}
|
|
57
|
-
*/
|
|
58
|
-
(chgState, entityOrId) => {
|
|
59
|
-
/** @type {?} */
|
|
39
|
+
const changeState = entityOrIdList.reduce((chgState, entityOrId) => {
|
|
60
40
|
const id = typeof entityOrId === 'object'
|
|
61
41
|
? this.selectId(entityOrId)
|
|
62
|
-
:
|
|
42
|
+
: entityOrId;
|
|
63
43
|
if (chgState[id]) {
|
|
64
44
|
if (!didMutate) {
|
|
65
45
|
chgState = Object.assign({}, chgState);
|
|
@@ -68,15 +48,14 @@ export class EntityChangeTrackerBase {
|
|
|
68
48
|
delete chgState[id];
|
|
69
49
|
}
|
|
70
50
|
return chgState;
|
|
71
|
-
}
|
|
51
|
+
}, collection.changeState);
|
|
72
52
|
return didMutate ? Object.assign(Object.assign({}, collection), { changeState }) : collection;
|
|
73
53
|
}
|
|
74
54
|
/**
|
|
75
55
|
* Commit changes for the given entity as when it have been refreshed from the server.
|
|
76
56
|
* Harmless when no entity changes to commit.
|
|
77
|
-
* @param
|
|
78
|
-
* @param
|
|
79
|
-
* @return {?}
|
|
57
|
+
* @param entityOrId The entity to clear tracking or its id.
|
|
58
|
+
* @param collection The entity collection
|
|
80
59
|
*/
|
|
81
60
|
commitOne(entityOrId, collection) {
|
|
82
61
|
return entityOrId == null
|
|
@@ -87,10 +66,11 @@ export class EntityChangeTrackerBase {
|
|
|
87
66
|
// #region merge query
|
|
88
67
|
/**
|
|
89
68
|
* Merge query results into the collection, adjusting the ChangeState per the mergeStrategy.
|
|
90
|
-
* @param
|
|
91
|
-
* @param
|
|
92
|
-
* @param
|
|
93
|
-
*
|
|
69
|
+
* @param entities Entities returned from querying the server.
|
|
70
|
+
* @param collection The entity collection
|
|
71
|
+
* @param [mergeStrategy] How to merge a queried entity when the corresponding entity in the collection has an unsaved change.
|
|
72
|
+
* Defaults to MergeStrategy.PreserveChanges.
|
|
73
|
+
* @returns The merged EntityCollection.
|
|
94
74
|
*/
|
|
95
75
|
mergeQueryResults(entities, collection, mergeStrategy) {
|
|
96
76
|
return this.mergeServerUpserts(entities, collection, MergeStrategy.PreserveChanges, mergeStrategy);
|
|
@@ -100,10 +80,11 @@ export class EntityChangeTrackerBase {
|
|
|
100
80
|
/**
|
|
101
81
|
* Merge result of saving new entities into the collection, adjusting the ChangeState per the mergeStrategy.
|
|
102
82
|
* The default is MergeStrategy.OverwriteChanges.
|
|
103
|
-
* @param
|
|
104
|
-
* @param
|
|
105
|
-
* @param
|
|
106
|
-
*
|
|
83
|
+
* @param entities Entities returned from saving new entities to the server.
|
|
84
|
+
* @param collection The entity collection
|
|
85
|
+
* @param [mergeStrategy] How to merge a saved entity when the corresponding entity in the collection has an unsaved change.
|
|
86
|
+
* Defaults to MergeStrategy.OverwriteChanges.
|
|
87
|
+
* @returns The merged EntityCollection.
|
|
107
88
|
*/
|
|
108
89
|
mergeSaveAdds(entities, collection, mergeStrategy) {
|
|
109
90
|
return this.mergeServerUpserts(entities, collection, MergeStrategy.OverwriteChanges, mergeStrategy);
|
|
@@ -111,17 +92,17 @@ export class EntityChangeTrackerBase {
|
|
|
111
92
|
/**
|
|
112
93
|
* Merge successful result of deleting entities on the server that have the given primary keys
|
|
113
94
|
* Clears the entity changeState for those keys unless the MergeStrategy is ignoreChanges.
|
|
114
|
-
* @param
|
|
115
|
-
* @param
|
|
116
|
-
* @param
|
|
117
|
-
*
|
|
95
|
+
* @param entities keys primary keys of the entities to remove/delete.
|
|
96
|
+
* @param collection The entity collection
|
|
97
|
+
* @param [mergeStrategy] How to adjust change tracking when the corresponding entity in the collection has an unsaved change.
|
|
98
|
+
* Defaults to MergeStrategy.OverwriteChanges.
|
|
99
|
+
* @returns The merged EntityCollection.
|
|
118
100
|
*/
|
|
119
101
|
mergeSaveDeletes(keys, collection, mergeStrategy) {
|
|
120
102
|
mergeStrategy =
|
|
121
103
|
mergeStrategy == null ? MergeStrategy.OverwriteChanges : mergeStrategy;
|
|
122
104
|
// same logic for all non-ignore merge strategies: always clear (commit) the changes
|
|
123
|
-
|
|
124
|
-
const deleteIds = (/** @type {?} */ (keys));
|
|
105
|
+
const deleteIds = keys; // make TypeScript happy
|
|
125
106
|
collection =
|
|
126
107
|
mergeStrategy === MergeStrategy.IgnoreChanges
|
|
127
108
|
? collection
|
|
@@ -131,38 +112,31 @@ export class EntityChangeTrackerBase {
|
|
|
131
112
|
/**
|
|
132
113
|
* Merge result of saving updated entities into the collection, adjusting the ChangeState per the mergeStrategy.
|
|
133
114
|
* The default is MergeStrategy.OverwriteChanges.
|
|
134
|
-
* @param
|
|
135
|
-
* @param
|
|
136
|
-
* @param
|
|
137
|
-
*
|
|
138
|
-
* @
|
|
115
|
+
* @param updateResponseData Entity response data returned from saving updated entities to the server.
|
|
116
|
+
* @param collection The entity collection
|
|
117
|
+
* @param [mergeStrategy] How to merge a saved entity when the corresponding entity in the collection has an unsaved change.
|
|
118
|
+
* Defaults to MergeStrategy.OverwriteChanges.
|
|
119
|
+
* @param [skipUnchanged] True means skip update if server didn't change it. False by default.
|
|
120
|
+
* If the update was optimistic and the server didn't make more changes of its own
|
|
121
|
+
* then the updates are already in the collection and shouldn't make them again.
|
|
122
|
+
* @returns The merged EntityCollection.
|
|
139
123
|
*/
|
|
140
124
|
mergeSaveUpdates(updateResponseData, collection, mergeStrategy, skipUnchanged = false) {
|
|
141
125
|
if (updateResponseData == null || updateResponseData.length === 0) {
|
|
142
126
|
return collection; // nothing to merge.
|
|
143
127
|
}
|
|
144
|
-
/** @type {?} */
|
|
145
128
|
let didMutate = false;
|
|
146
|
-
/** @type {?} */
|
|
147
129
|
let changeState = collection.changeState;
|
|
148
130
|
mergeStrategy =
|
|
149
131
|
mergeStrategy == null ? MergeStrategy.OverwriteChanges : mergeStrategy;
|
|
150
|
-
/** @type {?} */
|
|
151
132
|
let updates;
|
|
152
133
|
switch (mergeStrategy) {
|
|
153
134
|
case MergeStrategy.IgnoreChanges:
|
|
154
135
|
updates = filterChanged(updateResponseData);
|
|
155
136
|
return this.adapter.updateMany(updates, collection);
|
|
156
137
|
case MergeStrategy.OverwriteChanges:
|
|
157
|
-
changeState = updateResponseData.reduce((
|
|
158
|
-
* @param {?} chgState
|
|
159
|
-
* @param {?} update
|
|
160
|
-
* @return {?}
|
|
161
|
-
*/
|
|
162
|
-
(chgState, update) => {
|
|
163
|
-
/** @type {?} */
|
|
138
|
+
changeState = updateResponseData.reduce((chgState, update) => {
|
|
164
139
|
const oldId = update.id;
|
|
165
|
-
/** @type {?} */
|
|
166
140
|
const change = chgState[oldId];
|
|
167
141
|
if (change) {
|
|
168
142
|
if (!didMutate) {
|
|
@@ -172,22 +146,14 @@ export class EntityChangeTrackerBase {
|
|
|
172
146
|
delete chgState[oldId];
|
|
173
147
|
}
|
|
174
148
|
return chgState;
|
|
175
|
-
}
|
|
149
|
+
}, collection.changeState);
|
|
176
150
|
collection = didMutate ? Object.assign(Object.assign({}, collection), { changeState }) : collection;
|
|
177
151
|
updates = filterChanged(updateResponseData);
|
|
178
152
|
return this.adapter.updateMany(updates, collection);
|
|
179
153
|
case MergeStrategy.PreserveChanges: {
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
changeState = updateResponseData.reduce((/**
|
|
183
|
-
* @param {?} chgState
|
|
184
|
-
* @param {?} update
|
|
185
|
-
* @return {?}
|
|
186
|
-
*/
|
|
187
|
-
(chgState, update) => {
|
|
188
|
-
/** @type {?} */
|
|
154
|
+
const updateableEntities = [];
|
|
155
|
+
changeState = updateResponseData.reduce((chgState, update) => {
|
|
189
156
|
const oldId = update.id;
|
|
190
|
-
/** @type {?} */
|
|
191
157
|
const change = chgState[oldId];
|
|
192
158
|
if (change) {
|
|
193
159
|
// Tracking a change so update original value but not the current value
|
|
@@ -195,24 +161,21 @@ export class EntityChangeTrackerBase {
|
|
|
195
161
|
chgState = Object.assign({}, chgState);
|
|
196
162
|
didMutate = true;
|
|
197
163
|
}
|
|
198
|
-
|
|
199
|
-
const newId = this.selectId((/** @type {?} */ (update.changes)));
|
|
200
|
-
/** @type {?} */
|
|
164
|
+
const newId = this.selectId(update.changes);
|
|
201
165
|
const oldChangeState = change;
|
|
202
166
|
// If the server changed the id, register the new "originalValue" under the new id
|
|
203
167
|
// and remove the change tracked under the old id.
|
|
204
168
|
if (newId !== oldId) {
|
|
205
169
|
delete chgState[oldId];
|
|
206
170
|
}
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
((/** @type {?} */ (chgState)))[newId] = Object.assign(Object.assign({}, oldChangeState), { originalValue: newOrigValue });
|
|
171
|
+
const newOrigValue = Object.assign(Object.assign({}, oldChangeState.originalValue), update.changes);
|
|
172
|
+
chgState[newId] = Object.assign(Object.assign({}, oldChangeState), { originalValue: newOrigValue });
|
|
210
173
|
}
|
|
211
174
|
else {
|
|
212
175
|
updateableEntities.push(update);
|
|
213
176
|
}
|
|
214
177
|
return chgState;
|
|
215
|
-
}
|
|
178
|
+
}, collection.changeState);
|
|
216
179
|
collection = didMutate ? Object.assign(Object.assign({}, collection), { changeState }) : collection;
|
|
217
180
|
updates = filterChanged(updateableEntities);
|
|
218
181
|
return this.adapter.updateMany(updates, collection);
|
|
@@ -222,36 +185,28 @@ export class EntityChangeTrackerBase {
|
|
|
222
185
|
* Conditionally keep only those updates that have additional server changes.
|
|
223
186
|
* (e.g., for optimistic saves because they updates are already in the current collection)
|
|
224
187
|
* Strip off the `changed` property.
|
|
225
|
-
*
|
|
188
|
+
* @responseData Entity response data from server.
|
|
226
189
|
* May be an UpdateResponseData<T>, a subclass of Update<T> with a 'changed' flag.
|
|
227
|
-
* @
|
|
228
|
-
* @return {?} Update<T> (without the changed flag)
|
|
190
|
+
* @returns Update<T> (without the changed flag)
|
|
229
191
|
*/
|
|
230
192
|
function filterChanged(responseData) {
|
|
231
193
|
if (skipUnchanged === true) {
|
|
232
194
|
// keep only those updates that the server changed (knowable if is UpdateResponseData<T>)
|
|
233
|
-
responseData = responseData.filter((
|
|
234
|
-
* @param {?} r
|
|
235
|
-
* @return {?}
|
|
236
|
-
*/
|
|
237
|
-
(r) => r.changed === true));
|
|
195
|
+
responseData = responseData.filter((r) => r.changed === true);
|
|
238
196
|
}
|
|
239
197
|
// Strip unchanged property from responseData, leaving just the pure Update<T>
|
|
240
198
|
// TODO: Remove? probably not necessary as the Update isn't stored and adapter will ignore `changed`.
|
|
241
|
-
return responseData.map((
|
|
242
|
-
* @param {?} r
|
|
243
|
-
* @return {?}
|
|
244
|
-
*/
|
|
245
|
-
(r) => ({ id: (/** @type {?} */ (r.id)), changes: r.changes })));
|
|
199
|
+
return responseData.map((r) => ({ id: r.id, changes: r.changes }));
|
|
246
200
|
}
|
|
247
201
|
}
|
|
248
202
|
/**
|
|
249
203
|
* Merge result of saving upserted entities into the collection, adjusting the ChangeState per the mergeStrategy.
|
|
250
204
|
* The default is MergeStrategy.OverwriteChanges.
|
|
251
|
-
* @param
|
|
252
|
-
* @param
|
|
253
|
-
* @param
|
|
254
|
-
*
|
|
205
|
+
* @param entities Entities returned from saving upserts to the server.
|
|
206
|
+
* @param collection The entity collection
|
|
207
|
+
* @param [mergeStrategy] How to merge a saved entity when the corresponding entity in the collection has an unsaved change.
|
|
208
|
+
* Defaults to MergeStrategy.OverwriteChanges.
|
|
209
|
+
* @returns The merged EntityCollection.
|
|
255
210
|
*/
|
|
256
211
|
mergeSaveUpserts(entities, collection, mergeStrategy) {
|
|
257
212
|
return this.mergeServerUpserts(entities, collection, MergeStrategy.OverwriteChanges, mergeStrategy);
|
|
@@ -260,20 +215,16 @@ export class EntityChangeTrackerBase {
|
|
|
260
215
|
// #region query & save helpers
|
|
261
216
|
/**
|
|
262
217
|
*
|
|
263
|
-
* @
|
|
264
|
-
* @param
|
|
265
|
-
* @param
|
|
266
|
-
* @param
|
|
267
|
-
* @param {?=} mergeStrategy
|
|
268
|
-
* @return {?}
|
|
218
|
+
* @param entities Entities to merge
|
|
219
|
+
* @param collection Collection into which entities are merged
|
|
220
|
+
* @param defaultMergeStrategy How to merge when action's MergeStrategy is unspecified
|
|
221
|
+
* @param [mergeStrategy] The action's MergeStrategy
|
|
269
222
|
*/
|
|
270
223
|
mergeServerUpserts(entities, collection, defaultMergeStrategy, mergeStrategy) {
|
|
271
224
|
if (entities == null || entities.length === 0) {
|
|
272
225
|
return collection; // nothing to merge.
|
|
273
226
|
}
|
|
274
|
-
/** @type {?} */
|
|
275
227
|
let didMutate = false;
|
|
276
|
-
/** @type {?} */
|
|
277
228
|
let changeState = collection.changeState;
|
|
278
229
|
mergeStrategy =
|
|
279
230
|
mergeStrategy == null ? defaultMergeStrategy : mergeStrategy;
|
|
@@ -282,15 +233,8 @@ export class EntityChangeTrackerBase {
|
|
|
282
233
|
return this.adapter.upsertMany(entities, collection);
|
|
283
234
|
case MergeStrategy.OverwriteChanges:
|
|
284
235
|
collection = this.adapter.upsertMany(entities, collection);
|
|
285
|
-
changeState = entities.reduce((
|
|
286
|
-
* @param {?} chgState
|
|
287
|
-
* @param {?} entity
|
|
288
|
-
* @return {?}
|
|
289
|
-
*/
|
|
290
|
-
(chgState, entity) => {
|
|
291
|
-
/** @type {?} */
|
|
236
|
+
changeState = entities.reduce((chgState, entity) => {
|
|
292
237
|
const id = this.selectId(entity);
|
|
293
|
-
/** @type {?} */
|
|
294
238
|
const change = chgState[id];
|
|
295
239
|
if (change) {
|
|
296
240
|
if (!didMutate) {
|
|
@@ -300,24 +244,16 @@ export class EntityChangeTrackerBase {
|
|
|
300
244
|
delete chgState[id];
|
|
301
245
|
}
|
|
302
246
|
return chgState;
|
|
303
|
-
}
|
|
247
|
+
}, collection.changeState);
|
|
304
248
|
return didMutate ? Object.assign(Object.assign({}, collection), { changeState }) : collection;
|
|
305
249
|
case MergeStrategy.PreserveChanges: {
|
|
306
|
-
|
|
307
|
-
|
|
308
|
-
changeState = entities.reduce((/**
|
|
309
|
-
* @param {?} chgState
|
|
310
|
-
* @param {?} entity
|
|
311
|
-
* @return {?}
|
|
312
|
-
*/
|
|
313
|
-
(chgState, entity) => {
|
|
314
|
-
/** @type {?} */
|
|
250
|
+
const upsertEntities = [];
|
|
251
|
+
changeState = entities.reduce((chgState, entity) => {
|
|
315
252
|
const id = this.selectId(entity);
|
|
316
|
-
/** @type {?} */
|
|
317
253
|
const change = chgState[id];
|
|
318
254
|
if (change) {
|
|
319
255
|
if (!didMutate) {
|
|
320
|
-
chgState = Object.assign(Object.assign({}, chgState), { [id]: Object.assign(Object.assign({},
|
|
256
|
+
chgState = Object.assign(Object.assign({}, chgState), { [id]: Object.assign(Object.assign({}, chgState[id]), { originalValue: entity }) });
|
|
321
257
|
didMutate = true;
|
|
322
258
|
}
|
|
323
259
|
}
|
|
@@ -325,7 +261,7 @@ export class EntityChangeTrackerBase {
|
|
|
325
261
|
upsertEntities.push(entity);
|
|
326
262
|
}
|
|
327
263
|
return chgState;
|
|
328
|
-
}
|
|
264
|
+
}, collection.changeState);
|
|
329
265
|
collection = this.adapter.upsertMany(upsertEntities, collection);
|
|
330
266
|
return didMutate ? Object.assign(Object.assign({}, collection), { changeState }) : collection;
|
|
331
267
|
}
|
|
@@ -336,10 +272,9 @@ export class EntityChangeTrackerBase {
|
|
|
336
272
|
/**
|
|
337
273
|
* Track multiple entities before adding them to the collection.
|
|
338
274
|
* Does NOT add to the collection (the reducer's job).
|
|
339
|
-
* @param
|
|
340
|
-
* @param
|
|
341
|
-
* @param
|
|
342
|
-
* @return {?}
|
|
275
|
+
* @param entities The entities to add. They must all have their ids.
|
|
276
|
+
* @param collection The entity collection
|
|
277
|
+
* @param [mergeStrategy] Track by default. Don't track if is MergeStrategy.IgnoreChanges.
|
|
343
278
|
*/
|
|
344
279
|
trackAddMany(entities, collection, mergeStrategy) {
|
|
345
280
|
if (mergeStrategy === MergeStrategy.IgnoreChanges ||
|
|
@@ -347,21 +282,12 @@ export class EntityChangeTrackerBase {
|
|
|
347
282
|
entities.length === 0) {
|
|
348
283
|
return collection; // nothing to track
|
|
349
284
|
}
|
|
350
|
-
/** @type {?} */
|
|
351
285
|
let didMutate = false;
|
|
352
|
-
|
|
353
|
-
const changeState = entities.reduce((/**
|
|
354
|
-
* @param {?} chgState
|
|
355
|
-
* @param {?} entity
|
|
356
|
-
* @return {?}
|
|
357
|
-
*/
|
|
358
|
-
(chgState, entity) => {
|
|
359
|
-
/** @type {?} */
|
|
286
|
+
const changeState = entities.reduce((chgState, entity) => {
|
|
360
287
|
const id = this.selectId(entity);
|
|
361
288
|
if (id == null || id === '') {
|
|
362
289
|
throw new Error(`${collection.entityName} entity add requires a key to be tracked`);
|
|
363
290
|
}
|
|
364
|
-
/** @type {?} */
|
|
365
291
|
const trackedChange = chgState[id];
|
|
366
292
|
if (!trackedChange) {
|
|
367
293
|
if (!didMutate) {
|
|
@@ -371,16 +297,16 @@ export class EntityChangeTrackerBase {
|
|
|
371
297
|
chgState[id] = { changeType: ChangeType.Added };
|
|
372
298
|
}
|
|
373
299
|
return chgState;
|
|
374
|
-
}
|
|
300
|
+
}, collection.changeState);
|
|
375
301
|
return didMutate ? Object.assign(Object.assign({}, collection), { changeState }) : collection;
|
|
376
302
|
}
|
|
377
303
|
/**
|
|
378
304
|
* Track an entity before adding it to the collection.
|
|
379
305
|
* Does NOT add to the collection (the reducer's job).
|
|
380
|
-
* @param
|
|
381
|
-
* @param
|
|
382
|
-
* @param
|
|
383
|
-
*
|
|
306
|
+
* @param entity The entity to add. It must have an id.
|
|
307
|
+
* @param collection The entity collection
|
|
308
|
+
* @param [mergeStrategy] Track by default. Don't track if is MergeStrategy.IgnoreChanges.
|
|
309
|
+
* If not specified, implementation supplies a default strategy.
|
|
384
310
|
*/
|
|
385
311
|
trackAddOne(entity, collection, mergeStrategy) {
|
|
386
312
|
return entity == null
|
|
@@ -390,10 +316,9 @@ export class EntityChangeTrackerBase {
|
|
|
390
316
|
/**
|
|
391
317
|
* Track multiple entities before removing them with the intention of deleting them on the server.
|
|
392
318
|
* Does NOT remove from the collection (the reducer's job).
|
|
393
|
-
* @param
|
|
394
|
-
* @param
|
|
395
|
-
* @param
|
|
396
|
-
* @return {?}
|
|
319
|
+
* @param keys The primary keys of the entities to delete.
|
|
320
|
+
* @param collection The entity collection
|
|
321
|
+
* @param [mergeStrategy] Track by default. Don't track if is MergeStrategy.IgnoreChanges.
|
|
397
322
|
*/
|
|
398
323
|
trackDeleteMany(keys, collection, mergeStrategy) {
|
|
399
324
|
if (mergeStrategy === MergeStrategy.IgnoreChanges ||
|
|
@@ -401,21 +326,11 @@ export class EntityChangeTrackerBase {
|
|
|
401
326
|
keys.length === 0) {
|
|
402
327
|
return collection; // nothing to track
|
|
403
328
|
}
|
|
404
|
-
/** @type {?} */
|
|
405
329
|
let didMutate = false;
|
|
406
|
-
/** @type {?} */
|
|
407
330
|
const entityMap = collection.entities;
|
|
408
|
-
|
|
409
|
-
const changeState = keys.reduce((/**
|
|
410
|
-
* @param {?} chgState
|
|
411
|
-
* @param {?} id
|
|
412
|
-
* @return {?}
|
|
413
|
-
*/
|
|
414
|
-
(chgState, id) => {
|
|
415
|
-
/** @type {?} */
|
|
331
|
+
const changeState = keys.reduce((chgState, id) => {
|
|
416
332
|
const originalValue = entityMap[id];
|
|
417
333
|
if (originalValue) {
|
|
418
|
-
/** @type {?} */
|
|
419
334
|
const trackedChange = chgState[id];
|
|
420
335
|
if (trackedChange) {
|
|
421
336
|
if (trackedChange.changeType === ChangeType.Added) {
|
|
@@ -438,25 +353,21 @@ export class EntityChangeTrackerBase {
|
|
|
438
353
|
}
|
|
439
354
|
}
|
|
440
355
|
return chgState;
|
|
441
|
-
/**
|
|
442
|
-
* @return {?}
|
|
443
|
-
*/
|
|
444
356
|
function cloneChgStateOnce() {
|
|
445
357
|
if (!didMutate) {
|
|
446
358
|
didMutate = true;
|
|
447
359
|
chgState = Object.assign({}, chgState);
|
|
448
360
|
}
|
|
449
361
|
}
|
|
450
|
-
}
|
|
362
|
+
}, collection.changeState);
|
|
451
363
|
return didMutate ? Object.assign(Object.assign({}, collection), { changeState }) : collection;
|
|
452
364
|
}
|
|
453
365
|
/**
|
|
454
366
|
* Track an entity before it is removed with the intention of deleting it on the server.
|
|
455
367
|
* Does NOT remove from the collection (the reducer's job).
|
|
456
|
-
* @param
|
|
457
|
-
* @param
|
|
458
|
-
* @param
|
|
459
|
-
* @return {?}
|
|
368
|
+
* @param key The primary key of the entity to delete.
|
|
369
|
+
* @param collection The entity collection
|
|
370
|
+
* @param [mergeStrategy] Track by default. Don't track if is MergeStrategy.IgnoreChanges.
|
|
460
371
|
*/
|
|
461
372
|
trackDeleteOne(key, collection, mergeStrategy) {
|
|
462
373
|
return key == null
|
|
@@ -466,10 +377,9 @@ export class EntityChangeTrackerBase {
|
|
|
466
377
|
/**
|
|
467
378
|
* Track multiple entities before updating them in the collection.
|
|
468
379
|
* Does NOT update the collection (the reducer's job).
|
|
469
|
-
* @param
|
|
470
|
-
* @param
|
|
471
|
-
* @param
|
|
472
|
-
* @return {?}
|
|
380
|
+
* @param updates The entities to update.
|
|
381
|
+
* @param collection The entity collection
|
|
382
|
+
* @param [mergeStrategy] Track by default. Don't track if is MergeStrategy.IgnoreChanges.
|
|
473
383
|
*/
|
|
474
384
|
trackUpdateMany(updates, collection, mergeStrategy) {
|
|
475
385
|
if (mergeStrategy === MergeStrategy.IgnoreChanges ||
|
|
@@ -477,28 +387,18 @@ export class EntityChangeTrackerBase {
|
|
|
477
387
|
updates.length === 0) {
|
|
478
388
|
return collection; // nothing to track
|
|
479
389
|
}
|
|
480
|
-
/** @type {?} */
|
|
481
390
|
let didMutate = false;
|
|
482
|
-
/** @type {?} */
|
|
483
391
|
const entityMap = collection.entities;
|
|
484
|
-
|
|
485
|
-
const changeState = updates.reduce((/**
|
|
486
|
-
* @param {?} chgState
|
|
487
|
-
* @param {?} update
|
|
488
|
-
* @return {?}
|
|
489
|
-
*/
|
|
490
|
-
(chgState, update) => {
|
|
392
|
+
const changeState = updates.reduce((chgState, update) => {
|
|
491
393
|
const { id, changes: entity } = update;
|
|
492
394
|
if (id == null || id === '') {
|
|
493
395
|
throw new Error(`${collection.entityName} entity update requires a key to be tracked`);
|
|
494
396
|
}
|
|
495
|
-
/** @type {?} */
|
|
496
397
|
const originalValue = entityMap[id];
|
|
497
398
|
// Only track if it is in the collection. Silently ignore if it is not.
|
|
498
399
|
// @ngrx/entity adapter would also silently ignore.
|
|
499
400
|
// Todo: should missing update entity really be reported as an error?
|
|
500
401
|
if (originalValue) {
|
|
501
|
-
/** @type {?} */
|
|
502
402
|
const trackedChange = chgState[id];
|
|
503
403
|
if (!trackedChange) {
|
|
504
404
|
if (!didMutate) {
|
|
@@ -509,16 +409,15 @@ export class EntityChangeTrackerBase {
|
|
|
509
409
|
}
|
|
510
410
|
}
|
|
511
411
|
return chgState;
|
|
512
|
-
}
|
|
412
|
+
}, collection.changeState);
|
|
513
413
|
return didMutate ? Object.assign(Object.assign({}, collection), { changeState }) : collection;
|
|
514
414
|
}
|
|
515
415
|
/**
|
|
516
416
|
* Track an entity before updating it in the collection.
|
|
517
417
|
* Does NOT update the collection (the reducer's job).
|
|
518
|
-
* @param
|
|
519
|
-
* @param
|
|
520
|
-
* @param
|
|
521
|
-
* @return {?}
|
|
418
|
+
* @param update The entity to update.
|
|
419
|
+
* @param collection The entity collection
|
|
420
|
+
* @param [mergeStrategy] Track by default. Don't track if is MergeStrategy.IgnoreChanges.
|
|
522
421
|
*/
|
|
523
422
|
trackUpdateOne(update, collection, mergeStrategy) {
|
|
524
423
|
return update == null
|
|
@@ -528,10 +427,9 @@ export class EntityChangeTrackerBase {
|
|
|
528
427
|
/**
|
|
529
428
|
* Track multiple entities before upserting (adding and updating) them to the collection.
|
|
530
429
|
* Does NOT update the collection (the reducer's job).
|
|
531
|
-
* @param
|
|
532
|
-
* @param
|
|
533
|
-
* @param
|
|
534
|
-
* @return {?}
|
|
430
|
+
* @param entities The entities to add or update. They must be complete entities with ids.
|
|
431
|
+
* @param collection The entity collection
|
|
432
|
+
* @param [mergeStrategy] Track by default. Don't track if is MergeStrategy.IgnoreChanges.
|
|
535
433
|
*/
|
|
536
434
|
trackUpsertMany(entities, collection, mergeStrategy) {
|
|
537
435
|
if (mergeStrategy === MergeStrategy.IgnoreChanges ||
|
|
@@ -539,30 +437,19 @@ export class EntityChangeTrackerBase {
|
|
|
539
437
|
entities.length === 0) {
|
|
540
438
|
return collection; // nothing to track
|
|
541
439
|
}
|
|
542
|
-
/** @type {?} */
|
|
543
440
|
let didMutate = false;
|
|
544
|
-
/** @type {?} */
|
|
545
441
|
const entityMap = collection.entities;
|
|
546
|
-
|
|
547
|
-
const changeState = entities.reduce((/**
|
|
548
|
-
* @param {?} chgState
|
|
549
|
-
* @param {?} entity
|
|
550
|
-
* @return {?}
|
|
551
|
-
*/
|
|
552
|
-
(chgState, entity) => {
|
|
553
|
-
/** @type {?} */
|
|
442
|
+
const changeState = entities.reduce((chgState, entity) => {
|
|
554
443
|
const id = this.selectId(entity);
|
|
555
444
|
if (id == null || id === '') {
|
|
556
445
|
throw new Error(`${collection.entityName} entity upsert requires a key to be tracked`);
|
|
557
446
|
}
|
|
558
|
-
/** @type {?} */
|
|
559
447
|
const trackedChange = chgState[id];
|
|
560
448
|
if (!trackedChange) {
|
|
561
449
|
if (!didMutate) {
|
|
562
450
|
didMutate = true;
|
|
563
451
|
chgState = Object.assign({}, chgState);
|
|
564
452
|
}
|
|
565
|
-
/** @type {?} */
|
|
566
453
|
const originalValue = entityMap[id];
|
|
567
454
|
chgState[id] =
|
|
568
455
|
originalValue == null
|
|
@@ -570,16 +457,15 @@ export class EntityChangeTrackerBase {
|
|
|
570
457
|
: { changeType: ChangeType.Updated, originalValue };
|
|
571
458
|
}
|
|
572
459
|
return chgState;
|
|
573
|
-
}
|
|
460
|
+
}, collection.changeState);
|
|
574
461
|
return didMutate ? Object.assign(Object.assign({}, collection), { changeState }) : collection;
|
|
575
462
|
}
|
|
576
463
|
/**
|
|
577
464
|
* Track an entity before upsert (adding and updating) it to the collection.
|
|
578
465
|
* Does NOT update the collection (the reducer's job).
|
|
579
|
-
* @param
|
|
580
|
-
* @param
|
|
581
|
-
* @param
|
|
582
|
-
* @return {?}
|
|
466
|
+
* @param entities The entity to add or update. It must be a complete entity with its id.
|
|
467
|
+
* @param collection The entity collection
|
|
468
|
+
* @param [mergeStrategy] Track by default. Don't track if is MergeStrategy.IgnoreChanges.
|
|
583
469
|
*/
|
|
584
470
|
trackUpsertOne(entity, collection, mergeStrategy) {
|
|
585
471
|
return entity == null
|
|
@@ -591,74 +477,55 @@ export class EntityChangeTrackerBase {
|
|
|
591
477
|
/**
|
|
592
478
|
* Revert the unsaved changes for all collection.
|
|
593
479
|
* Harmless when there are no entity changes to undo.
|
|
594
|
-
* @param
|
|
595
|
-
* @return {?}
|
|
480
|
+
* @param collection The entity collection
|
|
596
481
|
*/
|
|
597
482
|
undoAll(collection) {
|
|
598
|
-
/** @type {?} */
|
|
599
483
|
const ids = Object.keys(collection.changeState);
|
|
600
|
-
const { remove, upsert } = ids.reduce((
|
|
601
|
-
|
|
602
|
-
* @param {?} id
|
|
603
|
-
* @return {?}
|
|
604
|
-
*/
|
|
605
|
-
(acc, id) => {
|
|
606
|
-
/** @type {?} */
|
|
607
|
-
const changeState = (/** @type {?} */ (acc.chgState[id]));
|
|
484
|
+
const { remove, upsert } = ids.reduce((acc, id) => {
|
|
485
|
+
const changeState = acc.chgState[id];
|
|
608
486
|
switch (changeState.changeType) {
|
|
609
487
|
case ChangeType.Added:
|
|
610
488
|
acc.remove.push(id);
|
|
611
489
|
break;
|
|
612
490
|
case ChangeType.Deleted:
|
|
613
|
-
|
|
614
|
-
const removed = (/** @type {?} */ (changeState)).originalValue;
|
|
491
|
+
const removed = changeState.originalValue;
|
|
615
492
|
if (removed) {
|
|
616
493
|
acc.upsert.push(removed);
|
|
617
494
|
}
|
|
618
495
|
break;
|
|
619
496
|
case ChangeType.Updated:
|
|
620
|
-
acc.upsert.push(
|
|
497
|
+
acc.upsert.push(changeState.originalValue);
|
|
621
498
|
break;
|
|
622
499
|
}
|
|
623
500
|
return acc;
|
|
624
|
-
}
|
|
501
|
+
},
|
|
625
502
|
// entitiesToUndo
|
|
626
503
|
{
|
|
627
|
-
remove:
|
|
628
|
-
upsert:
|
|
504
|
+
remove: [],
|
|
505
|
+
upsert: [],
|
|
629
506
|
chgState: collection.changeState,
|
|
630
507
|
});
|
|
631
|
-
collection = this.adapter.removeMany(
|
|
508
|
+
collection = this.adapter.removeMany(remove, collection);
|
|
632
509
|
collection = this.adapter.upsertMany(upsert, collection);
|
|
633
510
|
return Object.assign(Object.assign({}, collection), { changeState: {} });
|
|
634
511
|
}
|
|
635
512
|
/**
|
|
636
513
|
* Revert the unsaved changes for the given entities.
|
|
637
514
|
* Harmless when there are no entity changes to undo.
|
|
638
|
-
* @param
|
|
639
|
-
* @param
|
|
640
|
-
* @return {?}
|
|
515
|
+
* @param entityOrIdList The entities to revert or their ids.
|
|
516
|
+
* @param collection The entity collection
|
|
641
517
|
*/
|
|
642
518
|
undoMany(entityOrIdList, collection) {
|
|
643
519
|
if (entityOrIdList == null || entityOrIdList.length === 0) {
|
|
644
520
|
return collection; // nothing to undo
|
|
645
521
|
}
|
|
646
|
-
/** @type {?} */
|
|
647
522
|
let didMutate = false;
|
|
648
|
-
const { changeState, remove, upsert } = entityOrIdList.reduce((
|
|
649
|
-
* @param {?} acc
|
|
650
|
-
* @param {?} entityOrId
|
|
651
|
-
* @return {?}
|
|
652
|
-
*/
|
|
653
|
-
(acc, entityOrId) => {
|
|
654
|
-
/** @type {?} */
|
|
523
|
+
const { changeState, remove, upsert } = entityOrIdList.reduce((acc, entityOrId) => {
|
|
655
524
|
let chgState = acc.changeState;
|
|
656
|
-
/** @type {?} */
|
|
657
525
|
const id = typeof entityOrId === 'object'
|
|
658
526
|
? this.selectId(entityOrId)
|
|
659
|
-
:
|
|
660
|
-
|
|
661
|
-
const change = (/** @type {?} */ (chgState[id]));
|
|
527
|
+
: entityOrId;
|
|
528
|
+
const change = chgState[id];
|
|
662
529
|
if (change) {
|
|
663
530
|
if (!didMutate) {
|
|
664
531
|
chgState = Object.assign({}, chgState);
|
|
@@ -671,35 +538,33 @@ export class EntityChangeTrackerBase {
|
|
|
671
538
|
acc.remove.push(id);
|
|
672
539
|
break;
|
|
673
540
|
case ChangeType.Deleted:
|
|
674
|
-
|
|
675
|
-
const removed = (/** @type {?} */ (change)).originalValue;
|
|
541
|
+
const removed = change.originalValue;
|
|
676
542
|
if (removed) {
|
|
677
543
|
acc.upsert.push(removed);
|
|
678
544
|
}
|
|
679
545
|
break;
|
|
680
546
|
case ChangeType.Updated:
|
|
681
|
-
acc.upsert.push(
|
|
547
|
+
acc.upsert.push(change.originalValue);
|
|
682
548
|
break;
|
|
683
549
|
}
|
|
684
550
|
}
|
|
685
551
|
return acc;
|
|
686
|
-
}
|
|
552
|
+
},
|
|
687
553
|
// entitiesToUndo
|
|
688
554
|
{
|
|
689
|
-
remove:
|
|
690
|
-
upsert:
|
|
555
|
+
remove: [],
|
|
556
|
+
upsert: [],
|
|
691
557
|
changeState: collection.changeState,
|
|
692
558
|
});
|
|
693
|
-
collection = this.adapter.removeMany(
|
|
559
|
+
collection = this.adapter.removeMany(remove, collection);
|
|
694
560
|
collection = this.adapter.upsertMany(upsert, collection);
|
|
695
561
|
return didMutate ? Object.assign(Object.assign({}, collection), { changeState }) : collection;
|
|
696
562
|
}
|
|
697
563
|
/**
|
|
698
564
|
* Revert the unsaved changes for the given entity.
|
|
699
565
|
* Harmless when there are no entity changes to undo.
|
|
700
|
-
* @param
|
|
701
|
-
* @param
|
|
702
|
-
* @return {?}
|
|
566
|
+
* @param entityOrId The entity to revert or its id.
|
|
567
|
+
* @param collection The entity collection
|
|
703
568
|
*/
|
|
704
569
|
undoOne(entityOrId, collection) {
|
|
705
570
|
return entityOrId == null
|
|
@@ -707,16 +572,4 @@ export class EntityChangeTrackerBase {
|
|
|
707
572
|
: this.undoMany([entityOrId], collection);
|
|
708
573
|
}
|
|
709
574
|
}
|
|
710
|
-
if (false) {
|
|
711
|
-
/**
|
|
712
|
-
* @type {?}
|
|
713
|
-
* @private
|
|
714
|
-
*/
|
|
715
|
-
EntityChangeTrackerBase.prototype.adapter;
|
|
716
|
-
/**
|
|
717
|
-
* @type {?}
|
|
718
|
-
* @private
|
|
719
|
-
*/
|
|
720
|
-
EntityChangeTrackerBase.prototype.selectId;
|
|
721
|
-
}
|
|
722
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"entity-change-tracker-base.js","sourceRoot":"../../../../modules/data/","sources":["src/reducers/entity-change-tracker-base.ts"],"names":[],"mappings":"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","sourcesContent":["import { EntityAdapter, IdSelector, Update } from '@ngrx/entity';\n\nimport { ChangeType, EntityCollection } from './entity-collection';\nimport { defaultSelectId } from '../utils/utilities';\nimport { EntityChangeTracker } from './entity-change-tracker';\nimport { MergeStrategy } from '../actions/merge-strategy';\nimport { UpdateResponseData } from '../actions/update-response-data';\n\n/**\n * The default implementation of EntityChangeTracker with\n * methods for tracking, committing, and reverting/undoing unsaved entity changes.\n * Used by EntityCollectionReducerMethods which should call tracker methods BEFORE modifying the collection.\n * See EntityChangeTracker docs.\n */\nexport class EntityChangeTrackerBase<T> implements EntityChangeTracker<T> {\n  constructor(\n    private adapter: EntityAdapter<T>,\n    private selectId: IdSelector<T>\n  ) {\n    /** Extract the primary key (id); default to `id` */\n    this.selectId = selectId || defaultSelectId;\n  }\n\n  // #region commit methods\n  /**\n   * Commit all changes as when the collection has been completely reloaded from the server.\n   * Harmless when there are no entity changes to commit.\n   * @param collection The entity collection\n   */\n  commitAll(collection: EntityCollection<T>): EntityCollection<T> {\n    return Object.keys(collection.changeState).length === 0\n      ? collection\n      : { ...collection, changeState: {} };\n  }\n\n  /**\n   * Commit changes for the given entities as when they have been refreshed from the server.\n   * Harmless when there are no entity changes to commit.\n   * @param entityOrIdList The entities to clear tracking or their ids.\n   * @param collection The entity collection\n   */\n  commitMany(\n    entityOrIdList: (number | string | T)[],\n    collection: EntityCollection<T>\n  ): EntityCollection<T> {\n    if (entityOrIdList == null || entityOrIdList.length === 0) {\n      return collection; // nothing to commit\n    }\n    let didMutate = false;\n    const changeState = entityOrIdList.reduce((chgState, entityOrId) => {\n      const id =\n        typeof entityOrId === 'object'\n          ? this.selectId(entityOrId)\n          : (entityOrId as string | number);\n      if (chgState[id]) {\n        if (!didMutate) {\n          chgState = { ...chgState };\n          didMutate = true;\n        }\n        delete chgState[id];\n      }\n      return chgState;\n    }, collection.changeState);\n\n    return didMutate ? { ...collection, changeState } : collection;\n  }\n\n  /**\n   * Commit changes for the given entity as when it have been refreshed from the server.\n   * Harmless when no entity changes to commit.\n   * @param entityOrId The entity to clear tracking or its id.\n   * @param collection The entity collection\n   */\n  commitOne(\n    entityOrId: number | string | T,\n    collection: EntityCollection<T>\n  ): EntityCollection<T> {\n    return entityOrId == null\n      ? collection\n      : this.commitMany([entityOrId], collection);\n  }\n\n  // #endregion commit methods\n\n  // #region merge query\n  /**\n   * Merge query results into the collection, adjusting the ChangeState per the mergeStrategy.\n   * @param entities Entities returned from querying the server.\n   * @param collection The entity collection\n   * @param [mergeStrategy] How to merge a queried entity when the corresponding entity in the collection has an unsaved change.\n   * Defaults to MergeStrategy.PreserveChanges.\n   * @returns The merged EntityCollection.\n   */\n  mergeQueryResults(\n    entities: T[],\n    collection: EntityCollection<T>,\n    mergeStrategy?: MergeStrategy\n  ): EntityCollection<T> {\n    return this.mergeServerUpserts(\n      entities,\n      collection,\n      MergeStrategy.PreserveChanges,\n      mergeStrategy\n    );\n  }\n  // #endregion merge query results\n\n  // #region merge save results\n  /**\n   * Merge result of saving new entities into the collection, adjusting the ChangeState per the mergeStrategy.\n   * The default is MergeStrategy.OverwriteChanges.\n   * @param entities Entities returned from saving new entities to the server.\n   * @param collection The entity collection\n   * @param [mergeStrategy] How to merge a saved entity when the corresponding entity in the collection has an unsaved change.\n   * Defaults to MergeStrategy.OverwriteChanges.\n   * @returns The merged EntityCollection.\n   */\n  mergeSaveAdds(\n    entities: T[],\n    collection: EntityCollection<T>,\n    mergeStrategy?: MergeStrategy\n  ): EntityCollection<T> {\n    return this.mergeServerUpserts(\n      entities,\n      collection,\n      MergeStrategy.OverwriteChanges,\n      mergeStrategy\n    );\n  }\n\n  /**\n   * Merge successful result of deleting entities on the server that have the given primary keys\n   * Clears the entity changeState for those keys unless the MergeStrategy is ignoreChanges.\n   * @param entities keys primary keys of the entities to remove/delete.\n   * @param collection The entity collection\n   * @param [mergeStrategy] How to adjust change tracking when the corresponding entity in the collection has an unsaved change.\n   * Defaults to MergeStrategy.OverwriteChanges.\n   * @returns The merged EntityCollection.\n   */\n  mergeSaveDeletes(\n    keys: (number | string)[],\n    collection: EntityCollection<T>,\n    mergeStrategy?: MergeStrategy\n  ): EntityCollection<T> {\n    mergeStrategy =\n      mergeStrategy == null ? MergeStrategy.OverwriteChanges : mergeStrategy;\n    // same logic for all non-ignore merge strategies: always clear (commit) the changes\n    const deleteIds = keys as string[]; // make TypeScript happy\n    collection =\n      mergeStrategy === MergeStrategy.IgnoreChanges\n        ? collection\n        : this.commitMany(deleteIds, collection);\n    return this.adapter.removeMany(deleteIds, collection);\n  }\n\n  /**\n   * Merge result of saving updated entities into the collection, adjusting the ChangeState per the mergeStrategy.\n   * The default is MergeStrategy.OverwriteChanges.\n   * @param updateResponseData Entity response data returned from saving updated entities to the server.\n   * @param collection The entity collection\n   * @param [mergeStrategy] How to merge a saved entity when the corresponding entity in the collection has an unsaved change.\n   * Defaults to MergeStrategy.OverwriteChanges.\n   * @param [skipUnchanged] True means skip update if server didn't change it. False by default.\n   * If the update was optimistic and the server didn't make more changes of its own\n   * then the updates are already in the collection and shouldn't make them again.\n   * @returns The merged EntityCollection.\n   */\n  mergeSaveUpdates(\n    updateResponseData: UpdateResponseData<T>[],\n    collection: EntityCollection<T>,\n    mergeStrategy?: MergeStrategy,\n    skipUnchanged = false\n  ): EntityCollection<T> {\n    if (updateResponseData == null || updateResponseData.length === 0) {\n      return collection; // nothing to merge.\n    }\n\n    let didMutate = false;\n    let changeState = collection.changeState;\n    mergeStrategy =\n      mergeStrategy == null ? MergeStrategy.OverwriteChanges : mergeStrategy;\n    let updates: Update<T>[];\n\n    switch (mergeStrategy) {\n      case MergeStrategy.IgnoreChanges:\n        updates = filterChanged(updateResponseData);\n        return this.adapter.updateMany(updates, collection);\n\n      case MergeStrategy.OverwriteChanges:\n        changeState = updateResponseData.reduce((chgState, update) => {\n          const oldId = update.id;\n          const change = chgState[oldId];\n          if (change) {\n            if (!didMutate) {\n              chgState = { ...chgState };\n              didMutate = true;\n            }\n            delete chgState[oldId];\n          }\n          return chgState;\n        }, collection.changeState);\n\n        collection = didMutate ? { ...collection, changeState } : collection;\n\n        updates = filterChanged(updateResponseData);\n        return this.adapter.updateMany(updates, collection);\n\n      case MergeStrategy.PreserveChanges: {\n        const updateableEntities = [] as UpdateResponseData<T>[];\n        changeState = updateResponseData.reduce((chgState, update) => {\n          const oldId = update.id;\n          const change = chgState[oldId];\n          if (change) {\n            // Tracking a change so update original value but not the current value\n            if (!didMutate) {\n              chgState = { ...chgState };\n              didMutate = true;\n            }\n            const newId = this.selectId(update.changes as T);\n            const oldChangeState = change;\n            // If the server changed the id, register the new \"originalValue\" under the new id\n            // and remove the change tracked under the old id.\n            if (newId !== oldId) {\n              delete chgState[oldId];\n            }\n            const newOrigValue = {\n              ...(oldChangeState!.originalValue as any),\n              ...(update.changes as any),\n            };\n            (chgState as any)[newId] = {\n              ...oldChangeState,\n              originalValue: newOrigValue,\n            };\n          } else {\n            updateableEntities.push(update);\n          }\n          return chgState;\n        }, collection.changeState);\n        collection = didMutate ? { ...collection, changeState } : collection;\n\n        updates = filterChanged(updateableEntities);\n        return this.adapter.updateMany(updates, collection);\n      }\n    }\n\n    /**\n     * Conditionally keep only those updates that have additional server changes.\n     * (e.g., for optimistic saves because they updates are already in the current collection)\n     * Strip off the `changed` property.\n     * @responseData Entity response data from server.\n     * May be an UpdateResponseData<T>, a subclass of Update<T> with a 'changed' flag.\n     * @returns Update<T> (without the changed flag)\n     */\n    function filterChanged(responseData: UpdateResponseData<T>[]): Update<T>[] {\n      if (skipUnchanged === true) {\n        // keep only those updates that the server changed (knowable if is UpdateResponseData<T>)\n        responseData = responseData.filter((r) => r.changed === true);\n      }\n      // Strip unchanged property from responseData, leaving just the pure Update<T>\n      // TODO: Remove? probably not necessary as the Update isn't stored and adapter will ignore `changed`.\n      return responseData.map((r) => ({ id: r.id as any, changes: r.changes }));\n    }\n  }\n\n  /**\n   * Merge result of saving upserted entities into the collection, adjusting the ChangeState per the mergeStrategy.\n   * The default is MergeStrategy.OverwriteChanges.\n   * @param entities Entities returned from saving upserts to the server.\n   * @param collection The entity collection\n   * @param [mergeStrategy] How to merge a saved entity when the corresponding entity in the collection has an unsaved change.\n   * Defaults to MergeStrategy.OverwriteChanges.\n   * @returns The merged EntityCollection.\n   */\n  mergeSaveUpserts(\n    entities: T[],\n    collection: EntityCollection<T>,\n    mergeStrategy?: MergeStrategy\n  ): EntityCollection<T> {\n    return this.mergeServerUpserts(\n      entities,\n      collection,\n      MergeStrategy.OverwriteChanges,\n      mergeStrategy\n    );\n  }\n  // #endregion merge save results\n\n  // #region query & save helpers\n  /**\n   *\n   * @param entities Entities to merge\n   * @param collection Collection into which entities are merged\n   * @param defaultMergeStrategy How to merge when action's MergeStrategy is unspecified\n   * @param [mergeStrategy] The action's MergeStrategy\n   */\n  private mergeServerUpserts(\n    entities: T[],\n    collection: EntityCollection<T>,\n    defaultMergeStrategy: MergeStrategy,\n    mergeStrategy?: MergeStrategy\n  ): EntityCollection<T> {\n    if (entities == null || entities.length === 0) {\n      return collection; // nothing to merge.\n    }\n\n    let didMutate = false;\n    let changeState = collection.changeState;\n    mergeStrategy =\n      mergeStrategy == null ? defaultMergeStrategy : mergeStrategy;\n\n    switch (mergeStrategy) {\n      case MergeStrategy.IgnoreChanges:\n        return this.adapter.upsertMany(entities, collection);\n\n      case MergeStrategy.OverwriteChanges:\n        collection = this.adapter.upsertMany(entities, collection);\n\n        changeState = entities.reduce((chgState, entity) => {\n          const id = this.selectId(entity);\n          const change = chgState[id];\n          if (change) {\n            if (!didMutate) {\n              chgState = { ...chgState };\n              didMutate = true;\n            }\n            delete chgState[id];\n          }\n          return chgState;\n        }, collection.changeState);\n\n        return didMutate ? { ...collection, changeState } : collection;\n\n      case MergeStrategy.PreserveChanges: {\n        const upsertEntities = [] as T[];\n        changeState = entities.reduce((chgState, entity) => {\n          const id = this.selectId(entity);\n          const change = chgState[id];\n          if (change) {\n            if (!didMutate) {\n              chgState = {\n                ...chgState,\n                [id]: {\n                  ...chgState[id]!,\n                  originalValue: entity,\n                },\n              };\n              didMutate = true;\n            }\n          } else {\n            upsertEntities.push(entity);\n          }\n          return chgState;\n        }, collection.changeState);\n\n        collection = this.adapter.upsertMany(upsertEntities, collection);\n        return didMutate ? { ...collection, changeState } : collection;\n      }\n    }\n  }\n  // #endregion query & save helpers\n\n  // #region track methods\n  /**\n   * Track multiple entities before adding them to the collection.\n   * Does NOT add to the collection (the reducer's job).\n   * @param entities The entities to add. They must all have their ids.\n   * @param collection The entity collection\n   * @param [mergeStrategy] Track by default. Don't track if is MergeStrategy.IgnoreChanges.\n   */\n  trackAddMany(\n    entities: T[],\n    collection: EntityCollection<T>,\n    mergeStrategy?: MergeStrategy\n  ): EntityCollection<T> {\n    if (\n      mergeStrategy === MergeStrategy.IgnoreChanges ||\n      entities == null ||\n      entities.length === 0\n    ) {\n      return collection; // nothing to track\n    }\n    let didMutate = false;\n    const changeState = entities.reduce((chgState, entity) => {\n      const id = this.selectId(entity);\n      if (id == null || id === '') {\n        throw new Error(\n          `${collection.entityName} entity add requires a key to be tracked`\n        );\n      }\n      const trackedChange = chgState[id];\n\n      if (!trackedChange) {\n        if (!didMutate) {\n          didMutate = true;\n          chgState = { ...chgState };\n        }\n        chgState[id] = { changeType: ChangeType.Added };\n      }\n      return chgState;\n    }, collection.changeState);\n    return didMutate ? { ...collection, changeState } : collection;\n  }\n\n  /**\n   * Track an entity before adding it to the collection.\n   * Does NOT add to the collection (the reducer's job).\n   * @param entity The entity to add. It must have an id.\n   * @param collection The entity collection\n   * @param [mergeStrategy] Track by default. Don't track if is MergeStrategy.IgnoreChanges.\n   * If not specified, implementation supplies a default strategy.\n   */\n  trackAddOne(\n    entity: T,\n    collection: EntityCollection<T>,\n    mergeStrategy?: MergeStrategy\n  ): EntityCollection<T> {\n    return entity == null\n      ? collection\n      : this.trackAddMany([entity], collection, mergeStrategy);\n  }\n\n  /**\n   * Track multiple entities before removing them with the intention of deleting them on the server.\n   * Does NOT remove from the collection (the reducer's job).\n   * @param keys The primary keys of the entities to delete.\n   * @param collection The entity collection\n   * @param [mergeStrategy] Track by default. Don't track if is MergeStrategy.IgnoreChanges.\n   */\n  trackDeleteMany(\n    keys: (number | string)[],\n    collection: EntityCollection<T>,\n    mergeStrategy?: MergeStrategy\n  ): EntityCollection<T> {\n    if (\n      mergeStrategy === MergeStrategy.IgnoreChanges ||\n      keys == null ||\n      keys.length === 0\n    ) {\n      return collection; // nothing to track\n    }\n    let didMutate = false;\n    const entityMap = collection.entities;\n    const changeState = keys.reduce((chgState, id) => {\n      const originalValue = entityMap[id];\n      if (originalValue) {\n        const trackedChange = chgState[id];\n        if (trackedChange) {\n          if (trackedChange.changeType === ChangeType.Added) {\n            // Special case: stop tracking an added entity that you delete\n            // The caller must also detect this, remove it immediately from the collection\n            // and skip attempt to delete on the server.\n            cloneChgStateOnce();\n            delete chgState[id];\n          } else if (trackedChange.changeType === ChangeType.Updated) {\n            // Special case: switch change type from Updated to Deleted.\n            cloneChgStateOnce();\n            trackedChange.changeType = ChangeType.Deleted;\n          }\n        } else {\n          // Start tracking this entity\n          cloneChgStateOnce();\n          chgState[id] = { changeType: ChangeType.Deleted, originalValue };\n        }\n      }\n      return chgState;\n\n      function cloneChgStateOnce() {\n        if (!didMutate) {\n          didMutate = true;\n          chgState = { ...chgState };\n        }\n      }\n    }, collection.changeState);\n\n    return didMutate ? { ...collection, changeState } : collection;\n  }\n\n  /**\n   * Track an entity before it is removed with the intention of deleting it on the server.\n   * Does NOT remove from the collection (the reducer's job).\n   * @param key The primary key of the entity to delete.\n   * @param collection The entity collection\n   * @param [mergeStrategy] Track by default. Don't track if is MergeStrategy.IgnoreChanges.\n   */\n  trackDeleteOne(\n    key: number | string,\n    collection: EntityCollection<T>,\n    mergeStrategy?: MergeStrategy\n  ): EntityCollection<T> {\n    return key == null\n      ? collection\n      : this.trackDeleteMany([key], collection, mergeStrategy);\n  }\n\n  /**\n   * Track multiple entities before updating them in the collection.\n   * Does NOT update the collection (the reducer's job).\n   * @param updates The entities to update.\n   * @param collection The entity collection\n   * @param [mergeStrategy] Track by default. Don't track if is MergeStrategy.IgnoreChanges.\n   */\n  trackUpdateMany(\n    updates: Update<T>[],\n    collection: EntityCollection<T>,\n    mergeStrategy?: MergeStrategy\n  ): EntityCollection<T> {\n    if (\n      mergeStrategy === MergeStrategy.IgnoreChanges ||\n      updates == null ||\n      updates.length === 0\n    ) {\n      return collection; // nothing to track\n    }\n    let didMutate = false;\n    const entityMap = collection.entities;\n    const changeState = updates.reduce((chgState, update) => {\n      const { id, changes: entity } = update;\n      if (id == null || id === '') {\n        throw new Error(\n          `${collection.entityName} entity update requires a key to be tracked`\n        );\n      }\n      const originalValue = entityMap[id];\n      // Only track if it is in the collection. Silently ignore if it is not.\n      // @ngrx/entity adapter would also silently ignore.\n      // Todo: should missing update entity really be reported as an error?\n      if (originalValue) {\n        const trackedChange = chgState[id];\n        if (!trackedChange) {\n          if (!didMutate) {\n            didMutate = true;\n            chgState = { ...chgState };\n          }\n          chgState[id] = { changeType: ChangeType.Updated, originalValue };\n        }\n      }\n      return chgState;\n    }, collection.changeState);\n    return didMutate ? { ...collection, changeState } : collection;\n  }\n\n  /**\n   * Track an entity before updating it in the collection.\n   * Does NOT update the collection (the reducer's job).\n   * @param update The entity to update.\n   * @param collection The entity collection\n   * @param [mergeStrategy] Track by default. Don't track if is MergeStrategy.IgnoreChanges.\n   */\n  trackUpdateOne(\n    update: Update<T>,\n    collection: EntityCollection<T>,\n    mergeStrategy?: MergeStrategy\n  ): EntityCollection<T> {\n    return update == null\n      ? collection\n      : this.trackUpdateMany([update], collection, mergeStrategy);\n  }\n\n  /**\n   * Track multiple entities before upserting (adding and updating) them to the collection.\n   * Does NOT update the collection (the reducer's job).\n   * @param entities The entities to add or update. They must be complete entities with ids.\n   * @param collection The entity collection\n   * @param [mergeStrategy] Track by default. Don't track if is MergeStrategy.IgnoreChanges.\n   */\n  trackUpsertMany(\n    entities: T[],\n    collection: EntityCollection<T>,\n    mergeStrategy?: MergeStrategy\n  ): EntityCollection<T> {\n    if (\n      mergeStrategy === MergeStrategy.IgnoreChanges ||\n      entities == null ||\n      entities.length === 0\n    ) {\n      return collection; // nothing to track\n    }\n    let didMutate = false;\n    const entityMap = collection.entities;\n    const changeState = entities.reduce((chgState, entity) => {\n      const id = this.selectId(entity);\n      if (id == null || id === '') {\n        throw new Error(\n          `${collection.entityName} entity upsert requires a key to be tracked`\n        );\n      }\n      const trackedChange = chgState[id];\n\n      if (!trackedChange) {\n        if (!didMutate) {\n          didMutate = true;\n          chgState = { ...chgState };\n        }\n\n        const originalValue = entityMap[id];\n        chgState[id] =\n          originalValue == null\n            ? { changeType: ChangeType.Added }\n            : { changeType: ChangeType.Updated, originalValue };\n      }\n      return chgState;\n    }, collection.changeState);\n    return didMutate ? { ...collection, changeState } : collection;\n  }\n\n  /**\n   * Track an entity before upsert (adding and updating) it to the collection.\n   * Does NOT update the collection (the reducer's job).\n   * @param entities The entity to add or update. It must be a complete entity with its id.\n   * @param collection The entity collection\n   * @param [mergeStrategy] Track by default. Don't track if is MergeStrategy.IgnoreChanges.\n   */\n  trackUpsertOne(\n    entity: T,\n    collection: EntityCollection<T>,\n    mergeStrategy?: MergeStrategy\n  ): EntityCollection<T> {\n    return entity == null\n      ? collection\n      : this.trackUpsertMany([entity], collection, mergeStrategy);\n  }\n  // #endregion track methods\n\n  // #region undo methods\n  /**\n   * Revert the unsaved changes for all collection.\n   * Harmless when there are no entity changes to undo.\n   * @param collection The entity collection\n   */\n  undoAll(collection: EntityCollection<T>): EntityCollection<T> {\n    const ids = Object.keys(collection.changeState);\n\n    const { remove, upsert } = ids.reduce(\n      (acc, id) => {\n        const changeState = acc.chgState[id]!;\n        switch (changeState.changeType) {\n          case ChangeType.Added:\n            acc.remove.push(id);\n            break;\n          case ChangeType.Deleted:\n            const removed = changeState!.originalValue;\n            if (removed) {\n              acc.upsert.push(removed);\n            }\n            break;\n          case ChangeType.Updated:\n            acc.upsert.push(changeState!.originalValue!);\n            break;\n        }\n        return acc;\n      },\n      // entitiesToUndo\n      {\n        remove: [] as (number | string)[],\n        upsert: [] as T[],\n        chgState: collection.changeState,\n      }\n    );\n\n    collection = this.adapter.removeMany(remove as string[], collection);\n    collection = this.adapter.upsertMany(upsert, collection);\n\n    return { ...collection, changeState: {} };\n  }\n\n  /**\n   * Revert the unsaved changes for the given entities.\n   * Harmless when there are no entity changes to undo.\n   * @param entityOrIdList The entities to revert or their ids.\n   * @param collection The entity collection\n   */\n  undoMany(\n    entityOrIdList: (number | string | T)[],\n    collection: EntityCollection<T>\n  ): EntityCollection<T> {\n    if (entityOrIdList == null || entityOrIdList.length === 0) {\n      return collection; // nothing to undo\n    }\n    let didMutate = false;\n\n    const { changeState, remove, upsert } = entityOrIdList.reduce(\n      (acc, entityOrId) => {\n        let chgState = acc.changeState;\n        const id =\n          typeof entityOrId === 'object'\n            ? this.selectId(entityOrId)\n            : (entityOrId as string | number);\n        const change = chgState[id]!;\n        if (change) {\n          if (!didMutate) {\n            chgState = { ...chgState };\n            didMutate = true;\n          }\n          delete chgState[id]; // clear tracking of this entity\n          acc.changeState = chgState;\n          switch (change.changeType) {\n            case ChangeType.Added:\n              acc.remove.push(id);\n              break;\n            case ChangeType.Deleted:\n              const removed = change!.originalValue;\n              if (removed) {\n                acc.upsert.push(removed);\n              }\n              break;\n            case ChangeType.Updated:\n              acc.upsert.push(change!.originalValue!);\n              break;\n          }\n        }\n        return acc;\n      },\n      // entitiesToUndo\n      {\n        remove: [] as (number | string)[],\n        upsert: [] as T[],\n        changeState: collection.changeState,\n      }\n    );\n\n    collection = this.adapter.removeMany(remove as string[], collection);\n    collection = this.adapter.upsertMany(upsert, collection);\n    return didMutate ? { ...collection, changeState } : collection;\n  }\n\n  /**\n   * Revert the unsaved changes for the given entity.\n   * Harmless when there are no entity changes to undo.\n   * @param entityOrId The entity to revert or its id.\n   * @param collection The entity collection\n   */\n  undoOne(\n    entityOrId: number | string | T,\n    collection: EntityCollection<T>\n  ): EntityCollection<T> {\n    return entityOrId == null\n      ? collection\n      : this.undoMany([entityOrId], collection);\n  }\n  // #endregion undo methods\n}\n"]}
|
|
575
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"entity-change-tracker-base.js","sourceRoot":"","sources":["../../../../../../modules/data/src/reducers/entity-change-tracker-base.ts"],"names":[],"mappings":"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","sourcesContent":["import { EntityAdapter, IdSelector, Update } from '@ngrx/entity';\n\nimport { ChangeType, EntityCollection } from './entity-collection';\nimport { defaultSelectId } from '../utils/utilities';\nimport { EntityChangeTracker } from './entity-change-tracker';\nimport { MergeStrategy } from '../actions/merge-strategy';\nimport { UpdateResponseData } from '../actions/update-response-data';\n\n/**\n * The default implementation of EntityChangeTracker with\n * methods for tracking, committing, and reverting/undoing unsaved entity changes.\n * Used by EntityCollectionReducerMethods which should call tracker methods BEFORE modifying the collection.\n * See EntityChangeTracker docs.\n */\nexport class EntityChangeTrackerBase<T> implements EntityChangeTracker<T> {\n  constructor(\n    private adapter: EntityAdapter<T>,\n    private selectId: IdSelector<T>\n  ) {\n    /** Extract the primary key (id); default to `id` */\n    this.selectId = selectId || defaultSelectId;\n  }\n\n  // #region commit methods\n  /**\n   * Commit all changes as when the collection has been completely reloaded from the server.\n   * Harmless when there are no entity changes to commit.\n   * @param collection The entity collection\n   */\n  commitAll(collection: EntityCollection<T>): EntityCollection<T> {\n    return Object.keys(collection.changeState).length === 0\n      ? collection\n      : { ...collection, changeState: {} };\n  }\n\n  /**\n   * Commit changes for the given entities as when they have been refreshed from the server.\n   * Harmless when there are no entity changes to commit.\n   * @param entityOrIdList The entities to clear tracking or their ids.\n   * @param collection The entity collection\n   */\n  commitMany(\n    entityOrIdList: (number | string | T)[],\n    collection: EntityCollection<T>\n  ): EntityCollection<T> {\n    if (entityOrIdList == null || entityOrIdList.length === 0) {\n      return collection; // nothing to commit\n    }\n    let didMutate = false;\n    const changeState = entityOrIdList.reduce((chgState, entityOrId) => {\n      const id =\n        typeof entityOrId === 'object'\n          ? this.selectId(entityOrId)\n          : (entityOrId as string | number);\n      if (chgState[id]) {\n        if (!didMutate) {\n          chgState = { ...chgState };\n          didMutate = true;\n        }\n        delete chgState[id];\n      }\n      return chgState;\n    }, collection.changeState);\n\n    return didMutate ? { ...collection, changeState } : collection;\n  }\n\n  /**\n   * Commit changes for the given entity as when it have been refreshed from the server.\n   * Harmless when no entity changes to commit.\n   * @param entityOrId The entity to clear tracking or its id.\n   * @param collection The entity collection\n   */\n  commitOne(\n    entityOrId: number | string | T,\n    collection: EntityCollection<T>\n  ): EntityCollection<T> {\n    return entityOrId == null\n      ? collection\n      : this.commitMany([entityOrId], collection);\n  }\n\n  // #endregion commit methods\n\n  // #region merge query\n  /**\n   * Merge query results into the collection, adjusting the ChangeState per the mergeStrategy.\n   * @param entities Entities returned from querying the server.\n   * @param collection The entity collection\n   * @param [mergeStrategy] How to merge a queried entity when the corresponding entity in the collection has an unsaved change.\n   * Defaults to MergeStrategy.PreserveChanges.\n   * @returns The merged EntityCollection.\n   */\n  mergeQueryResults(\n    entities: T[],\n    collection: EntityCollection<T>,\n    mergeStrategy?: MergeStrategy\n  ): EntityCollection<T> {\n    return this.mergeServerUpserts(\n      entities,\n      collection,\n      MergeStrategy.PreserveChanges,\n      mergeStrategy\n    );\n  }\n  // #endregion merge query results\n\n  // #region merge save results\n  /**\n   * Merge result of saving new entities into the collection, adjusting the ChangeState per the mergeStrategy.\n   * The default is MergeStrategy.OverwriteChanges.\n   * @param entities Entities returned from saving new entities to the server.\n   * @param collection The entity collection\n   * @param [mergeStrategy] How to merge a saved entity when the corresponding entity in the collection has an unsaved change.\n   * Defaults to MergeStrategy.OverwriteChanges.\n   * @returns The merged EntityCollection.\n   */\n  mergeSaveAdds(\n    entities: T[],\n    collection: EntityCollection<T>,\n    mergeStrategy?: MergeStrategy\n  ): EntityCollection<T> {\n    return this.mergeServerUpserts(\n      entities,\n      collection,\n      MergeStrategy.OverwriteChanges,\n      mergeStrategy\n    );\n  }\n\n  /**\n   * Merge successful result of deleting entities on the server that have the given primary keys\n   * Clears the entity changeState for those keys unless the MergeStrategy is ignoreChanges.\n   * @param entities keys primary keys of the entities to remove/delete.\n   * @param collection The entity collection\n   * @param [mergeStrategy] How to adjust change tracking when the corresponding entity in the collection has an unsaved change.\n   * Defaults to MergeStrategy.OverwriteChanges.\n   * @returns The merged EntityCollection.\n   */\n  mergeSaveDeletes(\n    keys: (number | string)[],\n    collection: EntityCollection<T>,\n    mergeStrategy?: MergeStrategy\n  ): EntityCollection<T> {\n    mergeStrategy =\n      mergeStrategy == null ? MergeStrategy.OverwriteChanges : mergeStrategy;\n    // same logic for all non-ignore merge strategies: always clear (commit) the changes\n    const deleteIds = keys as string[]; // make TypeScript happy\n    collection =\n      mergeStrategy === MergeStrategy.IgnoreChanges\n        ? collection\n        : this.commitMany(deleteIds, collection);\n    return this.adapter.removeMany(deleteIds, collection);\n  }\n\n  /**\n   * Merge result of saving updated entities into the collection, adjusting the ChangeState per the mergeStrategy.\n   * The default is MergeStrategy.OverwriteChanges.\n   * @param updateResponseData Entity response data returned from saving updated entities to the server.\n   * @param collection The entity collection\n   * @param [mergeStrategy] How to merge a saved entity when the corresponding entity in the collection has an unsaved change.\n   * Defaults to MergeStrategy.OverwriteChanges.\n   * @param [skipUnchanged] True means skip update if server didn't change it. False by default.\n   * If the update was optimistic and the server didn't make more changes of its own\n   * then the updates are already in the collection and shouldn't make them again.\n   * @returns The merged EntityCollection.\n   */\n  mergeSaveUpdates(\n    updateResponseData: UpdateResponseData<T>[],\n    collection: EntityCollection<T>,\n    mergeStrategy?: MergeStrategy,\n    skipUnchanged = false\n  ): EntityCollection<T> {\n    if (updateResponseData == null || updateResponseData.length === 0) {\n      return collection; // nothing to merge.\n    }\n\n    let didMutate = false;\n    let changeState = collection.changeState;\n    mergeStrategy =\n      mergeStrategy == null ? MergeStrategy.OverwriteChanges : mergeStrategy;\n    let updates: Update<T>[];\n\n    switch (mergeStrategy) {\n      case MergeStrategy.IgnoreChanges:\n        updates = filterChanged(updateResponseData);\n        return this.adapter.updateMany(updates, collection);\n\n      case MergeStrategy.OverwriteChanges:\n        changeState = updateResponseData.reduce((chgState, update) => {\n          const oldId = update.id;\n          const change = chgState[oldId];\n          if (change) {\n            if (!didMutate) {\n              chgState = { ...chgState };\n              didMutate = true;\n            }\n            delete chgState[oldId];\n          }\n          return chgState;\n        }, collection.changeState);\n\n        collection = didMutate ? { ...collection, changeState } : collection;\n\n        updates = filterChanged(updateResponseData);\n        return this.adapter.updateMany(updates, collection);\n\n      case MergeStrategy.PreserveChanges: {\n        const updateableEntities = [] as UpdateResponseData<T>[];\n        changeState = updateResponseData.reduce((chgState, update) => {\n          const oldId = update.id;\n          const change = chgState[oldId];\n          if (change) {\n            // Tracking a change so update original value but not the current value\n            if (!didMutate) {\n              chgState = { ...chgState };\n              didMutate = true;\n            }\n            const newId = this.selectId(update.changes as T);\n            const oldChangeState = change;\n            // If the server changed the id, register the new \"originalValue\" under the new id\n            // and remove the change tracked under the old id.\n            if (newId !== oldId) {\n              delete chgState[oldId];\n            }\n            const newOrigValue = {\n              ...(oldChangeState!.originalValue as any),\n              ...(update.changes as any),\n            };\n            (chgState as any)[newId] = {\n              ...oldChangeState,\n              originalValue: newOrigValue,\n            };\n          } else {\n            updateableEntities.push(update);\n          }\n          return chgState;\n        }, collection.changeState);\n        collection = didMutate ? { ...collection, changeState } : collection;\n\n        updates = filterChanged(updateableEntities);\n        return this.adapter.updateMany(updates, collection);\n      }\n    }\n\n    /**\n     * Conditionally keep only those updates that have additional server changes.\n     * (e.g., for optimistic saves because they updates are already in the current collection)\n     * Strip off the `changed` property.\n     * @responseData Entity response data from server.\n     * May be an UpdateResponseData<T>, a subclass of Update<T> with a 'changed' flag.\n     * @returns Update<T> (without the changed flag)\n     */\n    function filterChanged(responseData: UpdateResponseData<T>[]): Update<T>[] {\n      if (skipUnchanged === true) {\n        // keep only those updates that the server changed (knowable if is UpdateResponseData<T>)\n        responseData = responseData.filter((r) => r.changed === true);\n      }\n      // Strip unchanged property from responseData, leaving just the pure Update<T>\n      // TODO: Remove? probably not necessary as the Update isn't stored and adapter will ignore `changed`.\n      return responseData.map((r) => ({ id: r.id as any, changes: r.changes }));\n    }\n  }\n\n  /**\n   * Merge result of saving upserted entities into the collection, adjusting the ChangeState per the mergeStrategy.\n   * The default is MergeStrategy.OverwriteChanges.\n   * @param entities Entities returned from saving upserts to the server.\n   * @param collection The entity collection\n   * @param [mergeStrategy] How to merge a saved entity when the corresponding entity in the collection has an unsaved change.\n   * Defaults to MergeStrategy.OverwriteChanges.\n   * @returns The merged EntityCollection.\n   */\n  mergeSaveUpserts(\n    entities: T[],\n    collection: EntityCollection<T>,\n    mergeStrategy?: MergeStrategy\n  ): EntityCollection<T> {\n    return this.mergeServerUpserts(\n      entities,\n      collection,\n      MergeStrategy.OverwriteChanges,\n      mergeStrategy\n    );\n  }\n  // #endregion merge save results\n\n  // #region query & save helpers\n  /**\n   *\n   * @param entities Entities to merge\n   * @param collection Collection into which entities are merged\n   * @param defaultMergeStrategy How to merge when action's MergeStrategy is unspecified\n   * @param [mergeStrategy] The action's MergeStrategy\n   */\n  private mergeServerUpserts(\n    entities: T[],\n    collection: EntityCollection<T>,\n    defaultMergeStrategy: MergeStrategy,\n    mergeStrategy?: MergeStrategy\n  ): EntityCollection<T> {\n    if (entities == null || entities.length === 0) {\n      return collection; // nothing to merge.\n    }\n\n    let didMutate = false;\n    let changeState = collection.changeState;\n    mergeStrategy =\n      mergeStrategy == null ? defaultMergeStrategy : mergeStrategy;\n\n    switch (mergeStrategy) {\n      case MergeStrategy.IgnoreChanges:\n        return this.adapter.upsertMany(entities, collection);\n\n      case MergeStrategy.OverwriteChanges:\n        collection = this.adapter.upsertMany(entities, collection);\n\n        changeState = entities.reduce((chgState, entity) => {\n          const id = this.selectId(entity);\n          const change = chgState[id];\n          if (change) {\n            if (!didMutate) {\n              chgState = { ...chgState };\n              didMutate = true;\n            }\n            delete chgState[id];\n          }\n          return chgState;\n        }, collection.changeState);\n\n        return didMutate ? { ...collection, changeState } : collection;\n\n      case MergeStrategy.PreserveChanges: {\n        const upsertEntities = [] as T[];\n        changeState = entities.reduce((chgState, entity) => {\n          const id = this.selectId(entity);\n          const change = chgState[id];\n          if (change) {\n            if (!didMutate) {\n              chgState = {\n                ...chgState,\n                [id]: {\n                  ...chgState[id]!,\n                  originalValue: entity,\n                },\n              };\n              didMutate = true;\n            }\n          } else {\n            upsertEntities.push(entity);\n          }\n          return chgState;\n        }, collection.changeState);\n\n        collection = this.adapter.upsertMany(upsertEntities, collection);\n        return didMutate ? { ...collection, changeState } : collection;\n      }\n    }\n  }\n  // #endregion query & save helpers\n\n  // #region track methods\n  /**\n   * Track multiple entities before adding them to the collection.\n   * Does NOT add to the collection (the reducer's job).\n   * @param entities The entities to add. They must all have their ids.\n   * @param collection The entity collection\n   * @param [mergeStrategy] Track by default. Don't track if is MergeStrategy.IgnoreChanges.\n   */\n  trackAddMany(\n    entities: T[],\n    collection: EntityCollection<T>,\n    mergeStrategy?: MergeStrategy\n  ): EntityCollection<T> {\n    if (\n      mergeStrategy === MergeStrategy.IgnoreChanges ||\n      entities == null ||\n      entities.length === 0\n    ) {\n      return collection; // nothing to track\n    }\n    let didMutate = false;\n    const changeState = entities.reduce((chgState, entity) => {\n      const id = this.selectId(entity);\n      if (id == null || id === '') {\n        throw new Error(\n          `${collection.entityName} entity add requires a key to be tracked`\n        );\n      }\n      const trackedChange = chgState[id];\n\n      if (!trackedChange) {\n        if (!didMutate) {\n          didMutate = true;\n          chgState = { ...chgState };\n        }\n        chgState[id] = { changeType: ChangeType.Added };\n      }\n      return chgState;\n    }, collection.changeState);\n    return didMutate ? { ...collection, changeState } : collection;\n  }\n\n  /**\n   * Track an entity before adding it to the collection.\n   * Does NOT add to the collection (the reducer's job).\n   * @param entity The entity to add. It must have an id.\n   * @param collection The entity collection\n   * @param [mergeStrategy] Track by default. Don't track if is MergeStrategy.IgnoreChanges.\n   * If not specified, implementation supplies a default strategy.\n   */\n  trackAddOne(\n    entity: T,\n    collection: EntityCollection<T>,\n    mergeStrategy?: MergeStrategy\n  ): EntityCollection<T> {\n    return entity == null\n      ? collection\n      : this.trackAddMany([entity], collection, mergeStrategy);\n  }\n\n  /**\n   * Track multiple entities before removing them with the intention of deleting them on the server.\n   * Does NOT remove from the collection (the reducer's job).\n   * @param keys The primary keys of the entities to delete.\n   * @param collection The entity collection\n   * @param [mergeStrategy] Track by default. Don't track if is MergeStrategy.IgnoreChanges.\n   */\n  trackDeleteMany(\n    keys: (number | string)[],\n    collection: EntityCollection<T>,\n    mergeStrategy?: MergeStrategy\n  ): EntityCollection<T> {\n    if (\n      mergeStrategy === MergeStrategy.IgnoreChanges ||\n      keys == null ||\n      keys.length === 0\n    ) {\n      return collection; // nothing to track\n    }\n    let didMutate = false;\n    const entityMap = collection.entities;\n    const changeState = keys.reduce((chgState, id) => {\n      const originalValue = entityMap[id];\n      if (originalValue) {\n        const trackedChange = chgState[id];\n        if (trackedChange) {\n          if (trackedChange.changeType === ChangeType.Added) {\n            // Special case: stop tracking an added entity that you delete\n            // The caller must also detect this, remove it immediately from the collection\n            // and skip attempt to delete on the server.\n            cloneChgStateOnce();\n            delete chgState[id];\n          } else if (trackedChange.changeType === ChangeType.Updated) {\n            // Special case: switch change type from Updated to Deleted.\n            cloneChgStateOnce();\n            trackedChange.changeType = ChangeType.Deleted;\n          }\n        } else {\n          // Start tracking this entity\n          cloneChgStateOnce();\n          chgState[id] = { changeType: ChangeType.Deleted, originalValue };\n        }\n      }\n      return chgState;\n\n      function cloneChgStateOnce() {\n        if (!didMutate) {\n          didMutate = true;\n          chgState = { ...chgState };\n        }\n      }\n    }, collection.changeState);\n\n    return didMutate ? { ...collection, changeState } : collection;\n  }\n\n  /**\n   * Track an entity before it is removed with the intention of deleting it on the server.\n   * Does NOT remove from the collection (the reducer's job).\n   * @param key The primary key of the entity to delete.\n   * @param collection The entity collection\n   * @param [mergeStrategy] Track by default. Don't track if is MergeStrategy.IgnoreChanges.\n   */\n  trackDeleteOne(\n    key: number | string,\n    collection: EntityCollection<T>,\n    mergeStrategy?: MergeStrategy\n  ): EntityCollection<T> {\n    return key == null\n      ? collection\n      : this.trackDeleteMany([key], collection, mergeStrategy);\n  }\n\n  /**\n   * Track multiple entities before updating them in the collection.\n   * Does NOT update the collection (the reducer's job).\n   * @param updates The entities to update.\n   * @param collection The entity collection\n   * @param [mergeStrategy] Track by default. Don't track if is MergeStrategy.IgnoreChanges.\n   */\n  trackUpdateMany(\n    updates: Update<T>[],\n    collection: EntityCollection<T>,\n    mergeStrategy?: MergeStrategy\n  ): EntityCollection<T> {\n    if (\n      mergeStrategy === MergeStrategy.IgnoreChanges ||\n      updates == null ||\n      updates.length === 0\n    ) {\n      return collection; // nothing to track\n    }\n    let didMutate = false;\n    const entityMap = collection.entities;\n    const changeState = updates.reduce((chgState, update) => {\n      const { id, changes: entity } = update;\n      if (id == null || id === '') {\n        throw new Error(\n          `${collection.entityName} entity update requires a key to be tracked`\n        );\n      }\n      const originalValue = entityMap[id];\n      // Only track if it is in the collection. Silently ignore if it is not.\n      // @ngrx/entity adapter would also silently ignore.\n      // Todo: should missing update entity really be reported as an error?\n      if (originalValue) {\n        const trackedChange = chgState[id];\n        if (!trackedChange) {\n          if (!didMutate) {\n            didMutate = true;\n            chgState = { ...chgState };\n          }\n          chgState[id] = { changeType: ChangeType.Updated, originalValue };\n        }\n      }\n      return chgState;\n    }, collection.changeState);\n    return didMutate ? { ...collection, changeState } : collection;\n  }\n\n  /**\n   * Track an entity before updating it in the collection.\n   * Does NOT update the collection (the reducer's job).\n   * @param update The entity to update.\n   * @param collection The entity collection\n   * @param [mergeStrategy] Track by default. Don't track if is MergeStrategy.IgnoreChanges.\n   */\n  trackUpdateOne(\n    update: Update<T>,\n    collection: EntityCollection<T>,\n    mergeStrategy?: MergeStrategy\n  ): EntityCollection<T> {\n    return update == null\n      ? collection\n      : this.trackUpdateMany([update], collection, mergeStrategy);\n  }\n\n  /**\n   * Track multiple entities before upserting (adding and updating) them to the collection.\n   * Does NOT update the collection (the reducer's job).\n   * @param entities The entities to add or update. They must be complete entities with ids.\n   * @param collection The entity collection\n   * @param [mergeStrategy] Track by default. Don't track if is MergeStrategy.IgnoreChanges.\n   */\n  trackUpsertMany(\n    entities: T[],\n    collection: EntityCollection<T>,\n    mergeStrategy?: MergeStrategy\n  ): EntityCollection<T> {\n    if (\n      mergeStrategy === MergeStrategy.IgnoreChanges ||\n      entities == null ||\n      entities.length === 0\n    ) {\n      return collection; // nothing to track\n    }\n    let didMutate = false;\n    const entityMap = collection.entities;\n    const changeState = entities.reduce((chgState, entity) => {\n      const id = this.selectId(entity);\n      if (id == null || id === '') {\n        throw new Error(\n          `${collection.entityName} entity upsert requires a key to be tracked`\n        );\n      }\n      const trackedChange = chgState[id];\n\n      if (!trackedChange) {\n        if (!didMutate) {\n          didMutate = true;\n          chgState = { ...chgState };\n        }\n\n        const originalValue = entityMap[id];\n        chgState[id] =\n          originalValue == null\n            ? { changeType: ChangeType.Added }\n            : { changeType: ChangeType.Updated, originalValue };\n      }\n      return chgState;\n    }, collection.changeState);\n    return didMutate ? { ...collection, changeState } : collection;\n  }\n\n  /**\n   * Track an entity before upsert (adding and updating) it to the collection.\n   * Does NOT update the collection (the reducer's job).\n   * @param entities The entity to add or update. It must be a complete entity with its id.\n   * @param collection The entity collection\n   * @param [mergeStrategy] Track by default. Don't track if is MergeStrategy.IgnoreChanges.\n   */\n  trackUpsertOne(\n    entity: T,\n    collection: EntityCollection<T>,\n    mergeStrategy?: MergeStrategy\n  ): EntityCollection<T> {\n    return entity == null\n      ? collection\n      : this.trackUpsertMany([entity], collection, mergeStrategy);\n  }\n  // #endregion track methods\n\n  // #region undo methods\n  /**\n   * Revert the unsaved changes for all collection.\n   * Harmless when there are no entity changes to undo.\n   * @param collection The entity collection\n   */\n  undoAll(collection: EntityCollection<T>): EntityCollection<T> {\n    const ids = Object.keys(collection.changeState);\n\n    const { remove, upsert } = ids.reduce(\n      (acc, id) => {\n        const changeState = acc.chgState[id]!;\n        switch (changeState.changeType) {\n          case ChangeType.Added:\n            acc.remove.push(id);\n            break;\n          case ChangeType.Deleted:\n            const removed = changeState!.originalValue;\n            if (removed) {\n              acc.upsert.push(removed);\n            }\n            break;\n          case ChangeType.Updated:\n            acc.upsert.push(changeState!.originalValue!);\n            break;\n        }\n        return acc;\n      },\n      // entitiesToUndo\n      {\n        remove: [] as (number | string)[],\n        upsert: [] as T[],\n        chgState: collection.changeState,\n      }\n    );\n\n    collection = this.adapter.removeMany(remove as string[], collection);\n    collection = this.adapter.upsertMany(upsert, collection);\n\n    return { ...collection, changeState: {} };\n  }\n\n  /**\n   * Revert the unsaved changes for the given entities.\n   * Harmless when there are no entity changes to undo.\n   * @param entityOrIdList The entities to revert or their ids.\n   * @param collection The entity collection\n   */\n  undoMany(\n    entityOrIdList: (number | string | T)[],\n    collection: EntityCollection<T>\n  ): EntityCollection<T> {\n    if (entityOrIdList == null || entityOrIdList.length === 0) {\n      return collection; // nothing to undo\n    }\n    let didMutate = false;\n\n    const { changeState, remove, upsert } = entityOrIdList.reduce(\n      (acc, entityOrId) => {\n        let chgState = acc.changeState;\n        const id =\n          typeof entityOrId === 'object'\n            ? this.selectId(entityOrId)\n            : (entityOrId as string | number);\n        const change = chgState[id]!;\n        if (change) {\n          if (!didMutate) {\n            chgState = { ...chgState };\n            didMutate = true;\n          }\n          delete chgState[id]; // clear tracking of this entity\n          acc.changeState = chgState;\n          switch (change.changeType) {\n            case ChangeType.Added:\n              acc.remove.push(id);\n              break;\n            case ChangeType.Deleted:\n              const removed = change!.originalValue;\n              if (removed) {\n                acc.upsert.push(removed);\n              }\n              break;\n            case ChangeType.Updated:\n              acc.upsert.push(change!.originalValue!);\n              break;\n          }\n        }\n        return acc;\n      },\n      // entitiesToUndo\n      {\n        remove: [] as (number | string)[],\n        upsert: [] as T[],\n        changeState: collection.changeState,\n      }\n    );\n\n    collection = this.adapter.removeMany(remove as string[], collection);\n    collection = this.adapter.upsertMany(upsert, collection);\n    return didMutate ? { ...collection, changeState } : collection;\n  }\n\n  /**\n   * Revert the unsaved changes for the given entity.\n   * Harmless when there are no entity changes to undo.\n   * @param entityOrId The entity to revert or its id.\n   * @param collection The entity collection\n   */\n  undoOne(\n    entityOrId: number | string | T,\n    collection: EntityCollection<T>\n  ): EntityCollection<T> {\n    return entityOrId == null\n      ? collection\n      : this.undoMany([entityOrId], collection);\n  }\n  // #endregion undo methods\n}\n"]}
|