@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,22 +1,14 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @fileoverview added by tsickle
|
|
3
|
-
* Generated from: src/entity-services/entity-collection-service-base.ts
|
|
4
|
-
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
|
|
5
|
-
*/
|
|
6
1
|
// tslint:disable:member-ordering
|
|
7
2
|
/**
|
|
8
3
|
* Base class for a concrete EntityCollectionService<T>.
|
|
9
4
|
* Can be instantiated. Cannot be injected. Use EntityCollectionServiceFactory to create.
|
|
10
5
|
* @param EntityCollectionServiceElements The ingredients for this service
|
|
11
6
|
* as a source of supporting services for creating an EntityCollectionService<T> instance.
|
|
12
|
-
* @template T, S$
|
|
13
7
|
*/
|
|
14
8
|
export class EntityCollectionServiceBase {
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
*/
|
|
19
|
-
constructor(entityName,
|
|
9
|
+
constructor(
|
|
10
|
+
/** Name of the entity type of this collection service */
|
|
11
|
+
entityName,
|
|
20
12
|
/** Creates the core elements of the EntityCollectionService for this entity type */
|
|
21
13
|
serviceElementsFactory) {
|
|
22
14
|
this.entityName = entityName;
|
|
@@ -44,11 +36,10 @@ export class EntityCollectionServiceBase {
|
|
|
44
36
|
}
|
|
45
37
|
/**
|
|
46
38
|
* Create an {EntityAction} for this entity type.
|
|
47
|
-
* @
|
|
48
|
-
* @param
|
|
49
|
-
* @param
|
|
50
|
-
* @
|
|
51
|
-
* @return {?} the EntityAction
|
|
39
|
+
* @param op {EntityOp} the entity operation
|
|
40
|
+
* @param [data] the action data
|
|
41
|
+
* @param [options] additional options
|
|
42
|
+
* @returns the EntityAction
|
|
52
43
|
*/
|
|
53
44
|
createEntityAction(op, data, options) {
|
|
54
45
|
return this.dispatcher.createEntityAction(op, data, options);
|
|
@@ -56,63 +47,48 @@ export class EntityCollectionServiceBase {
|
|
|
56
47
|
/**
|
|
57
48
|
* Create an {EntityAction} for this entity type and
|
|
58
49
|
* dispatch it immediately to the store.
|
|
59
|
-
* @
|
|
60
|
-
* @param
|
|
61
|
-
* @param
|
|
62
|
-
* @
|
|
63
|
-
* @return {?} the dispatched EntityAction
|
|
50
|
+
* @param op {EntityOp} the entity operation
|
|
51
|
+
* @param [data] the action data
|
|
52
|
+
* @param [options] additional options
|
|
53
|
+
* @returns the dispatched EntityAction
|
|
64
54
|
*/
|
|
65
55
|
createAndDispatch(op, data, options) {
|
|
66
56
|
return this.dispatcher.createAndDispatch(op, data, options);
|
|
67
57
|
}
|
|
68
58
|
/**
|
|
69
59
|
* Dispatch an action of any type to the ngrx store.
|
|
70
|
-
* @param
|
|
71
|
-
* @
|
|
60
|
+
* @param action the Action
|
|
61
|
+
* @returns the dispatched Action
|
|
72
62
|
*/
|
|
73
63
|
dispatch(action) {
|
|
74
64
|
return this.dispatcher.dispatch(action);
|
|
75
65
|
}
|
|
76
|
-
/**
|
|
77
|
-
* The NgRx Store for the {EntityCache}
|
|
78
|
-
* @return {?}
|
|
79
|
-
*/
|
|
66
|
+
/** The NgRx Store for the {EntityCache} */
|
|
80
67
|
get store() {
|
|
81
68
|
return this.dispatcher.store;
|
|
82
69
|
}
|
|
83
|
-
/**
|
|
84
|
-
* @param {?} entity
|
|
85
|
-
* @param {?=} options
|
|
86
|
-
* @return {?}
|
|
87
|
-
*/
|
|
88
70
|
add(entity, options) {
|
|
89
71
|
return this.dispatcher.add(entity, options);
|
|
90
72
|
}
|
|
91
73
|
/**
|
|
92
74
|
* Dispatch action to cancel the persistence operation (query or save) with the given correlationId.
|
|
93
|
-
* @param
|
|
94
|
-
* @param
|
|
95
|
-
* @param
|
|
96
|
-
* @return {?}
|
|
75
|
+
* @param correlationId The correlation id for the corresponding EntityAction
|
|
76
|
+
* @param [reason] explains why canceled and by whom.
|
|
77
|
+
* @param [options] options such as the tag and mergeStrategy
|
|
97
78
|
*/
|
|
98
79
|
cancel(correlationId, reason, options) {
|
|
99
80
|
this.dispatcher.cancel(correlationId, reason, options);
|
|
100
81
|
}
|
|
101
|
-
/**
|
|
102
|
-
* @param {?} arg
|
|
103
|
-
* @param {?=} options
|
|
104
|
-
* @return {?}
|
|
105
|
-
*/
|
|
106
82
|
delete(arg, options) {
|
|
107
|
-
return this.dispatcher.delete(
|
|
83
|
+
return this.dispatcher.delete(arg, options);
|
|
108
84
|
}
|
|
109
85
|
/**
|
|
110
86
|
* Dispatch action to query remote storage for all entities and
|
|
111
87
|
* merge the queried entities into the cached collection.
|
|
112
|
-
* @
|
|
113
|
-
* @
|
|
114
|
-
* @return {?} Observable of the collection
|
|
88
|
+
* @param [options] options that influence merge behavior
|
|
89
|
+
* @returns Observable of the collection
|
|
115
90
|
* after server reports successful query or the query error.
|
|
91
|
+
* @see load()
|
|
116
92
|
*/
|
|
117
93
|
getAll(options) {
|
|
118
94
|
return this.dispatcher.getAll(options);
|
|
@@ -121,9 +97,9 @@ export class EntityCollectionServiceBase {
|
|
|
121
97
|
* Dispatch action to query remote storage for the entity with this primary key.
|
|
122
98
|
* If the server returns an entity,
|
|
123
99
|
* merge it into the cached collection.
|
|
124
|
-
* @param
|
|
125
|
-
* @param
|
|
126
|
-
* @
|
|
100
|
+
* @param key The primary key of the entity to get.
|
|
101
|
+
* @param [options] options that influence merge behavior
|
|
102
|
+
* @returns Observable of the queried entity that is in the collection
|
|
127
103
|
* after server reports success or the query error.
|
|
128
104
|
*/
|
|
129
105
|
getByKey(key, options) {
|
|
@@ -133,9 +109,9 @@ export class EntityCollectionServiceBase {
|
|
|
133
109
|
* Dispatch action to query remote storage for the entities that satisfy a query expressed
|
|
134
110
|
* with either a query parameter map or an HTTP URL query string,
|
|
135
111
|
* and merge the results into the cached collection.
|
|
136
|
-
* @param
|
|
137
|
-
* @param
|
|
138
|
-
* @
|
|
112
|
+
* @param queryParams the query in a form understood by the server
|
|
113
|
+
* @param [options] options that influence merge behavior
|
|
114
|
+
* @returns Observable of the queried entities
|
|
139
115
|
* after server reports successful query or the query error.
|
|
140
116
|
*/
|
|
141
117
|
getWithQuery(queryParams, options) {
|
|
@@ -144,10 +120,10 @@ export class EntityCollectionServiceBase {
|
|
|
144
120
|
/**
|
|
145
121
|
* Dispatch action to query remote storage for all entities and
|
|
146
122
|
* completely replace the cached collection with the queried entities.
|
|
147
|
-
* @
|
|
148
|
-
* @
|
|
149
|
-
* @return {?} Observable of the collection
|
|
123
|
+
* @param [options] options that influence load behavior
|
|
124
|
+
* @returns Observable of the collection
|
|
150
125
|
* after server reports successful query or the query error.
|
|
126
|
+
* @see getAll
|
|
151
127
|
*/
|
|
152
128
|
load(options) {
|
|
153
129
|
return this.dispatcher.load(options);
|
|
@@ -156,9 +132,9 @@ export class EntityCollectionServiceBase {
|
|
|
156
132
|
* Dispatch action to save the updated entity (or partial entity) in remote storage.
|
|
157
133
|
* The update entity may be partial (but must have its key)
|
|
158
134
|
* in which case it patches the existing entity.
|
|
159
|
-
* @param
|
|
160
|
-
* @param
|
|
161
|
-
* @
|
|
135
|
+
* @param entity update entity, which might be a partial of T but must at least have its key.
|
|
136
|
+
* @param [options] options that influence save and merge behavior
|
|
137
|
+
* @returns Observable of the updated entity
|
|
162
138
|
* after server reports successful save or the save error.
|
|
163
139
|
*/
|
|
164
140
|
update(entity, options) {
|
|
@@ -167,11 +143,11 @@ export class EntityCollectionServiceBase {
|
|
|
167
143
|
/**
|
|
168
144
|
* Dispatch action to save a new or existing entity to remote storage.
|
|
169
145
|
* Call only if the server supports upsert.
|
|
170
|
-
* @param
|
|
146
|
+
* @param entity entity to add or upsert.
|
|
171
147
|
* It may omit its key if an add, and is pessimistic, and the server creates the key;
|
|
172
148
|
* must have a key if optimistic save.
|
|
173
|
-
* @param
|
|
174
|
-
* @
|
|
149
|
+
* @param [options] options that influence save and merge behavior
|
|
150
|
+
* @returns Observable of the entity
|
|
175
151
|
* after server reports successful save or the save error.
|
|
176
152
|
*/
|
|
177
153
|
upsert(entity, options) {
|
|
@@ -181,9 +157,8 @@ export class EntityCollectionServiceBase {
|
|
|
181
157
|
/**
|
|
182
158
|
* Replace all entities in the cached collection.
|
|
183
159
|
* Does not save to remote storage.
|
|
184
|
-
* @param
|
|
185
|
-
* @param
|
|
186
|
-
* @return {?}
|
|
160
|
+
* @param entities to add directly to cache.
|
|
161
|
+
* @param [options] options such as mergeStrategy
|
|
187
162
|
*/
|
|
188
163
|
addAllToCache(entities, options) {
|
|
189
164
|
this.dispatcher.addAllToCache(entities, options);
|
|
@@ -192,9 +167,8 @@ export class EntityCollectionServiceBase {
|
|
|
192
167
|
* Add a new entity directly to the cache.
|
|
193
168
|
* Does not save to remote storage.
|
|
194
169
|
* Ignored if an entity with the same primary key is already in cache.
|
|
195
|
-
* @param
|
|
196
|
-
* @param
|
|
197
|
-
* @return {?}
|
|
170
|
+
* @param entity to add directly to cache.
|
|
171
|
+
* @param [options] options such as mergeStrategy
|
|
198
172
|
*/
|
|
199
173
|
addOneToCache(entity, options) {
|
|
200
174
|
this.dispatcher.addOneToCache(entity, options);
|
|
@@ -203,35 +177,21 @@ export class EntityCollectionServiceBase {
|
|
|
203
177
|
* Add multiple new entities directly to the cache.
|
|
204
178
|
* Does not save to remote storage.
|
|
205
179
|
* Entities with primary keys already in cache are ignored.
|
|
206
|
-
* @param
|
|
207
|
-
* @param
|
|
208
|
-
* @return {?}
|
|
180
|
+
* @param entities to add directly to cache.
|
|
181
|
+
* @param [options] options such as mergeStrategy
|
|
209
182
|
*/
|
|
210
183
|
addManyToCache(entities, options) {
|
|
211
184
|
this.dispatcher.addManyToCache(entities, options);
|
|
212
185
|
}
|
|
213
|
-
/**
|
|
214
|
-
* Clear the cached entity collection
|
|
215
|
-
* @return {?}
|
|
216
|
-
*/
|
|
186
|
+
/** Clear the cached entity collection */
|
|
217
187
|
clearCache() {
|
|
218
188
|
this.dispatcher.clearCache();
|
|
219
189
|
}
|
|
220
|
-
/**
|
|
221
|
-
* @param {?} arg
|
|
222
|
-
* @param {?=} options
|
|
223
|
-
* @return {?}
|
|
224
|
-
*/
|
|
225
190
|
removeOneFromCache(arg, options) {
|
|
226
|
-
this.dispatcher.removeOneFromCache(
|
|
191
|
+
this.dispatcher.removeOneFromCache(arg, options);
|
|
227
192
|
}
|
|
228
|
-
/**
|
|
229
|
-
* @param {?} args
|
|
230
|
-
* @param {?=} options
|
|
231
|
-
* @return {?}
|
|
232
|
-
*/
|
|
233
193
|
removeManyFromCache(args, options) {
|
|
234
|
-
this.dispatcher.removeManyFromCache(
|
|
194
|
+
this.dispatcher.removeManyFromCache(args, options);
|
|
235
195
|
}
|
|
236
196
|
/**
|
|
237
197
|
* Update a cached entity directly.
|
|
@@ -239,9 +199,8 @@ export class EntityCollectionServiceBase {
|
|
|
239
199
|
* Ignored if an entity with matching primary key is not in cache.
|
|
240
200
|
* The update entity may be partial (but must have its key)
|
|
241
201
|
* in which case it patches the existing entity.
|
|
242
|
-
* @param
|
|
243
|
-
* @param
|
|
244
|
-
* @return {?}
|
|
202
|
+
* @param entity to update directly in cache.
|
|
203
|
+
* @param [options] options such as mergeStrategy
|
|
245
204
|
*/
|
|
246
205
|
updateOneInCache(entity, options) {
|
|
247
206
|
// update entity might be a partial of T but must at least have its key.
|
|
@@ -254,9 +213,8 @@ export class EntityCollectionServiceBase {
|
|
|
254
213
|
* Entities whose primary keys are not in cache are ignored.
|
|
255
214
|
* Update entities may be partial but must at least have their keys.
|
|
256
215
|
* such partial entities patch their cached counterparts.
|
|
257
|
-
* @param
|
|
258
|
-
* @param
|
|
259
|
-
* @return {?}
|
|
216
|
+
* @param entities to update directly in cache.
|
|
217
|
+
* @param [options] options such as mergeStrategy
|
|
260
218
|
*/
|
|
261
219
|
updateManyInCache(entities, options) {
|
|
262
220
|
this.dispatcher.updateManyInCache(entities, options);
|
|
@@ -266,9 +224,8 @@ export class EntityCollectionServiceBase {
|
|
|
266
224
|
* Does not save to remote storage.
|
|
267
225
|
* Upsert entity might be a partial of T but must at least have its key.
|
|
268
226
|
* Pass the Update<T> structure as the payload.
|
|
269
|
-
* @param
|
|
270
|
-
* @param
|
|
271
|
-
* @return {?}
|
|
227
|
+
* @param entity to upsert directly in cache.
|
|
228
|
+
* @param [options] options such as mergeStrategy
|
|
272
229
|
*/
|
|
273
230
|
upsertOneInCache(entity, options) {
|
|
274
231
|
this.dispatcher.upsertOneInCache(entity, options);
|
|
@@ -278,9 +235,8 @@ export class EntityCollectionServiceBase {
|
|
|
278
235
|
* Does not save to remote storage.
|
|
279
236
|
* Upsert entities might be partial but must at least have their keys.
|
|
280
237
|
* Pass an array of the Update<T> structure as the payload.
|
|
281
|
-
* @param
|
|
282
|
-
* @param
|
|
283
|
-
* @return {?}
|
|
238
|
+
* @param entities to upsert directly in cache.
|
|
239
|
+
* @param [options] options such as mergeStrategy
|
|
284
240
|
*/
|
|
285
241
|
upsertManyInCache(entities, options) {
|
|
286
242
|
this.dispatcher.upsertManyInCache(entities, options);
|
|
@@ -288,125 +244,17 @@ export class EntityCollectionServiceBase {
|
|
|
288
244
|
/**
|
|
289
245
|
* Set the pattern that the collection's filter applies
|
|
290
246
|
* when using the `filteredEntities` selector.
|
|
291
|
-
* @param {?} pattern
|
|
292
|
-
* @return {?}
|
|
293
247
|
*/
|
|
294
248
|
setFilter(pattern) {
|
|
295
249
|
this.dispatcher.setFilter(pattern);
|
|
296
250
|
}
|
|
297
|
-
/**
|
|
298
|
-
* Set the loaded flag
|
|
299
|
-
* @param {?} isLoaded
|
|
300
|
-
* @return {?}
|
|
301
|
-
*/
|
|
251
|
+
/** Set the loaded flag */
|
|
302
252
|
setLoaded(isLoaded) {
|
|
303
253
|
this.dispatcher.setLoaded(!!isLoaded);
|
|
304
254
|
}
|
|
305
|
-
/**
|
|
306
|
-
* Set the loading flag
|
|
307
|
-
* @param {?} isLoading
|
|
308
|
-
* @return {?}
|
|
309
|
-
*/
|
|
255
|
+
/** Set the loading flag */
|
|
310
256
|
setLoading(isLoading) {
|
|
311
257
|
this.dispatcher.setLoading(!!isLoading);
|
|
312
258
|
}
|
|
313
259
|
}
|
|
314
|
-
if (false) {
|
|
315
|
-
/**
|
|
316
|
-
* Dispatcher of EntityCommands (EntityActions)
|
|
317
|
-
* @type {?}
|
|
318
|
-
*/
|
|
319
|
-
EntityCollectionServiceBase.prototype.dispatcher;
|
|
320
|
-
/**
|
|
321
|
-
* All selectors of entity collection properties
|
|
322
|
-
* @type {?}
|
|
323
|
-
*/
|
|
324
|
-
EntityCollectionServiceBase.prototype.selectors;
|
|
325
|
-
/**
|
|
326
|
-
* All selectors$ (observables of entity collection properties)
|
|
327
|
-
* @type {?}
|
|
328
|
-
*/
|
|
329
|
-
EntityCollectionServiceBase.prototype.selectors$;
|
|
330
|
-
/**
|
|
331
|
-
* Utility class with methods to validate EntityAction payloads.
|
|
332
|
-
* @type {?}
|
|
333
|
-
*/
|
|
334
|
-
EntityCollectionServiceBase.prototype.guard;
|
|
335
|
-
/**
|
|
336
|
-
* Returns the primary key (id) of this entity
|
|
337
|
-
* @type {?}
|
|
338
|
-
*/
|
|
339
|
-
EntityCollectionServiceBase.prototype.selectId;
|
|
340
|
-
/**
|
|
341
|
-
* Convert an entity (or partial entity) into the `Update<T>` object
|
|
342
|
-
* `update...` and `upsert...` methods take `Update<T>` args
|
|
343
|
-
* @type {?}
|
|
344
|
-
*/
|
|
345
|
-
EntityCollectionServiceBase.prototype.toUpdate;
|
|
346
|
-
/**
|
|
347
|
-
* Observable of the collection as a whole
|
|
348
|
-
* @type {?}
|
|
349
|
-
*/
|
|
350
|
-
EntityCollectionServiceBase.prototype.collection$;
|
|
351
|
-
/**
|
|
352
|
-
* Observable of count of entities in the cached collection.
|
|
353
|
-
* @type {?}
|
|
354
|
-
*/
|
|
355
|
-
EntityCollectionServiceBase.prototype.count$;
|
|
356
|
-
/**
|
|
357
|
-
* Observable of all entities in the cached collection.
|
|
358
|
-
* @type {?}
|
|
359
|
-
*/
|
|
360
|
-
EntityCollectionServiceBase.prototype.entities$;
|
|
361
|
-
/**
|
|
362
|
-
* Observable of actions related to this entity type.
|
|
363
|
-
* @type {?}
|
|
364
|
-
*/
|
|
365
|
-
EntityCollectionServiceBase.prototype.entityActions$;
|
|
366
|
-
/**
|
|
367
|
-
* Observable of the map of entity keys to entities
|
|
368
|
-
* @type {?}
|
|
369
|
-
*/
|
|
370
|
-
EntityCollectionServiceBase.prototype.entityMap$;
|
|
371
|
-
/**
|
|
372
|
-
* Observable of error actions related to this entity type.
|
|
373
|
-
* @type {?}
|
|
374
|
-
*/
|
|
375
|
-
EntityCollectionServiceBase.prototype.errors$;
|
|
376
|
-
/**
|
|
377
|
-
* Observable of the filter pattern applied by the entity collection's filter function
|
|
378
|
-
* @type {?}
|
|
379
|
-
*/
|
|
380
|
-
EntityCollectionServiceBase.prototype.filter$;
|
|
381
|
-
/**
|
|
382
|
-
* Observable of entities in the cached collection that pass the filter function
|
|
383
|
-
* @type {?}
|
|
384
|
-
*/
|
|
385
|
-
EntityCollectionServiceBase.prototype.filteredEntities$;
|
|
386
|
-
/**
|
|
387
|
-
* Observable of the keys of the cached collection, in the collection's native sort order
|
|
388
|
-
* @type {?}
|
|
389
|
-
*/
|
|
390
|
-
EntityCollectionServiceBase.prototype.keys$;
|
|
391
|
-
/**
|
|
392
|
-
* Observable true when the collection has been loaded
|
|
393
|
-
* @type {?}
|
|
394
|
-
*/
|
|
395
|
-
EntityCollectionServiceBase.prototype.loaded$;
|
|
396
|
-
/**
|
|
397
|
-
* Observable true when a multi-entity query command is in progress.
|
|
398
|
-
* @type {?}
|
|
399
|
-
*/
|
|
400
|
-
EntityCollectionServiceBase.prototype.loading$;
|
|
401
|
-
/**
|
|
402
|
-
* Original entity values for entities with unsaved changes
|
|
403
|
-
* @type {?}
|
|
404
|
-
*/
|
|
405
|
-
EntityCollectionServiceBase.prototype.changeState$;
|
|
406
|
-
/**
|
|
407
|
-
* Name of the entity type of this collection service
|
|
408
|
-
* @type {?}
|
|
409
|
-
*/
|
|
410
|
-
EntityCollectionServiceBase.prototype.entityName;
|
|
411
|
-
}
|
|
412
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"entity-collection-service-base.js","sourceRoot":"../../../../modules/data/","sources":["src/entity-services/entity-collection-service-base.ts"],"names":[],"mappings":"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","sourcesContent":["import { Action, Store } from '@ngrx/store';\nimport { Dictionary, IdSelector, Update } from '@ngrx/entity';\n\nimport { Observable } from 'rxjs';\n\nimport { EntityAction, EntityActionOptions } from '../actions/entity-action';\nimport { EntityActionGuard } from '../actions/entity-action-guard';\nimport {\n  EntityCollection,\n  ChangeStateMap,\n} from '../reducers/entity-collection';\nimport { EntityDispatcher } from '../dispatchers/entity-dispatcher';\nimport { EntityCollectionService } from './entity-collection-service';\nimport { EntityCollectionServiceElementsFactory } from './entity-collection-service-elements-factory';\nimport { EntityOp } from '../actions/entity-op';\nimport { EntitySelectors } from '../selectors/entity-selectors';\nimport { EntitySelectors$ } from '../selectors/entity-selectors$';\nimport { QueryParams } from '../dataservices/interfaces';\n\n// tslint:disable:member-ordering\n\n/**\n * Base class for a concrete EntityCollectionService<T>.\n * Can be instantiated. Cannot be injected. Use EntityCollectionServiceFactory to create.\n * @param EntityCollectionServiceElements The ingredients for this service\n * as a source of supporting services for creating an EntityCollectionService<T> instance.\n */\nexport class EntityCollectionServiceBase<\n  T,\n  S$ extends EntitySelectors$<T> = EntitySelectors$<T>\n> implements EntityCollectionService<T> {\n  /** Dispatcher of EntityCommands (EntityActions) */\n  readonly dispatcher: EntityDispatcher<T>;\n\n  /** All selectors of entity collection properties */\n  readonly selectors: EntitySelectors<T>;\n\n  /** All selectors$ (observables of entity collection properties) */\n  readonly selectors$: S$;\n\n  constructor(\n    /** Name of the entity type of this collection service */\n    public readonly entityName: string,\n    /** Creates the core elements of the EntityCollectionService for this entity type */\n    serviceElementsFactory: EntityCollectionServiceElementsFactory\n  ) {\n    entityName = entityName.trim();\n    const { dispatcher, selectors, selectors$ } = serviceElementsFactory.create<\n      T,\n      S$\n    >(entityName);\n\n    this.entityName = entityName;\n    this.dispatcher = dispatcher;\n    this.guard = dispatcher.guard;\n    this.selectId = dispatcher.selectId;\n    this.toUpdate = dispatcher.toUpdate;\n\n    this.selectors = selectors;\n    this.selectors$ = selectors$;\n    this.collection$ = selectors$.collection$;\n    this.count$ = selectors$.count$;\n    this.entities$ = selectors$.entities$;\n    this.entityActions$ = selectors$.entityActions$;\n    this.entityMap$ = selectors$.entityMap$;\n    this.errors$ = selectors$.errors$;\n    this.filter$ = selectors$.filter$;\n    this.filteredEntities$ = selectors$.filteredEntities$;\n    this.keys$ = selectors$.keys$;\n    this.loaded$ = selectors$.loaded$;\n    this.loading$ = selectors$.loading$;\n    this.changeState$ = selectors$.changeState$;\n  }\n\n  /**\n   * Create an {EntityAction} for this entity type.\n   * @param op {EntityOp} the entity operation\n   * @param [data] the action data\n   * @param [options] additional options\n   * @returns the EntityAction\n   */\n  createEntityAction<P = any>(\n    op: EntityOp,\n    data?: P,\n    options?: EntityActionOptions\n  ): EntityAction<P> {\n    return this.dispatcher.createEntityAction(op, data, options);\n  }\n\n  /**\n   * Create an {EntityAction} for this entity type and\n   * dispatch it immediately to the store.\n   * @param op {EntityOp} the entity operation\n   * @param [data] the action data\n   * @param [options] additional options\n   * @returns the dispatched EntityAction\n   */\n  createAndDispatch<P = any>(\n    op: EntityOp,\n    data?: P,\n    options?: EntityActionOptions\n  ): EntityAction<P> {\n    return this.dispatcher.createAndDispatch(op, data, options);\n  }\n\n  /**\n   * Dispatch an action of any type to the ngrx store.\n   * @param action the Action\n   * @returns the dispatched Action\n   */\n  dispatch(action: Action): Action {\n    return this.dispatcher.dispatch(action);\n  }\n\n  /** The NgRx Store for the {EntityCache} */\n  get store() {\n    return this.dispatcher.store;\n  }\n\n  /**\n   * Utility class with methods to validate EntityAction payloads.\n   */\n  guard: EntityActionGuard<T>;\n\n  /** Returns the primary key (id) of this entity */\n  selectId: IdSelector<T>;\n\n  /**\n   * Convert an entity (or partial entity) into the `Update<T>` object\n   * `update...` and `upsert...` methods take `Update<T>` args\n   */\n  toUpdate: (entity: Partial<T>) => Update<T>;\n\n  // region Dispatch commands\n\n  /**\n   * Dispatch action to save a new entity to remote storage.\n   * @param entity entity to add, which may omit its key if pessimistic and the server creates the key;\n   * must have a key if optimistic save.\n   * @param [options] options that influence save and merge behavior\n   * @returns Observable of the entity\n   * after server reports successful save or the save error.\n   */\n  add(\n    entity: Partial<T>,\n    options: EntityActionOptions & { isOptimistic: false }\n  ): Observable<T>;\n  add(\n    entity: T,\n    options?: EntityActionOptions & { isOptimistic?: true }\n  ): Observable<T>;\n  add(entity: T, options?: EntityActionOptions): Observable<T> {\n    return this.dispatcher.add(entity, options);\n  }\n\n  /**\n   * Dispatch action to cancel the persistence operation (query or save) with the given correlationId.\n   * @param correlationId The correlation id for the corresponding EntityAction\n   * @param [reason] explains why canceled and by whom.\n   * @param [options] options such as the tag and mergeStrategy\n   */\n  cancel(\n    correlationId: any,\n    reason?: string,\n    options?: EntityActionOptions\n  ): void {\n    this.dispatcher.cancel(correlationId, reason, options);\n  }\n\n  /**\n   * Dispatch action to delete entity from remote storage by key.\n   * @param key The entity to delete\n   * @param [options] options that influence save and merge behavior\n   * @returns Observable of the deleted key\n   * after server reports successful save or the save error.\n   */\n  delete(entity: T, options?: EntityActionOptions): Observable<number | string>;\n\n  /**\n   * Dispatch action to delete entity from remote storage by key.\n   * @param key The primary key of the entity to remove\n   * @param [options] options that influence save and merge behavior\n   * @returns Observable of the deleted key\n   * after server reports successful save or the save error.\n   */\n  delete(\n    key: number | string,\n    options?: EntityActionOptions\n  ): Observable<number | string>;\n  delete(\n    arg: number | string | T,\n    options?: EntityActionOptions\n  ): Observable<number | string> {\n    return this.dispatcher.delete(arg as any, options);\n  }\n\n  /**\n   * Dispatch action to query remote storage for all entities and\n   * merge the queried entities into the cached collection.\n   * @param [options] options that influence merge behavior\n   * @returns Observable of the collection\n   * after server reports successful query or the query error.\n   * @see load()\n   */\n  getAll(options?: EntityActionOptions): Observable<T[]> {\n    return this.dispatcher.getAll(options);\n  }\n\n  /**\n   * Dispatch action to query remote storage for the entity with this primary key.\n   * If the server returns an entity,\n   * merge it into the cached collection.\n   * @param key The primary key of the entity to get.\n   * @param [options] options that influence merge behavior\n   * @returns Observable of the queried entity that is in the collection\n   * after server reports success or the query error.\n   */\n  getByKey(key: any, options?: EntityActionOptions): Observable<T> {\n    return this.dispatcher.getByKey(key, options);\n  }\n\n  /**\n   * Dispatch action to query remote storage for the entities that satisfy a query expressed\n   * with either a query parameter map or an HTTP URL query string,\n   * and merge the results into the cached collection.\n   * @param queryParams the query in a form understood by the server\n   * @param [options] options that influence merge behavior\n   * @returns Observable of the queried entities\n   * after server reports successful query or the query error.\n   */\n  getWithQuery(\n    queryParams: QueryParams | string,\n    options?: EntityActionOptions\n  ): Observable<T[]> {\n    return this.dispatcher.getWithQuery(queryParams, options);\n  }\n\n  /**\n   * Dispatch action to query remote storage for all entities and\n   * completely replace the cached collection with the queried entities.\n   * @param [options] options that influence load behavior\n   * @returns Observable of the collection\n   * after server reports successful query or the query error.\n   * @see getAll\n   */\n  load(options?: EntityActionOptions): Observable<T[]> {\n    return this.dispatcher.load(options);\n  }\n\n  /**\n   * Dispatch action to save the updated entity (or partial entity) in remote storage.\n   * The update entity may be partial (but must have its key)\n   * in which case it patches the existing entity.\n   * @param entity update entity, which might be a partial of T but must at least have its key.\n   * @param [options] options that influence save and merge behavior\n   * @returns Observable of the updated entity\n   * after server reports successful save or the save error.\n   */\n  update(entity: Partial<T>, options?: EntityActionOptions): Observable<T> {\n    return this.dispatcher.update(entity, options);\n  }\n\n  /**\n   * Dispatch action to save a new or existing entity to remote storage.\n   * Call only if the server supports upsert.\n   * @param entity entity to add or upsert.\n   * It may omit its key if an add, and is pessimistic, and the server creates the key;\n   * must have a key if optimistic save.\n   * @param [options] options that influence save and merge behavior\n   * @returns Observable of the entity\n   * after server reports successful save or the save error.\n   */\n  upsert(entity: T, options?: EntityActionOptions): Observable<T> {\n    return this.dispatcher.upsert(entity, options);\n  }\n\n  /*** Cache-only operations that do not update remote storage ***/\n\n  /**\n   * Replace all entities in the cached collection.\n   * Does not save to remote storage.\n   * @param entities to add directly to cache.\n   * @param [options] options such as mergeStrategy\n   */\n  addAllToCache(entities: T[], options?: EntityActionOptions): void {\n    this.dispatcher.addAllToCache(entities, options);\n  }\n\n  /**\n   * Add a new entity directly to the cache.\n   * Does not save to remote storage.\n   * Ignored if an entity with the same primary key is already in cache.\n   * @param entity to add directly to cache.\n   * @param [options] options such as mergeStrategy\n   */\n  addOneToCache(entity: T, options?: EntityActionOptions): void {\n    this.dispatcher.addOneToCache(entity, options);\n  }\n\n  /**\n   * Add multiple new entities directly to the cache.\n   * Does not save to remote storage.\n   * Entities with primary keys already in cache are ignored.\n   * @param entities to add directly to cache.\n   * @param [options] options such as mergeStrategy\n   */\n  addManyToCache(entities: T[], options?: EntityActionOptions): void {\n    this.dispatcher.addManyToCache(entities, options);\n  }\n\n  /** Clear the cached entity collection */\n  clearCache(): void {\n    this.dispatcher.clearCache();\n  }\n\n  /**\n   * Remove an entity directly from the cache.\n   * Does not delete that entity from remote storage.\n   * @param entity The entity to remove\n   * @param [options] options such as mergeStrategy\n   */\n  removeOneFromCache(entity: T, options?: EntityActionOptions): void;\n\n  /**\n   * Remove an entity directly from the cache.\n   * Does not delete that entity from remote storage.\n   * @param key The primary key of the entity to remove\n   * @param [options] options such as mergeStrategy\n   */\n  removeOneFromCache(key: number | string, options?: EntityActionOptions): void;\n  removeOneFromCache(\n    arg: (number | string) | T,\n    options?: EntityActionOptions\n  ): void {\n    this.dispatcher.removeOneFromCache(arg as any, options);\n  }\n\n  /**\n   * Remove multiple entities directly from the cache.\n   * Does not delete these entities from remote storage.\n   * @param entity The entities to remove\n   * @param [options] options such as mergeStrategy\n   */\n  removeManyFromCache(entities: T[], options?: EntityActionOptions): void;\n\n  /**\n   * Remove multiple entities directly from the cache.\n   * Does not delete these entities from remote storage.\n   * @param keys The primary keys of the entities to remove\n   * @param [options] options such as mergeStrategy\n   */\n  removeManyFromCache(\n    keys: (number | string)[],\n    options?: EntityActionOptions\n  ): void;\n  removeManyFromCache(\n    args: (number | string)[] | T[],\n    options?: EntityActionOptions\n  ): void {\n    this.dispatcher.removeManyFromCache(args as any[], options);\n  }\n\n  /**\n   * Update a cached entity directly.\n   * Does not update that entity in remote storage.\n   * Ignored if an entity with matching primary key is not in cache.\n   * The update entity may be partial (but must have its key)\n   * in which case it patches the existing entity.\n   * @param entity to update directly in cache.\n   * @param [options] options such as mergeStrategy\n   */\n  updateOneInCache(entity: Partial<T>, options?: EntityActionOptions): void {\n    // update entity might be a partial of T but must at least have its key.\n    // pass the Update<T> structure as the payload\n    this.dispatcher.updateOneInCache(entity, options);\n  }\n\n  /**\n   * Update multiple cached entities directly.\n   * Does not update these entities in remote storage.\n   * Entities whose primary keys are not in cache are ignored.\n   * Update entities may be partial but must at least have their keys.\n   * such partial entities patch their cached counterparts.\n   * @param entities to update directly in cache.\n   * @param [options] options such as mergeStrategy\n   */\n  updateManyInCache(\n    entities: Partial<T>[],\n    options?: EntityActionOptions\n  ): void {\n    this.dispatcher.updateManyInCache(entities, options);\n  }\n\n  /**\n   * Insert or update a cached entity directly.\n   * Does not save to remote storage.\n   * Upsert entity might be a partial of T but must at least have its key.\n   * Pass the Update<T> structure as the payload.\n   * @param entity to upsert directly in cache.\n   * @param [options] options such as mergeStrategy\n   */\n  upsertOneInCache(entity: Partial<T>, options?: EntityActionOptions): void {\n    this.dispatcher.upsertOneInCache(entity, options);\n  }\n\n  /**\n   * Insert or update multiple cached entities directly.\n   * Does not save to remote storage.\n   * Upsert entities might be partial but must at least have their keys.\n   * Pass an array of the Update<T> structure as the payload.\n   * @param entities to upsert directly in cache.\n   * @param [options] options such as mergeStrategy\n   */\n  upsertManyInCache(\n    entities: Partial<T>[],\n    options?: EntityActionOptions\n  ): void {\n    this.dispatcher.upsertManyInCache(entities, options);\n  }\n\n  /**\n   * Set the pattern that the collection's filter applies\n   * when using the `filteredEntities` selector.\n   */\n  setFilter(pattern: any): void {\n    this.dispatcher.setFilter(pattern);\n  }\n\n  /** Set the loaded flag */\n  setLoaded(isLoaded: boolean): void {\n    this.dispatcher.setLoaded(!!isLoaded);\n  }\n\n  /** Set the loading flag */\n  setLoading(isLoading: boolean): void {\n    this.dispatcher.setLoading(!!isLoading);\n  }\n\n  // endregion Dispatch commands\n\n  // region Selectors$\n  /** Observable of the collection as a whole */\n  collection$: Observable<EntityCollection<T>> | Store<EntityCollection<T>>;\n\n  /** Observable of count of entities in the cached collection. */\n  count$: Observable<number> | Store<number>;\n\n  /** Observable of all entities in the cached collection. */\n  entities$: Observable<T[]> | Store<T[]>;\n\n  /** Observable of actions related to this entity type. */\n  entityActions$: Observable<EntityAction>;\n\n  /** Observable of the map of entity keys to entities */\n  entityMap$: Observable<Dictionary<T>> | Store<Dictionary<T>>;\n\n  /** Observable of error actions related to this entity type. */\n  errors$: Observable<EntityAction>;\n\n  /** Observable of the filter pattern applied by the entity collection's filter function */\n  filter$: Observable<any> | Store<any>;\n\n  /** Observable of entities in the cached collection that pass the filter function */\n  filteredEntities$: Observable<T[]> | Store<T[]>;\n\n  /** Observable of the keys of the cached collection, in the collection's native sort order */\n  keys$: Observable<string[] | number[]> | Store<string[] | number[]>;\n\n  /** Observable true when the collection has been loaded */\n  loaded$: Observable<boolean> | Store<boolean>;\n\n  /** Observable true when a multi-entity query command is in progress. */\n  loading$: Observable<boolean> | Store<boolean>;\n\n  /** Original entity values for entities with unsaved changes */\n  changeState$: Observable<ChangeStateMap<T>> | Store<ChangeStateMap<T>>;\n\n  // endregion Selectors$\n}\n"]}
|
|
260
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"entity-collection-service-base.js","sourceRoot":"","sources":["../../../../../../modules/data/src/entity-services/entity-collection-service-base.ts"],"names":[],"mappings":"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","sourcesContent":["import { Action, Store } from '@ngrx/store';\nimport { Dictionary, IdSelector, Update } from '@ngrx/entity';\n\nimport { Observable } from 'rxjs';\n\nimport { EntityAction, EntityActionOptions } from '../actions/entity-action';\nimport { EntityActionGuard } from '../actions/entity-action-guard';\nimport {\n  EntityCollection,\n  ChangeStateMap,\n} from '../reducers/entity-collection';\nimport { EntityDispatcher } from '../dispatchers/entity-dispatcher';\nimport { EntityCollectionService } from './entity-collection-service';\nimport { EntityCollectionServiceElementsFactory } from './entity-collection-service-elements-factory';\nimport { EntityOp } from '../actions/entity-op';\nimport { EntitySelectors } from '../selectors/entity-selectors';\nimport { EntitySelectors$ } from '../selectors/entity-selectors$';\nimport { QueryParams } from '../dataservices/interfaces';\n\n// tslint:disable:member-ordering\n\n/**\n * Base class for a concrete EntityCollectionService<T>.\n * Can be instantiated. Cannot be injected. Use EntityCollectionServiceFactory to create.\n * @param EntityCollectionServiceElements The ingredients for this service\n * as a source of supporting services for creating an EntityCollectionService<T> instance.\n */\nexport class EntityCollectionServiceBase<\n  T,\n  S$ extends EntitySelectors$<T> = EntitySelectors$<T>\n> implements EntityCollectionService<T> {\n  /** Dispatcher of EntityCommands (EntityActions) */\n  readonly dispatcher: EntityDispatcher<T>;\n\n  /** All selectors of entity collection properties */\n  readonly selectors: EntitySelectors<T>;\n\n  /** All selectors$ (observables of entity collection properties) */\n  readonly selectors$: S$;\n\n  constructor(\n    /** Name of the entity type of this collection service */\n    public readonly entityName: string,\n    /** Creates the core elements of the EntityCollectionService for this entity type */\n    serviceElementsFactory: EntityCollectionServiceElementsFactory\n  ) {\n    entityName = entityName.trim();\n    const { dispatcher, selectors, selectors$ } = serviceElementsFactory.create<\n      T,\n      S$\n    >(entityName);\n\n    this.entityName = entityName;\n    this.dispatcher = dispatcher;\n    this.guard = dispatcher.guard;\n    this.selectId = dispatcher.selectId;\n    this.toUpdate = dispatcher.toUpdate;\n\n    this.selectors = selectors;\n    this.selectors$ = selectors$;\n    this.collection$ = selectors$.collection$;\n    this.count$ = selectors$.count$;\n    this.entities$ = selectors$.entities$;\n    this.entityActions$ = selectors$.entityActions$;\n    this.entityMap$ = selectors$.entityMap$;\n    this.errors$ = selectors$.errors$;\n    this.filter$ = selectors$.filter$;\n    this.filteredEntities$ = selectors$.filteredEntities$;\n    this.keys$ = selectors$.keys$;\n    this.loaded$ = selectors$.loaded$;\n    this.loading$ = selectors$.loading$;\n    this.changeState$ = selectors$.changeState$;\n  }\n\n  /**\n   * Create an {EntityAction} for this entity type.\n   * @param op {EntityOp} the entity operation\n   * @param [data] the action data\n   * @param [options] additional options\n   * @returns the EntityAction\n   */\n  createEntityAction<P = any>(\n    op: EntityOp,\n    data?: P,\n    options?: EntityActionOptions\n  ): EntityAction<P> {\n    return this.dispatcher.createEntityAction(op, data, options);\n  }\n\n  /**\n   * Create an {EntityAction} for this entity type and\n   * dispatch it immediately to the store.\n   * @param op {EntityOp} the entity operation\n   * @param [data] the action data\n   * @param [options] additional options\n   * @returns the dispatched EntityAction\n   */\n  createAndDispatch<P = any>(\n    op: EntityOp,\n    data?: P,\n    options?: EntityActionOptions\n  ): EntityAction<P> {\n    return this.dispatcher.createAndDispatch(op, data, options);\n  }\n\n  /**\n   * Dispatch an action of any type to the ngrx store.\n   * @param action the Action\n   * @returns the dispatched Action\n   */\n  dispatch(action: Action): Action {\n    return this.dispatcher.dispatch(action);\n  }\n\n  /** The NgRx Store for the {EntityCache} */\n  get store() {\n    return this.dispatcher.store;\n  }\n\n  /**\n   * Utility class with methods to validate EntityAction payloads.\n   */\n  guard: EntityActionGuard<T>;\n\n  /** Returns the primary key (id) of this entity */\n  selectId: IdSelector<T>;\n\n  /**\n   * Convert an entity (or partial entity) into the `Update<T>` object\n   * `update...` and `upsert...` methods take `Update<T>` args\n   */\n  toUpdate: (entity: Partial<T>) => Update<T>;\n\n  // region Dispatch commands\n\n  /**\n   * Dispatch action to save a new entity to remote storage.\n   * @param entity entity to add, which may omit its key if pessimistic and the server creates the key;\n   * must have a key if optimistic save.\n   * @param [options] options that influence save and merge behavior\n   * @returns Observable of the entity\n   * after server reports successful save or the save error.\n   */\n  add(\n    entity: Partial<T>,\n    options: EntityActionOptions & { isOptimistic: false }\n  ): Observable<T>;\n  add(\n    entity: T,\n    options?: EntityActionOptions & { isOptimistic?: true }\n  ): Observable<T>;\n  add(entity: T, options?: EntityActionOptions): Observable<T> {\n    return this.dispatcher.add(entity, options);\n  }\n\n  /**\n   * Dispatch action to cancel the persistence operation (query or save) with the given correlationId.\n   * @param correlationId The correlation id for the corresponding EntityAction\n   * @param [reason] explains why canceled and by whom.\n   * @param [options] options such as the tag and mergeStrategy\n   */\n  cancel(\n    correlationId: any,\n    reason?: string,\n    options?: EntityActionOptions\n  ): void {\n    this.dispatcher.cancel(correlationId, reason, options);\n  }\n\n  /**\n   * Dispatch action to delete entity from remote storage by key.\n   * @param key The entity to delete\n   * @param [options] options that influence save and merge behavior\n   * @returns Observable of the deleted key\n   * after server reports successful save or the save error.\n   */\n  delete(entity: T, options?: EntityActionOptions): Observable<number | string>;\n\n  /**\n   * Dispatch action to delete entity from remote storage by key.\n   * @param key The primary key of the entity to remove\n   * @param [options] options that influence save and merge behavior\n   * @returns Observable of the deleted key\n   * after server reports successful save or the save error.\n   */\n  delete(\n    key: number | string,\n    options?: EntityActionOptions\n  ): Observable<number | string>;\n  delete(\n    arg: number | string | T,\n    options?: EntityActionOptions\n  ): Observable<number | string> {\n    return this.dispatcher.delete(arg as any, options);\n  }\n\n  /**\n   * Dispatch action to query remote storage for all entities and\n   * merge the queried entities into the cached collection.\n   * @param [options] options that influence merge behavior\n   * @returns Observable of the collection\n   * after server reports successful query or the query error.\n   * @see load()\n   */\n  getAll(options?: EntityActionOptions): Observable<T[]> {\n    return this.dispatcher.getAll(options);\n  }\n\n  /**\n   * Dispatch action to query remote storage for the entity with this primary key.\n   * If the server returns an entity,\n   * merge it into the cached collection.\n   * @param key The primary key of the entity to get.\n   * @param [options] options that influence merge behavior\n   * @returns Observable of the queried entity that is in the collection\n   * after server reports success or the query error.\n   */\n  getByKey(key: any, options?: EntityActionOptions): Observable<T> {\n    return this.dispatcher.getByKey(key, options);\n  }\n\n  /**\n   * Dispatch action to query remote storage for the entities that satisfy a query expressed\n   * with either a query parameter map or an HTTP URL query string,\n   * and merge the results into the cached collection.\n   * @param queryParams the query in a form understood by the server\n   * @param [options] options that influence merge behavior\n   * @returns Observable of the queried entities\n   * after server reports successful query or the query error.\n   */\n  getWithQuery(\n    queryParams: QueryParams | string,\n    options?: EntityActionOptions\n  ): Observable<T[]> {\n    return this.dispatcher.getWithQuery(queryParams, options);\n  }\n\n  /**\n   * Dispatch action to query remote storage for all entities and\n   * completely replace the cached collection with the queried entities.\n   * @param [options] options that influence load behavior\n   * @returns Observable of the collection\n   * after server reports successful query or the query error.\n   * @see getAll\n   */\n  load(options?: EntityActionOptions): Observable<T[]> {\n    return this.dispatcher.load(options);\n  }\n\n  /**\n   * Dispatch action to save the updated entity (or partial entity) in remote storage.\n   * The update entity may be partial (but must have its key)\n   * in which case it patches the existing entity.\n   * @param entity update entity, which might be a partial of T but must at least have its key.\n   * @param [options] options that influence save and merge behavior\n   * @returns Observable of the updated entity\n   * after server reports successful save or the save error.\n   */\n  update(entity: Partial<T>, options?: EntityActionOptions): Observable<T> {\n    return this.dispatcher.update(entity, options);\n  }\n\n  /**\n   * Dispatch action to save a new or existing entity to remote storage.\n   * Call only if the server supports upsert.\n   * @param entity entity to add or upsert.\n   * It may omit its key if an add, and is pessimistic, and the server creates the key;\n   * must have a key if optimistic save.\n   * @param [options] options that influence save and merge behavior\n   * @returns Observable of the entity\n   * after server reports successful save or the save error.\n   */\n  upsert(entity: T, options?: EntityActionOptions): Observable<T> {\n    return this.dispatcher.upsert(entity, options);\n  }\n\n  /*** Cache-only operations that do not update remote storage ***/\n\n  /**\n   * Replace all entities in the cached collection.\n   * Does not save to remote storage.\n   * @param entities to add directly to cache.\n   * @param [options] options such as mergeStrategy\n   */\n  addAllToCache(entities: T[], options?: EntityActionOptions): void {\n    this.dispatcher.addAllToCache(entities, options);\n  }\n\n  /**\n   * Add a new entity directly to the cache.\n   * Does not save to remote storage.\n   * Ignored if an entity with the same primary key is already in cache.\n   * @param entity to add directly to cache.\n   * @param [options] options such as mergeStrategy\n   */\n  addOneToCache(entity: T, options?: EntityActionOptions): void {\n    this.dispatcher.addOneToCache(entity, options);\n  }\n\n  /**\n   * Add multiple new entities directly to the cache.\n   * Does not save to remote storage.\n   * Entities with primary keys already in cache are ignored.\n   * @param entities to add directly to cache.\n   * @param [options] options such as mergeStrategy\n   */\n  addManyToCache(entities: T[], options?: EntityActionOptions): void {\n    this.dispatcher.addManyToCache(entities, options);\n  }\n\n  /** Clear the cached entity collection */\n  clearCache(): void {\n    this.dispatcher.clearCache();\n  }\n\n  /**\n   * Remove an entity directly from the cache.\n   * Does not delete that entity from remote storage.\n   * @param entity The entity to remove\n   * @param [options] options such as mergeStrategy\n   */\n  removeOneFromCache(entity: T, options?: EntityActionOptions): void;\n\n  /**\n   * Remove an entity directly from the cache.\n   * Does not delete that entity from remote storage.\n   * @param key The primary key of the entity to remove\n   * @param [options] options such as mergeStrategy\n   */\n  removeOneFromCache(key: number | string, options?: EntityActionOptions): void;\n  removeOneFromCache(\n    arg: (number | string) | T,\n    options?: EntityActionOptions\n  ): void {\n    this.dispatcher.removeOneFromCache(arg as any, options);\n  }\n\n  /**\n   * Remove multiple entities directly from the cache.\n   * Does not delete these entities from remote storage.\n   * @param entity The entities to remove\n   * @param [options] options such as mergeStrategy\n   */\n  removeManyFromCache(entities: T[], options?: EntityActionOptions): void;\n\n  /**\n   * Remove multiple entities directly from the cache.\n   * Does not delete these entities from remote storage.\n   * @param keys The primary keys of the entities to remove\n   * @param [options] options such as mergeStrategy\n   */\n  removeManyFromCache(\n    keys: (number | string)[],\n    options?: EntityActionOptions\n  ): void;\n  removeManyFromCache(\n    args: (number | string)[] | T[],\n    options?: EntityActionOptions\n  ): void {\n    this.dispatcher.removeManyFromCache(args as any[], options);\n  }\n\n  /**\n   * Update a cached entity directly.\n   * Does not update that entity in remote storage.\n   * Ignored if an entity with matching primary key is not in cache.\n   * The update entity may be partial (but must have its key)\n   * in which case it patches the existing entity.\n   * @param entity to update directly in cache.\n   * @param [options] options such as mergeStrategy\n   */\n  updateOneInCache(entity: Partial<T>, options?: EntityActionOptions): void {\n    // update entity might be a partial of T but must at least have its key.\n    // pass the Update<T> structure as the payload\n    this.dispatcher.updateOneInCache(entity, options);\n  }\n\n  /**\n   * Update multiple cached entities directly.\n   * Does not update these entities in remote storage.\n   * Entities whose primary keys are not in cache are ignored.\n   * Update entities may be partial but must at least have their keys.\n   * such partial entities patch their cached counterparts.\n   * @param entities to update directly in cache.\n   * @param [options] options such as mergeStrategy\n   */\n  updateManyInCache(\n    entities: Partial<T>[],\n    options?: EntityActionOptions\n  ): void {\n    this.dispatcher.updateManyInCache(entities, options);\n  }\n\n  /**\n   * Insert or update a cached entity directly.\n   * Does not save to remote storage.\n   * Upsert entity might be a partial of T but must at least have its key.\n   * Pass the Update<T> structure as the payload.\n   * @param entity to upsert directly in cache.\n   * @param [options] options such as mergeStrategy\n   */\n  upsertOneInCache(entity: Partial<T>, options?: EntityActionOptions): void {\n    this.dispatcher.upsertOneInCache(entity, options);\n  }\n\n  /**\n   * Insert or update multiple cached entities directly.\n   * Does not save to remote storage.\n   * Upsert entities might be partial but must at least have their keys.\n   * Pass an array of the Update<T> structure as the payload.\n   * @param entities to upsert directly in cache.\n   * @param [options] options such as mergeStrategy\n   */\n  upsertManyInCache(\n    entities: Partial<T>[],\n    options?: EntityActionOptions\n  ): void {\n    this.dispatcher.upsertManyInCache(entities, options);\n  }\n\n  /**\n   * Set the pattern that the collection's filter applies\n   * when using the `filteredEntities` selector.\n   */\n  setFilter(pattern: any): void {\n    this.dispatcher.setFilter(pattern);\n  }\n\n  /** Set the loaded flag */\n  setLoaded(isLoaded: boolean): void {\n    this.dispatcher.setLoaded(!!isLoaded);\n  }\n\n  /** Set the loading flag */\n  setLoading(isLoading: boolean): void {\n    this.dispatcher.setLoading(!!isLoading);\n  }\n\n  // endregion Dispatch commands\n\n  // region Selectors$\n  /** Observable of the collection as a whole */\n  collection$: Observable<EntityCollection<T>> | Store<EntityCollection<T>>;\n\n  /** Observable of count of entities in the cached collection. */\n  count$: Observable<number> | Store<number>;\n\n  /** Observable of all entities in the cached collection. */\n  entities$: Observable<T[]> | Store<T[]>;\n\n  /** Observable of actions related to this entity type. */\n  entityActions$: Observable<EntityAction>;\n\n  /** Observable of the map of entity keys to entities */\n  entityMap$: Observable<Dictionary<T>> | Store<Dictionary<T>>;\n\n  /** Observable of error actions related to this entity type. */\n  errors$: Observable<EntityAction>;\n\n  /** Observable of the filter pattern applied by the entity collection's filter function */\n  filter$: Observable<any> | Store<any>;\n\n  /** Observable of entities in the cached collection that pass the filter function */\n  filteredEntities$: Observable<T[]> | Store<T[]>;\n\n  /** Observable of the keys of the cached collection, in the collection's native sort order */\n  keys$: Observable<string[] | number[]> | Store<string[] | number[]>;\n\n  /** Observable true when the collection has been loaded */\n  loaded$: Observable<boolean> | Store<boolean>;\n\n  /** Observable true when a multi-entity query command is in progress. */\n  loading$: Observable<boolean> | Store<boolean>;\n\n  /** Original entity values for entities with unsaved changes */\n  changeState$: Observable<ChangeStateMap<T>> | Store<ChangeStateMap<T>>;\n\n  // endregion Selectors$\n}\n"]}
|