angular-three 2.0.0-beta.2 → 2.0.0-beta.21
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 +4 -147
- package/esm2022/angular-three.mjs +1 -1
- package/esm2022/index.mjs +11 -10
- package/esm2022/lib/before-render.mjs +13 -0
- package/esm2022/lib/canvas.mjs +130 -161
- package/esm2022/lib/directives/args.mjs +13 -11
- package/esm2022/lib/directives/common.mjs +29 -27
- package/esm2022/lib/directives/key.mjs +29 -0
- package/esm2022/lib/directives/parent.mjs +13 -11
- package/esm2022/lib/directives/repeat.mjs +5 -6
- package/esm2022/lib/dom/events.mjs +6 -1
- package/esm2022/lib/events.mjs +75 -58
- package/esm2022/lib/instance.mjs +65 -0
- package/esm2022/lib/loader.mjs +30 -37
- package/esm2022/lib/loop.mjs +6 -3
- package/esm2022/lib/portal.mjs +91 -102
- package/esm2022/lib/ref.mjs +48 -0
- package/esm2022/lib/renderer/catalogue.mjs +7 -0
- package/esm2022/lib/renderer/constants.mjs +21 -0
- package/esm2022/lib/renderer/index.mjs +419 -0
- package/esm2022/lib/renderer/store.mjs +144 -108
- package/esm2022/lib/renderer/utils.mjs +63 -48
- package/esm2022/lib/roots.mjs +249 -0
- package/esm2022/lib/routed-scene.mjs +11 -8
- package/esm2022/lib/store.mjs +207 -0
- package/esm2022/lib/three-types.mjs +2 -2
- package/esm2022/lib/types.mjs +1 -1
- package/esm2022/lib/utils/apply-props.mjs +23 -11
- package/esm2022/lib/utils/assert-injection-context.mjs +14 -0
- package/esm2022/lib/utils/attach.mjs +2 -2
- package/esm2022/lib/utils/create-injection-token.mjs +47 -0
- package/esm2022/lib/utils/is.mjs +1 -1
- package/esm2022/lib/utils/make.mjs +1 -1
- package/esm2022/lib/utils/safe-detect-changes.mjs +15 -13
- package/esm2022/lib/utils/signal-store.mjs +91 -0
- package/esm2022/lib/utils/update.mjs +1 -1
- package/fesm2022/angular-three.mjs +1770 -1589
- package/fesm2022/angular-three.mjs.map +1 -1
- package/index.d.ts +10 -9
- package/lib/{di/before-render.d.ts → before-render.d.ts} +1 -1
- package/lib/canvas.d.ts +81 -11
- package/lib/directives/args.d.ts +2 -2
- package/lib/directives/common.d.ts +5 -1
- package/lib/directives/key.d.ts +10 -0
- package/lib/directives/parent.d.ts +5 -5
- package/lib/dom/events.d.ts +3 -2
- package/lib/events.d.ts +78 -2
- package/lib/instance.d.ts +36 -0
- package/lib/loader.d.ts +13 -2
- package/lib/loop.d.ts +64 -6
- package/lib/portal.d.ts +20 -12
- package/lib/{di/ref.d.ts → ref.d.ts} +3 -2
- package/lib/renderer/catalogue.d.ts +9 -0
- package/lib/renderer/constants.d.ts +20 -0
- package/lib/renderer/index.d.ts +5 -0
- package/lib/renderer/store.d.ts +19 -15
- package/lib/renderer/utils.d.ts +28 -18
- package/lib/roots.d.ts +11 -0
- package/lib/routed-scene.d.ts +1 -1
- package/lib/store.d.ts +143 -0
- package/lib/three-types.d.ts +6 -6
- package/lib/types.d.ts +1 -309
- package/lib/utils/apply-props.d.ts +4 -2
- package/lib/utils/attach.d.ts +5 -3
- package/lib/utils/create-injection-token.d.ts +27 -0
- package/lib/utils/is.d.ts +4 -3
- package/lib/utils/make.d.ts +12 -1
- package/lib/utils/safe-detect-changes.d.ts +2 -2
- package/lib/utils/signal-store.d.ts +17 -0
- package/lib/utils/update.d.ts +1 -1
- package/metadata.json +1 -1
- package/package.json +5 -4
- package/plugin/generators.json +47 -17
- package/plugin/package.json +2 -5
- package/plugin/src/generators/init/compat.d.ts +3 -1
- package/plugin/src/generators/init/compat.js +2 -2
- package/plugin/src/generators/init/compat.js.map +1 -1
- package/plugin/src/generators/init/files/experience/experience.component.html.__tmpl__ +4 -0
- package/plugin/src/generators/init/files/experience/experience.component.ts.__tmpl__ +17 -0
- package/plugin/src/generators/init/generator.d.ts +6 -0
- package/plugin/src/generators/init/generator.js +144 -0
- package/plugin/src/generators/init/generator.js.map +1 -0
- package/plugin/src/generators/init/schema.json +15 -4
- package/plugin/src/generators/init-cannon/compat.d.ts +2 -0
- package/plugin/src/generators/init-cannon/compat.js +6 -0
- package/plugin/src/generators/init-cannon/compat.js.map +1 -0
- package/plugin/src/generators/init-cannon/generator.d.ts +2 -0
- package/plugin/src/generators/init-cannon/generator.js +22 -0
- package/plugin/src/generators/init-cannon/generator.js.map +1 -0
- package/plugin/src/generators/init-cannon/schema.json +6 -0
- package/plugin/src/generators/init-postprocessing/compat.d.ts +2 -0
- package/plugin/src/generators/init-postprocessing/compat.js +6 -0
- package/plugin/src/generators/init-postprocessing/compat.js.map +1 -0
- package/plugin/src/generators/init-postprocessing/generator.d.ts +2 -0
- package/plugin/src/generators/init-postprocessing/generator.js +20 -0
- package/plugin/src/generators/init-postprocessing/generator.js.map +1 -0
- package/plugin/src/generators/init-postprocessing/schema.json +6 -0
- package/plugin/src/generators/init-soba/compat.d.ts +2 -0
- package/plugin/src/generators/init-soba/compat.js +6 -0
- package/plugin/src/generators/init-soba/compat.js.map +1 -0
- package/plugin/src/generators/init-soba/generator.d.ts +2 -0
- package/plugin/src/generators/init-soba/generator.js +26 -0
- package/plugin/src/generators/init-soba/generator.js.map +1 -0
- package/plugin/src/generators/init-soba/schema.json +6 -0
- package/plugin/src/generators/utils.d.ts +2 -0
- package/plugin/src/generators/utils.js +34 -0
- package/plugin/src/generators/utils.js.map +1 -0
- package/plugin/src/generators/versions.d.ts +12 -0
- package/plugin/src/generators/versions.js +16 -0
- package/plugin/src/generators/versions.js.map +1 -0
- package/plugin/src/index.d.ts +3 -1
- package/plugin/src/index.js +7 -3
- package/plugin/src/index.js.map +1 -1
- package/web-types.json +1 -1
- package/esm2022/lib/di/before-render.mjs +0 -13
- package/esm2022/lib/di/catalogue.mjs +0 -7
- package/esm2022/lib/di/ref.mjs +0 -49
- package/esm2022/lib/renderer/di.mjs +0 -3
- package/esm2022/lib/renderer/enums.mjs +0 -2
- package/esm2022/lib/renderer/provider.mjs +0 -18
- package/esm2022/lib/renderer/renderer.mjs +0 -365
- package/esm2022/lib/stores/signal.store.mjs +0 -81
- package/esm2022/lib/stores/store.mjs +0 -423
- package/esm2022/lib/utils/assert-in-injection-context.mjs +0 -14
- package/esm2022/lib/utils/instance.mjs +0 -63
- package/esm2022/lib/utils/signal.mjs +0 -24
- package/esm2022/lib/utils/timing.mjs +0 -21
- package/lib/di/catalogue.d.ts +0 -3
- package/lib/renderer/di.d.ts +0 -2
- package/lib/renderer/enums.d.ts +0 -26
- package/lib/renderer/provider.d.ts +0 -8
- package/lib/renderer/renderer.d.ts +0 -49
- package/lib/stores/signal.store.d.ts +0 -20
- package/lib/stores/store.d.ts +0 -13
- package/lib/utils/instance.d.ts +0 -4
- package/lib/utils/signal.d.ts +0 -2
- package/lib/utils/timing.d.ts +0 -4
- package/plugin/src/generators/init/init.d.ts +0 -5
- package/plugin/src/generators/init/init.js +0 -56
- package/plugin/src/generators/init/init.js.map +0 -1
- /package/lib/utils/{assert-in-injection-context.d.ts → assert-injection-context.d.ts} +0 -0
|
@@ -0,0 +1,419 @@
|
|
|
1
|
+
import { DOCUMENT } from '@angular/common';
|
|
2
|
+
import { ChangeDetectorRef, Injectable, Injector, NgZone, RendererFactory2, effect, getDebugNode, inject, makeEnvironmentProviders, provideZoneChangeDetection, signal, untracked, } from '@angular/core';
|
|
3
|
+
import { getLocalState, prepare } from '../instance';
|
|
4
|
+
import { injectNgtStore, provideNgtStore } from '../store';
|
|
5
|
+
import { is } from '../utils/is';
|
|
6
|
+
import { injectNgtCatalogue } from './catalogue';
|
|
7
|
+
import { HTML, ROUTED_SCENE, SPECIAL_DOM_TAG } from './constants';
|
|
8
|
+
import { NGT_COMPOUND_PREFIXES, NgtRendererStore } from './store';
|
|
9
|
+
import { NgtCompoundClassId, NgtRendererClassId, attachThreeChild, kebabToPascal, processThreeEvent, removeThreeChild, } from './utils';
|
|
10
|
+
import * as i0 from "@angular/core";
|
|
11
|
+
class NgtRendererFactory {
|
|
12
|
+
constructor() {
|
|
13
|
+
this.delegateRendererFactory = inject(RendererFactory2, { skipSelf: true });
|
|
14
|
+
this.zone = inject(NgZone);
|
|
15
|
+
this.catalogue = injectNgtCatalogue();
|
|
16
|
+
this.cdr = inject(ChangeDetectorRef);
|
|
17
|
+
this.rendererMap = new Map();
|
|
18
|
+
this.routedSet = new Set();
|
|
19
|
+
// all Renderer instances share the same Store
|
|
20
|
+
this.rendererStore = new NgtRendererStore({
|
|
21
|
+
portals: [],
|
|
22
|
+
store: injectNgtStore(),
|
|
23
|
+
compoundPrefixes: inject(NGT_COMPOUND_PREFIXES),
|
|
24
|
+
document: inject(DOCUMENT),
|
|
25
|
+
});
|
|
26
|
+
}
|
|
27
|
+
createRenderer(hostElement, type) {
|
|
28
|
+
const delegate = this.delegateRendererFactory.createRenderer(hostElement, type);
|
|
29
|
+
if (!type)
|
|
30
|
+
return delegate;
|
|
31
|
+
// TODO: handle html in canvas
|
|
32
|
+
if (type['type'][HTML]) {
|
|
33
|
+
this.rendererMap.set(type.id, delegate);
|
|
34
|
+
return delegate;
|
|
35
|
+
}
|
|
36
|
+
if (type['type'][ROUTED_SCENE]) {
|
|
37
|
+
this.routedSet.add(type.id);
|
|
38
|
+
}
|
|
39
|
+
let renderer = this.rendererMap.get(type.id);
|
|
40
|
+
if (!renderer) {
|
|
41
|
+
renderer = new NgtRenderer(delegate, this.rendererStore, this.catalogue, this.zone, this.cdr,
|
|
42
|
+
// setting root scene if there's no routed scene OR this component is the routed Scene
|
|
43
|
+
!hostElement && (this.routedSet.size === 0 || this.routedSet.has(type.id)));
|
|
44
|
+
this.rendererMap.set(type.id, renderer);
|
|
45
|
+
}
|
|
46
|
+
return renderer;
|
|
47
|
+
}
|
|
48
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.2", ngImport: i0, type: NgtRendererFactory, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
49
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.2", ngImport: i0, type: NgtRendererFactory }); }
|
|
50
|
+
}
|
|
51
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.2", ngImport: i0, type: NgtRendererFactory, decorators: [{
|
|
52
|
+
type: Injectable
|
|
53
|
+
}] });
|
|
54
|
+
/**
|
|
55
|
+
* Anything abbreviated with rS/RS stands for RendererState
|
|
56
|
+
*/
|
|
57
|
+
class NgtRenderer {
|
|
58
|
+
constructor(delegate, store, catalogue, zone, cdr, root = true) {
|
|
59
|
+
this.delegate = delegate;
|
|
60
|
+
this.store = store;
|
|
61
|
+
this.catalogue = catalogue;
|
|
62
|
+
this.zone = zone;
|
|
63
|
+
this.cdr = cdr;
|
|
64
|
+
this.root = root;
|
|
65
|
+
this.createText = this.delegate.createText.bind(this.delegate);
|
|
66
|
+
this.destroy = this.delegate.destroy.bind(this.delegate);
|
|
67
|
+
this.destroyNode = null;
|
|
68
|
+
this.selectRootElement = this.delegate.selectRootElement.bind(this.delegate);
|
|
69
|
+
this.nextSibling = this.delegate.nextSibling.bind(this.delegate);
|
|
70
|
+
this.removeAttribute = this.delegate.removeAttribute.bind(this.delegate);
|
|
71
|
+
this.addClass = this.delegate.addClass.bind(this.delegate);
|
|
72
|
+
this.removeClass = this.delegate.removeClass.bind(this.delegate);
|
|
73
|
+
this.setStyle = this.delegate.setStyle.bind(this.delegate);
|
|
74
|
+
this.removeStyle = this.delegate.removeStyle.bind(this.delegate);
|
|
75
|
+
this.setValue = this.delegate.setValue.bind(this.delegate);
|
|
76
|
+
}
|
|
77
|
+
createElement(name, namespace) {
|
|
78
|
+
const element = this.delegate.createElement(name, namespace);
|
|
79
|
+
// on first pass, we return the Root Scene as the root node
|
|
80
|
+
if (this.root) {
|
|
81
|
+
this.root = false;
|
|
82
|
+
const node = this.store.createNode('three', this.store.rootScene);
|
|
83
|
+
node.__ngt_renderer__[NgtRendererClassId.injectorFactory] = () => getDebugNode(element).injector;
|
|
84
|
+
return node;
|
|
85
|
+
}
|
|
86
|
+
// handle compound
|
|
87
|
+
if (this.store.isCompound(name)) {
|
|
88
|
+
return this.store.createNode('compound', element);
|
|
89
|
+
}
|
|
90
|
+
// handle portal
|
|
91
|
+
if (name === SPECIAL_DOM_TAG.NGT_PORTAL) {
|
|
92
|
+
return this.store.createNode('portal', element);
|
|
93
|
+
}
|
|
94
|
+
// handle raw value
|
|
95
|
+
if (name === SPECIAL_DOM_TAG.NGT_VALUE) {
|
|
96
|
+
return this.store.createNode('three', Object.assign({ __ngt_renderer__: { rawValue: undefined } },
|
|
97
|
+
// NOTE: we assign this manually to a raw value node
|
|
98
|
+
// because we say it is a 'three' node but we're not using prepare()
|
|
99
|
+
{ __ngt__: { isRaw: true, parent: signal(null) } }));
|
|
100
|
+
}
|
|
101
|
+
const { injectedArgs, injectedParent, store } = this.store.getCreationState();
|
|
102
|
+
let parent = injectedParent;
|
|
103
|
+
if (typeof injectedParent === 'string') {
|
|
104
|
+
parent = store
|
|
105
|
+
.get('scene')
|
|
106
|
+
.getObjectByName(injectedParent);
|
|
107
|
+
}
|
|
108
|
+
// handle primitive
|
|
109
|
+
if (name === SPECIAL_DOM_TAG.NGT_PRIMITIVE) {
|
|
110
|
+
if (!injectedArgs[0])
|
|
111
|
+
throw new Error(`[NGT] ngt-primitive without args is invalid`);
|
|
112
|
+
const object = injectedArgs[0];
|
|
113
|
+
let localState = getLocalState(object);
|
|
114
|
+
if (!Object.keys(localState).length) {
|
|
115
|
+
// NOTE: if an object isn't already "prepared", we prepare it
|
|
116
|
+
localState = getLocalState(prepare(object, { store, args: injectedArgs, primitive: true }));
|
|
117
|
+
}
|
|
118
|
+
if (!localState.store)
|
|
119
|
+
localState.store = store;
|
|
120
|
+
const node = this.store.createNode('three', object);
|
|
121
|
+
if (parent) {
|
|
122
|
+
node.__ngt_renderer__[NgtRendererClassId.injectedParent] = parent;
|
|
123
|
+
}
|
|
124
|
+
return node;
|
|
125
|
+
}
|
|
126
|
+
const threeTag = name.startsWith('ngt') ? name.slice(4) : name;
|
|
127
|
+
const threeName = kebabToPascal(threeTag);
|
|
128
|
+
const threeTarget = this.catalogue[threeName];
|
|
129
|
+
// we have the THREE constructor here, handle it
|
|
130
|
+
if (threeTarget) {
|
|
131
|
+
const instance = prepare(new threeTarget(...injectedArgs), { store, args: injectedArgs });
|
|
132
|
+
const node = this.store.createNode('three', instance);
|
|
133
|
+
const localState = getLocalState(instance);
|
|
134
|
+
// auto-attach for geometry and material
|
|
135
|
+
if (is.geometry(instance)) {
|
|
136
|
+
localState.attach = ['geometry'];
|
|
137
|
+
}
|
|
138
|
+
else if (is.material(instance)) {
|
|
139
|
+
localState.attach = ['material'];
|
|
140
|
+
}
|
|
141
|
+
if (parent) {
|
|
142
|
+
node.__ngt_renderer__[NgtRendererClassId.injectedParent] = parent;
|
|
143
|
+
}
|
|
144
|
+
return node;
|
|
145
|
+
}
|
|
146
|
+
return this.store.createNode('dom', element);
|
|
147
|
+
}
|
|
148
|
+
createComment(value) {
|
|
149
|
+
return this.store.createNode('comment', this.delegate.createComment(value));
|
|
150
|
+
}
|
|
151
|
+
appendChild(parent, newChild) {
|
|
152
|
+
const pRS = parent.__ngt_renderer__;
|
|
153
|
+
const cRS = newChild.__ngt_renderer__;
|
|
154
|
+
if (pRS[NgtRendererClassId.type] === 'dom' &&
|
|
155
|
+
(newChild instanceof Text || cRS[NgtRendererClassId.type] === 'dom')) {
|
|
156
|
+
this.store.addChild(parent, newChild);
|
|
157
|
+
this.delegate.appendChild(parent, newChild);
|
|
158
|
+
if (cRS) {
|
|
159
|
+
this.store.setParent(newChild, parent);
|
|
160
|
+
if (this.shouldFindGrandparentInstance(pRS, cRS, newChild)) {
|
|
161
|
+
// we'll try to get the grandparent instance here so that we can run appendChild with both instances
|
|
162
|
+
const closestGrandparentInstance = this.store.getClosestParentWithInstance(parent);
|
|
163
|
+
if (closestGrandparentInstance)
|
|
164
|
+
this.appendChild(closestGrandparentInstance, newChild);
|
|
165
|
+
}
|
|
166
|
+
}
|
|
167
|
+
return;
|
|
168
|
+
}
|
|
169
|
+
if (cRS?.[NgtRendererClassId.type] === 'comment') {
|
|
170
|
+
this.store.setParent(newChild, parent);
|
|
171
|
+
return;
|
|
172
|
+
}
|
|
173
|
+
if (cRS?.[NgtRendererClassId.injectedParent]) {
|
|
174
|
+
if (is.ref(cRS[NgtRendererClassId.injectedParent])) {
|
|
175
|
+
const injector = cRS[NgtRendererClassId.injectorFactory]().get(Injector, null);
|
|
176
|
+
if (!injector) {
|
|
177
|
+
console.warn(`[NGT] NgtRenderer is attempting to start an effect for injectedParent but no Injector is found.`);
|
|
178
|
+
return;
|
|
179
|
+
}
|
|
180
|
+
const watcher = effect(() => {
|
|
181
|
+
const injectedParent = cRS[NgtRendererClassId.injectedParent].nativeElement;
|
|
182
|
+
if (injectedParent && injectedParent !== parent) {
|
|
183
|
+
this.appendChild(injectedParent, newChild);
|
|
184
|
+
// only run this effect once
|
|
185
|
+
// as soon as we re-run appendChild with the injectedParent, we stop the effect
|
|
186
|
+
watcher.destroy();
|
|
187
|
+
}
|
|
188
|
+
}, { injector, manualCleanup: true });
|
|
189
|
+
return;
|
|
190
|
+
}
|
|
191
|
+
else if (parent !== cRS[NgtRendererClassId.injectedParent]) {
|
|
192
|
+
this.appendChild(cRS[NgtRendererClassId.injectedParent], newChild);
|
|
193
|
+
return;
|
|
194
|
+
}
|
|
195
|
+
}
|
|
196
|
+
this.store.setParent(newChild, parent);
|
|
197
|
+
this.store.addChild(parent, newChild);
|
|
198
|
+
// if new child is a portal
|
|
199
|
+
if (cRS?.[NgtRendererClassId.type] === 'portal') {
|
|
200
|
+
this.store.processPortalContainer(newChild);
|
|
201
|
+
if (cRS[NgtRendererClassId.portalContainer]) {
|
|
202
|
+
this.appendChild(parent, cRS[NgtRendererClassId.portalContainer]);
|
|
203
|
+
}
|
|
204
|
+
return;
|
|
205
|
+
}
|
|
206
|
+
// if parent is a portal
|
|
207
|
+
if (pRS[NgtRendererClassId.type] === 'portal') {
|
|
208
|
+
this.store.processPortalContainer(parent);
|
|
209
|
+
if (pRS[NgtRendererClassId.portalContainer]) {
|
|
210
|
+
this.appendChild(pRS[NgtRendererClassId.portalContainer], newChild);
|
|
211
|
+
}
|
|
212
|
+
return;
|
|
213
|
+
}
|
|
214
|
+
// if both are three instances, straightforward case
|
|
215
|
+
if (pRS[NgtRendererClassId.type] === 'three' && cRS?.[NgtRendererClassId.type] === 'three') {
|
|
216
|
+
// if child already attached to a parent, skip
|
|
217
|
+
if (getLocalState(newChild).parent && untracked(getLocalState(newChild).parent))
|
|
218
|
+
return;
|
|
219
|
+
// attach THREE child
|
|
220
|
+
attachThreeChild(parent, newChild);
|
|
221
|
+
// here, we handle the special case of if the parent has a compoundParent, which means this child is part of a compound parent template
|
|
222
|
+
if (!cRS[NgtRendererClassId.compound])
|
|
223
|
+
return;
|
|
224
|
+
const closestGrandparentWithCompound = this.store.getClosestParentWithCompound(parent);
|
|
225
|
+
if (!closestGrandparentWithCompound)
|
|
226
|
+
return;
|
|
227
|
+
this.appendChild(closestGrandparentWithCompound, newChild);
|
|
228
|
+
return;
|
|
229
|
+
}
|
|
230
|
+
// if only the parent is the THREE instance
|
|
231
|
+
if (pRS[NgtRendererClassId.type] === 'three') {
|
|
232
|
+
for (const renderChild of cRS?.[NgtRendererClassId.children]) {
|
|
233
|
+
this.appendChild(parent, renderChild);
|
|
234
|
+
}
|
|
235
|
+
}
|
|
236
|
+
// if parent is a compound
|
|
237
|
+
if (pRS[NgtRendererClassId.type] === 'compound') {
|
|
238
|
+
// if compound doesn't have a THREE instance set yet
|
|
239
|
+
if (!pRS[NgtRendererClassId.compounded] && cRS[NgtRendererClassId.type] === 'three') {
|
|
240
|
+
// if child is indeed an ngtCompound
|
|
241
|
+
if (cRS[NgtRendererClassId.compound])
|
|
242
|
+
this.store.setCompound(parent, newChild);
|
|
243
|
+
// if not, we track the parent (that is supposedly the compound component) on this three instance
|
|
244
|
+
else if (!cRS[NgtRendererClassId.compoundParent])
|
|
245
|
+
cRS[NgtRendererClassId.compoundParent] = parent;
|
|
246
|
+
}
|
|
247
|
+
// reset the compound if it's changed
|
|
248
|
+
if (pRS[NgtRendererClassId.compounded] &&
|
|
249
|
+
cRS[NgtRendererClassId.type] === 'three' &&
|
|
250
|
+
cRS[NgtRendererClassId.compound] &&
|
|
251
|
+
pRS[NgtRendererClassId.compounded] !== newChild) {
|
|
252
|
+
this.store.setCompound(parent, newChild);
|
|
253
|
+
}
|
|
254
|
+
}
|
|
255
|
+
if (this.shouldFindGrandparentInstance(pRS, cRS, newChild)) {
|
|
256
|
+
// we'll try to get the grandparent instance here so that we can run appendChild with both instances
|
|
257
|
+
const closestGrandparentInstance = this.store.getClosestParentWithInstance(parent);
|
|
258
|
+
if (closestGrandparentInstance)
|
|
259
|
+
this.appendChild(closestGrandparentInstance, newChild);
|
|
260
|
+
return;
|
|
261
|
+
}
|
|
262
|
+
}
|
|
263
|
+
insertBefore(parent, newChild) {
|
|
264
|
+
if (parent == null || !parent.__ngt_renderer__ || parent === newChild)
|
|
265
|
+
return;
|
|
266
|
+
this.appendChild(parent, newChild);
|
|
267
|
+
}
|
|
268
|
+
removeChild(parent, oldChild, isHostElement) {
|
|
269
|
+
const pRS = parent.__ngt_renderer__;
|
|
270
|
+
const cRS = oldChild.__ngt_renderer__;
|
|
271
|
+
if ((!cRS || !pRS) &&
|
|
272
|
+
parent instanceof Element &&
|
|
273
|
+
(oldChild instanceof Element || oldChild instanceof Text || oldChild instanceof Comment)) {
|
|
274
|
+
this.delegate.removeChild(parent, oldChild);
|
|
275
|
+
this.store.destroy(oldChild, parent);
|
|
276
|
+
return;
|
|
277
|
+
}
|
|
278
|
+
if (cRS[NgtRendererClassId.type] === 'dom' && (!pRS || pRS[NgtRendererClassId.type] === 'dom')) {
|
|
279
|
+
this.delegate.removeChild(parent, oldChild);
|
|
280
|
+
this.store.destroy(oldChild, parent);
|
|
281
|
+
return;
|
|
282
|
+
}
|
|
283
|
+
if (pRS[NgtRendererClassId.type] === 'three' && cRS[NgtRendererClassId.type] === 'three') {
|
|
284
|
+
removeThreeChild(parent, oldChild, true);
|
|
285
|
+
this.store.destroy(oldChild, parent);
|
|
286
|
+
return;
|
|
287
|
+
}
|
|
288
|
+
if (pRS[NgtRendererClassId.type] === 'compound' && pRS[NgtRendererClassId.parent]) {
|
|
289
|
+
this.removeChild(pRS[NgtRendererClassId.parent], oldChild, isHostElement);
|
|
290
|
+
return;
|
|
291
|
+
}
|
|
292
|
+
if (pRS[NgtRendererClassId.type] === 'three') {
|
|
293
|
+
this.store.destroy(oldChild, parent);
|
|
294
|
+
return;
|
|
295
|
+
}
|
|
296
|
+
const closestGrandparentInstance = this.store.getClosestParentWithInstance(parent);
|
|
297
|
+
if (closestGrandparentInstance)
|
|
298
|
+
this.removeChild(closestGrandparentInstance, oldChild, isHostElement);
|
|
299
|
+
this.store.destroy(oldChild, closestGrandparentInstance);
|
|
300
|
+
}
|
|
301
|
+
parentNode(node) {
|
|
302
|
+
const rS = node.__ngt_renderer__;
|
|
303
|
+
if (rS?.[NgtRendererClassId.parent])
|
|
304
|
+
return rS[NgtRendererClassId.parent];
|
|
305
|
+
return this.delegate.parentNode(node);
|
|
306
|
+
}
|
|
307
|
+
setAttribute(el, name, value, namespace) {
|
|
308
|
+
const rS = el.__ngt_renderer__;
|
|
309
|
+
if (rS[NgtRendererClassId.type] === 'compound') {
|
|
310
|
+
// we don't have the compound instance yet
|
|
311
|
+
rS[NgtRendererClassId.attributes][name] = value;
|
|
312
|
+
if (!rS[NgtRendererClassId.compounded]) {
|
|
313
|
+
this.store.queueOperation(el, ['op', () => this.setAttribute(el, name, value, namespace)]);
|
|
314
|
+
return;
|
|
315
|
+
}
|
|
316
|
+
this.setAttribute(rS[NgtRendererClassId.compounded], name, value, namespace);
|
|
317
|
+
return;
|
|
318
|
+
}
|
|
319
|
+
if (rS[NgtRendererClassId.type] === 'three') {
|
|
320
|
+
this.store.applyAttribute(el, name, value);
|
|
321
|
+
return;
|
|
322
|
+
}
|
|
323
|
+
return this.delegate.setAttribute(el, name, value);
|
|
324
|
+
}
|
|
325
|
+
setProperty(el, name, value) {
|
|
326
|
+
// TODO: should we support ref value
|
|
327
|
+
const rS = el.__ngt_renderer__;
|
|
328
|
+
if (rS[NgtRendererClassId.type] === 'compound') {
|
|
329
|
+
// we don't have the compound instance yet
|
|
330
|
+
rS[NgtRendererClassId.properties][name] = value;
|
|
331
|
+
if (!rS[NgtRendererClassId.compounded]) {
|
|
332
|
+
this.store.queueOperation(el, ['op', () => this.setProperty(el, name, value)]);
|
|
333
|
+
return;
|
|
334
|
+
}
|
|
335
|
+
if (rS[NgtRendererClassId.compounded].__ngt_renderer__[NgtRendererClassId.compound]) {
|
|
336
|
+
Object.assign(rS[NgtRendererClassId.compounded].__ngt_renderer__[NgtRendererClassId.compound][NgtCompoundClassId.props], { [name]: value });
|
|
337
|
+
}
|
|
338
|
+
this.setProperty(rS[NgtRendererClassId.compounded], name, value);
|
|
339
|
+
return;
|
|
340
|
+
}
|
|
341
|
+
if (rS[NgtRendererClassId.type] === 'three') {
|
|
342
|
+
this.store.applyProperty(el, name, value);
|
|
343
|
+
return;
|
|
344
|
+
}
|
|
345
|
+
return this.delegate.setProperty(el, name, value);
|
|
346
|
+
}
|
|
347
|
+
listen(target, eventName, callback) {
|
|
348
|
+
const rS = target.__ngt_renderer__;
|
|
349
|
+
// if the target doesn't have __ngt_renderer__, we delegate
|
|
350
|
+
// if target is DOM node, then we pass that to delegate Renderer
|
|
351
|
+
if (!rS || this.store.isDOM(target)) {
|
|
352
|
+
return this.delegate.listen(target, eventName, callback);
|
|
353
|
+
}
|
|
354
|
+
if (rS[NgtRendererClassId.type] === 'three' ||
|
|
355
|
+
(rS[NgtRendererClassId.type] === 'compound' && rS[NgtRendererClassId.compounded])) {
|
|
356
|
+
const instance = rS[NgtRendererClassId.compounded] || target;
|
|
357
|
+
const priority = getLocalState(target).priority;
|
|
358
|
+
const targetCdr = rS[NgtRendererClassId.injectorFactory]?.().get(ChangeDetectorRef, null) ||
|
|
359
|
+
rS[NgtRendererClassId.parent]?.__ngt_renderer__?.[NgtRendererClassId.injectorFactory]?.().get(ChangeDetectorRef, null);
|
|
360
|
+
return processThreeEvent(instance, priority || 0, eventName, callback, this.zone, this.cdr, targetCdr);
|
|
361
|
+
}
|
|
362
|
+
if (rS[NgtRendererClassId.type] === 'compound' && !rS[NgtRendererClassId.compounded]) {
|
|
363
|
+
this.store.queueOperation(target, [
|
|
364
|
+
'op',
|
|
365
|
+
() => this.store.queueOperation(target, ['cleanUp', this.listen(target, eventName, callback)]),
|
|
366
|
+
]);
|
|
367
|
+
return () => { };
|
|
368
|
+
}
|
|
369
|
+
// @ts-expect-error - we know that target is not DOM node
|
|
370
|
+
if (target === this.store.rootScene) {
|
|
371
|
+
let [domTarget, event] = eventName.split(':');
|
|
372
|
+
if (event == null) {
|
|
373
|
+
event = domTarget;
|
|
374
|
+
domTarget = '';
|
|
375
|
+
}
|
|
376
|
+
const eventTarget = domTarget === 'window'
|
|
377
|
+
? target['ownerDocument']['defaultView']
|
|
378
|
+
: target['ownerDocument'];
|
|
379
|
+
return this.delegate.listen(eventTarget, event, callback);
|
|
380
|
+
}
|
|
381
|
+
return () => { };
|
|
382
|
+
}
|
|
383
|
+
shouldFindGrandparentInstance(pRS, cRS, child) {
|
|
384
|
+
const pType = pRS[NgtRendererClassId.type];
|
|
385
|
+
const cType = cRS[NgtRendererClassId.type];
|
|
386
|
+
const isParentCompounded = pRS[NgtRendererClassId.compounded];
|
|
387
|
+
const isChildCompounded = cRS[NgtRendererClassId.compounded];
|
|
388
|
+
// if child is three but haven't been attached to a parent yet
|
|
389
|
+
const isDanglingThreeChild = cType === 'three' && !untracked(getLocalState(child).parent);
|
|
390
|
+
// or both parent and child are DOM elements
|
|
391
|
+
// or they are compound AND haven't had a THREE instance yet
|
|
392
|
+
const isParentStillDOM = pType === 'dom' || (pType === 'compound' && !isParentCompounded);
|
|
393
|
+
const isChildStillDOM = cType === 'dom' || (cType === 'compound' && !isChildCompounded);
|
|
394
|
+
// and the child is a compounded compound
|
|
395
|
+
const isCompoundChildCompounded = cType === 'compound' && !!isChildCompounded;
|
|
396
|
+
return (isDanglingThreeChild ||
|
|
397
|
+
(isParentStillDOM && isChildStillDOM) ||
|
|
398
|
+
(isParentStillDOM && isCompoundChildCompounded));
|
|
399
|
+
}
|
|
400
|
+
get data() {
|
|
401
|
+
return this.delegate.data;
|
|
402
|
+
}
|
|
403
|
+
}
|
|
404
|
+
export function provideNgtRenderer(store, compoundPrefixes, cdr) {
|
|
405
|
+
if (!compoundPrefixes.includes('ngts'))
|
|
406
|
+
compoundPrefixes.push('ngts');
|
|
407
|
+
if (!compoundPrefixes.includes('ngtp'))
|
|
408
|
+
compoundPrefixes.push('ngtp');
|
|
409
|
+
return makeEnvironmentProviders([
|
|
410
|
+
{ provide: RendererFactory2, useClass: NgtRendererFactory },
|
|
411
|
+
{ provide: NGT_COMPOUND_PREFIXES, useValue: compoundPrefixes },
|
|
412
|
+
{ provide: ChangeDetectorRef, useValue: cdr },
|
|
413
|
+
provideNgtStore(store),
|
|
414
|
+
provideZoneChangeDetection({ runCoalescing: true, eventCoalescing: true }),
|
|
415
|
+
]);
|
|
416
|
+
}
|
|
417
|
+
export { extend } from './catalogue';
|
|
418
|
+
export { HTML } from './constants';
|
|
419
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../libs/core/src/lib/renderer/index.ts"],"names":[],"mappings":"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","sourcesContent":["import { DOCUMENT } from '@angular/common';\nimport {\n\tChangeDetectorRef,\n\tInjectable,\n\tInjector,\n\tNgZone,\n\tRendererFactory2,\n\teffect,\n\tgetDebugNode,\n\tinject,\n\tmakeEnvironmentProviders,\n\tprovideZoneChangeDetection,\n\tsignal,\n\tuntracked,\n\ttype Renderer2,\n\ttype RendererType2,\n} from '@angular/core';\nimport { getLocalState, prepare } from '../instance';\nimport type { NgtInjectedRef } from '../ref';\nimport { injectNgtStore, provideNgtStore, type NgtStore } from '../store';\nimport type { NgtAnyRecord } from '../types';\nimport { is } from '../utils/is';\nimport { injectNgtCatalogue, type NgtAnyConstructor } from './catalogue';\nimport { HTML, ROUTED_SCENE, SPECIAL_DOM_TAG } from './constants';\nimport { NGT_COMPOUND_PREFIXES, NgtRendererStore, type NgtRendererNode, type NgtRendererState } from './store';\nimport {\n\tNgtCompoundClassId,\n\tNgtRendererClassId,\n\tattachThreeChild,\n\tkebabToPascal,\n\tprocessThreeEvent,\n\tremoveThreeChild,\n} from './utils';\n\n@Injectable()\nclass NgtRendererFactory implements RendererFactory2 {\n\tprivate delegateRendererFactory = inject(RendererFactory2, { skipSelf: true });\n\tprivate zone = inject(NgZone);\n\tprivate catalogue = injectNgtCatalogue();\n\tprivate cdr = inject(ChangeDetectorRef);\n\n\tprivate rendererMap = new Map<string, Renderer2>();\n\tprivate routedSet = new Set<string>();\n\n\t// all Renderer instances share the same Store\n\tprivate rendererStore = new NgtRendererStore({\n\t\tportals: [],\n\t\tstore: injectNgtStore(),\n\t\tcompoundPrefixes: inject(NGT_COMPOUND_PREFIXES),\n\t\tdocument: inject(DOCUMENT),\n\t});\n\n\tcreateRenderer(hostElement: any, type: RendererType2 | null): Renderer2 {\n\t\tconst delegate = this.delegateRendererFactory.createRenderer(hostElement, type);\n\t\tif (!type) return delegate;\n\t\t// TODO: handle html in canvas\n\t\tif ((type as NgtAnyRecord)['type'][HTML]) {\n\t\t\tthis.rendererMap.set(type.id, delegate);\n\t\t\treturn delegate;\n\t\t}\n\t\tif ((type as NgtAnyRecord)['type'][ROUTED_SCENE]) {\n\t\t\tthis.routedSet.add(type.id);\n\t\t}\n\n\t\tlet renderer = this.rendererMap.get(type.id);\n\n\t\tif (!renderer) {\n\t\t\trenderer = new NgtRenderer(\n\t\t\t\tdelegate,\n\t\t\t\tthis.rendererStore,\n\t\t\t\tthis.catalogue,\n\t\t\t\tthis.zone,\n\t\t\t\tthis.cdr,\n\t\t\t\t// setting root scene if there's no routed scene OR this component is the routed Scene\n\t\t\t\t!hostElement && (this.routedSet.size === 0 || this.routedSet.has(type.id)),\n\t\t\t);\n\t\t\tthis.rendererMap.set(type.id, renderer);\n\t\t}\n\t\treturn renderer;\n\t}\n}\n\n/**\n * Anything abbreviated with rS/RS stands for RendererState\n */\nclass NgtRenderer implements Renderer2 {\n\tconstructor(\n\t\tprivate delegate: Renderer2,\n\t\tprivate store: NgtRendererStore,\n\t\tprivate catalogue: Record<string, NgtAnyConstructor>,\n\t\tprivate zone: NgZone,\n\t\tprivate cdr: ChangeDetectorRef,\n\t\tprivate root = true,\n\t) {}\n\n\tcreateElement(name: string, namespace?: string | null | undefined) {\n\t\tconst element = this.delegate.createElement(name, namespace);\n\n\t\t// on first pass, we return the Root Scene as the root node\n\t\tif (this.root) {\n\t\t\tthis.root = false;\n\t\t\tconst node = this.store.createNode('three', this.store.rootScene);\n\t\t\tnode.__ngt_renderer__[NgtRendererClassId.injectorFactory] = () => getDebugNode(element)!.injector;\n\t\t\treturn node;\n\t\t}\n\n\t\t// handle compound\n\t\tif (this.store.isCompound(name)) {\n\t\t\treturn this.store.createNode('compound', element);\n\t\t}\n\n\t\t// handle portal\n\t\tif (name === SPECIAL_DOM_TAG.NGT_PORTAL) {\n\t\t\treturn this.store.createNode('portal', element);\n\t\t}\n\n\t\t// handle raw value\n\t\tif (name === SPECIAL_DOM_TAG.NGT_VALUE) {\n\t\t\treturn this.store.createNode(\n\t\t\t\t'three',\n\t\t\t\tObject.assign(\n\t\t\t\t\t{ __ngt_renderer__: { rawValue: undefined } },\n\t\t\t\t\t// NOTE: we assign this manually to a raw value node\n\t\t\t\t\t// because we say it is a 'three' node but we're not using prepare()\n\t\t\t\t\t{ __ngt__: { isRaw: true, parent: signal(null) } },\n\t\t\t\t),\n\t\t\t);\n\t\t}\n\n\t\tconst { injectedArgs, injectedParent, store } = this.store.getCreationState();\n\n\t\tlet parent = injectedParent as NgtRendererState[NgtRendererClassId.injectedParent];\n\t\tif (typeof injectedParent === 'string') {\n\t\t\tparent = store\n\t\t\t\t.get('scene')\n\t\t\t\t.getObjectByName(injectedParent) as unknown as NgtRendererState[NgtRendererClassId.injectedParent];\n\t\t}\n\n\t\t// handle primitive\n\t\tif (name === SPECIAL_DOM_TAG.NGT_PRIMITIVE) {\n\t\t\tif (!injectedArgs[0]) throw new Error(`[NGT] ngt-primitive without args is invalid`);\n\t\t\tconst object = injectedArgs[0];\n\t\t\tlet localState = getLocalState(object);\n\t\t\tif (!Object.keys(localState).length) {\n\t\t\t\t// NOTE: if an object isn't already \"prepared\", we prepare it\n\t\t\t\tlocalState = getLocalState(prepare(object, { store, args: injectedArgs, primitive: true }));\n\t\t\t}\n\t\t\tif (!localState.store) localState.store = store;\n\t\t\tconst node = this.store.createNode('three', object);\n\t\t\tif (parent) {\n\t\t\t\tnode.__ngt_renderer__[NgtRendererClassId.injectedParent] = parent;\n\t\t\t}\n\t\t\treturn node;\n\t\t}\n\n\t\tconst threeTag = name.startsWith('ngt') ? name.slice(4) : name;\n\t\tconst threeName = kebabToPascal(threeTag);\n\t\tconst threeTarget = this.catalogue[threeName];\n\t\t// we have the THREE constructor here, handle it\n\t\tif (threeTarget) {\n\t\t\tconst instance = prepare(new threeTarget(...injectedArgs), { store, args: injectedArgs });\n\t\t\tconst node = this.store.createNode('three', instance);\n\t\t\tconst localState = getLocalState(instance);\n\n\t\t\t// auto-attach for geometry and material\n\t\t\tif (is.geometry(instance)) {\n\t\t\t\tlocalState.attach = ['geometry'];\n\t\t\t} else if (is.material(instance)) {\n\t\t\t\tlocalState.attach = ['material'];\n\t\t\t}\n\n\t\t\tif (parent) {\n\t\t\t\tnode.__ngt_renderer__[NgtRendererClassId.injectedParent] = parent;\n\t\t\t}\n\n\t\t\treturn node;\n\t\t}\n\n\t\treturn this.store.createNode('dom', element);\n\t}\n\n\tcreateComment(value: string) {\n\t\treturn this.store.createNode('comment', this.delegate.createComment(value));\n\t}\n\n\tappendChild(parent: NgtRendererNode, newChild: NgtRendererNode): void {\n\t\tconst pRS = parent.__ngt_renderer__;\n\t\tconst cRS = newChild.__ngt_renderer__;\n\n\t\tif (\n\t\t\tpRS[NgtRendererClassId.type] === 'dom' &&\n\t\t\t(newChild instanceof Text || cRS[NgtRendererClassId.type] === 'dom')\n\t\t) {\n\t\t\tthis.store.addChild(parent, newChild);\n\t\t\tthis.delegate.appendChild(parent, newChild);\n\t\t\tif (cRS) {\n\t\t\t\tthis.store.setParent(newChild, parent);\n\t\t\t\tif (this.shouldFindGrandparentInstance(pRS, cRS, newChild)) {\n\t\t\t\t\t// we'll try to get the grandparent instance here so that we can run appendChild with both instances\n\t\t\t\t\tconst closestGrandparentInstance = this.store.getClosestParentWithInstance(parent);\n\t\t\t\t\tif (closestGrandparentInstance) this.appendChild(closestGrandparentInstance, newChild);\n\t\t\t\t}\n\t\t\t}\n\n\t\t\treturn;\n\t\t}\n\n\t\tif (cRS?.[NgtRendererClassId.type] === 'comment') {\n\t\t\tthis.store.setParent(newChild, parent);\n\t\t\treturn;\n\t\t}\n\n\t\tif (cRS?.[NgtRendererClassId.injectedParent]) {\n\t\t\tif (is.ref(cRS[NgtRendererClassId.injectedParent])) {\n\t\t\t\tconst injector = cRS[NgtRendererClassId.injectorFactory]().get(Injector, null);\n\t\t\t\tif (!injector) {\n\t\t\t\t\tconsole.warn(\n\t\t\t\t\t\t`[NGT] NgtRenderer is attempting to start an effect for injectedParent but no Injector is found.`,\n\t\t\t\t\t);\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t\tconst watcher = effect(\n\t\t\t\t\t() => {\n\t\t\t\t\t\tconst injectedParent = (\n\t\t\t\t\t\t\tcRS[NgtRendererClassId.injectedParent] as NgtInjectedRef<NgtRendererNode>\n\t\t\t\t\t\t).nativeElement;\n\t\t\t\t\t\tif (injectedParent && injectedParent !== parent) {\n\t\t\t\t\t\t\tthis.appendChild(injectedParent, newChild);\n\t\t\t\t\t\t\t// only run this effect once\n\t\t\t\t\t\t\t// as soon as we re-run appendChild with the injectedParent, we stop the effect\n\t\t\t\t\t\t\twatcher.destroy();\n\t\t\t\t\t\t}\n\t\t\t\t\t},\n\t\t\t\t\t{ injector, manualCleanup: true },\n\t\t\t\t);\n\t\t\t\treturn;\n\t\t\t} else if (parent !== cRS[NgtRendererClassId.injectedParent]) {\n\t\t\t\tthis.appendChild(cRS[NgtRendererClassId.injectedParent], newChild);\n\t\t\t\treturn;\n\t\t\t}\n\t\t}\n\n\t\tthis.store.setParent(newChild, parent);\n\t\tthis.store.addChild(parent, newChild);\n\n\t\t// if new child is a portal\n\t\tif (cRS?.[NgtRendererClassId.type] === 'portal') {\n\t\t\tthis.store.processPortalContainer(newChild);\n\t\t\tif (cRS[NgtRendererClassId.portalContainer]) {\n\t\t\t\tthis.appendChild(parent, cRS[NgtRendererClassId.portalContainer]);\n\t\t\t}\n\t\t\treturn;\n\t\t}\n\n\t\t// if parent is a portal\n\t\tif (pRS[NgtRendererClassId.type] === 'portal') {\n\t\t\tthis.store.processPortalContainer(parent);\n\t\t\tif (pRS[NgtRendererClassId.portalContainer]) {\n\t\t\t\tthis.appendChild(pRS[NgtRendererClassId.portalContainer], newChild);\n\t\t\t}\n\t\t\treturn;\n\t\t}\n\n\t\t// if both are three instances, straightforward case\n\t\tif (pRS[NgtRendererClassId.type] === 'three' && cRS?.[NgtRendererClassId.type] === 'three') {\n\t\t\t// if child already attached to a parent, skip\n\t\t\tif (getLocalState(newChild).parent && untracked(getLocalState(newChild).parent)) return;\n\t\t\t// attach THREE child\n\t\t\tattachThreeChild(parent, newChild);\n\t\t\t// here, we handle the special case of if the parent has a compoundParent, which means this child is part of a compound parent template\n\t\t\tif (!cRS[NgtRendererClassId.compound]) return;\n\t\t\tconst closestGrandparentWithCompound = this.store.getClosestParentWithCompound(parent);\n\t\t\tif (!closestGrandparentWithCompound) return;\n\t\t\tthis.appendChild(closestGrandparentWithCompound, newChild);\n\t\t\treturn;\n\t\t}\n\n\t\t// if only the parent is the THREE instance\n\t\tif (pRS[NgtRendererClassId.type] === 'three') {\n\t\t\tfor (const renderChild of cRS?.[NgtRendererClassId.children]) {\n\t\t\t\tthis.appendChild(parent, renderChild);\n\t\t\t}\n\t\t}\n\n\t\t// if parent is a compound\n\t\tif (pRS[NgtRendererClassId.type] === 'compound') {\n\t\t\t// if compound doesn't have a THREE instance set yet\n\t\t\tif (!pRS[NgtRendererClassId.compounded] && cRS[NgtRendererClassId.type] === 'three') {\n\t\t\t\t// if child is indeed an ngtCompound\n\t\t\t\tif (cRS[NgtRendererClassId.compound]) this.store.setCompound(parent, newChild);\n\t\t\t\t// if not, we track the parent (that is supposedly the compound component) on this three instance\n\t\t\t\telse if (!cRS[NgtRendererClassId.compoundParent]) cRS[NgtRendererClassId.compoundParent] = parent;\n\t\t\t}\n\n\t\t\t// reset the compound if it's changed\n\t\t\tif (\n\t\t\t\tpRS[NgtRendererClassId.compounded] &&\n\t\t\t\tcRS[NgtRendererClassId.type] === 'three' &&\n\t\t\t\tcRS[NgtRendererClassId.compound] &&\n\t\t\t\tpRS[NgtRendererClassId.compounded] !== newChild\n\t\t\t) {\n\t\t\t\tthis.store.setCompound(parent, newChild);\n\t\t\t}\n\t\t}\n\n\t\tif (this.shouldFindGrandparentInstance(pRS, cRS, newChild)) {\n\t\t\t// we'll try to get the grandparent instance here so that we can run appendChild with both instances\n\t\t\tconst closestGrandparentInstance = this.store.getClosestParentWithInstance(parent);\n\t\t\tif (closestGrandparentInstance) this.appendChild(closestGrandparentInstance, newChild);\n\t\t\treturn;\n\t\t}\n\t}\n\n\tinsertBefore(\n\t\tparent: NgtRendererNode,\n\t\tnewChild: NgtRendererNode,\n\t\t// TODO: we might need these?\n\t\t// refChild: NgtRendererNode\n\t\t// isMove?: boolean | undefined\n\t): void {\n\t\tif (parent == null || !parent.__ngt_renderer__ || parent === newChild) return;\n\t\tthis.appendChild(parent, newChild);\n\t}\n\n\tremoveChild(parent: NgtRendererNode, oldChild: NgtRendererNode, isHostElement?: boolean | undefined): void {\n\t\tconst pRS = parent.__ngt_renderer__;\n\t\tconst cRS = oldChild.__ngt_renderer__;\n\n\t\tif (\n\t\t\t(!cRS || !pRS) &&\n\t\t\tparent instanceof Element &&\n\t\t\t(oldChild instanceof Element || oldChild instanceof Text || oldChild instanceof Comment)\n\t\t) {\n\t\t\tthis.delegate.removeChild(parent, oldChild);\n\t\t\tthis.store.destroy(oldChild, parent);\n\t\t\treturn;\n\t\t}\n\n\t\tif (cRS[NgtRendererClassId.type] === 'dom' && (!pRS || pRS[NgtRendererClassId.type] === 'dom')) {\n\t\t\tthis.delegate.removeChild(parent, oldChild);\n\t\t\tthis.store.destroy(oldChild, parent);\n\t\t\treturn;\n\t\t}\n\n\t\tif (pRS[NgtRendererClassId.type] === 'three' && cRS[NgtRendererClassId.type] === 'three') {\n\t\t\tremoveThreeChild(parent, oldChild, true);\n\t\t\tthis.store.destroy(oldChild, parent);\n\t\t\treturn;\n\t\t}\n\n\t\tif (pRS[NgtRendererClassId.type] === 'compound' && pRS[NgtRendererClassId.parent]) {\n\t\t\tthis.removeChild(pRS[NgtRendererClassId.parent], oldChild, isHostElement);\n\t\t\treturn;\n\t\t}\n\n\t\tif (pRS[NgtRendererClassId.type] === 'three') {\n\t\t\tthis.store.destroy(oldChild, parent);\n\t\t\treturn;\n\t\t}\n\n\t\tconst closestGrandparentInstance = this.store.getClosestParentWithInstance(parent);\n\t\tif (closestGrandparentInstance) this.removeChild(closestGrandparentInstance, oldChild, isHostElement);\n\t\tthis.store.destroy(oldChild, closestGrandparentInstance as NgtRendererNode);\n\t}\n\n\tparentNode(node: NgtRendererNode) {\n\t\tconst rS = node.__ngt_renderer__;\n\t\tif (rS?.[NgtRendererClassId.parent]) return rS[NgtRendererClassId.parent];\n\t\treturn this.delegate.parentNode(node);\n\t}\n\n\tsetAttribute(el: NgtRendererNode, name: string, value: string, namespace?: string | null | undefined): void {\n\t\tconst rS = el.__ngt_renderer__;\n\t\tif (rS[NgtRendererClassId.type] === 'compound') {\n\t\t\t// we don't have the compound instance yet\n\t\t\trS[NgtRendererClassId.attributes][name] = value;\n\t\t\tif (!rS[NgtRendererClassId.compounded]) {\n\t\t\t\tthis.store.queueOperation(el, ['op', () => this.setAttribute(el, name, value, namespace)]);\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tthis.setAttribute(rS[NgtRendererClassId.compounded], name, value, namespace);\n\t\t\treturn;\n\t\t}\n\n\t\tif (rS[NgtRendererClassId.type] === 'three') {\n\t\t\tthis.store.applyAttribute(el, name, value);\n\t\t\treturn;\n\t\t}\n\n\t\treturn this.delegate.setAttribute(el, name, value);\n\t}\n\n\tsetProperty(el: NgtRendererNode, name: string, value: any): void {\n\t\t// TODO: should we support ref value\n\n\t\tconst rS = el.__ngt_renderer__;\n\t\tif (rS[NgtRendererClassId.type] === 'compound') {\n\t\t\t// we don't have the compound instance yet\n\t\t\trS[NgtRendererClassId.properties][name] = value;\n\t\t\tif (!rS[NgtRendererClassId.compounded]) {\n\t\t\t\tthis.store.queueOperation(el, ['op', () => this.setProperty(el, name, value)]);\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tif (rS[NgtRendererClassId.compounded].__ngt_renderer__[NgtRendererClassId.compound]) {\n\t\t\t\tObject.assign(\n\t\t\t\t\trS[NgtRendererClassId.compounded].__ngt_renderer__[NgtRendererClassId.compound][\n\t\t\t\t\t\tNgtCompoundClassId.props\n\t\t\t\t\t],\n\t\t\t\t\t{ [name]: value },\n\t\t\t\t);\n\t\t\t}\n\t\t\tthis.setProperty(rS[NgtRendererClassId.compounded], name, value);\n\t\t\treturn;\n\t\t}\n\n\t\tif (rS[NgtRendererClassId.type] === 'three') {\n\t\t\tthis.store.applyProperty(el, name, value);\n\t\t\treturn;\n\t\t}\n\n\t\treturn this.delegate.setProperty(el, name, value);\n\t}\n\n\tlisten(target: NgtRendererNode, eventName: string, callback: (event: any) => boolean | void): () => void {\n\t\tconst rS = target.__ngt_renderer__;\n\n\t\t// if the target doesn't have __ngt_renderer__, we delegate\n\t\t// if target is DOM node, then we pass that to delegate Renderer\n\t\tif (!rS || this.store.isDOM(target)) {\n\t\t\treturn this.delegate.listen(target, eventName, callback);\n\t\t}\n\n\t\tif (\n\t\t\trS[NgtRendererClassId.type] === 'three' ||\n\t\t\t(rS[NgtRendererClassId.type] === 'compound' && rS[NgtRendererClassId.compounded])\n\t\t) {\n\t\t\tconst instance = rS[NgtRendererClassId.compounded] || target;\n\t\t\tconst priority = getLocalState(target).priority;\n\t\t\tconst targetCdr =\n\t\t\t\trS[NgtRendererClassId.injectorFactory]?.().get(ChangeDetectorRef, null) ||\n\t\t\t\trS[NgtRendererClassId.parent]?.__ngt_renderer__?.[NgtRendererClassId.injectorFactory]?.().get(\n\t\t\t\t\tChangeDetectorRef,\n\t\t\t\t\tnull,\n\t\t\t\t);\n\n\t\t\treturn processThreeEvent(instance, priority || 0, eventName, callback, this.zone, this.cdr, targetCdr);\n\t\t}\n\n\t\tif (rS[NgtRendererClassId.type] === 'compound' && !rS[NgtRendererClassId.compounded]) {\n\t\t\tthis.store.queueOperation(target, [\n\t\t\t\t'op',\n\t\t\t\t() => this.store.queueOperation(target, ['cleanUp', this.listen(target, eventName, callback)]),\n\t\t\t]);\n\t\t\treturn () => {};\n\t\t}\n\n\t\t// @ts-expect-error - we know that target is not DOM node\n\t\tif (target === this.store.rootScene) {\n\t\t\tlet [domTarget, event] = eventName.split(':');\n\t\t\tif (event == null) {\n\t\t\t\tevent = domTarget;\n\t\t\t\tdomTarget = '';\n\t\t\t}\n\t\t\tconst eventTarget =\n\t\t\t\tdomTarget === 'window'\n\t\t\t\t\t? (target as NgtAnyRecord)['ownerDocument']['defaultView']\n\t\t\t\t\t: (target as NgtAnyRecord)['ownerDocument'];\n\t\t\treturn this.delegate.listen(eventTarget, event, callback);\n\t\t}\n\n\t\treturn () => {};\n\t}\n\n\tprivate shouldFindGrandparentInstance(pRS: NgtRendererState, cRS: NgtRendererState, child: NgtRendererNode) {\n\t\tconst pType = pRS[NgtRendererClassId.type];\n\t\tconst cType = cRS[NgtRendererClassId.type];\n\t\tconst isParentCompounded = pRS[NgtRendererClassId.compounded];\n\t\tconst isChildCompounded = cRS[NgtRendererClassId.compounded];\n\n\t\t// if child is three but haven't been attached to a parent yet\n\t\tconst isDanglingThreeChild = cType === 'three' && !untracked(getLocalState(child).parent);\n\t\t// or both parent and child are DOM elements\n\t\t// or they are compound AND haven't had a THREE instance yet\n\t\tconst isParentStillDOM = pType === 'dom' || (pType === 'compound' && !isParentCompounded);\n\t\tconst isChildStillDOM = cType === 'dom' || (cType === 'compound' && !isChildCompounded);\n\t\t// and the child is a compounded compound\n\t\tconst isCompoundChildCompounded = cType === 'compound' && !!isChildCompounded;\n\n\t\treturn (\n\t\t\tisDanglingThreeChild ||\n\t\t\t(isParentStillDOM && isChildStillDOM) ||\n\t\t\t(isParentStillDOM && isCompoundChildCompounded)\n\t\t);\n\t}\n\n\tcreateText = this.delegate.createText.bind(this.delegate);\n\tdestroy = this.delegate.destroy.bind(this.delegate);\n\tdestroyNode: ((node: any) => void) | null = null;\n\tselectRootElement = this.delegate.selectRootElement.bind(this.delegate);\n\tnextSibling = this.delegate.nextSibling.bind(this.delegate);\n\tremoveAttribute = this.delegate.removeAttribute.bind(this.delegate);\n\taddClass = this.delegate.addClass.bind(this.delegate);\n\tremoveClass = this.delegate.removeClass.bind(this.delegate);\n\tsetStyle = this.delegate.setStyle.bind(this.delegate);\n\tremoveStyle = this.delegate.removeStyle.bind(this.delegate);\n\tsetValue = this.delegate.setValue.bind(this.delegate);\n\tget data(): { [key: string]: any } {\n\t\treturn this.delegate.data;\n\t}\n}\n\nexport function provideNgtRenderer(store: NgtStore, compoundPrefixes: string[], cdr: ChangeDetectorRef) {\n\tif (!compoundPrefixes.includes('ngts')) compoundPrefixes.push('ngts');\n\tif (!compoundPrefixes.includes('ngtp')) compoundPrefixes.push('ngtp');\n\n\treturn makeEnvironmentProviders([\n\t\t{ provide: RendererFactory2, useClass: NgtRendererFactory },\n\t\t{ provide: NGT_COMPOUND_PREFIXES, useValue: compoundPrefixes },\n\t\t{ provide: ChangeDetectorRef, useValue: cdr },\n\t\tprovideNgtStore(store),\n\t\tprovideZoneChangeDetection({ runCoalescing: true, eventCoalescing: true }),\n\t]);\n}\n\nexport { extend } from './catalogue';\nexport { HTML } from './constants';\n"]}
|