@cascateer/core 2.3.48 → 2.3.50

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/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@cascateer/core",
3
- "version": "2.3.48",
3
+ "version": "2.3.50",
4
4
  "repository": {
5
5
  "type": "git",
6
6
  "url": "https://github.com/cascateer/core.git"
@@ -1,12 +1,40 @@
1
- import { lastValueFrom, of, toArray } from "rxjs";
1
+ import { identity } from "lodash";
2
+ import {
3
+ lastValueFrom,
4
+ of,
5
+ ReplaySubject,
6
+ scan,
7
+ startWith,
8
+ toArray,
9
+ } from "rxjs";
2
10
  import { expect, test } from "vitest";
11
+ import { Transform } from "../types";
3
12
  import { ComputedSignal } from "./Signal";
4
13
 
5
- test("projects", () =>
6
- lastValueFrom(
7
- new ComputedSignal({
8
- value: of({ number: 1 }, { number: 2 }, { number: 3 }),
9
- })
10
- .property("number")
11
- .pipe(toArray()),
12
- ).then((numbers) => expect(numbers).toEqual([1, 2, 3])));
14
+ test("projection", () => {
15
+ const signal = new ComputedSignal({
16
+ value: of({ number: 1 }, { number: 2 }, { number: 3 }),
17
+ }).property("number");
18
+
19
+ lastValueFrom(signal.pipe(toArray())).then((numbers) =>
20
+ expect(numbers).toEqual([1, 2, 3]),
21
+ );
22
+ });
23
+
24
+ test("transformation", () => {
25
+ const transforms = new ReplaySubject<Transform<any>>();
26
+ const signal = new ComputedSignal({
27
+ value: transforms.pipe(
28
+ startWith(identity),
29
+ scan((state, transform) => transform(state), { number: 1 }),
30
+ ),
31
+ }).property("number");
32
+
33
+ transforms.next(signal.adapter.lift((number) => number + 1));
34
+ transforms.next(signal.adapter.lift((number) => number + 2));
35
+ transforms.complete();
36
+
37
+ return lastValueFrom(signal.pipe(toArray())).then((numbers) =>
38
+ expect(numbers).toEqual([1, 2, 4]),
39
+ );
40
+ });
@@ -12,25 +12,24 @@ import {
12
12
  import { Transform } from "../types";
13
13
 
14
14
  class SignalEnumerator<T> {
15
- constructor(private predicate: Enumerator<T> = nthArg(1)) {}
15
+ constructor(private enumerator: Enumerator<T> = nthArg(1)) {}
16
16
 
17
17
  findIndex = (key: PropertyKey) => (value: T) =>
18
- asEnumerable(value).map(this.predicate).indexOf(key);
18
+ asEnumerable(value).map(this.enumerator).indexOf(key);
19
19
 
20
- enumerate = (value: T) => asEnumerable(value).map(this.predicate);
20
+ enumerate = (value: T) => asEnumerable(value).map(this.enumerator);
21
21
  }
22
22
 
23
- class SignalReflector<T> {
23
+ class SignalAdapter<T> {
24
24
  constructor(
25
- public predicate: (
26
- transform: Transform<T>,
27
- ) => Transform<unknown> = identity,
25
+ public lift: (transform: Transform<T>) => Transform<unknown> = identity,
28
26
  ) {}
29
27
 
30
- reflect = <U>(
31
- lift: UnaryFunction<Transform<U>, Transform<T>>,
32
- ): SignalReflector<U> =>
33
- new SignalReflector((transform) => this.predicate(lift(transform)));
28
+ connect<U>(
29
+ connector: UnaryFunction<Transform<U>, Transform<T>>,
30
+ ): SignalAdapter<U> {
31
+ return new SignalAdapter((transform) => this.lift(connector(transform)));
32
+ }
34
33
  }
35
34
 
36
35
  export class Signal<T> extends ProxyObservable<T> {
@@ -43,38 +42,38 @@ export class Signal<T> extends ProxyObservable<T> {
43
42
  }
44
43
 
45
44
  enumerator: SignalEnumerator<T>;
46
- reflector: SignalReflector<T>;
45
+ adapter: SignalAdapter<T>;
47
46
 
48
47
  constructor({
49
48
  value,
50
49
  enumerator = new SignalEnumerator(),
51
- reflector = new SignalReflector(),
50
+ adapter = new SignalAdapter(),
52
51
  }: {
53
52
  value: Observable<T>;
54
53
  enumerator?: SignalEnumerator<T>;
55
- reflector?: SignalReflector<T>;
54
+ adapter?: SignalAdapter<T>;
56
55
  }) {
57
56
  super(value);
58
57
 
59
58
  this.enumerator = enumerator;
60
- this.reflector = reflector;
59
+ this.adapter = adapter;
61
60
  }
62
61
 
63
62
  private project<U>(
64
- project: UnaryFunction<T, U>,
65
- lift: UnaryFunction<Transform<U>, Transform<T>>,
66
- enumerate?: Enumerator<U>,
63
+ projector: UnaryFunction<T, U>,
64
+ connector: UnaryFunction<Transform<U>, Transform<T>>,
65
+ enumerator?: Enumerator<U>,
67
66
  ): Signal<U> {
68
67
  return new Signal({
69
- value: this.pipe(map(project), distinctUntilChanged()),
70
- enumerator: new SignalEnumerator(enumerate),
71
- reflector: this.reflector.reflect(lift),
68
+ value: this.pipe(map(projector), distinctUntilChanged()),
69
+ enumerator: new SignalEnumerator(enumerator),
70
+ adapter: this.adapter.connect(connector),
72
71
  });
73
72
  }
74
73
 
75
74
  protected property<K extends keyof T>(
76
75
  key: K,
77
- enumerate?: Enumerator<T[K]>,
76
+ enumerator?: Enumerator<T[K]>,
78
77
  ): Signal<T[K]> {
79
78
  const findProperty: UnaryFunction<T, T[K]> = property(key);
80
79
 
@@ -87,13 +86,13 @@ export class Signal<T> extends ProxyObservable<T> {
87
86
 
88
87
  return value;
89
88
  },
90
- enumerate,
89
+ enumerator,
91
90
  );
92
91
  }
93
92
 
94
93
  protected item(
95
94
  key: PropertyKey,
96
- enumerate?: Enumerator<EnumerableItem<T>>,
95
+ enumerator?: Enumerator<EnumerableItem<T>>,
97
96
  ): Signal<EnumerableItem<T>> {
98
97
  const findIndex = this.enumerator.findIndex(key);
99
98
  const findItem: UnaryFunction<T, EnumerableItem<T>> = (value) =>
@@ -108,7 +107,7 @@ export class Signal<T> extends ProxyObservable<T> {
108
107
 
109
108
  return value;
110
109
  },
111
- enumerate,
110
+ enumerator,
112
111
  );
113
112
  }
114
113
 
@@ -151,16 +150,16 @@ export class Signal<T> extends ProxyObservable<T> {
151
150
  export class ComputedSignal<T> extends Signal<T> {
152
151
  property<K extends keyof T>(
153
152
  key: K,
154
- enumerate?: Enumerator<T[K]>,
153
+ enumerator?: Enumerator<T[K]>,
155
154
  ): ComputedSignal<T[K]> {
156
- return new ComputedSignal(super.property(key, enumerate));
155
+ return new ComputedSignal(super.property(key, enumerator));
157
156
  }
158
157
 
159
158
  item(
160
159
  key: PropertyKey,
161
- enumerate?: Enumerator<EnumerableItem<T>>,
160
+ enumerator?: Enumerator<EnumerableItem<T>>,
162
161
  ): ComputedSignal<EnumerableItem<T>> {
163
- return new ComputedSignal(super.item(key, enumerate));
162
+ return new ComputedSignal(super.item(key, enumerator));
164
163
  }
165
164
 
166
165
  collection<K extends keyof EnumerableItem<T>>(
package/src/store.ts CHANGED
@@ -143,7 +143,7 @@ export class ExtendableStoreAdapter<
143
143
  update: (predicate, config = {}) =>
144
144
  thru(this.context.transform(key), (transform) => {
145
145
  transform.register((args) =>
146
- signal.reflector.predicate(predicate(args)),
146
+ signal.adapter.lift(predicate(args)),
147
147
  );
148
148
 
149
149
  return (args) =>