angular-three 1.0.0-beta.9 → 1.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -41,10 +41,10 @@ export class Scene {}
41
41
  - Custom Element tags follow this rule: `ngt-` + THREE classes in **kebab-case**. `Mesh` -> `ngt-mesh`
42
42
  - `schemas: [CUSTOM_ELEMENTS_SCHEMA]` allows us to use custom tags on the template. This is Angular's limitation at the moment
43
43
 
44
- 2. Render `<ngt-canvas>` component, use `Scene` component above to pass into `[scene]` input on `<ngt-canvas>`
44
+ 2. Render `<ngt-canvas>` component, use `Scene` component above to pass into `[sceneGraph]` input on `<ngt-canvas>`
45
45
 
46
46
  ```html
47
- <ngt-canvas [scene]="Scene" />
47
+ <ngt-canvas [sceneGraph]="Scene" />
48
48
  ```
49
49
 
50
50
  - `ngt-canvas` creates the basic building blocks of THREE.js: a default `WebGLRenderer`, a default `Scene`, and a default `PerspectiveCamera`
package/esm2020/index.mjs CHANGED
@@ -7,10 +7,13 @@ export * from './lib/directives/args';
7
7
  export * from './lib/directives/repeat';
8
8
  export * from './lib/loader';
9
9
  export * from './lib/pipes/push';
10
+ export * from './lib/portal';
10
11
  export * from './lib/stores/rx-store';
11
12
  export * from './lib/stores/store';
12
13
  export * from './lib/types';
14
+ export { createAttachFunction } from './lib/utils/attach';
13
15
  export * from './lib/utils/instance';
14
16
  export * from './lib/utils/is';
17
+ export * from './lib/utils/make';
15
18
  export * from './lib/utils/update';
16
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXItdGhyZWUvc3JjL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMsd0JBQXdCLENBQUM7QUFDdkMsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLGFBQWEsQ0FBQztBQUM1QixjQUFjLHNCQUFzQixDQUFDO0FBQ3JDLGNBQWMsZ0JBQWdCLENBQUM7QUFDL0IsY0FBYyxvQkFBb0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbGliL2NhbnZhcyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9kaS9iZWZvcmUtcmVuZGVyJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2RpL2NhdGFsb2d1ZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9kaS9kZXN0cm95JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2RpL3JlZic7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9kaXJlY3RpdmVzL2FyZ3MnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZGlyZWN0aXZlcy9yZXBlYXQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbG9hZGVyJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3BpcGVzL3B1c2gnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvc3RvcmVzL3J4LXN0b3JlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3N0b3Jlcy9zdG9yZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi90eXBlcyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi91dGlscy9pbnN0YW5jZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi91dGlscy9pcyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi91dGlscy91cGRhdGUnO1xuIl19
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXItdGhyZWUvc3JjL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMsd0JBQXdCLENBQUM7QUFDdkMsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLGFBQWEsQ0FBQztBQUM1QixPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUMxRCxjQUFjLHNCQUFzQixDQUFDO0FBQ3JDLGNBQWMsZ0JBQWdCLENBQUM7QUFDL0IsY0FBYyxrQkFBa0IsQ0FBQztBQUNqQyxjQUFjLG9CQUFvQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9saWIvY2FudmFzJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2RpL2JlZm9yZS1yZW5kZXInO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZGkvY2F0YWxvZ3VlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2RpL2Rlc3Ryb3knO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZGkvcmVmJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2RpcmVjdGl2ZXMvYXJncyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9kaXJlY3RpdmVzL3JlcGVhdCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9sb2FkZXInO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvcGlwZXMvcHVzaCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9wb3J0YWwnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvc3RvcmVzL3J4LXN0b3JlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3N0b3Jlcy9zdG9yZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi90eXBlcyc7XG5leHBvcnQgeyBjcmVhdGVBdHRhY2hGdW5jdGlvbiB9IGZyb20gJy4vbGliL3V0aWxzL2F0dGFjaCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi91dGlscy9pbnN0YW5jZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi91dGlscy9pcyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi91dGlscy9tYWtlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3V0aWxzL3VwZGF0ZSc7XG4iXX0=
@@ -0,0 +1,241 @@
1
+ var _NgtPortal_instances, _NgtPortal_inject;
2
+ import { __classPrivateFieldGet } from "tslib";
3
+ import { NgIf } from '@angular/common';
4
+ import { Component, ContentChild, Directive, EventEmitter, inject, Input, Output, SkipSelf, TemplateRef, ViewChild, ViewContainerRef, } from '@angular/core';
5
+ import * as THREE from 'three';
6
+ import { injectNgtRef } from './di/ref';
7
+ import { NgtRxStore } from './stores/rx-store';
8
+ import { NgtStore } from './stores/store';
9
+ import { getLocalState, prepare } from './utils/instance';
10
+ import { is } from './utils/is';
11
+ import { updateCamera } from './utils/update';
12
+ import * as i0 from "@angular/core";
13
+ const privateKeys = [
14
+ 'get',
15
+ 'set',
16
+ 'select',
17
+ 'setSize',
18
+ 'setDpr',
19
+ 'setFrameloop',
20
+ 'events',
21
+ 'invalidate',
22
+ 'advance',
23
+ 'size',
24
+ 'viewport',
25
+ 'addInteraction',
26
+ 'removeInteraction',
27
+ ];
28
+ export class NgtPortalBeforeRender {
29
+ constructor() {
30
+ this.portalStore = inject(NgtStore);
31
+ this.renderPriority = 1;
32
+ this.beforeRender = new EventEmitter();
33
+ }
34
+ ngOnInit() {
35
+ let oldClear;
36
+ this.subscription = this.portalStore.get('internal').subscribe(({ delta, frame }) => {
37
+ this.beforeRender.emit({ ...this.portalStore.get(), delta, frame });
38
+ const { gl, scene, camera } = this.portalStore.get();
39
+ oldClear = gl.autoClear;
40
+ if (this.renderPriority === 1) {
41
+ // clear scene and render with default
42
+ gl.autoClear = true;
43
+ gl.render(this.parentScene, this.parentCamera);
44
+ }
45
+ // disable cleaning
46
+ gl.autoClear = false;
47
+ gl.clearDepth();
48
+ gl.render(scene, camera);
49
+ // restore
50
+ gl.autoClear = oldClear;
51
+ }, this.renderPriority, this.portalStore);
52
+ }
53
+ ngOnDestroy() {
54
+ this.subscription?.();
55
+ }
56
+ }
57
+ NgtPortalBeforeRender.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.1", ngImport: i0, type: NgtPortalBeforeRender, deps: [], target: i0.ɵɵFactoryTarget.Directive });
58
+ NgtPortalBeforeRender.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.1.1", type: NgtPortalBeforeRender, isStandalone: true, selector: "ngt-portal-before-render", inputs: { renderPriority: "renderPriority", parentScene: "parentScene", parentCamera: "parentCamera" }, outputs: { beforeRender: "beforeRender" }, ngImport: i0 });
59
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.1", ngImport: i0, type: NgtPortalBeforeRender, decorators: [{
60
+ type: Directive,
61
+ args: [{
62
+ selector: 'ngt-portal-before-render',
63
+ standalone: true,
64
+ }]
65
+ }], propDecorators: { renderPriority: [{
66
+ type: Input
67
+ }], parentScene: [{
68
+ type: Input
69
+ }], parentCamera: [{
70
+ type: Input
71
+ }], beforeRender: [{
72
+ type: Output
73
+ }] } });
74
+ export class NgtPortalContent {
75
+ constructor(vcr, parentVcr) {
76
+ const commentNode = vcr.element.nativeElement;
77
+ if (commentNode['__ngt_renderer_add_comment__']) {
78
+ commentNode['__ngt_renderer_add_comment__'](parentVcr.element.nativeElement);
79
+ delete commentNode['__ngt_renderer_add_comment__'];
80
+ }
81
+ }
82
+ }
83
+ NgtPortalContent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.1", ngImport: i0, type: NgtPortalContent, deps: [{ token: i0.ViewContainerRef }, { token: i0.ViewContainerRef, skipSelf: true }], target: i0.ɵɵFactoryTarget.Directive });
84
+ NgtPortalContent.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.1.1", type: NgtPortalContent, isStandalone: true, selector: "ng-template[ngtPortalContent]", ngImport: i0 });
85
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.1", ngImport: i0, type: NgtPortalContent, decorators: [{
86
+ type: Directive,
87
+ args: [{ selector: 'ng-template[ngtPortalContent]', standalone: true }]
88
+ }], ctorParameters: function () { return [{ type: i0.ViewContainerRef }, { type: i0.ViewContainerRef, decorators: [{
89
+ type: SkipSelf
90
+ }] }]; } });
91
+ export class NgtPortal extends NgtRxStore {
92
+ constructor() {
93
+ super(...arguments);
94
+ _NgtPortal_instances.add(this);
95
+ this.autoRender = true;
96
+ this.autoRenderPriority = 1;
97
+ this.beforeRender = new EventEmitter();
98
+ this.parentStore = inject(NgtStore, { skipSelf: true });
99
+ this.parentScene = this.parentStore.get('scene');
100
+ this.parentCamera = this.parentStore.get('camera');
101
+ this.portalStore = inject(NgtStore, { self: true });
102
+ this.raycaster = new THREE.Raycaster();
103
+ this.pointer = new THREE.Vector2();
104
+ this.portalContentRendered = false;
105
+ }
106
+ set container(container) {
107
+ this.set({ container });
108
+ }
109
+ set state(state) {
110
+ this.set({ state });
111
+ }
112
+ initialize() {
113
+ super.initialize();
114
+ this.set({ container: injectNgtRef(prepare(new THREE.Scene())) });
115
+ }
116
+ ngOnInit() {
117
+ const previousState = this.parentStore.get();
118
+ const inputsState = this.get();
119
+ if (!inputsState.state && this.autoRender) {
120
+ inputsState.state = { events: { priority: this.autoRenderPriority + 1 } };
121
+ }
122
+ const { events, size, ...restInputsState } = inputsState.state || {};
123
+ const containerState = inputsState.container;
124
+ const container = is.ref(containerState) ? containerState.nativeElement : containerState;
125
+ const localState = getLocalState(container);
126
+ if (!localState.store) {
127
+ localState.store = this.portalStore;
128
+ }
129
+ this.portalStore.set({
130
+ ...previousState,
131
+ scene: container,
132
+ raycaster: this.raycaster,
133
+ pointer: this.pointer,
134
+ previousStore: this.parentStore,
135
+ events: { ...previousState.events, ...(events || {}) },
136
+ size: { ...previousState.size, ...(size || {}) },
137
+ ...restInputsState,
138
+ get: this.portalStore.get.bind(this.portalStore),
139
+ set: this.portalStore.set.bind(this.portalStore),
140
+ select: this.portalStore.select.bind(this.portalStore),
141
+ setEvents: (events) => this.portalStore.set((state) => ({ ...state, events: { ...state.events, ...events } })),
142
+ });
143
+ this.hold(this.parentStore.select(), (previous) => this.portalStore.set((state) => __classPrivateFieldGet(this, _NgtPortal_instances, "m", _NgtPortal_inject).call(this, previous, state)));
144
+ requestAnimationFrame(() => {
145
+ this.portalStore.set((injectState) => __classPrivateFieldGet(this, _NgtPortal_instances, "m", _NgtPortal_inject).call(this, this.parentStore.get(), injectState));
146
+ });
147
+ this.portalContentView = this.portalContentAnchor.createEmbeddedView(this.portalContentTemplate);
148
+ this.portalContentView.detectChanges();
149
+ this.portalContentRendered = true;
150
+ }
151
+ onBeforeRender(portal) {
152
+ this.beforeRender.emit({
153
+ root: { ...this.parentStore.get(), delta: portal.delta, frame: portal.frame },
154
+ portal,
155
+ });
156
+ }
157
+ ngOnDestroy() {
158
+ if (this.portalContentView && !this.portalContentView.destroyed) {
159
+ this.portalContentView.destroy();
160
+ }
161
+ super.ngOnDestroy();
162
+ }
163
+ }
164
+ _NgtPortal_instances = new WeakSet(), _NgtPortal_inject = function _NgtPortal_inject(rootState, injectState) {
165
+ const intersect = { ...rootState };
166
+ Object.keys(intersect).forEach((key) => {
167
+ if (privateKeys.includes(key) ||
168
+ rootState[key] !== injectState[key]) {
169
+ delete intersect[key];
170
+ }
171
+ });
172
+ const inputs = this.get();
173
+ const { size, events, ...restInputsState } = inputs.state || {};
174
+ let viewport = undefined;
175
+ if (injectState && size) {
176
+ const camera = injectState.camera;
177
+ viewport = rootState.viewport.getCurrentViewport(camera, new THREE.Vector3(), size);
178
+ if (camera !== rootState.camera)
179
+ updateCamera(camera, size);
180
+ }
181
+ return {
182
+ ...intersect,
183
+ scene: is.ref(inputs.container) ? inputs.container.nativeElement : inputs.container,
184
+ raycaster: this.raycaster,
185
+ pointer: this.pointer,
186
+ previousStore: this.parentStore,
187
+ events: { ...rootState.events, ...(injectState?.events || {}), ...events },
188
+ size: { ...rootState.size, ...size },
189
+ viewport: { ...rootState.viewport, ...(viewport || {}) },
190
+ ...restInputsState,
191
+ };
192
+ };
193
+ NgtPortal.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.1", ngImport: i0, type: NgtPortal, deps: null, target: i0.ɵɵFactoryTarget.Component });
194
+ NgtPortal.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.1", type: NgtPortal, isStandalone: true, selector: "ngt-portal", inputs: { container: "container", state: "state", autoRender: "autoRender", autoRenderPriority: "autoRenderPriority" }, outputs: { beforeRender: "beforeRender" }, providers: [NgtStore], queries: [{ propertyName: "portalContentTemplate", first: true, predicate: NgtPortalContent, descendants: true, read: TemplateRef, static: true }], viewQueries: [{ propertyName: "portalContentAnchor", first: true, predicate: ["portalContentAnchor"], descendants: true, read: ViewContainerRef, static: true }], usesInheritance: true, ngImport: i0, template: `
195
+ <ng-container #portalContentAnchor>
196
+ <ngt-portal-before-render
197
+ *ngIf="autoRender && portalContentRendered"
198
+ [renderPriority]="autoRenderPriority"
199
+ [parentScene]="parentScene"
200
+ [parentCamera]="parentCamera"
201
+ (beforeRender)="onBeforeRender($event)"
202
+ />
203
+ </ng-container>
204
+ `, isInline: true, dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgtPortalBeforeRender, selector: "ngt-portal-before-render", inputs: ["renderPriority", "parentScene", "parentCamera"], outputs: ["beforeRender"] }] });
205
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.1", ngImport: i0, type: NgtPortal, decorators: [{
206
+ type: Component,
207
+ args: [{
208
+ selector: 'ngt-portal',
209
+ standalone: true,
210
+ template: `
211
+ <ng-container #portalContentAnchor>
212
+ <ngt-portal-before-render
213
+ *ngIf="autoRender && portalContentRendered"
214
+ [renderPriority]="autoRenderPriority"
215
+ [parentScene]="parentScene"
216
+ [parentCamera]="parentCamera"
217
+ (beforeRender)="onBeforeRender($event)"
218
+ />
219
+ </ng-container>
220
+ `,
221
+ imports: [NgIf, NgtPortalBeforeRender],
222
+ providers: [NgtStore],
223
+ }]
224
+ }], propDecorators: { container: [{
225
+ type: Input
226
+ }], state: [{
227
+ type: Input
228
+ }], autoRender: [{
229
+ type: Input
230
+ }], autoRenderPriority: [{
231
+ type: Input
232
+ }], beforeRender: [{
233
+ type: Output
234
+ }], portalContentTemplate: [{
235
+ type: ContentChild,
236
+ args: [NgtPortalContent, { read: TemplateRef, static: true }]
237
+ }], portalContentAnchor: [{
238
+ type: ViewChild,
239
+ args: ['portalContentAnchor', { read: ViewContainerRef, static: true }]
240
+ }] } });
241
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"portal.js","sourceRoot":"","sources":["../../../../../libs/angular-three/src/lib/portal.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgIf } from '@angular/common';\nimport {\n    Component,\n    ContentChild,\n    Directive,\n    ElementRef,\n    EmbeddedViewRef,\n    EventEmitter,\n    inject,\n    Input,\n    OnDestroy,\n    OnInit,\n    Output,\n    SkipSelf,\n    TemplateRef,\n    ViewChild,\n    ViewContainerRef,\n} from '@angular/core';\nimport * as THREE from 'three';\nimport { injectNgtRef } from './di/ref';\nimport { NgtRxStore } from './stores/rx-store';\nimport { NgtStore } from './stores/store';\nimport { NgtEventManager, NgtRenderState, NgtSize, NgtState } from './types';\nimport { getLocalState, prepare } from './utils/instance';\nimport { is } from './utils/is';\nimport { updateCamera } from './utils/update';\n\nconst privateKeys = [\n    'get',\n    'set',\n    'select',\n    'setSize',\n    'setDpr',\n    'setFrameloop',\n    'events',\n    'invalidate',\n    'advance',\n    'size',\n    'viewport',\n    'addInteraction',\n    'removeInteraction',\n] as const;\ntype PrivateKeys = (typeof privateKeys)[number];\n\nexport interface NgtPortalInputs {\n    container: ElementRef<THREE.Object3D> | THREE.Object3D;\n    camera: ElementRef<THREE.Camera> | THREE.Camera;\n    state: Partial<\n        Omit<NgtState, PrivateKeys> & {\n            events: Partial<Pick<NgtEventManager<any>, 'enabled' | 'priority' | 'compute' | 'connected'>>;\n            size: NgtSize;\n        }\n    >;\n}\n\n@Directive({\n    selector: 'ngt-portal-before-render',\n    standalone: true,\n})\nexport class NgtPortalBeforeRender implements OnInit, OnDestroy {\n    private readonly portalStore = inject(NgtStore);\n\n    @Input() renderPriority = 1;\n    @Input() parentScene!: THREE.Scene;\n    @Input() parentCamera!: THREE.Camera;\n\n    @Output() beforeRender = new EventEmitter<NgtRenderState>();\n\n    private subscription?: () => void;\n\n    ngOnInit() {\n        let oldClear: boolean;\n        this.subscription = this.portalStore.get('internal').subscribe(\n            ({ delta, frame }) => {\n                this.beforeRender.emit({ ...this.portalStore.get(), delta, frame });\n                const { gl, scene, camera } = this.portalStore.get();\n                oldClear = gl.autoClear;\n                if (this.renderPriority === 1) {\n                    // clear scene and render with default\n                    gl.autoClear = true;\n                    gl.render(this.parentScene, this.parentCamera);\n                }\n                // disable cleaning\n                gl.autoClear = false;\n                gl.clearDepth();\n                gl.render(scene, camera);\n                // restore\n                gl.autoClear = oldClear;\n            },\n            this.renderPriority,\n            this.portalStore\n        );\n    }\n\n    ngOnDestroy() {\n        this.subscription?.();\n    }\n}\n\n@Directive({ selector: 'ng-template[ngtPortalContent]', standalone: true })\nexport class NgtPortalContent {\n    constructor(vcr: ViewContainerRef, @SkipSelf() parentVcr: ViewContainerRef) {\n        const commentNode = vcr.element.nativeElement;\n        if (commentNode['__ngt_renderer_add_comment__']) {\n            commentNode['__ngt_renderer_add_comment__'](parentVcr.element.nativeElement);\n            delete commentNode['__ngt_renderer_add_comment__'];\n        }\n    }\n}\n\n@Component({\n    selector: 'ngt-portal',\n    standalone: true,\n    template: `\n        <ng-container #portalContentAnchor>\n            <ngt-portal-before-render\n                *ngIf=\"autoRender && portalContentRendered\"\n                [renderPriority]=\"autoRenderPriority\"\n                [parentScene]=\"parentScene\"\n                [parentCamera]=\"parentCamera\"\n                (beforeRender)=\"onBeforeRender($event)\"\n            />\n        </ng-container>\n    `,\n    imports: [NgIf, NgtPortalBeforeRender],\n    providers: [NgtStore],\n})\nexport class NgtPortal extends NgtRxStore<NgtPortalInputs> implements OnInit, OnDestroy {\n    @Input() set container(container: NgtPortalInputs['container']) {\n        this.set({ container });\n    }\n\n    @Input() set state(state: NgtPortalInputs['state']) {\n        this.set({ state });\n    }\n\n    @Input() autoRender = true;\n    @Input() autoRenderPriority = 1;\n\n    @Output() beforeRender = new EventEmitter<{ root: NgtRenderState; portal: NgtRenderState }>();\n\n    @ContentChild(NgtPortalContent, { read: TemplateRef, static: true })\n    readonly portalContentTemplate!: TemplateRef<unknown>;\n\n    @ViewChild('portalContentAnchor', { read: ViewContainerRef, static: true })\n    readonly portalContentAnchor!: ViewContainerRef;\n\n    private readonly parentStore = inject(NgtStore, { skipSelf: true });\n    readonly parentScene = this.parentStore.get('scene');\n    readonly parentCamera = this.parentStore.get('camera');\n\n    private readonly portalStore = inject(NgtStore, { self: true });\n\n    private readonly raycaster = new THREE.Raycaster();\n    private readonly pointer = new THREE.Vector2();\n\n    portalContentRendered = false;\n    private portalContentView?: EmbeddedViewRef<unknown>;\n\n    override initialize() {\n        super.initialize();\n        this.set({ container: injectNgtRef<THREE.Scene>(prepare(new THREE.Scene())) });\n    }\n\n    ngOnInit() {\n        const previousState = this.parentStore.get();\n        const inputsState = this.get();\n\n        if (!inputsState.state && this.autoRender) {\n            inputsState.state = { events: { priority: this.autoRenderPriority + 1 } };\n        }\n\n        const { events, size, ...restInputsState } = inputsState.state || {};\n\n        const containerState = inputsState.container;\n        const container = is.ref(containerState) ? containerState.nativeElement : containerState;\n\n        const localState = getLocalState(container);\n        if (!localState.store) {\n            localState.store = this.portalStore;\n        }\n\n        this.portalStore.set({\n            ...previousState,\n            scene: container as THREE.Scene,\n            raycaster: this.raycaster,\n            pointer: this.pointer,\n            previousStore: this.parentStore,\n            events: { ...previousState.events, ...(events || {}) },\n            size: { ...previousState.size, ...(size || {}) },\n            ...restInputsState,\n            get: this.portalStore.get.bind(this.portalStore),\n            set: this.portalStore.set.bind(this.portalStore),\n            select: this.portalStore.select.bind(this.portalStore),\n            setEvents: (events) =>\n                this.portalStore.set((state) => ({ ...state, events: { ...state.events, ...events } })),\n        });\n\n        this.hold(this.parentStore.select(), (previous) =>\n            this.portalStore.set((state) => this.#inject(previous, state))\n        );\n\n        requestAnimationFrame(() => {\n            this.portalStore.set((injectState) => this.#inject(this.parentStore.get(), injectState));\n        });\n        this.portalContentView = this.portalContentAnchor.createEmbeddedView(this.portalContentTemplate);\n        this.portalContentView.detectChanges();\n        this.portalContentRendered = true;\n    }\n\n    onBeforeRender(portal: NgtRenderState) {\n        this.beforeRender.emit({\n            root: { ...this.parentStore.get(), delta: portal.delta, frame: portal.frame },\n            portal,\n        });\n    }\n\n    override ngOnDestroy() {\n        if (this.portalContentView && !this.portalContentView.destroyed) {\n            this.portalContentView.destroy();\n        }\n        super.ngOnDestroy();\n    }\n\n    #inject(rootState: NgtState, injectState: NgtState) {\n        const intersect: Partial<NgtState> = { ...rootState };\n\n        Object.keys(intersect).forEach((key) => {\n            if (\n                privateKeys.includes(key as PrivateKeys) ||\n                rootState[key as keyof NgtState] !== injectState[key as keyof NgtState]\n            ) {\n                delete intersect[key as keyof NgtState];\n            }\n        });\n\n        const inputs = this.get();\n        const { size, events, ...restInputsState } = inputs.state || {};\n\n        let viewport = undefined;\n        if (injectState && size) {\n            const camera = injectState.camera;\n            viewport = rootState.viewport.getCurrentViewport(camera, new THREE.Vector3(), size);\n            if (camera !== rootState.camera) updateCamera(camera, size);\n        }\n\n        return {\n            ...intersect,\n            scene: is.ref(inputs.container) ? inputs.container.nativeElement : inputs.container,\n            raycaster: this.raycaster,\n            pointer: this.pointer,\n            previousStore: this.parentStore,\n            events: { ...rootState.events, ...(injectState?.events || {}), ...events },\n            size: { ...rootState.size, ...size },\n            viewport: { ...rootState.viewport, ...(viewport || {}) },\n            ...restInputsState,\n        } as NgtState;\n    }\n}\n"]}
@@ -33,14 +33,18 @@ export class NgtRendererStore {
33
33
  state[13 /* NgtRendererClassId.injectorFactory */] = () => getDebugNode(rendererNode).injector;
34
34
  // we attach an arrow function to the Comment node
35
35
  // In our directives, we can call this function to then start tracking the RendererNode
36
- rendererNode['__ngt_renderer_add_comment__'] = () => {
37
- this.comments.push(rendererNode);
36
+ rendererNode['__ngt_renderer_add_comment__'] = (portalNode) => {
37
+ if (portalNode && portalNode.__ngt_renderer__[0 /* NgtRendererClassId.type */] === 'portal') {
38
+ this.portals.push(portalNode);
39
+ }
40
+ else {
41
+ this.comments.push(rendererNode);
42
+ }
38
43
  };
39
44
  return rendererNode;
40
45
  }
41
46
  if (state[0 /* NgtRendererClassId.type */] === 'portal') {
42
47
  state[13 /* NgtRendererClassId.injectorFactory */] = () => getDebugNode(rendererNode).injector;
43
- this.portals.push(rendererNode);
44
48
  return rendererNode;
45
49
  }
46
50
  if (state[0 /* NgtRendererClassId.type */] === 'compound') {
@@ -153,6 +157,7 @@ export class NgtRendererStore {
153
157
  if (node.__ngt_renderer__[3 /* NgtRendererClassId.destroyed */])
154
158
  return;
155
159
  // setup [ref] here
160
+ // ref should never change
156
161
  if (name === SPECIAL_PROPERTIES.REF && is.ref(value)) {
157
162
  node.__ngt_renderer__[11 /* NgtRendererClassId.ref */] = value;
158
163
  value.nativeElement = node;
@@ -338,7 +343,8 @@ export class NgtRendererStore {
338
343
  continue;
339
344
  }
340
345
  const instance = injector.get(NgtStore, null);
341
- if (instance) {
346
+ // only the instance with previousStore should pass
347
+ if (instance && instance.get('previousStore')) {
342
348
  store = instance;
343
349
  break;
344
350
  }
@@ -347,4 +353,4 @@ export class NgtRendererStore {
347
353
  return store || this.root.store;
348
354
  }
349
355
  }
350
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"state.js","sourceRoot":"","sources":["../../../../../../libs/angular-three/src/lib/renderer/state.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, getDebugNode, Injector, Type } from '@angular/core';\nimport { NgtArgs } from '../directives/args';\nimport { NgtStore } from '../stores/store';\nimport type { NgtAnyRecord } from '../types';\nimport { applyProps } from '../utils/apply-props';\nimport { getLocalState } from '../utils/instance';\nimport { is } from '../utils/is';\nimport { NgtCompoundClassId, NgtQueueOpClassId, NgtRendererClassId } from './enums';\nimport { attachThreeChild, removeThreeChild, SPECIAL_PROPERTIES } from './utils';\n\nexport type NgtRendererRootState = {\n    store: NgtStore;\n    cdr: ChangeDetectorRef;\n    compoundPrefixes: string[];\n};\n\nexport type NgtQueueOp = [type: 'op' | 'cleanUp', op: () => void, done?: true];\n\nexport type NgtRendererState = [\n    type: 'three' | 'compound' | 'portal' | 'comment' | 'dom',\n    parent: NgtRendererNode | null,\n    children: NgtRendererNode[],\n    destroyed: boolean,\n    compound: [applyFirst: boolean, props: Record<string, any>],\n    compoundParent: NgtRendererNode,\n    compounded: NgtRendererNode,\n    queueOps: Set<NgtQueueOp>,\n    attributes: Record<string, any>,\n    properties: Record<string, any>,\n    rawValue: any,\n    ref: any,\n    portalContainer: NgtRendererNode,\n    injectorFactory: () => Injector\n];\n\nexport type NgtRendererNode = {\n    __ngt_renderer__: NgtRendererState;\n};\n\nexport class NgtRendererStore {\n    private readonly comments = [] as Array<NgtRendererNode>;\n    private readonly portals = [] as Array<NgtRendererNode>;\n\n    constructor(private readonly root: NgtRendererRootState) {}\n\n    createNode(type: NgtRendererState[NgtRendererClassId.type], node: NgtAnyRecord) {\n        const state = [\n            type,\n            null,\n            [],\n            false,\n            undefined!,\n            undefined!,\n            undefined!,\n            undefined!,\n            undefined!,\n            undefined!,\n            undefined!,\n            undefined!,\n            undefined!,\n            undefined!,\n        ] as NgtRendererState;\n\n        const rendererNode = Object.assign(node, { __ngt_renderer__: state });\n\n        if (state[NgtRendererClassId.type] === 'comment') {\n            state[NgtRendererClassId.injectorFactory] = () => getDebugNode(rendererNode)!.injector;\n            // we attach an arrow function to the Comment node\n            // In our directives, we can call this function to then start tracking the RendererNode\n            rendererNode['__ngt_renderer_add_comment__'] = () => {\n                this.comments.push(rendererNode);\n            };\n            return rendererNode;\n        }\n\n        if (state[NgtRendererClassId.type] === 'portal') {\n            state[NgtRendererClassId.injectorFactory] = () => getDebugNode(rendererNode)!.injector;\n            this.portals.push(rendererNode);\n            return rendererNode;\n        }\n\n        if (state[NgtRendererClassId.type] === 'compound') {\n            state[NgtRendererClassId.queueOps] = new Set();\n            state[NgtRendererClassId.attributes] = {};\n            state[NgtRendererClassId.properties] = {};\n            return rendererNode;\n        }\n\n        return rendererNode;\n    }\n\n    setParent(node: NgtRendererNode, parent: NgtRendererNode) {\n        if (!node.__ngt_renderer__[NgtRendererClassId.parent]) {\n            node.__ngt_renderer__[NgtRendererClassId.parent] = parent;\n        }\n    }\n\n    addChild(node: NgtRendererNode, child: NgtRendererNode) {\n        if (!node.__ngt_renderer__[NgtRendererClassId.children].includes(child)) {\n            node.__ngt_renderer__[NgtRendererClassId.children].push(child);\n        }\n    }\n\n    removeChild(node: NgtRendererNode, child: NgtRendererNode) {\n        const index = node.__ngt_renderer__[NgtRendererClassId.children].findIndex((c) => child === c);\n        if (index >= 0) {\n            node.__ngt_renderer__[NgtRendererClassId.children].splice(index, 1);\n        }\n    }\n\n    setCompound(compound: NgtRendererNode, instance: NgtRendererNode) {\n        compound.__ngt_renderer__[NgtRendererClassId.compounded] = instance;\n        const attributes = Object.keys(compound.__ngt_renderer__[NgtRendererClassId.attributes]);\n        const properties = Object.keys(compound.__ngt_renderer__[NgtRendererClassId.properties]);\n\n        if (attributes.length) {\n            for (const key of attributes) {\n                this.applyAttribute(instance, key, compound.__ngt_renderer__[NgtRendererClassId.attributes][key]);\n            }\n        }\n        if (properties.length) {\n            for (const key of properties) {\n                this.applyProperty(instance, key, compound.__ngt_renderer__[NgtRendererClassId.properties][key]);\n            }\n        }\n\n        this.executeOperation(compound);\n    }\n\n    queueOperation(node: NgtRendererNode, op: NgtQueueOp) {\n        node.__ngt_renderer__[NgtRendererClassId.queueOps].add(op);\n    }\n\n    executeOperation(node: NgtRendererNode, type: NgtQueueOp[NgtQueueOpClassId.type] = 'op') {\n        if (node.__ngt_renderer__[NgtRendererClassId.queueOps]?.size) {\n            node.__ngt_renderer__[NgtRendererClassId.queueOps].forEach((op) => {\n                if (op[NgtQueueOpClassId.type] === type) {\n                    op[NgtQueueOpClassId.op]();\n                    node.__ngt_renderer__[NgtRendererClassId.queueOps].delete(op);\n                }\n            });\n        }\n    }\n\n    processPortalContainer(portal: NgtRendererNode) {\n        const injectorFactory = portal.__ngt_renderer__[NgtRendererClassId.injectorFactory];\n        const injector = injectorFactory?.();\n        if (!injector) return;\n\n        const portalStore = injector.get(NgtStore, null);\n        if (!portalStore) return;\n\n        const portalContainer = portalStore.get('scene');\n        if (!portalContainer) return;\n\n        portal.__ngt_renderer__[NgtRendererClassId.portalContainer] = this.createNode('three', portalContainer);\n    }\n\n    applyAttribute(node: NgtRendererNode, name: string, value: string) {\n        if (node.__ngt_renderer__[NgtRendererClassId.destroyed]) return;\n        if (name === SPECIAL_PROPERTIES.RENDER_PRIORITY) {\n            // priority needs to be set as an attribute string so that they can be set as early as possible\n            // we convert that string to a number. if it's invalid, 0\n            let priority = Number(value);\n            if (isNaN(priority)) {\n                priority = 0;\n                console.warn(`[NGT] \"priority\" is an invalid number, default to 0`);\n            }\n            getLocalState(node).priority = priority;\n        }\n\n        if (name === SPECIAL_PROPERTIES.COMPOUND) {\n            // we set the compound property on instance node now so we know that this instance is being compounded\n            node.__ngt_renderer__[NgtRendererClassId.compound] = [value === '' || value === 'first', {}];\n            return;\n        }\n\n        if (name === SPECIAL_PROPERTIES.ATTACH) {\n            // handle attach as tring\n            const paths = value.split('.');\n            if (paths.length) getLocalState(node).attach = paths;\n            return;\n        }\n\n        if (name === SPECIAL_PROPERTIES.VALUE) {\n            // TODO  the last time we tried this here, this didn't work\n\n            // coercion\n            let maybeCoerced: any = value;\n            if (maybeCoerced === '' || maybeCoerced === 'true' || maybeCoerced === 'false') {\n                maybeCoerced = maybeCoerced === 'true' || maybeCoerced === '';\n            } else if (!isNaN(Number(maybeCoerced))) {\n                maybeCoerced = Number(maybeCoerced);\n            }\n            node.__ngt_renderer__[NgtRendererClassId.rawValue] = maybeCoerced;\n            return;\n        }\n\n        applyProps(node, { [name]: value });\n    }\n\n    applyProperty(node: NgtRendererNode, name: string, value: any) {\n        if (node.__ngt_renderer__[NgtRendererClassId.destroyed]) return;\n        // setup [ref] here\n        if (name === SPECIAL_PROPERTIES.REF && is.ref(value)) {\n            node.__ngt_renderer__[NgtRendererClassId.ref] = value;\n            value.nativeElement = node;\n            return;\n        }\n\n        const parent = getLocalState(node).parent || node.__ngt_renderer__[NgtRendererClassId.parent];\n\n        // rawValue\n        if (getLocalState(node).isRaw && name === SPECIAL_PROPERTIES.VALUE) {\n            node.__ngt_renderer__[NgtRendererClassId.rawValue] = value;\n            attachThreeChild(parent, node);\n            return;\n        }\n\n        // attach\n        if (name === SPECIAL_PROPERTIES.ATTACH) {\n            getLocalState(node).attach = Array.isArray(value) ? value.map((v) => v.toString()) : value;\n            attachThreeChild(parent, node);\n            return;\n        }\n\n        const compound = node.__ngt_renderer__[NgtRendererClassId.compound];\n        if (\n            compound?.[NgtCompoundClassId.props] &&\n            name in compound[NgtCompoundClassId.props] &&\n            !compound[NgtCompoundClassId.applyFirst]\n        ) {\n            value = compound[NgtCompoundClassId.props][name];\n        }\n        applyProps(node, { [name]: value });\n    }\n\n    isCompound(name: string) {\n        return this.root.compoundPrefixes.some((prefix) => name.startsWith(prefix));\n    }\n\n    get rootScene() {\n        return this.root.store.get('scene');\n    }\n\n    get rootCdr() {\n        return this.root.cdr;\n    }\n\n    getClosestParentWithInstance(node: NgtRendererNode): NgtRendererNode | null {\n        let parent = node.__ngt_renderer__[NgtRendererClassId.parent];\n        while (parent && parent.__ngt_renderer__[NgtRendererClassId.type] !== 'three') {\n            parent = parent.__ngt_renderer__[NgtRendererClassId.portalContainer]\n                ? parent.__ngt_renderer__[NgtRendererClassId.portalContainer]\n                : parent.__ngt_renderer__[NgtRendererClassId.parent];\n        }\n\n        return parent;\n    }\n\n    getClosestParentWithCompound(node: NgtRendererNode) {\n        if (node.__ngt_renderer__[NgtRendererClassId.compoundParent]) {\n            return node.__ngt_renderer__[NgtRendererClassId.compoundParent];\n        }\n\n        let parent = node.__ngt_renderer__[NgtRendererClassId.parent];\n        if (\n            parent &&\n            parent.__ngt_renderer__[NgtRendererClassId.type] === 'compound' &&\n            !parent.__ngt_renderer__[NgtRendererClassId.compounded]\n        ) {\n            return parent;\n        }\n\n        while (\n            parent &&\n            (parent.__ngt_renderer__[NgtRendererClassId.type] === 'three' ||\n                !parent.__ngt_renderer__[NgtRendererClassId.compoundParent] ||\n                parent.__ngt_renderer__[NgtRendererClassId.type] !== 'compound')\n        ) {\n            parent = parent.__ngt_renderer__[NgtRendererClassId.parent];\n        }\n\n        if (!parent) return;\n\n        if (\n            parent.__ngt_renderer__[NgtRendererClassId.type] === 'three' &&\n            parent.__ngt_renderer__[NgtRendererClassId.compoundParent]\n        ) {\n            return parent.__ngt_renderer__[NgtRendererClassId.compoundParent];\n        }\n\n        if (!parent.__ngt_renderer__[NgtRendererClassId.compounded]) {\n            return parent;\n        }\n\n        return null;\n    }\n\n    getCreationState() {\n        const injectedArgs = this.firstNonInjectedDirective(NgtArgs)?.args || [];\n        const store = this.tryGetPortalStore();\n        return { injectedArgs, store };\n    }\n\n    destroy(node: NgtRendererNode, parent?: NgtRendererNode) {\n        const state = node.__ngt_renderer__;\n        if (state[NgtRendererClassId.destroyed]) return;\n        if (state[NgtRendererClassId.type] === 'three') {\n            state[NgtRendererClassId.compound] = undefined!;\n            state[NgtRendererClassId.compoundParent] = undefined!;\n\n            const localState = getLocalState(node);\n            if (localState.objects) {\n                localState.objects.value.forEach((obj) => this.destroy(obj, parent));\n                localState.objects.complete();\n            }\n\n            if (localState.nonObjects) {\n                localState.nonObjects.value.forEach((obj) => this.destroy(obj, parent));\n                localState.nonObjects.complete();\n            }\n\n            if (localState.afterUpdate) localState.afterUpdate.complete();\n            if (localState.afterAttach) localState.afterAttach.complete();\n\n            delete (localState as NgtAnyRecord)['objects'];\n            delete (localState as NgtAnyRecord)['nonObjects'];\n            delete (localState as NgtAnyRecord)['add'];\n            delete (localState as NgtAnyRecord)['remove'];\n            delete (localState as NgtAnyRecord)['afterUpdate'];\n            delete (localState as NgtAnyRecord)['afterAttach'];\n            delete (localState as NgtAnyRecord)['store'];\n            delete (localState as NgtAnyRecord)['handlers'];\n\n            if (!localState.primitive) {\n                delete (node as NgtAnyRecord)['__ngt__'];\n            }\n        }\n\n        if (state[NgtRendererClassId.type] === 'comment') {\n            state[NgtRendererClassId.injectorFactory] = null!;\n            delete (node as NgtAnyRecord)['__ngt_renderer_add_comment__'];\n            const index = this.comments.findIndex((comment) => comment === node);\n            if (index > -1) {\n                this.comments.splice(index, 1);\n            }\n        }\n\n        if (state[NgtRendererClassId.type] === 'portal') {\n            state[NgtRendererClassId.injectorFactory] = null!;\n            const index = this.portals.findIndex((portal) => portal === node);\n            if (index > -1) {\n                this.portals.splice(index, 1);\n            }\n        }\n\n        if (state[NgtRendererClassId.type] === 'compound') {\n            state[NgtRendererClassId.compounded] = undefined!;\n            state[NgtRendererClassId.attributes] = null!;\n            state[NgtRendererClassId.properties] = null!;\n            this.executeOperation(node, 'cleanUp');\n            state[NgtRendererClassId.queueOps].clear();\n            state[NgtRendererClassId.queueOps] = null!;\n        }\n\n        if (state[NgtRendererClassId.ref]) {\n            // nullify ref\n            state[NgtRendererClassId.ref].nativeElement = null;\n            state[NgtRendererClassId.ref] = undefined!;\n        }\n\n        // nullify parent\n        state[NgtRendererClassId.parent] = null;\n        for (const renderChild of state[NgtRendererClassId.children] || []) {\n            if (renderChild.__ngt_renderer__[NgtRendererClassId.type] === 'three' && parent) {\n                removeThreeChild(parent, renderChild, true);\n            }\n            this.destroy(renderChild, parent);\n        }\n\n        state[NgtRendererClassId.children] = [];\n        state[NgtRendererClassId.destroyed] = true;\n        if (parent) {\n            this.removeChild(parent, node);\n        }\n    }\n\n    private firstNonInjectedDirective(dir: Type<NgtArgs>) {\n        let directive: NgtArgs | undefined;\n\n        let i = this.comments.length - 1;\n        while (i >= 0) {\n            const comment = this.comments[i];\n            if (comment.__ngt_renderer__[NgtRendererClassId.destroyed]) {\n                i--;\n                continue;\n            }\n            const injector = comment.__ngt_renderer__[NgtRendererClassId.injectorFactory]();\n            if (!injector) {\n                i--;\n                continue;\n            }\n            const instance = injector.get(dir, null);\n            if (instance && instance.validate()) {\n                directive = instance;\n                break;\n            }\n\n            i--;\n        }\n\n        return directive;\n    }\n\n    tryGetPortalStore() {\n        let store: NgtStore | undefined;\n        // we only care about the portal states because NgtStore only differs per Portal\n        let i = this.portals.length - 1;\n        while (i >= 0) {\n            // loop through the portal state backwards to find the closest NgtStore\n            const injector = this.portals[i].__ngt_renderer__[NgtRendererClassId.injectorFactory]();\n            if (!injector) {\n                i--;\n                continue;\n            }\n            const instance = injector.get(NgtStore, null);\n            if (instance) {\n                store = instance;\n                break;\n            }\n            i--;\n        }\n        return store || this.root.store;\n    }\n}\n"]}
356
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"state.js","sourceRoot":"","sources":["../../../../../../libs/angular-three/src/lib/renderer/state.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, getDebugNode, Injector, Type } from '@angular/core';\nimport { NgtArgs } from '../directives/args';\nimport { NgtStore } from '../stores/store';\nimport type { NgtAnyRecord } from '../types';\nimport { applyProps } from '../utils/apply-props';\nimport { getLocalState } from '../utils/instance';\nimport { is } from '../utils/is';\nimport { NgtCompoundClassId, NgtQueueOpClassId, NgtRendererClassId } from './enums';\nimport { attachThreeChild, removeThreeChild, SPECIAL_PROPERTIES } from './utils';\n\nexport type NgtRendererRootState = {\n    store: NgtStore;\n    cdr: ChangeDetectorRef;\n    compoundPrefixes: string[];\n};\n\nexport type NgtQueueOp = [type: 'op' | 'cleanUp', op: () => void, done?: true];\n\nexport type NgtRendererState = [\n    type: 'three' | 'compound' | 'portal' | 'comment' | 'dom',\n    parent: NgtRendererNode | null,\n    children: NgtRendererNode[],\n    destroyed: boolean,\n    compound: [applyFirst: boolean, props: Record<string, any>],\n    compoundParent: NgtRendererNode,\n    compounded: NgtRendererNode,\n    queueOps: Set<NgtQueueOp>,\n    attributes: Record<string, any>,\n    properties: Record<string, any>,\n    rawValue: any,\n    ref: any,\n    portalContainer: NgtRendererNode,\n    injectorFactory: () => Injector\n];\n\nexport type NgtRendererNode = {\n    __ngt_renderer__: NgtRendererState;\n};\n\nexport class NgtRendererStore {\n    private readonly comments = [] as Array<NgtRendererNode>;\n    private readonly portals = [] as Array<NgtRendererNode>;\n\n    constructor(private readonly root: NgtRendererRootState) {}\n\n    createNode(type: NgtRendererState[NgtRendererClassId.type], node: NgtAnyRecord) {\n        const state = [\n            type,\n            null,\n            [],\n            false,\n            undefined!,\n            undefined!,\n            undefined!,\n            undefined!,\n            undefined!,\n            undefined!,\n            undefined!,\n            undefined!,\n            undefined!,\n            undefined!,\n        ] as NgtRendererState;\n\n        const rendererNode = Object.assign(node, { __ngt_renderer__: state });\n\n        if (state[NgtRendererClassId.type] === 'comment') {\n            state[NgtRendererClassId.injectorFactory] = () => getDebugNode(rendererNode)!.injector;\n            // we attach an arrow function to the Comment node\n            // In our directives, we can call this function to then start tracking the RendererNode\n            rendererNode['__ngt_renderer_add_comment__'] = (portalNode?: NgtRendererNode) => {\n                if (portalNode && portalNode.__ngt_renderer__[NgtRendererClassId.type] === 'portal') {\n                    this.portals.push(portalNode);\n                } else {\n                    this.comments.push(rendererNode);\n                }\n            };\n            return rendererNode;\n        }\n\n        if (state[NgtRendererClassId.type] === 'portal') {\n            state[NgtRendererClassId.injectorFactory] = () => getDebugNode(rendererNode)!.injector;\n            return rendererNode;\n        }\n\n        if (state[NgtRendererClassId.type] === 'compound') {\n            state[NgtRendererClassId.queueOps] = new Set();\n            state[NgtRendererClassId.attributes] = {};\n            state[NgtRendererClassId.properties] = {};\n            return rendererNode;\n        }\n\n        return rendererNode;\n    }\n\n    setParent(node: NgtRendererNode, parent: NgtRendererNode) {\n        if (!node.__ngt_renderer__[NgtRendererClassId.parent]) {\n            node.__ngt_renderer__[NgtRendererClassId.parent] = parent;\n        }\n    }\n\n    addChild(node: NgtRendererNode, child: NgtRendererNode) {\n        if (!node.__ngt_renderer__[NgtRendererClassId.children].includes(child)) {\n            node.__ngt_renderer__[NgtRendererClassId.children].push(child);\n        }\n    }\n\n    removeChild(node: NgtRendererNode, child: NgtRendererNode) {\n        const index = node.__ngt_renderer__[NgtRendererClassId.children].findIndex((c) => child === c);\n        if (index >= 0) {\n            node.__ngt_renderer__[NgtRendererClassId.children].splice(index, 1);\n        }\n    }\n\n    setCompound(compound: NgtRendererNode, instance: NgtRendererNode) {\n        compound.__ngt_renderer__[NgtRendererClassId.compounded] = instance;\n        const attributes = Object.keys(compound.__ngt_renderer__[NgtRendererClassId.attributes]);\n        const properties = Object.keys(compound.__ngt_renderer__[NgtRendererClassId.properties]);\n\n        if (attributes.length) {\n            for (const key of attributes) {\n                this.applyAttribute(instance, key, compound.__ngt_renderer__[NgtRendererClassId.attributes][key]);\n            }\n        }\n        if (properties.length) {\n            for (const key of properties) {\n                this.applyProperty(instance, key, compound.__ngt_renderer__[NgtRendererClassId.properties][key]);\n            }\n        }\n\n        this.executeOperation(compound);\n    }\n\n    queueOperation(node: NgtRendererNode, op: NgtQueueOp) {\n        node.__ngt_renderer__[NgtRendererClassId.queueOps].add(op);\n    }\n\n    executeOperation(node: NgtRendererNode, type: NgtQueueOp[NgtQueueOpClassId.type] = 'op') {\n        if (node.__ngt_renderer__[NgtRendererClassId.queueOps]?.size) {\n            node.__ngt_renderer__[NgtRendererClassId.queueOps].forEach((op) => {\n                if (op[NgtQueueOpClassId.type] === type) {\n                    op[NgtQueueOpClassId.op]();\n                    node.__ngt_renderer__[NgtRendererClassId.queueOps].delete(op);\n                }\n            });\n        }\n    }\n\n    processPortalContainer(portal: NgtRendererNode) {\n        const injectorFactory = portal.__ngt_renderer__[NgtRendererClassId.injectorFactory];\n        const injector = injectorFactory?.();\n        if (!injector) return;\n\n        const portalStore = injector.get(NgtStore, null);\n        if (!portalStore) return;\n\n        const portalContainer = portalStore.get('scene');\n        if (!portalContainer) return;\n\n        portal.__ngt_renderer__[NgtRendererClassId.portalContainer] = this.createNode('three', portalContainer);\n    }\n\n    applyAttribute(node: NgtRendererNode, name: string, value: string) {\n        if (node.__ngt_renderer__[NgtRendererClassId.destroyed]) return;\n        if (name === SPECIAL_PROPERTIES.RENDER_PRIORITY) {\n            // priority needs to be set as an attribute string so that they can be set as early as possible\n            // we convert that string to a number. if it's invalid, 0\n            let priority = Number(value);\n            if (isNaN(priority)) {\n                priority = 0;\n                console.warn(`[NGT] \"priority\" is an invalid number, default to 0`);\n            }\n            getLocalState(node).priority = priority;\n        }\n\n        if (name === SPECIAL_PROPERTIES.COMPOUND) {\n            // we set the compound property on instance node now so we know that this instance is being compounded\n            node.__ngt_renderer__[NgtRendererClassId.compound] = [value === '' || value === 'first', {}];\n            return;\n        }\n\n        if (name === SPECIAL_PROPERTIES.ATTACH) {\n            // handle attach as tring\n            const paths = value.split('.');\n            if (paths.length) getLocalState(node).attach = paths;\n            return;\n        }\n\n        if (name === SPECIAL_PROPERTIES.VALUE) {\n            // TODO  the last time we tried this here, this didn't work\n\n            // coercion\n            let maybeCoerced: any = value;\n            if (maybeCoerced === '' || maybeCoerced === 'true' || maybeCoerced === 'false') {\n                maybeCoerced = maybeCoerced === 'true' || maybeCoerced === '';\n            } else if (!isNaN(Number(maybeCoerced))) {\n                maybeCoerced = Number(maybeCoerced);\n            }\n            node.__ngt_renderer__[NgtRendererClassId.rawValue] = maybeCoerced;\n            return;\n        }\n\n        applyProps(node, { [name]: value });\n    }\n\n    applyProperty(node: NgtRendererNode, name: string, value: any) {\n        if (node.__ngt_renderer__[NgtRendererClassId.destroyed]) return;\n        // setup [ref] here\n        // ref should never change\n        if (name === SPECIAL_PROPERTIES.REF && is.ref(value)) {\n            node.__ngt_renderer__[NgtRendererClassId.ref] = value;\n            value.nativeElement = node;\n            return;\n        }\n\n        const parent = getLocalState(node).parent || node.__ngt_renderer__[NgtRendererClassId.parent];\n\n        // rawValue\n        if (getLocalState(node).isRaw && name === SPECIAL_PROPERTIES.VALUE) {\n            node.__ngt_renderer__[NgtRendererClassId.rawValue] = value;\n            attachThreeChild(parent, node);\n            return;\n        }\n\n        // attach\n        if (name === SPECIAL_PROPERTIES.ATTACH) {\n            getLocalState(node).attach = Array.isArray(value) ? value.map((v) => v.toString()) : value;\n            attachThreeChild(parent, node);\n            return;\n        }\n\n        const compound = node.__ngt_renderer__[NgtRendererClassId.compound];\n        if (\n            compound?.[NgtCompoundClassId.props] &&\n            name in compound[NgtCompoundClassId.props] &&\n            !compound[NgtCompoundClassId.applyFirst]\n        ) {\n            value = compound[NgtCompoundClassId.props][name];\n        }\n        applyProps(node, { [name]: value });\n    }\n\n    isCompound(name: string) {\n        return this.root.compoundPrefixes.some((prefix) => name.startsWith(prefix));\n    }\n\n    get rootScene() {\n        return this.root.store.get('scene');\n    }\n\n    get rootCdr() {\n        return this.root.cdr;\n    }\n\n    getClosestParentWithInstance(node: NgtRendererNode): NgtRendererNode | null {\n        let parent = node.__ngt_renderer__[NgtRendererClassId.parent];\n        while (parent && parent.__ngt_renderer__[NgtRendererClassId.type] !== 'three') {\n            parent = parent.__ngt_renderer__[NgtRendererClassId.portalContainer]\n                ? parent.__ngt_renderer__[NgtRendererClassId.portalContainer]\n                : parent.__ngt_renderer__[NgtRendererClassId.parent];\n        }\n\n        return parent;\n    }\n\n    getClosestParentWithCompound(node: NgtRendererNode) {\n        if (node.__ngt_renderer__[NgtRendererClassId.compoundParent]) {\n            return node.__ngt_renderer__[NgtRendererClassId.compoundParent];\n        }\n\n        let parent = node.__ngt_renderer__[NgtRendererClassId.parent];\n        if (\n            parent &&\n            parent.__ngt_renderer__[NgtRendererClassId.type] === 'compound' &&\n            !parent.__ngt_renderer__[NgtRendererClassId.compounded]\n        ) {\n            return parent;\n        }\n\n        while (\n            parent &&\n            (parent.__ngt_renderer__[NgtRendererClassId.type] === 'three' ||\n                !parent.__ngt_renderer__[NgtRendererClassId.compoundParent] ||\n                parent.__ngt_renderer__[NgtRendererClassId.type] !== 'compound')\n        ) {\n            parent = parent.__ngt_renderer__[NgtRendererClassId.parent];\n        }\n\n        if (!parent) return;\n\n        if (\n            parent.__ngt_renderer__[NgtRendererClassId.type] === 'three' &&\n            parent.__ngt_renderer__[NgtRendererClassId.compoundParent]\n        ) {\n            return parent.__ngt_renderer__[NgtRendererClassId.compoundParent];\n        }\n\n        if (!parent.__ngt_renderer__[NgtRendererClassId.compounded]) {\n            return parent;\n        }\n\n        return null;\n    }\n\n    getCreationState() {\n        const injectedArgs = this.firstNonInjectedDirective(NgtArgs)?.args || [];\n        const store = this.tryGetPortalStore();\n        return { injectedArgs, store };\n    }\n\n    destroy(node: NgtRendererNode, parent?: NgtRendererNode) {\n        const state = node.__ngt_renderer__;\n        if (state[NgtRendererClassId.destroyed]) return;\n        if (state[NgtRendererClassId.type] === 'three') {\n            state[NgtRendererClassId.compound] = undefined!;\n            state[NgtRendererClassId.compoundParent] = undefined!;\n\n            const localState = getLocalState(node);\n            if (localState.objects) {\n                localState.objects.value.forEach((obj) => this.destroy(obj, parent));\n                localState.objects.complete();\n            }\n\n            if (localState.nonObjects) {\n                localState.nonObjects.value.forEach((obj) => this.destroy(obj, parent));\n                localState.nonObjects.complete();\n            }\n\n            if (localState.afterUpdate) localState.afterUpdate.complete();\n            if (localState.afterAttach) localState.afterAttach.complete();\n\n            delete (localState as NgtAnyRecord)['objects'];\n            delete (localState as NgtAnyRecord)['nonObjects'];\n            delete (localState as NgtAnyRecord)['add'];\n            delete (localState as NgtAnyRecord)['remove'];\n            delete (localState as NgtAnyRecord)['afterUpdate'];\n            delete (localState as NgtAnyRecord)['afterAttach'];\n            delete (localState as NgtAnyRecord)['store'];\n            delete (localState as NgtAnyRecord)['handlers'];\n\n            if (!localState.primitive) {\n                delete (node as NgtAnyRecord)['__ngt__'];\n            }\n        }\n\n        if (state[NgtRendererClassId.type] === 'comment') {\n            state[NgtRendererClassId.injectorFactory] = null!;\n            delete (node as NgtAnyRecord)['__ngt_renderer_add_comment__'];\n            const index = this.comments.findIndex((comment) => comment === node);\n            if (index > -1) {\n                this.comments.splice(index, 1);\n            }\n        }\n\n        if (state[NgtRendererClassId.type] === 'portal') {\n            state[NgtRendererClassId.injectorFactory] = null!;\n            const index = this.portals.findIndex((portal) => portal === node);\n            if (index > -1) {\n                this.portals.splice(index, 1);\n            }\n        }\n\n        if (state[NgtRendererClassId.type] === 'compound') {\n            state[NgtRendererClassId.compounded] = undefined!;\n            state[NgtRendererClassId.attributes] = null!;\n            state[NgtRendererClassId.properties] = null!;\n            this.executeOperation(node, 'cleanUp');\n            state[NgtRendererClassId.queueOps].clear();\n            state[NgtRendererClassId.queueOps] = null!;\n        }\n\n        if (state[NgtRendererClassId.ref]) {\n            // nullify ref\n            state[NgtRendererClassId.ref].nativeElement = null;\n            state[NgtRendererClassId.ref] = undefined!;\n        }\n\n        // nullify parent\n        state[NgtRendererClassId.parent] = null;\n        for (const renderChild of state[NgtRendererClassId.children] || []) {\n            if (renderChild.__ngt_renderer__[NgtRendererClassId.type] === 'three' && parent) {\n                removeThreeChild(parent, renderChild, true);\n            }\n            this.destroy(renderChild, parent);\n        }\n\n        state[NgtRendererClassId.children] = [];\n        state[NgtRendererClassId.destroyed] = true;\n        if (parent) {\n            this.removeChild(parent, node);\n        }\n    }\n\n    private firstNonInjectedDirective(dir: Type<NgtArgs>) {\n        let directive: NgtArgs | undefined;\n\n        let i = this.comments.length - 1;\n        while (i >= 0) {\n            const comment = this.comments[i];\n            if (comment.__ngt_renderer__[NgtRendererClassId.destroyed]) {\n                i--;\n                continue;\n            }\n            const injector = comment.__ngt_renderer__[NgtRendererClassId.injectorFactory]();\n            if (!injector) {\n                i--;\n                continue;\n            }\n            const instance = injector.get(dir, null);\n            if (instance && instance.validate()) {\n                directive = instance;\n                break;\n            }\n\n            i--;\n        }\n\n        return directive;\n    }\n\n    tryGetPortalStore() {\n        let store: NgtStore | undefined;\n        // we only care about the portal states because NgtStore only differs per Portal\n        let i = this.portals.length - 1;\n        while (i >= 0) {\n            // loop through the portal state backwards to find the closest NgtStore\n            const injector = this.portals[i].__ngt_renderer__[NgtRendererClassId.injectorFactory]();\n            if (!injector) {\n                i--;\n                continue;\n            }\n            const instance = injector.get(NgtStore, null);\n            // only the instance with previousStore should pass\n            if (instance && instance.get('previousStore')) {\n                store = instance;\n                break;\n            }\n            i--;\n        }\n        return store || this.root.store;\n    }\n}\n"]}