@fireflysemantics/slice 16.2.14 → 16.2.16

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 CHANGED
@@ -1,19 +1,29 @@
1
- [![Build Status](https://travis-ci.org/fireflysemantics/slice.svg?branch=master)](https://travis-ci.org/fireflysemantics/slice)
2
-
3
1
  ![Slice](slicelogo.png)
4
2
 
5
3
  # @fireflysemantics/slice
6
4
 
7
- Lightweight Javascript Reactive State Management for Web Applications.
5
+ Lightweight Javascript Reactive State Management for Angular Applications.
8
6
 
9
7
  If you like the [@fireflysemantics/slice API](https://fireflysemantics.github.io/slice/doc/) please star our [Github Repository](https://github.com/fireflysemantics/slice).
10
8
 
11
9
  # Install
12
10
 
13
- Install Slice with peer dependencies:
11
+
12
+ Install Slice with the `nanoid` peer dependency:
13
+
14
+ - `v17.0.x` for Angular 17
15
+ - `v16.2.x` for Angular 16
16
+ - `v15.2.x` for Angular 15
17
+
18
+ So for example for an Angular 15 project run.
19
+
20
+ ```
21
+ npm i @fireflysemantics/slice@15.2.x nanoid
22
+ ```
23
+ For Angular 17 run.
14
24
 
15
25
  ```
16
- npm i @fireflysemantics/slice tslib rxjs nanoid
26
+ npm i @fireflysemantics/slice@lastest nanoid
17
27
  ```
18
28
 
19
29
  # Firefly Semantics Slice Development Center Media and Documentation
@@ -0,0 +1,145 @@
1
+ import { ReplaySubject } from 'rxjs';
2
+ export class OStore {
3
+ constructor(start) {
4
+ /**
5
+ * Map of Key Value pair entries
6
+ * containing values store in this store.
7
+ */
8
+ this.entries = new Map();
9
+ /**
10
+ * Map of replay subject id to `ReplaySubject` instance.
11
+ */
12
+ this.subjects = new Map();
13
+ if (start) {
14
+ this.S = start;
15
+ const keys = Object.keys(start);
16
+ keys.forEach((k) => {
17
+ const ovr = start[k];
18
+ this.post(ovr, ovr.value);
19
+ ovr.obs = this.observe(ovr);
20
+ });
21
+ }
22
+ }
23
+ /**
24
+ * Reset the state of the OStore to the
25
+ * values or reset provided in the constructor
26
+ * {@link OStoreStart} instance.
27
+ */
28
+ reset() {
29
+ if (this.S) {
30
+ const keys = Object.keys(this.S);
31
+ keys.forEach((k) => {
32
+ const ovr = this.S[k];
33
+ this.put(ovr, ovr.reset ? ovr.reset : ovr.value);
34
+ });
35
+ }
36
+ }
37
+ /**
38
+ * Set create a key value pair entry and creates a
39
+ * corresponding replay subject instance that will
40
+ * be used to broadcast updates.
41
+ *
42
+ * @param key The key identifying the value
43
+ * @param value The value
44
+ */
45
+ post(key, value) {
46
+ this.entries.set(key, value);
47
+ this.subjects.set(key, new ReplaySubject(1));
48
+ //Emit immediately so that Observers can receive
49
+ //the value straight away.
50
+ const subject = this.subjects.get(key);
51
+ if (subject) {
52
+ subject.next(value);
53
+ }
54
+ }
55
+ /**
56
+ * Update a value and notify subscribers.
57
+ *
58
+ * @param key
59
+ * @param value
60
+ */
61
+ put(key, value) {
62
+ this.entries.set(key, value);
63
+ const subject = this.subjects.get(key);
64
+ if (subject) {
65
+ subject.next(value);
66
+ }
67
+ }
68
+ /**
69
+ * Deletes both the value entry and the corresponding {@link ReplaySubject}.
70
+ * Will unsubscribe the {@link ReplaySubject} prior to deleting it,
71
+ * severing communication with corresponding {@link Observable}s.
72
+ *
73
+ * @param key
74
+ */
75
+ delete(key) {
76
+ //===========================================
77
+ // Delete the entry
78
+ //===========================================
79
+ this.entries.delete(key);
80
+ const subject = this.subjects.get(key);
81
+ if (subject) {
82
+ subject.next(undefined);
83
+ }
84
+ }
85
+ /**
86
+ * Clear all entries.
87
+ *
88
+ * Note that
89
+ * this will call delete for on all
90
+ * keys defined which also also
91
+ * unsubscribes and deletes
92
+ * all the sbujects.
93
+ */
94
+ clear() {
95
+ for (let key of this.entries.keys()) {
96
+ this.delete(key);
97
+ }
98
+ }
99
+ /**
100
+ * Observe changes to the values.
101
+ *
102
+ * @param key
103
+ * @return An {@link Observable} of the value
104
+ */
105
+ observe(key) {
106
+ return this.subjects.get(key)
107
+ ? this.subjects.get(key).asObservable()
108
+ : undefined;
109
+ }
110
+ /**
111
+ * Check whether a value exists.
112
+ *
113
+ * @param key
114
+ * @return True if the entry exists ( Is not null or undefined ) and false otherwise.
115
+ */
116
+ exists(key) {
117
+ return !!this.entries.get(key);
118
+ }
119
+ /**
120
+ * Retrieve a snapshot of the
121
+ * value.
122
+ *
123
+ * @param key
124
+ * @return A snapshot of the value corresponding to the key.
125
+ */
126
+ snapshot(key) {
127
+ return this.entries.get(key);
128
+ }
129
+ /**
130
+ * Indicates whether the store is empty.
131
+ * @return true if the store is empty, false otherwise.
132
+ */
133
+ isEmpty() {
134
+ return Array.from(this.entries.values()).length == 0;
135
+ }
136
+ /**
137
+ * Returns the number of key value pairs contained.
138
+ *
139
+ * @return the number of entries in the store.
140
+ */
141
+ count() {
142
+ return Array.from(this.entries.values()).length;
143
+ }
144
+ }
145
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"OStore.js","sourceRoot":"","sources":["../../../../projects/slice/src/lib/OStore.ts"],"names":[],"mappings":"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","sourcesContent":["import { ReplaySubject, Observable } from 'rxjs';\n\n/**\n * Initialize hte store with this.\n */\nexport interface ValueReset {\n  value: any;\n  reset?: any;\n}\n\n/**\n * OStore Key Value Reset\n */\nexport interface ObsValueReset {\n  value: any;\n  reset?: any;\n  obs?: Observable<any>;\n}\n\nexport interface KeyObsValueReset {\n  [key: string]: ObsValueReset;\n}\n\nexport interface OStoreStart {\n  [key: string]: ValueReset;\n}\n\nexport class OStore<E extends KeyObsValueReset> {\n  /**\n   * Start keys and values\n   * passed in via constructor.\n   */\n  public S!: E;\n\n  constructor(start: OStoreStart) {\n    if (start) {\n      this.S = <E>start;\n      const keys = Object.keys(start);\n      keys.forEach((k) => {\n        const ovr = start[k] as ObsValueReset;\n        this.post(ovr, ovr.value);\n        ovr.obs = this.observe(ovr);\n      });\n    }\n  }\n\n  /**\n   * Reset the state of the OStore to the\n   * values or reset provided in the constructor\n   * {@link OStoreStart} instance.\n   */\n  public reset() {\n    if (this.S) {\n      const keys = Object.keys(this.S);\n      keys.forEach((k) => {\n        const ovr: ObsValueReset = this.S[k];\n        this.put(ovr, ovr.reset ? ovr.reset : ovr.value);\n      });\n    }\n  }\n\n  /**\n   * Map of Key Value pair entries\n   * containing values store in this store.\n   */\n  public entries: Map<any, any> = new Map();\n\n  /**\n   * Map of replay subject id to `ReplaySubject` instance.\n   */\n  private subjects: Map<any, ReplaySubject<any>> = new Map();\n\n  /**\n   * Set create a key value pair entry and creates a\n   * corresponding replay subject instance that will\n   * be used to broadcast updates.\n   *\n   * @param key The key identifying the value\n   * @param value The value\n   */\n  private post(key: ObsValueReset, value: any) {\n    this.entries.set(key, value);\n    this.subjects.set(key, new ReplaySubject(1));\n    //Emit immediately so that Observers can receive\n    //the value straight away.\n    const subject = this.subjects.get(key);\n    if (subject) {\n      subject.next(value);\n    }\n  }\n  /**\n   * Update a value and notify subscribers.\n   *\n   * @param key\n   * @param value\n   */\n  public put(key: any, value: any) {\n    this.entries.set(key, value);\n    const subject = this.subjects.get(key);\n    if (subject) {\n      subject.next(value);\n    }\n  }\n\n  /**\n   * Deletes both the value entry and the corresponding {@link ReplaySubject}.\n   * Will unsubscribe the {@link ReplaySubject} prior to deleting it,\n   * severing communication with corresponding {@link Observable}s.\n   *\n   * @param key\n   */\n  public delete(key: any) {\n    //===========================================\n    // Delete the entry\n    //===========================================\n    this.entries.delete(key);\n    const subject = this.subjects.get(key);\n    if (subject) {\n      subject.next(undefined);\n    }\n  }\n\n  /**\n   * Clear all entries.  \n   * \n   * Note that \n   * this will call delete for on all\n   * keys defined which also also \n   * unsubscribes and deletes \n   * all the sbujects.\n   */\n  public clear() {\n    for (let key of this.entries.keys()) {\n        this.delete(key);\n    }\n  }\n\n  /**\n   * Observe changes to the values.\n   *\n   * @param key\n   * @return An {@link Observable} of the value\n   */\n  public observe(key: any): Observable<any> | undefined {\n    return this.subjects.get(key)\n      ? this.subjects.get(key)!.asObservable()\n      : undefined;\n  }\n\n  /**\n   * Check whether a value exists.\n   *\n   * @param key\n   * @return True if the entry exists ( Is not null or undefined ) and false otherwise.\n   */\n  public exists(key: any): boolean {\n    return !!this.entries.get(key);\n  }\n\n  /**\n   * Retrieve a snapshot of the\n   * value.\n   *\n   * @param key\n   * @return A snapshot of the value corresponding to the key.\n   */\n  public snapshot(key: any): any {\n    return this.entries.get(key);\n  }\n\n  /**\n   * Indicates whether the store is empty.\n   * @return true if the store is empty, false otherwise.\n   */\n  public isEmpty() {\n    return Array.from(this.entries.values()).length == 0;\n  }\n\n  /**\n   * Returns the number of key value pairs contained.\n   *\n   * @return the number of entries in the store.\n   */\n  public count() {\n    return Array.from(this.entries.values()).length;\n  }\n}\n"]}