@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/README.md
CHANGED
@@ -2,15 +2,17 @@
|
|
2
2
|
|
3
3
|
# @fireflysemantics/slice
|
4
4
|
|
5
|
-
##
|
5
|
+
## Table of Contents
|
6
6
|
|
7
7
|
- [Overview](#overview)
|
8
8
|
- [Why Slice](#why-slice)
|
9
9
|
- [Install](#install)
|
10
|
+
- [API Reference](#api-documentation)
|
10
11
|
- [Object Store Core Use Cases](#object-store-core-use-cases)
|
11
12
|
- [Entity Store Core Use Cases](#entity-store-core-use-cases)
|
12
13
|
- [Features](#features)
|
13
|
-
- [Documentatino and Media](#firefly-semantics-slice-development-center-media-and-documentation)
|
14
|
+
- [Help Center Documentatino and Media](#firefly-semantics-slice-development-center-media-and-documentation)
|
15
|
+
- [Getting Help](#getting-help)
|
14
16
|
|
15
17
|
## Overview
|
16
18
|
|
@@ -366,13 +368,43 @@ console.log(
|
|
366
368
|
);
|
367
369
|
|
368
370
|
//============================================
|
369
|
-
// API: count()
|
371
|
+
// API: count() and snapshotCount()
|
370
372
|
//
|
371
|
-
//
|
373
|
+
// Take snapshot and observable
|
374
|
+
// the counts of store entities
|
372
375
|
//============================================
|
373
|
-
|
374
|
-
|
376
|
+
|
377
|
+
const completePredicate: Predicate<Todo> = function pred(t: Todo) {
|
378
|
+
return t.complete;
|
379
|
+
};
|
380
|
+
|
381
|
+
const incompletePredicate: Predicate<Todo> = function pred(t: Todo) {
|
382
|
+
return !t.complete;
|
383
|
+
};
|
384
|
+
|
385
|
+
store.count().subscribe((c) => {
|
386
|
+
console.log(`The observed count of Todo entities is ${c}`);
|
375
387
|
});
|
388
|
+
store.count(incompletePredicate).subscribe((c) => {
|
389
|
+
console.log(`The observed count of incomplete Todo enttiies is ${c}`);
|
390
|
+
});
|
391
|
+
store.count(completePredicate).subscribe((c) => {
|
392
|
+
console.log(`The observed count of complete Todo enttiies is ${c}`);
|
393
|
+
});
|
394
|
+
|
395
|
+
const snapshotCount = store.countSnapshot(completePredicate);
|
396
|
+
console.log(`The count is ${snapshotCount}`);
|
397
|
+
|
398
|
+
const completeSnapshotCount = store.countSnapshot(completePredicate);
|
399
|
+
console.log(
|
400
|
+
`The complete Todo Entity Snapshot count is ${completeSnapshotCount}`
|
401
|
+
);
|
402
|
+
|
403
|
+
const incompleteSnapshotCount = store.countSnapshot(incompletePredicate);
|
404
|
+
console.log(
|
405
|
+
`The incomplete Todo Entity Snapshot count is ${incompleteSnapshotCount}`
|
406
|
+
);
|
407
|
+
|
376
408
|
|
377
409
|
//============================================
|
378
410
|
// API: toggle()
|
@@ -563,11 +595,13 @@ store.isEmpty().subscribe((empty) => {
|
|
563
595
|
- [Minimal Slice Object Store](https://developer.fireflysemantics.com/examples/examples--slice--minimal-slice-object-store)
|
564
596
|
- [Minimal Angular Slice Object Store State Service](https://developer.fireflysemantics.com/examples/examples--slice--minial-angular-slice-object-store-state-service)
|
565
597
|
|
566
|
-
# API
|
598
|
+
# API Reference
|
599
|
+
|
600
|
+
The [Typedoc API Reference](https://fireflysemantics.github.io/slice/typedoc/) includes simple examples of how to apply the API for the various stores, methods, and classes included.
|
567
601
|
|
568
|
-
|
602
|
+
## Getting Help
|
569
603
|
|
570
|
-
|
604
|
+
[Firefly Semantics Slice on Stackoverflow](https://stackoverflow.com/questions/tagged/fireflysemantics-slice)
|
571
605
|
|
572
606
|
## Build
|
573
607
|
|
@@ -575,9 +609,7 @@ Run `npm run c` to build the project. The build artifacts will be stored in the
|
|
575
609
|
|
576
610
|
## Running unit tests
|
577
611
|
|
578
|
-
Run `npm run test` to execute the unit tests
|
579
|
-
|
580
|
-
|
612
|
+
Run `npm run test` to execute the unit tests.
|
581
613
|
|
582
614
|
## Tests
|
583
615
|
|
@@ -1,11 +1,11 @@
|
|
1
|
-
import { ReplaySubject } from
|
2
|
-
import { map } from
|
1
|
+
import { ReplaySubject } from 'rxjs';
|
2
|
+
import { map } from 'rxjs/operators';
|
3
3
|
const { freeze } = Object;
|
4
|
-
const ESTORE_DEFAULT_ID_KEY =
|
5
|
-
const ESTORE_DEFAULT_GID_KEY =
|
4
|
+
const ESTORE_DEFAULT_ID_KEY = 'id';
|
5
|
+
const ESTORE_DEFAULT_GID_KEY = 'gid';
|
6
6
|
export const ESTORE_CONFIG_DEFAULT = freeze({
|
7
7
|
idKey: ESTORE_DEFAULT_ID_KEY,
|
8
|
-
guidKey: ESTORE_DEFAULT_GID_KEY
|
8
|
+
guidKey: ESTORE_DEFAULT_GID_KEY,
|
9
9
|
});
|
10
10
|
export class AbstractStore {
|
11
11
|
constructor(config) {
|
@@ -40,7 +40,6 @@ export class AbstractStore {
|
|
40
40
|
* An Observable<E[]> reference
|
41
41
|
* to the entities in the store or
|
42
42
|
* Slice instance.
|
43
|
-
*
|
44
43
|
*/
|
45
44
|
this.obs = this.observe();
|
46
45
|
this.config = config
|
@@ -96,14 +95,15 @@ export class AbstractStore {
|
|
96
95
|
}
|
97
96
|
/**
|
98
97
|
* Observe store state changes.
|
98
|
+
*
|
99
99
|
* @param sort Optional sorting function yielding a sorted observable.
|
100
100
|
* @example
|
101
|
-
|
102
|
-
|
103
|
-
|
104
|
-
|
105
|
-
|
106
|
-
|
101
|
+
* ```
|
102
|
+
* let todos$ = source.observe();
|
103
|
+
* //or with a sort by title function
|
104
|
+
* let todos$ = source.observe((a, b)=>(a.title > b.title ? -1 : 1));
|
105
|
+
* ```
|
106
|
+
*/
|
107
107
|
observe(sort) {
|
108
108
|
if (sort) {
|
109
109
|
return this.notify.pipe(map((e) => e.sort(sort)));
|
@@ -112,10 +112,11 @@ export class AbstractStore {
|
|
112
112
|
}
|
113
113
|
/**
|
114
114
|
* Observe delta updates.
|
115
|
+
*
|
115
116
|
* @example
|
116
|
-
|
117
|
-
|
118
|
-
|
117
|
+
* ```
|
118
|
+
* let todos$ = source.observeDelta();
|
119
|
+
* ```
|
119
120
|
*/
|
120
121
|
observeDelta() {
|
121
122
|
return this.notifyDelta.asObservable();
|
@@ -126,10 +127,10 @@ export class AbstractStore {
|
|
126
127
|
* @return A hot {@link Observable} that indicates whether the store is empty.
|
127
128
|
*
|
128
129
|
* @example
|
129
|
-
|
130
|
-
|
131
|
-
|
132
|
-
|
130
|
+
* ```
|
131
|
+
* const empty$:Observable<boolean> = source.isEmpty();
|
132
|
+
* ```
|
133
|
+
*/
|
133
134
|
isEmpty() {
|
134
135
|
return this.notify.pipe(map((entries) => entries.length == 0));
|
135
136
|
}
|
@@ -139,10 +140,10 @@ export class AbstractStore {
|
|
139
140
|
* @return A snapshot that indicates whether the store is empty.
|
140
141
|
*
|
141
142
|
* @example
|
142
|
-
|
143
|
-
|
144
|
-
|
145
|
-
|
143
|
+
* ```
|
144
|
+
* const empty:boolean = source.isEmptySnapshot();
|
145
|
+
* ```
|
146
|
+
*/
|
146
147
|
isEmptySnapshot() {
|
147
148
|
return Array.from(this.entries.values()).length == 0;
|
148
149
|
}
|
@@ -192,7 +193,7 @@ export class AbstractStore {
|
|
192
193
|
</pre>
|
193
194
|
*/
|
194
195
|
contains(target) {
|
195
|
-
if (typeof target ===
|
196
|
+
if (typeof target === 'string') {
|
196
197
|
return this.entries.get(target) ? true : false;
|
197
198
|
}
|
198
199
|
const guid = target[this.config.guidKey];
|
@@ -210,7 +211,7 @@ export class AbstractStore {
|
|
210
211
|
</pre>
|
211
212
|
*/
|
212
213
|
containsById(target) {
|
213
|
-
if (typeof target ===
|
214
|
+
if (typeof target === 'string') {
|
214
215
|
return this.idEntries.get(target) ? true : false;
|
215
216
|
}
|
216
217
|
const id = target[this.config.idKey];
|
@@ -242,14 +243,14 @@ export class AbstractStore {
|
|
242
243
|
* @param p The predicate used to query for the selection.
|
243
244
|
* @return A snapshot array containing the entities that match the predicate.
|
244
245
|
*
|
245
|
-
* @example Select all the
|
246
|
-
|
247
|
-
|
248
|
-
|
246
|
+
* @example Select all the Todo instances where the title length is greater than 100.
|
247
|
+
* ```
|
248
|
+
* let todos:Todo[]=store.select(todo=>todo.title.length>100);
|
249
|
+
* ```
|
249
250
|
*/
|
250
251
|
select(p) {
|
251
252
|
const selected = [];
|
252
|
-
Array.from(this.entries.values()).forEach(e => {
|
253
|
+
Array.from(this.entries.values()).forEach((e) => {
|
253
254
|
if (p(e)) {
|
254
255
|
selected.push(e);
|
255
256
|
}
|
@@ -261,10 +262,11 @@ export class AbstractStore {
|
|
261
262
|
* @param e1 The first entity
|
262
263
|
* @param e2 The second entity
|
263
264
|
* @return true if the two entities have equal GUID ids
|
264
|
-
*
|
265
|
-
|
266
|
-
|
267
|
-
|
265
|
+
*
|
266
|
+
* @example Compare todo1 with todo2 by gid.
|
267
|
+
* ```
|
268
|
+
* if (equalsByGUID(todo1, todo2)){...};
|
269
|
+
* ```
|
268
270
|
*/
|
269
271
|
equalsByGUID(e1, e2) {
|
270
272
|
return e1[this.GUID_KEY] == e2[this.GUID_KEY];
|
@@ -274,16 +276,18 @@ export class AbstractStore {
|
|
274
276
|
* @param e1 The first entity
|
275
277
|
* @param e2 The second entity
|
276
278
|
* @return true if the two entities have equal ID ids
|
277
|
-
*
|
278
|
-
|
279
|
-
|
280
|
-
|
279
|
+
*
|
280
|
+
* @example Compare todo1 with todo2 by id.
|
281
|
+
*
|
282
|
+
* ```
|
283
|
+
* if (equalsByID(todo1, todo2)){...};
|
284
|
+
* ```
|
281
285
|
*/
|
282
286
|
equalsByID(e1, e2) {
|
283
287
|
return e1[this.ID_KEY] == e2[this.ID_KEY];
|
284
288
|
}
|
285
289
|
/**
|
286
|
-
* Calls complete on all {@link
|
290
|
+
* Calls complete on all {@link ReplaySubject} instances.
|
287
291
|
*
|
288
292
|
* Call destroy when disposing of the store.
|
289
293
|
*/
|
@@ -293,4 +297,4 @@ export class AbstractStore {
|
|
293
297
|
this.notifyQuery.complete();
|
294
298
|
}
|
295
299
|
}
|
296
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"AbstractStore.js","sourceRoot":"","sources":["../../../../projects/slice/src/lib/AbstractStore.ts"],"names":[],"mappings":"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","sourcesContent":["import { ReplaySubject, Observable } from \"rxjs\"\nimport { map } from \"rxjs/operators\"\nimport { Delta, Predicate } from \"./models\"\nimport { StoreConfig } from \"./models/StoreConfig\"\n\nconst { freeze } = Object\n\nconst ESTORE_DEFAULT_ID_KEY = \"id\"\nconst ESTORE_DEFAULT_GID_KEY = \"gid\"\n\nexport const ESTORE_CONFIG_DEFAULT: StoreConfig = freeze({\n  idKey: ESTORE_DEFAULT_ID_KEY,\n  guidKey: ESTORE_DEFAULT_GID_KEY\n});\n\nexport abstract class AbstractStore<E> {\n\n  /**\n   * The configuration for the store.\n   */\n   public config: StoreConfig;\n\n   constructor(config?: StoreConfig) {\n     this.config = config\n       ? freeze({ ...ESTORE_CONFIG_DEFAULT, ...config })\n       : ESTORE_CONFIG_DEFAULT;\n   }\n \n  /**\n   * Notifies observers of the store query.\n   */\n  protected notifyQuery = new ReplaySubject<string>(1);\n\n  /**\n   * The current query state.\n   */\n  protected _query: string = '';\n\n  /**\n   * Sets the current query state and notifies observers.\n   */\n  set query(query: string) {\n    this._query = query;\n    this.notifyQuery.next(this._query);\n  }\n\n  /**\n   * @return A snapshot of the query state.\n   */\n  get query() {\n    return this._query;\n  }\n\n  /**\n   * Observe the query.\n   * @example\n     <pre>\n    let query$ = source.observeQuery();\n    </pre>\n  */\n  public observeQuery() {\n    return this.notifyQuery.asObservable();\n  }\n\n\n  /**\n   * The current id key for the EStore instance.\n   * @return this.config.idKey;\n   */\n  get ID_KEY(): string {\n    return this.config.idKey\n  }\n  /**\n   * The current guid key for the EStore instance.\n   * @return this.config.guidKey;\n   */\n  get GUID_KEY(): string {\n    return this.config.guidKey\n  }\n\n  /**\n   * Primary index for the stores elements.\n   */\n  public entries: Map<string, E> = new Map()\n\n  /**\n   * The element entries that are keyed by\n   * an id generated on the server.\n   */\n  public idEntries: Map<string, E> = new Map()\n\n  /**\n   * Create notifications that broacast\n   * the entire set of entries.\n   */\n  protected notify = new ReplaySubject<E[]>(1)\n\n  /**\n   * Create notifications that broacast\n   * store or slice delta state changes.\n   */\n  protected notifyDelta = new ReplaySubject<Delta<E>>(1)\n\n  /**\n   * Call all the notifiers at once.\n   *\n   * @param v\n   * @param delta\n   */\n  protected notifyAll(v: E[], delta: Delta<E>) {\n    this.notify.next(v);\n    this.notifyDelta.next(delta);\n  }\n\n  /**\n   * Observe store state changes.\n   * @param sort Optional sorting function yielding a sorted observable.\n   * @example\n```\nlet todos$ = source.observe();\n//or with a sort by title function\nlet todos$ = source.observe((a, b)=>(a.title > b.title ? -1 : 1));\n```\n  */\n  public observe(sort?: (a: any, b: any) => number): Observable<E[]> {\n    if (sort) {\n      return this.notify.pipe(map((e: E[]) => e.sort(sort)));\n    }\n    return this.notify.asObservable();\n  }\n\n  /**\n   * An Observable<E[]> reference\n   * to the entities in the store or\n   * Slice instance.\n   * \n   */\n   public obs: Observable<E[]> = this.observe()\n\n\n\n  /**\n   * Observe delta updates.\n   * @example\n     <pre>\n     let todos$ = source.observeDelta();\n     </pre>\n   */\n  public observeDelta(): Observable<Delta<E>> {\n    return this.notifyDelta.asObservable();\n  }\n\n  /**\n   * Check whether the store is empty.\n   * \n   * @return A hot {@link Observable} that indicates whether the store is empty.\n   * \n   * @example\n    <pre>\n    source.isEmpty();\n    </pre>\n  */\n  isEmpty(): Observable<boolean> {\n    return this.notify.pipe(\n      map((entries: E[]) => entries.length == 0)\n    );\n  }\n\n  /**\n   * Check whether the store is empty.\n   * \n   * @return A snapshot that indicates whether the store is empty.\n   * \n   * @example\n     <pre>\n    source.isEmpty();\n    </pre>\n  */\n  isEmptySnapshot(): boolean {\n    return Array.from(this.entries.values()).length == 0;\n  }\n\n  /**\n   * Returns the number of entries contained.\n   * @param p The predicate to apply in order to filter the count\n   */\n  count(p?: Predicate<E>): Observable<number> {\n    if (p) {\n      return this.notify.pipe(\n        map((e: E[]) => e.reduce((total, e) => total + (p(e) ? 1 : 0), 0))\n      );\n    }\n    return this.notify.pipe(map((entries: E[]) => entries.length));\n  }\n\n  /**\n   * Returns a snapshot of the number of entries contained in the store.\n   * @param p The predicate to apply in order to filter the count\n   */\n  countSnapshot(p?: Predicate<E>): number {\n    if (p) {\n      return Array.from(this.entries.values()).filter(p).length;\n    }\n    return Array.from(this.entries.values()).length;\n  }\n\n  /**\n   * Snapshot of all entries.\n   * \n   * @return Snapshot array of all the elements the entities the store contains.\n   * \n   * @example Observe a snapshot of all the entities in the store.\n```\nlet selectedTodos:Todo[] = source.allSnapshot();\n```\n   */\n  allSnapshot(): E[] {\n    return Array.from(this.entries.values());\n  }\n\n  /**\n   * Returns true if the entries contain the identified instance.\n   * \n   * @param target Either an instance of type `E` or a `guid` identifying the instance. \n   * @param byId Whether the lookup should be performed with the `id` key rather than the `guid`.\n   * @returns true if the instance identified by the guid exists, false otherwise.\n   * \n   * @example\n     <pre>\n     let contains:boolean = source.contains(guid);\n     </pre>\n   */\n  contains(target: E | string):boolean {\n    if (typeof target === \"string\") {\n      return this.entries.get(target) ? true : false;\n    }\n    const guid: string = (<any>target)[this.config.guidKey];\n    return this.entries.get(guid) ? true : false;\n  }\n\n  /**\n   * Returns true if the entries contain the identified instance.\n   * \n   * @param target Either an instance of type `E` or a `id` identifying the instance. \n   * @returns true if the instance identified by the `id` exists, false otherwise.\n   * \n   * @example\n     <pre>\n     let contains:boolean = source.contains(guid);\n     </pre>\n   */\n  containsById(target: E | string):boolean {\n    if (typeof target === \"string\") {\n      return this.idEntries.get(target) ? true : false;\n    }\n    const id: string = (<any>target)[this.config.idKey];\n    return this.idEntries.get(id) ? true : false;\n  }\n\n  /**\n   * Find and return the entity identified by the GUID parameter\n   * if it exists and return it.\n   *\n   * @param guid\n   * @return The entity instance if it exists, null otherwise\n   */\n  findOne(guid: string): E | undefined{\n    return this.entries.get(guid);\n  }\n\n  /**\n   * Find and return the entity identified by the ID parameter\n   * if it exists and return it.\n   *\n   * @param id\n   * @return The entity instance if it exists, null otherwise\n   */\n  findOneByID(id: string): E | undefined {\n    return this.idEntries.get(id);\n  }\n\n  /**\n   * Snapshot of the entries that match the predicate.\n   *\n   * @param p The predicate used to query for the selection.\n   * @return A snapshot array containing the entities that match the predicate.\n   * \n   * @example Select all the `Todo` instance where the `title` length is greater than 100. \n```\nlet todos:Todo[]=store.select(todo=>todo.title.length>100);\n```\n   */\n  select(p: Predicate<E>): E[] {\n    const selected: E[] = [];\n    Array.from(this.entries.values()).forEach(e => {\n      if (p(e)) {\n        selected.push(e);\n      }\n    });\n    return selected;\n  }\n\n  /** \n   * Compare entities by GUID \n   * @param e1 The first entity\n   * @param e2 The second entity\n   * @return true if the two entities have equal GUID ids\n   * @example Compare `todo1` with `todo2` by `gid`.\n```\nif (equalsByGUID(todo1, todo2)){...};\n```\n   */\n  equalsByGUID(e1:any, e2:any) {\n    return e1[this.GUID_KEY] == e2[this.GUID_KEY];\n  }\n\n  /**\n   * Compare entities by ID \n   * @param e1 The first entity\n   * @param e2 The second entity\n   * @return true if the two entities have equal ID ids\n   * @example Compare `todo1` with `todo2` by `id`.\n```\nif (equalsByID(todo1, todo2)){...};\n```\n   */\n  equalsByID(e1:any, e2:any) {\n    return e1[this.ID_KEY] == e2[this.ID_KEY];\n  }\n  /**\n   * Calls complete on all {@link BehaviorSubject} instances.\n   * \n   * Call destroy when disposing of the store.\n   */\n  destroy() {\n    this.notify.complete();\n    this.notifyDelta.complete();\n    this.notifyQuery.complete();\n  }\n}"]}
|
300
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"AbstractStore.js","sourceRoot":"","sources":["../../../../projects/slice/src/lib/AbstractStore.ts"],"names":[],"mappings":"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","sourcesContent":["import { ReplaySubject, Observable } from 'rxjs';\nimport { map } from 'rxjs/operators';\nimport { Delta, Predicate } from './models';\nimport { StoreConfig } from './models/StoreConfig';\n\nconst { freeze } = Object;\n\nconst ESTORE_DEFAULT_ID_KEY = 'id';\nconst ESTORE_DEFAULT_GID_KEY = 'gid';\n\nexport const ESTORE_CONFIG_DEFAULT: StoreConfig = freeze({\n  idKey: ESTORE_DEFAULT_ID_KEY,\n  guidKey: ESTORE_DEFAULT_GID_KEY,\n});\n\nexport abstract class AbstractStore<E> {\n  /**\n   * The configuration for the store.\n   */\n  public config: StoreConfig;\n\n  constructor(config?: StoreConfig) {\n    this.config = config\n      ? freeze({ ...ESTORE_CONFIG_DEFAULT, ...config })\n      : ESTORE_CONFIG_DEFAULT;\n  }\n\n  /**\n   * Notifies observers of the store query.\n   */\n  protected notifyQuery = new ReplaySubject<string>(1);\n\n  /**\n   * The current query state.\n   */\n  protected _query: string = '';\n\n  /**\n   * Sets the current query state and notifies observers.\n   */\n  set query(query: string) {\n    this._query = query;\n    this.notifyQuery.next(this._query);\n  }\n\n  /**\n   * @return A snapshot of the query state.\n   */\n  get query() {\n    return this._query;\n  }\n\n  /**\n   * Observe the query.\n   * @example\n     <pre>\n    let query$ = source.observeQuery();\n    </pre>\n  */\n  public observeQuery() {\n    return this.notifyQuery.asObservable();\n  }\n\n  /**\n   * The current id key for the EStore instance.\n   * @return this.config.idKey;\n   */\n  get ID_KEY(): string {\n    return this.config.idKey;\n  }\n  /**\n   * The current guid key for the EStore instance.\n   * @return this.config.guidKey;\n   */\n  get GUID_KEY(): string {\n    return this.config.guidKey;\n  }\n\n  /**\n   * Primary index for the stores elements.\n   */\n  public entries: Map<string, E> = new Map();\n\n  /**\n   * The element entries that are keyed by\n   * an id generated on the server.\n   */\n  public idEntries: Map<string, E> = new Map();\n\n  /**\n   * Create notifications that broacast\n   * the entire set of entries.\n   */\n  protected notify = new ReplaySubject<E[]>(1);\n\n  /**\n   * Create notifications that broacast\n   * store or slice delta state changes.\n   */\n  protected notifyDelta = new ReplaySubject<Delta<E>>(1);\n\n  /**\n   * Call all the notifiers at once.\n   *\n   * @param v\n   * @param delta\n   */\n  protected notifyAll(v: E[], delta: Delta<E>) {\n    this.notify.next(v);\n    this.notifyDelta.next(delta);\n  }\n\n  /**\n   * Observe store state changes.\n   *\n   * @param sort Optional sorting function yielding a sorted observable.\n   * @example\n   * ```\n   * let todos$ = source.observe();\n   * //or with a sort by title function\n   * let todos$ = source.observe((a, b)=>(a.title > b.title ? -1 : 1));\n   * ```\n   */\n  public observe(sort?: (a: any, b: any) => number): Observable<E[]> {\n    if (sort) {\n      return this.notify.pipe(map((e: E[]) => e.sort(sort)));\n    }\n    return this.notify.asObservable();\n  }\n\n  /**\n   * An Observable<E[]> reference\n   * to the entities in the store or\n   * Slice instance.\n   */\n  public obs: Observable<E[]> = this.observe();\n\n  /**\n   * Observe delta updates.\n   *\n   * @example\n   * ```\n   * let todos$ = source.observeDelta();\n   * ```\n   */\n  public observeDelta(): Observable<Delta<E>> {\n    return this.notifyDelta.asObservable();\n  }\n\n  /**\n   * Check whether the store is empty.\n   *\n   * @return A hot {@link Observable} that indicates whether the store is empty.\n   *\n   * @example\n   * ```\n   * const empty$:Observable<boolean> = source.isEmpty();\n   * ```\n   */\n  isEmpty(): Observable<boolean> {\n    return this.notify.pipe(map((entries: E[]) => entries.length == 0));\n  }\n\n  /**\n   * Check whether the store is empty.\n   *\n   * @return A snapshot that indicates whether the store is empty.\n   *\n   * @example\n   * ```\n   * const empty:boolean = source.isEmptySnapshot();\n   * ```\n   */\n  isEmptySnapshot(): boolean {\n    return Array.from(this.entries.values()).length == 0;\n  }\n\n  /**\n   * Returns the number of entries contained.\n   * @param p The predicate to apply in order to filter the count\n   */\n  count(p?: Predicate<E>): Observable<number> {\n    if (p) {\n      return this.notify.pipe(\n        map((e: E[]) => e.reduce((total, e) => total + (p(e) ? 1 : 0), 0))\n      );\n    }\n    return this.notify.pipe(map((entries: E[]) => entries.length));\n  }\n\n  /**\n   * Returns a snapshot of the number of entries contained in the store.\n   * @param p The predicate to apply in order to filter the count\n   */\n  countSnapshot(p?: Predicate<E>): number {\n    if (p) {\n      return Array.from(this.entries.values()).filter(p).length;\n    }\n    return Array.from(this.entries.values()).length;\n  }\n\n  /**\n   * Snapshot of all entries.\n   * \n   * @return Snapshot array of all the elements the entities the store contains.\n   * \n   * @example Observe a snapshot of all the entities in the store.\n```\nlet selectedTodos:Todo[] = source.allSnapshot();\n```\n   */\n  allSnapshot(): E[] {\n    return Array.from(this.entries.values());\n  }\n\n  /**\n   * Returns true if the entries contain the identified instance.\n   * \n   * @param target Either an instance of type `E` or a `guid` identifying the instance. \n   * @param byId Whether the lookup should be performed with the `id` key rather than the `guid`.\n   * @returns true if the instance identified by the guid exists, false otherwise.\n   * \n   * @example\n     <pre>\n     let contains:boolean = source.contains(guid);\n     </pre>\n   */\n  contains(target: E | string): boolean {\n    if (typeof target === 'string') {\n      return this.entries.get(target) ? true : false;\n    }\n    const guid: string = (<any>target)[this.config.guidKey];\n    return this.entries.get(guid) ? true : false;\n  }\n\n  /**\n   * Returns true if the entries contain the identified instance.\n   * \n   * @param target Either an instance of type `E` or a `id` identifying the instance. \n   * @returns true if the instance identified by the `id` exists, false otherwise.\n   * \n   * @example\n     <pre>\n     let contains:boolean = source.contains(guid);\n     </pre>\n   */\n  containsById(target: E | string): boolean {\n    if (typeof target === 'string') {\n      return this.idEntries.get(target) ? true : false;\n    }\n    const id: string = (<any>target)[this.config.idKey];\n    return this.idEntries.get(id) ? true : false;\n  }\n\n  /**\n   * Find and return the entity identified by the GUID parameter\n   * if it exists and return it.\n   *\n   * @param guid\n   * @return The entity instance if it exists, null otherwise\n   */\n  findOne(guid: string): E | undefined {\n    return this.entries.get(guid);\n  }\n\n  /**\n   * Find and return the entity identified by the ID parameter\n   * if it exists and return it.\n   *\n   * @param id\n   * @return The entity instance if it exists, null otherwise\n   */\n  findOneByID(id: string): E | undefined {\n    return this.idEntries.get(id);\n  }\n\n  /**\n   * Snapshot of the entries that match the predicate.\n   *\n   * @param p The predicate used to query for the selection.\n   * @return A snapshot array containing the entities that match the predicate.\n   *\n   * @example Select all the Todo instances where the title length is greater than 100.\n   * ```\n   * let todos:Todo[]=store.select(todo=>todo.title.length>100);\n   * ```\n   */\n  select(p: Predicate<E>): E[] {\n    const selected: E[] = [];\n    Array.from(this.entries.values()).forEach((e) => {\n      if (p(e)) {\n        selected.push(e);\n      }\n    });\n    return selected;\n  }\n\n  /**\n   * Compare entities by GUID\n   * @param e1 The first entity\n   * @param e2 The second entity\n   * @return true if the two entities have equal GUID ids\n   *\n   * @example Compare todo1 with todo2 by gid.\n   * ```\n   * if (equalsByGUID(todo1, todo2)){...};\n   * ```\n   */\n  equalsByGUID(e1: any, e2: any) {\n    return e1[this.GUID_KEY] == e2[this.GUID_KEY];\n  }\n\n  /**\n   * Compare entities by ID\n   * @param e1 The first entity\n   * @param e2 The second entity\n   * @return true if the two entities have equal ID ids\n   *\n   * @example Compare todo1 with todo2 by id.\n   *\n   * ```\n   * if (equalsByID(todo1, todo2)){...};\n   * ```\n   */\n  equalsByID(e1: any, e2: any) {\n    return e1[this.ID_KEY] == e2[this.ID_KEY];\n  }\n  /**\n   * Calls complete on all {@link ReplaySubject} instances.\n   *\n   * Call destroy when disposing of the store.\n   */\n  destroy() {\n    this.notify.complete();\n    this.notifyDelta.complete();\n    this.notifyQuery.complete();\n  }\n}\n"]}
|