angular-three 2.13.0 → 3.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/fesm2022/angular-three-nativescript.mjs +3 -3
- package/fesm2022/angular-three-nativescript.mjs.map +1 -1
- package/fesm2022/angular-three-testing.mjs +12 -14
- package/fesm2022/angular-three-testing.mjs.map +1 -1
- package/fesm2022/angular-three.mjs +123 -106
- package/fesm2022/angular-three.mjs.map +1 -1
- package/lib/canvas.d.ts +7 -7
- package/lib/html.d.ts +2 -2
- package/lib/portal.d.ts +2 -2
- package/lib/routed-scene.d.ts +8 -2
- package/lib/utils/object-events.d.ts +0 -19
- package/package.json +4 -10
- package/plugin/src/generators/init/schema.json +8 -8
- package/testing/lib/utils/web-gl-rendering-context.d.ts +1 -1
- package/esm2022/angular-three.mjs +0 -5
- package/esm2022/index.mjs +0 -25
- package/esm2022/lib/canvas.mjs +0 -188
- package/esm2022/lib/directives/args.mjs +0 -53
- package/esm2022/lib/directives/selection.mjs +0 -69
- package/esm2022/lib/dom/events.mjs +0 -73
- package/esm2022/lib/events.mjs +0 -361
- package/esm2022/lib/html.mjs +0 -44
- package/esm2022/lib/instance.mjs +0 -83
- package/esm2022/lib/loader.mjs +0 -93
- package/esm2022/lib/loop.mjs +0 -141
- package/esm2022/lib/pipes/hexify.mjs +0 -86
- package/esm2022/lib/portal.mjs +0 -220
- package/esm2022/lib/renderer/catalogue.mjs +0 -7
- package/esm2022/lib/renderer/constants.mjs +0 -23
- package/esm2022/lib/renderer/index.mjs +0 -544
- package/esm2022/lib/renderer/state.mjs +0 -54
- package/esm2022/lib/renderer/utils.mjs +0 -223
- package/esm2022/lib/roots.mjs +0 -275
- package/esm2022/lib/routed-scene.mjs +0 -33
- package/esm2022/lib/store.mjs +0 -176
- package/esm2022/lib/three-types.mjs +0 -2
- package/esm2022/lib/types.mjs +0 -2
- package/esm2022/lib/utils/apply-props.mjs +0 -130
- package/esm2022/lib/utils/attach.mjs +0 -46
- package/esm2022/lib/utils/before-render.mjs +0 -41
- package/esm2022/lib/utils/is.mjs +0 -52
- package/esm2022/lib/utils/make.mjs +0 -52
- package/esm2022/lib/utils/object-events.mjs +0 -137
- package/esm2022/lib/utils/output-ref.mjs +0 -9
- package/esm2022/lib/utils/parameters.mjs +0 -70
- package/esm2022/lib/utils/resolve-ref.mjs +0 -8
- package/esm2022/lib/utils/signal-store.mjs +0 -90
- package/esm2022/lib/utils/update.mjs +0 -37
- package/esm2022/nativescript/angular-three-nativescript.mjs +0 -5
- package/esm2022/nativescript/index.mjs +0 -2
- package/esm2022/nativescript/lib/canvas.mjs +0 -127
- package/esm2022/testing/angular-three-testing.mjs +0 -5
- package/esm2022/testing/index.mjs +0 -3
- package/esm2022/testing/lib/test-bed.mjs +0 -130
- package/esm2022/testing/lib/test-canvas.mjs +0 -45
- package/esm2022/testing/lib/utils/mock-canvas.mjs +0 -37
- package/esm2022/testing/lib/utils/web-gl-rendering-context.mjs +0 -752
|
@@ -1,137 +0,0 @@
|
|
|
1
|
-
import { DestroyRef, Directive, effect, inject, model, output, Renderer2 } from '@angular/core';
|
|
2
|
-
import { assertInjector } from 'ngxtension/assert-injector';
|
|
3
|
-
import { resolveRef } from './resolve-ref';
|
|
4
|
-
import * as i0 from "@angular/core";
|
|
5
|
-
/**
|
|
6
|
-
* As host directive:
|
|
7
|
-
* - outputs: [
|
|
8
|
-
* 'click',
|
|
9
|
-
* 'dblclick',
|
|
10
|
-
* 'contextmenu',
|
|
11
|
-
* 'pointerup',
|
|
12
|
-
* 'pointerdown',
|
|
13
|
-
* 'pointerover',
|
|
14
|
-
* 'pointerout',
|
|
15
|
-
* 'pointerenter',
|
|
16
|
-
* 'pointerleave',
|
|
17
|
-
* 'pointermove',
|
|
18
|
-
* 'pointermissed',
|
|
19
|
-
* 'pointercancel',
|
|
20
|
-
* 'wheel',
|
|
21
|
-
* ]
|
|
22
|
-
* - inputs: [
|
|
23
|
-
* 'ngtObjectEvents'
|
|
24
|
-
* ]
|
|
25
|
-
*/
|
|
26
|
-
export class NgtObjectEvents {
|
|
27
|
-
constructor() {
|
|
28
|
-
this.click = output();
|
|
29
|
-
this.dblclick = output();
|
|
30
|
-
this.contextmenu = output();
|
|
31
|
-
this.pointerup = output();
|
|
32
|
-
this.pointerdown = output();
|
|
33
|
-
this.pointerover = output();
|
|
34
|
-
this.pointerout = output();
|
|
35
|
-
this.pointerenter = output();
|
|
36
|
-
this.pointerleave = output();
|
|
37
|
-
this.pointermove = output();
|
|
38
|
-
this.pointermissed = output();
|
|
39
|
-
this.pointercancel = output();
|
|
40
|
-
this.wheel = output();
|
|
41
|
-
// NOTE: we use model here to allow for the hostDirective host to set this value
|
|
42
|
-
this.ngtObjectEvents = model();
|
|
43
|
-
injectObjectEvents(this.ngtObjectEvents, {
|
|
44
|
-
click: this.emitEvent('click'),
|
|
45
|
-
dblclick: this.emitEvent('dblclick'),
|
|
46
|
-
contextmenu: this.emitEvent('contextmenu'),
|
|
47
|
-
pointerup: this.emitEvent('pointerup'),
|
|
48
|
-
pointerdown: this.emitEvent('pointerdown'),
|
|
49
|
-
pointerover: this.emitEvent('pointerover'),
|
|
50
|
-
pointerout: this.emitEvent('pointerout'),
|
|
51
|
-
pointerenter: this.emitEvent('pointerenter'),
|
|
52
|
-
pointerleave: this.emitEvent('pointerleave'),
|
|
53
|
-
pointermove: this.emitEvent('pointermove'),
|
|
54
|
-
pointermissed: this.emitEvent('pointermissed'),
|
|
55
|
-
pointercancel: this.emitEvent('pointercancel'),
|
|
56
|
-
wheel: this.emitEvent('wheel'),
|
|
57
|
-
});
|
|
58
|
-
}
|
|
59
|
-
emitEvent(eventName) {
|
|
60
|
-
return this[eventName].emit.bind(this[eventName]);
|
|
61
|
-
}
|
|
62
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: NgtObjectEvents, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
63
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.2.11", type: NgtObjectEvents, isStandalone: true, selector: "[ngtObjectEvents]", inputs: { ngtObjectEvents: { classPropertyName: "ngtObjectEvents", publicName: "ngtObjectEvents", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { click: "click", dblclick: "dblclick", contextmenu: "contextmenu", pointerup: "pointerup", pointerdown: "pointerdown", pointerover: "pointerover", pointerout: "pointerout", pointerenter: "pointerenter", pointerleave: "pointerleave", pointermove: "pointermove", pointermissed: "pointermissed", pointercancel: "pointercancel", wheel: "wheel", ngtObjectEvents: "ngtObjectEventsChange" }, ngImport: i0 }); }
|
|
64
|
-
}
|
|
65
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: NgtObjectEvents, decorators: [{
|
|
66
|
-
type: Directive,
|
|
67
|
-
args: [{ standalone: true, selector: '[ngtObjectEvents]' }]
|
|
68
|
-
}], ctorParameters: () => [] });
|
|
69
|
-
/**
|
|
70
|
-
* @deprecated this has never worked. Use `NgtObjectEvents` and explicit value for inputs and outputs instead
|
|
71
|
-
* @since 2.12.0 Will be removed in 3.0.0
|
|
72
|
-
*/
|
|
73
|
-
export const NgtObjectEventsInputs = ['ngtObjectEvents'];
|
|
74
|
-
/**
|
|
75
|
-
* @deprecated this has never worked. Use `NgtObjectEvents` and explicit value for inputs and outputs instead
|
|
76
|
-
* @since 2.12.0 Will be removed in 3.0.0
|
|
77
|
-
*/
|
|
78
|
-
export const NgtObjectEventsOutputs = [
|
|
79
|
-
'click',
|
|
80
|
-
'dblclick',
|
|
81
|
-
'contextmenu',
|
|
82
|
-
'pointerup',
|
|
83
|
-
'pointerdown',
|
|
84
|
-
'pointerover',
|
|
85
|
-
'pointerout',
|
|
86
|
-
'pointerenter',
|
|
87
|
-
'pointerleave',
|
|
88
|
-
'pointermove',
|
|
89
|
-
'pointermissed',
|
|
90
|
-
'pointercancel',
|
|
91
|
-
'wheel',
|
|
92
|
-
];
|
|
93
|
-
/**
|
|
94
|
-
* @deprecated Use NgtObjectEventsInputs and NgtObjectEventsOutputs instead along with NgtObjectEvents
|
|
95
|
-
* @since 2.6.0 Will be removed in 3.0.0
|
|
96
|
-
*/
|
|
97
|
-
export const NgtObjectEventsHostDirective = {
|
|
98
|
-
directive: NgtObjectEvents,
|
|
99
|
-
inputs: ['ngtObjectEvents'],
|
|
100
|
-
outputs: [
|
|
101
|
-
'click',
|
|
102
|
-
'dblclick',
|
|
103
|
-
'contextmenu',
|
|
104
|
-
'pointerup',
|
|
105
|
-
'pointerdown',
|
|
106
|
-
'pointerover',
|
|
107
|
-
'pointerout',
|
|
108
|
-
'pointerenter',
|
|
109
|
-
'pointerleave',
|
|
110
|
-
'pointermove',
|
|
111
|
-
'pointermissed',
|
|
112
|
-
'pointercancel',
|
|
113
|
-
'wheel',
|
|
114
|
-
],
|
|
115
|
-
};
|
|
116
|
-
export function injectObjectEvents(target, events, { injector } = {}) {
|
|
117
|
-
return assertInjector(injectObjectEvents, injector, () => {
|
|
118
|
-
const renderer = inject(Renderer2);
|
|
119
|
-
const cleanUps = [];
|
|
120
|
-
effect((onCleanup) => {
|
|
121
|
-
const targetRef = resolveRef(target());
|
|
122
|
-
if (!targetRef)
|
|
123
|
-
return;
|
|
124
|
-
Object.entries(events).forEach(([eventName, eventHandler]) => {
|
|
125
|
-
cleanUps.push(renderer.listen(targetRef, eventName, eventHandler));
|
|
126
|
-
});
|
|
127
|
-
onCleanup(() => {
|
|
128
|
-
cleanUps.forEach((cleanUp) => cleanUp());
|
|
129
|
-
});
|
|
130
|
-
});
|
|
131
|
-
inject(DestroyRef).onDestroy(() => {
|
|
132
|
-
cleanUps.forEach((cleanUp) => cleanUp());
|
|
133
|
-
});
|
|
134
|
-
return cleanUps;
|
|
135
|
-
});
|
|
136
|
-
}
|
|
137
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"object-events.js","sourceRoot":"","sources":["../../../../../../libs/core/src/lib/utils/object-events.ts"],"names":[],"mappings":"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","sourcesContent":["import { DestroyRef, Directive, effect, ElementRef, inject, Injector, model, output, Renderer2 } from '@angular/core';\nimport { assertInjector } from 'ngxtension/assert-injector';\nimport { Object3D } from 'three';\nimport { NgtEventHandlers, NgtThreeEvent } from '../types';\nimport { resolveRef } from './resolve-ref';\n\n@Directive({ standalone: true, selector: '[ngtObjectEvents]' })\n/**\n * As host directive:\n * - outputs: [\n * 'click',\n * 'dblclick',\n * 'contextmenu',\n * 'pointerup',\n * 'pointerdown',\n * 'pointerover',\n * 'pointerout',\n * 'pointerenter',\n * 'pointerleave',\n * 'pointermove',\n * 'pointermissed',\n * 'pointercancel',\n * 'wheel',\n * ]\n * - inputs: [\n *   'ngtObjectEvents'\n *   ]\n */\nexport class NgtObjectEvents {\n\tclick = output<NgtThreeEvent<MouseEvent>>();\n\tdblclick = output<NgtThreeEvent<MouseEvent>>();\n\tcontextmenu = output<NgtThreeEvent<MouseEvent>>();\n\tpointerup = output<NgtThreeEvent<PointerEvent>>();\n\tpointerdown = output<NgtThreeEvent<PointerEvent>>();\n\tpointerover = output<NgtThreeEvent<PointerEvent>>();\n\tpointerout = output<NgtThreeEvent<PointerEvent>>();\n\tpointerenter = output<NgtThreeEvent<PointerEvent>>();\n\tpointerleave = output<NgtThreeEvent<PointerEvent>>();\n\tpointermove = output<NgtThreeEvent<PointerEvent>>();\n\tpointermissed = output<NgtThreeEvent<MouseEvent>>();\n\tpointercancel = output<NgtThreeEvent<PointerEvent>>();\n\twheel = output<NgtThreeEvent<WheelEvent>>();\n\n\t// NOTE: we use model here to allow for the hostDirective host to set this value\n\tngtObjectEvents = model<ElementRef<Object3D> | Object3D | null | undefined>();\n\n\tconstructor() {\n\t\tinjectObjectEvents(this.ngtObjectEvents, {\n\t\t\tclick: this.emitEvent('click'),\n\t\t\tdblclick: this.emitEvent('dblclick'),\n\t\t\tcontextmenu: this.emitEvent('contextmenu'),\n\t\t\tpointerup: this.emitEvent('pointerup'),\n\t\t\tpointerdown: this.emitEvent('pointerdown'),\n\t\t\tpointerover: this.emitEvent('pointerover'),\n\t\t\tpointerout: this.emitEvent('pointerout'),\n\t\t\tpointerenter: this.emitEvent('pointerenter'),\n\t\t\tpointerleave: this.emitEvent('pointerleave'),\n\t\t\tpointermove: this.emitEvent('pointermove'),\n\t\t\tpointermissed: this.emitEvent('pointermissed'),\n\t\t\tpointercancel: this.emitEvent('pointercancel'),\n\t\t\twheel: this.emitEvent('wheel'),\n\t\t});\n\t}\n\n\tprivate emitEvent<TEvent extends keyof NgtEventHandlers>(eventName: TEvent) {\n\t\treturn this[eventName].emit.bind(this[eventName]) as NgtEventHandlers[TEvent];\n\t}\n}\n\n/**\n * @deprecated this has never worked. Use `NgtObjectEvents` and explicit value for inputs and outputs instead\n * @since 2.12.0 Will be removed in 3.0.0\n */\nexport const NgtObjectEventsInputs = ['ngtObjectEvents'];\n\n/**\n * @deprecated this has never worked. Use `NgtObjectEvents` and explicit value for inputs and outputs instead\n * @since 2.12.0 Will be removed in 3.0.0\n */\nexport const NgtObjectEventsOutputs = [\n\t'click',\n\t'dblclick',\n\t'contextmenu',\n\t'pointerup',\n\t'pointerdown',\n\t'pointerover',\n\t'pointerout',\n\t'pointerenter',\n\t'pointerleave',\n\t'pointermove',\n\t'pointermissed',\n\t'pointercancel',\n\t'wheel',\n];\n\n/**\n * @deprecated Use NgtObjectEventsInputs and NgtObjectEventsOutputs instead along with NgtObjectEvents\n * @since 2.6.0 Will be removed in 3.0.0\n */\nexport const NgtObjectEventsHostDirective = {\n\tdirective: NgtObjectEvents,\n\tinputs: ['ngtObjectEvents'],\n\toutputs: [\n\t\t'click',\n\t\t'dblclick',\n\t\t'contextmenu',\n\t\t'pointerup',\n\t\t'pointerdown',\n\t\t'pointerover',\n\t\t'pointerout',\n\t\t'pointerenter',\n\t\t'pointerleave',\n\t\t'pointermove',\n\t\t'pointermissed',\n\t\t'pointercancel',\n\t\t'wheel',\n\t],\n};\n\nexport function injectObjectEvents(\n\ttarget: () => ElementRef<Object3D> | Object3D | null | undefined,\n\tevents: NgtEventHandlers,\n\t{ injector }: { injector?: Injector } = {},\n) {\n\treturn assertInjector(injectObjectEvents, injector, () => {\n\t\tconst renderer = inject(Renderer2);\n\n\t\tconst cleanUps: Array<() => void> = [];\n\n\t\teffect((onCleanup) => {\n\t\t\tconst targetRef = resolveRef(target());\n\n\t\t\tif (!targetRef) return;\n\n\t\t\tObject.entries(events).forEach(([eventName, eventHandler]) => {\n\t\t\t\tcleanUps.push(renderer.listen(targetRef, eventName, eventHandler));\n\t\t\t});\n\n\t\t\tonCleanup(() => {\n\t\t\t\tcleanUps.forEach((cleanUp) => cleanUp());\n\t\t\t});\n\t\t});\n\n\t\tinject(DestroyRef).onDestroy(() => {\n\t\t\tcleanUps.forEach((cleanUp) => cleanUp());\n\t\t});\n\n\t\treturn cleanUps;\n\t});\n}\n"]}
|
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
export function getEmitter(emitterRef) {
|
|
2
|
-
if (!emitterRef || !emitterRef['listeners'] || emitterRef['destroyed'])
|
|
3
|
-
return undefined;
|
|
4
|
-
return emitterRef.emit.bind(emitterRef);
|
|
5
|
-
}
|
|
6
|
-
export function hasListener(...emitterRefs) {
|
|
7
|
-
return emitterRefs.some((emitterRef) => emitterRef && !emitterRef['destroyed'] && emitterRef['listeners'] && emitterRef['listeners'].length > 0);
|
|
8
|
-
}
|
|
9
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3V0cHV0LXJlZi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29yZS9zcmMvbGliL3V0aWxzL291dHB1dC1yZWYudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsTUFBTSxVQUFVLFVBQVUsQ0FBSSxVQUEyQztJQUN4RSxJQUFJLENBQUMsVUFBVSxJQUFJLENBQUMsVUFBVSxDQUFDLFdBQVcsQ0FBQyxJQUFJLFVBQVUsQ0FBQyxXQUFXLENBQUM7UUFBRSxPQUFPLFNBQVMsQ0FBQztJQUN6RixPQUFPLFVBQVUsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDO0FBQ3pDLENBQUM7QUFFRCxNQUFNLFVBQVUsV0FBVyxDQUFDLEdBQUcsV0FBc0Q7SUFDcEYsT0FBTyxXQUFXLENBQUMsSUFBSSxDQUN0QixDQUFDLFVBQVUsRUFBRSxFQUFFLENBQ2QsVUFBVSxJQUFJLENBQUMsVUFBVSxDQUFDLFdBQVcsQ0FBQyxJQUFJLFVBQVUsQ0FBQyxXQUFXLENBQUMsSUFBSSxVQUFVLENBQUMsV0FBVyxDQUFDLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FDeEcsQ0FBQztBQUNILENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBPdXRwdXRFbWl0dGVyUmVmIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXRFbWl0dGVyPFQ+KGVtaXR0ZXJSZWY6IE91dHB1dEVtaXR0ZXJSZWY8VD4gfCB1bmRlZmluZWQpIHtcblx0aWYgKCFlbWl0dGVyUmVmIHx8ICFlbWl0dGVyUmVmWydsaXN0ZW5lcnMnXSB8fCBlbWl0dGVyUmVmWydkZXN0cm95ZWQnXSkgcmV0dXJuIHVuZGVmaW5lZDtcblx0cmV0dXJuIGVtaXR0ZXJSZWYuZW1pdC5iaW5kKGVtaXR0ZXJSZWYpO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gaGFzTGlzdGVuZXIoLi4uZW1pdHRlclJlZnM6IChPdXRwdXRFbWl0dGVyUmVmPHVua25vd24+IHwgdW5kZWZpbmVkKVtdKSB7XG5cdHJldHVybiBlbWl0dGVyUmVmcy5zb21lKFxuXHRcdChlbWl0dGVyUmVmKSA9PlxuXHRcdFx0ZW1pdHRlclJlZiAmJiAhZW1pdHRlclJlZlsnZGVzdHJveWVkJ10gJiYgZW1pdHRlclJlZlsnbGlzdGVuZXJzJ10gJiYgZW1pdHRlclJlZlsnbGlzdGVuZXJzJ10ubGVuZ3RoID4gMCxcblx0KTtcbn1cbiJdfQ==
|
|
@@ -1,70 +0,0 @@
|
|
|
1
|
-
import { computed } from '@angular/core';
|
|
2
|
-
import { Vector2, Vector3, Vector4 } from 'three';
|
|
3
|
-
export function omit(objFn, keysToOmit) {
|
|
4
|
-
return computed(() => {
|
|
5
|
-
const obj = objFn();
|
|
6
|
-
const result = {};
|
|
7
|
-
for (const key of Object.keys(obj)) {
|
|
8
|
-
if (keysToOmit.includes(key))
|
|
9
|
-
continue;
|
|
10
|
-
Object.assign(result, { [key]: obj[key] });
|
|
11
|
-
}
|
|
12
|
-
return result;
|
|
13
|
-
});
|
|
14
|
-
}
|
|
15
|
-
export function pick(objFn, keyOrKeys) {
|
|
16
|
-
if (Array.isArray(keyOrKeys)) {
|
|
17
|
-
return computed(() => {
|
|
18
|
-
const obj = objFn();
|
|
19
|
-
const result = {};
|
|
20
|
-
for (const key of keyOrKeys) {
|
|
21
|
-
if (!(key in obj))
|
|
22
|
-
continue;
|
|
23
|
-
Object.assign(result, { [key]: obj[key] });
|
|
24
|
-
}
|
|
25
|
-
return result;
|
|
26
|
-
});
|
|
27
|
-
}
|
|
28
|
-
return computed(() => objFn()[keyOrKeys]);
|
|
29
|
-
}
|
|
30
|
-
export function merge(objFn, toMerge, mode = 'override') {
|
|
31
|
-
if (mode === 'override')
|
|
32
|
-
return computed(() => ({ ...objFn(), ...toMerge }));
|
|
33
|
-
return computed(() => ({ ...toMerge, ...objFn() }));
|
|
34
|
-
}
|
|
35
|
-
function createVectorComputed(vectorCtor) {
|
|
36
|
-
return ((inputOrOptions, keyOrKeepUndefined, keepUndefined) => {
|
|
37
|
-
if (typeof keyOrKeepUndefined === 'undefined' || typeof keyOrKeepUndefined === 'boolean') {
|
|
38
|
-
keepUndefined = !!keyOrKeepUndefined;
|
|
39
|
-
const input = inputOrOptions;
|
|
40
|
-
return computed(() => {
|
|
41
|
-
const value = input();
|
|
42
|
-
if (keepUndefined && value == undefined)
|
|
43
|
-
return undefined;
|
|
44
|
-
if (typeof value === 'number')
|
|
45
|
-
return new vectorCtor().setScalar(value);
|
|
46
|
-
else if (value)
|
|
47
|
-
return new vectorCtor(...value);
|
|
48
|
-
else
|
|
49
|
-
return new vectorCtor();
|
|
50
|
-
}, { equal: (a, b) => !!a && !!b && a.equals(b) });
|
|
51
|
-
}
|
|
52
|
-
const options = inputOrOptions;
|
|
53
|
-
const key = keyOrKeepUndefined;
|
|
54
|
-
return computed(() => {
|
|
55
|
-
const value = options()[key];
|
|
56
|
-
if (keepUndefined && value == undefined)
|
|
57
|
-
return undefined;
|
|
58
|
-
if (typeof value === 'number')
|
|
59
|
-
return new vectorCtor().setScalar(value);
|
|
60
|
-
else if (value)
|
|
61
|
-
return new vectorCtor(...value);
|
|
62
|
-
else
|
|
63
|
-
return new vectorCtor();
|
|
64
|
-
}, { equal: (a, b) => !!a && !!b && a.equals(b) });
|
|
65
|
-
});
|
|
66
|
-
}
|
|
67
|
-
export const vector2 = createVectorComputed(Vector2);
|
|
68
|
-
export const vector3 = createVectorComputed(Vector3);
|
|
69
|
-
export const vector4 = createVectorComputed(Vector4);
|
|
70
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"parameters.js","sourceRoot":"","sources":["../../../../../../libs/core/src/lib/utils/parameters.ts"],"names":[],"mappings":"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","sourcesContent":["import { computed, Signal, Type } from '@angular/core';\nimport { Vector2, Vector3, Vector4 } from 'three';\nimport { NgtVector2, NgtVector3, NgtVector4 } from '../three-types';\nimport { NgtAnyRecord } from '../types';\n\ntype KeysOfType<TObject extends object, TType> = Exclude<\n\t{\n\t\t[K in keyof TObject]: TObject[K] extends TType | undefined | null ? K : never;\n\t}[keyof TObject],\n\tundefined\n>;\n\nexport function omit<TObject extends object, TKeys extends (keyof TObject)[]>(\n\tobjFn: () => TObject,\n\tkeysToOmit: TKeys,\n): Signal<Omit<TObject, TKeys[number]>>;\nexport function omit(objFn: () => NgtAnyRecord, keysToOmit: string[]) {\n\treturn computed(() => {\n\t\tconst obj = objFn();\n\t\tconst result = {} as NgtAnyRecord;\n\n\t\tfor (const key of Object.keys(obj)) {\n\t\t\tif (keysToOmit.includes(key)) continue;\n\t\t\tObject.assign(result, { [key]: obj[key] });\n\t\t}\n\n\t\treturn result;\n\t});\n}\n\nexport function pick<TObject extends object, TKey extends keyof TObject>(\n\tobjFn: () => TObject,\n\tkey: TKey,\n): Signal<TObject[TKey]>;\nexport function pick<TObject extends object, TKeys extends (keyof TObject)[]>(\n\tobjFn: () => TObject,\n\tkeys: TKeys,\n): Signal<Pick<TObject, TKeys[number]>>;\nexport function pick(objFn: () => NgtAnyRecord, keyOrKeys: string | string[]) {\n\tif (Array.isArray(keyOrKeys)) {\n\t\treturn computed(() => {\n\t\t\tconst obj = objFn();\n\t\t\tconst result = {} as NgtAnyRecord;\n\t\t\tfor (const key of keyOrKeys) {\n\t\t\t\tif (!(key in obj)) continue;\n\t\t\t\tObject.assign(result, { [key]: obj[key] });\n\t\t\t}\n\t\t\treturn result;\n\t\t});\n\t}\n\n\treturn computed(() => objFn()[keyOrKeys]);\n}\n\nexport function merge<TObject extends object>(\n\tobjFn: () => TObject,\n\ttoMerge: Partial<TObject>,\n\tmode: 'override' | 'backfill' = 'override',\n) {\n\tif (mode === 'override') return computed(() => ({ ...objFn(), ...toMerge }));\n\treturn computed(() => ({ ...toMerge, ...objFn() }));\n}\n\ntype NgtVectorComputed<\n\tTVector extends Vector2 | Vector3 | Vector4,\n\tTNgtVector = TVector extends Vector2 ? NgtVector2 : TVector extends Vector3 ? NgtVector3 : NgtVector4,\n> = {\n\t(input: Signal<TNgtVector>): Signal<TVector>;\n\t(input: Signal<TNgtVector>, keepUndefined: true): Signal<TVector | undefined>;\n\t<TObject extends object>(options: Signal<TObject>, key: KeysOfType<TObject, TNgtVector>): Signal<TVector>;\n\t<TObject extends object>(\n\t\toptions: Signal<TObject>,\n\t\tkey: KeysOfType<TObject, TNgtVector>,\n\t\tkeepUndefined: true,\n\t): Signal<TVector | undefined>;\n};\n\nfunction createVectorComputed<TVector extends Vector2 | Vector3 | Vector4>(vectorCtor: Type<TVector>) {\n\ttype TNgtVector = TVector extends Vector2 ? NgtVector2 : TVector extends Vector3 ? NgtVector3 : NgtVector4;\n\treturn ((\n\t\tinputOrOptions: Signal<NgtAnyRecord> | Signal<TNgtVector>,\n\t\tkeyOrKeepUndefined?: string | true,\n\t\tkeepUndefined?: boolean,\n\t) => {\n\t\tif (typeof keyOrKeepUndefined === 'undefined' || typeof keyOrKeepUndefined === 'boolean') {\n\t\t\tkeepUndefined = !!keyOrKeepUndefined;\n\t\t\tconst input = inputOrOptions as Signal<TNgtVector>;\n\t\t\treturn computed(\n\t\t\t\t() => {\n\t\t\t\t\tconst value = input();\n\t\t\t\t\tif (keepUndefined && value == undefined) return undefined;\n\t\t\t\t\tif (typeof value === 'number') return new vectorCtor().setScalar(value);\n\t\t\t\t\telse if (value) return new vectorCtor(...(value as any));\n\t\t\t\t\telse return new vectorCtor();\n\t\t\t\t},\n\t\t\t\t{ equal: (a, b) => !!a && !!b && a.equals(b as any) },\n\t\t\t);\n\t\t}\n\n\t\tconst options = inputOrOptions as Signal<NgtAnyRecord>;\n\t\tconst key = keyOrKeepUndefined as string;\n\n\t\treturn computed(\n\t\t\t() => {\n\t\t\t\tconst value = options()[key];\n\t\t\t\tif (keepUndefined && value == undefined) return undefined;\n\t\t\t\tif (typeof value === 'number') return new vectorCtor().setScalar(value);\n\t\t\t\telse if (value) return new vectorCtor(...(value as any));\n\t\t\t\telse return new vectorCtor();\n\t\t\t},\n\t\t\t{ equal: (a, b) => !!a && !!b && a.equals(b as any) },\n\t\t);\n\t}) as NgtVectorComputed<TVector, TNgtVector>;\n}\n\nexport const vector2 = createVectorComputed(Vector2);\nexport const vector3 = createVectorComputed(Vector3);\nexport const vector4 = createVectorComputed(Vector4);\n"]}
|
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
import { is } from './is';
|
|
2
|
-
export function resolveRef(ref) {
|
|
3
|
-
if (is.ref(ref)) {
|
|
4
|
-
return ref.nativeElement;
|
|
5
|
-
}
|
|
6
|
-
return ref;
|
|
7
|
-
}
|
|
8
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVzb2x2ZS1yZWYuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvcmUvc3JjL2xpYi91dGlscy9yZXNvbHZlLXJlZi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsRUFBRSxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBRTFCLE1BQU0sVUFBVSxVQUFVLENBQVUsR0FBMEQ7SUFDN0YsSUFBSSxFQUFFLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUM7UUFDakIsT0FBTyxHQUFHLENBQUMsYUFBYSxDQUFDO0lBQzFCLENBQUM7SUFFRCxPQUFPLEdBQUcsQ0FBQztBQUNaLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBFbGVtZW50UmVmIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBpcyB9IGZyb20gJy4vaXMnO1xuXG5leHBvcnQgZnVuY3Rpb24gcmVzb2x2ZVJlZjxUT2JqZWN0PihyZWY6IEVsZW1lbnRSZWY8VE9iamVjdCB8IHVuZGVmaW5lZD4gfCBUT2JqZWN0IHwgdW5kZWZpbmVkKTogVE9iamVjdCB8IHVuZGVmaW5lZCB7XG5cdGlmIChpcy5yZWYocmVmKSkge1xuXHRcdHJldHVybiByZWYubmF0aXZlRWxlbWVudDtcblx0fVxuXG5cdHJldHVybiByZWY7XG59XG4iXX0=
|
|
@@ -1,90 +0,0 @@
|
|
|
1
|
-
import { computed, signal, untracked, } from '@angular/core';
|
|
2
|
-
const STORE_COMPUTED_KEY = '__ngt_signal_store_computed__';
|
|
3
|
-
function reducer(state) {
|
|
4
|
-
return (previous) => {
|
|
5
|
-
const partial = typeof state === 'function' ? state(previous) : state;
|
|
6
|
-
Object.keys(partial).forEach((key) => {
|
|
7
|
-
const typedKey = key;
|
|
8
|
-
if (partial[typedKey] === undefined && previous[typedKey] != null) {
|
|
9
|
-
partial[typedKey] = previous[typedKey];
|
|
10
|
-
}
|
|
11
|
-
});
|
|
12
|
-
return partial;
|
|
13
|
-
};
|
|
14
|
-
}
|
|
15
|
-
function updater(_source) {
|
|
16
|
-
return (state) => {
|
|
17
|
-
const updater = reducer(state);
|
|
18
|
-
untracked(() => {
|
|
19
|
-
_source.update((previous) => ({ ...previous, ...updater(previous) }));
|
|
20
|
-
});
|
|
21
|
-
};
|
|
22
|
-
}
|
|
23
|
-
function getter(_source) {
|
|
24
|
-
return (...keys) => {
|
|
25
|
-
const root = untracked(_source);
|
|
26
|
-
if (keys.length === 0)
|
|
27
|
-
return root;
|
|
28
|
-
return keys.reduce((value, key) => value[key], root);
|
|
29
|
-
};
|
|
30
|
-
}
|
|
31
|
-
function selector(_state, computedCache) {
|
|
32
|
-
return (...keysAndOptions) => {
|
|
33
|
-
if (keysAndOptions.length === 0)
|
|
34
|
-
return _state;
|
|
35
|
-
if (keysAndOptions.length === 1 && typeof keysAndOptions[0] === 'object') {
|
|
36
|
-
const cachedKey = STORE_COMPUTED_KEY.concat(JSON.stringify(keysAndOptions[0]));
|
|
37
|
-
if (!computedCache.has(cachedKey)) {
|
|
38
|
-
computedCache.set(cachedKey, computed(_state, keysAndOptions));
|
|
39
|
-
}
|
|
40
|
-
return computedCache.get(cachedKey);
|
|
41
|
-
}
|
|
42
|
-
const [keys, options] = parseStoreOptions(keysAndOptions);
|
|
43
|
-
const joinedKeys = keys.join('-');
|
|
44
|
-
const cachedKeys = joinedKeys.concat(JSON.stringify(options));
|
|
45
|
-
if (!computedCache.has(cachedKeys)) {
|
|
46
|
-
computedCache.set(cachedKeys, computed(() => keys.reduce((value, key) => value[key], _state()), options));
|
|
47
|
-
}
|
|
48
|
-
return computedCache.get(cachedKeys);
|
|
49
|
-
};
|
|
50
|
-
}
|
|
51
|
-
function parseStoreOptions(keysAndOptions) {
|
|
52
|
-
if (typeof keysAndOptions.at(-1) === 'object') {
|
|
53
|
-
return [keysAndOptions.slice(0, -1), keysAndOptions.at(-1)];
|
|
54
|
-
}
|
|
55
|
-
return [keysAndOptions, { equal: Object.is }];
|
|
56
|
-
}
|
|
57
|
-
export function signalStore(initialState = {}, options) {
|
|
58
|
-
let source;
|
|
59
|
-
let update;
|
|
60
|
-
let get;
|
|
61
|
-
let select;
|
|
62
|
-
let state;
|
|
63
|
-
const computedCache = new Map();
|
|
64
|
-
if (!options) {
|
|
65
|
-
options = { equal: Object.is };
|
|
66
|
-
}
|
|
67
|
-
if (typeof initialState === 'function') {
|
|
68
|
-
source = signal({}, options);
|
|
69
|
-
state = source.asReadonly();
|
|
70
|
-
get = getter(source);
|
|
71
|
-
update = updater(source);
|
|
72
|
-
select = selector(state, computedCache);
|
|
73
|
-
source.set(initialState({ update, get, select }));
|
|
74
|
-
}
|
|
75
|
-
else {
|
|
76
|
-
source = signal(initialState, options);
|
|
77
|
-
state = source.asReadonly();
|
|
78
|
-
get = getter(source);
|
|
79
|
-
update = updater(source);
|
|
80
|
-
select = selector(state, computedCache);
|
|
81
|
-
}
|
|
82
|
-
const store = { select, get, update, state };
|
|
83
|
-
Object.defineProperty(store, 'snapshot', {
|
|
84
|
-
get: untracked.bind({}, state),
|
|
85
|
-
configurable: false,
|
|
86
|
-
enumerable: false,
|
|
87
|
-
});
|
|
88
|
-
return store;
|
|
89
|
-
}
|
|
90
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"signal-store.js","sourceRoot":"","sources":["../../../../../../libs/core/src/lib/utils/signal-store.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n\tCreateComputedOptions,\n\tCreateSignalOptions,\n\tSignal,\n\tWritableSignal,\n\tcomputed,\n\tsignal,\n\tuntracked,\n} from '@angular/core';\nimport { NgtAnyRecord } from '../types';\n\nconst STORE_COMPUTED_KEY = '__ngt_signal_store_computed__';\n\nexport type NgtSignalStore<State extends object> = {\n\tselect<\n\t\tKey1 extends keyof State,\n\t\tKey2 extends keyof State[Key1],\n\t\tKey3 extends keyof State[Key1][Key2],\n\t\tKey4 extends keyof State[Key1][Key2][Key3],\n\t>(\n\t\tkey1: Key1,\n\t\tkey2: Key2,\n\t\tkey3: Key3,\n\t\tkey4: Key4,\n\t\toptions?: CreateComputedOptions<State[Key1][Key2][Key3][Key4]>,\n\t): Signal<State[Key1][Key2][Key3][Key4]>;\n\tselect<Key1 extends keyof State, Key2 extends keyof State[Key1], Key3 extends keyof State[Key1][Key2]>(\n\t\tkey1: Key1,\n\t\tkey2: Key2,\n\t\tkey3: Key3,\n\t\toptions?: CreateComputedOptions<State[Key1][Key2][Key3]>,\n\t): Signal<State[Key1][Key2][Key3]>;\n\tselect<Key1 extends keyof State, Key2 extends keyof State[Key1]>(\n\t\tkey1: Key1,\n\t\tkey2: Key2,\n\t\toptions?: CreateComputedOptions<State[Key1][Key2]>,\n\t): Signal<State[Key1][Key2]>;\n\tselect<Key extends keyof State>(key: Key, options?: CreateComputedOptions<State[Key]>): Signal<State[Key]>;\n\tselect(options?: CreateComputedOptions<State>): Signal<State>;\n\n\tget<\n\t\tKey1 extends keyof State,\n\t\tKey2 extends keyof State[Key1],\n\t\tKey3 extends keyof State[Key1][Key2],\n\t\tKey4 extends keyof State[Key1][Key2][Key3],\n\t>(\n\t\tkey1: Key1,\n\t\tkey2: Key2,\n\t\tkey3: Key3,\n\t\tkey4: Key4,\n\t): State[Key1][Key2][Key3][Key4];\n\tget<Key1 extends keyof State, Key2 extends keyof State[Key1], Key3 extends keyof State[Key1][Key2]>(\n\t\tkey1: Key1,\n\t\tkey2: Key2,\n\t\tkey3: Key3,\n\t): State[Key1][Key2][Key3];\n\tget<Key1 extends keyof State, Key2 extends keyof State[Key1]>(key1: Key1, key2: Key2): State[Key1][Key2];\n\tget<Key extends keyof State>(key: Key): State[Key];\n\tget(): State;\n\n\t/**\n\t * New state takes precedence\n\t */\n\tupdate(state: Partial<State> | ((previous: State) => Partial<State>)): void;\n\n\t/**\n\t * Equivalence to select()\n\t */\n\tstate: Signal<State>;\n\t/**\n\t * Equivalence to get()\n\t */\n\tget snapshot(): State;\n};\n\nfunction reducer<State extends object>(state: State | ((previous: State) => State)) {\n\treturn (previous: State) => {\n\t\tconst partial = typeof state === 'function' ? state(previous) : state;\n\t\tObject.keys(partial).forEach((key) => {\n\t\t\tconst typedKey = key as keyof State;\n\t\t\tif (partial[typedKey] === undefined && previous[typedKey] != null) {\n\t\t\t\tpartial[typedKey] = previous[typedKey];\n\t\t\t}\n\t\t});\n\t\treturn partial;\n\t};\n}\n\nfunction updater<State extends object>(_source: WritableSignal<State>) {\n\treturn (state: State | ((previous: State) => State)) => {\n\t\tconst updater = reducer(state);\n\t\tuntracked(() => {\n\t\t\t_source.update((previous) => ({ ...previous, ...updater(previous) }));\n\t\t});\n\t};\n}\n\nfunction getter<State extends object>(_source: WritableSignal<State>) {\n\treturn (...keys: string[]) => {\n\t\tconst root = untracked(_source);\n\t\tif (keys.length === 0) return root;\n\t\treturn keys.reduce((value, key) => (value as NgtAnyRecord)[key], root);\n\t};\n}\n\nfunction selector<State extends object>(_state: Signal<State>, computedCache: Map<string, Signal<any>>) {\n\treturn (...keysAndOptions: any[]) => {\n\t\tif (keysAndOptions.length === 0) return _state;\n\t\tif (keysAndOptions.length === 1 && typeof keysAndOptions[0] === 'object') {\n\t\t\tconst cachedKey = STORE_COMPUTED_KEY.concat(JSON.stringify(keysAndOptions[0]));\n\t\t\tif (!computedCache.has(cachedKey)) {\n\t\t\t\tcomputedCache.set(cachedKey, computed(_state, keysAndOptions as CreateComputedOptions<object>));\n\t\t\t}\n\t\t\treturn computedCache.get(cachedKey)!;\n\t\t}\n\t\tconst [keys, options] = parseStoreOptions(keysAndOptions);\n\t\tconst joinedKeys = keys.join('-');\n\t\tconst cachedKeys = joinedKeys.concat(JSON.stringify(options));\n\n\t\tif (!computedCache.has(cachedKeys)) {\n\t\t\tcomputedCache.set(\n\t\t\t\tcachedKeys,\n\t\t\t\tcomputed(() => keys.reduce((value, key) => (value as NgtAnyRecord)[key], _state()), options),\n\t\t\t);\n\t\t}\n\t\treturn computedCache.get(cachedKeys)!;\n\t};\n}\n\nfunction parseStoreOptions(keysAndOptions: any[]): [string[], CreateComputedOptions<any>?] {\n\tif (typeof keysAndOptions.at(-1) === 'object') {\n\t\treturn [keysAndOptions.slice(0, -1), keysAndOptions.at(-1)];\n\t}\n\n\treturn [keysAndOptions, { equal: Object.is }];\n}\n\nexport function signalStore<State extends object>(\n\tinitialState:\n\t\t| Partial<State>\n\t\t| ((storeApi: Pick<NgtSignalStore<State>, 'get' | 'update' | 'select'>) => Partial<State>) = {},\n\toptions?: CreateSignalOptions<State>,\n): NgtSignalStore<State> {\n\tlet source: WritableSignal<State>;\n\tlet update: NgtSignalStore<State>['update'];\n\tlet get: NgtSignalStore<State>['get'];\n\tlet select: NgtSignalStore<State>['select'];\n\tlet state: Signal<State>;\n\n\tconst computedCache = new Map();\n\n\tif (!options) {\n\t\toptions = { equal: Object.is };\n\t}\n\n\tif (typeof initialState === 'function') {\n\t\tsource = signal({} as State, options);\n\t\tstate = source.asReadonly();\n\t\tget = getter(source);\n\t\tupdate = updater(source);\n\t\tselect = selector(state, computedCache);\n\t\tsource.set(initialState({ update, get, select }) as State);\n\t} else {\n\t\tsource = signal(initialState as State, options);\n\t\tstate = source.asReadonly();\n\t\tget = getter(source);\n\t\tupdate = updater(source);\n\t\tselect = selector(state, computedCache);\n\t}\n\n\tconst store = { select, get, update, state };\n\n\tObject.defineProperty(store, 'snapshot', {\n\t\tget: untracked.bind({}, state),\n\t\tconfigurable: false,\n\t\tenumerable: false,\n\t});\n\n\treturn store as NgtSignalStore<State>;\n}\n"]}
|
|
@@ -1,37 +0,0 @@
|
|
|
1
|
-
import { is } from './is';
|
|
2
|
-
export function checkNeedsUpdate(value) {
|
|
3
|
-
if (value !== null && is.obj(value) && 'needsUpdate' in value) {
|
|
4
|
-
value['needsUpdate'] = true;
|
|
5
|
-
if ('uniformsNeedUpdate' in value)
|
|
6
|
-
value['uniformsNeedUpdate'] = true;
|
|
7
|
-
}
|
|
8
|
-
}
|
|
9
|
-
export function checkUpdate(value) {
|
|
10
|
-
// TODO (chau): this is messing with PivotControls. Re-evaluate later
|
|
11
|
-
// if (is.object3D(value)) value.updateMatrix();
|
|
12
|
-
if (is.camera(value)) {
|
|
13
|
-
if (is.perspectiveCamera(value) || is.orthographicCamera(value))
|
|
14
|
-
value.updateProjectionMatrix();
|
|
15
|
-
value.updateMatrixWorld();
|
|
16
|
-
}
|
|
17
|
-
// NOTE: skip checkNeedsUpdate for CubeTexture
|
|
18
|
-
if (value && value.isCubeTexture)
|
|
19
|
-
return;
|
|
20
|
-
checkNeedsUpdate(value);
|
|
21
|
-
}
|
|
22
|
-
export function updateCamera(camera, size) {
|
|
23
|
-
if (!camera.manual) {
|
|
24
|
-
if (is.orthographicCamera(camera)) {
|
|
25
|
-
camera.left = size.width / -2;
|
|
26
|
-
camera.right = size.width / 2;
|
|
27
|
-
camera.top = size.height / 2;
|
|
28
|
-
camera.bottom = size.height / -2;
|
|
29
|
-
}
|
|
30
|
-
else {
|
|
31
|
-
camera.aspect = size.width / size.height;
|
|
32
|
-
}
|
|
33
|
-
camera.updateProjectionMatrix();
|
|
34
|
-
camera.updateMatrixWorld();
|
|
35
|
-
}
|
|
36
|
-
}
|
|
37
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXBkYXRlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb3JlL3NyYy9saWIvdXRpbHMvdXBkYXRlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE9BQU8sRUFBRSxFQUFFLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFFMUIsTUFBTSxVQUFVLGdCQUFnQixDQUFDLEtBQWM7SUFDOUMsSUFBSSxLQUFLLEtBQUssSUFBSSxJQUFJLEVBQUUsQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLElBQUksYUFBYSxJQUFJLEtBQUssRUFBRSxDQUFDO1FBQy9ELEtBQUssQ0FBQyxhQUFhLENBQUMsR0FBRyxJQUFJLENBQUM7UUFDNUIsSUFBSSxvQkFBb0IsSUFBSSxLQUFLO1lBQUUsS0FBSyxDQUFDLG9CQUFvQixDQUFDLEdBQUcsSUFBSSxDQUFDO0lBQ3ZFLENBQUM7QUFDRixDQUFDO0FBRUQsTUFBTSxVQUFVLFdBQVcsQ0FBQyxLQUFjO0lBQ3pDLHFFQUFxRTtJQUNyRSxnREFBZ0Q7SUFFaEQsSUFBSSxFQUFFLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUM7UUFDdEIsSUFBSSxFQUFFLENBQUMsaUJBQWlCLENBQUMsS0FBSyxDQUFDLElBQUksRUFBRSxDQUFDLGtCQUFrQixDQUFDLEtBQUssQ0FBQztZQUFFLEtBQUssQ0FBQyxzQkFBc0IsRUFBRSxDQUFDO1FBQ2hHLEtBQUssQ0FBQyxpQkFBaUIsRUFBRSxDQUFDO0lBQzNCLENBQUM7SUFFRCw4Q0FBOEM7SUFDOUMsSUFBSSxLQUFLLElBQUssS0FBcUIsQ0FBQyxhQUFhO1FBQUUsT0FBTztJQUUxRCxnQkFBZ0IsQ0FBQyxLQUFLLENBQUMsQ0FBQztBQUN6QixDQUFDO0FBRUQsTUFBTSxVQUFVLFlBQVksQ0FBQyxNQUF1QixFQUFFLElBQWE7SUFDbEUsSUFBSSxDQUFDLE1BQU0sQ0FBQyxNQUFNLEVBQUUsQ0FBQztRQUNwQixJQUFJLEVBQUUsQ0FBQyxrQkFBa0IsQ0FBQyxNQUFNLENBQUMsRUFBRSxDQUFDO1lBQ25DLE1BQU0sQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDLEtBQUssR0FBRyxDQUFDLENBQUMsQ0FBQztZQUM5QixNQUFNLENBQUMsS0FBSyxHQUFHLElBQUksQ0FBQyxLQUFLLEdBQUcsQ0FBQyxDQUFDO1lBQzlCLE1BQU0sQ0FBQyxHQUFHLEdBQUcsSUFBSSxDQUFDLE1BQU0sR0FBRyxDQUFDLENBQUM7WUFDN0IsTUFBTSxDQUFDLE1BQU0sR0FBRyxJQUFJLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQyxDQUFDO1FBQ2xDLENBQUM7YUFBTSxDQUFDO1lBQ1AsTUFBTSxDQUFDLE1BQU0sR0FBRyxJQUFJLENBQUMsS0FBSyxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUM7UUFDMUMsQ0FBQztRQUVELE1BQU0sQ0FBQyxzQkFBc0IsRUFBRSxDQUFDO1FBQ2hDLE1BQU0sQ0FBQyxpQkFBaUIsRUFBRSxDQUFDO0lBQzVCLENBQUM7QUFDRixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ3ViZVRleHR1cmUgfSBmcm9tICd0aHJlZSc7XG5pbXBvcnQgeyBOZ3RDYW1lcmFNYW51YWwsIE5ndFNpemUgfSBmcm9tICcuLi90eXBlcyc7XG5pbXBvcnQgeyBpcyB9IGZyb20gJy4vaXMnO1xuXG5leHBvcnQgZnVuY3Rpb24gY2hlY2tOZWVkc1VwZGF0ZSh2YWx1ZTogdW5rbm93bikge1xuXHRpZiAodmFsdWUgIT09IG51bGwgJiYgaXMub2JqKHZhbHVlKSAmJiAnbmVlZHNVcGRhdGUnIGluIHZhbHVlKSB7XG5cdFx0dmFsdWVbJ25lZWRzVXBkYXRlJ10gPSB0cnVlO1xuXHRcdGlmICgndW5pZm9ybXNOZWVkVXBkYXRlJyBpbiB2YWx1ZSkgdmFsdWVbJ3VuaWZvcm1zTmVlZFVwZGF0ZSddID0gdHJ1ZTtcblx0fVxufVxuXG5leHBvcnQgZnVuY3Rpb24gY2hlY2tVcGRhdGUodmFsdWU6IHVua25vd24pIHtcblx0Ly8gVE9ETyAoY2hhdSk6IHRoaXMgaXMgbWVzc2luZyB3aXRoIFBpdm90Q29udHJvbHMuIFJlLWV2YWx1YXRlIGxhdGVyXG5cdC8vIGlmIChpcy5vYmplY3QzRCh2YWx1ZSkpIHZhbHVlLnVwZGF0ZU1hdHJpeCgpO1xuXG5cdGlmIChpcy5jYW1lcmEodmFsdWUpKSB7XG5cdFx0aWYgKGlzLnBlcnNwZWN0aXZlQ2FtZXJhKHZhbHVlKSB8fCBpcy5vcnRob2dyYXBoaWNDYW1lcmEodmFsdWUpKSB2YWx1ZS51cGRhdGVQcm9qZWN0aW9uTWF0cml4KCk7XG5cdFx0dmFsdWUudXBkYXRlTWF0cml4V29ybGQoKTtcblx0fVxuXG5cdC8vIE5PVEU6IHNraXAgY2hlY2tOZWVkc1VwZGF0ZSBmb3IgQ3ViZVRleHR1cmVcblx0aWYgKHZhbHVlICYmICh2YWx1ZSBhcyBDdWJlVGV4dHVyZSkuaXNDdWJlVGV4dHVyZSkgcmV0dXJuO1xuXG5cdGNoZWNrTmVlZHNVcGRhdGUodmFsdWUpO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gdXBkYXRlQ2FtZXJhKGNhbWVyYTogTmd0Q2FtZXJhTWFudWFsLCBzaXplOiBOZ3RTaXplKSB7XG5cdGlmICghY2FtZXJhLm1hbnVhbCkge1xuXHRcdGlmIChpcy5vcnRob2dyYXBoaWNDYW1lcmEoY2FtZXJhKSkge1xuXHRcdFx0Y2FtZXJhLmxlZnQgPSBzaXplLndpZHRoIC8gLTI7XG5cdFx0XHRjYW1lcmEucmlnaHQgPSBzaXplLndpZHRoIC8gMjtcblx0XHRcdGNhbWVyYS50b3AgPSBzaXplLmhlaWdodCAvIDI7XG5cdFx0XHRjYW1lcmEuYm90dG9tID0gc2l6ZS5oZWlnaHQgLyAtMjtcblx0XHR9IGVsc2Uge1xuXHRcdFx0Y2FtZXJhLmFzcGVjdCA9IHNpemUud2lkdGggLyBzaXplLmhlaWdodDtcblx0XHR9XG5cblx0XHRjYW1lcmEudXBkYXRlUHJvamVjdGlvbk1hdHJpeCgpO1xuXHRcdGNhbWVyYS51cGRhdGVNYXRyaXhXb3JsZCgpO1xuXHR9XG59XG4iXX0=
|
|
@@ -1,5 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Generated bundle index. Do not edit.
|
|
3
|
-
*/
|
|
4
|
-
export * from './index';
|
|
5
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5ndWxhci10aHJlZS1uYXRpdmVzY3JpcHQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2NvcmUvbmF0aXZlc2NyaXB0L3NyYy9hbmd1bGFyLXRocmVlLW5hdGl2ZXNjcmlwdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2luZGV4JztcbiJdfQ==
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
export * from './lib/canvas';
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2NvcmUvbmF0aXZlc2NyaXB0L3NyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbGliL2NhbnZhcyc7XG4iXX0=
|
|
@@ -1,127 +0,0 @@
|
|
|
1
|
-
import '@nativescript/canvas-three';
|
|
2
|
-
import { DOCUMENT } from '@angular/common';
|
|
3
|
-
import { booleanAttribute, ChangeDetectionStrategy, Component, createEnvironmentInjector, DestroyRef, EnvironmentInjector, inject, Injector, input, NgZone, NO_ERRORS_SCHEMA, output, untracked, viewChild, ViewContainerRef, } from '@angular/core';
|
|
4
|
-
import { registerElement } from '@nativescript/angular';
|
|
5
|
-
import { Canvas } from '@nativescript/canvas';
|
|
6
|
-
import { injectCanvasRootInitializer, injectStore, makeDpr, NgtRoutedScene, provideNgtRenderer, provideStore, } from 'angular-three';
|
|
7
|
-
import { WebGLRenderer } from 'three';
|
|
8
|
-
import * as i0 from "@angular/core";
|
|
9
|
-
registerElement('Canvas', () => Canvas);
|
|
10
|
-
export class NgtCanvasNative {
|
|
11
|
-
constructor() {
|
|
12
|
-
this.sceneGraph = input.required({
|
|
13
|
-
transform: (value) => {
|
|
14
|
-
if (value === 'routed')
|
|
15
|
-
return NgtRoutedScene;
|
|
16
|
-
return value;
|
|
17
|
-
},
|
|
18
|
-
});
|
|
19
|
-
this.gl = input();
|
|
20
|
-
this.size = input();
|
|
21
|
-
this.shadows = input(false, {
|
|
22
|
-
transform: (value) => {
|
|
23
|
-
if (value === '')
|
|
24
|
-
return booleanAttribute(value);
|
|
25
|
-
return value;
|
|
26
|
-
},
|
|
27
|
-
});
|
|
28
|
-
this.legacy = input(false, { transform: booleanAttribute });
|
|
29
|
-
this.linear = input(false, { transform: booleanAttribute });
|
|
30
|
-
this.flat = input(false, { transform: booleanAttribute });
|
|
31
|
-
this.orthographic = input(false, { transform: booleanAttribute });
|
|
32
|
-
this.frameloop = input('always');
|
|
33
|
-
this.performance = input();
|
|
34
|
-
this.dpr = input([1, 2]);
|
|
35
|
-
this.raycaster = input();
|
|
36
|
-
this.scene = input();
|
|
37
|
-
this.camera = input();
|
|
38
|
-
this.lookAt = input();
|
|
39
|
-
this.created = output();
|
|
40
|
-
this.store = injectStore();
|
|
41
|
-
this.initRoot = injectCanvasRootInitializer();
|
|
42
|
-
this.injector = inject(Injector);
|
|
43
|
-
this.environmentInjector = inject(EnvironmentInjector);
|
|
44
|
-
this.destroyRef = inject(DestroyRef);
|
|
45
|
-
this.zone = inject(NgZone);
|
|
46
|
-
this.canvasViewContainerRef = viewChild.required('canvas', { read: ViewContainerRef });
|
|
47
|
-
this.destroyRef.onDestroy(() => {
|
|
48
|
-
this.glRef?.destroy();
|
|
49
|
-
this.glEnvironmentInjector?.destroy();
|
|
50
|
-
this.configurator?.destroy();
|
|
51
|
-
});
|
|
52
|
-
}
|
|
53
|
-
onReady(event) {
|
|
54
|
-
const canvas = event.object;
|
|
55
|
-
const dpr = makeDpr(untracked(this.dpr), window);
|
|
56
|
-
const canvasWidth = canvas.clientWidth * dpr;
|
|
57
|
-
const canvasHeight = canvas.clientHeight * dpr;
|
|
58
|
-
Object.assign(canvas, { width: canvasWidth, height: canvasHeight });
|
|
59
|
-
const context = canvas.getContext('webgl2');
|
|
60
|
-
const gl = new WebGLRenderer({
|
|
61
|
-
canvas,
|
|
62
|
-
context: context,
|
|
63
|
-
powerPreference: 'high-performance',
|
|
64
|
-
antialias: true,
|
|
65
|
-
alpha: true,
|
|
66
|
-
...untracked(this.gl),
|
|
67
|
-
});
|
|
68
|
-
gl.setSize(canvasWidth, canvasHeight);
|
|
69
|
-
this.zone.runOutsideAngular(() => {
|
|
70
|
-
this.configurator = this.initRoot(canvas);
|
|
71
|
-
this.configurator.configure({
|
|
72
|
-
gl,
|
|
73
|
-
size: { width: canvasWidth, height: canvasHeight, top: 0, left: 0 },
|
|
74
|
-
shadows: untracked(this.shadows),
|
|
75
|
-
legacy: untracked(this.legacy),
|
|
76
|
-
linear: untracked(this.linear),
|
|
77
|
-
flat: untracked(this.flat),
|
|
78
|
-
orthographic: untracked(this.orthographic),
|
|
79
|
-
frameloop: untracked(this.frameloop),
|
|
80
|
-
performance: untracked(this.performance),
|
|
81
|
-
dpr: untracked(this.dpr),
|
|
82
|
-
raycaster: untracked(this.raycaster),
|
|
83
|
-
scene: untracked(this.scene),
|
|
84
|
-
camera: untracked(this.camera),
|
|
85
|
-
lookAt: untracked(this.lookAt),
|
|
86
|
-
});
|
|
87
|
-
untracked(this.noZoneRender.bind(this));
|
|
88
|
-
});
|
|
89
|
-
}
|
|
90
|
-
noZoneRender() {
|
|
91
|
-
// NOTE: destroy previous instances if existed
|
|
92
|
-
this.glEnvironmentInjector?.destroy();
|
|
93
|
-
this.glRef?.destroy();
|
|
94
|
-
// NOTE: Flag the canvas active, rendering will now begin
|
|
95
|
-
this.store.update((state) => ({ internal: { ...state.internal, active: true } }));
|
|
96
|
-
// emit created event if observed
|
|
97
|
-
this.created.emit(this.store.snapshot);
|
|
98
|
-
this.glEnvironmentInjector = createEnvironmentInjector([{ provide: DOCUMENT, useValue: document }, provideNgtRenderer(this.store)], this.environmentInjector);
|
|
99
|
-
this.glRef = untracked(this.canvasViewContainerRef).createComponent(untracked(this.sceneGraph), {
|
|
100
|
-
environmentInjector: this.glEnvironmentInjector,
|
|
101
|
-
injector: this.injector,
|
|
102
|
-
});
|
|
103
|
-
this.glRef.changeDetectorRef.detectChanges();
|
|
104
|
-
}
|
|
105
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: NgtCanvasNative, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
106
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "18.2.11", type: NgtCanvasNative, isStandalone: true, selector: "NgtCanvas", 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 }, lookAt: { classPropertyName: "lookAt", publicName: "lookAt", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { created: "created" }, providers: [{ provide: DOCUMENT, useValue: document }, provideStore()], viewQueries: [{ propertyName: "canvasViewContainerRef", first: true, predicate: ["canvas"], descendants: true, read: ViewContainerRef, isSignal: true }], ngImport: i0, template: `
|
|
107
|
-
<GridLayout>
|
|
108
|
-
<Canvas #canvas style="width: 100%; height: auto" (ready)="onReady($event)"></Canvas>
|
|
109
|
-
</GridLayout>
|
|
110
|
-
`, isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
111
|
-
}
|
|
112
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: NgtCanvasNative, decorators: [{
|
|
113
|
-
type: Component,
|
|
114
|
-
args: [{
|
|
115
|
-
selector: 'NgtCanvas',
|
|
116
|
-
standalone: true,
|
|
117
|
-
template: `
|
|
118
|
-
<GridLayout>
|
|
119
|
-
<Canvas #canvas style="width: 100%; height: auto" (ready)="onReady($event)"></Canvas>
|
|
120
|
-
</GridLayout>
|
|
121
|
-
`,
|
|
122
|
-
providers: [{ provide: DOCUMENT, useValue: document }, provideStore()],
|
|
123
|
-
schemas: [NO_ERRORS_SCHEMA],
|
|
124
|
-
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
125
|
-
}]
|
|
126
|
-
}], ctorParameters: () => [] });
|
|
127
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"canvas.js","sourceRoot":"","sources":["../../../../../../libs/core/nativescript/src/lib/canvas.ts"],"names":[],"mappings":"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","sourcesContent":["import '@nativescript/canvas-three';\n\nimport { DOCUMENT } from '@angular/common';\nimport {\n\tbooleanAttribute,\n\tChangeDetectionStrategy,\n\tComponent,\n\tComponentRef,\n\tcreateEnvironmentInjector,\n\tDestroyRef,\n\tEnvironmentInjector,\n\tinject,\n\tInjector,\n\tinput,\n\tNgZone,\n\tNO_ERRORS_SCHEMA,\n\toutput,\n\tType,\n\tuntracked,\n\tviewChild,\n\tViewContainerRef,\n} from '@angular/core';\nimport { registerElement } from '@nativescript/angular';\nimport { Canvas } from '@nativescript/canvas';\nimport {\n\tinjectCanvasRootInitializer,\n\tinjectStore,\n\tmakeDpr,\n\tNgtCanvasConfigurator,\n\tNgtCanvasOptions,\n\tNgtDpr,\n\tNgtGLOptions,\n\tNgtPerformance,\n\tNgtRoutedScene,\n\tNgtSize,\n\tNgtState,\n\tprovideNgtRenderer,\n\tprovideStore,\n} from 'angular-three';\nimport { Raycaster, Scene, Vector3, WebGLRenderer } from 'three';\n\nregisterElement('Canvas', () => Canvas);\n\n@Component({\n\tselector: 'NgtCanvas',\n\tstandalone: true,\n\ttemplate: `\n\t\t<GridLayout>\n\t\t\t<Canvas #canvas style=\"width: 100%; height: auto\" (ready)=\"onReady($event)\"></Canvas>\n\t\t</GridLayout>\n\t`,\n\tproviders: [{ provide: DOCUMENT, useValue: document }, provideStore()],\n\tschemas: [NO_ERRORS_SCHEMA],\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class NgtCanvasNative {\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\tlookAt = input<Vector3 | Parameters<Vector3['set']>>();\n\tcreated = output<NgtState>();\n\n\tprivate store = injectStore();\n\tprivate initRoot = injectCanvasRootInitializer();\n\tprivate injector = inject(Injector);\n\tprivate environmentInjector = inject(EnvironmentInjector);\n\tprivate destroyRef = inject(DestroyRef);\n\tprivate zone = inject(NgZone);\n\n\tprivate canvasViewContainerRef = viewChild.required('canvas', { read: ViewContainerRef });\n\n\tprivate configurator?: NgtCanvasConfigurator;\n\tprivate glEnvironmentInjector?: EnvironmentInjector;\n\tprivate glRef?: ComponentRef<any>;\n\n\tconstructor() {\n\t\tthis.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\tonReady(event: any) {\n\t\tconst canvas = event.object;\n\t\tconst dpr = makeDpr(untracked(this.dpr), window);\n\t\tconst canvasWidth = canvas.clientWidth * dpr;\n\t\tconst canvasHeight = canvas.clientHeight * dpr;\n\t\tObject.assign(canvas, { width: canvasWidth, height: canvasHeight });\n\n\t\tconst context = canvas.getContext('webgl2');\n\t\tconst gl = new WebGLRenderer({\n\t\t\tcanvas,\n\t\t\tcontext: context as unknown as WebGLRenderingContext,\n\t\t\tpowerPreference: 'high-performance',\n\t\t\tantialias: true,\n\t\t\talpha: true,\n\t\t\t...untracked(this.gl),\n\t\t});\n\t\tgl.setSize(canvasWidth, canvasHeight);\n\n\t\tthis.zone.runOutsideAngular(() => {\n\t\t\tthis.configurator = this.initRoot(canvas);\n\t\t\tthis.configurator.configure({\n\t\t\t\tgl,\n\t\t\t\tsize: { width: canvasWidth, height: canvasHeight, top: 0, left: 0 },\n\t\t\t\tshadows: untracked(this.shadows),\n\t\t\t\tlegacy: untracked(this.legacy),\n\t\t\t\tlinear: untracked(this.linear),\n\t\t\t\tflat: untracked(this.flat),\n\t\t\t\torthographic: untracked(this.orthographic),\n\t\t\t\tframeloop: untracked(this.frameloop),\n\t\t\t\tperformance: untracked(this.performance),\n\t\t\t\tdpr: untracked(this.dpr),\n\t\t\t\traycaster: untracked(this.raycaster),\n\t\t\t\tscene: untracked(this.scene),\n\t\t\t\tcamera: untracked(this.camera),\n\t\t\t\tlookAt: untracked(this.lookAt),\n\t\t\t});\n\t\t\tuntracked(this.noZoneRender.bind(this));\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\t// emit created event if observed\n\t\tthis.created.emit(this.store.snapshot);\n\n\t\tthis.glEnvironmentInjector = createEnvironmentInjector(\n\t\t\t[{ provide: DOCUMENT, useValue: document }, provideNgtRenderer(this.store)],\n\t\t\tthis.environmentInjector,\n\t\t);\n\t\tthis.glRef = untracked(this.canvasViewContainerRef).createComponent(untracked(this.sceneGraph), {\n\t\t\tenvironmentInjector: this.glEnvironmentInjector,\n\t\t\tinjector: this.injector,\n\t\t});\n\n\t\tthis.glRef.changeDetectorRef.detectChanges();\n\t}\n}\n"]}
|
|
@@ -1,5 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Generated bundle index. Do not edit.
|
|
3
|
-
*/
|
|
4
|
-
export * from './index';
|
|
5
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5ndWxhci10aHJlZS10ZXN0aW5nLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vbGlicy9jb3JlL3Rlc3Rpbmcvc3JjL2FuZ3VsYXItdGhyZWUtdGVzdGluZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2luZGV4JztcbiJdfQ==
|
|
@@ -1,3 +0,0 @@
|
|
|
1
|
-
export * from './lib/test-bed';
|
|
2
|
-
export * from './lib/test-canvas';
|
|
3
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2NvcmUvdGVzdGluZy9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxnQkFBZ0IsQ0FBQztBQUMvQixjQUFjLG1CQUFtQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9saWIvdGVzdC1iZWQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdGVzdC1jYW52YXMnO1xuIl19
|