angular-three 2.0.0-beta.21 → 2.0.0-beta.223
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 +4 -11
- package/esm2022/lib/canvas.mjs +81 -156
- package/esm2022/lib/directives/args.mjs +6 -6
- package/esm2022/lib/directives/common.mjs +15 -14
- package/esm2022/lib/directives/parent.mjs +6 -6
- package/esm2022/lib/dom/events.mjs +2 -2
- package/esm2022/lib/events.mjs +28 -25
- package/esm2022/lib/instance.mjs +39 -34
- package/esm2022/lib/loader.mjs +12 -14
- package/esm2022/lib/loop.mjs +9 -10
- package/esm2022/lib/portal.mjs +122 -135
- package/esm2022/lib/ref.mjs +18 -20
- package/esm2022/lib/renderer/catalogue.mjs +2 -2
- package/esm2022/lib/renderer/constants.mjs +2 -2
- package/esm2022/lib/renderer/index.mjs +58 -62
- package/esm2022/lib/renderer/store.mjs +129 -120
- package/esm2022/lib/renderer/utils.mjs +35 -42
- package/esm2022/lib/roots.mjs +41 -38
- package/esm2022/lib/routed-scene.mjs +6 -7
- package/esm2022/lib/store.mjs +163 -189
- package/esm2022/lib/utils/apply-props.mjs +12 -17
- package/esm2022/lib/utils/attach.mjs +6 -6
- package/esm2022/lib/utils/before-render.mjs +12 -0
- package/esm2022/lib/utils/cd-aware-signal.mjs +24 -0
- package/esm2022/lib/utils/create-api-token.mjs +13 -0
- package/esm2022/lib/utils/is.mjs +6 -5
- package/esm2022/lib/utils/make.mjs +15 -12
- package/esm2022/lib/utils/signal-store.mjs +67 -57
- package/esm2022/lib/utils/update.mjs +3 -2
- package/fesm2022/angular-three.mjs +1621 -1795
- package/fesm2022/angular-three.mjs.map +1 -1
- package/index.d.ts +6 -10
- package/lib/canvas.d.ts +24 -37
- package/lib/directives/common.d.ts +12 -1
- package/lib/events.d.ts +2 -2
- package/lib/instance.d.ts +19 -10
- package/lib/loader.d.ts +13 -4
- package/lib/loop.d.ts +6 -29
- package/lib/portal.d.ts +18 -26
- package/lib/ref.d.ts +0 -1
- package/lib/renderer/catalogue.d.ts +5 -1
- package/lib/renderer/constants.d.ts +1 -1
- package/lib/renderer/index.d.ts +55 -4
- package/lib/renderer/store.d.ts +18 -21
- package/lib/renderer/utils.d.ts +2 -3
- package/lib/roots.d.ts +4 -3
- package/lib/store.d.ts +9 -11
- package/lib/utils/apply-props.d.ts +0 -1
- package/lib/{before-render.d.ts → utils/before-render.d.ts} +1 -1
- package/lib/utils/cd-aware-signal.d.ts +4 -0
- package/lib/utils/create-api-token.d.ts +23 -0
- package/lib/utils/is.d.ts +11 -12
- package/lib/utils/make.d.ts +3 -2
- package/lib/utils/signal-store.d.ts +16 -3
- package/metadata.json +1 -1
- package/package.json +30 -11
- package/plugin/generators.json +0 -32
- package/plugin/src/generators/init/compat.d.ts +1 -3
- package/plugin/src/generators/init/files/experience/{experience.component.ts.__tmpl__ → experience.component.ts__tmpl__} +1 -0
- package/plugin/src/generators/init/generator.d.ts +2 -5
- package/plugin/src/generators/init/generator.js +94 -95
- package/plugin/src/generators/init/generator.js.map +1 -1
- package/plugin/src/generators/init/schema.json +1 -12
- package/plugin/src/generators/utils.js.map +1 -1
- package/plugin/src/generators/{versions.d.ts → version.d.ts} +5 -3
- package/plugin/src/generators/version.js +18 -0
- package/plugin/src/generators/version.js.map +1 -0
- package/plugin/src/index.d.ts +0 -3
- package/plugin/src/index.js +0 -9
- package/plugin/src/index.js.map +1 -1
- package/web-types.json +1 -1
- package/esm2022/lib/before-render.mjs +0 -13
- package/esm2022/lib/directives/key.mjs +0 -29
- package/esm2022/lib/directives/repeat.mjs +0 -17
- package/esm2022/lib/three-types.mjs +0 -2
- package/esm2022/lib/utils/assert-injection-context.mjs +0 -14
- package/esm2022/lib/utils/create-injection-token.mjs +0 -47
- package/esm2022/lib/utils/safe-detect-changes.mjs +0 -17
- package/lib/directives/key.d.ts +0 -10
- package/lib/directives/repeat.d.ts +0 -7
- package/lib/three-types.d.ts +0 -306
- package/lib/utils/assert-injection-context.d.ts +0 -2
- package/lib/utils/create-injection-token.d.ts +0 -27
- package/lib/utils/safe-detect-changes.d.ts +0 -2
- package/plugin/package.json +0 -6
- package/plugin/src/generators/init-cannon/compat.d.ts +0 -2
- package/plugin/src/generators/init-cannon/compat.js +0 -6
- package/plugin/src/generators/init-cannon/compat.js.map +0 -1
- package/plugin/src/generators/init-cannon/generator.d.ts +0 -2
- package/plugin/src/generators/init-cannon/generator.js +0 -22
- package/plugin/src/generators/init-cannon/generator.js.map +0 -1
- package/plugin/src/generators/init-cannon/schema.json +0 -6
- package/plugin/src/generators/init-postprocessing/compat.d.ts +0 -2
- package/plugin/src/generators/init-postprocessing/compat.js +0 -6
- package/plugin/src/generators/init-postprocessing/compat.js.map +0 -1
- package/plugin/src/generators/init-postprocessing/generator.d.ts +0 -2
- package/plugin/src/generators/init-postprocessing/generator.js +0 -20
- package/plugin/src/generators/init-postprocessing/generator.js.map +0 -1
- package/plugin/src/generators/init-postprocessing/schema.json +0 -6
- package/plugin/src/generators/init-soba/compat.d.ts +0 -2
- package/plugin/src/generators/init-soba/compat.js +0 -6
- package/plugin/src/generators/init-soba/compat.js.map +0 -1
- package/plugin/src/generators/init-soba/generator.d.ts +0 -2
- package/plugin/src/generators/init-soba/generator.js +0 -26
- package/plugin/src/generators/init-soba/generator.js.map +0 -1
- package/plugin/src/generators/init-soba/schema.json +0 -6
- package/plugin/src/generators/versions.js +0 -16
- package/plugin/src/generators/versions.js.map +0 -1
- /package/plugin/src/generators/init/files/experience/{experience.component.html.__tmpl__ → experience.component.html__tmpl__} +0 -0
package/esm2022/lib/portal.mjs
CHANGED
|
@@ -1,13 +1,13 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
1
|
+
import { afterNextRender, ChangeDetectionStrategy, Component, computed, ContentChild, CUSTOM_ELEMENTS_SCHEMA, DestroyRef, Directive, ElementRef, inject, Injector, Input, signal, SkipSelf, TemplateRef, untracked, ViewChild, ViewContainerRef, } from '@angular/core';
|
|
2
|
+
import { injectAutoEffect } from 'ngxtension/auto-effect';
|
|
3
|
+
import { createInjectionToken } from 'ngxtension/create-injection-token';
|
|
3
4
|
import * as THREE from 'three';
|
|
4
|
-
import {
|
|
5
|
-
import { getLocalState, prepare } from './instance';
|
|
5
|
+
import { prepare } from './instance';
|
|
6
6
|
import { injectNgtRef } from './ref';
|
|
7
7
|
import { SPECIAL_INTERNAL_ADD_COMMENT } from './renderer/constants';
|
|
8
|
-
import {
|
|
8
|
+
import { injectNgtStore, NGT_STORE } from './store';
|
|
9
|
+
import { injectBeforeRender } from './utils/before-render';
|
|
9
10
|
import { is } from './utils/is';
|
|
10
|
-
import { safeDetectChanges } from './utils/safe-detect-changes';
|
|
11
11
|
import { signalStore } from './utils/signal-store';
|
|
12
12
|
import { updateCamera } from './utils/update';
|
|
13
13
|
import * as i0 from "@angular/core";
|
|
@@ -24,39 +24,66 @@ const privateKeys = [
|
|
|
24
24
|
'size',
|
|
25
25
|
'viewport',
|
|
26
26
|
];
|
|
27
|
+
const [, providePortalStore] = createInjectionToken((parentStore) => {
|
|
28
|
+
const parentState = parentStore.snapshot;
|
|
29
|
+
const pointer = new THREE.Vector2();
|
|
30
|
+
const raycaster = new THREE.Raycaster();
|
|
31
|
+
return signalStore(({ update }) => {
|
|
32
|
+
return {
|
|
33
|
+
...parentState,
|
|
34
|
+
pointer,
|
|
35
|
+
raycaster,
|
|
36
|
+
previousRoot: parentStore,
|
|
37
|
+
// Layers are allowed to override events
|
|
38
|
+
setEvents: (events) => update((state) => ({ ...state, events: { ...state.events, ...events } })),
|
|
39
|
+
};
|
|
40
|
+
});
|
|
41
|
+
}, { isRoot: false, token: NGT_STORE, deps: [[new SkipSelf(), NGT_STORE]] });
|
|
27
42
|
export class NgtPortalBeforeRender {
|
|
28
43
|
constructor() {
|
|
29
44
|
this.portalStore = injectNgtStore();
|
|
30
45
|
this.injector = inject(Injector);
|
|
31
46
|
this.renderPriority = 1;
|
|
32
|
-
|
|
47
|
+
afterNextRender(() => {
|
|
48
|
+
let oldClear;
|
|
49
|
+
injectBeforeRender(() => {
|
|
50
|
+
const { gl, scene, camera } = this.portalStore.get();
|
|
51
|
+
oldClear = gl.autoClear;
|
|
52
|
+
if (this.renderPriority === 1) {
|
|
53
|
+
// clear scene and render with default
|
|
54
|
+
gl.autoClear = true;
|
|
55
|
+
gl.render(this.parentScene, this.parentCamera);
|
|
56
|
+
}
|
|
57
|
+
// disable cleaning
|
|
58
|
+
gl.autoClear = false;
|
|
59
|
+
gl.clearDepth();
|
|
60
|
+
gl.render(scene, camera);
|
|
61
|
+
// restore
|
|
62
|
+
gl.autoClear = oldClear;
|
|
63
|
+
}, { priority: this.renderPriority, injector: this.injector });
|
|
64
|
+
});
|
|
33
65
|
}
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
injectBeforeRender(({ 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
|
-
}, { priority: this.renderPriority, injector: this.injector });
|
|
66
|
+
onPointerOver() {
|
|
67
|
+
/* noop */
|
|
52
68
|
}
|
|
53
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
54
|
-
static { this.ɵ
|
|
69
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type: NgtPortalBeforeRender, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
70
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.1", type: NgtPortalBeforeRender, isStandalone: true, selector: "ngt-portal-before-render", inputs: { renderPriority: "renderPriority", parentScene: "parentScene", parentCamera: "parentCamera" }, ngImport: i0, template: `
|
|
71
|
+
<!-- Without an element that receives pointer events state.pointer will always be 0/0 -->
|
|
72
|
+
<ngt-group (pointerover)="onPointerOver()" attach="none" />
|
|
73
|
+
`, isInline: true }); }
|
|
55
74
|
}
|
|
56
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
57
|
-
type:
|
|
58
|
-
args: [{
|
|
59
|
-
|
|
75
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type: NgtPortalBeforeRender, decorators: [{
|
|
76
|
+
type: Component,
|
|
77
|
+
args: [{
|
|
78
|
+
selector: 'ngt-portal-before-render',
|
|
79
|
+
standalone: true,
|
|
80
|
+
template: `
|
|
81
|
+
<!-- Without an element that receives pointer events state.pointer will always be 0/0 -->
|
|
82
|
+
<ngt-group (pointerover)="onPointerOver()" attach="none" />
|
|
83
|
+
`,
|
|
84
|
+
schemas: [CUSTOM_ELEMENTS_SCHEMA],
|
|
85
|
+
}]
|
|
86
|
+
}], ctorParameters: () => [], propDecorators: { renderPriority: [{
|
|
60
87
|
type: Input
|
|
61
88
|
}], parentScene: [{
|
|
62
89
|
type: Input,
|
|
@@ -64,8 +91,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.2", ngImpor
|
|
|
64
91
|
}], parentCamera: [{
|
|
65
92
|
type: Input,
|
|
66
93
|
args: [{ required: true }]
|
|
67
|
-
}], beforeRender: [{
|
|
68
|
-
type: Output
|
|
69
94
|
}] } });
|
|
70
95
|
export class NgtPortalContent {
|
|
71
96
|
constructor(vcr, parentVcr) {
|
|
@@ -75,87 +100,55 @@ export class NgtPortalContent {
|
|
|
75
100
|
delete commentNode[SPECIAL_INTERNAL_ADD_COMMENT];
|
|
76
101
|
}
|
|
77
102
|
}
|
|
78
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
79
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "
|
|
103
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type: NgtPortalContent, deps: [{ token: i0.ViewContainerRef }, { token: i0.ViewContainerRef, skipSelf: true }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
104
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.2.1", type: NgtPortalContent, isStandalone: true, selector: "ng-template[ngtPortalContent]", ngImport: i0 }); }
|
|
80
105
|
}
|
|
81
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
106
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type: NgtPortalContent, decorators: [{
|
|
82
107
|
type: Directive,
|
|
83
108
|
args: [{ selector: 'ng-template[ngtPortalContent]', standalone: true }]
|
|
84
|
-
}], ctorParameters:
|
|
109
|
+
}], ctorParameters: () => [{ type: i0.ViewContainerRef }, { type: i0.ViewContainerRef, decorators: [{
|
|
85
110
|
type: SkipSelf
|
|
86
|
-
}] }]
|
|
111
|
+
}] }] });
|
|
87
112
|
export class NgtPortal {
|
|
88
|
-
set
|
|
89
|
-
this.
|
|
113
|
+
set _portalInputs(value) {
|
|
114
|
+
this.portalInputs.update(value);
|
|
90
115
|
}
|
|
91
|
-
set
|
|
92
|
-
this.
|
|
116
|
+
set _autoRender(value) {
|
|
117
|
+
this.autoRender.set(value);
|
|
93
118
|
}
|
|
94
119
|
constructor() {
|
|
95
|
-
this.
|
|
96
|
-
|
|
120
|
+
this.portalInputs = signalStore({
|
|
121
|
+
container: injectNgtRef(prepare(new THREE.Scene())),
|
|
122
|
+
});
|
|
123
|
+
this.autoRender = signal(false);
|
|
97
124
|
this.autoRenderPriority = 1;
|
|
98
|
-
this.
|
|
125
|
+
this.destroyRef = inject(DestroyRef);
|
|
126
|
+
this.autoEffect = injectAutoEffect();
|
|
99
127
|
this.parentStore = injectNgtStore({ skipSelf: true });
|
|
128
|
+
this.portalStore = injectNgtStore({ self: true });
|
|
129
|
+
this.portalRendered = signal(false);
|
|
130
|
+
this.renderAutoBeforeRender = computed(() => this.portalRendered() && this.autoRender());
|
|
100
131
|
this.parentScene = this.parentStore.get('scene');
|
|
101
132
|
this.parentCamera = this.parentStore.get('camera');
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
this.portalContentView.destroy();
|
|
111
|
-
}
|
|
112
|
-
});
|
|
113
|
-
}
|
|
114
|
-
ngOnInit() {
|
|
115
|
-
const previousState = this.parentStore.get();
|
|
116
|
-
const inputsState = this.inputs.get();
|
|
117
|
-
if (!inputsState.state && this.autoRender) {
|
|
118
|
-
inputsState.state = { events: { priority: this.autoRenderPriority + 1 } };
|
|
119
|
-
}
|
|
120
|
-
const { events, size, ...restInputsState } = inputsState.state || {};
|
|
121
|
-
const containerState = inputsState.container;
|
|
122
|
-
let container = is.ref(containerState) ? containerState.nativeElement : containerState;
|
|
123
|
-
if (!is.instance(container)) {
|
|
124
|
-
container = prepare(container);
|
|
125
|
-
}
|
|
126
|
-
const localState = getLocalState(container);
|
|
127
|
-
if (!localState.store) {
|
|
128
|
-
localState.store = this.portalStore;
|
|
129
|
-
}
|
|
130
|
-
this.portalStore.set({
|
|
131
|
-
...previousState,
|
|
132
|
-
scene: container,
|
|
133
|
-
raycaster: this.raycaster,
|
|
134
|
-
pointer: this.pointer,
|
|
135
|
-
previousRoot: this.parentStore,
|
|
136
|
-
events: { ...previousState.events, ...(events || {}) },
|
|
137
|
-
size: { ...previousState.size, ...(size || {}) },
|
|
138
|
-
...restInputsState,
|
|
139
|
-
setEvents: (events) => this.portalStore.set((state) => ({ ...state, events: { ...state.events, ...events } })),
|
|
140
|
-
});
|
|
141
|
-
const parentState = this.parentStore.select();
|
|
142
|
-
effect(() => {
|
|
143
|
-
const previous = parentState();
|
|
144
|
-
this.zone.runOutsideAngular(() => {
|
|
145
|
-
this.portalStore.set((state) => this.inject(previous, state));
|
|
133
|
+
afterNextRender(() => {
|
|
134
|
+
const parentState = this.parentStore.snapshot;
|
|
135
|
+
const { container, state: { events = {}, size = {}, ...rest }, } = this.portalInputs.snapshot;
|
|
136
|
+
this.portalStore.update({
|
|
137
|
+
scene: (is.ref(container) ? container.nativeElement : container),
|
|
138
|
+
events: { ...parentState.events, ...events },
|
|
139
|
+
size: { ...parentState.size, ...size },
|
|
140
|
+
...rest,
|
|
146
141
|
});
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
root: { ...this.parentStore.get(), delta: portal.delta, frame: portal.frame },
|
|
158
|
-
portal,
|
|
142
|
+
this.autoEffect(() => {
|
|
143
|
+
const previous = this.parentStore.state();
|
|
144
|
+
this.portalStore.update((state) => this.inject(previous, state));
|
|
145
|
+
});
|
|
146
|
+
untracked(() => {
|
|
147
|
+
const portalView = this.portalContentAnchor.createEmbeddedView(this.portalContentTemplate);
|
|
148
|
+
portalView.detectChanges();
|
|
149
|
+
this.destroyRef.onDestroy(portalView.destroy.bind(portalView));
|
|
150
|
+
});
|
|
151
|
+
this.portalRendered.set(true);
|
|
159
152
|
});
|
|
160
153
|
}
|
|
161
154
|
inject(rootState, injectState) {
|
|
@@ -166,7 +159,7 @@ export class NgtPortal {
|
|
|
166
159
|
delete intersect[key];
|
|
167
160
|
}
|
|
168
161
|
});
|
|
169
|
-
const inputs = this.
|
|
162
|
+
const inputs = this.portalInputs.snapshot;
|
|
170
163
|
const { size, events, ...restInputsState } = inputs.state || {};
|
|
171
164
|
let viewport = undefined;
|
|
172
165
|
if (injectState && size) {
|
|
@@ -178,8 +171,6 @@ export class NgtPortal {
|
|
|
178
171
|
return {
|
|
179
172
|
...intersect,
|
|
180
173
|
scene: is.ref(inputs.container) ? inputs.container.nativeElement : inputs.container,
|
|
181
|
-
raycaster: this.raycaster,
|
|
182
|
-
pointer: this.pointer,
|
|
183
174
|
previousRoot: this.parentStore,
|
|
184
175
|
events: { ...rootState.events, ...(injectState?.events || {}), ...events },
|
|
185
176
|
size: { ...rootState.size, ...size },
|
|
@@ -187,51 +178,47 @@ export class NgtPortal {
|
|
|
187
178
|
...restInputsState,
|
|
188
179
|
};
|
|
189
180
|
}
|
|
190
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
191
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "
|
|
181
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type: NgtPortal, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
182
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.2.1", type: NgtPortal, isStandalone: true, selector: "ngt-portal", inputs: { _portalInputs: ["options", "_portalInputs"], _autoRender: ["autoRender", "_autoRender"], autoRenderPriority: "autoRenderPriority" }, providers: [providePortalStore()], 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 }], ngImport: i0, template: `
|
|
192
183
|
<ng-container #portalContentAnchor>
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
/>
|
|
184
|
+
@if (renderAutoBeforeRender()) {
|
|
185
|
+
<ngt-portal-before-render
|
|
186
|
+
[renderPriority]="autoRenderPriority"
|
|
187
|
+
[parentScene]="parentScene"
|
|
188
|
+
[parentCamera]="parentCamera"
|
|
189
|
+
/>
|
|
190
|
+
}
|
|
201
191
|
</ng-container>
|
|
202
|
-
`, isInline: true, dependencies: [{ kind: "
|
|
192
|
+
`, isInline: true, dependencies: [{ kind: "component", type: NgtPortalBeforeRender, selector: "ngt-portal-before-render", inputs: ["renderPriority", "parentScene", "parentCamera"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
203
193
|
}
|
|
204
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
194
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type: NgtPortal, decorators: [{
|
|
205
195
|
type: Component,
|
|
206
196
|
args: [{
|
|
207
197
|
selector: 'ngt-portal',
|
|
208
198
|
standalone: true,
|
|
209
199
|
template: `
|
|
210
200
|
<ng-container #portalContentAnchor>
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
/>
|
|
201
|
+
@if (renderAutoBeforeRender()) {
|
|
202
|
+
<ngt-portal-before-render
|
|
203
|
+
[renderPriority]="autoRenderPriority"
|
|
204
|
+
[parentScene]="parentScene"
|
|
205
|
+
[parentCamera]="parentCamera"
|
|
206
|
+
/>
|
|
207
|
+
}
|
|
219
208
|
</ng-container>
|
|
220
209
|
`,
|
|
221
|
-
imports: [
|
|
222
|
-
providers: [
|
|
210
|
+
imports: [NgtPortalBeforeRender],
|
|
211
|
+
providers: [providePortalStore()],
|
|
212
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
223
213
|
}]
|
|
224
|
-
}], ctorParameters:
|
|
225
|
-
type: Input
|
|
226
|
-
}], portalState: [{
|
|
214
|
+
}], ctorParameters: () => [], propDecorators: { _portalInputs: [{
|
|
227
215
|
type: Input,
|
|
228
|
-
args: ['
|
|
229
|
-
}],
|
|
230
|
-
type: Input
|
|
216
|
+
args: [{ alias: 'options' }]
|
|
217
|
+
}], _autoRender: [{
|
|
218
|
+
type: Input,
|
|
219
|
+
args: [{ alias: 'autoRender' }]
|
|
231
220
|
}], autoRenderPriority: [{
|
|
232
221
|
type: Input
|
|
233
|
-
}], beforeRender: [{
|
|
234
|
-
type: Output
|
|
235
222
|
}], portalContentTemplate: [{
|
|
236
223
|
type: ContentChild,
|
|
237
224
|
args: [NgtPortalContent, { read: TemplateRef, static: true }]
|
|
@@ -239,4 +226,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.2", ngImpor
|
|
|
239
226
|
type: ViewChild,
|
|
240
227
|
args: ['portalContentAnchor', { read: ViewContainerRef, static: true }]
|
|
241
228
|
}] } });
|
|
242
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"portal.js","sourceRoot":"","sources":["../../../../../libs/core/src/lib/portal.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgIf } from '@angular/common';\nimport {\n\tComponent,\n\tContentChild,\n\tDestroyRef,\n\tDirective,\n\tEventEmitter,\n\tInjector,\n\tInput,\n\tNgZone,\n\tOutput,\n\tSkipSelf,\n\tTemplateRef,\n\tViewChild,\n\tViewContainerRef,\n\teffect,\n\tinject,\n\ttype ElementRef,\n\ttype EmbeddedViewRef,\n\ttype OnInit,\n} from '@angular/core';\nimport * as THREE from 'three';\nimport { injectBeforeRender } from './before-render';\nimport type { NgtEventManager } from './events';\nimport { getLocalState, prepare } from './instance';\nimport { injectNgtRef } from './ref';\nimport { SPECIAL_INTERNAL_ADD_COMMENT } from './renderer/constants';\nimport { NGT_STORE, injectNgtStore, type NgtRenderState, type NgtSize, type NgtState } from './store';\nimport { is } from './utils/is';\nimport { safeDetectChanges } from './utils/safe-detect-changes';\nimport { signalStore } from './utils/signal-store';\nimport { updateCamera } from './utils/update';\n\nconst privateKeys = [\n\t'get',\n\t'set',\n\t'select',\n\t'setSize',\n\t'setDpr',\n\t'setFrameloop',\n\t'events',\n\t'invalidate',\n\t'advance',\n\t'size',\n\t'viewport',\n] as const;\ntype PrivateKeys = (typeof privateKeys)[number];\n\nexport interface NgtPortalInputs {\n\tcontainer: ElementRef<THREE.Object3D> | THREE.Object3D;\n\tcamera: ElementRef<THREE.Camera> | THREE.Camera;\n\tstate: Partial<\n\t\tOmit<NgtState, PrivateKeys> & {\n\t\t\tevents: Partial<Pick<NgtEventManager<any>, 'enabled' | 'priority' | 'compute' | 'connected'>>;\n\t\t\tsize: NgtSize;\n\t\t}\n\t>;\n}\n\n@Directive({ selector: '[ngtPortalBeforeRender]', standalone: true })\nexport class NgtPortalBeforeRender implements OnInit {\n\tprivate portalStore = injectNgtStore();\n\tprivate injector = inject(Injector);\n\n\t@Input() renderPriority = 1;\n\t@Input({ required: true }) parentScene!: THREE.Scene;\n\t@Input({ required: true }) parentCamera!: THREE.Camera;\n\n\t@Output() beforeRender = new EventEmitter<NgtRenderState>();\n\n\tngOnInit() {\n\t\tlet oldClear: boolean;\n\t\tinjectBeforeRender(\n\t\t\t({ delta, frame }) => {\n\t\t\t\tthis.beforeRender.emit({ ...this.portalStore.get(), delta, frame });\n\t\t\t\tconst { gl, scene, camera } = this.portalStore.get();\n\t\t\t\toldClear = gl.autoClear;\n\t\t\t\tif (this.renderPriority === 1) {\n\t\t\t\t\t// clear scene and render with default\n\t\t\t\t\tgl.autoClear = true;\n\t\t\t\t\tgl.render(this.parentScene, this.parentCamera);\n\t\t\t\t}\n\t\t\t\t// disable cleaning\n\t\t\t\tgl.autoClear = false;\n\t\t\t\tgl.clearDepth();\n\t\t\t\tgl.render(scene, camera);\n\t\t\t\t// restore\n\t\t\t\tgl.autoClear = oldClear;\n\t\t\t},\n\t\t\t{ priority: this.renderPriority, injector: this.injector },\n\t\t);\n\t}\n}\n\n@Directive({ selector: 'ng-template[ngtPortalContent]', standalone: true })\nexport class NgtPortalContent {\n\tconstructor(vcr: ViewContainerRef, @SkipSelf() parentVcr: ViewContainerRef) {\n\t\tconst commentNode = vcr.element.nativeElement;\n\t\tif (commentNode[SPECIAL_INTERNAL_ADD_COMMENT]) {\n\t\t\tcommentNode[SPECIAL_INTERNAL_ADD_COMMENT](parentVcr.element.nativeElement);\n\t\t\tdelete commentNode[SPECIAL_INTERNAL_ADD_COMMENT];\n\t\t}\n\t}\n}\n\n@Component({\n\tselector: 'ngt-portal',\n\tstandalone: true,\n\ttemplate: `\n\t\t<ng-container #portalContentAnchor>\n\t\t\t<ng-container\n\t\t\t\t*ngIf=\"autoRender && portalContentRendered\"\n\t\t\t\tngtPortalBeforeRender\n\t\t\t\t[renderPriority]=\"autoRenderPriority\"\n\t\t\t\t[parentScene]=\"parentScene\"\n\t\t\t\t[parentCamera]=\"parentCamera\"\n\t\t\t\t(beforeRender)=\"onBeforeRender($event)\"\n\t\t\t/>\n\t\t</ng-container>\n\t`,\n\timports: [NgIf, NgtPortalBeforeRender],\n\tproviders: [{ provide: NGT_STORE, useFactory: () => signalStore<NgtState>({}) }],\n})\nexport class NgtPortal implements OnInit {\n\tprivate inputs = signalStore<NgtPortalInputs>({ container: injectNgtRef<THREE.Scene>(prepare(new THREE.Scene())) });\n\n\t@Input() set container(container: NgtPortalInputs['container']) {\n\t\tthis.inputs.set({ container });\n\t}\n\n\t@Input('state') set portalState(state: NgtPortalInputs['state']) {\n\t\tthis.inputs.set({ state });\n\t}\n\n\t@Input() autoRender = true;\n\t@Input() autoRenderPriority = 1;\n\n\t@Output() beforeRender = new EventEmitter<{ root: NgtRenderState; portal: NgtRenderState }>();\n\n\t@ContentChild(NgtPortalContent, { read: TemplateRef, static: true })\n\tportalContentTemplate!: TemplateRef<unknown>;\n\n\t@ViewChild('portalContentAnchor', { read: ViewContainerRef, static: true })\n\tportalContentAnchor!: ViewContainerRef;\n\n\tprivate parentStore = injectNgtStore({ skipSelf: true });\n\tparentScene = this.parentStore.get('scene');\n\tparentCamera = this.parentStore.get('camera');\n\n\tprivate portalStore = injectNgtStore({ self: true });\n\tprivate injector = inject(Injector);\n\tprivate zone = inject(NgZone);\n\n\tprivate raycaster = new THREE.Raycaster();\n\tprivate pointer = new THREE.Vector2();\n\n\tportalContentRendered = false;\n\tprivate portalContentView?: EmbeddedViewRef<unknown>;\n\n\tconstructor() {\n\t\tinject(DestroyRef).onDestroy(() => {\n\t\t\tif (this.portalContentView && !this.portalContentView.destroyed) {\n\t\t\t\tthis.portalContentView.destroy();\n\t\t\t}\n\t\t});\n\t}\n\n\tngOnInit() {\n\t\tconst previousState = this.parentStore.get();\n\t\tconst inputsState = this.inputs.get();\n\n\t\tif (!inputsState.state && this.autoRender) {\n\t\t\tinputsState.state = { events: { priority: this.autoRenderPriority + 1 } };\n\t\t}\n\n\t\tconst { events, size, ...restInputsState } = inputsState.state || {};\n\n\t\tconst containerState = inputsState.container;\n\t\tlet container = is.ref(containerState) ? containerState.nativeElement : containerState;\n\n\t\tif (!is.instance(container)) {\n\t\t\tcontainer = prepare(container);\n\t\t}\n\n\t\tconst localState = getLocalState(container);\n\t\tif (!localState.store) {\n\t\t\tlocalState.store = this.portalStore;\n\t\t}\n\n\t\tthis.portalStore.set({\n\t\t\t...previousState,\n\t\t\tscene: container as THREE.Scene,\n\t\t\traycaster: this.raycaster,\n\t\t\tpointer: this.pointer,\n\t\t\tpreviousRoot: this.parentStore,\n\t\t\tevents: { ...previousState.events, ...(events || {}) },\n\t\t\tsize: { ...previousState.size, ...(size || {}) },\n\t\t\t...restInputsState,\n\t\t\tsetEvents: (events) =>\n\t\t\t\tthis.portalStore.set((state) => ({ ...state, events: { ...state.events, ...events } })),\n\t\t});\n\n\t\tconst parentState = this.parentStore.select();\n\t\teffect(\n\t\t\t() => {\n\t\t\t\tconst previous = parentState();\n\t\t\t\tthis.zone.runOutsideAngular(() => {\n\t\t\t\t\tthis.portalStore.set((state) => this.inject(previous, state));\n\t\t\t\t});\n\t\t\t},\n\t\t\t{ injector: this.injector },\n\t\t);\n\n\t\trequestAnimationFrame(() => {\n\t\t\tthis.portalStore.set((injectState) => this.inject(this.parentStore.get(), injectState));\n\t\t});\n\t\tthis.portalContentView = this.portalContentAnchor.createEmbeddedView(this.portalContentTemplate);\n\t\tsafeDetectChanges(this.portalContentView);\n\t\tthis.portalContentRendered = true;\n\t}\n\n\tonBeforeRender(portal: NgtRenderState) {\n\t\tthis.beforeRender.emit({\n\t\t\troot: { ...this.parentStore.get(), delta: portal.delta, frame: portal.frame },\n\t\t\tportal,\n\t\t});\n\t}\n\n\tprivate inject(rootState: NgtState, injectState: NgtState) {\n\t\tconst intersect: Partial<NgtState> = { ...rootState };\n\n\t\tObject.keys(intersect).forEach((key) => {\n\t\t\tif (\n\t\t\t\tprivateKeys.includes(key as PrivateKeys) ||\n\t\t\t\trootState[key as keyof NgtState] !== injectState[key as keyof NgtState]\n\t\t\t) {\n\t\t\t\tdelete intersect[key as keyof NgtState];\n\t\t\t}\n\t\t});\n\n\t\tconst inputs = this.inputs.get();\n\t\tconst { size, events, ...restInputsState } = inputs.state || {};\n\n\t\tlet viewport = undefined;\n\t\tif (injectState && size) {\n\t\t\tconst camera = injectState.camera;\n\t\t\tviewport = rootState.viewport.getCurrentViewport(camera, new THREE.Vector3(), size);\n\t\t\tif (camera !== rootState.camera) updateCamera(camera, size);\n\t\t}\n\n\t\treturn {\n\t\t\t...intersect,\n\t\t\tscene: is.ref(inputs.container) ? inputs.container.nativeElement : inputs.container,\n\t\t\traycaster: this.raycaster,\n\t\t\tpointer: this.pointer,\n\t\t\tpreviousRoot: this.parentStore,\n\t\t\tevents: { ...rootState.events, ...(injectState?.events || {}), ...events },\n\t\t\tsize: { ...rootState.size, ...size },\n\t\t\tviewport: { ...rootState.viewport, ...(viewport || {}) },\n\t\t\t...restInputsState,\n\t\t} as NgtState;\n\t}\n}\n"]}
|
|
229
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"portal.js","sourceRoot":"","sources":["../../../../../libs/core/src/lib/portal.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n\tafterNextRender,\n\tChangeDetectionStrategy,\n\tComponent,\n\tcomputed,\n\tContentChild,\n\tCUSTOM_ELEMENTS_SCHEMA,\n\tDestroyRef,\n\tDirective,\n\tElementRef,\n\tinject,\n\tInjector,\n\tInput,\n\tsignal,\n\tSkipSelf,\n\tTemplateRef,\n\tuntracked,\n\tViewChild,\n\tViewContainerRef,\n} from '@angular/core';\nimport { injectAutoEffect } from 'ngxtension/auto-effect';\nimport { createInjectionToken } from 'ngxtension/create-injection-token';\nimport * as THREE from 'three';\nimport type { NgtEventManager } from './events';\nimport { prepare } from './instance';\nimport { injectNgtRef } from './ref';\nimport { SPECIAL_INTERNAL_ADD_COMMENT } from './renderer/constants';\nimport { injectNgtStore, NGT_STORE, type NgtSize, type NgtState } from './store';\nimport { injectBeforeRender } from './utils/before-render';\nimport { is } from './utils/is';\nimport { signalStore, type NgtSignalStore } from './utils/signal-store';\nimport { updateCamera } from './utils/update';\n\nconst privateKeys = [\n\t'get',\n\t'set',\n\t'select',\n\t'setSize',\n\t'setDpr',\n\t'setFrameloop',\n\t'events',\n\t'invalidate',\n\t'advance',\n\t'size',\n\t'viewport',\n] as const;\ntype PrivateKeys = (typeof privateKeys)[number];\n\nexport interface NgtPortalInputs {\n\tcontainer: ElementRef<THREE.Object3D> | THREE.Object3D;\n\tcamera: ElementRef<THREE.Camera> | THREE.Camera;\n\tstate: Partial<\n\t\tOmit<NgtState, PrivateKeys> & {\n\t\t\tevents: Partial<Pick<NgtEventManager<any>, 'enabled' | 'priority' | 'compute' | 'connected'>>;\n\t\t\tsize: NgtSize;\n\t\t}\n\t>;\n}\n\nconst [, providePortalStore] = createInjectionToken(\n\t(parentStore: NgtSignalStore<NgtState>) => {\n\t\tconst parentState = parentStore.snapshot;\n\t\tconst pointer = new THREE.Vector2();\n\t\tconst raycaster = new THREE.Raycaster();\n\t\treturn signalStore<NgtState>(({ update }) => {\n\t\t\treturn {\n\t\t\t\t...parentState,\n\t\t\t\tpointer,\n\t\t\t\traycaster,\n\t\t\t\tpreviousRoot: parentStore,\n\t\t\t\t// Layers are allowed to override events\n\t\t\t\tsetEvents: (events) => update((state) => ({ ...state, events: { ...state.events, ...events } })),\n\t\t\t};\n\t\t});\n\t},\n\t{ isRoot: false, token: NGT_STORE, deps: [[new SkipSelf(), NGT_STORE]] },\n);\n\n@Component({\n\tselector: 'ngt-portal-before-render',\n\tstandalone: true,\n\ttemplate: `\n\t\t<!-- Without an element that receives pointer events state.pointer will always be 0/0 -->\n\t\t<ngt-group (pointerover)=\"onPointerOver()\" attach=\"none\" />\n\t`,\n\tschemas: [CUSTOM_ELEMENTS_SCHEMA],\n})\nexport class NgtPortalBeforeRender {\n\tprivate portalStore = injectNgtStore();\n\tprivate injector = inject(Injector);\n\n\t@Input() renderPriority = 1;\n\t@Input({ required: true }) parentScene!: THREE.Scene;\n\t@Input({ required: true }) parentCamera!: THREE.Camera;\n\n\tconstructor() {\n\t\tafterNextRender(() => {\n\t\t\tlet oldClear: boolean;\n\t\t\tinjectBeforeRender(\n\t\t\t\t() => {\n\t\t\t\t\tconst { gl, scene, camera } = this.portalStore.get();\n\t\t\t\t\toldClear = gl.autoClear;\n\t\t\t\t\tif (this.renderPriority === 1) {\n\t\t\t\t\t\t// clear scene and render with default\n\t\t\t\t\t\tgl.autoClear = true;\n\t\t\t\t\t\tgl.render(this.parentScene, this.parentCamera);\n\t\t\t\t\t}\n\t\t\t\t\t// disable cleaning\n\t\t\t\t\tgl.autoClear = false;\n\t\t\t\t\tgl.clearDepth();\n\t\t\t\t\tgl.render(scene, camera);\n\t\t\t\t\t// restore\n\t\t\t\t\tgl.autoClear = oldClear;\n\t\t\t\t},\n\t\t\t\t{ priority: this.renderPriority, injector: this.injector },\n\t\t\t);\n\t\t});\n\t}\n\n\tonPointerOver() {\n\t\t/* noop */\n\t}\n}\n\n@Directive({ selector: 'ng-template[ngtPortalContent]', standalone: true })\nexport class NgtPortalContent {\n\tconstructor(vcr: ViewContainerRef, @SkipSelf() parentVcr: ViewContainerRef) {\n\t\tconst commentNode = vcr.element.nativeElement;\n\t\tif (commentNode[SPECIAL_INTERNAL_ADD_COMMENT]) {\n\t\t\tcommentNode[SPECIAL_INTERNAL_ADD_COMMENT](parentVcr.element.nativeElement);\n\t\t\tdelete commentNode[SPECIAL_INTERNAL_ADD_COMMENT];\n\t\t}\n\t}\n}\n\n@Component({\n\tselector: 'ngt-portal',\n\tstandalone: true,\n\ttemplate: `\n\t\t<ng-container #portalContentAnchor>\n\t\t\t@if (renderAutoBeforeRender()) {\n\t\t\t\t<ngt-portal-before-render\n\t\t\t\t\t[renderPriority]=\"autoRenderPriority\"\n\t\t\t\t\t[parentScene]=\"parentScene\"\n\t\t\t\t\t[parentCamera]=\"parentCamera\"\n\t\t\t\t/>\n\t\t\t}\n\t\t</ng-container>\n\t`,\n\timports: [NgtPortalBeforeRender],\n\tproviders: [providePortalStore()],\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class NgtPortal {\n\tprivate portalInputs = signalStore<NgtPortalInputs>({\n\t\tcontainer: injectNgtRef<THREE.Scene>(prepare(new THREE.Scene())),\n\t});\n\n\t@Input({ alias: 'options' }) set _portalInputs(value: Partial<NgtPortalInputs>) {\n\t\tthis.portalInputs.update(value);\n\t}\n\n\tprivate autoRender = signal(false);\n\t@Input({ alias: 'autoRender' }) set _autoRender(value: boolean) {\n\t\tthis.autoRender.set(value);\n\t}\n\n\t@Input() autoRenderPriority = 1;\n\n\t@ContentChild(NgtPortalContent, { read: TemplateRef, static: true })\n\tportalContentTemplate!: TemplateRef<unknown>;\n\n\t@ViewChild('portalContentAnchor', { read: ViewContainerRef, static: true })\n\tportalContentAnchor!: ViewContainerRef;\n\n\tprivate destroyRef = inject(DestroyRef);\n\tprivate autoEffect = injectAutoEffect();\n\tprivate parentStore = injectNgtStore({ skipSelf: true });\n\tprivate portalStore = injectNgtStore({ self: true });\n\n\tprivate portalRendered = signal(false);\n\n\tprotected renderAutoBeforeRender = computed(() => this.portalRendered() && this.autoRender());\n\tprotected parentScene = this.parentStore.get('scene');\n\tprotected parentCamera = this.parentStore.get('camera');\n\n\tconstructor() {\n\t\tafterNextRender(() => {\n\t\t\tconst parentState = this.parentStore.snapshot;\n\t\t\tconst {\n\t\t\t\tcontainer,\n\t\t\t\tstate: { events = {}, size = {}, ...rest },\n\t\t\t} = this.portalInputs.snapshot;\n\n\t\t\tthis.portalStore.update({\n\t\t\t\tscene: (is.ref(container) ? container.nativeElement : container) as THREE.Scene,\n\t\t\t\tevents: { ...parentState.events, ...events },\n\t\t\t\tsize: { ...parentState.size, ...size },\n\t\t\t\t...rest,\n\t\t\t});\n\n\t\t\tthis.autoEffect(() => {\n\t\t\t\tconst previous = this.parentStore.state();\n\t\t\t\tthis.portalStore.update((state) => this.inject(previous, state));\n\t\t\t});\n\n\t\t\tuntracked(() => {\n\t\t\t\tconst portalView = this.portalContentAnchor.createEmbeddedView(this.portalContentTemplate);\n\t\t\t\tportalView.detectChanges();\n\t\t\t\tthis.destroyRef.onDestroy(portalView.destroy.bind(portalView));\n\t\t\t});\n\n\t\t\tthis.portalRendered.set(true);\n\t\t});\n\t}\n\n\tprivate inject(rootState: NgtState, injectState: NgtState) {\n\t\tconst intersect: Partial<NgtState> = { ...rootState };\n\n\t\tObject.keys(intersect).forEach((key) => {\n\t\t\tif (\n\t\t\t\tprivateKeys.includes(key as PrivateKeys) ||\n\t\t\t\trootState[key as keyof NgtState] !== injectState[key as keyof NgtState]\n\t\t\t) {\n\t\t\t\tdelete intersect[key as keyof NgtState];\n\t\t\t}\n\t\t});\n\n\t\tconst inputs = this.portalInputs.snapshot;\n\t\tconst { size, events, ...restInputsState } = inputs.state || {};\n\n\t\tlet viewport = undefined;\n\t\tif (injectState && size) {\n\t\t\tconst camera = injectState.camera;\n\t\t\tviewport = rootState.viewport.getCurrentViewport(camera, new THREE.Vector3(), size);\n\t\t\tif (camera !== rootState.camera) updateCamera(camera, size);\n\t\t}\n\n\t\treturn {\n\t\t\t...intersect,\n\t\t\tscene: is.ref(inputs.container) ? inputs.container.nativeElement : inputs.container,\n\t\t\tpreviousRoot: this.parentStore,\n\t\t\tevents: { ...rootState.events, ...(injectState?.events || {}), ...events },\n\t\t\tsize: { ...rootState.size, ...size },\n\t\t\tviewport: { ...rootState.viewport, ...(viewport || {}) },\n\t\t\t...restInputsState,\n\t\t} as NgtState;\n\t}\n}\n"]}
|
package/esm2022/lib/ref.mjs
CHANGED
|
@@ -1,23 +1,22 @@
|
|
|
1
|
-
import { DestroyRef, ElementRef, computed, inject,
|
|
1
|
+
import { DestroyRef, ElementRef, computed, inject, signal, untracked } from '@angular/core';
|
|
2
|
+
import { assertInjector } from 'ngxtension/assert-injector';
|
|
2
3
|
import { getLocalState } from './instance';
|
|
3
|
-
import { assertInjectionContext } from './utils/assert-injection-context';
|
|
4
4
|
import { is } from './utils/is';
|
|
5
5
|
export function injectNgtRef(initial = null, injector) {
|
|
6
|
-
injector
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
inject(DestroyRef).onDestroy(() => void cached.clear());
|
|
6
|
+
return assertInjector(injectNgtRef, injector, () => {
|
|
7
|
+
const ref = is.ref(initial) ? initial : new ElementRef(initial);
|
|
8
|
+
const refSignal = signal(ref.nativeElement, { equal: Object.is });
|
|
9
|
+
const readonlyRef = refSignal.asReadonly();
|
|
10
|
+
const computedCached = new Map();
|
|
11
|
+
inject(DestroyRef).onDestroy(() => void computedCached.clear());
|
|
13
12
|
const children = (type = 'objects') => {
|
|
14
|
-
if (!
|
|
15
|
-
|
|
16
|
-
const instance =
|
|
13
|
+
if (!computedCached.has(type)) {
|
|
14
|
+
computedCached.set(type, computed(() => {
|
|
15
|
+
const instance = readonlyRef();
|
|
17
16
|
if (!instance)
|
|
18
17
|
return [];
|
|
19
18
|
const localState = getLocalState(instance);
|
|
20
|
-
if (!localState
|
|
19
|
+
if (!localState?.instanceStore)
|
|
21
20
|
return [];
|
|
22
21
|
if (type === 'objects')
|
|
23
22
|
return localState.objects();
|
|
@@ -26,23 +25,22 @@ export function injectNgtRef(initial = null, injector) {
|
|
|
26
25
|
return [...localState.objects(), ...localState.nonObjects()];
|
|
27
26
|
}));
|
|
28
27
|
}
|
|
29
|
-
return
|
|
28
|
+
return computedCached.get(type);
|
|
30
29
|
};
|
|
31
30
|
Object.defineProperties(ref, {
|
|
32
31
|
nativeElement: {
|
|
33
32
|
set: (newElement) => {
|
|
34
33
|
untracked(() => {
|
|
35
|
-
if (newElement !==
|
|
36
|
-
|
|
34
|
+
if (newElement !== readonlyRef()) {
|
|
35
|
+
refSignal.set(newElement);
|
|
37
36
|
}
|
|
38
37
|
});
|
|
39
38
|
},
|
|
40
|
-
get:
|
|
39
|
+
get: readonlyRef,
|
|
41
40
|
},
|
|
42
|
-
|
|
43
|
-
children: { get: () => children },
|
|
41
|
+
children: { value: children },
|
|
44
42
|
});
|
|
45
43
|
return ref;
|
|
46
44
|
});
|
|
47
45
|
}
|
|
48
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
46
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVmLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vbGlicy9jb3JlL3NyYy9saWIvcmVmLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsVUFBVSxFQUFFLFFBQVEsRUFBRSxNQUFNLEVBQUUsTUFBTSxFQUFFLFNBQVMsRUFBOEIsTUFBTSxlQUFlLENBQUM7QUFDeEgsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBQzVELE9BQU8sRUFBRSxhQUFhLEVBQXdCLE1BQU0sWUFBWSxDQUFDO0FBQ2pFLE9BQU8sRUFBRSxFQUFFLEVBQUUsTUFBTSxZQUFZLENBQUM7QUFTaEMsTUFBTSxVQUFVLFlBQVksQ0FDM0IsVUFBMkMsSUFBSyxFQUNoRCxRQUFtQjtJQUVuQixPQUFPLGNBQWMsQ0FBQyxZQUFZLEVBQUUsUUFBUSxFQUFFLEdBQUcsRUFBRTtRQUNsRCxNQUFNLEdBQUcsR0FBRyxFQUFFLENBQUMsR0FBRyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLElBQUksVUFBVSxDQUFDLE9BQW1CLENBQUMsQ0FBQztRQUM1RSxNQUFNLFNBQVMsR0FBRyxNQUFNLENBQUMsR0FBRyxDQUFDLGFBQWEsRUFBRSxFQUFFLEtBQUssRUFBRSxNQUFNLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQztRQUNsRSxNQUFNLFdBQVcsR0FBRyxTQUFTLENBQUMsVUFBVSxFQUFFLENBQUM7UUFDM0MsTUFBTSxjQUFjLEdBQUcsSUFBSSxHQUFHLEVBQUUsQ0FBQztRQUVqQyxNQUFNLENBQUMsVUFBVSxDQUFDLENBQUMsU0FBUyxDQUFDLEdBQUcsRUFBRSxDQUFDLEtBQUssY0FBYyxDQUFDLEtBQUssRUFBRSxDQUFDLENBQUM7UUFFaEUsTUFBTSxRQUFRLEdBQUcsQ0FBQyxPQUEwQyxTQUFTLEVBQUUsRUFBRTtZQUN4RSxJQUFJLENBQUMsY0FBYyxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDO2dCQUMvQixjQUFjLENBQUMsR0FBRyxDQUNqQixJQUFJLEVBQ0osUUFBUSxDQUFDLEdBQUcsRUFBRTtvQkFDYixNQUFNLFFBQVEsR0FBRyxXQUFXLEVBQUUsQ0FBQztvQkFDL0IsSUFBSSxDQUFDLFFBQVE7d0JBQUUsT0FBTyxFQUFFLENBQUM7b0JBQ3pCLE1BQU0sVUFBVSxHQUFHLGFBQWEsQ0FBQyxRQUFRLENBQUMsQ0FBQztvQkFDM0MsSUFBSSxDQUFDLFVBQVUsRUFBRSxhQUFhO3dCQUFFLE9BQU8sRUFBRSxDQUFDO29CQUMxQyxJQUFJLElBQUksS0FBSyxTQUFTO3dCQUFFLE9BQU8sVUFBVSxDQUFDLE9BQU8sRUFBRSxDQUFDO29CQUNwRCxJQUFJLElBQUksS0FBSyxZQUFZO3dCQUFFLE9BQU8sVUFBVSxDQUFDLFVBQVUsRUFBRSxDQUFDO29CQUMxRCxPQUFPLENBQUMsR0FBRyxVQUFVLENBQUMsT0FBTyxFQUFFLEVBQUUsR0FBRyxVQUFVLENBQUMsVUFBVSxFQUFFLENBQUMsQ0FBQztnQkFDOUQsQ0FBQyxDQUFDLENBQ0YsQ0FBQztZQUNILENBQUM7WUFDRCxPQUFPLGNBQWMsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFFLENBQUM7UUFDbEMsQ0FBQyxDQUFDO1FBRUYsTUFBTSxDQUFDLGdCQUFnQixDQUFDLEdBQUcsRUFBRTtZQUM1QixhQUFhLEVBQUU7Z0JBQ2QsR0FBRyxFQUFFLENBQUMsVUFBVSxFQUFFLEVBQUU7b0JBQ25CLFNBQVMsQ0FBQyxHQUFHLEVBQUU7d0JBQ2QsSUFBSSxVQUFVLEtBQUssV0FBVyxFQUFFLEVBQUUsQ0FBQzs0QkFDbEMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxVQUFVLENBQUMsQ0FBQzt3QkFDM0IsQ0FBQztvQkFDRixDQUFDLENBQUMsQ0FBQztnQkFDSixDQUFDO2dCQUNELEdBQUcsRUFBRSxXQUFXO2FBQ2hCO1lBQ0QsUUFBUSxFQUFFLEVBQUUsS0FBSyxFQUFFLFFBQVEsRUFBRTtTQUM3QixDQUFDLENBQUM7UUFFSCxPQUFPLEdBQStCLENBQUM7SUFDeEMsQ0FBQyxDQUFDLENBQUM7QUFDSixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGVzdHJveVJlZiwgRWxlbWVudFJlZiwgY29tcHV0ZWQsIGluamVjdCwgc2lnbmFsLCB1bnRyYWNrZWQsIHR5cGUgSW5qZWN0b3IsIHR5cGUgU2lnbmFsIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBhc3NlcnRJbmplY3RvciB9IGZyb20gJ25neHRlbnNpb24vYXNzZXJ0LWluamVjdG9yJztcbmltcG9ydCB7IGdldExvY2FsU3RhdGUsIHR5cGUgTmd0SW5zdGFuY2VOb2RlIH0gZnJvbSAnLi9pbnN0YW5jZSc7XG5pbXBvcnQgeyBpcyB9IGZyb20gJy4vdXRpbHMvaXMnO1xuXG5leHBvcnQgdHlwZSBOZ3RJbmplY3RlZFJlZjxURWxlbWVudD4gPSBFbGVtZW50UmVmPFRFbGVtZW50PiAmIHtcblx0LyogY29uc3VtZXJzIHNob3VsZCB1c2UgdGhpcyBmb3IgbGlzdGVudGluZyB0byBjaGlsZHJlbiBjaGFuZ2VzIG9uIHRoaXMgcmVmICovXG5cdGNoaWxkcmVuOiAodHlwZT86ICdvYmplY3RzJyB8ICdub25PYmplY3RzJyB8ICdib3RoJykgPT4gU2lnbmFsPE5ndEluc3RhbmNlTm9kZVtdPjtcbn07XG5cbmV4cG9ydCB0eXBlIE5ndFJlZjxURWxlbWVudD4gPSBURWxlbWVudCB8IE5ndEluamVjdGVkUmVmPFRFbGVtZW50PjtcblxuZXhwb3J0IGZ1bmN0aW9uIGluamVjdE5ndFJlZjxURWxlbWVudD4oXG5cdGluaXRpYWw6IEVsZW1lbnRSZWY8VEVsZW1lbnQ+IHwgVEVsZW1lbnQgPSBudWxsISxcblx0aW5qZWN0b3I/OiBJbmplY3Rvcixcbik6IE5ndEluamVjdGVkUmVmPFRFbGVtZW50PiB7XG5cdHJldHVybiBhc3NlcnRJbmplY3RvcihpbmplY3ROZ3RSZWYsIGluamVjdG9yLCAoKSA9PiB7XG5cdFx0Y29uc3QgcmVmID0gaXMucmVmKGluaXRpYWwpID8gaW5pdGlhbCA6IG5ldyBFbGVtZW50UmVmKGluaXRpYWwgYXMgVEVsZW1lbnQpO1xuXHRcdGNvbnN0IHJlZlNpZ25hbCA9IHNpZ25hbChyZWYubmF0aXZlRWxlbWVudCwgeyBlcXVhbDogT2JqZWN0LmlzIH0pO1xuXHRcdGNvbnN0IHJlYWRvbmx5UmVmID0gcmVmU2lnbmFsLmFzUmVhZG9ubHkoKTtcblx0XHRjb25zdCBjb21wdXRlZENhY2hlZCA9IG5ldyBNYXAoKTtcblxuXHRcdGluamVjdChEZXN0cm95UmVmKS5vbkRlc3Ryb3koKCkgPT4gdm9pZCBjb21wdXRlZENhY2hlZC5jbGVhcigpKTtcblxuXHRcdGNvbnN0IGNoaWxkcmVuID0gKHR5cGU6ICdvYmplY3RzJyB8ICdub25PYmplY3RzJyB8ICdib3RoJyA9ICdvYmplY3RzJykgPT4ge1xuXHRcdFx0aWYgKCFjb21wdXRlZENhY2hlZC5oYXModHlwZSkpIHtcblx0XHRcdFx0Y29tcHV0ZWRDYWNoZWQuc2V0KFxuXHRcdFx0XHRcdHR5cGUsXG5cdFx0XHRcdFx0Y29tcHV0ZWQoKCkgPT4ge1xuXHRcdFx0XHRcdFx0Y29uc3QgaW5zdGFuY2UgPSByZWFkb25seVJlZigpO1xuXHRcdFx0XHRcdFx0aWYgKCFpbnN0YW5jZSkgcmV0dXJuIFtdO1xuXHRcdFx0XHRcdFx0Y29uc3QgbG9jYWxTdGF0ZSA9IGdldExvY2FsU3RhdGUoaW5zdGFuY2UpO1xuXHRcdFx0XHRcdFx0aWYgKCFsb2NhbFN0YXRlPy5pbnN0YW5jZVN0b3JlKSByZXR1cm4gW107XG5cdFx0XHRcdFx0XHRpZiAodHlwZSA9PT0gJ29iamVjdHMnKSByZXR1cm4gbG9jYWxTdGF0ZS5vYmplY3RzKCk7XG5cdFx0XHRcdFx0XHRpZiAodHlwZSA9PT0gJ25vbk9iamVjdHMnKSByZXR1cm4gbG9jYWxTdGF0ZS5ub25PYmplY3RzKCk7XG5cdFx0XHRcdFx0XHRyZXR1cm4gWy4uLmxvY2FsU3RhdGUub2JqZWN0cygpLCAuLi5sb2NhbFN0YXRlLm5vbk9iamVjdHMoKV07XG5cdFx0XHRcdFx0fSksXG5cdFx0XHRcdCk7XG5cdFx0XHR9XG5cdFx0XHRyZXR1cm4gY29tcHV0ZWRDYWNoZWQuZ2V0KHR5cGUpITtcblx0XHR9O1xuXG5cdFx0T2JqZWN0LmRlZmluZVByb3BlcnRpZXMocmVmLCB7XG5cdFx0XHRuYXRpdmVFbGVtZW50OiB7XG5cdFx0XHRcdHNldDogKG5ld0VsZW1lbnQpID0+IHtcblx0XHRcdFx0XHR1bnRyYWNrZWQoKCkgPT4ge1xuXHRcdFx0XHRcdFx0aWYgKG5ld0VsZW1lbnQgIT09IHJlYWRvbmx5UmVmKCkpIHtcblx0XHRcdFx0XHRcdFx0cmVmU2lnbmFsLnNldChuZXdFbGVtZW50KTtcblx0XHRcdFx0XHRcdH1cblx0XHRcdFx0XHR9KTtcblx0XHRcdFx0fSxcblx0XHRcdFx0Z2V0OiByZWFkb25seVJlZixcblx0XHRcdH0sXG5cdFx0XHRjaGlsZHJlbjogeyB2YWx1ZTogY2hpbGRyZW4gfSxcblx0XHR9KTtcblxuXHRcdHJldHVybiByZWYgYXMgTmd0SW5qZWN0ZWRSZWY8VEVsZW1lbnQ+O1xuXHR9KTtcbn1cbiJdfQ==
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import { createInjectionToken } from '
|
|
1
|
+
import { createInjectionToken } from 'ngxtension/create-injection-token';
|
|
2
2
|
const catalogue = {};
|
|
3
3
|
export function extend(objects) {
|
|
4
4
|
Object.assign(catalogue, objects);
|
|
5
5
|
}
|
|
6
6
|
export const [injectNgtCatalogue] = createInjectionToken(() => catalogue);
|
|
7
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
7
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2F0YWxvZ3VlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb3JlL3NyYy9saWIvcmVuZGVyZXIvY2F0YWxvZ3VlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLG1DQUFtQyxDQUFDO0FBSXpFLE1BQU0sU0FBUyxHQUFzQyxFQUFFLENBQUM7QUFFeEQsTUFBTSxVQUFVLE1BQU0sQ0FBQyxPQUFlO0lBQ3JDLE1BQU0sQ0FBQyxNQUFNLENBQUMsU0FBUyxFQUFFLE9BQU8sQ0FBQyxDQUFDO0FBQ25DLENBQUM7QUFFRCxNQUFNLENBQUMsTUFBTSxDQUFDLGtCQUFrQixDQUFDLEdBQUcsb0JBQW9CLENBQUMsR0FBRyxFQUFFLENBQUMsU0FBUyxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjcmVhdGVJbmplY3Rpb25Ub2tlbiB9IGZyb20gJ25neHRlbnNpb24vY3JlYXRlLWluamVjdGlvbi10b2tlbic7XG5cbmV4cG9ydCB0eXBlIE5ndEFueUNvbnN0cnVjdG9yID0gbmV3ICguLi5hcmdzOiBhbnlbXSkgPT4gYW55O1xuXG5jb25zdCBjYXRhbG9ndWU6IFJlY29yZDxzdHJpbmcsIE5ndEFueUNvbnN0cnVjdG9yPiA9IHt9O1xuXG5leHBvcnQgZnVuY3Rpb24gZXh0ZW5kKG9iamVjdHM6IG9iamVjdCk6IHZvaWQge1xuXHRPYmplY3QuYXNzaWduKGNhdGFsb2d1ZSwgb2JqZWN0cyk7XG59XG5cbmV4cG9ydCBjb25zdCBbaW5qZWN0Tmd0Q2F0YWxvZ3VlXSA9IGNyZWF0ZUluamVjdGlvblRva2VuKCgpID0+IGNhdGFsb2d1ZSk7XG4iXX0=
|
|
@@ -10,7 +10,7 @@ export const SPECIAL_PROPERTIES = {
|
|
|
10
10
|
COMPOUND: 'ngtCompound',
|
|
11
11
|
RENDER_PRIORITY: 'priority',
|
|
12
12
|
ATTACH: 'attach',
|
|
13
|
-
|
|
13
|
+
RAW_VALUE: 'rawValue',
|
|
14
14
|
REF: 'ref',
|
|
15
15
|
};
|
|
16
16
|
export const SPECIAL_EVENTS = {
|
|
@@ -18,4 +18,4 @@ export const SPECIAL_EVENTS = {
|
|
|
18
18
|
AFTER_UPDATE: 'afterUpdate',
|
|
19
19
|
AFTER_ATTACH: 'afterAttach',
|
|
20
20
|
};
|
|
21
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
21
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc3RhbnRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb3JlL3NyYy9saWIvcmVuZGVyZXIvY29uc3RhbnRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBQyxNQUFNLFlBQVksR0FBRyxrQ0FBa0MsQ0FBQztBQUMvRCxNQUFNLENBQUMsTUFBTSxJQUFJLEdBQUcsd0JBQXdCLENBQUM7QUFDN0MsTUFBTSxDQUFDLE1BQU0sNEJBQTRCLEdBQUcsOEJBQThCLENBQUM7QUFFM0UsTUFBTSxDQUFDLE1BQU0sZUFBZSxHQUFHO0lBQzlCLFVBQVUsRUFBRSxZQUFZO0lBQ3hCLGFBQWEsRUFBRSxlQUFlO0lBQzlCLFNBQVMsRUFBRSxXQUFXO0NBQ2IsQ0FBQztBQUVYLE1BQU0sQ0FBQyxNQUFNLGtCQUFrQixHQUFHO0lBQ2pDLFFBQVEsRUFBRSxhQUFhO0lBQ3ZCLGVBQWUsRUFBRSxVQUFVO0lBQzNCLE1BQU0sRUFBRSxRQUFRO0lBQ2hCLFNBQVMsRUFBRSxVQUFVO0lBQ3JCLEdBQUcsRUFBRSxLQUFLO0NBQ0QsQ0FBQztBQUVYLE1BQU0sQ0FBQyxNQUFNLGNBQWMsR0FBRztJQUM3QixhQUFhLEVBQUUsY0FBYztJQUM3QixZQUFZLEVBQUUsYUFBYTtJQUMzQixZQUFZLEVBQUUsYUFBYTtDQUNsQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNvbnN0IFJPVVRFRF9TQ0VORSA9ICdfX25ndF9yZW5kZXJlcl9pc19yb3V0ZWRfc2NlbmVfXyc7XG5leHBvcnQgY29uc3QgSFRNTCA9ICdfX25ndF9yZW5kZXJlcl9pc19odG1sJztcbmV4cG9ydCBjb25zdCBTUEVDSUFMX0lOVEVSTkFMX0FERF9DT01NRU5UID0gJ19fbmd0X3JlbmRlcmVyX2FkZF9jb21tZW50X18nO1xuXG5leHBvcnQgY29uc3QgU1BFQ0lBTF9ET01fVEFHID0ge1xuXHROR1RfUE9SVEFMOiAnbmd0LXBvcnRhbCcsXG5cdE5HVF9QUklNSVRJVkU6ICduZ3QtcHJpbWl0aXZlJyxcblx0TkdUX1ZBTFVFOiAnbmd0LXZhbHVlJyxcbn0gYXMgY29uc3Q7XG5cbmV4cG9ydCBjb25zdCBTUEVDSUFMX1BST1BFUlRJRVMgPSB7XG5cdENPTVBPVU5EOiAnbmd0Q29tcG91bmQnLFxuXHRSRU5ERVJfUFJJT1JJVFk6ICdwcmlvcml0eScsXG5cdEFUVEFDSDogJ2F0dGFjaCcsXG5cdFJBV19WQUxVRTogJ3Jhd1ZhbHVlJyxcblx0UkVGOiAncmVmJyxcbn0gYXMgY29uc3Q7XG5cbmV4cG9ydCBjb25zdCBTUEVDSUFMX0VWRU5UUyA9IHtcblx0QkVGT1JFX1JFTkRFUjogJ2JlZm9yZVJlbmRlcicsXG5cdEFGVEVSX1VQREFURTogJ2FmdGVyVXBkYXRlJyxcblx0QUZURVJfQVRUQUNIOiAnYWZ0ZXJBdHRhY2gnLFxufSBhcyBjb25zdDtcbiJdfQ==
|