angular-three 2.0.0-beta.223 → 2.0.0-beta.225
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/esm2022/index.mjs +2 -2
- package/esm2022/lib/canvas.mjs +22 -40
- package/esm2022/lib/directives/args.mjs +17 -17
- package/esm2022/lib/directives/common.mjs +3 -3
- package/esm2022/lib/directives/parent.mjs +17 -17
- package/esm2022/lib/instance.mjs +1 -1
- package/esm2022/lib/loader.mjs +1 -1
- package/esm2022/lib/loop.mjs +19 -3
- package/esm2022/lib/portal.mjs +29 -53
- package/esm2022/lib/renderer/index.mjs +3 -3
- package/esm2022/lib/renderer/store.mjs +9 -3
- package/esm2022/lib/renderer/utils.mjs +16 -5
- package/esm2022/lib/roots.mjs +11 -2
- package/esm2022/lib/routed-scene.mjs +3 -3
- package/esm2022/lib/three-types.mjs +2 -0
- package/esm2022/lib/utils/apply-props.mjs +4 -3
- package/esm2022/lib/utils/is.mjs +1 -1
- package/fesm2022/angular-three.mjs +140 -162
- package/fesm2022/angular-three.mjs.map +1 -1
- package/index.d.ts +1 -1
- package/lib/canvas.d.ts +8 -10
- package/lib/directives/args.d.ts +4 -3
- package/lib/directives/parent.d.ts +5 -3
- package/lib/instance.d.ts +4 -3
- package/lib/loader.d.ts +1 -0
- package/lib/portal.d.ts +10 -12
- package/lib/three-types.d.ts +302 -0
- package/lib/utils/is.d.ts +9 -8
- package/metadata.json +1 -1
- package/package.json +4 -4
- package/web-types.json +1 -1
- package/esm2022/lib/utils/cd-aware-signal.mjs +0 -24
- package/lib/utils/cd-aware-signal.d.ts +0 -4
package/esm2022/index.mjs
CHANGED
|
@@ -11,10 +11,10 @@ export * from './lib/store';
|
|
|
11
11
|
export * from './lib/utils/apply-props';
|
|
12
12
|
export { createAttachFunction } from './lib/utils/attach';
|
|
13
13
|
export * from './lib/utils/before-render';
|
|
14
|
-
export * from './lib/utils/cd-aware-signal';
|
|
15
14
|
export * from './lib/utils/create-api-token';
|
|
16
15
|
export * from './lib/utils/is';
|
|
17
16
|
export * from './lib/utils/make';
|
|
18
17
|
export * from './lib/utils/signal-store';
|
|
19
18
|
export * from './lib/utils/update';
|
|
20
|
-
|
|
19
|
+
import './lib/three-types';
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9saWJzL2NvcmUvc3JjL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYyxnQkFBZ0IsQ0FBQztBQUMvQixjQUFjLGNBQWMsQ0FBQztBQUM3QixPQUFPLEVBQUUsY0FBYyxFQUFFLFNBQVMsRUFBRSxPQUFPLEVBQUUsTUFBTSxZQUFZLENBQUM7QUFDaEUsT0FBTyxFQUFFLFNBQVMsRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGNBQWMsQ0FBQztBQUMzRCxjQUFjLFdBQVcsQ0FBQztBQUMxQixjQUFjLGdCQUFnQixDQUFDO0FBQy9CLGNBQWMsb0JBQW9CLENBQUM7QUFDbkMsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUMxRCxjQUFjLDJCQUEyQixDQUFDO0FBQzFDLGNBQWMsOEJBQThCLENBQUM7QUFDN0MsY0FBYyxnQkFBZ0IsQ0FBQztBQUMvQixjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsMEJBQTBCLENBQUM7QUFDekMsY0FBYyxvQkFBb0IsQ0FBQztBQU1uQyxPQUFPLG1CQUFtQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9saWIvY2FudmFzJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2RpcmVjdGl2ZXMvYXJncyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9pbnN0YW5jZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9sb2FkZXInO1xuZXhwb3J0IHsgYWRkQWZ0ZXJFZmZlY3QsIGFkZEVmZmVjdCwgYWRkVGFpbCB9IGZyb20gJy4vbGliL2xvb3AnO1xuZXhwb3J0IHsgTmd0UG9ydGFsLCBOZ3RQb3J0YWxDb250ZW50IH0gZnJvbSAnLi9saWIvcG9ydGFsJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3JlZic7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9yZW5kZXJlcic7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9yb3V0ZWQtc2NlbmUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvc3RvcmUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdXRpbHMvYXBwbHktcHJvcHMnO1xuZXhwb3J0IHsgY3JlYXRlQXR0YWNoRnVuY3Rpb24gfSBmcm9tICcuL2xpYi91dGlscy9hdHRhY2gnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdXRpbHMvYmVmb3JlLXJlbmRlcic7XG5leHBvcnQgKiBmcm9tICcuL2xpYi91dGlscy9jcmVhdGUtYXBpLXRva2VuJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3V0aWxzL2lzJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3V0aWxzL21ha2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdXRpbHMvc2lnbmFsLXN0b3JlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3V0aWxzL3VwZGF0ZSc7XG5cbmV4cG9ydCB0eXBlIHsgTmd0Q2FtZXJhLCBOZ3RUaHJlZUV2ZW50IH0gZnJvbSAnLi9saWIvZXZlbnRzJztcbmV4cG9ydCB0eXBlICogZnJvbSAnLi9saWIvdGhyZWUtdHlwZXMnO1xuZXhwb3J0IHR5cGUgKiBmcm9tICcuL2xpYi90eXBlcyc7XG5cbmltcG9ydCAnLi9saWIvdGhyZWUtdHlwZXMnO1xuIl19
|
package/esm2022/lib/canvas.mjs
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component, DestroyRef, ElementRef, EnvironmentInjector, EventEmitter, Injector,
|
|
1
|
+
import { ChangeDetectionStrategy, Component, DestroyRef, ElementRef, EnvironmentInjector, EventEmitter, Injector, NgZone, Output, ViewContainerRef, afterNextRender, computed, createEnvironmentInjector, inject, input, signal, untracked, viewChild, } from '@angular/core';
|
|
2
2
|
import { injectAutoEffect } from 'ngxtension/auto-effect';
|
|
3
3
|
import { NgxResize, provideResizeOptions } from 'ngxtension/resize';
|
|
4
4
|
import * as THREE from 'three';
|
|
@@ -7,27 +7,21 @@ import { provideNgtRenderer } from './renderer';
|
|
|
7
7
|
import { injectCanvasRootInitializer } from './roots';
|
|
8
8
|
import { injectNgtStore, provideNgtStore, } from './store';
|
|
9
9
|
import { is } from './utils/is';
|
|
10
|
-
import {
|
|
10
|
+
import {} from './utils/signal-store';
|
|
11
11
|
import * as i0 from "@angular/core";
|
|
12
12
|
export class NgtCanvas {
|
|
13
|
-
set _sceneGraphInputs(value) {
|
|
14
|
-
this.sceneGraphInputs.set(value);
|
|
15
|
-
}
|
|
16
|
-
set _canvasInputs(value) {
|
|
17
|
-
this.canvasInputs.update(value);
|
|
18
|
-
}
|
|
19
13
|
constructor() {
|
|
20
14
|
this.store = injectNgtStore();
|
|
21
15
|
this.initRoot = injectCanvasRootInitializer();
|
|
22
16
|
this.autoEffect = injectAutoEffect();
|
|
23
17
|
this.host = inject(ElementRef);
|
|
24
|
-
this.viewContainerRef = inject(ViewContainerRef);
|
|
25
18
|
this.zone = inject(NgZone);
|
|
26
19
|
this.environmentInjector = inject(EnvironmentInjector);
|
|
27
20
|
this.injector = inject(Injector);
|
|
28
|
-
this.
|
|
29
|
-
this.
|
|
30
|
-
this.
|
|
21
|
+
this.sceneGraph = input.required();
|
|
22
|
+
this.compoundPrefixes = input([]);
|
|
23
|
+
this.sceneGraphInputs = input({});
|
|
24
|
+
this.options = input({
|
|
31
25
|
shadows: false,
|
|
32
26
|
linear: false,
|
|
33
27
|
flat: false,
|
|
@@ -38,13 +32,15 @@ export class NgtCanvas {
|
|
|
38
32
|
events: createPointerEvents,
|
|
39
33
|
});
|
|
40
34
|
this.created = new EventEmitter();
|
|
35
|
+
this.glCanvas = viewChild.required('glCanvas');
|
|
36
|
+
this.glCanvasViewContainerRef = viewChild.required('glCanvas', { read: ViewContainerRef });
|
|
41
37
|
// NOTE: this signal is updated outside of Zone
|
|
42
38
|
this.resizeResult = signal({}, { equal: Object.is });
|
|
43
|
-
this.eventSource = this.
|
|
39
|
+
this.eventSource = computed(() => this.options().eventSource);
|
|
44
40
|
this.hbPointerEvents = computed(() => (this.eventSource() ? 'none' : 'auto'));
|
|
45
41
|
afterNextRender(() => {
|
|
46
42
|
this.zone.runOutsideAngular(() => {
|
|
47
|
-
this.configurator = this.initRoot(this.glCanvas.nativeElement);
|
|
43
|
+
this.configurator = this.initRoot(this.glCanvas().nativeElement);
|
|
48
44
|
this.noZoneResizeEffect();
|
|
49
45
|
this.noZoneSceneGraphInputsEffect();
|
|
50
46
|
});
|
|
@@ -60,8 +56,8 @@ export class NgtCanvas {
|
|
|
60
56
|
const resizeResult = this.resizeResult();
|
|
61
57
|
if (resizeResult.width > 0 && resizeResult.height > 0) {
|
|
62
58
|
if (!this.configurator)
|
|
63
|
-
this.configurator = this.initRoot(this.glCanvas.nativeElement);
|
|
64
|
-
this.configurator.configure({ ...this.
|
|
59
|
+
this.configurator = this.initRoot(this.glCanvas().nativeElement);
|
|
60
|
+
this.configurator.configure({ ...this.options(), size: resizeResult });
|
|
65
61
|
untracked(() => {
|
|
66
62
|
if (this.glRef) {
|
|
67
63
|
this.glRef.changeDetectorRef.detectChanges();
|
|
@@ -79,7 +75,7 @@ export class NgtCanvas {
|
|
|
79
75
|
this.glRef?.destroy();
|
|
80
76
|
// NOTE: Flag the canvas active, rendering will now begin
|
|
81
77
|
this.store.update((state) => ({ internal: { ...state.internal, active: true } }));
|
|
82
|
-
const [inputs, state] = [this.
|
|
78
|
+
const [inputs, state] = [untracked(this.options), this.store.snapshot];
|
|
83
79
|
// connect to event source
|
|
84
80
|
state.events.connect?.(inputs.eventSource
|
|
85
81
|
? is.ref(inputs.eventSource)
|
|
@@ -103,10 +99,10 @@ export class NgtCanvas {
|
|
|
103
99
|
this.created.emit(this.store.snapshot);
|
|
104
100
|
}
|
|
105
101
|
if (!this.store.get('events', 'connected')) {
|
|
106
|
-
this.store.get('events').connect?.(this.glCanvas.nativeElement);
|
|
102
|
+
this.store.get('events').connect?.(this.glCanvas().nativeElement);
|
|
107
103
|
}
|
|
108
|
-
this.glEnvironmentInjector = createEnvironmentInjector([provideNgtRenderer(this.store, this.compoundPrefixes)], this.environmentInjector);
|
|
109
|
-
this.glRef = this.
|
|
104
|
+
this.glEnvironmentInjector = createEnvironmentInjector([provideNgtRenderer(this.store, untracked(this.compoundPrefixes))], this.environmentInjector);
|
|
105
|
+
this.glRef = untracked(this.glCanvasViewContainerRef).createComponent(untracked(this.sceneGraph), {
|
|
110
106
|
environmentInjector: this.glEnvironmentInjector,
|
|
111
107
|
injector: this.injector,
|
|
112
108
|
});
|
|
@@ -125,17 +121,17 @@ export class NgtCanvas {
|
|
|
125
121
|
}
|
|
126
122
|
}
|
|
127
123
|
}
|
|
128
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.
|
|
129
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "
|
|
124
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.9", ngImport: i0, type: NgtCanvas, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
125
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "17.3.9", type: NgtCanvas, isStandalone: true, selector: "ngt-canvas", inputs: { sceneGraph: { classPropertyName: "sceneGraph", publicName: "sceneGraph", isSignal: true, isRequired: true, transformFunction: null }, compoundPrefixes: { classPropertyName: "compoundPrefixes", publicName: "compoundPrefixes", isSignal: true, isRequired: false, transformFunction: null }, sceneGraphInputs: { classPropertyName: "sceneGraphInputs", publicName: "sceneGraphInputs", isSignal: true, isRequired: false, transformFunction: null }, options: { classPropertyName: "options", publicName: "options", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { created: "created" }, host: { properties: { "style.pointerEvents": "hbPointerEvents()" }, styleAttribute: "display: block;position: relative;width: 100%;height: 100%;overflow: hidden;" }, providers: [
|
|
130
126
|
provideResizeOptions({ emitInZone: false, emitInitialResult: true, debounce: 250 }),
|
|
131
127
|
provideNgtStore(),
|
|
132
|
-
], viewQueries: [{ propertyName: "glCanvas", first: true, predicate: ["glCanvas"], descendants: true,
|
|
128
|
+
], viewQueries: [{ propertyName: "glCanvas", first: true, predicate: ["glCanvas"], descendants: true, isSignal: true }, { propertyName: "glCanvasViewContainerRef", first: true, predicate: ["glCanvas"], descendants: true, read: ViewContainerRef, isSignal: true }], ngImport: i0, template: `
|
|
133
129
|
<div (ngxResize)="resizeResult.set($event)" style="height: 100%; width: 100%;">
|
|
134
130
|
<canvas #glCanvas style="display: block;"></canvas>
|
|
135
131
|
</div>
|
|
136
132
|
`, isInline: true, dependencies: [{ kind: "directive", type: NgxResize, selector: "[ngxResize]", inputs: ["ngxResizeOptions"], outputs: ["ngxResize"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
137
133
|
}
|
|
138
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.
|
|
134
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.9", ngImport: i0, type: NgtCanvas, decorators: [{
|
|
139
135
|
type: Component,
|
|
140
136
|
args: [{
|
|
141
137
|
selector: 'ngt-canvas',
|
|
@@ -156,21 +152,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.1", ngImpor
|
|
|
156
152
|
},
|
|
157
153
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
158
154
|
}]
|
|
159
|
-
}], ctorParameters: () => [], propDecorators: {
|
|
160
|
-
type: Input,
|
|
161
|
-
args: [{ required: true }]
|
|
162
|
-
}], compoundPrefixes: [{
|
|
163
|
-
type: Input
|
|
164
|
-
}], _sceneGraphInputs: [{
|
|
165
|
-
type: Input,
|
|
166
|
-
args: [{ alias: 'sceneGraphInputs' }]
|
|
167
|
-
}], _canvasInputs: [{
|
|
168
|
-
type: Input,
|
|
169
|
-
args: [{ alias: 'options' }]
|
|
170
|
-
}], created: [{
|
|
155
|
+
}], ctorParameters: () => [], propDecorators: { created: [{
|
|
171
156
|
type: Output
|
|
172
|
-
}], glCanvas: [{
|
|
173
|
-
type: ViewChild,
|
|
174
|
-
args: ['glCanvas', { static: true }]
|
|
175
157
|
}] } });
|
|
176
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"canvas.js","sourceRoot":"","sources":["../../../../../libs/core/src/lib/canvas.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n\tChangeDetectionStrategy,\n\tComponent,\n\tDestroyRef,\n\tElementRef,\n\tEnvironmentInjector,\n\tEventEmitter,\n\tInjector,\n\tInput,\n\tNgZone,\n\tOutput,\n\tViewChild,\n\tViewContainerRef,\n\tafterNextRender,\n\tcomputed,\n\tcreateEnvironmentInjector,\n\tinject,\n\tsignal,\n\tuntracked,\n\ttype ComponentRef,\n\ttype Type,\n} from '@angular/core';\nimport { injectAutoEffect } from 'ngxtension/auto-effect';\nimport { NgxResize, provideResizeOptions, type ResizeOptions, type ResizeResult } from 'ngxtension/resize';\nimport * as THREE from 'three';\nimport { createPointerEvents } from './dom/events';\nimport type { NgtCamera, NgtDomEvent, NgtEventManager } from './events';\nimport { provideNgtRenderer } from './renderer';\nimport { injectCanvasRootInitializer, type NgtCanvasConfigurator, type NgtCanvasElement } from './roots';\nimport {\n\tinjectNgtStore,\n\tprovideNgtStore,\n\ttype NgtDpr,\n\ttype NgtPerformance,\n\ttype NgtRendererLike,\n\ttype NgtSize,\n\ttype NgtState,\n} from './store';\nimport type { NgtObject3DNode } from './three-types';\nimport type { NgtAnyRecord, NgtProperties } from './types';\nimport { is } from './utils/is';\nimport { signalStore, type NgtSignalStore } from './utils/signal-store';\n\nexport type NgtGLOptions =\n\t| NgtRendererLike\n\t| ((canvas: NgtCanvasElement) => NgtRendererLike)\n\t| Partial<NgtProperties<THREE.WebGLRenderer> | THREE.WebGLRendererParameters>\n\t| undefined;\n\nexport type NgtCanvasInputs = {\n\t/** A threejs renderer instance or props that go into the default renderer */\n\tgl?: NgtGLOptions;\n\t/** Dimensions to fit the renderer to. Will measure canvas dimensions if omitted */\n\tsize?: NgtSize;\n\t/**\n\t * Enables shadows (by default PCFsoft). Can accept `gl.shadowMap` options for fine-tuning,\n\t * but also strings: 'basic' | 'percentage' | 'soft' | 'variance'.\n\t * @see https://threejs.org/docs/#api/en/renderers/WebGLRenderer.shadowMap\n\t */\n\tshadows?: boolean | 'basic' | 'percentage' | 'soft' | 'variance' | Partial<THREE.WebGLShadowMap>;\n\t/**\n\t * Disables three r139 color management.\n\t * @see https://threejs.org/docs/#manual/en/introduction/Color-management\n\t */\n\tlegacy?: boolean;\n\t/** Switch off automatic sRGB color space and gamma correction */\n\tlinear?: boolean;\n\t/** Use `THREE.NoToneMapping` instead of `THREE.ACESFilmicToneMapping` */\n\tflat?: boolean;\n\t/** Creates an orthographic camera */\n\torthographic?: boolean;\n\t/**\n\t * R3F's render mode. Set to `demand` to only render on state change or `never` to take control.\n\t * @see https://docs.pmnd.rs/react-three-fiber/advanced/scaling-performance#on-demand-rendering\n\t */\n\tframeloop?: 'always' | 'demand' | 'never';\n\t/**\n\t * R3F performance options for adaptive performance.\n\t * @see https://docs.pmnd.rs/react-three-fiber/advanced/scaling-performance#movement-regression\n\t */\n\tperformance?: Partial<Omit<NgtPerformance, 'regress'>>;\n\t/** Target pixel ratio. Can clamp between a range: `[min, max]` */\n\tdpr?: NgtDpr;\n\t/** Props that go into the default raycaster */\n\traycaster?: Partial<THREE.Raycaster>;\n\t/** A `THREE.Scene` instance or props that go into the default scene */\n\tscene?: THREE.Scene | Partial<THREE.Scene>;\n\t/** A `Camera` instance or props that go into the default camera */\n\tcamera?: (\n\t\t| NgtCamera\n\t\t| Partial<\n\t\t\t\tNgtObject3DNode<THREE.Camera, typeof THREE.Camera> &\n\t\t\t\t\tNgtObject3DNode<THREE.PerspectiveCamera, typeof THREE.PerspectiveCamera> &\n\t\t\t\t\tNgtObject3DNode<THREE.OrthographicCamera, typeof THREE.OrthographicCamera>\n\t\t  >\n\t) & {\n\t\t/** Flags the camera as manual, putting projection into your own hands */\n\t\tmanual?: boolean;\n\t};\n\t/** An R3F event manager to manage elements' pointer events */\n\tevents?: (store: NgtSignalStore<NgtState>) => NgtEventManager<HTMLElement>;\n\t/** The target where events are being subscribed to, default: the div that wraps canvas */\n\teventSource?: HTMLElement | ElementRef<HTMLElement>;\n\t/** The event prefix that is cast into canvas pointer x/y events, default: \"offset\" */\n\teventPrefix?: 'offset' | 'client' | 'page' | 'layer' | 'screen';\n\t/** Default coordinate for the camera to look at */\n\tlookAt?: THREE.Vector3 | Parameters<THREE.Vector3['set']>;\n};\n\n@Component({\n\tselector: 'ngt-canvas',\n\tstandalone: true,\n\ttemplate: `\n\t\t<div (ngxResize)=\"resizeResult.set($event)\" style=\"height: 100%; width: 100%;\">\n\t\t\t<canvas #glCanvas style=\"display: block;\"></canvas>\n\t\t</div>\n\t`,\n\timports: [NgxResize],\n\tproviders: [\n\t\tprovideResizeOptions({ emitInZone: false, emitInitialResult: true, debounce: 250 } as ResizeOptions),\n\t\tprovideNgtStore(),\n\t],\n\thost: {\n\t\tstyle: 'display: block;position: relative;width: 100%;height: 100%;overflow: hidden;',\n\t\t'[style.pointerEvents]': 'hbPointerEvents()',\n\t},\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class NgtCanvas {\n\tprivate store = injectNgtStore();\n\tprivate initRoot = injectCanvasRootInitializer();\n\tprivate autoEffect = injectAutoEffect();\n\n\tprivate host = inject<ElementRef<HTMLElement>>(ElementRef);\n\tprivate viewContainerRef = inject(ViewContainerRef);\n\tprivate zone = inject(NgZone);\n\tprivate environmentInjector = inject(EnvironmentInjector);\n\tprivate injector = inject(Injector);\n\n\t@Input({ required: true }) sceneGraph!: Type<any>;\n\t@Input() compoundPrefixes: string[] = [];\n\n\tprivate sceneGraphInputs = signal<NgtAnyRecord>({}, { equal: Object.is });\n\t@Input({ alias: 'sceneGraphInputs' }) set _sceneGraphInputs(value: NgtAnyRecord) {\n\t\tthis.sceneGraphInputs.set(value);\n\t}\n\n\tprivate canvasInputs = signalStore<NgtCanvasInputs>({\n\t\tshadows: false,\n\t\tlinear: false,\n\t\tflat: false,\n\t\tlegacy: false,\n\t\torthographic: false,\n\t\tframeloop: 'always',\n\t\tdpr: [1, 2],\n\t\tevents: createPointerEvents,\n\t});\n\t@Input({ alias: 'options' }) set _canvasInputs(value: Partial<NgtCanvasInputs>) {\n\t\tthis.canvasInputs.update(value);\n\t}\n\n\t@Output() created = new EventEmitter<NgtState>();\n\n\t@ViewChild('glCanvas', { static: true }) glCanvas!: ElementRef<HTMLCanvasElement>;\n\n\t// NOTE: this signal is updated outside of Zone\n\tprotected resizeResult = signal<ResizeResult>({} as ResizeResult, { equal: Object.is });\n\n\tprivate eventSource = this.canvasInputs.select('eventSource');\n\tprotected hbPointerEvents = computed(() => (this.eventSource() ? 'none' : 'auto'));\n\n\tprivate configurator?: NgtCanvasConfigurator;\n\tprivate glEnvironmentInjector?: EnvironmentInjector;\n\tprivate glRef?: ComponentRef<unknown>;\n\n\tconstructor() {\n\t\tafterNextRender(() => {\n\t\t\tthis.zone.runOutsideAngular(() => {\n\t\t\t\tthis.configurator = this.initRoot(this.glCanvas.nativeElement);\n\t\t\t\tthis.noZoneResizeEffect();\n\t\t\t\tthis.noZoneSceneGraphInputsEffect();\n\t\t\t});\n\t\t});\n\n\t\tinject(DestroyRef).onDestroy(() => {\n\t\t\tthis.glRef?.destroy();\n\t\t\tthis.glEnvironmentInjector?.destroy();\n\t\t\tthis.configurator?.destroy();\n\t\t});\n\t}\n\n\tprivate noZoneResizeEffect() {\n\t\tthis.autoEffect(() => {\n\t\t\tconst resizeResult = this.resizeResult();\n\t\t\tif (resizeResult.width > 0 && resizeResult.height > 0) {\n\t\t\t\tif (!this.configurator) this.configurator = this.initRoot(this.glCanvas.nativeElement);\n\t\t\t\tthis.configurator.configure({ ...this.canvasInputs.state(), size: resizeResult });\n\n\t\t\t\tuntracked(() => {\n\t\t\t\t\tif (this.glRef) {\n\t\t\t\t\t\tthis.glRef.changeDetectorRef.detectChanges();\n\t\t\t\t\t} else {\n\t\t\t\t\t\tthis.noZoneRender();\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t}\n\t\t});\n\t}\n\n\tprivate noZoneRender() {\n\t\t// NOTE: destroy previous instances if existed\n\t\tthis.glEnvironmentInjector?.destroy();\n\t\tthis.glRef?.destroy();\n\n\t\t// NOTE: Flag the canvas active, rendering will now begin\n\t\tthis.store.update((state) => ({ internal: { ...state.internal, active: true } }));\n\n\t\tconst [inputs, state] = [this.canvasInputs.snapshot, this.store.snapshot];\n\n\t\t// connect to event source\n\t\tstate.events.connect?.(\n\t\t\tinputs.eventSource\n\t\t\t\t? is.ref(inputs.eventSource)\n\t\t\t\t\t? inputs.eventSource.nativeElement\n\t\t\t\t\t: inputs.eventSource\n\t\t\t\t: this.host.nativeElement,\n\t\t);\n\n\t\t// setup compute for eventPrefix\n\t\tif (inputs.eventPrefix) {\n\t\t\tstate.setEvents({\n\t\t\t\tcompute: (event, store) => {\n\t\t\t\t\tconst { pointer, raycaster, camera, size } = store.snapshot;\n\t\t\t\t\tconst x = event[(inputs.eventPrefix + 'X') as keyof NgtDomEvent] as number;\n\t\t\t\t\tconst y = event[(inputs.eventPrefix + 'Y') as keyof NgtDomEvent] as number;\n\t\t\t\t\tpointer.set((x / size.width) * 2 - 1, -(y / size.height) * 2 + 1);\n\t\t\t\t\traycaster.setFromCamera(pointer, camera);\n\t\t\t\t},\n\t\t\t});\n\t\t}\n\n\t\t// emit created event if observed\n\t\tif (this.created.observed) {\n\t\t\tthis.created.emit(this.store.snapshot);\n\t\t}\n\n\t\tif (!this.store.get('events', 'connected')) {\n\t\t\tthis.store.get('events').connect?.(this.glCanvas.nativeElement);\n\t\t}\n\n\t\tthis.glEnvironmentInjector = createEnvironmentInjector(\n\t\t\t[provideNgtRenderer(this.store, this.compoundPrefixes)],\n\t\t\tthis.environmentInjector,\n\t\t);\n\t\tthis.glRef = this.viewContainerRef.createComponent(this.sceneGraph, {\n\t\t\tenvironmentInjector: this.glEnvironmentInjector,\n\t\t\tinjector: this.injector,\n\t\t});\n\n\t\tthis.glRef.changeDetectorRef.detectChanges();\n\t\tthis.setSceneGraphInputs(untracked(this.sceneGraphInputs));\n\t}\n\n\tprivate noZoneSceneGraphInputsEffect() {\n\t\tthis.autoEffect(() => {\n\t\t\tthis.setSceneGraphInputs(this.sceneGraphInputs());\n\t\t});\n\t}\n\n\tprivate setSceneGraphInputs(sceneGraphInputs: NgtAnyRecord) {\n\t\tif (this.glRef) {\n\t\t\tfor (const [key, value] of Object.entries(sceneGraphInputs)) {\n\t\t\t\tthis.glRef.setInput(key, value);\n\t\t\t}\n\t\t}\n\t}\n}\n"]}
|
|
158
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"canvas.js","sourceRoot":"","sources":["../../../../../libs/core/src/lib/canvas.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n\tChangeDetectionStrategy,\n\tComponent,\n\tDestroyRef,\n\tElementRef,\n\tEnvironmentInjector,\n\tEventEmitter,\n\tInjector,\n\tNgZone,\n\tOutput,\n\tViewContainerRef,\n\tafterNextRender,\n\tcomputed,\n\tcreateEnvironmentInjector,\n\tinject,\n\tinput,\n\tsignal,\n\tuntracked,\n\tviewChild,\n\ttype ComponentRef,\n\ttype Type,\n} from '@angular/core';\nimport { injectAutoEffect } from 'ngxtension/auto-effect';\nimport { NgxResize, provideResizeOptions, type ResizeOptions, type ResizeResult } from 'ngxtension/resize';\nimport * as THREE from 'three';\nimport { createPointerEvents } from './dom/events';\nimport type { NgtCamera, NgtDomEvent, NgtEventManager } from './events';\nimport { provideNgtRenderer } from './renderer';\nimport { injectCanvasRootInitializer, type NgtCanvasConfigurator, type NgtCanvasElement } from './roots';\nimport {\n\tinjectNgtStore,\n\tprovideNgtStore,\n\ttype NgtDpr,\n\ttype NgtPerformance,\n\ttype NgtRendererLike,\n\ttype NgtSize,\n\ttype NgtState,\n} from './store';\nimport type { NgtObject3DNode } from './three-types';\nimport type { NgtAnyRecord, NgtProperties } from './types';\nimport { is } from './utils/is';\nimport { type NgtSignalStore } from './utils/signal-store';\n\nexport type NgtGLOptions =\n\t| NgtRendererLike\n\t| ((canvas: NgtCanvasElement) => NgtRendererLike)\n\t| Partial<NgtProperties<THREE.WebGLRenderer> | THREE.WebGLRendererParameters>\n\t| undefined;\n\nexport type NgtCanvasInputs = {\n\t/** A threejs renderer instance or props that go into the default renderer */\n\tgl?: NgtGLOptions;\n\t/** Dimensions to fit the renderer to. Will measure canvas dimensions if omitted */\n\tsize?: NgtSize;\n\t/**\n\t * Enables shadows (by default PCFsoft). Can accept `gl.shadowMap` options for fine-tuning,\n\t * but also strings: 'basic' | 'percentage' | 'soft' | 'variance'.\n\t * @see https://threejs.org/docs/#api/en/renderers/WebGLRenderer.shadowMap\n\t */\n\tshadows?: boolean | 'basic' | 'percentage' | 'soft' | 'variance' | Partial<THREE.WebGLShadowMap>;\n\t/**\n\t * Disables three r139 color management.\n\t * @see https://threejs.org/docs/#manual/en/introduction/Color-management\n\t */\n\tlegacy?: boolean;\n\t/** Switch off automatic sRGB color space and gamma correction */\n\tlinear?: boolean;\n\t/** Use `THREE.NoToneMapping` instead of `THREE.ACESFilmicToneMapping` */\n\tflat?: boolean;\n\t/** Creates an orthographic camera */\n\torthographic?: boolean;\n\t/**\n\t * R3F's render mode. Set to `demand` to only render on state change or `never` to take control.\n\t * @see https://docs.pmnd.rs/react-three-fiber/advanced/scaling-performance#on-demand-rendering\n\t */\n\tframeloop?: 'always' | 'demand' | 'never';\n\t/**\n\t * R3F performance options for adaptive performance.\n\t * @see https://docs.pmnd.rs/react-three-fiber/advanced/scaling-performance#movement-regression\n\t */\n\tperformance?: Partial<Omit<NgtPerformance, 'regress'>>;\n\t/** Target pixel ratio. Can clamp between a range: `[min, max]` */\n\tdpr?: NgtDpr;\n\t/** Props that go into the default raycaster */\n\traycaster?: Partial<THREE.Raycaster>;\n\t/** A `THREE.Scene` instance or props that go into the default scene */\n\tscene?: THREE.Scene | Partial<THREE.Scene>;\n\t/** A `Camera` instance or props that go into the default camera */\n\tcamera?: (\n\t\t| NgtCamera\n\t\t| Partial<\n\t\t\t\tNgtObject3DNode<THREE.Camera, typeof THREE.Camera> &\n\t\t\t\t\tNgtObject3DNode<THREE.PerspectiveCamera, typeof THREE.PerspectiveCamera> &\n\t\t\t\t\tNgtObject3DNode<THREE.OrthographicCamera, typeof THREE.OrthographicCamera>\n\t\t  >\n\t) & {\n\t\t/** Flags the camera as manual, putting projection into your own hands */\n\t\tmanual?: boolean;\n\t};\n\t/** An R3F event manager to manage elements' pointer events */\n\tevents?: (store: NgtSignalStore<NgtState>) => NgtEventManager<HTMLElement>;\n\t/** The target where events are being subscribed to, default: the div that wraps canvas */\n\teventSource?: HTMLElement | ElementRef<HTMLElement>;\n\t/** The event prefix that is cast into canvas pointer x/y events, default: \"offset\" */\n\teventPrefix?: 'offset' | 'client' | 'page' | 'layer' | 'screen';\n\t/** Default coordinate for the camera to look at */\n\tlookAt?: THREE.Vector3 | Parameters<THREE.Vector3['set']>;\n};\n\n@Component({\n\tselector: 'ngt-canvas',\n\tstandalone: true,\n\ttemplate: `\n\t\t<div (ngxResize)=\"resizeResult.set($event)\" style=\"height: 100%; width: 100%;\">\n\t\t\t<canvas #glCanvas style=\"display: block;\"></canvas>\n\t\t</div>\n\t`,\n\timports: [NgxResize],\n\tproviders: [\n\t\tprovideResizeOptions({ emitInZone: false, emitInitialResult: true, debounce: 250 } as ResizeOptions),\n\t\tprovideNgtStore(),\n\t],\n\thost: {\n\t\tstyle: 'display: block;position: relative;width: 100%;height: 100%;overflow: hidden;',\n\t\t'[style.pointerEvents]': 'hbPointerEvents()',\n\t},\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class NgtCanvas {\n\tprivate store = injectNgtStore();\n\tprivate initRoot = injectCanvasRootInitializer();\n\tprivate autoEffect = injectAutoEffect();\n\n\tprivate host = inject<ElementRef<HTMLElement>>(ElementRef);\n\tprivate zone = inject(NgZone);\n\tprivate environmentInjector = inject(EnvironmentInjector);\n\tprivate injector = inject(Injector);\n\n\tsceneGraph = input.required<Type<any>>();\n\tcompoundPrefixes = input<string[]>([]);\n\tsceneGraphInputs = input<NgtAnyRecord>({});\n\toptions = input<NgtCanvasInputs>({\n\t\tshadows: false,\n\t\tlinear: false,\n\t\tflat: false,\n\t\tlegacy: false,\n\t\torthographic: false,\n\t\tframeloop: 'always',\n\t\tdpr: [1, 2],\n\t\tevents: createPointerEvents,\n\t});\n\n\t@Output() created = new EventEmitter<NgtState>();\n\n\tglCanvas = viewChild.required<ElementRef<HTMLCanvasElement>>('glCanvas');\n\tglCanvasViewContainerRef = viewChild.required('glCanvas', { read: ViewContainerRef });\n\n\t// NOTE: this signal is updated outside of Zone\n\tprotected resizeResult = signal<ResizeResult>({} as ResizeResult, { equal: Object.is });\n\n\tprivate eventSource = computed(() => this.options().eventSource);\n\tprotected hbPointerEvents = computed(() => (this.eventSource() ? 'none' : 'auto'));\n\n\tprivate configurator?: NgtCanvasConfigurator;\n\tprivate glEnvironmentInjector?: EnvironmentInjector;\n\tprivate glRef?: ComponentRef<unknown>;\n\n\tconstructor() {\n\t\tafterNextRender(() => {\n\t\t\tthis.zone.runOutsideAngular(() => {\n\t\t\t\tthis.configurator = this.initRoot(this.glCanvas().nativeElement);\n\t\t\t\tthis.noZoneResizeEffect();\n\t\t\t\tthis.noZoneSceneGraphInputsEffect();\n\t\t\t});\n\t\t});\n\n\t\tinject(DestroyRef).onDestroy(() => {\n\t\t\tthis.glRef?.destroy();\n\t\t\tthis.glEnvironmentInjector?.destroy();\n\t\t\tthis.configurator?.destroy();\n\t\t});\n\t}\n\n\tprivate noZoneResizeEffect() {\n\t\tthis.autoEffect(() => {\n\t\t\tconst resizeResult = this.resizeResult();\n\t\t\tif (resizeResult.width > 0 && resizeResult.height > 0) {\n\t\t\t\tif (!this.configurator) this.configurator = this.initRoot(this.glCanvas().nativeElement);\n\t\t\t\tthis.configurator.configure({ ...this.options(), size: resizeResult });\n\n\t\t\t\tuntracked(() => {\n\t\t\t\t\tif (this.glRef) {\n\t\t\t\t\t\tthis.glRef.changeDetectorRef.detectChanges();\n\t\t\t\t\t} else {\n\t\t\t\t\t\tthis.noZoneRender();\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t}\n\t\t});\n\t}\n\n\tprivate noZoneRender() {\n\t\t// NOTE: destroy previous instances if existed\n\t\tthis.glEnvironmentInjector?.destroy();\n\t\tthis.glRef?.destroy();\n\n\t\t// NOTE: Flag the canvas active, rendering will now begin\n\t\tthis.store.update((state) => ({ internal: { ...state.internal, active: true } }));\n\n\t\tconst [inputs, state] = [untracked(this.options), this.store.snapshot];\n\n\t\t// connect to event source\n\t\tstate.events.connect?.(\n\t\t\tinputs.eventSource\n\t\t\t\t? is.ref(inputs.eventSource)\n\t\t\t\t\t? inputs.eventSource.nativeElement\n\t\t\t\t\t: inputs.eventSource\n\t\t\t\t: this.host.nativeElement,\n\t\t);\n\n\t\t// setup compute for eventPrefix\n\t\tif (inputs.eventPrefix) {\n\t\t\tstate.setEvents({\n\t\t\t\tcompute: (event, store) => {\n\t\t\t\t\tconst { pointer, raycaster, camera, size } = store.snapshot;\n\t\t\t\t\tconst x = event[(inputs.eventPrefix + 'X') as keyof NgtDomEvent] as number;\n\t\t\t\t\tconst y = event[(inputs.eventPrefix + 'Y') as keyof NgtDomEvent] as number;\n\t\t\t\t\tpointer.set((x / size.width) * 2 - 1, -(y / size.height) * 2 + 1);\n\t\t\t\t\traycaster.setFromCamera(pointer, camera);\n\t\t\t\t},\n\t\t\t});\n\t\t}\n\n\t\t// emit created event if observed\n\t\tif (this.created.observed) {\n\t\t\tthis.created.emit(this.store.snapshot);\n\t\t}\n\n\t\tif (!this.store.get('events', 'connected')) {\n\t\t\tthis.store.get('events').connect?.(this.glCanvas().nativeElement);\n\t\t}\n\n\t\tthis.glEnvironmentInjector = createEnvironmentInjector(\n\t\t\t[provideNgtRenderer(this.store, untracked(this.compoundPrefixes))],\n\t\t\tthis.environmentInjector,\n\t\t);\n\t\tthis.glRef = untracked(this.glCanvasViewContainerRef).createComponent(untracked(this.sceneGraph), {\n\t\t\tenvironmentInjector: this.glEnvironmentInjector,\n\t\t\tinjector: this.injector,\n\t\t});\n\n\t\tthis.glRef.changeDetectorRef.detectChanges();\n\t\tthis.setSceneGraphInputs(untracked(this.sceneGraphInputs));\n\t}\n\n\tprivate noZoneSceneGraphInputsEffect() {\n\t\tthis.autoEffect(() => {\n\t\t\tthis.setSceneGraphInputs(this.sceneGraphInputs());\n\t\t});\n\t}\n\n\tprivate setSceneGraphInputs(sceneGraphInputs: NgtAnyRecord) {\n\t\tif (this.glRef) {\n\t\t\tfor (const [key, value] of Object.entries(sceneGraphInputs)) {\n\t\t\t\tthis.glRef.setInput(key, value);\n\t\t\t}\n\t\t}\n\t}\n}\n"]}
|
|
@@ -1,19 +1,21 @@
|
|
|
1
|
-
import { Directive,
|
|
1
|
+
import { Directive, effect, input } from '@angular/core';
|
|
2
2
|
import { NgtCommonDirective, provideNodeType } from './common';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
export class NgtArgs extends NgtCommonDirective {
|
|
5
5
|
constructor() {
|
|
6
|
-
super(
|
|
6
|
+
super();
|
|
7
|
+
this.args = input(null);
|
|
7
8
|
this.injectedArgs = [];
|
|
9
|
+
effect(() => {
|
|
10
|
+
const args = this.args();
|
|
11
|
+
if (args == null || !Array.isArray(args) || (args.length === 1 && args[0] === null))
|
|
12
|
+
return;
|
|
13
|
+
this.injected = false;
|
|
14
|
+
this.injectedArgs = args;
|
|
15
|
+
this.createView();
|
|
16
|
+
});
|
|
8
17
|
}
|
|
9
|
-
|
|
10
|
-
if (args == null || !Array.isArray(args) || (args.length === 1 && args[0] === null))
|
|
11
|
-
return;
|
|
12
|
-
this.injected = false;
|
|
13
|
-
this.injectedArgs = args;
|
|
14
|
-
this.createView();
|
|
15
|
-
}
|
|
16
|
-
get args() {
|
|
18
|
+
get value() {
|
|
17
19
|
if (this.validate()) {
|
|
18
20
|
this.injected = true;
|
|
19
21
|
return this.injectedArgs;
|
|
@@ -23,13 +25,11 @@ export class NgtArgs extends NgtCommonDirective {
|
|
|
23
25
|
validate() {
|
|
24
26
|
return !this.injected && !!this.injectedArgs.length;
|
|
25
27
|
}
|
|
26
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.
|
|
27
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "
|
|
28
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.9", ngImport: i0, type: NgtArgs, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
29
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "17.3.9", type: NgtArgs, isStandalone: true, selector: "ng-template[args]", inputs: { args: { classPropertyName: "args", publicName: "args", isSignal: true, isRequired: false, transformFunction: null } }, providers: [provideNodeType('args')], usesInheritance: true, ngImport: i0 }); }
|
|
28
30
|
}
|
|
29
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.
|
|
31
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.9", ngImport: i0, type: NgtArgs, decorators: [{
|
|
30
32
|
type: Directive,
|
|
31
33
|
args: [{ selector: 'ng-template[args]', standalone: true, providers: [provideNodeType('args')] }]
|
|
32
|
-
}],
|
|
33
|
-
|
|
34
|
-
}] } });
|
|
35
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXJncy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29yZS9zcmMvbGliL2RpcmVjdGl2ZXMvYXJncy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNqRCxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsZUFBZSxFQUFFLE1BQU0sVUFBVSxDQUFDOztBQUcvRCxNQUFNLE9BQU8sT0FBcUMsU0FBUSxrQkFBa0I7SUFENUU7O1FBRVMsaUJBQVksR0FBVSxFQUFzQixDQUFDO0tBb0JyRDtJQWxCQSxJQUFhLElBQUksQ0FBQyxJQUFrQjtRQUNuQyxJQUFJLElBQUksSUFBSSxJQUFJLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sS0FBSyxDQUFDLElBQUksSUFBSSxDQUFDLENBQUMsQ0FBQyxLQUFLLElBQUksQ0FBQztZQUFFLE9BQU87UUFDNUYsSUFBSSxDQUFDLFFBQVEsR0FBRyxLQUFLLENBQUM7UUFDdEIsSUFBSSxDQUFDLFlBQVksR0FBRyxJQUFJLENBQUM7UUFDekIsSUFBSSxDQUFDLFVBQVUsRUFBRSxDQUFDO0lBQ25CLENBQUM7SUFFRCxJQUFJLElBQUk7UUFDUCxJQUFJLElBQUksQ0FBQyxRQUFRLEVBQUUsRUFBRSxDQUFDO1lBQ3JCLElBQUksQ0FBQyxRQUFRLEdBQUcsSUFBSSxDQUFDO1lBQ3JCLE9BQU8sSUFBSSxDQUFDLFlBQVksQ0FBQztRQUMxQixDQUFDO1FBQ0QsT0FBTyxJQUFJLENBQUM7SUFDYixDQUFDO0lBRUQsUUFBUTtRQUNQLE9BQU8sQ0FBQyxJQUFJLENBQUMsUUFBUSxJQUFJLENBQUMsQ0FBQyxJQUFJLENBQUMsWUFBWSxDQUFDLE1BQU0sQ0FBQztJQUNyRCxDQUFDOzhHQXBCVyxPQUFPO2tHQUFQLE9BQU8sMEZBRHFELENBQUMsZUFBZSxDQUFDLE1BQU0sQ0FBQyxDQUFDOzsyRkFDckYsT0FBTztrQkFEbkIsU0FBUzttQkFBQyxFQUFFLFFBQVEsRUFBRSxtQkFBbUIsRUFBRSxVQUFVLEVBQUUsSUFBSSxFQUFFLFNBQVMsRUFBRSxDQUFDLGVBQWUsQ0FBQyxNQUFNLENBQUMsQ0FBQyxFQUFFOzhCQUl0RixJQUFJO3NCQUFoQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTmd0Q29tbW9uRGlyZWN0aXZlLCBwcm92aWRlTm9kZVR5cGUgfSBmcm9tICcuL2NvbW1vbic7XG5cbkBEaXJlY3RpdmUoeyBzZWxlY3RvcjogJ25nLXRlbXBsYXRlW2FyZ3NdJywgc3RhbmRhbG9uZTogdHJ1ZSwgcHJvdmlkZXJzOiBbcHJvdmlkZU5vZGVUeXBlKCdhcmdzJyldIH0pXG5leHBvcnQgY2xhc3MgTmd0QXJnczxUQXJncyBleHRlbmRzIGFueVtdID0gYW55W10+IGV4dGVuZHMgTmd0Q29tbW9uRGlyZWN0aXZlIHtcblx0cHJpdmF0ZSBpbmplY3RlZEFyZ3M6IFRBcmdzID0gW10gYXMgdW5rbm93biBhcyBUQXJncztcblxuXHRASW5wdXQoKSBzZXQgYXJncyhhcmdzOiBUQXJncyB8IG51bGwpIHtcblx0XHRpZiAoYXJncyA9PSBudWxsIHx8ICFBcnJheS5pc0FycmF5KGFyZ3MpIHx8IChhcmdzLmxlbmd0aCA9PT0gMSAmJiBhcmdzWzBdID09PSBudWxsKSkgcmV0dXJuO1xuXHRcdHRoaXMuaW5qZWN0ZWQgPSBmYWxzZTtcblx0XHR0aGlzLmluamVjdGVkQXJncyA9IGFyZ3M7XG5cdFx0dGhpcy5jcmVhdGVWaWV3KCk7XG5cdH1cblxuXHRnZXQgYXJncygpIHtcblx0XHRpZiAodGhpcy52YWxpZGF0ZSgpKSB7XG5cdFx0XHR0aGlzLmluamVjdGVkID0gdHJ1ZTtcblx0XHRcdHJldHVybiB0aGlzLmluamVjdGVkQXJncztcblx0XHR9XG5cdFx0cmV0dXJuIG51bGw7XG5cdH1cblxuXHR2YWxpZGF0ZSgpIHtcblx0XHRyZXR1cm4gIXRoaXMuaW5qZWN0ZWQgJiYgISF0aGlzLmluamVjdGVkQXJncy5sZW5ndGg7XG5cdH1cbn1cbiJdfQ==
|
|
34
|
+
}], ctorParameters: () => [] });
|
|
35
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXJncy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29yZS9zcmMvbGliL2RpcmVjdGl2ZXMvYXJncy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLGVBQWUsRUFBRSxNQUFNLFVBQVUsQ0FBQzs7QUFHL0QsTUFBTSxPQUFPLE9BQXFDLFNBQVEsa0JBQWtCO0lBSzNFO1FBQ0MsS0FBSyxFQUFFLENBQUM7UUFMVCxTQUFJLEdBQUcsS0FBSyxDQUFlLElBQUksQ0FBQyxDQUFDO1FBRXpCLGlCQUFZLEdBQVUsRUFBc0IsQ0FBQztRQUlwRCxNQUFNLENBQUMsR0FBRyxFQUFFO1lBQ1gsTUFBTSxJQUFJLEdBQUcsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDO1lBQ3pCLElBQUksSUFBSSxJQUFJLElBQUksSUFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsTUFBTSxLQUFLLENBQUMsSUFBSSxJQUFJLENBQUMsQ0FBQyxDQUFDLEtBQUssSUFBSSxDQUFDO2dCQUFFLE9BQU87WUFDNUYsSUFBSSxDQUFDLFFBQVEsR0FBRyxLQUFLLENBQUM7WUFDdEIsSUFBSSxDQUFDLFlBQVksR0FBRyxJQUFJLENBQUM7WUFDekIsSUFBSSxDQUFDLFVBQVUsRUFBRSxDQUFDO1FBQ25CLENBQUMsQ0FBQyxDQUFDO0lBQ0osQ0FBQztJQUVELElBQUksS0FBSztRQUNSLElBQUksSUFBSSxDQUFDLFFBQVEsRUFBRSxFQUFFLENBQUM7WUFDckIsSUFBSSxDQUFDLFFBQVEsR0FBRyxJQUFJLENBQUM7WUFDckIsT0FBTyxJQUFJLENBQUMsWUFBWSxDQUFDO1FBQzFCLENBQUM7UUFDRCxPQUFPLElBQUksQ0FBQztJQUNiLENBQUM7SUFFRCxRQUFRO1FBQ1AsT0FBTyxDQUFDLElBQUksQ0FBQyxRQUFRLElBQUksQ0FBQyxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsTUFBTSxDQUFDO0lBQ3JELENBQUM7OEdBMUJXLE9BQU87a0dBQVAsT0FBTyxpTUFEcUQsQ0FBQyxlQUFlLENBQUMsTUFBTSxDQUFDLENBQUM7OzJGQUNyRixPQUFPO2tCQURuQixTQUFTO21CQUFDLEVBQUUsUUFBUSxFQUFFLG1CQUFtQixFQUFFLFVBQVUsRUFBRSxJQUFJLEVBQUUsU0FBUyxFQUFFLENBQUMsZUFBZSxDQUFDLE1BQU0sQ0FBQyxDQUFDLEVBQUUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIGVmZmVjdCwgaW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE5ndENvbW1vbkRpcmVjdGl2ZSwgcHJvdmlkZU5vZGVUeXBlIH0gZnJvbSAnLi9jb21tb24nO1xuXG5ARGlyZWN0aXZlKHsgc2VsZWN0b3I6ICduZy10ZW1wbGF0ZVthcmdzXScsIHN0YW5kYWxvbmU6IHRydWUsIHByb3ZpZGVyczogW3Byb3ZpZGVOb2RlVHlwZSgnYXJncycpXSB9KVxuZXhwb3J0IGNsYXNzIE5ndEFyZ3M8VEFyZ3MgZXh0ZW5kcyBhbnlbXSA9IGFueVtdPiBleHRlbmRzIE5ndENvbW1vbkRpcmVjdGl2ZSB7XG5cdGFyZ3MgPSBpbnB1dDxUQXJncyB8IG51bGw+KG51bGwpO1xuXG5cdHByaXZhdGUgaW5qZWN0ZWRBcmdzOiBUQXJncyA9IFtdIGFzIHVua25vd24gYXMgVEFyZ3M7XG5cblx0Y29uc3RydWN0b3IoKSB7XG5cdFx0c3VwZXIoKTtcblx0XHRlZmZlY3QoKCkgPT4ge1xuXHRcdFx0Y29uc3QgYXJncyA9IHRoaXMuYXJncygpO1xuXHRcdFx0aWYgKGFyZ3MgPT0gbnVsbCB8fCAhQXJyYXkuaXNBcnJheShhcmdzKSB8fCAoYXJncy5sZW5ndGggPT09IDEgJiYgYXJnc1swXSA9PT0gbnVsbCkpIHJldHVybjtcblx0XHRcdHRoaXMuaW5qZWN0ZWQgPSBmYWxzZTtcblx0XHRcdHRoaXMuaW5qZWN0ZWRBcmdzID0gYXJncztcblx0XHRcdHRoaXMuY3JlYXRlVmlldygpO1xuXHRcdH0pO1xuXHR9XG5cblx0Z2V0IHZhbHVlKCkge1xuXHRcdGlmICh0aGlzLnZhbGlkYXRlKCkpIHtcblx0XHRcdHRoaXMuaW5qZWN0ZWQgPSB0cnVlO1xuXHRcdFx0cmV0dXJuIHRoaXMuaW5qZWN0ZWRBcmdzO1xuXHRcdH1cblx0XHRyZXR1cm4gbnVsbDtcblx0fVxuXG5cdHZhbGlkYXRlKCkge1xuXHRcdHJldHVybiAhdGhpcy5pbmplY3RlZCAmJiAhIXRoaXMuaW5qZWN0ZWRBcmdzLmxlbmd0aDtcblx0fVxufVxuIl19
|
|
@@ -33,10 +33,10 @@ export class NgtCommonDirective {
|
|
|
33
33
|
}
|
|
34
34
|
});
|
|
35
35
|
}
|
|
36
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.
|
|
37
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.
|
|
36
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.9", ngImport: i0, type: NgtCommonDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
37
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.9", type: NgtCommonDirective, ngImport: i0 }); }
|
|
38
38
|
}
|
|
39
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.
|
|
39
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.9", ngImport: i0, type: NgtCommonDirective, decorators: [{
|
|
40
40
|
type: Directive
|
|
41
41
|
}], ctorParameters: () => [] });
|
|
42
42
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tbW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb3JlL3NyYy9saWIvZGlyZWN0aXZlcy9jb21tb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNOLFVBQVUsRUFDVixTQUFTLEVBQ1QsTUFBTSxFQUNOLFdBQVcsRUFDWCxnQkFBZ0IsRUFDaEIsTUFBTSxHQUVOLE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLG1DQUFtQyxDQUFDO0FBQ3pFLE9BQU8sRUFBRSw0QkFBNEIsRUFBRSxNQUFNLHVCQUF1QixDQUFDOztBQUVyRSxNQUFNLENBQUMsTUFBTSxDQUFDLGNBQWMsRUFBRSxlQUFlLENBQUMsR0FBRyxvQkFBb0IsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxFQUE0QixFQUFFO0lBQ3pHLE1BQU0sRUFBRSxLQUFLO0NBQ2IsQ0FBQyxDQUFDO0FBR0gsTUFBTSxPQUFnQixrQkFBa0I7SUFVdkM7UUFUUSxRQUFHLEdBQUcsTUFBTSxDQUFDLGdCQUFnQixDQUFDLENBQUM7UUFDL0IsU0FBSSxHQUFHLE1BQU0sQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUN0QixhQUFRLEdBQUcsTUFBTSxDQUFDLFdBQVcsQ0FBQyxDQUFDO1FBQy9CLGFBQVEsR0FBRyxjQUFjLEVBQUUsQ0FBQztRQUUxQixhQUFRLEdBQUcsS0FBSyxDQUFDO1FBQ2pCLHFCQUFnQixHQUFHLElBQUksQ0FBQztRQUlqQyxNQUFNLFdBQVcsR0FBRyxJQUFJLENBQUMsR0FBRyxDQUFDLE9BQU8sQ0FBQyxhQUFhLENBQUM7UUFDbkQsSUFBSSxXQUFXLENBQUMsNEJBQTRCLENBQUMsRUFBRSxDQUFDO1lBQy9DLFdBQVcsQ0FBQyw0QkFBNEIsQ0FBQyxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQztZQUN6RCxPQUFPLFdBQVcsQ0FBQyw0QkFBNEIsQ0FBQyxDQUFDO1FBQ2xELENBQUM7UUFFRCxNQUFNLENBQUMsVUFBVSxDQUFDLENBQUMsU0FBUyxDQUFDLEdBQUcsRUFBRTtZQUNqQyxJQUFJLENBQUMsSUFBSSxFQUFFLE9BQU8sRUFBRSxDQUFDO1FBQ3RCLENBQUMsQ0FBQyxDQUFDO0lBQ0osQ0FBQztJQUlTLFVBQVU7UUFDbkIsSUFBSSxDQUFDLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxHQUFHLEVBQUU7WUFDaEMsSUFBSSxJQUFJLENBQUMsZ0JBQWdCLEVBQUUsQ0FBQztnQkFDM0IsSUFBSSxJQUFJLENBQUMsSUFBSSxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxTQUFTLEVBQUUsQ0FBQztvQkFDdkMsSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQztnQkFDckIsQ0FBQztnQkFDRCxJQUFJLENBQUMsSUFBSSxHQUFHLElBQUksQ0FBQyxHQUFHLENBQUMsa0JBQWtCLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDO2dCQUN2RCxJQUFJLENBQUMsSUFBSSxDQUFDLGFBQWEsRUFBRSxDQUFDO1lBQzNCLENBQUM7UUFDRixDQUFDLENBQUMsQ0FBQztJQUNKLENBQUM7OEdBbENvQixrQkFBa0I7a0dBQWxCLGtCQUFrQjs7MkZBQWxCLGtCQUFrQjtrQkFEdkMsU0FBUyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG5cdERlc3Ryb3lSZWYsXG5cdERpcmVjdGl2ZSxcblx0Tmdab25lLFxuXHRUZW1wbGF0ZVJlZixcblx0Vmlld0NvbnRhaW5lclJlZixcblx0aW5qZWN0LFxuXHR0eXBlIEVtYmVkZGVkVmlld1JlZixcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBjcmVhdGVJbmplY3Rpb25Ub2tlbiB9IGZyb20gJ25neHRlbnNpb24vY3JlYXRlLWluamVjdGlvbi10b2tlbic7XG5pbXBvcnQgeyBTUEVDSUFMX0lOVEVSTkFMX0FERF9DT01NRU5UIH0gZnJvbSAnLi4vcmVuZGVyZXIvY29uc3RhbnRzJztcblxuZXhwb3J0IGNvbnN0IFtpbmplY3ROb2RlVHlwZSwgcHJvdmlkZU5vZGVUeXBlXSA9IGNyZWF0ZUluamVjdGlvblRva2VuKCgpID0+ICcnIGFzICdhcmdzJyB8ICdwYXJlbnQnIHwgJycsIHtcblx0aXNSb290OiBmYWxzZSxcbn0pO1xuXG5ARGlyZWN0aXZlKClcbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBOZ3RDb21tb25EaXJlY3RpdmUge1xuXHRwcml2YXRlIHZjciA9IGluamVjdChWaWV3Q29udGFpbmVyUmVmKTtcblx0cHJpdmF0ZSB6b25lID0gaW5qZWN0KE5nWm9uZSk7XG5cdHByaXZhdGUgdGVtcGxhdGUgPSBpbmplY3QoVGVtcGxhdGVSZWYpO1xuXHRwcml2YXRlIG5vZGVUeXBlID0gaW5qZWN0Tm9kZVR5cGUoKTtcblxuXHRwcm90ZWN0ZWQgaW5qZWN0ZWQgPSBmYWxzZTtcblx0cHJvdGVjdGVkIHNob3VsZENyZWF0ZVZpZXcgPSB0cnVlO1xuXHRwcml2YXRlIHZpZXc/OiBFbWJlZGRlZFZpZXdSZWY8dW5rbm93bj47XG5cblx0Y29uc3RydWN0b3IoKSB7XG5cdFx0Y29uc3QgY29tbWVudE5vZGUgPSB0aGlzLnZjci5lbGVtZW50Lm5hdGl2ZUVsZW1lbnQ7XG5cdFx0aWYgKGNvbW1lbnROb2RlW1NQRUNJQUxfSU5URVJOQUxfQUREX0NPTU1FTlRdKSB7XG5cdFx0XHRjb21tZW50Tm9kZVtTUEVDSUFMX0lOVEVSTkFMX0FERF9DT01NRU5UXSh0aGlzLm5vZGVUeXBlKTtcblx0XHRcdGRlbGV0ZSBjb21tZW50Tm9kZVtTUEVDSUFMX0lOVEVSTkFMX0FERF9DT01NRU5UXTtcblx0XHR9XG5cblx0XHRpbmplY3QoRGVzdHJveVJlZikub25EZXN0cm95KCgpID0+IHtcblx0XHRcdHRoaXMudmlldz8uZGVzdHJveSgpO1xuXHRcdH0pO1xuXHR9XG5cblx0YWJzdHJhY3QgdmFsaWRhdGUoKTogYm9vbGVhbjtcblxuXHRwcm90ZWN0ZWQgY3JlYXRlVmlldygpIHtcblx0XHR0aGlzLnpvbmUucnVuT3V0c2lkZUFuZ3VsYXIoKCkgPT4ge1xuXHRcdFx0aWYgKHRoaXMuc2hvdWxkQ3JlYXRlVmlldykge1xuXHRcdFx0XHRpZiAodGhpcy52aWV3ICYmICF0aGlzLnZpZXcuZGVzdHJveWVkKSB7XG5cdFx0XHRcdFx0dGhpcy52aWV3LmRlc3Ryb3koKTtcblx0XHRcdFx0fVxuXHRcdFx0XHR0aGlzLnZpZXcgPSB0aGlzLnZjci5jcmVhdGVFbWJlZGRlZFZpZXcodGhpcy50ZW1wbGF0ZSk7XG5cdFx0XHRcdHRoaXMudmlldy5kZXRlY3RDaGFuZ2VzKCk7XG5cdFx0XHR9XG5cdFx0fSk7XG5cdH1cbn1cbiJdfQ==
|
|
@@ -1,19 +1,21 @@
|
|
|
1
|
-
import { Directive,
|
|
1
|
+
import { Directive, effect, input } from '@angular/core';
|
|
2
2
|
import { NgtCommonDirective, provideNodeType } from './common';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
export class NgtParent extends NgtCommonDirective {
|
|
5
5
|
constructor() {
|
|
6
|
-
super(
|
|
6
|
+
super();
|
|
7
|
+
this.parent = input.required();
|
|
7
8
|
this.injectedParent = null;
|
|
9
|
+
effect(() => {
|
|
10
|
+
const parent = this.parent();
|
|
11
|
+
if (!parent)
|
|
12
|
+
return;
|
|
13
|
+
this.injected = false;
|
|
14
|
+
this.injectedParent = parent;
|
|
15
|
+
this.createView();
|
|
16
|
+
});
|
|
8
17
|
}
|
|
9
|
-
|
|
10
|
-
if (!parent)
|
|
11
|
-
return;
|
|
12
|
-
this.injected = false;
|
|
13
|
-
this.injectedParent = parent;
|
|
14
|
-
this.createView();
|
|
15
|
-
}
|
|
16
|
-
get parent() {
|
|
18
|
+
get value() {
|
|
17
19
|
if (this.validate()) {
|
|
18
20
|
this.injected = true;
|
|
19
21
|
return this.injectedParent;
|
|
@@ -23,13 +25,11 @@ export class NgtParent extends NgtCommonDirective {
|
|
|
23
25
|
validate() {
|
|
24
26
|
return !this.injected && !!this.injectedParent;
|
|
25
27
|
}
|
|
26
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.
|
|
27
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "
|
|
28
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.9", ngImport: i0, type: NgtParent, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
29
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "17.3.9", type: NgtParent, isStandalone: true, selector: "ng-template[parent]", inputs: { parent: { classPropertyName: "parent", publicName: "parent", isSignal: true, isRequired: true, transformFunction: null } }, providers: [provideNodeType('parent')], usesInheritance: true, ngImport: i0 }); }
|
|
28
30
|
}
|
|
29
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.
|
|
31
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.9", ngImport: i0, type: NgtParent, decorators: [{
|
|
30
32
|
type: Directive,
|
|
31
33
|
args: [{ selector: 'ng-template[parent]', standalone: true, providers: [provideNodeType('parent')] }]
|
|
32
|
-
}],
|
|
33
|
-
|
|
34
|
-
}] } });
|
|
35
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFyZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb3JlL3NyYy9saWIvZGlyZWN0aXZlcy9wYXJlbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFakQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLGVBQWUsRUFBRSxNQUFNLFVBQVUsQ0FBQzs7QUFHL0QsTUFBTSxPQUFPLFNBQVUsU0FBUSxrQkFBa0I7SUFEakQ7O1FBRVMsbUJBQWMsR0FBb0MsSUFBSyxDQUFDO0tBb0JoRTtJQWxCQSxJQUFhLE1BQU0sQ0FBQyxNQUF1QztRQUMxRCxJQUFJLENBQUMsTUFBTTtZQUFFLE9BQU87UUFDcEIsSUFBSSxDQUFDLFFBQVEsR0FBRyxLQUFLLENBQUM7UUFDdEIsSUFBSSxDQUFDLGNBQWMsR0FBRyxNQUFNLENBQUM7UUFDN0IsSUFBSSxDQUFDLFVBQVUsRUFBRSxDQUFDO0lBQ25CLENBQUM7SUFFRCxJQUFJLE1BQU07UUFDVCxJQUFJLElBQUksQ0FBQyxRQUFRLEVBQUUsRUFBRSxDQUFDO1lBQ3JCLElBQUksQ0FBQyxRQUFRLEdBQUcsSUFBSSxDQUFDO1lBQ3JCLE9BQU8sSUFBSSxDQUFDLGNBQWMsQ0FBQztRQUM1QixDQUFDO1FBQ0QsT0FBTyxJQUFLLENBQUM7SUFDZCxDQUFDO0lBRUQsUUFBUTtRQUNQLE9BQU8sQ0FBQyxJQUFJLENBQUMsUUFBUSxJQUFJLENBQUMsQ0FBQyxJQUFJLENBQUMsY0FBYyxDQUFDO0lBQ2hELENBQUM7OEdBcEJXLFNBQVM7a0dBQVQsU0FBUyxnR0FEcUQsQ0FBQyxlQUFlLENBQUMsUUFBUSxDQUFDLENBQUM7OzJGQUN6RixTQUFTO2tCQURyQixTQUFTO21CQUFDLEVBQUUsUUFBUSxFQUFFLHFCQUFxQixFQUFFLFVBQVUsRUFBRSxJQUFJLEVBQUUsU0FBUyxFQUFFLENBQUMsZUFBZSxDQUFDLFFBQVEsQ0FBQyxDQUFDLEVBQUU7OEJBSTFGLE1BQU07c0JBQWxCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgdHlwZSB7IE5ndFJlZiB9IGZyb20gJy4uL3JlZic7XG5pbXBvcnQgeyBOZ3RDb21tb25EaXJlY3RpdmUsIHByb3ZpZGVOb2RlVHlwZSB9IGZyb20gJy4vY29tbW9uJztcblxuQERpcmVjdGl2ZSh7IHNlbGVjdG9yOiAnbmctdGVtcGxhdGVbcGFyZW50XScsIHN0YW5kYWxvbmU6IHRydWUsIHByb3ZpZGVyczogW3Byb3ZpZGVOb2RlVHlwZSgncGFyZW50JyldIH0pXG5leHBvcnQgY2xhc3MgTmd0UGFyZW50IGV4dGVuZHMgTmd0Q29tbW9uRGlyZWN0aXZlIHtcblx0cHJpdmF0ZSBpbmplY3RlZFBhcmVudDogc3RyaW5nIHwgTmd0UmVmPFRIUkVFLk9iamVjdDNEPiA9IG51bGwhO1xuXG5cdEBJbnB1dCgpIHNldCBwYXJlbnQocGFyZW50OiBzdHJpbmcgfCBOZ3RSZWY8VEhSRUUuT2JqZWN0M0Q+KSB7XG5cdFx0aWYgKCFwYXJlbnQpIHJldHVybjtcblx0XHR0aGlzLmluamVjdGVkID0gZmFsc2U7XG5cdFx0dGhpcy5pbmplY3RlZFBhcmVudCA9IHBhcmVudDtcblx0XHR0aGlzLmNyZWF0ZVZpZXcoKTtcblx0fVxuXG5cdGdldCBwYXJlbnQoKSB7XG5cdFx0aWYgKHRoaXMudmFsaWRhdGUoKSkge1xuXHRcdFx0dGhpcy5pbmplY3RlZCA9IHRydWU7XG5cdFx0XHRyZXR1cm4gdGhpcy5pbmplY3RlZFBhcmVudDtcblx0XHR9XG5cdFx0cmV0dXJuIG51bGwhO1xuXHR9XG5cblx0dmFsaWRhdGUoKTogYm9vbGVhbiB7XG5cdFx0cmV0dXJuICF0aGlzLmluamVjdGVkICYmICEhdGhpcy5pbmplY3RlZFBhcmVudDtcblx0fVxufVxuIl19
|
|
34
|
+
}], ctorParameters: () => [] });
|
|
35
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFyZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb3JlL3NyYy9saWIvZGlyZWN0aXZlcy9wYXJlbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBR3pELE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxlQUFlLEVBQUUsTUFBTSxVQUFVLENBQUM7O0FBRy9ELE1BQU0sT0FBTyxTQUFVLFNBQVEsa0JBQWtCO0lBSWhEO1FBQ0MsS0FBSyxFQUFFLENBQUM7UUFKVCxXQUFNLEdBQUcsS0FBSyxDQUFDLFFBQVEsRUFBbUMsQ0FBQztRQUNuRCxtQkFBYyxHQUFvQyxJQUFLLENBQUM7UUFJL0QsTUFBTSxDQUFDLEdBQUcsRUFBRTtZQUNYLE1BQU0sTUFBTSxHQUFHLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQztZQUM3QixJQUFJLENBQUMsTUFBTTtnQkFBRSxPQUFPO1lBQ3BCLElBQUksQ0FBQyxRQUFRLEdBQUcsS0FBSyxDQUFDO1lBQ3RCLElBQUksQ0FBQyxjQUFjLEdBQUcsTUFBTSxDQUFDO1lBQzdCLElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQztRQUNuQixDQUFDLENBQUMsQ0FBQztJQUNKLENBQUM7SUFFRCxJQUFJLEtBQUs7UUFDUixJQUFJLElBQUksQ0FBQyxRQUFRLEVBQUUsRUFBRSxDQUFDO1lBQ3JCLElBQUksQ0FBQyxRQUFRLEdBQUcsSUFBSSxDQUFDO1lBQ3JCLE9BQU8sSUFBSSxDQUFDLGNBQWMsQ0FBQztRQUM1QixDQUFDO1FBQ0QsT0FBTyxJQUFJLENBQUM7SUFDYixDQUFDO0lBRUQsUUFBUTtRQUNQLE9BQU8sQ0FBQyxJQUFJLENBQUMsUUFBUSxJQUFJLENBQUMsQ0FBQyxJQUFJLENBQUMsY0FBYyxDQUFDO0lBQ2hELENBQUM7OEdBekJXLFNBQVM7a0dBQVQsU0FBUyx3TUFEcUQsQ0FBQyxlQUFlLENBQUMsUUFBUSxDQUFDLENBQUM7OzJGQUN6RixTQUFTO2tCQURyQixTQUFTO21CQUFDLEVBQUUsUUFBUSxFQUFFLHFCQUFxQixFQUFFLFVBQVUsRUFBRSxJQUFJLEVBQUUsU0FBUyxFQUFFLENBQUMsZUFBZSxDQUFDLFFBQVEsQ0FBQyxDQUFDLEVBQUUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIGVmZmVjdCwgaW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB0eXBlICogYXMgVEhSRUUgZnJvbSAndGhyZWUnO1xuaW1wb3J0IHR5cGUgeyBOZ3RSZWYgfSBmcm9tICcuLi9yZWYnO1xuaW1wb3J0IHsgTmd0Q29tbW9uRGlyZWN0aXZlLCBwcm92aWRlTm9kZVR5cGUgfSBmcm9tICcuL2NvbW1vbic7XG5cbkBEaXJlY3RpdmUoeyBzZWxlY3RvcjogJ25nLXRlbXBsYXRlW3BhcmVudF0nLCBzdGFuZGFsb25lOiB0cnVlLCBwcm92aWRlcnM6IFtwcm92aWRlTm9kZVR5cGUoJ3BhcmVudCcpXSB9KVxuZXhwb3J0IGNsYXNzIE5ndFBhcmVudCBleHRlbmRzIE5ndENvbW1vbkRpcmVjdGl2ZSB7XG5cdHBhcmVudCA9IGlucHV0LnJlcXVpcmVkPHN0cmluZyB8IE5ndFJlZjxUSFJFRS5PYmplY3QzRD4+KCk7XG5cdHByaXZhdGUgaW5qZWN0ZWRQYXJlbnQ6IHN0cmluZyB8IE5ndFJlZjxUSFJFRS5PYmplY3QzRD4gPSBudWxsITtcblxuXHRjb25zdHJ1Y3RvcigpIHtcblx0XHRzdXBlcigpO1xuXHRcdGVmZmVjdCgoKSA9PiB7XG5cdFx0XHRjb25zdCBwYXJlbnQgPSB0aGlzLnBhcmVudCgpO1xuXHRcdFx0aWYgKCFwYXJlbnQpIHJldHVybjtcblx0XHRcdHRoaXMuaW5qZWN0ZWQgPSBmYWxzZTtcblx0XHRcdHRoaXMuaW5qZWN0ZWRQYXJlbnQgPSBwYXJlbnQ7XG5cdFx0XHR0aGlzLmNyZWF0ZVZpZXcoKTtcblx0XHR9KTtcblx0fVxuXG5cdGdldCB2YWx1ZSgpIHtcblx0XHRpZiAodGhpcy52YWxpZGF0ZSgpKSB7XG5cdFx0XHR0aGlzLmluamVjdGVkID0gdHJ1ZTtcblx0XHRcdHJldHVybiB0aGlzLmluamVjdGVkUGFyZW50O1xuXHRcdH1cblx0XHRyZXR1cm4gbnVsbDtcblx0fVxuXG5cdHZhbGlkYXRlKCk6IGJvb2xlYW4ge1xuXHRcdHJldHVybiAhdGhpcy5pbmplY3RlZCAmJiAhIXRoaXMuaW5qZWN0ZWRQYXJlbnQ7XG5cdH1cbn1cbiJdfQ==
|
package/esm2022/lib/instance.mjs
CHANGED
|
@@ -67,4 +67,4 @@ function notifyAncestors(instance) {
|
|
|
67
67
|
localState.instanceStore.update((prev) => ({ objects: prev.objects, nonObjects: prev.nonObjects }));
|
|
68
68
|
notifyAncestors(localState.instanceStore.get('parent'));
|
|
69
69
|
}
|
|
70
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"instance.js","sourceRoot":"","sources":["../../../../../libs/core/src/lib/instance.ts"],"names":[],"mappings":"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","sourcesContent":["import type { EventEmitter, Signal } from '@angular/core';\nimport type { NgtEventHandlers } from './events';\nimport type { NgtState } from './store';\nimport type { NgtAnyRecord } from './types';\nimport { signalStore, type NgtSignalStore } from './utils/signal-store';\nimport { checkUpdate } from './utils/update';\n\nexport type NgtAttachFunction<TChild = any, TParent = any> = (\n\tparent: TParent,\n\tchild: TChild,\n\tstore: NgtSignalStore<NgtState>,\n) => void | (() => void);\n\nexport type NgtAfterAttach<\n\tTChild extends NgtInstanceNode = NgtInstanceNode,\n\tTParent extends NgtInstanceNode = NgtInstanceNode,\n> = { parent: TParent; node: TChild };\n\nexport type NgtLocalInstanceState = {\n\tobjects: NgtInstanceNode[];\n\tnonObjects: NgtInstanceNode[];\n\tparent: NgtInstanceNode | null;\n\tnativeProps: NgtAnyRecord;\n};\n\nexport type NgtLocalState = {\n\t/** the store of the canvas that the instance is being rendered to */\n\tstore: NgtSignalStore<NgtState>;\n\t// objects related to this instance\n\tinstanceStore: NgtSignalStore<NgtLocalInstanceState>;\n\t// shortcut to signals\n\tparent: Signal<NgtLocalInstanceState['parent']>;\n\tobjects: Signal<NgtLocalInstanceState['objects']>;\n\tnonObjects: Signal<NgtLocalInstanceState['nonObjects']>;\n\tnativeProps: Signal<NgtLocalInstanceState['nativeProps']>;\n\t// shortcut to add/remove object to list\n\tadd: (instance: NgtInstanceNode, type: 'objects' | 'nonObjects') => void;\n\tremove: (instance: NgtInstanceNode, type: 'objects' | 'nonObjects') => void;\n\tsetNativeProps: (key: string, value: any) => void;\n\tsetParent: (parent: NgtInstanceNode | null) => void;\n\t// if this THREE instance is a ngt-primitive\n\tprimitive?: boolean;\n\t// if this THREE object has any events bound to it\n\teventCount: number;\n\t// list of handlers to handle the events\n\thandlers: Partial<NgtEventHandlers>;\n\t// previous args\n\targs?: unknown[];\n\t// attach information so that we can detach as well as reset\n\tattach?: string[] | NgtAttachFunction;\n\t// previously attach information so we can reset as well as clean up\n\tpreviousAttach?: unknown | (() => void);\n\t// is raw value\n\tisRaw?: boolean;\n\t// priority for before render\n\tpriority?: number;\n\t// emitter after props update\n\tafterUpdate?: EventEmitter<NgtInstanceNode>;\n\t// emitter after attaching to parent\n\tafterAttach?: EventEmitter<NgtAfterAttach>;\n};\n\nexport type NgtInstanceNode<TNode = any> = { __ngt__: NgtLocalState } & NgtAnyRecord & TNode;\n\nexport function getLocalState<TInstance extends object>(obj: TInstance | undefined): NgtLocalState | undefined {\n\tif (!obj) return undefined;\n\treturn (obj as NgtAnyRecord)['__ngt__'];\n}\n\nexport function invalidateInstance<TInstance extends object>(instance: TInstance) {\n\tconst state = getLocalState(instance)?.store.snapshot;\n\tif (state && state.internal.frames === 0) state.invalidate();\n\tcheckUpdate(instance);\n}\n\nexport function prepare<TInstance extends object = NgtAnyRecord>(\n\tobject: TInstance,\n\tlocalState?: Partial<NgtLocalState>,\n) {\n\tconst instance = object as unknown as NgtInstanceNode<TInstance>;\n\n\tif (localState?.primitive || !instance.__ngt__) {\n\t\tconst {\n\t\t\tinstanceStore = signalStore<NgtLocalInstanceState>({\n\t\t\t\tnativeProps: {},\n\t\t\t\tparent: null,\n\t\t\t\tobjects: [],\n\t\t\t\tnonObjects: [],\n\t\t\t}),\n\t\t\t...rest\n\t\t} = localState || {};\n\n\t\tinstance.__ngt__ = {\n\t\t\tpreviousAttach: null,\n\t\t\tstore: null,\n\t\t\tmemoized: {},\n\t\t\teventCount: 0,\n\t\t\thandlers: {},\n\t\t\tinstanceStore,\n\t\t\tparent: instanceStore.select('parent'),\n\t\t\tobjects: instanceStore.select('objects'),\n\t\t\tnonObjects: instanceStore.select('nonObjects'),\n\t\t\tnativeProps: instanceStore.select('nativeProps'),\n\t\t\tadd(object, type) {\n\t\t\t\tconst current = instance.__ngt__.instanceStore.get(type);\n\t\t\t\tconst foundIndex = current.indexOf((node: NgtInstanceNode) => object === node);\n\t\t\t\tif (foundIndex > -1) {\n\t\t\t\t\tcurrent.splice(foundIndex, 1, object);\n\t\t\t\t\tinstance.__ngt__.instanceStore.update({ [type]: current });\n\t\t\t\t} else {\n\t\t\t\t\tinstance.__ngt__.instanceStore.update((prev) => ({ [type]: [...prev[type], object] }));\n\t\t\t\t}\n\t\t\t\tnotifyAncestors(instance.__ngt__.instanceStore.get('parent'));\n\t\t\t},\n\t\t\tremove(object, type) {\n\t\t\t\tinstance.__ngt__.instanceStore.update((prev) => ({ [type]: prev[type].filter((node) => node !== object) }));\n\t\t\t\tnotifyAncestors(instance.__ngt__.instanceStore.get('parent'));\n\t\t\t},\n\t\t\tsetNativeProps(key, value) {\n\t\t\t\tinstance.__ngt__.instanceStore.update((prev) => ({ nativeProps: { ...prev.nativeProps, [key]: value } }));\n\t\t\t},\n\t\t\tsetParent(parent) {\n\t\t\t\tinstance.__ngt__.instanceStore.update({ parent });\n\t\t\t},\n\t\t\t...rest,\n\t\t} as NgtLocalState;\n\t}\n\n\treturn instance;\n}\n\nfunction notifyAncestors(instance: NgtInstanceNode | null) {\n\tif (!instance) return;\n\tconst localState = getLocalState(instance);\n\tif (!localState) return;\n\tlocalState.instanceStore.update((prev) => ({ objects: prev.objects, nonObjects: prev.nonObjects }));\n\tnotifyAncestors(localState.instanceStore.get('parent'));\n}\n"]}
|
|
70
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"instance.js","sourceRoot":"","sources":["../../../../../libs/core/src/lib/instance.ts"],"names":[],"mappings":"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","sourcesContent":["import type { Signal } from '@angular/core';\nimport type { ReplaySubject } from 'rxjs';\nimport type { NgtEventHandlers } from './events';\nimport type { NgtState } from './store';\nimport type { NgtAnyRecord } from './types';\nimport { signalStore, type NgtSignalStore } from './utils/signal-store';\nimport { checkUpdate } from './utils/update';\n\nexport type NgtAttachFunction<TChild = any, TParent = any> = (\n\tparent: TParent,\n\tchild: TChild,\n\tstore: NgtSignalStore<NgtState>,\n) => void | (() => void);\n\nexport type NgtAfterAttach<\n\tTChild extends NgtInstanceNode = NgtInstanceNode,\n\tTParent extends NgtInstanceNode = NgtInstanceNode,\n> = { parent: TParent; node: TChild };\n\nexport type NgtLocalInstanceState = {\n\tobjects: NgtInstanceNode[];\n\tnonObjects: NgtInstanceNode[];\n\tparent: NgtInstanceNode | null;\n\tnativeProps: NgtAnyRecord;\n};\n\nexport type NgtLocalState = {\n\t/** the store of the canvas that the instance is being rendered to */\n\tstore: NgtSignalStore<NgtState>;\n\t// objects related to this instance\n\tinstanceStore: NgtSignalStore<NgtLocalInstanceState>;\n\t// shortcut to signals\n\tparent: Signal<NgtLocalInstanceState['parent']>;\n\tobjects: Signal<NgtLocalInstanceState['objects']>;\n\tnonObjects: Signal<NgtLocalInstanceState['nonObjects']>;\n\tnativeProps: Signal<NgtLocalInstanceState['nativeProps']>;\n\t// shortcut to add/remove object to list\n\tadd: (instance: NgtInstanceNode, type: 'objects' | 'nonObjects') => void;\n\tremove: (instance: NgtInstanceNode, type: 'objects' | 'nonObjects') => void;\n\tsetNativeProps: (key: string, value: any) => void;\n\tsetParent: (parent: NgtInstanceNode | null) => void;\n\t// if this THREE instance is a ngt-primitive\n\tprimitive?: boolean;\n\t// if this THREE object has any events bound to it\n\teventCount: number;\n\t// list of handlers to handle the events\n\thandlers: Partial<NgtEventHandlers>;\n\t// previous args\n\targs?: unknown[];\n\t// attach information so that we can detach as well as reset\n\tattach?: string[] | NgtAttachFunction;\n\t// previously attach information so we can reset as well as clean up\n\tpreviousAttach?: unknown | (() => void);\n\t// is raw value\n\tisRaw?: boolean;\n\t// priority for before render\n\tpriority?: number;\n\t// emitter after props update\n\tafterUpdate?: ReplaySubject<NgtInstanceNode>;\n\t// emitter after attaching to parent\n\tafterAttach?: ReplaySubject<NgtAfterAttach>;\n};\n\nexport type NgtInstanceNode<TNode = any> = { __ngt__: NgtLocalState } & NgtAnyRecord & TNode;\n\nexport function getLocalState<TInstance extends object>(obj: TInstance | undefined): NgtLocalState | undefined {\n\tif (!obj) return undefined;\n\treturn (obj as NgtAnyRecord)['__ngt__'];\n}\n\nexport function invalidateInstance<TInstance extends object>(instance: TInstance) {\n\tconst state = getLocalState(instance)?.store.snapshot;\n\tif (state && state.internal.frames === 0) state.invalidate();\n\tcheckUpdate(instance);\n}\n\nexport function prepare<TInstance extends object = NgtAnyRecord>(\n\tobject: TInstance,\n\tlocalState?: Partial<NgtLocalState>,\n) {\n\tconst instance = object as unknown as NgtInstanceNode<TInstance>;\n\n\tif (localState?.primitive || !instance.__ngt__) {\n\t\tconst {\n\t\t\tinstanceStore = signalStore<NgtLocalInstanceState>({\n\t\t\t\tnativeProps: {},\n\t\t\t\tparent: null,\n\t\t\t\tobjects: [],\n\t\t\t\tnonObjects: [],\n\t\t\t}),\n\t\t\t...rest\n\t\t} = localState || {};\n\n\t\tinstance.__ngt__ = {\n\t\t\tpreviousAttach: null,\n\t\t\tstore: null,\n\t\t\tmemoized: {},\n\t\t\teventCount: 0,\n\t\t\thandlers: {},\n\t\t\tinstanceStore,\n\t\t\tparent: instanceStore.select('parent'),\n\t\t\tobjects: instanceStore.select('objects'),\n\t\t\tnonObjects: instanceStore.select('nonObjects'),\n\t\t\tnativeProps: instanceStore.select('nativeProps'),\n\t\t\tadd(object, type) {\n\t\t\t\tconst current = instance.__ngt__.instanceStore.get(type);\n\t\t\t\tconst foundIndex = current.indexOf((node: NgtInstanceNode) => object === node);\n\t\t\t\tif (foundIndex > -1) {\n\t\t\t\t\tcurrent.splice(foundIndex, 1, object);\n\t\t\t\t\tinstance.__ngt__.instanceStore.update({ [type]: current });\n\t\t\t\t} else {\n\t\t\t\t\tinstance.__ngt__.instanceStore.update((prev) => ({ [type]: [...prev[type], object] }));\n\t\t\t\t}\n\t\t\t\tnotifyAncestors(instance.__ngt__.instanceStore.get('parent'));\n\t\t\t},\n\t\t\tremove(object, type) {\n\t\t\t\tinstance.__ngt__.instanceStore.update((prev) => ({ [type]: prev[type].filter((node) => node !== object) }));\n\t\t\t\tnotifyAncestors(instance.__ngt__.instanceStore.get('parent'));\n\t\t\t},\n\t\t\tsetNativeProps(key, value) {\n\t\t\t\tinstance.__ngt__.instanceStore.update((prev) => ({ nativeProps: { ...prev.nativeProps, [key]: value } }));\n\t\t\t},\n\t\t\tsetParent(parent) {\n\t\t\t\tinstance.__ngt__.instanceStore.update({ parent });\n\t\t\t},\n\t\t\t...rest,\n\t\t} as NgtLocalState;\n\t}\n\n\treturn instance;\n}\n\nfunction notifyAncestors(instance: NgtInstanceNode | null) {\n\tif (!instance) return;\n\tconst localState = getLocalState(instance);\n\tif (!localState) return;\n\tlocalState.instanceStore.update((prev) => ({ objects: prev.objects, nonObjects: prev.nonObjects }));\n\tnotifyAncestors(localState.instanceStore.get('parent'));\n}\n"]}
|
package/esm2022/lib/loader.mjs
CHANGED
|
@@ -61,4 +61,4 @@ _injectNgtLoader.destroy = () => {
|
|
|
61
61
|
cached.clear();
|
|
62
62
|
};
|
|
63
63
|
export const injectNgtLoader = _injectNgtLoader;
|
|
64
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"loader.js","sourceRoot":"","sources":["../../../../../libs/core/src/lib/loader.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injector, effect, signal, type Signal } from '@angular/core';\nimport { assertInjector } from 'ngxtension/assert-injector';\nimport type { NgtAnyRecord } from './types';\nimport { makeObjectGraph, type NgtObjectMap } from './utils/make';\n\nexport type NgtGLTFLike = { scene: THREE.Object3D };\n\nexport interface NgtLoader<T> extends THREE.Loader {\n\tload(\n\t\turl: string,\n\t\tonLoad?: (result: T) => void,\n\t\tonProgress?: (event: ProgressEvent) => void,\n\t\tonError?: (event: unknown) => void,\n\t): unknown;\n\tloadAsync(url: string, onProgress?: (event: ProgressEvent) => void): Promise<T>;\n}\n\nexport type NgtLoaderProto<T> = new (...args: any) => NgtLoader<T extends unknown ? any : T>;\nexport type NgtLoaderReturnType<T, L extends NgtLoaderProto<T>> = T extends unknown\n\t? Awaited<ReturnType<InstanceType<L>['loadAsync']>>\n\t: T;\n\nexport type NgtLoaderExtensions<T extends { prototype: NgtLoaderProto<any> }> = (loader: T['prototype']) => void;\nexport type NgtConditionalType<Child, Parent, Truthy, Falsy> = Child extends Parent ? Truthy : Falsy;\nexport type NgtBranchingReturn<T, Parent, Coerced> = NgtConditionalType<T, Parent, Coerced, T>;\n\nexport type NgtLoaderResults<\n\tTInput extends string | string[] | Record<string, string>,\n\tTReturn,\n> = TInput extends string[] ? TReturn[] : TInput extends object ? { [key in keyof TInput]: TReturn } : TReturn;\n\nconst cached = new Map();\n\nfunction normalizeInputs(input: string | string[] | Record<string, string>) {\n\tif (Array.isArray(input)) return input;\n\tif (typeof input === 'string') return [input];\n\treturn Object.values(input);\n}\n\nfunction load<\n\tTData,\n\tTUrl extends string | string[] | Record<string, string>,\n\tTLoaderConstructor extends NgtLoaderProto<TData>,\n>(\n\tloaderConstructorFactory: (inputs: string[]) => TLoaderConstructor,\n\tinputs: () => TUrl,\n\t{\n\t\textensions,\n\t\tonProgress,\n\t}: { extensions?: NgtLoaderExtensions<TLoaderConstructor>; onProgress?: (event: ProgressEvent) => void } = {},\n) {\n\treturn (): Array<Promise<any>> => {\n\t\tconst urls = normalizeInputs(inputs());\n\t\tconst loader = new (loaderConstructorFactory(urls))();\n\t\tif (extensions) extensions(loader);\n\t\t// TODO: reevaluate this\n\t\treturn urls.map((url) => {\n\t\t\tif (!cached.has(url)) {\n\t\t\t\tcached.set(\n\t\t\t\t\turl,\n\t\t\t\t\tnew Promise<TData>((resolve, reject) => {\n\t\t\t\t\t\tloader.load(\n\t\t\t\t\t\t\turl,\n\t\t\t\t\t\t\t(data) => {\n\t\t\t\t\t\t\t\tif ('scene' in (data as NgtAnyRecord)) {\n\t\t\t\t\t\t\t\t\tObject.assign(data as NgtAnyRecord, makeObjectGraph((data as NgtAnyRecord)['scene']));\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\tresolve(data);\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\tonProgress,\n\t\t\t\t\t\t\t(error) => reject(new Error(`[NGT] Could not load ${url}: ${error}`)),\n\t\t\t\t\t\t);\n\t\t\t\t\t}),\n\t\t\t\t);\n\t\t\t}\n\t\t\treturn cached.get(url)!;\n\t\t});\n\t};\n}\n\nfunction _injectNgtLoader<\n\tTData,\n\tTUrl extends string | string[] | Record<string, string>,\n\tTLoaderConstructor extends NgtLoaderProto<TData>,\n\tTReturn = NgtLoaderReturnType<TData, TLoaderConstructor>,\n>(\n\tloaderConstructorFactory: (inputs: string[]) => TLoaderConstructor,\n\tinputs: () => TUrl,\n\t{\n\t\textensions,\n\t\tonProgress,\n\t\tinjector,\n\t}: {\n\t\textensions?: NgtLoaderExtensions<TLoaderConstructor>;\n\t\tonProgress?: (event: ProgressEvent) => void;\n\t\tinjector?: Injector;\n\t} = {},\n): Signal<NgtLoaderResults<TUrl, NgtBranchingReturn<TReturn, NgtGLTFLike, NgtGLTFLike & NgtObjectMap>> | null> {\n\treturn assertInjector(_injectNgtLoader, injector, () => {\n\t\tconst response = signal<NgtLoaderResults<\n\t\t\tTUrl,\n\t\t\tNgtBranchingReturn<TReturn, NgtGLTFLike, NgtGLTFLike & NgtObjectMap>\n\t\t> | null>(null);\n\t\tconst effector = load(loaderConstructorFactory, inputs, { extensions, onProgress });\n\n\t\teffect(() => {\n\t\t\tconst originalUrls = inputs();\n\t\t\tPromise.all(effector()).then((results) => {\n\t\t\t\tresponse.update(() => {\n\t\t\t\t\tif (Array.isArray(originalUrls)) return results;\n\t\t\t\t\tif (typeof originalUrls === 'string') return results[0];\n\t\t\t\t\tconst keys = Object.keys(originalUrls);\n\t\t\t\t\treturn keys.reduce(\n\t\t\t\t\t\t(result, key) => {\n\t\t\t\t\t\t\t(result as NgtAnyRecord)[key] = results[keys.indexOf(key)];\n\t\t\t\t\t\t\treturn result;\n\t\t\t\t\t\t},\n\t\t\t\t\t\t{} as { [key in keyof TUrl]: NgtBranchingReturn<TReturn, NgtGLTFLike, NgtGLTFLike & NgtObjectMap> },\n\t\t\t\t\t);\n\t\t\t\t});\n\t\t\t});\n\t\t});\n\n\t\treturn response.asReadonly();\n\t});\n}\n\n_injectNgtLoader.preload = <\n\tTData,\n\tTUrl extends string | string[] | Record<string, string>,\n\tTLoaderConstructor extends NgtLoaderProto<TData>,\n>(\n\tloaderConstructorFactory: (inputs: string[]) => TLoaderConstructor,\n\tinputs: () => TUrl,\n\textensions?: NgtLoaderExtensions<TLoaderConstructor>,\n) => {\n\tvoid Promise.all(load(loaderConstructorFactory, inputs, { extensions })());\n};\n\n_injectNgtLoader.destroy = () => {\n\tcached.clear();\n};\n\nexport type NgtInjectedLoader = typeof _injectNgtLoader;\nexport const injectNgtLoader: NgtInjectedLoader = _injectNgtLoader;\n"]}
|
|
64
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"loader.js","sourceRoot":"","sources":["../../../../../libs/core/src/lib/loader.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injector, effect, signal, type Signal } from '@angular/core';\nimport { assertInjector } from 'ngxtension/assert-injector';\nimport type * as THREE from 'three';\nimport type { NgtAnyRecord } from './types';\nimport { makeObjectGraph, type NgtObjectMap } from './utils/make';\n\nexport type NgtGLTFLike = { scene: THREE.Object3D };\n\nexport interface NgtLoader<T> extends THREE.Loader {\n\tload(\n\t\turl: string,\n\t\tonLoad?: (result: T) => void,\n\t\tonProgress?: (event: ProgressEvent) => void,\n\t\tonError?: (event: unknown) => void,\n\t): unknown;\n\tloadAsync(url: string, onProgress?: (event: ProgressEvent) => void): Promise<T>;\n}\n\nexport type NgtLoaderProto<T> = new (...args: any) => NgtLoader<T extends unknown ? any : T>;\nexport type NgtLoaderReturnType<T, L extends NgtLoaderProto<T>> = T extends unknown\n\t? Awaited<ReturnType<InstanceType<L>['loadAsync']>>\n\t: T;\n\nexport type NgtLoaderExtensions<T extends { prototype: NgtLoaderProto<any> }> = (loader: T['prototype']) => void;\nexport type NgtConditionalType<Child, Parent, Truthy, Falsy> = Child extends Parent ? Truthy : Falsy;\nexport type NgtBranchingReturn<T, Parent, Coerced> = NgtConditionalType<T, Parent, Coerced, T>;\n\nexport type NgtLoaderResults<\n\tTInput extends string | string[] | Record<string, string>,\n\tTReturn,\n> = TInput extends string[] ? TReturn[] : TInput extends object ? { [key in keyof TInput]: TReturn } : TReturn;\n\nconst cached = new Map();\n\nfunction normalizeInputs(input: string | string[] | Record<string, string>) {\n\tif (Array.isArray(input)) return input;\n\tif (typeof input === 'string') return [input];\n\treturn Object.values(input);\n}\n\nfunction load<\n\tTData,\n\tTUrl extends string | string[] | Record<string, string>,\n\tTLoaderConstructor extends NgtLoaderProto<TData>,\n>(\n\tloaderConstructorFactory: (inputs: string[]) => TLoaderConstructor,\n\tinputs: () => TUrl,\n\t{\n\t\textensions,\n\t\tonProgress,\n\t}: { extensions?: NgtLoaderExtensions<TLoaderConstructor>; onProgress?: (event: ProgressEvent) => void } = {},\n) {\n\treturn (): Array<Promise<any>> => {\n\t\tconst urls = normalizeInputs(inputs());\n\t\tconst loader = new (loaderConstructorFactory(urls))();\n\t\tif (extensions) extensions(loader);\n\t\t// TODO: reevaluate this\n\t\treturn urls.map((url) => {\n\t\t\tif (!cached.has(url)) {\n\t\t\t\tcached.set(\n\t\t\t\t\turl,\n\t\t\t\t\tnew Promise<TData>((resolve, reject) => {\n\t\t\t\t\t\tloader.load(\n\t\t\t\t\t\t\turl,\n\t\t\t\t\t\t\t(data) => {\n\t\t\t\t\t\t\t\tif ('scene' in (data as NgtAnyRecord)) {\n\t\t\t\t\t\t\t\t\tObject.assign(data as NgtAnyRecord, makeObjectGraph((data as NgtAnyRecord)['scene']));\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\tresolve(data);\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\tonProgress,\n\t\t\t\t\t\t\t(error) => reject(new Error(`[NGT] Could not load ${url}: ${error}`)),\n\t\t\t\t\t\t);\n\t\t\t\t\t}),\n\t\t\t\t);\n\t\t\t}\n\t\t\treturn cached.get(url)!;\n\t\t});\n\t};\n}\n\nfunction _injectNgtLoader<\n\tTData,\n\tTUrl extends string | string[] | Record<string, string>,\n\tTLoaderConstructor extends NgtLoaderProto<TData>,\n\tTReturn = NgtLoaderReturnType<TData, TLoaderConstructor>,\n>(\n\tloaderConstructorFactory: (inputs: string[]) => TLoaderConstructor,\n\tinputs: () => TUrl,\n\t{\n\t\textensions,\n\t\tonProgress,\n\t\tinjector,\n\t}: {\n\t\textensions?: NgtLoaderExtensions<TLoaderConstructor>;\n\t\tonProgress?: (event: ProgressEvent) => void;\n\t\tinjector?: Injector;\n\t} = {},\n): Signal<NgtLoaderResults<TUrl, NgtBranchingReturn<TReturn, NgtGLTFLike, NgtGLTFLike & NgtObjectMap>> | null> {\n\treturn assertInjector(_injectNgtLoader, injector, () => {\n\t\tconst response = signal<NgtLoaderResults<\n\t\t\tTUrl,\n\t\t\tNgtBranchingReturn<TReturn, NgtGLTFLike, NgtGLTFLike & NgtObjectMap>\n\t\t> | null>(null);\n\t\tconst effector = load(loaderConstructorFactory, inputs, { extensions, onProgress });\n\n\t\teffect(() => {\n\t\t\tconst originalUrls = inputs();\n\t\t\tPromise.all(effector()).then((results) => {\n\t\t\t\tresponse.update(() => {\n\t\t\t\t\tif (Array.isArray(originalUrls)) return results;\n\t\t\t\t\tif (typeof originalUrls === 'string') return results[0];\n\t\t\t\t\tconst keys = Object.keys(originalUrls);\n\t\t\t\t\treturn keys.reduce(\n\t\t\t\t\t\t(result, key) => {\n\t\t\t\t\t\t\t(result as NgtAnyRecord)[key] = results[keys.indexOf(key)];\n\t\t\t\t\t\t\treturn result;\n\t\t\t\t\t\t},\n\t\t\t\t\t\t{} as { [key in keyof TUrl]: NgtBranchingReturn<TReturn, NgtGLTFLike, NgtGLTFLike & NgtObjectMap> },\n\t\t\t\t\t);\n\t\t\t\t});\n\t\t\t});\n\t\t});\n\n\t\treturn response.asReadonly();\n\t});\n}\n\n_injectNgtLoader.preload = <\n\tTData,\n\tTUrl extends string | string[] | Record<string, string>,\n\tTLoaderConstructor extends NgtLoaderProto<TData>,\n>(\n\tloaderConstructorFactory: (inputs: string[]) => TLoaderConstructor,\n\tinputs: () => TUrl,\n\textensions?: NgtLoaderExtensions<TLoaderConstructor>,\n) => {\n\tvoid Promise.all(load(loaderConstructorFactory, inputs, { extensions })());\n};\n\n_injectNgtLoader.destroy = () => {\n\tcached.clear();\n};\n\nexport type NgtInjectedLoader = typeof _injectNgtLoader;\nexport const injectNgtLoader: NgtInjectedLoader = _injectNgtLoader;\n"]}
|