@fireflysemantics/slice 17.0.14 → 17.0.17
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/README.md +44 -12
- package/esm2022/lib/AbstractStore.mjs +44 -40
- package/esm2022/lib/EStore.mjs +203 -139
- package/esm2022/lib/Slice.mjs +10 -10
- package/esm2022/lib/models/Delta.mjs +1 -1
- package/fesm2022/fireflysemantics-slice.mjs +252 -184
- package/fesm2022/fireflysemantics-slice.mjs.map +1 -1
- package/lib/AbstractStore.d.ts +38 -34
- package/lib/EStore.d.ts +182 -116
- package/lib/Slice.d.ts +9 -9
- package/lib/models/Delta.d.ts +1 -1
- package/package.json +1 -1
package/esm2022/lib/EStore.mjs
CHANGED
@@ -7,36 +7,43 @@ import { Slice } from './Slice';
|
|
7
7
|
* This `todoFactory` code will be used to illustrate the API examples. The following
|
8
8
|
* utilities are used in the tests and the API Typedoc examples contained here.
|
9
9
|
* @example Utilities for API Examples
|
10
|
-
```
|
11
|
-
export const enum TodoSliceEnum {
|
12
|
-
|
13
|
-
|
14
|
-
}
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
10
|
+
* ```
|
11
|
+
* export const enum TodoSliceEnum {
|
12
|
+
* COMPLETE = "Complete",
|
13
|
+
* INCOMPLETE = "Incomplete"
|
14
|
+
* }
|
15
|
+
* export class Todo {
|
16
|
+
* constructor(
|
17
|
+
* public complete: boolean,
|
18
|
+
* public title: string,
|
19
|
+
* public gid?:string,
|
20
|
+
* public id?:string) {}
|
21
|
+
* }
|
22
|
+
*
|
23
|
+
* export let todos = [new Todo(false, "You complete me!"), new Todo(true, "You completed me!")];
|
24
|
+
*
|
25
|
+
* export function todosFactory():Todo[] {
|
26
|
+
* return [new Todo(false, "You complete me!"), new Todo(true, "You completed me!")];
|
27
|
+
* }
|
28
|
+
* ```
|
26
29
|
*/
|
27
30
|
export class EStore extends AbstractStore {
|
28
31
|
/**
|
29
32
|
* Store constructor (Initialization with element is optional)
|
30
33
|
*
|
31
34
|
* perform initial notification to all observers,
|
32
|
-
* such that
|
35
|
+
* such that functions like {@link combineLatest}{}
|
33
36
|
* will execute at least once.
|
34
|
-
*
|
35
|
-
* @
|
36
|
-
|
37
|
-
|
38
|
-
|
39
|
-
|
37
|
+
*
|
38
|
+
* @param entities The entities to initialize the store with.
|
39
|
+
* @param config The optional configuration instance.
|
40
|
+
*
|
41
|
+
* @example EStore<Todo> Creation
|
42
|
+
* ```
|
43
|
+
* // Initialize the Store
|
44
|
+
* let store: EStore<Todo> = new EStore<Todo>(todosFactory());
|
45
|
+
* ```
|
46
|
+
*/
|
40
47
|
constructor(entities = [], config) {
|
41
48
|
super(config);
|
42
49
|
/**
|
@@ -91,7 +98,7 @@ export class EStore extends AbstractStore {
|
|
91
98
|
this.notifyDelta.next(delta);
|
92
99
|
}
|
93
100
|
/**
|
94
|
-
* Calls complete on all {@link
|
101
|
+
* Calls complete on all EStore {@link ReplaySubject} instances.
|
95
102
|
*
|
96
103
|
* Call destroy when disposing of the store.
|
97
104
|
*/
|
@@ -99,7 +106,7 @@ export class EStore extends AbstractStore {
|
|
99
106
|
super.destroy();
|
100
107
|
this.notifyLoading.complete();
|
101
108
|
this.notifyActive.complete();
|
102
|
-
this.slices.forEach(slice => slice.destroy());
|
109
|
+
this.slices.forEach((slice) => slice.destroy());
|
103
110
|
}
|
104
111
|
/**
|
105
112
|
* Toggles the entity:
|
@@ -108,16 +115,15 @@ export class EStore extends AbstractStore {
|
|
108
115
|
* it will be deleted. If the store
|
109
116
|
* does not contains the entity,
|
110
117
|
* it is added.
|
111
|
-
* @param e
|
112
|
-
* @example Toggle the
|
113
|
-
|
114
|
-
|
115
|
-
|
116
|
-
|
117
|
-
|
118
|
-
|
119
|
-
|
120
|
-
```
|
118
|
+
* @param e The entity to toggle
|
119
|
+
* @example Toggle the Todo instance
|
120
|
+
* ```
|
121
|
+
* estore.post(todo);
|
122
|
+
* // Remove todo
|
123
|
+
* estore.toggle(todo);
|
124
|
+
* // Add it back
|
125
|
+
* estore.toggle(todo);
|
126
|
+
* ```
|
121
127
|
*/
|
122
128
|
toggle(e) {
|
123
129
|
if (this.contains(e)) {
|
@@ -138,11 +144,11 @@ export class EStore extends AbstractStore {
|
|
138
144
|
* change detection in the event that it maintains
|
139
145
|
* a reference to the `active` state `Map` instance.
|
140
146
|
*
|
141
|
-
* @example Add
|
142
|
-
|
143
|
-
|
144
|
-
|
145
|
-
|
147
|
+
* @example Add todo1 and todo2 as active
|
148
|
+
* ```
|
149
|
+
* addActive(todo1);
|
150
|
+
* addActive(todo2);
|
151
|
+
* ```
|
146
152
|
*/
|
147
153
|
addActive(e) {
|
148
154
|
if (this.contains(e)) {
|
@@ -156,18 +162,18 @@ export class EStore extends AbstractStore {
|
|
156
162
|
}
|
157
163
|
}
|
158
164
|
/**
|
159
|
-
* Delete an entity
|
165
|
+
* Delete an active entity.
|
160
166
|
*
|
161
167
|
* Also we clone the map prior to broadcasting it with
|
162
168
|
* `notifyActive` to make sure we will trigger Angular
|
163
169
|
* change detection in the event that it maintains
|
164
170
|
* a reference to the `active` state `Map` instance.
|
165
171
|
*
|
166
|
-
* @example
|
167
|
-
|
168
|
-
|
169
|
-
|
170
|
-
|
172
|
+
* @example Remove todo1 and todo2 as active entities
|
173
|
+
* ```
|
174
|
+
* deleteActive(todo1);
|
175
|
+
* deleteActive(todo2);
|
176
|
+
* ```
|
171
177
|
*/
|
172
178
|
deleteActive(e) {
|
173
179
|
this.active.delete(e.gid);
|
@@ -181,23 +187,23 @@ export class EStore extends AbstractStore {
|
|
181
187
|
* change detection in the event that it maintains
|
182
188
|
* a reference to the `active` state `Map` instance.
|
183
189
|
*
|
184
|
-
* @example
|
185
|
-
|
186
|
-
|
187
|
-
|
188
|
-
```
|
190
|
+
* @example Clear active todo instances
|
191
|
+
* ```
|
192
|
+
* store.clearActive();
|
193
|
+
* ```
|
189
194
|
*/
|
190
195
|
clearActive() {
|
191
196
|
this.active.clear();
|
192
197
|
this.notifyActive.next(new Map(this.active));
|
193
198
|
}
|
194
199
|
/**
|
195
|
-
* Observe the active
|
200
|
+
* Observe the active entities.
|
201
|
+
*
|
196
202
|
* @example
|
197
|
-
|
198
|
-
|
199
|
-
|
200
|
-
|
203
|
+
* ```
|
204
|
+
* let active$ = store.observeActive();
|
205
|
+
* ```
|
206
|
+
*/
|
201
207
|
observeActive() {
|
202
208
|
return this.notifyActive.asObservable();
|
203
209
|
}
|
@@ -220,35 +226,91 @@ export class EStore extends AbstractStore {
|
|
220
226
|
}
|
221
227
|
/**
|
222
228
|
* @return A snapshot of the loading state.
|
229
|
+
* @example Create a reference to the loading state
|
230
|
+
* ```
|
231
|
+
* const loading:boolean = todoStore.loading;
|
232
|
+
* ```
|
223
233
|
*/
|
224
234
|
get loading() {
|
225
235
|
return this._loading;
|
226
236
|
}
|
227
237
|
/**
|
228
238
|
* Observe loading.
|
239
|
+
*
|
240
|
+
* Note that this obverable piped through
|
241
|
+
* `takeWhile(v->v, true), such that it will
|
242
|
+
* complete after each emission.
|
243
|
+
*
|
244
|
+
* See:
|
245
|
+
* https://fireflysemantics.medium.com/waiting-on-estore-to-load-8dcbe161613c
|
246
|
+
*
|
247
|
+
* For more details.
|
248
|
+
* Also note that v=>v is the same as v=>v!=false
|
249
|
+
*
|
229
250
|
* @example
|
230
|
-
|
231
|
-
|
232
|
-
|
233
|
-
|
234
|
-
|
235
|
-
|
236
|
-
|
237
|
-
|
238
|
-
|
239
|
-
|
240
|
-
|
241
|
-
|
242
|
-
|
251
|
+
* ```
|
252
|
+
* const observeLoadingHandler: Observer<boolean> = {
|
253
|
+
* complete: () => {
|
254
|
+
* console.log(`Data Loaded and Observable Marked as Complete`);
|
255
|
+
* }, // completeHandler
|
256
|
+
* error: () => {
|
257
|
+
* console.log(`Any Errors?`);
|
258
|
+
* }, // errorHandler
|
259
|
+
* next: (l) => {
|
260
|
+
* console.log(`Data loaded and loading is ${l}`);
|
261
|
+
* },
|
262
|
+
* };
|
263
|
+
*
|
264
|
+
* const observeLoadingResubscribeHandler: Observer<boolean> = {
|
265
|
+
* complete: () => {
|
266
|
+
* console.log(`Data Loaded and Resubscribe Observable Marked as Complete`);
|
267
|
+
* }, // completeHandler
|
268
|
+
* error: () => {
|
269
|
+
* console.log(`Any Resubscribe Errors?`);
|
270
|
+
* }, // errorHandler
|
271
|
+
* next: (l) => {
|
272
|
+
* console.log(`Data loaded and resusbscribe loading value is ${l}`);
|
273
|
+
* },
|
274
|
+
* };
|
275
|
+
*
|
276
|
+
* const todoStore: EStore<Todo> = new EStore();
|
277
|
+
* //============================================
|
278
|
+
* // Loading is true by default
|
279
|
+
* //============================================
|
280
|
+
* console.log(`The initial value of loading is ${todoStore.loading}`);
|
281
|
+
* //============================================
|
282
|
+
* // Observe Loading
|
283
|
+
* //============================================
|
284
|
+
* let loading$: Observable<boolean> = todoStore.observeLoading();
|
285
|
+
* loading$.subscribe((l) => console.log(`The value of loading is ${l}`));
|
286
|
+
*
|
287
|
+
* todoStore.loading = false;
|
288
|
+
* loading$.subscribe(observeLoadingHandler);
|
289
|
+
* //============================================
|
290
|
+
* // The subscription no longer fires
|
291
|
+
* //============================================
|
292
|
+
* todoStore.loading = true;
|
293
|
+
* todoStore.loading = false;
|
294
|
+
*
|
295
|
+
* //============================================
|
296
|
+
* // The subscription no longer fires,
|
297
|
+
* // so if we want to observe loading again
|
298
|
+
* // resusbscribe.
|
299
|
+
* //============================================
|
300
|
+
* todoStore.loading = true;
|
301
|
+
* loading$ = todoStore.observeLoading();
|
302
|
+
* loading$.subscribe(observeLoadingResubscribeHandler);
|
303
|
+
* todoStore.loading = false;
|
304
|
+
* ```
|
305
|
+
*/
|
243
306
|
observeLoading() {
|
244
|
-
return this.notifyLoading.asObservable().
|
245
|
-
pipe(takeWhile(v => v, true));
|
307
|
+
return this.notifyLoading.asObservable().pipe(takeWhile((v) => v, true));
|
246
308
|
}
|
247
309
|
/**
|
248
310
|
* Notfiies when loading has completed.
|
249
311
|
*/
|
250
312
|
observeLoadingComplete() {
|
251
|
-
return this.observeLoading().pipe(filter(loading => loading == false), switchMap(() => of(true)));
|
313
|
+
return this.observeLoading().pipe(filter((loading) => loading == false), switchMap(() => of(true)));
|
252
314
|
}
|
253
315
|
/**
|
254
316
|
* Sets the current searching state and notifies observers.
|
@@ -280,14 +342,13 @@ export class EStore extends AbstractStore {
|
|
280
342
|
For more details.
|
281
343
|
*/
|
282
344
|
observeSearching() {
|
283
|
-
return this.notifySearching.asObservable().
|
284
|
-
pipe(takeWhile(v => v, true));
|
345
|
+
return this.notifySearching.asObservable().pipe(takeWhile((v) => v, true));
|
285
346
|
}
|
286
347
|
/**
|
287
348
|
* Notfiies when searching has completed.
|
288
349
|
*/
|
289
350
|
observeSearchingComplete() {
|
290
|
-
return this.observeSearching().pipe(filter(searching => searching == false), switchMap(() => of(true)));
|
351
|
+
return this.observeSearching().pipe(filter((searching) => searching == false), switchMap(() => of(true)));
|
291
352
|
}
|
292
353
|
/**
|
293
354
|
* Adds a slice to the store and keys it by the slices label.
|
@@ -332,10 +393,11 @@ export class EStore extends AbstractStore {
|
|
332
393
|
/**
|
333
394
|
* Post (Add a new) element(s) to the store.
|
334
395
|
* @param e An indiidual entity or an array of entities
|
335
|
-
* @example Post a
|
336
|
-
|
337
|
-
|
338
|
-
|
396
|
+
* @example Post a Todo instance.
|
397
|
+
*
|
398
|
+
*```
|
399
|
+
* store.post(todo);
|
400
|
+
*```
|
339
401
|
*/
|
340
402
|
post(e) {
|
341
403
|
if (!Array.isArray(e)) {
|
@@ -345,7 +407,7 @@ export class EStore extends AbstractStore {
|
|
345
407
|
e[this.GUID_KEY] = guid;
|
346
408
|
this.entries.set(guid, e);
|
347
409
|
this.updateIDEntry(e);
|
348
|
-
Array.from(this.slices.values()).forEach(s => {
|
410
|
+
Array.from(this.slices.values()).forEach((s) => {
|
349
411
|
s.post(e);
|
350
412
|
});
|
351
413
|
//Create a new array reference to trigger Angular change detection.
|
@@ -358,15 +420,15 @@ export class EStore extends AbstractStore {
|
|
358
420
|
}
|
359
421
|
}
|
360
422
|
/**
|
361
|
-
* Post
|
423
|
+
* Post N entities to the store.
|
362
424
|
* @param ...e
|
363
|
-
* @example Post two
|
364
|
-
|
365
|
-
|
366
|
-
|
425
|
+
* @example Post two Todo instances.
|
426
|
+
* ```
|
427
|
+
* store.post(todo1, todo2);
|
428
|
+
* ```
|
367
429
|
*/
|
368
430
|
postN(...e) {
|
369
|
-
e.forEach(e => {
|
431
|
+
e.forEach((e) => {
|
370
432
|
const guid = e[this.GUID_KEY]
|
371
433
|
? e[this.GUID_KEY]
|
372
434
|
: GUID();
|
@@ -374,7 +436,7 @@ export class EStore extends AbstractStore {
|
|
374
436
|
this.entries.set(guid, e);
|
375
437
|
this.updateIDEntry(e);
|
376
438
|
});
|
377
|
-
Array.from(this.slices.values()).forEach(s => {
|
439
|
+
Array.from(this.slices.values()).forEach((s) => {
|
378
440
|
s.postA(e);
|
379
441
|
});
|
380
442
|
//Create a new array reference to trigger Angular change detection.
|
@@ -385,21 +447,22 @@ export class EStore extends AbstractStore {
|
|
385
447
|
/**
|
386
448
|
* Post (Add) an array of elements to the store.
|
387
449
|
* @param e
|
388
|
-
* @example Post a
|
389
|
-
|
390
|
-
|
391
|
-
|
450
|
+
* @example Post a Todo array.
|
451
|
+
*
|
452
|
+
* ```
|
453
|
+
* store.post([todo1, todo2]);
|
454
|
+
* ```
|
392
455
|
*/
|
393
456
|
postA(e) {
|
394
457
|
this.postN(...e);
|
395
458
|
}
|
396
459
|
/**
|
397
|
-
* Put (Update) an
|
460
|
+
* Put (Update) an entity.
|
398
461
|
* @param e
|
399
462
|
* @example Put a Todo instance.
|
400
|
-
|
401
|
-
|
402
|
-
|
463
|
+
* ```
|
464
|
+
* store.put(todo1);
|
465
|
+
* ```
|
403
466
|
*/
|
404
467
|
put(e) {
|
405
468
|
if (!Array.isArray(e)) {
|
@@ -410,7 +473,7 @@ export class EStore extends AbstractStore {
|
|
410
473
|
this.notify.next(v);
|
411
474
|
const delta = { type: "Put" /* ActionTypes.PUT */, entries: [e] };
|
412
475
|
this.notifyDelta.next(delta);
|
413
|
-
Array.from(this.slices.values()).forEach(s => {
|
476
|
+
Array.from(this.slices.values()).forEach((s) => {
|
414
477
|
s.put(e);
|
415
478
|
});
|
416
479
|
}
|
@@ -421,25 +484,26 @@ export class EStore extends AbstractStore {
|
|
421
484
|
/**
|
422
485
|
* Put (Update) an element or add an element that was read from a persistence source
|
423
486
|
* and thus already has an assigned global id`.
|
424
|
-
* @param e
|
425
|
-
* @example Put Todo instances.
|
426
|
-
|
427
|
-
|
428
|
-
|
487
|
+
* @param e The enetity instances to update.
|
488
|
+
* @example Put N Todo instances.
|
489
|
+
*
|
490
|
+
* ```
|
491
|
+
* store.put(todo1, todo2);
|
492
|
+
* ```
|
429
493
|
*/
|
430
494
|
putN(...e) {
|
431
495
|
this.putA(e);
|
432
496
|
}
|
433
497
|
/**
|
434
|
-
* Put (Update) the array of
|
435
|
-
* @param e
|
436
|
-
* @example Put Todo instances.
|
437
|
-
|
438
|
-
|
439
|
-
|
498
|
+
* Put (Update) the array of enntities.
|
499
|
+
* @param e The array of enntities to update
|
500
|
+
* @example Put an array of Todo instances.
|
501
|
+
* ```
|
502
|
+
* store.put([todo1, todo2]);
|
503
|
+
* ```
|
440
504
|
*/
|
441
505
|
putA(e) {
|
442
|
-
e.forEach(e => {
|
506
|
+
e.forEach((e) => {
|
443
507
|
let guid = e[this.GUID_KEY];
|
444
508
|
this.entries.set(guid, e);
|
445
509
|
this.updateIDEntry(e);
|
@@ -449,7 +513,7 @@ export class EStore extends AbstractStore {
|
|
449
513
|
this.notify.next(v);
|
450
514
|
const delta = { type: "Put" /* ActionTypes.PUT */, entries: e };
|
451
515
|
this.notifyDelta.next(delta);
|
452
|
-
Array.from(this.slices.values()).forEach(s => {
|
516
|
+
Array.from(this.slices.values()).forEach((s) => {
|
453
517
|
s.putA(e);
|
454
518
|
});
|
455
519
|
}
|
@@ -457,9 +521,9 @@ export class EStore extends AbstractStore {
|
|
457
521
|
* Delete (Update) the array of elements.
|
458
522
|
* @param e
|
459
523
|
* @example Delete todo1.
|
460
|
-
|
461
|
-
|
462
|
-
|
524
|
+
* ```
|
525
|
+
* store.delete(todo1]);
|
526
|
+
* ```
|
463
527
|
*/
|
464
528
|
delete(e) {
|
465
529
|
if (!Array.isArray(e)) {
|
@@ -467,14 +531,14 @@ export class EStore extends AbstractStore {
|
|
467
531
|
const guid = e[this.GUID_KEY];
|
468
532
|
this.entries.delete(guid);
|
469
533
|
this.deleteIDEntry(e);
|
470
|
-
Array.from(this.slices.values()).forEach(s => {
|
534
|
+
Array.from(this.slices.values()).forEach((s) => {
|
471
535
|
s.entries.delete(guid);
|
472
536
|
});
|
473
537
|
//Create a new array reference to trigger Angular change detection.
|
474
538
|
let v = [...Array.from(this.entries.values())];
|
475
539
|
const delta = { type: "Delete" /* ActionTypes.DELETE */, entries: [e] };
|
476
540
|
this.notifyAll(v, delta);
|
477
|
-
Array.from(this.slices.values()).forEach(s => {
|
541
|
+
Array.from(this.slices.values()).forEach((s) => {
|
478
542
|
s.delete(e);
|
479
543
|
});
|
480
544
|
}
|
@@ -485,29 +549,29 @@ export class EStore extends AbstractStore {
|
|
485
549
|
/**
|
486
550
|
* Delete N elements.
|
487
551
|
* @param ...e
|
488
|
-
* @example
|
489
|
-
|
490
|
-
|
491
|
-
|
552
|
+
* @example Delete N Todo instance argument.
|
553
|
+
* ```
|
554
|
+
* store.deleteN(todo1, todo2);
|
555
|
+
* ```
|
492
556
|
*/
|
493
557
|
deleteN(...e) {
|
494
558
|
this.deleteA(e);
|
495
559
|
}
|
496
560
|
/**
|
497
|
-
* Delete
|
498
|
-
* @param
|
499
|
-
* @example
|
500
|
-
|
501
|
-
|
502
|
-
|
561
|
+
* Delete an array of elements.
|
562
|
+
* @param e The array of instances to be deleted
|
563
|
+
* @example Delete the array of Todo instances.
|
564
|
+
* ```
|
565
|
+
* store.deleteA([todo1, todo2]);
|
566
|
+
* ```
|
503
567
|
*/
|
504
568
|
deleteA(e) {
|
505
|
-
e.forEach(e => {
|
569
|
+
e.forEach((e) => {
|
506
570
|
this.deleteActive(e);
|
507
571
|
const guid = e[this.GUID_KEY];
|
508
572
|
this.entries.delete(guid);
|
509
573
|
this.deleteIDEntry(e);
|
510
|
-
Array.from(this.slices.values()).forEach(s => {
|
574
|
+
Array.from(this.slices.values()).forEach((s) => {
|
511
575
|
s.entries.delete(guid);
|
512
576
|
});
|
513
577
|
});
|
@@ -515,21 +579,21 @@ export class EStore extends AbstractStore {
|
|
515
579
|
let v = [...Array.from(this.entries.values())];
|
516
580
|
const delta = { type: "Delete" /* ActionTypes.DELETE */, entries: e };
|
517
581
|
this.notifyAll(v, delta);
|
518
|
-
Array.from(this.slices.values()).forEach(s => {
|
582
|
+
Array.from(this.slices.values()).forEach((s) => {
|
519
583
|
s.deleteA(e);
|
520
584
|
});
|
521
585
|
}
|
522
586
|
/**
|
523
587
|
* Delete elements by {@link Predicate}.
|
524
588
|
* @param p The predicate.
|
525
|
-
* @example
|
526
|
-
|
527
|
-
|
528
|
-
|
589
|
+
* @example Delete the Todo instances.
|
590
|
+
* ```
|
591
|
+
* store.delete(todo1, todo2);
|
592
|
+
* ```
|
529
593
|
*/
|
530
594
|
deleteP(p) {
|
531
595
|
const d = [];
|
532
|
-
Array.from(this.entries.values()).forEach(e => {
|
596
|
+
Array.from(this.entries.values()).forEach((e) => {
|
533
597
|
if (p(e)) {
|
534
598
|
d.push(e);
|
535
599
|
const id = e[this.GUID_KEY];
|
@@ -542,7 +606,7 @@ export class EStore extends AbstractStore {
|
|
542
606
|
let v = [...Array.from(this.entries.values())];
|
543
607
|
const delta = { type: "Delete" /* ActionTypes.DELETE */, entries: d };
|
544
608
|
this.notifyAll(v, delta);
|
545
|
-
Array.from(this.slices.values()).forEach(s => {
|
609
|
+
Array.from(this.slices.values()).forEach((s) => {
|
546
610
|
s.deleteA(d);
|
547
611
|
});
|
548
612
|
}
|
@@ -575,18 +639,18 @@ export class EStore extends AbstractStore {
|
|
575
639
|
* send their own delta notification.
|
576
640
|
*
|
577
641
|
* @example Reset the store.
|
578
|
-
|
579
|
-
|
580
|
-
|
642
|
+
* ```
|
643
|
+
* store.reset();
|
644
|
+
* ```
|
581
645
|
*/
|
582
646
|
reset() {
|
583
647
|
const delta = {
|
584
648
|
type: "Reset" /* ActionTypes.RESET */,
|
585
|
-
entries: Array.from(this.entries.values())
|
649
|
+
entries: Array.from(this.entries.values()),
|
586
650
|
};
|
587
651
|
this.notifyAll([], delta);
|
588
652
|
this.entries = new Map();
|
589
|
-
Array.from(this.slices.values()).forEach(s => {
|
653
|
+
Array.from(this.slices.values()).forEach((s) => {
|
590
654
|
s.reset();
|
591
655
|
});
|
592
656
|
}
|
@@ -601,4 +665,4 @@ export class EStore extends AbstractStore {
|
|
601
665
|
this.notifyLoading.next(this.loading);
|
602
666
|
}
|
603
667
|
}
|
604
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"EStore.js","sourceRoot":"","sources":["../../../../projects/slice/src/lib/EStore.ts"],"names":[],"mappings":"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","sourcesContent":["import { AbstractStore } from './AbstractStore';\nimport { StoreConfig } from './models/StoreConfig';\nimport { GUID } from './utilities';\n\nimport { ActionTypes, Predicate, Delta } from './models/';\nimport { ReplaySubject, of, Observable } from 'rxjs';\nimport { takeWhile, filter, switchMap } from 'rxjs/operators';\nimport { Slice } from './Slice';\n\n/**\n * This `todoFactory` code will be used to illustrate the API examples.  The following\n * utilities are used in the tests and the API Typedoc examples contained here.\n * @example Utilities for API Examples\n```\nexport const enum TodoSliceEnum {\n  COMPLETE = \"Complete\",\n  INCOMPLETE = \"Incomplete\"\n}\n\nexport class Todo {\n  constructor(public complete: boolean, public title: string,public gid?:string, public id?:string) {}\n}\n\nexport let todos = [new Todo(false, \"You complete me!\"), new Todo(true, \"You completed me!\")];\n\nexport function todosFactory():Todo[] {\n  return [new Todo(false, \"You complete me!\"), new Todo(true, \"You completed me!\")];\n}\n ``` \n */\n\nexport class EStore<E> extends AbstractStore<E> {\n  /**\n   * Store constructor (Initialization with element is optional)\n   *\n   * perform initial notification to all observers,\n   * such that function like {@link combineLatest}{}\n   * will execute at least once.\n   * @param entities\n   * @example Dynamic `EStore<Todo>` Creation \n```\n// Initialize the Store\nlet store: EStore<Todo> = new EStore<Todo>(todosFactory());\n```*/\n  constructor(entities: E[] = [], config?: StoreConfig) {\n    super(config);\n    const delta: Delta<E> = { type: ActionTypes.INTIALIZE, entries: entities };\n    this.post(entities)\n    this.notifyDelta.next(delta);\n  }\n\n  /**\n   * Calls complete on all {@link BehaviorSubject} instances.\n   * \n   * Call destroy when disposing of the store.\n   */\n  override destroy() {\n    super.destroy()\n    this.notifyLoading.complete()\n    this.notifyActive.complete()\n    this.slices.forEach(slice => slice.destroy())\n  }\n\n  /**\n   * Toggles the entity:\n   * \n   * If the store contains the entity\n   * it will be deleted.  If the store \n   * does not contains the entity,\n   * it is added.\n   * @param e \n   * @example Toggle the `Todo` instance\n```\nestore.post(todo);\n// Remove todo\nestore.toggle(todo);\n// Add it back\nestore.toggle(todo);\n\n```\n   */\n  public toggle(e: E) {\n    if (this.contains(e)) {\n      this.delete(e);\n    } else {\n      this.post(e);\n    }\n  }\n\n  /**\n   * Notifies observers when the store is empty.\n   */\n  private notifyActive = new ReplaySubject<Map<string, E>>(1);\n\n\n  /**\n   * `Map` of active entties. The instance is public and can be used\n   * directly to add and remove active entities, however we recommend\n   * using the {@link addActive} and {@link deleteActive} methods.\n   */\n  public active: Map<string, E> = new Map();\n\n  /**\n   * Add multiple entity entities to active.\n   * \n   * If the entity is not contained in the store it is added\n   * to the store before it is added to `active`.\n   * \n   * Also we clone the map prior to broadcasting it with\n   * `notifyActive` to make sure we will trigger Angular \n   * change detection in the event that it maintains \n   * a reference to the `active` state `Map` instance.\n   * \n   * @example Add a `todo1` and `todo2` as active\n```\naddActive(todo1);\naddActive(todo2);\n```\n   */\n  public addActive(e: E) {\n    if (this.contains(e)) {\n      this.active.set((<any>e).gid, e);\n      this.notifyActive.next(new Map(this.active));\n    }\n    else {\n      this.post(e);\n      this.active.set((<any>e).gid, e);\n      this.notifyActive.next(new Map(this.active));\n    }\n  }\n\n  /**\n   * Delete an entity as active.\n   * \n   * Also we clone the map prior to broadcasting it with\n   * `notifyActive` to make sure we will trigger Angular \n   * change detection in the event that it maintains \n   * a reference to the `active` state `Map` instance.\n   * \n   * @example Mark a `todo` instance as active\n  ```\ndeleteActive(todo1);\ndeleteActive(todo2);\n  ```\n   */\n  public deleteActive(e: E) {\n    this.active.delete((<any>e).gid);\n    this.notifyActive.next(new Map(this.active));\n  }\n\n  /**\n   * Clear / reset the active entity map.\n   * \n   * Also we clone the map prior to broadcasting it with\n   * `notifyActive` to make sure we will trigger Angular \n   * change detection in the event that it maintains \n   * a reference to the `active` state `Map` instance.\n   * \n   * @example Mark a `todo` instance as active\n  ```\ndeleteActive(todo1);\ndeleteActive(todo2);\n  ```\n   */\n  clearActive() {\n    this.active.clear();\n    this.notifyActive.next(new Map(this.active));\n  }\n\n  /**\n   * Observe the active entity.\n   * @example\n     <pre>\n    let active$ = source.observeActive();\n    </pre>\n  */\n  public observeActive() {\n    return this.notifyActive.asObservable()\n  }\n\n  /**\n   * Observe the active entity.\n   * @example\n     <pre>\n    let active$ = source.activeSnapshot();\n    </pre>\n  */\n    public activeSnapshot() {\n      return Array.from(this.active.values())\n  }\n\n\n  //================================================\n  // LOADING\n  //================================================\n\n  /**\n   * Observable of errors occurred during a load request.\n   * \n   * The error Observable should be created by the \n   * client.\n   */\n  public loadingError!: Observable<any>;\n\n  /**\n   * Notifies observers when the store is loading.\n   * \n   * This is a common pattern found when implementing\n   * `Observable` data sources.\n   */\n  private notifyLoading = new ReplaySubject<boolean>(1);\n\n  /**\n   * The current loading state.  Use loading when fetching new\n   * data for the store.  The default loading state is `true`.\n   * \n   * This is such that if data is fetched asynchronously \n   * in a service, components can wait on loading notification\n   * before attempting to retrieve data from the service.\n   *\n   * Loading could be based on a composite response.  For example\n   * when the stock and mutual funds have loaded, set loading to `false`.\n   */\n  private _loading: boolean = true;\n\n  /**\n   * Sets the current loading state and notifies observers.\n   */\n  set loading(loading: boolean) {\n    this._loading = loading;\n    this.notifyLoading.next(this._loading);\n  }\n\n  /**\n   * @return A snapshot of the loading state.\n   */\n  get loading() {\n    return this._loading;\n  }\n\n  /**\n   * Observe loading.\n   * @example\n     <pre>\n    let loading$ = source.observeLoading();\n    </pre>\n\n    Note that this obverable piped through\n    `takeWhile(v->v, true), such that it will \n    complete after each emission.\n\n    See:\n    https://medium.com/@ole.ersoy/waiting-on-estore-to-load-8dcbe161613c\n\n    For more details.\n  */\n  public observeLoading() {\n    return this.notifyLoading.asObservable().\n      pipe(takeWhile(v => v, true));\n  }\n\n  /**\n   * Notfiies when loading has completed.\n   */\n  public observeLoadingComplete() {\n    return this.observeLoading().pipe(\n      filter(loading => loading == false),\n      switchMap(() => of(true)))\n  }\n\n\n\n\n\n\n  //================================================\n  // SEARCHING\n  //================================================\n  /**\n   * Observable of errors occurred during a search request.\n   * \n   * The error Observable should be created by the \n   * client.\n   */\n  public searchError!: Observable<any>;\n\n  /**\n   * Notifies observers that a search is in progress.\n   * \n   * This is a common pattern found when implementing\n   * `Observable` data sources.\n   */\n  private notifySearching = new ReplaySubject<boolean>(1);\n\n  /**\n   * The current `searching` state.  Use `searching`\n   * for example to display a spinnner \n   * when performing a search.  \n   * The default `searching` state is `false`.\n   */\n  private _searching: boolean = false;\n\n  /**\n   * Sets the current searching state and notifies observers.\n   */\n  set searching(searching: boolean) {\n    this._searching = searching;\n    this.notifySearching.next(this._searching);\n  }\n\n  /**\n   * @return A snapshot of the searching state.\n   */\n  get searching() {\n    return this._searching;\n  }\n\n  /**\n   * Observe searching.\n   * @example\n     <pre>\n    let searching$ = source.observeSearching();\n    </pre>\n  \n    Note that this obverable piped through\n    `takeWhile(v->v, true), such that it will \n    complete after each emission.\n  \n    See:\n    https://medium.com/@ole.ersoy/waiting-on-estore-to-load-8dcbe161613c\n  \n    For more details.\n  */\n  public observeSearching(): Observable<boolean> {\n    return this.notifySearching.asObservable().\n      pipe(takeWhile(v => v, true));\n  }\n\n  /**\n   * Notfiies when searching has completed.\n   */\n  public observeSearchingComplete(): Observable<boolean> {\n    return this.observeSearching().pipe(\n      filter(searching => searching == false),\n      switchMap(() => of(true)))\n  }\n\n  /**\n   * Store slices\n   */\n  private slices: Map<string, Slice<E>> = new Map();\n\n  /**\n   * Adds a slice to the store and keys it by the slices label.\n   *\n   * @param p\n   * @param label\n   * \n   * @example Setup a Todo Slice for COMPLETE Todos\n```\nsource.addSlice(todo => todo.complete, TodoSlices.COMPLETE);\n```\n   */\n  addSlice(p: Predicate<E>, label: string) {\n    const slice: Slice<E> = new Slice(\n      label,\n      p,\n      this)\n    this.slices.set(slice.label, slice)\n  }\n\n  /**\n   * Remove a slice\n   * @param label The label identifying the slice\n   * \n   * @example Remove the TodoSlices.COMPLETE Slice\n```\nsource.removeSlice(TodoSlices.COMPLETE);\n```\n   */\n  removeSlice(label: string) {\n    this.slices.delete(label);\n  }\n\n  /**\n   * Get a slice\n   * @param label The label identifying the slice\n   * @return The Slice instance or undefined \n   * \n   * @example Get the TodoSlices.COMPLETE slice\n```\nsource.getSlice(TodoSlices.COMPLETE);\n```\n   */\n  getSlice(label: string): Slice<E> | undefined {\n    return this.slices.get(label);\n  }\n\n  /**\n   * Post (Add a new) element(s) to the store.\n   * @param e An indiidual entity or an array of entities\n   * @example Post a `todo`.\n```\nstore.post(todo);\n```\n   */\n  post(e: E | E[]) {\n    if (!Array.isArray(e)) {\n      const guid: string = (<any>e)[this.GUID_KEY]\n        ? (<any>e)[this.GUID_KEY]\n        : GUID();\n      (<any>e)[this.GUID_KEY] = guid;\n      this.entries.set(guid, e);\n      this.updateIDEntry(e);\n      Array.from(this.slices.values()).forEach(s => {\n        s.post(e);\n      });\n      //Create a new array reference to trigger Angular change detection.\n      let v: E[] = [...Array.from(this.entries.values())];\n      const delta: Delta<E> = { type: ActionTypes.POST, entries: [e] };\n      this.notifyAll(v, delta);\n    }\n    else {\n      this.postA(e)\n    }\n  }\n\n  /**\n   * Post elements to the store.\n   * @param ...e\n   * @example Post two `Todo` instances.\n```\nstore.post(todo1, todo2);\n```\n   */\n  postN(...e: E[]) {\n    e.forEach(e => {\n      const guid: string = (<any>e)[this.GUID_KEY]\n        ? (<any>e)[this.GUID_KEY]\n        : GUID();\n      (<any>e)[this.GUID_KEY] = guid;\n      this.entries.set(guid, e);\n      this.updateIDEntry(e);\n    });\n    Array.from(this.slices.values()).forEach(s => {\n      s.postA(e);\n    });\n    //Create a new array reference to trigger Angular change detection.\n    let v: E[] = [...Array.from(this.entries.values())];\n    const delta: Delta<E> = { type: ActionTypes.POST, entries: e };\n    this.notifyAll(v, delta);\n  }\n\n  /**\n   * Post (Add) an array of elements to the store.\n   * @param e\n   * @example Post a `Todo` array.\n```\nstore.post([todo1, todo2]);\n```\n   */\n  postA(e: E[]) {\n    this.postN(...e);\n  }\n\n  /**\n   * Put (Update) an element.\n   * @param e\n   * @example Put a Todo instance.\n```\nstore.put(todo1);\n```\n   */\n  put(e: E | E[]) {\n    if (!Array.isArray(e)) {\n      let id: string = (<any>e)[this.GUID_KEY];\n      this.entries.set(id, e);\n      this.updateIDEntry(e);\n      let v: E[] = [...Array.from(this.entries.values())];\n      this.notify.next(v);\n      const delta: Delta<E> = { type: ActionTypes.PUT, entries: [e] };\n      this.notifyDelta.next(delta);\n      Array.from(this.slices.values()).forEach(s => {\n        s.put(e);\n      });\n    }\n    else {\n      this.putA(e)\n    }\n  }\n\n  /**\n   * Put (Update) an element or add an element that was read from a persistence source\n   * and thus already has an assigned global id`.\n   * @param e\n   * @example Put Todo instances.\n```\nstore.put(todo1, todo2);\n```\n   */\n  putN(...e: E[]) {\n    this.putA(e);\n  }\n\n  /**\n   * Put (Update) the array of elements.\n   * @param e\n   * @example Put Todo instances.\n```\nstore.put([todo1, todo2]);\n```\n   */\n  putA(e: E[]) {\n    e.forEach(e => {\n      let guid: string = (<any>e)[this.GUID_KEY]\n      this.entries.set(guid, e)\n      this.updateIDEntry(e);\n    });\n    //Create a new array reference to trigger Angular change detection.\n    let v: E[] = [...Array.from(this.entries.values())];\n    this.notify.next(v);\n    const delta: Delta<E> = { type: ActionTypes.PUT, entries: e };\n    this.notifyDelta.next(delta);\n    Array.from(this.slices.values()).forEach(s => {\n      s.putA(e);\n    });\n  }\n\n  /**\n   * Delete (Update) the array of elements.\n   * @param e\n   * @example Delete todo1.\n```\nstore.delete(todo1]);\n```\n   */\n  delete(e: E | E[]) {\n    if (!Array.isArray(e)) {\n      this.deleteActive(e);\n      const guid = (<any>e)[this.GUID_KEY];\n      this.entries.delete(guid);\n      this.deleteIDEntry(e);\n      Array.from(this.slices.values()).forEach(s => {\n        s.entries.delete(guid);\n      });\n      //Create a new array reference to trigger Angular change detection.\n      let v: E[] = [...Array.from(this.entries.values())];\n      const delta: Delta<E> = { type: ActionTypes.DELETE, entries: [e] };\n      this.notifyAll(v, delta);\n      Array.from(this.slices.values()).forEach(s => {\n        s.delete(e);\n      });\n    }\n    else {\n      this.deleteA(e)\n    }\n\n  }\n\n  /**\n   * Delete N elements.\n   * @param ...e\n   * @example Put Todo instances.\n```\nstore.delete(todo1, todo2);\n```\n   */\n  deleteN(...e: E[]) {\n    this.deleteA(e);\n  }\n\n  /**\n   * Delete N elements.\n   * @param ...e\n   * @example Put Todo instances.\n```\nstore.delete(todo1, todo2);\n```\n   */\n  deleteA(e: E[]) {\n    e.forEach(e => {\n      this.deleteActive(e);\n      const guid = (<any>e)[this.GUID_KEY];\n      this.entries.delete(guid);\n      this.deleteIDEntry(e);\n      Array.from(this.slices.values()).forEach(s => {\n        s.entries.delete(guid);\n      });\n    });\n    //Create a new array reference to trigger Angular change detection.\n    let v: E[] = [...Array.from(this.entries.values())];\n    const delta: Delta<E> = { type: ActionTypes.DELETE, entries: e };\n    this.notifyAll(v, delta);\n    Array.from(this.slices.values()).forEach(s => {\n      s.deleteA(e);\n    });\n  }\n\n  /**\n   * Delete elements by {@link Predicate}.\n   * @param p The predicate.\n   * @example Put Todo instances.\n```\nstore.delete(todo1, todo2);\n```\n   */\n  deleteP(p: Predicate<E>) {\n    const d: E[] = [];\n    Array.from(this.entries.values()).forEach(e => {\n      if (p(e)) {\n        d.push(e);\n        const id = (<any>e)[this.GUID_KEY];\n        this.entries.delete(id);\n        this.deleteActive(e);\n        this.deleteIDEntry(e);\n      }\n    });\n    //Create a new array reference to trigger Angular change detection.\n    let v: E[] = [...Array.from(this.entries.values())];\n    const delta: Delta<E> = { type: ActionTypes.DELETE, entries: d };\n    this.notifyAll(v, delta);\n    Array.from(this.slices.values()).forEach(s => {\n      s.deleteA(d);\n    });\n  }\n\n  /**\n   * If the entity has the `id` key initialized with a value,\n   * then also add the entity to the `idEntries`.\n   *\n   * @param e The element to be added to the `idEntries`.\n   */\n  private updateIDEntry(e: E) {\n    if ((<any>e)[this.ID_KEY]) {\n      this.idEntries.set((<any>e)[this.ID_KEY], e);\n    }\n  }\n\n  /**\n   * If the entity has the `id` key initialized with a value,\n   * then also delete the entity to the `idEntries`.\n   *\n   * @param e The element to be added to the `idEntries`.\n   */\n  private deleteIDEntry(e: E) {\n    if ((<any>e)[this.ID_KEY]) {\n      this.idEntries.delete((<any>e)[this.ID_KEY]);\n    }\n  }\n\n  /**\n   * Resets the store and all contained slice instances to empty.\n   * Also perform delta notification that sends all current store entries.\n   * The ActionType.RESET code is sent with the delta notification.  Slices\n   * send their own delta notification.\n   * \n   * @example Reset the store.\n```\nstore.reset();\n```\n   */\n  reset() {\n    const delta: Delta<E> = {\n      type: ActionTypes.RESET,\n      entries: Array.from(this.entries.values())\n    };\n    this.notifyAll([], delta);\n    this.entries = new Map();\n    Array.from(this.slices.values()).forEach(s => {\n      s.reset();\n    });\n  }\n\n  /**\n   * Call all the notifiers at once.\n   *\n   * @param v\n   * @param delta\n   */\n  protected override notifyAll(v: E[], delta: Delta<E>) {\n    super.notifyAll(v, delta);\n    this.notifyLoading.next(this.loading);\n  }\n}"]}
|
668
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"EStore.js","sourceRoot":"","sources":["../../../../projects/slice/src/lib/EStore.ts"],"names":[],"mappings":"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","sourcesContent":["import { AbstractStore } from './AbstractStore';\nimport { StoreConfig } from './models/StoreConfig';\nimport { GUID } from './utilities';\n\nimport { ActionTypes, Predicate, Delta } from './models/';\nimport { ReplaySubject, of, Observable, combineLatest } from 'rxjs';\nimport { takeWhile, filter, switchMap } from 'rxjs/operators';\nimport { Slice } from './Slice';\n\n/**\n * This `todoFactory` code will be used to illustrate the API examples.  The following\n * utilities are used in the tests and the API Typedoc examples contained here.\n * @example Utilities for API Examples\n * ```\n * export const enum TodoSliceEnum {\n *    COMPLETE = \"Complete\",\n *    INCOMPLETE = \"Incomplete\"\n * }\n * export class Todo {\n *    constructor(\n *         public complete: boolean,\n *         public title: string,\n *         public gid?:string,\n *         public id?:string) {}\n * }\n *\n * export let todos = [new Todo(false, \"You complete me!\"), new Todo(true, \"You completed me!\")];\n *\n * export function todosFactory():Todo[] {\n *   return [new Todo(false, \"You complete me!\"), new Todo(true, \"You completed me!\")];\n * }\n * ```\n */\nexport class EStore<E> extends AbstractStore<E> {\n  /**\n   * Store constructor (Initialization with element is optional)\n   *\n   * perform initial notification to all observers,\n   * such that functions like {@link combineLatest}{}\n   * will execute at least once.\n   * \n   * @param entities The entities to initialize the store with.\n   * @param config The optional configuration instance.\n   * \n   * @example EStore<Todo> Creation\n   * ```\n   * // Initialize the Store\n   * let store: EStore<Todo> = new EStore<Todo>(todosFactory());\n   * ```\n   */\n  constructor(entities: E[] = [], config?: StoreConfig) {\n    super(config);\n    const delta: Delta<E> = { type: ActionTypes.INTIALIZE, entries: entities };\n    this.post(entities);\n    this.notifyDelta.next(delta);\n  }\n\n  /**\n   * Calls complete on all EStore {@link ReplaySubject} instances.\n   *\n   * Call destroy when disposing of the store.\n   */\n  override destroy() {\n    super.destroy();\n    this.notifyLoading.complete();\n    this.notifyActive.complete();\n    this.slices.forEach((slice) => slice.destroy());\n  }\n\n  /**\n   * Toggles the entity:\n   *\n   * If the store contains the entity\n   * it will be deleted.  If the store\n   * does not contains the entity,\n   * it is added.\n   * @param e The entity to toggle\n   * @example Toggle the Todo instance\n   * ```\n   * estore.post(todo);\n   * // Remove todo\n   * estore.toggle(todo);\n   * // Add it back\n   * estore.toggle(todo);\n   * ```\n   */\n  public toggle(e: E) {\n    if (this.contains(e)) {\n      this.delete(e);\n    } else {\n      this.post(e);\n    }\n  }\n\n  /**\n   * Notifies observers when the store is empty.\n   */\n  private notifyActive = new ReplaySubject<Map<string, E>>(1);\n\n  /**\n   * `Map` of active entties. The instance is public and can be used\n   * directly to add and remove active entities, however we recommend\n   * using the {@link addActive} and {@link deleteActive} methods.\n   */\n  public active: Map<string, E> = new Map();\n\n  /**\n   * Add multiple entity entities to active.\n   *\n   * If the entity is not contained in the store it is added\n   * to the store before it is added to `active`.\n   *\n   * Also we clone the map prior to broadcasting it with\n   * `notifyActive` to make sure we will trigger Angular\n   * change detection in the event that it maintains\n   * a reference to the `active` state `Map` instance.\n   *\n   * @example Add todo1 and todo2 as active\n   * ```\n   * addActive(todo1);\n   * addActive(todo2);\n   * ```\n   */\n  public addActive(e: E) {\n    if (this.contains(e)) {\n      this.active.set((<any>e).gid, e);\n      this.notifyActive.next(new Map(this.active));\n    } else {\n      this.post(e);\n      this.active.set((<any>e).gid, e);\n      this.notifyActive.next(new Map(this.active));\n    }\n  }\n\n  /**\n   * Delete an active entity.\n   *\n   * Also we clone the map prior to broadcasting it with\n   * `notifyActive` to make sure we will trigger Angular\n   * change detection in the event that it maintains\n   * a reference to the `active` state `Map` instance.\n   *\n   * @example Remove todo1 and todo2 as active entities\n   * ```\n   * deleteActive(todo1);\n   * deleteActive(todo2);\n   * ```\n   */\n  public deleteActive(e: E) {\n    this.active.delete((<any>e).gid);\n    this.notifyActive.next(new Map(this.active));\n  }\n\n  /**\n   * Clear / reset the active entity map.\n   *\n   * Also we clone the map prior to broadcasting it with\n   * `notifyActive` to make sure we will trigger Angular\n   * change detection in the event that it maintains\n   * a reference to the `active` state `Map` instance.\n   *\n   * @example Clear active todo instances\n   * ```\n   * store.clearActive();\n   * ```\n   */\n  clearActive() {\n    this.active.clear();\n    this.notifyActive.next(new Map(this.active));\n  }\n\n  /**\n   * Observe the active entities.\n   *\n   * @example\n   * ```\n   * let active$ = store.observeActive();\n   * ```\n   */\n  public observeActive() {\n    return this.notifyActive.asObservable();\n  }\n\n  /**\n   * Observe the active entity.\n   * @example\n     <pre>\n    let active$ = source.activeSnapshot();\n    </pre>\n  */\n  public activeSnapshot() {\n    return Array.from(this.active.values());\n  }\n\n  //================================================\n  // LOADING\n  //================================================\n\n  /**\n   * Observable of errors occurred during a load request.\n   *\n   * The error Observable should be created by the\n   * client.\n   */\n  public loadingError!: Observable<any>;\n\n  /**\n   * Notifies observers when the store is loading.\n   *\n   * This is a common pattern found when implementing\n   * `Observable` data sources.\n   */\n  private notifyLoading = new ReplaySubject<boolean>(1);\n\n  /**\n   * The current loading state.  Use loading when fetching new\n   * data for the store.  The default loading state is `true`.\n   *\n   * This is such that if data is fetched asynchronously\n   * in a service, components can wait on loading notification\n   * before attempting to retrieve data from the service.\n   *\n   * Loading could be based on a composite response.  For example\n   * when the stock and mutual funds have loaded, set loading to `false`.\n   */\n  private _loading: boolean = true;\n\n  /**\n   * Sets the current loading state and notifies observers.\n   */\n  set loading(loading: boolean) {\n    this._loading = loading;\n    this.notifyLoading.next(this._loading);\n  }\n\n  /**\n   * @return A snapshot of the loading state.\n   * @example Create a reference to the loading state\n   * ```\n   * const loading:boolean = todoStore.loading;\n   * ```\n   */\n  get loading() {\n    return this._loading;\n  }\n\n  /**\n   * Observe loading.\n   *\n   * Note that this obverable piped through\n   * `takeWhile(v->v, true), such that it will\n   * complete after each emission.\n   *\n   * See:\n   * https://fireflysemantics.medium.com/waiting-on-estore-to-load-8dcbe161613c\n   *\n   * For more details.\n   * Also note that v=>v is the same as v=>v!=false\n   * \n   * @example\n   * ```\n   * const observeLoadingHandler: Observer<boolean> = {\n   *   complete: () => {\n   *     console.log(`Data Loaded and Observable Marked as Complete`);\n   *   }, // completeHandler\n   *   error: () => {\n   *     console.log(`Any Errors?`);\n   *   }, // errorHandler\n   *   next: (l) => {\n   *     console.log(`Data loaded and loading is ${l}`);\n   *   },\n   * };\n   *\n   * const observeLoadingResubscribeHandler: Observer<boolean> = {\n   *   complete: () => {\n   *     console.log(`Data Loaded and Resubscribe Observable Marked as Complete`);\n   *   }, // completeHandler\n   *   error: () => {\n   *     console.log(`Any Resubscribe Errors?`);\n   *   }, // errorHandler\n   *   next: (l) => {\n   *     console.log(`Data loaded and resusbscribe loading  value is ${l}`);\n   *   },\n   * };\n   *\n   * const todoStore: EStore<Todo> = new EStore();\n   * //============================================\n   * // Loading is true by default\n   * //============================================\n   * console.log(`The initial value of loading is ${todoStore.loading}`);\n   * //============================================\n   * // Observe Loading\n   * //============================================\n   * let loading$: Observable<boolean> = todoStore.observeLoading();\n   * loading$.subscribe((l) => console.log(`The value of loading is ${l}`));\n   *\n   * todoStore.loading = false;\n   * loading$.subscribe(observeLoadingHandler);\n   * //============================================\n   * // The subscription no longer fires\n   * //============================================\n   * todoStore.loading = true;\n   * todoStore.loading = false;\n   *\n   * //============================================\n   * // The subscription no longer fires,\n   * // so if we want to observe loading again\n   * // resusbscribe.\n   * //============================================\n   * todoStore.loading = true;\n   * loading$ = todoStore.observeLoading();\n   * loading$.subscribe(observeLoadingResubscribeHandler);\n   * todoStore.loading = false;\n   * ```\n   */\n  public observeLoading() {\n    return this.notifyLoading.asObservable().pipe(takeWhile((v) => v, true));\n  }\n\n  /**\n   * Notfiies when loading has completed.\n   */\n  public observeLoadingComplete() {\n    return this.observeLoading().pipe(\n      filter((loading) => loading == false),\n      switchMap(() => of(true))\n    );\n  }\n\n  //================================================\n  // SEARCHING\n  //================================================\n  /**\n   * Observable of errors occurred during a search request.\n   *\n   * The error Observable should be created by the\n   * client.\n   */\n  public searchError!: Observable<any>;\n\n  /**\n   * Notifies observers that a search is in progress.\n   *\n   * This is a common pattern found when implementing\n   * `Observable` data sources.\n   */\n  private notifySearching = new ReplaySubject<boolean>(1);\n\n  /**\n   * The current `searching` state.  Use `searching`\n   * for example to display a spinnner\n   * when performing a search.\n   * The default `searching` state is `false`.\n   */\n  private _searching: boolean = false;\n\n  /**\n   * Sets the current searching state and notifies observers.\n   */\n  set searching(searching: boolean) {\n    this._searching = searching;\n    this.notifySearching.next(this._searching);\n  }\n\n  /**\n   * @return A snapshot of the searching state.\n   */\n  get searching() {\n    return this._searching;\n  }\n\n  /**\n   * Observe searching.\n   * @example\n     <pre>\n    let searching$ = source.observeSearching();\n    </pre>\n  \n    Note that this obverable piped through\n    `takeWhile(v->v, true), such that it will \n    complete after each emission.\n  \n    See:\n    https://medium.com/@ole.ersoy/waiting-on-estore-to-load-8dcbe161613c\n  \n    For more details.\n  */\n  public observeSearching(): Observable<boolean> {\n    return this.notifySearching.asObservable().pipe(takeWhile((v) => v, true));\n  }\n\n  /**\n   * Notfiies when searching has completed.\n   */\n  public observeSearchingComplete(): Observable<boolean> {\n    return this.observeSearching().pipe(\n      filter((searching) => searching == false),\n      switchMap(() => of(true))\n    );\n  }\n\n  /**\n   * Store slices\n   */\n  private slices: Map<string, Slice<E>> = new Map();\n\n  /**\n   * Adds a slice to the store and keys it by the slices label.\n   *\n   * @param p\n   * @param label\n   * \n   * @example Setup a Todo Slice for COMPLETE Todos\n```\nsource.addSlice(todo => todo.complete, TodoSlices.COMPLETE);\n```\n   */\n  addSlice(p: Predicate<E>, label: string) {\n    const slice: Slice<E> = new Slice(label, p, this);\n    this.slices.set(slice.label, slice);\n  }\n\n  /**\n   * Remove a slice\n   * @param label The label identifying the slice\n   * \n   * @example Remove the TodoSlices.COMPLETE Slice\n```\nsource.removeSlice(TodoSlices.COMPLETE);\n```\n   */\n  removeSlice(label: string) {\n    this.slices.delete(label);\n  }\n\n  /**\n   * Get a slice\n   * @param label The label identifying the slice\n   * @return The Slice instance or undefined \n   * \n   * @example Get the TodoSlices.COMPLETE slice\n```\nsource.getSlice(TodoSlices.COMPLETE);\n```\n   */\n  getSlice(label: string): Slice<E> | undefined {\n    return this.slices.get(label);\n  }\n\n  /**\n   * Post (Add a new) element(s) to the store.\n   * @param e An indiidual entity or an array of entities\n   * @example Post a Todo instance.\n   *\n   *```\n   * store.post(todo);\n   *```\n   */\n  post(e: E | E[]) {\n    if (!Array.isArray(e)) {\n      const guid: string = (<any>e)[this.GUID_KEY]\n        ? (<any>e)[this.GUID_KEY]\n        : GUID();\n      (<any>e)[this.GUID_KEY] = guid;\n      this.entries.set(guid, e);\n      this.updateIDEntry(e);\n      Array.from(this.slices.values()).forEach((s) => {\n        s.post(e);\n      });\n      //Create a new array reference to trigger Angular change detection.\n      let v: E[] = [...Array.from(this.entries.values())];\n      const delta: Delta<E> = { type: ActionTypes.POST, entries: [e] };\n      this.notifyAll(v, delta);\n    } else {\n      this.postA(e);\n    }\n  }\n\n  /**\n   * Post N entities to the store.\n   * @param ...e\n   * @example Post two Todo instances.\n   * ```\n   * store.post(todo1, todo2);\n   * ```\n   */\n  postN(...e: E[]) {\n    e.forEach((e) => {\n      const guid: string = (<any>e)[this.GUID_KEY]\n        ? (<any>e)[this.GUID_KEY]\n        : GUID();\n      (<any>e)[this.GUID_KEY] = guid;\n      this.entries.set(guid, e);\n      this.updateIDEntry(e);\n    });\n    Array.from(this.slices.values()).forEach((s) => {\n      s.postA(e);\n    });\n    //Create a new array reference to trigger Angular change detection.\n    let v: E[] = [...Array.from(this.entries.values())];\n    const delta: Delta<E> = { type: ActionTypes.POST, entries: e };\n    this.notifyAll(v, delta);\n  }\n\n  /**\n   * Post (Add) an array of elements to the store.\n   * @param e\n   * @example Post a Todo array.\n   *\n   * ```\n   * store.post([todo1, todo2]);\n   * ```\n   */\n  postA(e: E[]) {\n    this.postN(...e);\n  }\n\n  /**\n   * Put (Update) an entity.\n   * @param e\n   * @example Put a Todo instance.\n   * ```\n   * store.put(todo1);\n   * ```\n   */\n  put(e: E | E[]) {\n    if (!Array.isArray(e)) {\n      let id: string = (<any>e)[this.GUID_KEY];\n      this.entries.set(id, e);\n      this.updateIDEntry(e);\n      let v: E[] = [...Array.from(this.entries.values())];\n      this.notify.next(v);\n      const delta: Delta<E> = { type: ActionTypes.PUT, entries: [e] };\n      this.notifyDelta.next(delta);\n      Array.from(this.slices.values()).forEach((s) => {\n        s.put(e);\n      });\n    } else {\n      this.putA(e);\n    }\n  }\n\n  /**\n   * Put (Update) an element or add an element that was read from a persistence source\n   * and thus already has an assigned global id`.\n   * @param e The enetity instances to update.\n   * @example Put N Todo instances.\n   *\n   * ```\n   * store.put(todo1, todo2);\n   * ```\n   */\n  putN(...e: E[]) {\n    this.putA(e);\n  }\n\n  /**\n   * Put (Update) the array of enntities.\n   * @param e The array of enntities to update\n   * @example Put an array of Todo instances.\n   * ```\n   * store.put([todo1, todo2]);\n   * ```\n   */\n  putA(e: E[]) {\n    e.forEach((e) => {\n      let guid: string = (<any>e)[this.GUID_KEY];\n      this.entries.set(guid, e);\n      this.updateIDEntry(e);\n    });\n    //Create a new array reference to trigger Angular change detection.\n    let v: E[] = [...Array.from(this.entries.values())];\n    this.notify.next(v);\n    const delta: Delta<E> = { type: ActionTypes.PUT, entries: e };\n    this.notifyDelta.next(delta);\n    Array.from(this.slices.values()).forEach((s) => {\n      s.putA(e);\n    });\n  }\n\n  /**\n   * Delete (Update) the array of elements.\n   * @param e\n   * @example Delete todo1.\n   * ```\n   * store.delete(todo1]);\n   * ```\n   */\n  delete(e: E | E[]) {\n    if (!Array.isArray(e)) {\n      this.deleteActive(e);\n      const guid = (<any>e)[this.GUID_KEY];\n      this.entries.delete(guid);\n      this.deleteIDEntry(e);\n      Array.from(this.slices.values()).forEach((s) => {\n        s.entries.delete(guid);\n      });\n      //Create a new array reference to trigger Angular change detection.\n      let v: E[] = [...Array.from(this.entries.values())];\n      const delta: Delta<E> = { type: ActionTypes.DELETE, entries: [e] };\n      this.notifyAll(v, delta);\n      Array.from(this.slices.values()).forEach((s) => {\n        s.delete(e);\n      });\n    } else {\n      this.deleteA(e);\n    }\n  }\n\n  /**\n   * Delete N elements.\n   * @param ...e\n   * @example Delete N Todo instance argument.\n   * ```\n   * store.deleteN(todo1, todo2);\n   * ```\n   */\n  deleteN(...e: E[]) {\n    this.deleteA(e);\n  }\n\n  /**\n   * Delete an array of elements.\n   * @param e The array of instances to be deleted\n   * @example Delete the array of Todo instances.\n   * ```\n   * store.deleteA([todo1, todo2]);\n   * ```\n   */\n  deleteA(e: E[]) {\n    e.forEach((e) => {\n      this.deleteActive(e);\n      const guid = (<any>e)[this.GUID_KEY];\n      this.entries.delete(guid);\n      this.deleteIDEntry(e);\n      Array.from(this.slices.values()).forEach((s) => {\n        s.entries.delete(guid);\n      });\n    });\n    //Create a new array reference to trigger Angular change detection.\n    let v: E[] = [...Array.from(this.entries.values())];\n    const delta: Delta<E> = { type: ActionTypes.DELETE, entries: e };\n    this.notifyAll(v, delta);\n    Array.from(this.slices.values()).forEach((s) => {\n      s.deleteA(e);\n    });\n  }\n\n  /**\n   * Delete elements by {@link Predicate}.\n   * @param p The predicate.\n   * @example Delete the Todo instances.\n   * ```\n   * store.delete(todo1, todo2);\n   * ```\n   */\n  deleteP(p: Predicate<E>) {\n    const d: E[] = [];\n    Array.from(this.entries.values()).forEach((e) => {\n      if (p(e)) {\n        d.push(e);\n        const id = (<any>e)[this.GUID_KEY];\n        this.entries.delete(id);\n        this.deleteActive(e);\n        this.deleteIDEntry(e);\n      }\n    });\n    //Create a new array reference to trigger Angular change detection.\n    let v: E[] = [...Array.from(this.entries.values())];\n    const delta: Delta<E> = { type: ActionTypes.DELETE, entries: d };\n    this.notifyAll(v, delta);\n    Array.from(this.slices.values()).forEach((s) => {\n      s.deleteA(d);\n    });\n  }\n\n  /**\n   * If the entity has the `id` key initialized with a value,\n   * then also add the entity to the `idEntries`.\n   *\n   * @param e The element to be added to the `idEntries`.\n   */\n  private updateIDEntry(e: E) {\n    if ((<any>e)[this.ID_KEY]) {\n      this.idEntries.set((<any>e)[this.ID_KEY], e);\n    }\n  }\n\n  /**\n   * If the entity has the `id` key initialized with a value,\n   * then also delete the entity to the `idEntries`.\n   *\n   * @param e The element to be added to the `idEntries`.\n   */\n  private deleteIDEntry(e: E) {\n    if ((<any>e)[this.ID_KEY]) {\n      this.idEntries.delete((<any>e)[this.ID_KEY]);\n    }\n  }\n\n  /**\n   * Resets the store and all contained slice instances to empty.\n   * Also perform delta notification that sends all current store entries.\n   * The ActionType.RESET code is sent with the delta notification.  Slices\n   * send their own delta notification.\n   *\n   * @example Reset the store.\n   * ```\n   * store.reset();\n   * ```\n   */\n  reset() {\n    const delta: Delta<E> = {\n      type: ActionTypes.RESET,\n      entries: Array.from(this.entries.values()),\n    };\n    this.notifyAll([], delta);\n    this.entries = new Map();\n    Array.from(this.slices.values()).forEach((s) => {\n      s.reset();\n    });\n  }\n\n  /**\n   * Call all the notifiers at once.\n   *\n   * @param v\n   * @param delta\n   */\n  protected override notifyAll(v: E[], delta: Delta<E>) {\n    super.notifyAll(v, delta);\n    this.notifyLoading.next(this.loading);\n  }\n}\n"]}
|