angular-three 1.10.2 → 2.0.0-beta.0
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 +89 -5
- package/esm2022/index.mjs +5 -7
- package/esm2022/lib/canvas.mjs +138 -99
- package/esm2022/lib/di/before-render.mjs +7 -10
- package/esm2022/lib/di/ref.mjs +38 -59
- package/esm2022/lib/directives/args.mjs +5 -8
- package/esm2022/lib/directives/common.mjs +20 -13
- package/esm2022/lib/directives/parent.mjs +5 -8
- package/esm2022/lib/{web → dom}/events.mjs +1 -1
- package/esm2022/lib/events.mjs +2 -2
- package/esm2022/lib/loader.mjs +58 -44
- package/esm2022/lib/loop.mjs +6 -8
- package/esm2022/lib/portal.mjs +76 -63
- package/esm2022/lib/renderer/provider.mjs +3 -2
- package/esm2022/lib/renderer/renderer.mjs +53 -52
- package/esm2022/lib/renderer/store.mjs +14 -19
- package/esm2022/lib/renderer/utils.mjs +27 -18
- package/esm2022/lib/routed-scene.mjs +12 -10
- package/esm2022/lib/stores/signal.store.mjs +60 -0
- package/esm2022/lib/stores/store.mjs +69 -48
- package/esm2022/lib/three-types.mjs +2 -0
- package/esm2022/lib/types.mjs +1 -1
- package/esm2022/lib/utils/apply-props.mjs +11 -7
- package/esm2022/lib/utils/attach.mjs +1 -1
- package/esm2022/lib/utils/instance.mjs +14 -14
- package/esm2022/lib/utils/safe-detect-changes.mjs +1 -1
- package/fesm2022/angular-three.mjs +1673 -1744
- package/fesm2022/angular-three.mjs.map +1 -1
- package/index.d.ts +4 -6
- package/lib/canvas.d.ts +11 -20
- package/lib/di/before-render.d.ts +5 -1
- package/lib/di/ref.d.ts +5 -11
- package/lib/directives/args.d.ts +6 -6
- package/lib/directives/common.d.ts +1 -4
- package/lib/directives/parent.d.ts +1 -1
- package/lib/{web → dom}/events.d.ts +2 -2
- package/lib/events.d.ts +3 -3
- package/lib/loader.d.ts +6 -2
- package/lib/loop.d.ts +4 -4
- package/lib/portal.d.ts +11 -18
- package/lib/renderer/renderer.d.ts +7 -9
- package/lib/renderer/store.d.ts +3 -5
- package/lib/renderer/utils.d.ts +6 -4
- package/lib/routed-scene.d.ts +4 -2
- package/lib/stores/signal.store.d.ts +19 -0
- package/lib/stores/store.d.ts +4 -7
- package/lib/three-types.d.ts +306 -0
- package/lib/types.d.ts +22 -25
- package/lib/utils/attach.d.ts +2 -2
- package/lib/utils/instance.d.ts +1 -1
- package/package.json +6 -7
- package/plugin/package.json +1 -1
- package/plugin/src/generators/init/init.d.ts +1 -1
- package/plugin/src/generators/init/init.js +1 -1
- package/esm2022/lib/di/destroy.mjs +0 -23
- package/esm2022/lib/di/run-in-context.mjs +0 -40
- package/esm2022/lib/pipes/push.mjs +0 -50
- package/esm2022/lib/stores/rx-store.mjs +0 -108
- package/lib/di/destroy.d.ts +0 -9
- package/lib/di/run-in-context.d.ts +0 -6
- package/lib/pipes/push.d.ts +0 -16
- package/lib/stores/rx-store.d.ts +0 -42
|
@@ -1,50 +0,0 @@
|
|
|
1
|
-
import { ChangeDetectorRef, EnvironmentInjector, inject, Pipe } from '@angular/core';
|
|
2
|
-
import { isObservable } from 'rxjs';
|
|
3
|
-
import { safeDetectChanges } from '../utils/safe-detect-changes';
|
|
4
|
-
import * as i0 from "@angular/core";
|
|
5
|
-
function isPromise(value) {
|
|
6
|
-
return ((value instanceof Promise || Object.prototype.toString.call(value) === '[object Promise]') &&
|
|
7
|
-
typeof value['then'] === 'function');
|
|
8
|
-
}
|
|
9
|
-
class NgtPush {
|
|
10
|
-
constructor() {
|
|
11
|
-
this.cdr = inject(ChangeDetectorRef);
|
|
12
|
-
this.parentCdr = inject(ChangeDetectorRef, { skipSelf: true, optional: true });
|
|
13
|
-
this.envCdr = inject(EnvironmentInjector).get(ChangeDetectorRef, null);
|
|
14
|
-
}
|
|
15
|
-
transform(value, defaultValue = null) {
|
|
16
|
-
if (this.obj === value)
|
|
17
|
-
return this.latestValue;
|
|
18
|
-
this.obj = value;
|
|
19
|
-
this.latestValue = defaultValue;
|
|
20
|
-
if (this.sub)
|
|
21
|
-
this.sub.unsubscribe();
|
|
22
|
-
if (isObservable(this.obj))
|
|
23
|
-
this.sub = this.obj.subscribe(this.updateValue.bind(this));
|
|
24
|
-
else if (isPromise(this.obj))
|
|
25
|
-
this.obj.then(this.updateValue.bind(this));
|
|
26
|
-
else
|
|
27
|
-
throw new Error(`[NGT] Invalid value passed to ngtPush pipe`);
|
|
28
|
-
return this.latestValue;
|
|
29
|
-
}
|
|
30
|
-
updateValue(val) {
|
|
31
|
-
this.latestValue = val;
|
|
32
|
-
safeDetectChanges(this.cdr);
|
|
33
|
-
safeDetectChanges(this.parentCdr);
|
|
34
|
-
safeDetectChanges(this.envCdr);
|
|
35
|
-
}
|
|
36
|
-
ngOnDestroy() {
|
|
37
|
-
if (this.sub)
|
|
38
|
-
this.sub.unsubscribe();
|
|
39
|
-
this.latestValue = undefined;
|
|
40
|
-
this.obj = undefined;
|
|
41
|
-
}
|
|
42
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NgtPush, deps: [], target: i0.ɵɵFactoryTarget.Pipe }); }
|
|
43
|
-
static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "16.0.0", ngImport: i0, type: NgtPush, isStandalone: true, name: "ngtPush", pure: false }); }
|
|
44
|
-
}
|
|
45
|
-
export { NgtPush };
|
|
46
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NgtPush, decorators: [{
|
|
47
|
-
type: Pipe,
|
|
48
|
-
args: [{ name: 'ngtPush', pure: false, standalone: true }]
|
|
49
|
-
}] });
|
|
50
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVzaC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvYW5ndWxhci10aHJlZS9zcmMvbGliL3BpcGVzL3B1c2gudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGlCQUFpQixFQUFFLG1CQUFtQixFQUFFLE1BQU0sRUFBYSxJQUFJLEVBQWlCLE1BQU0sZUFBZSxDQUFDO0FBQy9HLE9BQU8sRUFBRSxZQUFZLEVBQWlDLE1BQU0sTUFBTSxDQUFDO0FBQ25FLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLDhCQUE4QixDQUFDOztBQUVqRSxTQUFTLFNBQVMsQ0FBQyxLQUFjO0lBQzdCLE9BQU8sQ0FDSCxDQUFDLEtBQUssWUFBWSxPQUFPLElBQUksTUFBTSxDQUFDLFNBQVMsQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxLQUFLLGtCQUFrQixDQUFDO1FBQzFGLE9BQVEsS0FBMEIsQ0FBQyxNQUFNLENBQUMsS0FBSyxVQUFVLENBQzVELENBQUM7QUFDTixDQUFDO0FBRUQsTUFDYSxPQUFPO0lBRHBCO1FBRXFCLFFBQUcsR0FBRyxNQUFNLENBQUMsaUJBQWlCLENBQUMsQ0FBQztRQUNoQyxjQUFTLEdBQUcsTUFBTSxDQUFDLGlCQUFpQixFQUFFLEVBQUUsUUFBUSxFQUFFLElBQUksRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztRQUMxRSxXQUFNLEdBQUcsTUFBTSxDQUFDLG1CQUFtQixDQUFDLENBQUMsR0FBRyxDQUFDLGlCQUFpQixFQUFFLElBQUksQ0FBQyxDQUFDO0tBaUN0RjtJQTNCRyxTQUFTLENBQUMsS0FBeUIsRUFBRSxlQUFrQixJQUFLO1FBQ3hELElBQUksSUFBSSxDQUFDLEdBQUcsS0FBSyxLQUFLO1lBQUUsT0FBTyxJQUFJLENBQUMsV0FBZ0IsQ0FBQztRQUVyRCxJQUFJLENBQUMsR0FBRyxHQUFHLEtBQUssQ0FBQztRQUNqQixJQUFJLENBQUMsV0FBVyxHQUFHLFlBQVksQ0FBQztRQUVoQyxJQUFJLElBQUksQ0FBQyxHQUFHO1lBQUUsSUFBSSxDQUFDLEdBQUcsQ0FBQyxXQUFXLEVBQUUsQ0FBQztRQUVyQyxJQUFJLFlBQVksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDO1lBQUUsSUFBSSxDQUFDLEdBQUcsR0FBRyxJQUFJLENBQUMsR0FBRyxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDO2FBQ2xGLElBQUksU0FBUyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUM7WUFBRyxJQUFJLENBQUMsR0FBa0IsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQzs7WUFDcEYsTUFBTSxJQUFJLEtBQUssQ0FBQyw0Q0FBNEMsQ0FBQyxDQUFDO1FBRW5FLE9BQU8sSUFBSSxDQUFDLFdBQWdCLENBQUM7SUFDakMsQ0FBQztJQUVPLFdBQVcsQ0FBQyxHQUFNO1FBQ3RCLElBQUksQ0FBQyxXQUFXLEdBQUcsR0FBRyxDQUFDO1FBQ3ZCLGlCQUFpQixDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUM1QixpQkFBaUIsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUM7UUFDbEMsaUJBQWlCLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQ25DLENBQUM7SUFFRCxXQUFXO1FBQ1AsSUFBSSxJQUFJLENBQUMsR0FBRztZQUFFLElBQUksQ0FBQyxHQUFHLENBQUMsV0FBVyxFQUFFLENBQUM7UUFDckMsSUFBSSxDQUFDLFdBQVcsR0FBRyxTQUFTLENBQUM7UUFDN0IsSUFBSSxDQUFDLEdBQUcsR0FBRyxTQUFTLENBQUM7SUFDekIsQ0FBQzs4R0FuQ1EsT0FBTzs0R0FBUCxPQUFPOztTQUFQLE9BQU87MkZBQVAsT0FBTztrQkFEbkIsSUFBSTttQkFBQyxFQUFFLElBQUksRUFBRSxTQUFTLEVBQUUsSUFBSSxFQUFFLEtBQUssRUFBRSxVQUFVLEVBQUUsSUFBSSxFQUFFIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0b3JSZWYsIEVudmlyb25tZW50SW5qZWN0b3IsIGluamVjdCwgT25EZXN0cm95LCBQaXBlLCBQaXBlVHJhbnNmb3JtIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBpc09ic2VydmFibGUsIE9ic2VydmFibGVJbnB1dCwgU3Vic2NyaXB0aW9uIH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBzYWZlRGV0ZWN0Q2hhbmdlcyB9IGZyb20gJy4uL3V0aWxzL3NhZmUtZGV0ZWN0LWNoYW5nZXMnO1xuXG5mdW5jdGlvbiBpc1Byb21pc2UodmFsdWU6IHVua25vd24pOiB2YWx1ZSBpcyBQcm9taXNlPHVua25vd24+IHtcbiAgICByZXR1cm4gKFxuICAgICAgICAodmFsdWUgaW5zdGFuY2VvZiBQcm9taXNlIHx8IE9iamVjdC5wcm90b3R5cGUudG9TdHJpbmcuY2FsbCh2YWx1ZSkgPT09ICdbb2JqZWN0IFByb21pc2VdJykgJiZcbiAgICAgICAgdHlwZW9mICh2YWx1ZSBhcyBQcm9taXNlPHVua25vd24+KVsndGhlbiddID09PSAnZnVuY3Rpb24nXG4gICAgKTtcbn1cblxuQFBpcGUoeyBuYW1lOiAnbmd0UHVzaCcsIHB1cmU6IGZhbHNlLCBzdGFuZGFsb25lOiB0cnVlIH0pXG5leHBvcnQgY2xhc3MgTmd0UHVzaDxUPiBpbXBsZW1lbnRzIFBpcGVUcmFuc2Zvcm0sIE9uRGVzdHJveSB7XG4gICAgcHJpdmF0ZSByZWFkb25seSBjZHIgPSBpbmplY3QoQ2hhbmdlRGV0ZWN0b3JSZWYpO1xuICAgIHByaXZhdGUgcmVhZG9ubHkgcGFyZW50Q2RyID0gaW5qZWN0KENoYW5nZURldGVjdG9yUmVmLCB7IHNraXBTZWxmOiB0cnVlLCBvcHRpb25hbDogdHJ1ZSB9KTtcbiAgICBwcml2YXRlIHJlYWRvbmx5IGVudkNkciA9IGluamVjdChFbnZpcm9ubWVudEluamVjdG9yKS5nZXQoQ2hhbmdlRGV0ZWN0b3JSZWYsIG51bGwpO1xuXG4gICAgcHJpdmF0ZSBzdWI/OiBTdWJzY3JpcHRpb247XG4gICAgcHJpdmF0ZSBvYmo/OiBPYnNlcnZhYmxlSW5wdXQ8VD47XG4gICAgcHJpdmF0ZSBsYXRlc3RWYWx1ZT86IFQ7XG5cbiAgICB0cmFuc2Zvcm0odmFsdWU6IE9ic2VydmFibGVJbnB1dDxUPiwgZGVmYXVsdFZhbHVlOiBUID0gbnVsbCEpOiBUIHtcbiAgICAgICAgaWYgKHRoaXMub2JqID09PSB2YWx1ZSkgcmV0dXJuIHRoaXMubGF0ZXN0VmFsdWUgYXMgVDtcblxuICAgICAgICB0aGlzLm9iaiA9IHZhbHVlO1xuICAgICAgICB0aGlzLmxhdGVzdFZhbHVlID0gZGVmYXVsdFZhbHVlO1xuXG4gICAgICAgIGlmICh0aGlzLnN1YikgdGhpcy5zdWIudW5zdWJzY3JpYmUoKTtcblxuICAgICAgICBpZiAoaXNPYnNlcnZhYmxlKHRoaXMub2JqKSkgdGhpcy5zdWIgPSB0aGlzLm9iai5zdWJzY3JpYmUodGhpcy51cGRhdGVWYWx1ZS5iaW5kKHRoaXMpKTtcbiAgICAgICAgZWxzZSBpZiAoaXNQcm9taXNlKHRoaXMub2JqKSkgKHRoaXMub2JqIGFzIFByb21pc2U8VD4pLnRoZW4odGhpcy51cGRhdGVWYWx1ZS5iaW5kKHRoaXMpKTtcbiAgICAgICAgZWxzZSB0aHJvdyBuZXcgRXJyb3IoYFtOR1RdIEludmFsaWQgdmFsdWUgcGFzc2VkIHRvIG5ndFB1c2ggcGlwZWApO1xuXG4gICAgICAgIHJldHVybiB0aGlzLmxhdGVzdFZhbHVlIGFzIFQ7XG4gICAgfVxuXG4gICAgcHJpdmF0ZSB1cGRhdGVWYWx1ZSh2YWw6IFQpIHtcbiAgICAgICAgdGhpcy5sYXRlc3RWYWx1ZSA9IHZhbDtcbiAgICAgICAgc2FmZURldGVjdENoYW5nZXModGhpcy5jZHIpO1xuICAgICAgICBzYWZlRGV0ZWN0Q2hhbmdlcyh0aGlzLnBhcmVudENkcik7XG4gICAgICAgIHNhZmVEZXRlY3RDaGFuZ2VzKHRoaXMuZW52Q2RyKTtcbiAgICB9XG5cbiAgICBuZ09uRGVzdHJveSgpIHtcbiAgICAgICAgaWYgKHRoaXMuc3ViKSB0aGlzLnN1Yi51bnN1YnNjcmliZSgpO1xuICAgICAgICB0aGlzLmxhdGVzdFZhbHVlID0gdW5kZWZpbmVkO1xuICAgICAgICB0aGlzLm9iaiA9IHVuZGVmaW5lZDtcbiAgICB9XG59XG4iXX0=
|
|
@@ -1,108 +0,0 @@
|
|
|
1
|
-
import { Injectable } from '@angular/core';
|
|
2
|
-
import { RxState } from '@rx-angular/state';
|
|
3
|
-
import { combineLatest, startWith, tap } from 'rxjs';
|
|
4
|
-
import { is } from '../utils/is';
|
|
5
|
-
import { safeDetectChanges } from '../utils/safe-detect-changes';
|
|
6
|
-
import * as i0 from "@angular/core";
|
|
7
|
-
export const startWithUndefined = () => startWith(undefined);
|
|
8
|
-
/**
|
|
9
|
-
* An extended `tap` operator that accepts an `effectFn` which:
|
|
10
|
-
* - runs on every `next` notification from `source$`
|
|
11
|
-
* - can optionally return a `cleanUp` function that
|
|
12
|
-
* invokes from the 2nd `next` notification onward and on `unsubscribe` (destroyed)
|
|
13
|
-
*
|
|
14
|
-
* @example
|
|
15
|
-
* ```typescript
|
|
16
|
-
* source$.pipe(
|
|
17
|
-
* tapEffect((sourceValue) = {
|
|
18
|
-
* const cb = () => {
|
|
19
|
-
* doStuff(sourceValue);
|
|
20
|
-
* };
|
|
21
|
-
* addListener('event', cb);
|
|
22
|
-
*
|
|
23
|
-
* return () => {
|
|
24
|
-
* removeListener('event', cb);
|
|
25
|
-
* }
|
|
26
|
-
* })
|
|
27
|
-
* )
|
|
28
|
-
* ```
|
|
29
|
-
*/
|
|
30
|
-
export function tapEffect(effectFn) {
|
|
31
|
-
let cleanupFn = () => { };
|
|
32
|
-
let firstRun = false;
|
|
33
|
-
let prev = undefined;
|
|
34
|
-
const teardown = (error) => () => {
|
|
35
|
-
if (cleanupFn)
|
|
36
|
-
cleanupFn({ prev, complete: true, error });
|
|
37
|
-
};
|
|
38
|
-
return tap({
|
|
39
|
-
next: (value) => {
|
|
40
|
-
if (cleanupFn && firstRun)
|
|
41
|
-
cleanupFn({ prev, complete: false, error: false });
|
|
42
|
-
const cleanUpOrVoid = effectFn(value);
|
|
43
|
-
if (cleanUpOrVoid)
|
|
44
|
-
cleanupFn = cleanUpOrVoid;
|
|
45
|
-
prev = value;
|
|
46
|
-
if (!firstRun)
|
|
47
|
-
firstRun = true;
|
|
48
|
-
},
|
|
49
|
-
complete: teardown(false),
|
|
50
|
-
unsubscribe: teardown(false),
|
|
51
|
-
error: teardown(true),
|
|
52
|
-
});
|
|
53
|
-
}
|
|
54
|
-
class NgtRxStore extends RxState {
|
|
55
|
-
constructor() {
|
|
56
|
-
super();
|
|
57
|
-
// set a dummy property so that initial this.get() won't return undefined
|
|
58
|
-
this.set({ __ngt_dummy__: '__ngt_dummy__' });
|
|
59
|
-
// override set so our consumers don't have to handle undefined for state that already have default values
|
|
60
|
-
const originalSet = this.set.bind(this);
|
|
61
|
-
Object.defineProperty(this, 'set', {
|
|
62
|
-
get: () => {
|
|
63
|
-
return (...args) => {
|
|
64
|
-
const firstArg = args[0];
|
|
65
|
-
if (is.obj(firstArg)) {
|
|
66
|
-
const modArgs = Object.entries(firstArg).reduce((modded, [key, value]) => {
|
|
67
|
-
modded[key] = value === undefined ? this.get(key) : value;
|
|
68
|
-
return modded;
|
|
69
|
-
}, {});
|
|
70
|
-
return originalSet(modArgs);
|
|
71
|
-
}
|
|
72
|
-
return originalSet(...args);
|
|
73
|
-
};
|
|
74
|
-
},
|
|
75
|
-
});
|
|
76
|
-
// override get to return {} if get() returns undefined
|
|
77
|
-
const originalGet = this.get.bind(this);
|
|
78
|
-
Object.defineProperty(this, 'get', {
|
|
79
|
-
get: () => (...args) => {
|
|
80
|
-
if (args.length === 0)
|
|
81
|
-
return originalGet() ?? {};
|
|
82
|
-
return originalGet(...args);
|
|
83
|
-
},
|
|
84
|
-
});
|
|
85
|
-
// call initialize that might be setup by derived Stores
|
|
86
|
-
this.initialize();
|
|
87
|
-
}
|
|
88
|
-
initialize() {
|
|
89
|
-
return;
|
|
90
|
-
}
|
|
91
|
-
effect(obs, sideEffectFn) {
|
|
92
|
-
return this.hold(obs.pipe(tapEffect(sideEffectFn)));
|
|
93
|
-
}
|
|
94
|
-
triggerChangeDetection(cdr, keys = []) {
|
|
95
|
-
let $ = this.$;
|
|
96
|
-
if (keys.length) {
|
|
97
|
-
$ = combineLatest(keys.map((key) => this.select(key).pipe(startWith(this.get(key) ?? undefined))));
|
|
98
|
-
}
|
|
99
|
-
this.hold($, () => void requestAnimationFrame(() => void safeDetectChanges(cdr)));
|
|
100
|
-
}
|
|
101
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NgtRxStore, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
102
|
-
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NgtRxStore }); }
|
|
103
|
-
}
|
|
104
|
-
export { NgtRxStore };
|
|
105
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NgtRxStore, decorators: [{
|
|
106
|
-
type: Injectable
|
|
107
|
-
}], ctorParameters: function () { return []; } });
|
|
108
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"rx-store.js","sourceRoot":"","sources":["../../../../../../libs/angular-three/src/lib/stores/rx-store.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Injectable } from '@angular/core';\nimport { RxState } from '@rx-angular/state';\nimport { combineLatest, MonoTypeOperatorFunction, Observable, startWith, tap } from 'rxjs';\nimport type { NgtAnyRecord } from '../types';\nimport { is } from '../utils/is';\nimport { safeDetectChanges } from '../utils/safe-detect-changes';\n\nexport const startWithUndefined = <T>(): MonoTypeOperatorFunction<T> => startWith<T>(undefined! as T);\n\ntype EffectFn<TValue> = (\n    value: TValue\n) => void | undefined | ((cleanUpParams: { prev: TValue | undefined; complete: boolean; error: boolean }) => void);\n\n/**\n * An extended `tap` operator that accepts an `effectFn` which:\n * - runs on every `next` notification from `source$`\n * - can optionally return a `cleanUp` function that\n * invokes from the 2nd `next` notification onward and on `unsubscribe` (destroyed)\n *\n * @example\n * ```typescript\n * source$.pipe(\n *  tapEffect((sourceValue) = {\n *    const cb = () => {\n *      doStuff(sourceValue);\n *    };\n *    addListener('event', cb);\n *\n *    return () => {\n *      removeListener('event', cb);\n *    }\n *  })\n * )\n * ```\n */\nexport function tapEffect<TValue>(effectFn: EffectFn<TValue>): MonoTypeOperatorFunction<TValue> {\n    let cleanupFn: (cleanUpParams: { prev: TValue | undefined; complete: boolean; error: boolean }) => void = () => {};\n    let firstRun = false;\n    let prev: TValue | undefined = undefined;\n\n    const teardown = (error: boolean) => () => {\n        if (cleanupFn) cleanupFn({ prev, complete: true, error });\n    };\n\n    return tap<TValue>({\n        next: (value: TValue) => {\n            if (cleanupFn && firstRun) cleanupFn({ prev, complete: false, error: false });\n\n            const cleanUpOrVoid = effectFn(value);\n            if (cleanUpOrVoid) cleanupFn = cleanUpOrVoid;\n\n            prev = value;\n\n            if (!firstRun) firstRun = true;\n        },\n        complete: teardown(false),\n        unsubscribe: teardown(false),\n        error: teardown(true),\n    });\n}\n\n@Injectable()\nexport class NgtRxStore<\n    TState extends object = any,\n    TRxState extends object = TState & Record<string, any>\n> extends RxState<TRxState> {\n    constructor() {\n        super();\n        // set a dummy property so that initial this.get() won't return undefined\n        this.set({ __ngt_dummy__: '__ngt_dummy__' } as TRxState);\n        // override set so our consumers don't have to handle undefined for state that already have default values\n        const originalSet = this.set.bind(this);\n        Object.defineProperty(this, 'set', {\n            get: () => {\n                return (...args: Parameters<RxState<TRxState>['set']>) => {\n                    const firstArg = args[0];\n                    if (is.obj(firstArg)) {\n                        const modArgs = Object.entries(firstArg).reduce((modded, [key, value]) => {\n                            modded[key] = value === undefined ? this.get(key as keyof TRxState) : value;\n                            return modded;\n                        }, {} as NgtAnyRecord);\n                        return originalSet(modArgs as Partial<TRxState>);\n                    }\n                    return originalSet(...args);\n                };\n            },\n        });\n\n        // override get to return {} if get() returns undefined\n        const originalGet = this.get.bind(this);\n        Object.defineProperty(this, 'get', {\n            get:\n                () =>\n                (...args: Parameters<RxState<TRxState>['get']>) => {\n                    if ((args as any[]).length === 0) return originalGet() ?? {};\n                    return originalGet(...args);\n                },\n        });\n\n        // call initialize that might be setup by derived Stores\n        this.initialize();\n    }\n\n    protected initialize() {\n        return;\n    }\n\n    effect<S>(obs: Observable<S>, sideEffectFn: EffectFn<S>): void {\n        return this.hold(obs.pipe(tapEffect(sideEffectFn)));\n    }\n\n    triggerChangeDetection(cdr: ChangeDetectorRef, keys: Array<keyof TRxState> = []) {\n        let $: Observable<any> = this.$;\n\n        if (keys.length) {\n            $ = combineLatest(keys.map((key) => this.select(key).pipe(startWith(this.get(key) ?? undefined))));\n        }\n\n        this.hold($, () => void requestAnimationFrame(() => void safeDetectChanges(cdr)));\n    }\n}\n"]}
|
package/lib/di/destroy.d.ts
DELETED
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
import { ChangeDetectorRef } from '@angular/core';
|
|
2
|
-
import { Observable } from 'rxjs';
|
|
3
|
-
/**
|
|
4
|
-
* A utility injection fn that can be used in other injection fn to provide the destroy capability.
|
|
5
|
-
*/
|
|
6
|
-
export declare function injectNgtDestroy(cb?: () => void): {
|
|
7
|
-
destroy$: Observable<void>;
|
|
8
|
-
cdr: ChangeDetectorRef;
|
|
9
|
-
};
|
package/lib/pipes/push.d.ts
DELETED
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
import { OnDestroy, PipeTransform } from '@angular/core';
|
|
2
|
-
import { ObservableInput } from 'rxjs';
|
|
3
|
-
import * as i0 from "@angular/core";
|
|
4
|
-
export declare class NgtPush<T> implements PipeTransform, OnDestroy {
|
|
5
|
-
private readonly cdr;
|
|
6
|
-
private readonly parentCdr;
|
|
7
|
-
private readonly envCdr;
|
|
8
|
-
private sub?;
|
|
9
|
-
private obj?;
|
|
10
|
-
private latestValue?;
|
|
11
|
-
transform(value: ObservableInput<T>, defaultValue?: T): T;
|
|
12
|
-
private updateValue;
|
|
13
|
-
ngOnDestroy(): void;
|
|
14
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<NgtPush<any>, never>;
|
|
15
|
-
static ɵpipe: i0.ɵɵPipeDeclaration<NgtPush<any>, "ngtPush", true>;
|
|
16
|
-
}
|
package/lib/stores/rx-store.d.ts
DELETED
|
@@ -1,42 +0,0 @@
|
|
|
1
|
-
import { ChangeDetectorRef } from '@angular/core';
|
|
2
|
-
import { RxState } from '@rx-angular/state';
|
|
3
|
-
import { MonoTypeOperatorFunction, Observable } from 'rxjs';
|
|
4
|
-
import * as i0 from "@angular/core";
|
|
5
|
-
export declare const startWithUndefined: <T>() => MonoTypeOperatorFunction<T>;
|
|
6
|
-
type EffectFn<TValue> = (value: TValue) => void | undefined | ((cleanUpParams: {
|
|
7
|
-
prev: TValue | undefined;
|
|
8
|
-
complete: boolean;
|
|
9
|
-
error: boolean;
|
|
10
|
-
}) => void);
|
|
11
|
-
/**
|
|
12
|
-
* An extended `tap` operator that accepts an `effectFn` which:
|
|
13
|
-
* - runs on every `next` notification from `source$`
|
|
14
|
-
* - can optionally return a `cleanUp` function that
|
|
15
|
-
* invokes from the 2nd `next` notification onward and on `unsubscribe` (destroyed)
|
|
16
|
-
*
|
|
17
|
-
* @example
|
|
18
|
-
* ```typescript
|
|
19
|
-
* source$.pipe(
|
|
20
|
-
* tapEffect((sourceValue) = {
|
|
21
|
-
* const cb = () => {
|
|
22
|
-
* doStuff(sourceValue);
|
|
23
|
-
* };
|
|
24
|
-
* addListener('event', cb);
|
|
25
|
-
*
|
|
26
|
-
* return () => {
|
|
27
|
-
* removeListener('event', cb);
|
|
28
|
-
* }
|
|
29
|
-
* })
|
|
30
|
-
* )
|
|
31
|
-
* ```
|
|
32
|
-
*/
|
|
33
|
-
export declare function tapEffect<TValue>(effectFn: EffectFn<TValue>): MonoTypeOperatorFunction<TValue>;
|
|
34
|
-
export declare class NgtRxStore<TState extends object = any, TRxState extends object = TState & Record<string, any>> extends RxState<TRxState> {
|
|
35
|
-
constructor();
|
|
36
|
-
protected initialize(): void;
|
|
37
|
-
effect<S>(obs: Observable<S>, sideEffectFn: EffectFn<S>): void;
|
|
38
|
-
triggerChangeDetection(cdr: ChangeDetectorRef, keys?: Array<keyof TRxState>): void;
|
|
39
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<NgtRxStore<any, any>, never>;
|
|
40
|
-
static ɵprov: i0.ɵɵInjectableDeclaration<NgtRxStore<any, any>>;
|
|
41
|
-
}
|
|
42
|
-
export {};
|