angular-three 2.0.0-beta.27 → 2.0.0-beta.271
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 +221 -4
- package/esm2022/index.mjs +6 -13
- package/esm2022/lib/canvas.mjs +131 -196
- package/esm2022/lib/directives/args.mjs +46 -20
- package/esm2022/lib/dom/events.mjs +2 -2
- package/esm2022/lib/events.mjs +33 -31
- package/esm2022/lib/html.mjs +39 -0
- package/esm2022/lib/instance.mjs +43 -36
- package/esm2022/lib/loader.mjs +60 -33
- package/esm2022/lib/loop.mjs +28 -25
- package/esm2022/lib/portal.mjs +173 -193
- package/esm2022/lib/renderer/catalogue.mjs +3 -3
- package/esm2022/lib/renderer/constants.mjs +5 -6
- package/esm2022/lib/renderer/index.mjs +357 -231
- package/esm2022/lib/renderer/state.mjs +49 -0
- package/esm2022/lib/renderer/utils.mjs +84 -87
- package/esm2022/lib/roots.mjs +99 -76
- package/esm2022/lib/routed-scene.mjs +6 -7
- package/esm2022/lib/store.mjs +170 -194
- package/esm2022/lib/three-types.mjs +2 -2
- package/esm2022/lib/utils/apply-props.mjs +24 -28
- package/esm2022/lib/utils/attach.mjs +13 -10
- package/esm2022/lib/utils/before-render.mjs +12 -0
- package/esm2022/lib/utils/is.mjs +6 -5
- package/esm2022/lib/utils/make.mjs +19 -17
- package/esm2022/lib/utils/object-events.mjs +29 -0
- package/esm2022/lib/utils/parameters.mjs +78 -0
- package/esm2022/lib/utils/resolve-ref.mjs +8 -0
- package/esm2022/lib/utils/signal-store.mjs +59 -60
- package/esm2022/lib/utils/update.mjs +6 -2
- package/fesm2022/angular-three.mjs +2346 -2662
- package/fesm2022/angular-three.mjs.map +1 -1
- package/index.d.ts +8 -12
- package/lib/canvas.d.ts +398 -53
- package/lib/directives/args.d.ts +14 -7
- package/lib/dom/events.d.ts +3 -3
- package/lib/events.d.ts +15 -15
- package/lib/html.d.ts +17 -0
- package/lib/instance.d.ts +25 -20
- package/lib/loader.d.ts +19 -7
- package/lib/loop.d.ts +10 -58
- package/lib/portal.d.ts +55 -48
- package/lib/renderer/catalogue.d.ts +7 -3
- package/lib/renderer/constants.d.ts +4 -5
- package/lib/renderer/index.d.ts +65 -4
- package/lib/renderer/state.d.ts +24 -0
- package/lib/renderer/utils.d.ts +8 -26
- package/lib/roots.d.ts +13 -7
- package/lib/store.d.ts +30 -33
- package/lib/three-types.d.ts +148 -147
- package/lib/utils/apply-props.d.ts +2 -3
- package/lib/utils/attach.d.ts +6 -6
- package/lib/{before-render.d.ts → utils/before-render.d.ts} +1 -1
- package/lib/utils/is.d.ts +15 -14
- package/lib/utils/make.d.ts +10 -13
- package/lib/utils/object-events.d.ts +9 -0
- package/lib/utils/parameters.d.ts +17 -0
- package/lib/utils/resolve-ref.d.ts +2 -0
- package/lib/utils/signal-store.d.ts +13 -4
- package/lib/utils/update.d.ts +1 -1
- package/metadata.json +1 -1
- package/package.json +30 -11
- package/web-types.json +1 -1
- package/esm2022/lib/before-render.mjs +0 -13
- package/esm2022/lib/directives/common.mjs +0 -41
- package/esm2022/lib/directives/key.mjs +0 -29
- package/esm2022/lib/directives/parent.mjs +0 -35
- package/esm2022/lib/directives/repeat.mjs +0 -17
- package/esm2022/lib/ref.mjs +0 -48
- package/esm2022/lib/renderer/store.mjs +0 -408
- package/esm2022/lib/utils/assert-injector.mjs +0 -6
- package/esm2022/lib/utils/create-injection-token.mjs +0 -47
- package/esm2022/lib/utils/safe-detect-changes.mjs +0 -17
- package/lib/directives/common.d.ts +0 -15
- package/lib/directives/key.d.ts +0 -10
- package/lib/directives/parent.d.ts +0 -11
- package/lib/directives/repeat.d.ts +0 -7
- package/lib/ref.d.ts +0 -8
- package/lib/renderer/store.d.ts +0 -67
- package/lib/utils/assert-injector.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/README.md +0 -11
- package/plugin/generators.json +0 -49
- package/plugin/package.json +0 -6
- package/plugin/src/generators/init/compat.d.ts +0 -4
- package/plugin/src/generators/init/compat.js +0 -6
- package/plugin/src/generators/init/compat.js.map +0 -1
- package/plugin/src/generators/init/files/experience/experience.component.html__tmpl__ +0 -4
- package/plugin/src/generators/init/files/experience/experience.component.ts__tmpl__ +0 -18
- package/plugin/src/generators/init/generator.d.ts +0 -6
- package/plugin/src/generators/init/generator.js +0 -160
- package/plugin/src/generators/init/generator.js.map +0 -1
- package/plugin/src/generators/init/schema.json +0 -17
- 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/utils.d.ts +0 -2
- package/plugin/src/generators/utils.js +0 -34
- package/plugin/src/generators/utils.js.map +0 -1
- package/plugin/src/generators/versions.d.ts +0 -12
- package/plugin/src/generators/versions.js +0 -16
- package/plugin/src/generators/versions.js.map +0 -1
- package/plugin/src/index.d.ts +0 -3
- package/plugin/src/index.js +0 -10
- package/plugin/src/index.js.map +0 -1
package/esm2022/lib/canvas.mjs
CHANGED
|
@@ -1,251 +1,186 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy,
|
|
2
|
-
import {
|
|
3
|
-
import
|
|
1
|
+
import { ChangeDetectionStrategy, Component, DestroyRef, ElementRef, EnvironmentInjector, Injector, NgZone, ViewContainerRef, afterNextRender, booleanAttribute, computed, createEnvironmentInjector, inject, input, output, signal, untracked, viewChild, } from '@angular/core';
|
|
2
|
+
import { outputFromObservable } from '@angular/core/rxjs-interop';
|
|
3
|
+
import { injectAutoEffect } from 'ngxtension/auto-effect';
|
|
4
|
+
import { NgxResize, provideResizeOptions } from 'ngxtension/resize';
|
|
4
5
|
import { createPointerEvents } from './dom/events';
|
|
5
|
-
import { injectNgtLoader } from './loader';
|
|
6
6
|
import { provideNgtRenderer } from './renderer';
|
|
7
7
|
import { injectCanvasRootInitializer } from './roots';
|
|
8
|
-
import {
|
|
8
|
+
import { NgtRoutedScene } from './routed-scene';
|
|
9
|
+
import { injectStore, provideStore } from './store';
|
|
9
10
|
import { is } from './utils/is';
|
|
10
|
-
import { safeDetectChanges } from './utils/safe-detect-changes';
|
|
11
|
-
import { signalStore } from './utils/signal-store';
|
|
12
11
|
import * as i0 from "@angular/core";
|
|
13
12
|
export class NgtCanvas {
|
|
14
13
|
constructor() {
|
|
15
|
-
this.store =
|
|
14
|
+
this.store = injectStore();
|
|
16
15
|
this.initRoot = injectCanvasRootInitializer();
|
|
16
|
+
this.autoEffect = injectAutoEffect();
|
|
17
17
|
this.host = inject(ElementRef);
|
|
18
18
|
this.viewContainerRef = inject(ViewContainerRef);
|
|
19
|
-
this.injector = inject(Injector);
|
|
20
|
-
this.environmentInjector = inject(EnvironmentInjector);
|
|
21
19
|
this.zone = inject(NgZone);
|
|
22
|
-
this.
|
|
23
|
-
this.
|
|
24
|
-
this.
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
frameloop: 'always',
|
|
31
|
-
dpr: [1, 2],
|
|
32
|
-
events: createPointerEvents,
|
|
20
|
+
this.environmentInjector = inject(EnvironmentInjector);
|
|
21
|
+
this.injector = inject(Injector);
|
|
22
|
+
this.sceneGraph = input.required({
|
|
23
|
+
transform: (value) => {
|
|
24
|
+
if (value === 'routed')
|
|
25
|
+
return NgtRoutedScene;
|
|
26
|
+
return value;
|
|
27
|
+
},
|
|
33
28
|
});
|
|
34
|
-
this.
|
|
35
|
-
this.
|
|
36
|
-
this.
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
this.
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
this.
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
this.
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
this.
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
this.
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
this.
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
this.
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
this.inputs.set({ gl });
|
|
72
|
-
}
|
|
73
|
-
set eventSource(eventSource) {
|
|
74
|
-
this.inputs.set({ eventSource });
|
|
75
|
-
}
|
|
76
|
-
set eventPrefix(eventPrefix) {
|
|
77
|
-
this.inputs.set({ eventPrefix });
|
|
78
|
-
}
|
|
79
|
-
set lookAt(lookAt) {
|
|
80
|
-
this.inputs.set({ lookAt });
|
|
81
|
-
}
|
|
82
|
-
set performance(performance) {
|
|
83
|
-
this.inputs.set({ performance });
|
|
84
|
-
}
|
|
85
|
-
ngOnChanges(changes) {
|
|
86
|
-
if (changes['sceneGraphInputs'] && !changes['sceneGraphInputs'].firstChange && this.glRef) {
|
|
87
|
-
this.setSceneGraphInputs();
|
|
88
|
-
}
|
|
89
|
-
}
|
|
90
|
-
ngOnInit() {
|
|
91
|
-
// NOTE: we resolve glCanvas at this point, setup the configurator
|
|
92
|
-
this.configurator = this.initRoot(this.glCanvas.nativeElement);
|
|
93
|
-
this.destroyRef.onDestroy(() => {
|
|
94
|
-
this.glEnvironmentInjector?.destroy();
|
|
29
|
+
this.gl = input();
|
|
30
|
+
this.size = input();
|
|
31
|
+
this.shadows = input(false, {
|
|
32
|
+
transform: (value) => {
|
|
33
|
+
if (value === '')
|
|
34
|
+
return booleanAttribute(value);
|
|
35
|
+
return value;
|
|
36
|
+
},
|
|
37
|
+
});
|
|
38
|
+
this.legacy = input(false, { transform: booleanAttribute });
|
|
39
|
+
this.linear = input(false, { transform: booleanAttribute });
|
|
40
|
+
this.flat = input(false, { transform: booleanAttribute });
|
|
41
|
+
this.orthographic = input(false, { transform: booleanAttribute });
|
|
42
|
+
this.frameloop = input('always');
|
|
43
|
+
this.performance = input();
|
|
44
|
+
this.dpr = input([1, 2]);
|
|
45
|
+
this.raycaster = input();
|
|
46
|
+
this.scene = input();
|
|
47
|
+
this.camera = input();
|
|
48
|
+
this.events = input(createPointerEvents);
|
|
49
|
+
this.eventSource = input();
|
|
50
|
+
this.eventPrefix = input('offset');
|
|
51
|
+
this.lookAt = input();
|
|
52
|
+
this.created = output();
|
|
53
|
+
this.pointerMissed = outputFromObservable(this.store.get('pointerMissed$'));
|
|
54
|
+
this.glCanvas = viewChild.required('glCanvas');
|
|
55
|
+
this.glCanvasViewContainerRef = viewChild.required('glCanvas', { read: ViewContainerRef });
|
|
56
|
+
// NOTE: this signal is updated outside of Zone
|
|
57
|
+
this.resizeResult = signal({}, { equal: Object.is });
|
|
58
|
+
this.hbPointerEvents = computed(() => (this.eventSource() ? 'none' : 'auto'));
|
|
59
|
+
afterNextRender(() => {
|
|
60
|
+
this.zone.runOutsideAngular(() => {
|
|
61
|
+
this.configurator = this.initRoot(this.glCanvas().nativeElement);
|
|
62
|
+
this.noZoneResizeEffect();
|
|
63
|
+
});
|
|
64
|
+
});
|
|
65
|
+
inject(DestroyRef).onDestroy(() => {
|
|
95
66
|
this.glRef?.destroy();
|
|
96
|
-
this.
|
|
97
|
-
injectNgtLoader.destroy();
|
|
67
|
+
this.glEnvironmentInjector?.destroy();
|
|
98
68
|
this.configurator?.destroy();
|
|
99
69
|
});
|
|
100
70
|
}
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
this.
|
|
71
|
+
noZoneResizeEffect() {
|
|
72
|
+
this.autoEffect(() => {
|
|
73
|
+
const resizeResult = this.resizeResult();
|
|
74
|
+
if (resizeResult.width > 0 && resizeResult.height > 0) {
|
|
75
|
+
if (!this.configurator)
|
|
76
|
+
this.configurator = this.initRoot(this.glCanvas().nativeElement);
|
|
77
|
+
this.configurator.configure({
|
|
78
|
+
gl: this.gl(),
|
|
79
|
+
shadows: this.shadows(),
|
|
80
|
+
legacy: this.legacy(),
|
|
81
|
+
linear: this.linear(),
|
|
82
|
+
flat: this.flat(),
|
|
83
|
+
orthographic: this.orthographic(),
|
|
84
|
+
frameloop: this.frameloop(),
|
|
85
|
+
performance: this.performance(),
|
|
86
|
+
dpr: this.dpr(),
|
|
87
|
+
raycaster: this.raycaster(),
|
|
88
|
+
scene: this.scene(),
|
|
89
|
+
camera: this.camera(),
|
|
90
|
+
events: this.events(),
|
|
91
|
+
eventSource: this.eventSource(),
|
|
92
|
+
eventPrefix: this.eventPrefix(),
|
|
93
|
+
lookAt: this.lookAt(),
|
|
94
|
+
size: resizeResult,
|
|
95
|
+
});
|
|
96
|
+
untracked(() => {
|
|
113
97
|
if (this.glRef) {
|
|
114
|
-
this.
|
|
98
|
+
this.glRef.changeDetectorRef.detectChanges();
|
|
115
99
|
}
|
|
116
100
|
else {
|
|
117
|
-
this.
|
|
101
|
+
this.noZoneRender();
|
|
118
102
|
}
|
|
119
103
|
});
|
|
120
|
-
}
|
|
121
|
-
}
|
|
104
|
+
}
|
|
105
|
+
});
|
|
122
106
|
}
|
|
123
|
-
|
|
107
|
+
noZoneRender() {
|
|
108
|
+
// NOTE: destroy previous instances if existed
|
|
124
109
|
this.glEnvironmentInjector?.destroy();
|
|
125
110
|
this.glRef?.destroy();
|
|
126
|
-
// Flag the canvas active, rendering will now begin
|
|
127
|
-
this.store.
|
|
128
|
-
const
|
|
129
|
-
|
|
111
|
+
// NOTE: Flag the canvas active, rendering will now begin
|
|
112
|
+
this.store.update((state) => ({ internal: { ...state.internal, active: true } }));
|
|
113
|
+
const [state, eventSource, eventPrefix] = [
|
|
114
|
+
this.store.snapshot,
|
|
115
|
+
untracked(this.eventSource),
|
|
116
|
+
untracked(this.eventPrefix),
|
|
117
|
+
];
|
|
130
118
|
// connect to event source
|
|
131
|
-
state.events.connect?.(
|
|
132
|
-
? is.ref(inputs.eventSource)
|
|
133
|
-
? inputs.eventSource.nativeElement
|
|
134
|
-
: inputs.eventSource
|
|
135
|
-
: this.host.nativeElement);
|
|
119
|
+
state.events.connect?.(eventSource ? (is.ref(eventSource) ? eventSource.nativeElement : eventSource) : this.host.nativeElement);
|
|
136
120
|
// setup compute for eventPrefix
|
|
137
|
-
if (
|
|
121
|
+
if (eventPrefix) {
|
|
138
122
|
state.setEvents({
|
|
139
123
|
compute: (event, store) => {
|
|
140
|
-
const
|
|
141
|
-
const x = event[(
|
|
142
|
-
const y = event[(
|
|
143
|
-
|
|
144
|
-
|
|
124
|
+
const { pointer, raycaster, camera, size } = store.snapshot;
|
|
125
|
+
const x = event[(eventPrefix + 'X')];
|
|
126
|
+
const y = event[(eventPrefix + 'Y')];
|
|
127
|
+
pointer.set((x / size.width) * 2 - 1, -(y / size.height) * 2 + 1);
|
|
128
|
+
raycaster.setFromCamera(pointer, camera);
|
|
145
129
|
},
|
|
146
130
|
});
|
|
147
131
|
}
|
|
148
132
|
// emit created event if observed
|
|
149
|
-
|
|
150
|
-
// but go back into zone to do so
|
|
151
|
-
this.zone.run(() => {
|
|
152
|
-
this.created.emit(this.store.get());
|
|
153
|
-
});
|
|
154
|
-
}
|
|
133
|
+
this.created.emit(this.store.snapshot);
|
|
155
134
|
if (!this.store.get('events', 'connected')) {
|
|
156
|
-
this.store.get('events').connect?.(this.glCanvas.nativeElement);
|
|
135
|
+
this.store.get('events').connect?.(untracked(this.glCanvas).nativeElement);
|
|
157
136
|
}
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
}
|
|
166
|
-
overrideChangeDetectorRef() {
|
|
167
|
-
const originalDetectChanges = this.cdr.detectChanges.bind(this.cdr);
|
|
168
|
-
this.cdr.detectChanges = () => {
|
|
169
|
-
originalDetectChanges();
|
|
170
|
-
safeDetectChanges(this.glRef?.changeDetectorRef);
|
|
171
|
-
};
|
|
172
|
-
}
|
|
173
|
-
setSceneGraphInputs() {
|
|
174
|
-
this.zone.run(() => {
|
|
175
|
-
if (this.glRef) {
|
|
176
|
-
for (const [key, value] of Object.entries(this.sceneGraphInputs)) {
|
|
177
|
-
this.glRef.setInput(key, value);
|
|
178
|
-
}
|
|
179
|
-
this.glRef.changeDetectorRef.detectChanges();
|
|
180
|
-
}
|
|
137
|
+
untracked(() => {
|
|
138
|
+
this.glEnvironmentInjector = createEnvironmentInjector([provideNgtRenderer(this.store)], this.environmentInjector);
|
|
139
|
+
this.glRef = this.viewContainerRef.createComponent(untracked(this.sceneGraph), {
|
|
140
|
+
environmentInjector: this.glEnvironmentInjector,
|
|
141
|
+
injector: this.injector,
|
|
142
|
+
});
|
|
143
|
+
this.glRef.changeDetectorRef.detectChanges();
|
|
181
144
|
});
|
|
182
145
|
}
|
|
183
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
184
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "
|
|
185
|
-
|
|
146
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.2", ngImport: i0, type: NgtCanvas, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
147
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "18.1.2", type: NgtCanvas, isStandalone: true, selector: "ngt-canvas", inputs: { sceneGraph: { classPropertyName: "sceneGraph", publicName: "sceneGraph", isSignal: true, isRequired: true, transformFunction: null }, gl: { classPropertyName: "gl", publicName: "gl", isSignal: true, isRequired: false, transformFunction: null }, size: { classPropertyName: "size", publicName: "size", isSignal: true, isRequired: false, transformFunction: null }, shadows: { classPropertyName: "shadows", publicName: "shadows", isSignal: true, isRequired: false, transformFunction: null }, legacy: { classPropertyName: "legacy", publicName: "legacy", isSignal: true, isRequired: false, transformFunction: null }, linear: { classPropertyName: "linear", publicName: "linear", isSignal: true, isRequired: false, transformFunction: null }, flat: { classPropertyName: "flat", publicName: "flat", isSignal: true, isRequired: false, transformFunction: null }, orthographic: { classPropertyName: "orthographic", publicName: "orthographic", isSignal: true, isRequired: false, transformFunction: null }, frameloop: { classPropertyName: "frameloop", publicName: "frameloop", isSignal: true, isRequired: false, transformFunction: null }, performance: { classPropertyName: "performance", publicName: "performance", isSignal: true, isRequired: false, transformFunction: null }, dpr: { classPropertyName: "dpr", publicName: "dpr", isSignal: true, isRequired: false, transformFunction: null }, raycaster: { classPropertyName: "raycaster", publicName: "raycaster", isSignal: true, isRequired: false, transformFunction: null }, scene: { classPropertyName: "scene", publicName: "scene", isSignal: true, isRequired: false, transformFunction: null }, camera: { classPropertyName: "camera", publicName: "camera", isSignal: true, isRequired: false, transformFunction: null }, events: { classPropertyName: "events", publicName: "events", isSignal: true, isRequired: false, transformFunction: null }, eventSource: { classPropertyName: "eventSource", publicName: "eventSource", isSignal: true, isRequired: false, transformFunction: null }, eventPrefix: { classPropertyName: "eventPrefix", publicName: "eventPrefix", isSignal: true, isRequired: false, transformFunction: null }, lookAt: { classPropertyName: "lookAt", publicName: "lookAt", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { created: "created", pointerMissed: "pointerMissed" }, host: { properties: { "style.pointerEvents": "hbPointerEvents()" }, styleAttribute: "display: block;position: relative;width: 100%;height: 100%;overflow: hidden;" }, providers: [
|
|
148
|
+
provideResizeOptions({
|
|
149
|
+
emitInZone: false,
|
|
150
|
+
emitInitialResult: true,
|
|
151
|
+
debounce: { scroll: 50, resize: 0 },
|
|
152
|
+
}),
|
|
153
|
+
provideStore(),
|
|
154
|
+
], viewQueries: [{ propertyName: "glCanvas", first: true, predicate: ["glCanvas"], descendants: true, isSignal: true }, { propertyName: "glCanvasViewContainerRef", first: true, predicate: ["glCanvas"], descendants: true, read: ViewContainerRef, isSignal: true }], ngImport: i0, template: `
|
|
155
|
+
<div (ngxResize)="resizeResult.set($event)" style="height: 100%; width: 100%;">
|
|
186
156
|
<canvas #glCanvas style="display: block;"></canvas>
|
|
187
157
|
</div>
|
|
188
158
|
`, isInline: true, dependencies: [{ kind: "directive", type: NgxResize, selector: "[ngxResize]", inputs: ["ngxResizeOptions"], outputs: ["ngxResize"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
189
159
|
}
|
|
190
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
160
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.2", ngImport: i0, type: NgtCanvas, decorators: [{
|
|
191
161
|
type: Component,
|
|
192
162
|
args: [{
|
|
193
163
|
selector: 'ngt-canvas',
|
|
194
164
|
standalone: true,
|
|
195
165
|
template: `
|
|
196
|
-
<div (ngxResize)="
|
|
166
|
+
<div (ngxResize)="resizeResult.set($event)" style="height: 100%; width: 100%;">
|
|
197
167
|
<canvas #glCanvas style="display: block;"></canvas>
|
|
198
168
|
</div>
|
|
199
169
|
`,
|
|
200
170
|
imports: [NgxResize],
|
|
201
|
-
providers: [
|
|
171
|
+
providers: [
|
|
172
|
+
provideResizeOptions({
|
|
173
|
+
emitInZone: false,
|
|
174
|
+
emitInitialResult: true,
|
|
175
|
+
debounce: { scroll: 50, resize: 0 },
|
|
176
|
+
}),
|
|
177
|
+
provideStore(),
|
|
178
|
+
],
|
|
202
179
|
host: {
|
|
203
180
|
style: 'display: block;position: relative;width: 100%;height: 100%;overflow: hidden;',
|
|
204
181
|
'[style.pointerEvents]': 'hbPointerEvents()',
|
|
205
182
|
},
|
|
206
183
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
207
184
|
}]
|
|
208
|
-
}],
|
|
209
|
-
type: Input,
|
|
210
|
-
args: [{ required: true }]
|
|
211
|
-
}], sceneGraphInputs: [{
|
|
212
|
-
type: Input
|
|
213
|
-
}], compoundPrefixes: [{
|
|
214
|
-
type: Input
|
|
215
|
-
}], linear: [{
|
|
216
|
-
type: Input
|
|
217
|
-
}], legacy: [{
|
|
218
|
-
type: Input
|
|
219
|
-
}], flat: [{
|
|
220
|
-
type: Input
|
|
221
|
-
}], orthographic: [{
|
|
222
|
-
type: Input
|
|
223
|
-
}], frameloop: [{
|
|
224
|
-
type: Input
|
|
225
|
-
}], dpr: [{
|
|
226
|
-
type: Input
|
|
227
|
-
}], raycaster: [{
|
|
228
|
-
type: Input
|
|
229
|
-
}], shadows: [{
|
|
230
|
-
type: Input
|
|
231
|
-
}], camera: [{
|
|
232
|
-
type: Input
|
|
233
|
-
}], scene: [{
|
|
234
|
-
type: Input
|
|
235
|
-
}], gl: [{
|
|
236
|
-
type: Input
|
|
237
|
-
}], eventSource: [{
|
|
238
|
-
type: Input
|
|
239
|
-
}], eventPrefix: [{
|
|
240
|
-
type: Input
|
|
241
|
-
}], lookAt: [{
|
|
242
|
-
type: Input
|
|
243
|
-
}], performance: [{
|
|
244
|
-
type: Input
|
|
245
|
-
}], created: [{
|
|
246
|
-
type: Output
|
|
247
|
-
}], glCanvas: [{
|
|
248
|
-
type: ViewChild,
|
|
249
|
-
args: ['glCanvas', { static: true }]
|
|
250
|
-
}] } });
|
|
251
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"canvas.js","sourceRoot":"","sources":["../../../../../libs/core/src/lib/canvas.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n\tChangeDetectionStrategy,\n\tChangeDetectorRef,\n\tComponent,\n\tDestroyRef,\n\tElementRef,\n\tEnvironmentInjector,\n\tEventEmitter,\n\tInjector,\n\tInput,\n\tNgZone,\n\tOutput,\n\tViewChild,\n\tViewContainerRef,\n\tcomputed,\n\tcreateEnvironmentInjector,\n\teffect,\n\tinject,\n\ttype ComponentRef,\n\ttype EffectRef,\n\ttype OnChanges,\n\ttype OnInit,\n\ttype SimpleChanges,\n\ttype Type,\n} from '@angular/core';\nimport { NgxResize, provideNgxResizeOptions, type NgxResizeResult } from 'ngx-resize';\nimport * as THREE from 'three';\nimport { createPointerEvents } from './dom/events';\nimport type { NgtCamera, NgtDomEvent, NgtEventManager } from './events';\nimport { injectNgtLoader } from './loader';\nimport { provideNgtRenderer } from './renderer';\nimport { injectCanvasRootInitializer, type NgtCanvasConfigurator } from './roots';\nimport {\n\tinjectNgtStore,\n\tprovideNgtStore,\n\ttype NgtDpr,\n\ttype NgtPerformance,\n\ttype NgtRenderer,\n\ttype NgtSize,\n\ttype NgtState,\n} from './store';\nimport type { NgtObject3DNode } from './three-types';\nimport type { NgtAnyRecord, NgtProperties } from './types';\nimport { is } from './utils/is';\nimport { safeDetectChanges } from './utils/safe-detect-changes';\nimport { signalStore, type NgtSignalStore } from './utils/signal-store';\n\nexport type NgtGLOptions =\n\t| NgtRenderer\n\t| ((canvas: HTMLCanvasElement) => NgtRenderer)\n\t| Partial<NgtProperties<THREE.WebGLRenderer> | THREE.WebGLRendererParameters>\n\t| undefined;\n\nexport type NgtCanvasInputs = {\n\t/** A threejs renderer instance or props that go into the default renderer */\n\tgl?: NgtGLOptions;\n\tsize?: NgtSize;\n\n\t/**\n\t * Enables shadows (by default PCFsoft). Can accept `gl.shadowMap` options for fine-tuning,\n\t * but also strings: 'basic' | 'percentage' | 'soft' | 'variance'.\n\t * @see https://threejs.org/docs/#api/en/renderers/WebGLRenderer.shadowMap\n\t */\n\tshadows?: boolean | 'basic' | 'percentage' | 'soft' | 'variance' | Partial<THREE.WebGLShadowMap>;\n\t/**\n\t * Disables three r139 color management.\n\t * @see https://threejs.org/docs/#manual/en/introduction/Color-management\n\t */\n\tlegacy?: boolean;\n\t/** Switch off automatic sRGB encoding and gamma correction */\n\tlinear?: boolean;\n\t/** Use `THREE.NoToneMapping` instead of `THREE.ACESFilmicToneMapping` */\n\tflat?: boolean;\n\t/** Creates an orthographic camera */\n\torthographic?: boolean;\n\t/**\n\t * R3F's render mode. Set to `demand` to only render on state change or `never` to take control.\n\t * @see https://docs.pmnd.rs/react-three-fiber/advanced/scaling-performance#on-demand-rendering\n\t */\n\tframeloop?: 'always' | 'demand' | 'never';\n\t/**\n\t * R3F performance options for adaptive performance.\n\t * @see https://docs.pmnd.rs/react-three-fiber/advanced/scaling-performance#movement-regression\n\t */\n\tperformance?: Partial<Omit<NgtPerformance, 'regress'>>;\n\t/** Target pixel ratio. Can clamp between a range: `[min, max]` */\n\tdpr?: NgtDpr;\n\t/** Props that go into the default raycaster */\n\traycaster?: Partial<THREE.Raycaster>;\n\t/** A `THREE.Scene` instance or props that go into the default scene */\n\tscene?: THREE.Scene | Partial<THREE.Scene>;\n\t/** A `Camera` instance or props that go into the default camera */\n\tcamera?: (\n\t\t| NgtCamera\n\t\t| Partial<\n\t\t\t\tNgtObject3DNode<THREE.Camera, typeof THREE.Camera> &\n\t\t\t\t\tNgtObject3DNode<THREE.PerspectiveCamera, typeof THREE.PerspectiveCamera> &\n\t\t\t\t\tNgtObject3DNode<THREE.OrthographicCamera, typeof THREE.OrthographicCamera>\n\t\t  >\n\t) & {\n\t\t/** Flags the camera as manual, putting projection into your own hands */\n\t\tmanual?: boolean;\n\t};\n\t/** An R3F event manager to manage elements' pointer events */\n\tevents?: (store: NgtSignalStore<NgtState>) => NgtEventManager<HTMLElement>;\n\t/** The target where events are being subscribed to, default: the div that wraps canvas */\n\teventSource?: HTMLElement | ElementRef<HTMLElement>;\n\t/** The event prefix that is cast into canvas pointer x/y events, default: \"offset\" */\n\teventPrefix?: 'offset' | 'client' | 'page' | 'layer' | 'screen';\n\t/** Default coordinate for the camera to look at */\n\tlookAt?: THREE.Vector3 | Parameters<THREE.Vector3['set']>;\n};\n\n@Component({\n\tselector: 'ngt-canvas',\n\tstandalone: true,\n\ttemplate: `\n\t\t<div (ngxResize)=\"onResize($event)\" style=\"height: 100%; width: 100%;\">\n\t\t\t<canvas #glCanvas style=\"display: block;\"></canvas>\n\t\t</div>\n\t`,\n\timports: [NgxResize],\n\tproviders: [provideNgxResizeOptions({ emitInZone: false, emitInitialResult: true }), provideNgtStore()],\n\thost: {\n\t\tstyle: 'display: block;position: relative;width: 100%;height: 100%;overflow: hidden;',\n\t\t'[style.pointerEvents]': 'hbPointerEvents()',\n\t},\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class NgtCanvas implements OnInit, OnChanges {\n\tprivate store = injectNgtStore();\n\tprivate initRoot = injectCanvasRootInitializer();\n\n\tprivate host = inject<ElementRef<HTMLElement>>(ElementRef);\n\tprivate viewContainerRef = inject(ViewContainerRef);\n\tprivate injector = inject(Injector);\n\tprivate environmentInjector = inject(EnvironmentInjector);\n\tprivate zone = inject(NgZone);\n\tprivate destroyRef = inject(DestroyRef);\n\tprivate cdr = inject(ChangeDetectorRef);\n\n\tprivate inputs = signalStore<NgtCanvasInputs>({\n\t\tshadows: false,\n\t\tlinear: false,\n\t\tflat: false,\n\t\tlegacy: false,\n\t\torthographic: false,\n\t\tframeloop: 'always',\n\t\tdpr: [1, 2],\n\t\tevents: createPointerEvents,\n\t});\n\n\t@Input({ required: true }) sceneGraph!: Type<unknown>;\n\t@Input() sceneGraphInputs: NgtAnyRecord = {};\n\t@Input() compoundPrefixes: string[] = [];\n\n\t@Input() set linear(linear: boolean) {\n\t\tthis.inputs.set({ linear });\n\t}\n\n\t@Input() set legacy(legacy: boolean) {\n\t\tthis.inputs.set({ legacy });\n\t}\n\n\t@Input() set flat(flat: boolean) {\n\t\tthis.inputs.set({ flat });\n\t}\n\n\t@Input() set orthographic(orthographic: boolean) {\n\t\tthis.inputs.set({ orthographic });\n\t}\n\n\t@Input() set frameloop(frameloop: NgtCanvasInputs['frameloop']) {\n\t\tthis.inputs.set({ frameloop });\n\t}\n\n\t@Input() set dpr(dpr: NgtDpr) {\n\t\tthis.inputs.set({ dpr });\n\t}\n\n\t@Input() set raycaster(raycaster: Partial<THREE.Raycaster>) {\n\t\tthis.inputs.set({ raycaster });\n\t}\n\n\t@Input() set shadows(shadows: boolean | Partial<THREE.WebGLShadowMap>) {\n\t\tthis.inputs.set({ shadows });\n\t}\n\n\t@Input() set camera(camera: NgtCanvasInputs['camera']) {\n\t\tthis.inputs.set({ camera });\n\t}\n\n\t@Input() set scene(scene: NgtCanvasInputs['scene']) {\n\t\tthis.inputs.set({ scene });\n\t}\n\n\t@Input() set gl(gl: NgtCanvasInputs['gl']) {\n\t\tthis.inputs.set({ gl });\n\t}\n\n\t@Input() set eventSource(eventSource: NgtCanvasInputs['eventSource']) {\n\t\tthis.inputs.set({ eventSource });\n\t}\n\n\t@Input() set eventPrefix(eventPrefix: NgtCanvasInputs['eventPrefix']) {\n\t\tthis.inputs.set({ eventPrefix });\n\t}\n\n\t@Input() set lookAt(lookAt: NgtCanvasInputs['lookAt']) {\n\t\tthis.inputs.set({ lookAt });\n\t}\n\n\t@Input() set performance(performance: NgtCanvasInputs['performance']) {\n\t\tthis.inputs.set({ performance });\n\t}\n\n\t@Output() created = new EventEmitter<NgtState>();\n\n\tprivate inputsEventSource = this.inputs.select('eventSource');\n\tprotected hbPointerEvents = computed(() => (!!this.inputsEventSource() ? 'none' : 'auto'));\n\n\t@ViewChild('glCanvas', { static: true }) glCanvas!: ElementRef<HTMLCanvasElement>;\n\n\tprivate resizeEffectRef?: EffectRef;\n\tprivate configurator?: NgtCanvasConfigurator;\n\tprivate glEnvironmentInjector?: EnvironmentInjector;\n\tprivate glRef?: ComponentRef<unknown>;\n\n\tngOnChanges(changes: SimpleChanges): void {\n\t\tif (changes['sceneGraphInputs'] && !changes['sceneGraphInputs'].firstChange && this.glRef) {\n\t\t\tthis.setSceneGraphInputs();\n\t\t}\n\t}\n\n\tngOnInit() {\n\t\t// NOTE: we resolve glCanvas at this point, setup the configurator\n\t\tthis.configurator = this.initRoot(this.glCanvas.nativeElement);\n\n\t\tthis.destroyRef.onDestroy(() => {\n\t\t\tthis.glEnvironmentInjector?.destroy();\n\t\t\tthis.glRef?.destroy();\n\t\t\tthis.resizeEffectRef?.destroy();\n\t\t\tinjectNgtLoader.destroy();\n\t\t\tthis.configurator?.destroy();\n\t\t});\n\t}\n\n\t// NOTE: runs outside of Zone due to emitInZone: false\n\tonResize(result: NgxResizeResult) {\n\t\tif (result.width > 0 && result.height > 0) {\n\t\t\tthis.resizeEffectRef?.destroy();\n\n\t\t\tconst inputs = this.inputs.select();\n\t\t\t// NOTE: go back into zone so that effect runs\n\t\t\t// TODO: Double-check when effect is made not depended on zone\n\t\t\tthis.resizeEffectRef = this.zone.run(() =>\n\t\t\t\teffect(\n\t\t\t\t\t() => {\n\t\t\t\t\t\tthis.zone.runOutsideAngular(() => {\n\t\t\t\t\t\t\tif (!this.configurator) this.configurator = this.initRoot(this.glCanvas.nativeElement);\n\t\t\t\t\t\t\tthis.configurator.configure({ ...inputs(), size: result });\n\n\t\t\t\t\t\t\tif (this.glRef) {\n\t\t\t\t\t\t\t\tthis.cdr.detectChanges();\n\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\tthis.render();\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t});\n\t\t\t\t\t},\n\t\t\t\t\t{ manualCleanup: true, injector: this.injector },\n\t\t\t\t),\n\t\t\t);\n\t\t}\n\t}\n\n\tprivate render() {\n\t\tthis.glEnvironmentInjector?.destroy();\n\t\tthis.glRef?.destroy();\n\n\t\t// Flag the canvas active, rendering will now begin\n\t\tthis.store.set((state) => ({ internal: { ...state.internal, active: true } }));\n\n\t\tconst inputs = this.inputs.get();\n\t\tconst state = this.store.get();\n\n\t\t// connect to event source\n\t\tstate.events.connect?.(\n\t\t\tinputs.eventSource\n\t\t\t\t? is.ref(inputs.eventSource)\n\t\t\t\t\t? inputs.eventSource.nativeElement\n\t\t\t\t\t: inputs.eventSource\n\t\t\t\t: this.host.nativeElement,\n\t\t);\n\n\t\t// setup compute for eventPrefix\n\t\tif (inputs.eventPrefix) {\n\t\t\tstate.setEvents({\n\t\t\t\tcompute: (event, store) => {\n\t\t\t\t\tconst innerState = store.get();\n\t\t\t\t\tconst x = event[(inputs.eventPrefix + 'X') as keyof NgtDomEvent] as number;\n\t\t\t\t\tconst y = event[(inputs.eventPrefix + 'Y') as keyof NgtDomEvent] as number;\n\t\t\t\t\tinnerState.pointer.set((x / innerState.size.width) * 2 - 1, -(y / innerState.size.height) * 2 + 1);\n\t\t\t\t\tinnerState.raycaster.setFromCamera(innerState.pointer, innerState.camera);\n\t\t\t\t},\n\t\t\t});\n\t\t}\n\n\t\t// emit created event if observed\n\t\tif (this.created.observed) {\n\t\t\t// but go back into zone to do so\n\t\t\tthis.zone.run(() => {\n\t\t\t\tthis.created.emit(this.store.get());\n\t\t\t});\n\t\t}\n\n\t\tif (!this.store.get('events', 'connected')) {\n\t\t\tthis.store.get('events').connect?.(this.glCanvas.nativeElement);\n\t\t}\n\n\t\tthis.glEnvironmentInjector = createEnvironmentInjector(\n\t\t\t[provideNgtRenderer(this.store, this.compoundPrefixes, this.cdr)],\n\t\t\tthis.environmentInjector,\n\t\t);\n\t\tthis.glRef = this.viewContainerRef.createComponent(this.sceneGraph, {\n\t\t\tenvironmentInjector: this.glEnvironmentInjector,\n\t\t\tinjector: this.injector,\n\t\t});\n\t\tthis.overrideChangeDetectorRef();\n\t\tthis.setSceneGraphInputs();\n\t}\n\n\tprivate overrideChangeDetectorRef() {\n\t\tconst originalDetectChanges = this.cdr.detectChanges.bind(this.cdr);\n\t\tthis.cdr.detectChanges = () => {\n\t\t\toriginalDetectChanges();\n\t\t\tsafeDetectChanges(this.glRef?.changeDetectorRef);\n\t\t};\n\t}\n\n\tprivate setSceneGraphInputs() {\n\t\tthis.zone.run(() => {\n\t\t\tif (this.glRef) {\n\t\t\t\tfor (const [key, value] of Object.entries(this.sceneGraphInputs)) {\n\t\t\t\t\tthis.glRef.setInput(key, value);\n\t\t\t\t}\n\t\t\t\tthis.glRef.changeDetectorRef.detectChanges();\n\t\t\t}\n\t\t});\n\t}\n}\n"]}
|
|
185
|
+
}], ctorParameters: () => [] });
|
|
186
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"canvas.js","sourceRoot":"","sources":["../../../../../libs/core/src/lib/canvas.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n\tChangeDetectionStrategy,\n\tComponent,\n\tComponentRef,\n\tDestroyRef,\n\tElementRef,\n\tEnvironmentInjector,\n\tInjector,\n\tNgZone,\n\tType,\n\tViewContainerRef,\n\tafterNextRender,\n\tbooleanAttribute,\n\tcomputed,\n\tcreateEnvironmentInjector,\n\tinject,\n\tinput,\n\toutput,\n\tsignal,\n\tuntracked,\n\tviewChild,\n} from '@angular/core';\nimport { outputFromObservable } from '@angular/core/rxjs-interop';\nimport { injectAutoEffect } from 'ngxtension/auto-effect';\nimport { NgxResize, ResizeOptions, ResizeResult, provideResizeOptions } from 'ngxtension/resize';\nimport {\n\tCamera,\n\tOrthographicCamera,\n\tPerspectiveCamera,\n\tRaycaster,\n\tScene,\n\tVector3,\n\tWebGLRenderer,\n\tWebGLRendererParameters,\n\tWebGLShadowMap,\n} from 'three';\nimport { createPointerEvents } from './dom/events';\nimport { NgtCamera, NgtDomEvent, NgtEventManager } from './events';\nimport { provideNgtRenderer } from './renderer';\nimport { NgtCanvasConfigurator, NgtCanvasElement, injectCanvasRootInitializer } from './roots';\nimport { NgtRoutedScene } from './routed-scene';\nimport { NgtDpr, NgtPerformance, NgtRendererLike, NgtSize, NgtState, injectStore, provideStore } from './store';\nimport { NgtObject3DNode } from './three-types';\nimport { NgtProperties } from './types';\nimport { is } from './utils/is';\nimport { NgtSignalStore } from './utils/signal-store';\n\nexport type NgtGLOptions =\n\t| NgtRendererLike\n\t| ((canvas: NgtCanvasElement) => NgtRendererLike)\n\t| Partial<NgtProperties<WebGLRenderer> | WebGLRendererParameters>\n\t| undefined;\n\nexport interface NgtCanvasOptions {\n\t/** A threejs renderer instance or props that go into the default renderer */\n\tgl?: NgtGLOptions;\n\t/** Dimensions to fit the renderer to. Will measure canvas dimensions if omitted */\n\tsize?: NgtSize;\n\t/**\n\t * Enables shadows (by default PCFsoft). Can accept `gl.shadowMap` options for fine-tuning,\n\t * but also strings: 'basic' | 'percentage' | 'soft' | 'variance'.\n\t * @see https://threejs.org/docs/#api/en/renderers/WebGLRenderer.shadowMap\n\t */\n\tshadows?: boolean | 'basic' | 'percentage' | 'soft' | 'variance' | Partial<WebGLShadowMap>;\n\t/**\n\t * Disables three r139 color management.\n\t * @see https://threejs.org/docs/#manual/en/introduction/Color-management\n\t */\n\tlegacy?: boolean;\n\t/** Switch off automatic sRGB color space and gamma correction */\n\tlinear?: boolean;\n\t/** Use `THREE.NoToneMapping` instead of `THREE.ACESFilmicToneMapping` */\n\tflat?: boolean;\n\t/** Creates an orthographic camera */\n\torthographic?: boolean;\n\t/**\n\t * R3F's render mode. Set to `demand` to only render on state change or `never` to take control.\n\t * @see https://docs.pmnd.rs/react-three-fiber/advanced/scaling-performance#on-demand-rendering\n\t */\n\tframeloop?: 'always' | 'demand' | 'never';\n\t/**\n\t * R3F performance options for adaptive performance.\n\t * @see https://docs.pmnd.rs/react-three-fiber/advanced/scaling-performance#movement-regression\n\t */\n\tperformance?: Partial<Omit<NgtPerformance, 'regress'>>;\n\t/** Target pixel ratio. Can clamp between a range: `[min, max]` */\n\tdpr?: NgtDpr;\n\t/** Props that go into the default raycaster */\n\traycaster?: Partial<Raycaster>;\n\t/** A `Scene` instance or props that go into the default scene */\n\tscene?: Scene | Partial<Scene>;\n\t/** A `Camera` instance or props that go into the default camera */\n\tcamera?: (\n\t\t| NgtCamera\n\t\t| Partial<\n\t\t\t\tNgtObject3DNode<Camera, typeof Camera> &\n\t\t\t\t\tNgtObject3DNode<PerspectiveCamera, typeof PerspectiveCamera> &\n\t\t\t\t\tNgtObject3DNode<OrthographicCamera, typeof OrthographicCamera>\n\t\t  >\n\t) & {\n\t\t/** Flags the camera as manual, putting projection into your own hands */\n\t\tmanual?: boolean;\n\t};\n\t/** An R3F event manager to manage elements' pointer events */\n\tevents?: (store: NgtSignalStore<NgtState>) => NgtEventManager<HTMLElement>;\n\t/** The target where events are being subscribed to, default: the div that wraps canvas */\n\teventSource?: HTMLElement | ElementRef<HTMLElement>;\n\t/** The event prefix that is cast into canvas pointer x/y events, default: \"offset\" */\n\teventPrefix?: 'offset' | 'client' | 'page' | 'layer' | 'screen';\n\t/** Default coordinate for the camera to look at */\n\tlookAt?: Vector3 | Parameters<Vector3['set']>;\n}\n\n@Component({\n\tselector: 'ngt-canvas',\n\tstandalone: true,\n\ttemplate: `\n\t\t<div (ngxResize)=\"resizeResult.set($event)\" style=\"height: 100%; width: 100%;\">\n\t\t\t<canvas #glCanvas style=\"display: block;\"></canvas>\n\t\t</div>\n\t`,\n\timports: [NgxResize],\n\tproviders: [\n\t\tprovideResizeOptions({\n\t\t\temitInZone: false,\n\t\t\temitInitialResult: true,\n\t\t\tdebounce: { scroll: 50, resize: 0 },\n\t\t} as ResizeOptions),\n\t\tprovideStore(),\n\t],\n\thost: {\n\t\tstyle: 'display: block;position: relative;width: 100%;height: 100%;overflow: hidden;',\n\t\t'[style.pointerEvents]': 'hbPointerEvents()',\n\t},\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class NgtCanvas {\n\tprivate store = injectStore();\n\tprivate initRoot = injectCanvasRootInitializer();\n\tprivate autoEffect = injectAutoEffect();\n\n\tprivate host = inject<ElementRef<HTMLElement>>(ElementRef);\n\tprivate viewContainerRef = inject(ViewContainerRef);\n\tprivate zone = inject(NgZone);\n\tprivate environmentInjector = inject(EnvironmentInjector);\n\tprivate injector = inject(Injector);\n\n\tsceneGraph = input.required<Type<any>, Type<any> | 'routed'>({\n\t\ttransform: (value) => {\n\t\t\tif (value === 'routed') return NgtRoutedScene;\n\t\t\treturn value;\n\t\t},\n\t});\n\tgl = input<NgtGLOptions>();\n\tsize = input<NgtSize>();\n\tshadows = input(false, {\n\t\ttransform: (value) => {\n\t\t\tif (value === '') return booleanAttribute(value);\n\t\t\treturn value as NonNullable<NgtCanvasOptions['shadows']>;\n\t\t},\n\t});\n\tlegacy = input(false, { transform: booleanAttribute });\n\tlinear = input(false, { transform: booleanAttribute });\n\tflat = input(false, { transform: booleanAttribute });\n\torthographic = input(false, { transform: booleanAttribute });\n\tframeloop = input<NonNullable<NgtCanvasOptions['frameloop']>>('always');\n\tperformance = input<Partial<Omit<NgtPerformance, 'regress'>>>();\n\tdpr = input<NgtDpr>([1, 2]);\n\traycaster = input<Partial<Raycaster>>();\n\tscene = input<Scene | Partial<Scene>>();\n\tcamera = input<NonNullable<NgtCanvasOptions['camera']>>();\n\tevents = input(createPointerEvents);\n\teventSource = input<HTMLElement | ElementRef<HTMLElement>>();\n\teventPrefix = input<NonNullable<NgtCanvasOptions['eventPrefix']>>('offset');\n\tlookAt = input<Vector3 | Parameters<Vector3['set']>>();\n\tcreated = output<NgtState>();\n\tpointerMissed = outputFromObservable(this.store.get('pointerMissed$'));\n\n\tglCanvas = viewChild.required<ElementRef<HTMLCanvasElement>>('glCanvas');\n\tglCanvasViewContainerRef = viewChild.required('glCanvas', { read: ViewContainerRef });\n\n\t// NOTE: this signal is updated outside of Zone\n\tprotected resizeResult = signal<ResizeResult>({} as ResizeResult, { equal: Object.is });\n\tprotected hbPointerEvents = computed(() => (this.eventSource() ? 'none' : 'auto'));\n\n\tprivate configurator?: NgtCanvasConfigurator;\n\tprivate glEnvironmentInjector?: EnvironmentInjector;\n\tprivate glRef?: ComponentRef<unknown>;\n\n\tconstructor() {\n\t\tafterNextRender(() => {\n\t\t\tthis.zone.runOutsideAngular(() => {\n\t\t\t\tthis.configurator = this.initRoot(this.glCanvas().nativeElement);\n\t\t\t\tthis.noZoneResizeEffect();\n\t\t\t});\n\t\t});\n\n\t\tinject(DestroyRef).onDestroy(() => {\n\t\t\tthis.glRef?.destroy();\n\t\t\tthis.glEnvironmentInjector?.destroy();\n\t\t\tthis.configurator?.destroy();\n\t\t});\n\t}\n\n\tprivate noZoneResizeEffect() {\n\t\tthis.autoEffect(() => {\n\t\t\tconst resizeResult = this.resizeResult();\n\t\t\tif (resizeResult.width > 0 && resizeResult.height > 0) {\n\t\t\t\tif (!this.configurator) this.configurator = this.initRoot(this.glCanvas().nativeElement);\n\t\t\t\tthis.configurator.configure({\n\t\t\t\t\tgl: this.gl(),\n\t\t\t\t\tshadows: this.shadows(),\n\t\t\t\t\tlegacy: this.legacy(),\n\t\t\t\t\tlinear: this.linear(),\n\t\t\t\t\tflat: this.flat(),\n\t\t\t\t\torthographic: this.orthographic(),\n\t\t\t\t\tframeloop: this.frameloop(),\n\t\t\t\t\tperformance: this.performance(),\n\t\t\t\t\tdpr: this.dpr(),\n\t\t\t\t\traycaster: this.raycaster(),\n\t\t\t\t\tscene: this.scene(),\n\t\t\t\t\tcamera: this.camera(),\n\t\t\t\t\tevents: this.events(),\n\t\t\t\t\teventSource: this.eventSource(),\n\t\t\t\t\teventPrefix: this.eventPrefix(),\n\t\t\t\t\tlookAt: this.lookAt(),\n\t\t\t\t\tsize: resizeResult,\n\t\t\t\t});\n\n\t\t\t\tuntracked(() => {\n\t\t\t\t\tif (this.glRef) {\n\t\t\t\t\t\tthis.glRef.changeDetectorRef.detectChanges();\n\t\t\t\t\t} else {\n\t\t\t\t\t\tthis.noZoneRender();\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t}\n\t\t});\n\t}\n\n\tprivate noZoneRender() {\n\t\t// NOTE: destroy previous instances if existed\n\t\tthis.glEnvironmentInjector?.destroy();\n\t\tthis.glRef?.destroy();\n\n\t\t// NOTE: Flag the canvas active, rendering will now begin\n\t\tthis.store.update((state) => ({ internal: { ...state.internal, active: true } }));\n\n\t\tconst [state, eventSource, eventPrefix] = [\n\t\t\tthis.store.snapshot,\n\t\t\tuntracked(this.eventSource),\n\t\t\tuntracked(this.eventPrefix),\n\t\t];\n\n\t\t// connect to event source\n\t\tstate.events.connect?.(\n\t\t\teventSource ? (is.ref(eventSource) ? eventSource.nativeElement : eventSource) : this.host.nativeElement,\n\t\t);\n\n\t\t// setup compute for eventPrefix\n\t\tif (eventPrefix) {\n\t\t\tstate.setEvents({\n\t\t\t\tcompute: (event, store) => {\n\t\t\t\t\tconst { pointer, raycaster, camera, size } = store.snapshot;\n\t\t\t\t\tconst x = event[(eventPrefix + 'X') as keyof NgtDomEvent] as number;\n\t\t\t\t\tconst y = event[(eventPrefix + 'Y') as keyof NgtDomEvent] as number;\n\t\t\t\t\tpointer.set((x / size.width) * 2 - 1, -(y / size.height) * 2 + 1);\n\t\t\t\t\traycaster.setFromCamera(pointer, camera);\n\t\t\t\t},\n\t\t\t});\n\t\t}\n\n\t\t// emit created event if observed\n\t\tthis.created.emit(this.store.snapshot);\n\n\t\tif (!this.store.get('events', 'connected')) {\n\t\t\tthis.store.get('events').connect?.(untracked(this.glCanvas).nativeElement);\n\t\t}\n\n\t\tuntracked(() => {\n\t\t\tthis.glEnvironmentInjector = createEnvironmentInjector(\n\t\t\t\t[provideNgtRenderer(this.store)],\n\t\t\t\tthis.environmentInjector,\n\t\t\t);\n\t\t\tthis.glRef = this.viewContainerRef.createComponent(untracked(this.sceneGraph), {\n\t\t\t\tenvironmentInjector: this.glEnvironmentInjector,\n\t\t\t\tinjector: this.injector,\n\t\t\t});\n\n\t\t\tthis.glRef.changeDetectorRef.detectChanges();\n\t\t});\n\t}\n}\n"]}
|
|
@@ -1,19 +1,38 @@
|
|
|
1
|
-
import { Directive,
|
|
2
|
-
import {
|
|
1
|
+
import { afterNextRender, DestroyRef, Directive, inject, input, NgZone, TemplateRef, untracked, ViewContainerRef, } from '@angular/core';
|
|
2
|
+
import { injectAutoEffect } from 'ngxtension/auto-effect';
|
|
3
|
+
import { SPECIAL_INTERNAL_ADD_COMMENT } from '../renderer/constants';
|
|
3
4
|
import * as i0 from "@angular/core";
|
|
4
|
-
export class NgtArgs
|
|
5
|
+
export class NgtArgs {
|
|
5
6
|
constructor() {
|
|
6
|
-
|
|
7
|
-
this.
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
return;
|
|
7
|
+
this.args = input.required();
|
|
8
|
+
this.vcr = inject(ViewContainerRef);
|
|
9
|
+
this.zone = inject(NgZone);
|
|
10
|
+
this.template = inject(TemplateRef);
|
|
11
|
+
this.autoEffect = injectAutoEffect();
|
|
12
12
|
this.injected = false;
|
|
13
|
-
this.injectedArgs =
|
|
14
|
-
this.
|
|
13
|
+
this.injectedArgs = null;
|
|
14
|
+
const commentNode = this.vcr.element.nativeElement;
|
|
15
|
+
if (commentNode[SPECIAL_INTERNAL_ADD_COMMENT]) {
|
|
16
|
+
commentNode[SPECIAL_INTERNAL_ADD_COMMENT]('args');
|
|
17
|
+
delete commentNode[SPECIAL_INTERNAL_ADD_COMMENT];
|
|
18
|
+
}
|
|
19
|
+
afterNextRender(() => {
|
|
20
|
+
this.autoEffect(() => {
|
|
21
|
+
const value = this.args();
|
|
22
|
+
if (value == null || !Array.isArray(value) || (value.length === 1 && value[0] === null))
|
|
23
|
+
return;
|
|
24
|
+
this.injected = false;
|
|
25
|
+
this.injectedArgs = value;
|
|
26
|
+
untracked(() => {
|
|
27
|
+
this.createView();
|
|
28
|
+
});
|
|
29
|
+
});
|
|
30
|
+
});
|
|
31
|
+
inject(DestroyRef).onDestroy(() => {
|
|
32
|
+
this.view?.destroy();
|
|
33
|
+
});
|
|
15
34
|
}
|
|
16
|
-
get
|
|
35
|
+
get value() {
|
|
17
36
|
if (this.validate()) {
|
|
18
37
|
this.injected = true;
|
|
19
38
|
return this.injectedArgs;
|
|
@@ -21,15 +40,22 @@ export class NgtArgs extends NgtCommonDirective {
|
|
|
21
40
|
return null;
|
|
22
41
|
}
|
|
23
42
|
validate() {
|
|
24
|
-
return !this.injected && !!this.injectedArgs
|
|
43
|
+
return !this.injected && !!this.injectedArgs?.length;
|
|
44
|
+
}
|
|
45
|
+
createView() {
|
|
46
|
+
this.zone.runOutsideAngular(() => {
|
|
47
|
+
if (this.view && !this.view.destroyed) {
|
|
48
|
+
this.view.destroy();
|
|
49
|
+
}
|
|
50
|
+
this.view = this.vcr.createEmbeddedView(this.template);
|
|
51
|
+
this.view.detectChanges();
|
|
52
|
+
});
|
|
25
53
|
}
|
|
26
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
27
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "
|
|
54
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.2", ngImport: i0, type: NgtArgs, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
55
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.1.2", type: NgtArgs, isStandalone: true, selector: "ng-template[args]", inputs: { args: { classPropertyName: "args", publicName: "args", isSignal: true, isRequired: true, transformFunction: null } }, ngImport: i0 }); }
|
|
28
56
|
}
|
|
29
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
57
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.2", ngImport: i0, type: NgtArgs, decorators: [{
|
|
30
58
|
type: Directive,
|
|
31
59
|
args: [{ selector: 'ng-template[args]', standalone: true }]
|
|
32
|
-
}],
|
|
33
|
-
|
|
34
|
-
}] } });
|
|
35
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXJncy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29yZS9zcmMvbGliL2RpcmVjdGl2ZXMvYXJncy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNqRCxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxVQUFVLENBQUM7O0FBRzlDLE1BQU0sT0FBTyxPQUFxQyxTQUFRLGtCQUFrQjtJQUQ1RTs7UUFFUyxpQkFBWSxHQUFVLEVBQXNCLENBQUM7S0FvQnJEO0lBbEJBLElBQWEsSUFBSSxDQUFDLElBQWtCO1FBQ25DLElBQUksSUFBSSxJQUFJLElBQUksSUFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsTUFBTSxLQUFLLENBQUMsSUFBSSxJQUFJLENBQUMsQ0FBQyxDQUFDLEtBQUssSUFBSSxDQUFDO1lBQUUsT0FBTztRQUM1RixJQUFJLENBQUMsUUFBUSxHQUFHLEtBQUssQ0FBQztRQUN0QixJQUFJLENBQUMsWUFBWSxHQUFHLElBQUksQ0FBQztRQUN6QixJQUFJLENBQUMsVUFBVSxFQUFFLENBQUM7SUFDbkIsQ0FBQztJQUVELElBQUksSUFBSTtRQUNQLElBQUksSUFBSSxDQUFDLFFBQVEsRUFBRSxFQUFFO1lBQ3BCLElBQUksQ0FBQyxRQUFRLEdBQUcsSUFBSSxDQUFDO1lBQ3JCLE9BQU8sSUFBSSxDQUFDLFlBQVksQ0FBQztTQUN6QjtRQUNELE9BQU8sSUFBSSxDQUFDO0lBQ2IsQ0FBQztJQUVELFFBQVE7UUFDUCxPQUFPLENBQUMsSUFBSSxDQUFDLFFBQVEsSUFBSSxDQUFDLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxNQUFNLENBQUM7SUFDckQsQ0FBQzs4R0FwQlcsT0FBTztrR0FBUCxPQUFPOzsyRkFBUCxPQUFPO2tCQURuQixTQUFTO21CQUFDLEVBQUUsUUFBUSxFQUFFLG1CQUFtQixFQUFFLFVBQVUsRUFBRSxJQUFJLEVBQUU7OEJBSWhELElBQUk7c0JBQWhCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBOZ3RDb21tb25EaXJlY3RpdmUgfSBmcm9tICcuL2NvbW1vbic7XG5cbkBEaXJlY3RpdmUoeyBzZWxlY3RvcjogJ25nLXRlbXBsYXRlW2FyZ3NdJywgc3RhbmRhbG9uZTogdHJ1ZSB9KVxuZXhwb3J0IGNsYXNzIE5ndEFyZ3M8VEFyZ3MgZXh0ZW5kcyBhbnlbXSA9IGFueVtdPiBleHRlbmRzIE5ndENvbW1vbkRpcmVjdGl2ZSB7XG5cdHByaXZhdGUgaW5qZWN0ZWRBcmdzOiBUQXJncyA9IFtdIGFzIHVua25vd24gYXMgVEFyZ3M7XG5cblx0QElucHV0KCkgc2V0IGFyZ3MoYXJnczogVEFyZ3MgfCBudWxsKSB7XG5cdFx0aWYgKGFyZ3MgPT0gbnVsbCB8fCAhQXJyYXkuaXNBcnJheShhcmdzKSB8fCAoYXJncy5sZW5ndGggPT09IDEgJiYgYXJnc1swXSA9PT0gbnVsbCkpIHJldHVybjtcblx0XHR0aGlzLmluamVjdGVkID0gZmFsc2U7XG5cdFx0dGhpcy5pbmplY3RlZEFyZ3MgPSBhcmdzO1xuXHRcdHRoaXMuY3JlYXRlVmlldygpO1xuXHR9XG5cblx0Z2V0IGFyZ3MoKSB7XG5cdFx0aWYgKHRoaXMudmFsaWRhdGUoKSkge1xuXHRcdFx0dGhpcy5pbmplY3RlZCA9IHRydWU7XG5cdFx0XHRyZXR1cm4gdGhpcy5pbmplY3RlZEFyZ3M7XG5cdFx0fVxuXHRcdHJldHVybiBudWxsO1xuXHR9XG5cblx0dmFsaWRhdGUoKSB7XG5cdFx0cmV0dXJuICF0aGlzLmluamVjdGVkICYmICEhdGhpcy5pbmplY3RlZEFyZ3MubGVuZ3RoO1xuXHR9XG59XG4iXX0=
|
|
60
|
+
}], ctorParameters: () => [] });
|
|
61
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXJncy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29yZS9zcmMvbGliL2RpcmVjdGl2ZXMvYXJncy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ04sZUFBZSxFQUNmLFVBQVUsRUFDVixTQUFTLEVBRVQsTUFBTSxFQUNOLEtBQUssRUFDTCxNQUFNLEVBQ04sV0FBVyxFQUNYLFNBQVMsRUFDVCxnQkFBZ0IsR0FDaEIsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDMUQsT0FBTyxFQUFFLDRCQUE0QixFQUFFLE1BQU0sdUJBQXVCLENBQUM7O0FBR3JFLE1BQU0sT0FBTyxPQUFPO0lBWW5CO1FBWEEsU0FBSSxHQUFHLEtBQUssQ0FBQyxRQUFRLEVBQWdCLENBQUM7UUFFOUIsUUFBRyxHQUFHLE1BQU0sQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO1FBQy9CLFNBQUksR0FBRyxNQUFNLENBQUMsTUFBTSxDQUFDLENBQUM7UUFDdEIsYUFBUSxHQUFHLE1BQU0sQ0FBQyxXQUFXLENBQUMsQ0FBQztRQUMvQixlQUFVLEdBQUcsZ0JBQWdCLEVBQUUsQ0FBQztRQUU5QixhQUFRLEdBQUcsS0FBSyxDQUFDO1FBQ2pCLGlCQUFZLEdBQWlCLElBQUksQ0FBQztRQUkzQyxNQUFNLFdBQVcsR0FBRyxJQUFJLENBQUMsR0FBRyxDQUFDLE9BQU8sQ0FBQyxhQUFhLENBQUM7UUFDbkQsSUFBSSxXQUFXLENBQUMsNEJBQTRCLENBQUMsRUFBRSxDQUFDO1lBQy9DLFdBQVcsQ0FBQyw0QkFBNEIsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxDQUFDO1lBQ2xELE9BQU8sV0FBVyxDQUFDLDRCQUE0QixDQUFDLENBQUM7UUFDbEQsQ0FBQztRQUVELGVBQWUsQ0FBQyxHQUFHLEVBQUU7WUFDcEIsSUFBSSxDQUFDLFVBQVUsQ0FBQyxHQUFHLEVBQUU7Z0JBQ3BCLE1BQU0sS0FBSyxHQUFHLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztnQkFDMUIsSUFBSSxLQUFLLElBQUksSUFBSSxJQUFJLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLEtBQUssQ0FBQyxJQUFJLEtBQUssQ0FBQyxDQUFDLENBQUMsS0FBSyxJQUFJLENBQUM7b0JBQUUsT0FBTztnQkFDaEcsSUFBSSxDQUFDLFFBQVEsR0FBRyxLQUFLLENBQUM7Z0JBQ3RCLElBQUksQ0FBQyxZQUFZLEdBQUcsS0FBSyxDQUFDO2dCQUMxQixTQUFTLENBQUMsR0FBRyxFQUFFO29CQUNkLElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQztnQkFDbkIsQ0FBQyxDQUFDLENBQUM7WUFDSixDQUFDLENBQUMsQ0FBQztRQUNKLENBQUMsQ0FBQyxDQUFDO1FBRUgsTUFBTSxDQUFDLFVBQVUsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxHQUFHLEVBQUU7WUFDakMsSUFBSSxDQUFDLElBQUksRUFBRSxPQUFPLEVBQUUsQ0FBQztRQUN0QixDQUFDLENBQUMsQ0FBQztJQUNKLENBQUM7SUFFRCxJQUFJLEtBQUs7UUFDUixJQUFJLElBQUksQ0FBQyxRQUFRLEVBQUUsRUFBRSxDQUFDO1lBQ3JCLElBQUksQ0FBQyxRQUFRLEdBQUcsSUFBSSxDQUFDO1lBQ3JCLE9BQU8sSUFBSSxDQUFDLFlBQVksQ0FBQztRQUMxQixDQUFDO1FBQ0QsT0FBTyxJQUFJLENBQUM7SUFDYixDQUFDO0lBRUQsUUFBUTtRQUNQLE9BQU8sQ0FBQyxJQUFJLENBQUMsUUFBUSxJQUFJLENBQUMsQ0FBQyxJQUFJLENBQUMsWUFBWSxFQUFFLE1BQU0sQ0FBQztJQUN0RCxDQUFDO0lBRU8sVUFBVTtRQUNqQixJQUFJLENBQUMsSUFBSSxDQUFDLGlCQUFpQixDQUFDLEdBQUcsRUFBRTtZQUNoQyxJQUFJLElBQUksQ0FBQyxJQUFJLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDO2dCQUN2QyxJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFDO1lBQ3JCLENBQUM7WUFDRCxJQUFJLENBQUMsSUFBSSxHQUFHLElBQUksQ0FBQyxHQUFHLENBQUMsa0JBQWtCLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDO1lBQ3ZELElBQUksQ0FBQyxJQUFJLENBQUMsYUFBYSxFQUFFLENBQUM7UUFDM0IsQ0FBQyxDQUFDLENBQUM7SUFDSixDQUFDOzhHQXhEVyxPQUFPO2tHQUFQLE9BQU87OzJGQUFQLE9BQU87a0JBRG5CLFNBQVM7bUJBQUMsRUFBRSxRQUFRLEVBQUUsbUJBQW1CLEVBQUUsVUFBVSxFQUFFLElBQUksRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG5cdGFmdGVyTmV4dFJlbmRlcixcblx0RGVzdHJveVJlZixcblx0RGlyZWN0aXZlLFxuXHRFbWJlZGRlZFZpZXdSZWYsXG5cdGluamVjdCxcblx0aW5wdXQsXG5cdE5nWm9uZSxcblx0VGVtcGxhdGVSZWYsXG5cdHVudHJhY2tlZCxcblx0Vmlld0NvbnRhaW5lclJlZixcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBpbmplY3RBdXRvRWZmZWN0IH0gZnJvbSAnbmd4dGVuc2lvbi9hdXRvLWVmZmVjdCc7XG5pbXBvcnQgeyBTUEVDSUFMX0lOVEVSTkFMX0FERF9DT01NRU5UIH0gZnJvbSAnLi4vcmVuZGVyZXIvY29uc3RhbnRzJztcblxuQERpcmVjdGl2ZSh7IHNlbGVjdG9yOiAnbmctdGVtcGxhdGVbYXJnc10nLCBzdGFuZGFsb25lOiB0cnVlIH0pXG5leHBvcnQgY2xhc3MgTmd0QXJncyB7XG5cdGFyZ3MgPSBpbnB1dC5yZXF1aXJlZDxhbnlbXSB8IG51bGw+KCk7XG5cblx0cHJpdmF0ZSB2Y3IgPSBpbmplY3QoVmlld0NvbnRhaW5lclJlZik7XG5cdHByaXZhdGUgem9uZSA9IGluamVjdChOZ1pvbmUpO1xuXHRwcml2YXRlIHRlbXBsYXRlID0gaW5qZWN0KFRlbXBsYXRlUmVmKTtcblx0cHJpdmF0ZSBhdXRvRWZmZWN0ID0gaW5qZWN0QXV0b0VmZmVjdCgpO1xuXG5cdHByb3RlY3RlZCBpbmplY3RlZCA9IGZhbHNlO1xuXHRwcm90ZWN0ZWQgaW5qZWN0ZWRBcmdzOiBhbnlbXSB8IG51bGwgPSBudWxsO1xuXHRwcml2YXRlIHZpZXc/OiBFbWJlZGRlZFZpZXdSZWY8dW5rbm93bj47XG5cblx0Y29uc3RydWN0b3IoKSB7XG5cdFx0Y29uc3QgY29tbWVudE5vZGUgPSB0aGlzLnZjci5lbGVtZW50Lm5hdGl2ZUVsZW1lbnQ7XG5cdFx0aWYgKGNvbW1lbnROb2RlW1NQRUNJQUxfSU5URVJOQUxfQUREX0NPTU1FTlRdKSB7XG5cdFx0XHRjb21tZW50Tm9kZVtTUEVDSUFMX0lOVEVSTkFMX0FERF9DT01NRU5UXSgnYXJncycpO1xuXHRcdFx0ZGVsZXRlIGNvbW1lbnROb2RlW1NQRUNJQUxfSU5URVJOQUxfQUREX0NPTU1FTlRdO1xuXHRcdH1cblxuXHRcdGFmdGVyTmV4dFJlbmRlcigoKSA9PiB7XG5cdFx0XHR0aGlzLmF1dG9FZmZlY3QoKCkgPT4ge1xuXHRcdFx0XHRjb25zdCB2YWx1ZSA9IHRoaXMuYXJncygpO1xuXHRcdFx0XHRpZiAodmFsdWUgPT0gbnVsbCB8fCAhQXJyYXkuaXNBcnJheSh2YWx1ZSkgfHwgKHZhbHVlLmxlbmd0aCA9PT0gMSAmJiB2YWx1ZVswXSA9PT0gbnVsbCkpIHJldHVybjtcblx0XHRcdFx0dGhpcy5pbmplY3RlZCA9IGZhbHNlO1xuXHRcdFx0XHR0aGlzLmluamVjdGVkQXJncyA9IHZhbHVlO1xuXHRcdFx0XHR1bnRyYWNrZWQoKCkgPT4ge1xuXHRcdFx0XHRcdHRoaXMuY3JlYXRlVmlldygpO1xuXHRcdFx0XHR9KTtcblx0XHRcdH0pO1xuXHRcdH0pO1xuXG5cdFx0aW5qZWN0KERlc3Ryb3lSZWYpLm9uRGVzdHJveSgoKSA9PiB7XG5cdFx0XHR0aGlzLnZpZXc/LmRlc3Ryb3koKTtcblx0XHR9KTtcblx0fVxuXG5cdGdldCB2YWx1ZSgpIHtcblx0XHRpZiAodGhpcy52YWxpZGF0ZSgpKSB7XG5cdFx0XHR0aGlzLmluamVjdGVkID0gdHJ1ZTtcblx0XHRcdHJldHVybiB0aGlzLmluamVjdGVkQXJncztcblx0XHR9XG5cdFx0cmV0dXJuIG51bGw7XG5cdH1cblxuXHR2YWxpZGF0ZSgpIHtcblx0XHRyZXR1cm4gIXRoaXMuaW5qZWN0ZWQgJiYgISF0aGlzLmluamVjdGVkQXJncz8ubGVuZ3RoO1xuXHR9XG5cblx0cHJpdmF0ZSBjcmVhdGVWaWV3KCkge1xuXHRcdHRoaXMuem9uZS5ydW5PdXRzaWRlQW5ndWxhcigoKSA9PiB7XG5cdFx0XHRpZiAodGhpcy52aWV3ICYmICF0aGlzLnZpZXcuZGVzdHJveWVkKSB7XG5cdFx0XHRcdHRoaXMudmlldy5kZXN0cm95KCk7XG5cdFx0XHR9XG5cdFx0XHR0aGlzLnZpZXcgPSB0aGlzLnZjci5jcmVhdGVFbWJlZGRlZFZpZXcodGhpcy50ZW1wbGF0ZSk7XG5cdFx0XHR0aGlzLnZpZXcuZGV0ZWN0Q2hhbmdlcygpO1xuXHRcdH0pO1xuXHR9XG59XG4iXX0=
|