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.
Files changed (141) hide show
  1. package/README.md +4 -147
  2. package/esm2022/angular-three.mjs +1 -1
  3. package/esm2022/index.mjs +11 -10
  4. package/esm2022/lib/before-render.mjs +13 -0
  5. package/esm2022/lib/canvas.mjs +130 -161
  6. package/esm2022/lib/directives/args.mjs +13 -11
  7. package/esm2022/lib/directives/common.mjs +29 -27
  8. package/esm2022/lib/directives/key.mjs +29 -0
  9. package/esm2022/lib/directives/parent.mjs +13 -11
  10. package/esm2022/lib/directives/repeat.mjs +5 -6
  11. package/esm2022/lib/dom/events.mjs +6 -1
  12. package/esm2022/lib/events.mjs +75 -58
  13. package/esm2022/lib/instance.mjs +65 -0
  14. package/esm2022/lib/loader.mjs +30 -37
  15. package/esm2022/lib/loop.mjs +6 -3
  16. package/esm2022/lib/portal.mjs +91 -102
  17. package/esm2022/lib/ref.mjs +48 -0
  18. package/esm2022/lib/renderer/catalogue.mjs +7 -0
  19. package/esm2022/lib/renderer/constants.mjs +21 -0
  20. package/esm2022/lib/renderer/index.mjs +419 -0
  21. package/esm2022/lib/renderer/store.mjs +144 -108
  22. package/esm2022/lib/renderer/utils.mjs +63 -48
  23. package/esm2022/lib/roots.mjs +249 -0
  24. package/esm2022/lib/routed-scene.mjs +11 -8
  25. package/esm2022/lib/store.mjs +207 -0
  26. package/esm2022/lib/three-types.mjs +2 -2
  27. package/esm2022/lib/types.mjs +1 -1
  28. package/esm2022/lib/utils/apply-props.mjs +23 -11
  29. package/esm2022/lib/utils/assert-injection-context.mjs +14 -0
  30. package/esm2022/lib/utils/attach.mjs +2 -2
  31. package/esm2022/lib/utils/create-injection-token.mjs +47 -0
  32. package/esm2022/lib/utils/is.mjs +1 -1
  33. package/esm2022/lib/utils/make.mjs +1 -1
  34. package/esm2022/lib/utils/safe-detect-changes.mjs +15 -13
  35. package/esm2022/lib/utils/signal-store.mjs +91 -0
  36. package/esm2022/lib/utils/update.mjs +1 -1
  37. package/fesm2022/angular-three.mjs +1770 -1589
  38. package/fesm2022/angular-three.mjs.map +1 -1
  39. package/index.d.ts +10 -9
  40. package/lib/{di/before-render.d.ts → before-render.d.ts} +1 -1
  41. package/lib/canvas.d.ts +81 -11
  42. package/lib/directives/args.d.ts +2 -2
  43. package/lib/directives/common.d.ts +5 -1
  44. package/lib/directives/key.d.ts +10 -0
  45. package/lib/directives/parent.d.ts +5 -5
  46. package/lib/dom/events.d.ts +3 -2
  47. package/lib/events.d.ts +78 -2
  48. package/lib/instance.d.ts +36 -0
  49. package/lib/loader.d.ts +13 -2
  50. package/lib/loop.d.ts +64 -6
  51. package/lib/portal.d.ts +20 -12
  52. package/lib/{di/ref.d.ts → ref.d.ts} +3 -2
  53. package/lib/renderer/catalogue.d.ts +9 -0
  54. package/lib/renderer/constants.d.ts +20 -0
  55. package/lib/renderer/index.d.ts +5 -0
  56. package/lib/renderer/store.d.ts +19 -15
  57. package/lib/renderer/utils.d.ts +28 -18
  58. package/lib/roots.d.ts +11 -0
  59. package/lib/routed-scene.d.ts +1 -1
  60. package/lib/store.d.ts +143 -0
  61. package/lib/three-types.d.ts +6 -6
  62. package/lib/types.d.ts +1 -309
  63. package/lib/utils/apply-props.d.ts +4 -2
  64. package/lib/utils/attach.d.ts +5 -3
  65. package/lib/utils/create-injection-token.d.ts +27 -0
  66. package/lib/utils/is.d.ts +4 -3
  67. package/lib/utils/make.d.ts +12 -1
  68. package/lib/utils/safe-detect-changes.d.ts +2 -2
  69. package/lib/utils/signal-store.d.ts +17 -0
  70. package/lib/utils/update.d.ts +1 -1
  71. package/metadata.json +1 -1
  72. package/package.json +5 -4
  73. package/plugin/generators.json +47 -17
  74. package/plugin/package.json +2 -5
  75. package/plugin/src/generators/init/compat.d.ts +3 -1
  76. package/plugin/src/generators/init/compat.js +2 -2
  77. package/plugin/src/generators/init/compat.js.map +1 -1
  78. package/plugin/src/generators/init/files/experience/experience.component.html.__tmpl__ +4 -0
  79. package/plugin/src/generators/init/files/experience/experience.component.ts.__tmpl__ +17 -0
  80. package/plugin/src/generators/init/generator.d.ts +6 -0
  81. package/plugin/src/generators/init/generator.js +144 -0
  82. package/plugin/src/generators/init/generator.js.map +1 -0
  83. package/plugin/src/generators/init/schema.json +15 -4
  84. package/plugin/src/generators/init-cannon/compat.d.ts +2 -0
  85. package/plugin/src/generators/init-cannon/compat.js +6 -0
  86. package/plugin/src/generators/init-cannon/compat.js.map +1 -0
  87. package/plugin/src/generators/init-cannon/generator.d.ts +2 -0
  88. package/plugin/src/generators/init-cannon/generator.js +22 -0
  89. package/plugin/src/generators/init-cannon/generator.js.map +1 -0
  90. package/plugin/src/generators/init-cannon/schema.json +6 -0
  91. package/plugin/src/generators/init-postprocessing/compat.d.ts +2 -0
  92. package/plugin/src/generators/init-postprocessing/compat.js +6 -0
  93. package/plugin/src/generators/init-postprocessing/compat.js.map +1 -0
  94. package/plugin/src/generators/init-postprocessing/generator.d.ts +2 -0
  95. package/plugin/src/generators/init-postprocessing/generator.js +20 -0
  96. package/plugin/src/generators/init-postprocessing/generator.js.map +1 -0
  97. package/plugin/src/generators/init-postprocessing/schema.json +6 -0
  98. package/plugin/src/generators/init-soba/compat.d.ts +2 -0
  99. package/plugin/src/generators/init-soba/compat.js +6 -0
  100. package/plugin/src/generators/init-soba/compat.js.map +1 -0
  101. package/plugin/src/generators/init-soba/generator.d.ts +2 -0
  102. package/plugin/src/generators/init-soba/generator.js +26 -0
  103. package/plugin/src/generators/init-soba/generator.js.map +1 -0
  104. package/plugin/src/generators/init-soba/schema.json +6 -0
  105. package/plugin/src/generators/utils.d.ts +2 -0
  106. package/plugin/src/generators/utils.js +34 -0
  107. package/plugin/src/generators/utils.js.map +1 -0
  108. package/plugin/src/generators/versions.d.ts +12 -0
  109. package/plugin/src/generators/versions.js +16 -0
  110. package/plugin/src/generators/versions.js.map +1 -0
  111. package/plugin/src/index.d.ts +3 -1
  112. package/plugin/src/index.js +7 -3
  113. package/plugin/src/index.js.map +1 -1
  114. package/web-types.json +1 -1
  115. package/esm2022/lib/di/before-render.mjs +0 -13
  116. package/esm2022/lib/di/catalogue.mjs +0 -7
  117. package/esm2022/lib/di/ref.mjs +0 -49
  118. package/esm2022/lib/renderer/di.mjs +0 -3
  119. package/esm2022/lib/renderer/enums.mjs +0 -2
  120. package/esm2022/lib/renderer/provider.mjs +0 -18
  121. package/esm2022/lib/renderer/renderer.mjs +0 -365
  122. package/esm2022/lib/stores/signal.store.mjs +0 -81
  123. package/esm2022/lib/stores/store.mjs +0 -423
  124. package/esm2022/lib/utils/assert-in-injection-context.mjs +0 -14
  125. package/esm2022/lib/utils/instance.mjs +0 -63
  126. package/esm2022/lib/utils/signal.mjs +0 -24
  127. package/esm2022/lib/utils/timing.mjs +0 -21
  128. package/lib/di/catalogue.d.ts +0 -3
  129. package/lib/renderer/di.d.ts +0 -2
  130. package/lib/renderer/enums.d.ts +0 -26
  131. package/lib/renderer/provider.d.ts +0 -8
  132. package/lib/renderer/renderer.d.ts +0 -49
  133. package/lib/stores/signal.store.d.ts +0 -20
  134. package/lib/stores/store.d.ts +0 -13
  135. package/lib/utils/instance.d.ts +0 -4
  136. package/lib/utils/signal.d.ts +0 -2
  137. package/lib/utils/timing.d.ts +0 -4
  138. package/plugin/src/generators/init/init.d.ts +0 -5
  139. package/plugin/src/generators/init/init.js +0 -56
  140. package/plugin/src/generators/init/init.js.map +0 -1
  141. /package/lib/utils/{assert-in-injection-context.d.ts → assert-injection-context.d.ts} +0 -0
@@ -1,13 +0,0 @@
1
- import { DestroyRef, inject, runInInjectionContext } from '@angular/core';
2
- import { NgtStore } from '../stores/store';
3
- import { assertInjectionContext } from '../utils/assert-in-injection-context';
4
- export function injectBeforeRender(cb, { priority = 0, injector } = {}) {
5
- injector = assertInjectionContext(injectBeforeRender, injector);
6
- return runInInjectionContext(injector, () => {
7
- const store = inject(NgtStore);
8
- const sub = store.get('internal').subscribe(cb, priority, store);
9
- inject(DestroyRef).onDestroy(() => void sub());
10
- return sub;
11
- });
12
- }
13
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmVmb3JlLXJlbmRlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvYW5ndWxhci10aHJlZS9zcmMvbGliL2RpL2JlZm9yZS1yZW5kZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBWSxNQUFNLEVBQUUscUJBQXFCLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDcEYsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBRTNDLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLHNDQUFzQyxDQUFDO0FBRTlFLE1BQU0sVUFBVSxrQkFBa0IsQ0FDOUIsRUFBcUMsRUFDckMsRUFBRSxRQUFRLEdBQUcsQ0FBQyxFQUFFLFFBQVEsS0FBaUQsRUFBRTtJQUUzRSxRQUFRLEdBQUcsc0JBQXNCLENBQUMsa0JBQWtCLEVBQUUsUUFBUSxDQUFDLENBQUM7SUFDaEUsT0FBTyxxQkFBcUIsQ0FBQyxRQUFRLEVBQUUsR0FBRyxFQUFFO1FBQ3hDLE1BQU0sS0FBSyxHQUFHLE1BQU0sQ0FBQyxRQUFRLENBQUMsQ0FBQztRQUMvQixNQUFNLEdBQUcsR0FBRyxLQUFLLENBQUMsR0FBRyxDQUFDLFVBQVUsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxFQUFFLEVBQUUsUUFBUSxFQUFFLEtBQUssQ0FBQyxDQUFDO1FBQ2pFLE1BQU0sQ0FBQyxVQUFVLENBQUMsQ0FBQyxTQUFTLENBQUMsR0FBRyxFQUFFLENBQUMsS0FBSyxHQUFHLEVBQUUsQ0FBQyxDQUFDO1FBQy9DLE9BQU8sR0FBRyxDQUFDO0lBQ2YsQ0FBQyxDQUFDLENBQUM7QUFDUCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGVzdHJveVJlZiwgSW5qZWN0b3IsIGluamVjdCwgcnVuSW5JbmplY3Rpb25Db250ZXh0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBOZ3RTdG9yZSB9IGZyb20gJy4uL3N0b3Jlcy9zdG9yZSc7XG5pbXBvcnQgeyBOZ3RCZWZvcmVSZW5kZXJSZWNvcmQgfSBmcm9tICcuLi90eXBlcyc7XG5pbXBvcnQgeyBhc3NlcnRJbmplY3Rpb25Db250ZXh0IH0gZnJvbSAnLi4vdXRpbHMvYXNzZXJ0LWluLWluamVjdGlvbi1jb250ZXh0JztcblxuZXhwb3J0IGZ1bmN0aW9uIGluamVjdEJlZm9yZVJlbmRlcihcbiAgICBjYjogTmd0QmVmb3JlUmVuZGVyUmVjb3JkWydjYWxsYmFjayddLFxuICAgIHsgcHJpb3JpdHkgPSAwLCBpbmplY3RvciB9OiB7IHByaW9yaXR5PzogbnVtYmVyOyBpbmplY3Rvcj86IEluamVjdG9yIH0gPSB7fVxuKSB7XG4gICAgaW5qZWN0b3IgPSBhc3NlcnRJbmplY3Rpb25Db250ZXh0KGluamVjdEJlZm9yZVJlbmRlciwgaW5qZWN0b3IpO1xuICAgIHJldHVybiBydW5JbkluamVjdGlvbkNvbnRleHQoaW5qZWN0b3IsICgpID0+IHtcbiAgICAgICAgY29uc3Qgc3RvcmUgPSBpbmplY3QoTmd0U3RvcmUpO1xuICAgICAgICBjb25zdCBzdWIgPSBzdG9yZS5nZXQoJ2ludGVybmFsJykuc3Vic2NyaWJlKGNiLCBwcmlvcml0eSwgc3RvcmUpO1xuICAgICAgICBpbmplY3QoRGVzdHJveVJlZikub25EZXN0cm95KCgpID0+IHZvaWQgc3ViKCkpO1xuICAgICAgICByZXR1cm4gc3ViO1xuICAgIH0pO1xufVxuIl19
@@ -1,7 +0,0 @@
1
- import { InjectionToken } from '@angular/core';
2
- const catalogue = {};
3
- export function extend(objects) {
4
- Object.assign(catalogue, objects);
5
- }
6
- export const NGT_CATALOGUE = new InjectionToken('THREE Constructors Catalogue', { factory: () => catalogue });
7
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2F0YWxvZ3VlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9hbmd1bGFyLXRocmVlL3NyYy9saWIvZGkvY2F0YWxvZ3VlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFL0MsTUFBTSxTQUFTLEdBQWdELEVBQUUsQ0FBQztBQUVsRSxNQUFNLFVBQVUsTUFBTSxDQUFDLE9BQWU7SUFDbEMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxTQUFTLEVBQUUsT0FBTyxDQUFDLENBQUM7QUFDdEMsQ0FBQztBQUVELE1BQU0sQ0FBQyxNQUFNLGFBQWEsR0FBRyxJQUFJLGNBQWMsQ0FDM0MsOEJBQThCLEVBQzlCLEVBQUUsT0FBTyxFQUFFLEdBQUcsRUFBRSxDQUFDLFNBQVMsRUFBRSxDQUMvQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0aW9uVG9rZW4gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuY29uc3QgY2F0YWxvZ3VlOiBSZWNvcmQ8c3RyaW5nLCBuZXcgKC4uLmFyZ3M6IGFueVtdKSA9PiBhbnk+ID0ge307XG5cbmV4cG9ydCBmdW5jdGlvbiBleHRlbmQob2JqZWN0czogb2JqZWN0KTogdm9pZCB7XG4gICAgT2JqZWN0LmFzc2lnbihjYXRhbG9ndWUsIG9iamVjdHMpO1xufVxuXG5leHBvcnQgY29uc3QgTkdUX0NBVEFMT0dVRSA9IG5ldyBJbmplY3Rpb25Ub2tlbjxSZWNvcmQ8c3RyaW5nLCBuZXcgKC4uLmFyZ3M6IGFueVtdKSA9PiBhbnk+PihcbiAgICAnVEhSRUUgQ29uc3RydWN0b3JzIENhdGFsb2d1ZScsXG4gICAgeyBmYWN0b3J5OiAoKSA9PiBjYXRhbG9ndWUgfVxuKTtcbiJdfQ==
@@ -1,49 +0,0 @@
1
- import { ChangeDetectorRef, DestroyRef, ElementRef, computed, inject, runInInjectionContext, untracked, } from '@angular/core';
2
- import { assertInjectionContext } from '../utils/assert-in-injection-context';
3
- import { getLocalState } from '../utils/instance';
4
- import { is } from '../utils/is';
5
- import { safeDetectChanges } from '../utils/safe-detect-changes';
6
- import { createSignal } from '../utils/signal';
7
- export function injectNgtRef(initial = null, injector) {
8
- injector = assertInjectionContext(injectNgtRef, injector);
9
- return runInInjectionContext(injector, () => {
10
- const cdr = inject(ChangeDetectorRef);
11
- const ref = is.ref(initial) ? initial : new ElementRef(initial);
12
- const signalRef = createSignal(ref.nativeElement);
13
- const readonlySignal = signalRef.asReadonly();
14
- const cached = new Map();
15
- inject(DestroyRef).onDestroy(() => void cached.clear());
16
- const children = (type = 'objects') => {
17
- if (!cached.has(type)) {
18
- cached.set(type, computed(() => {
19
- const instance = readonlySignal();
20
- if (!instance)
21
- return [];
22
- const localState = getLocalState(instance);
23
- if (!localState.objects || !localState.nonObjects)
24
- return [];
25
- if (type === 'objects')
26
- return localState.objects();
27
- if (type === 'nonObjects')
28
- return localState.nonObjects();
29
- return [...localState.objects(), ...localState.nonObjects()];
30
- }));
31
- }
32
- return cached.get(type);
33
- };
34
- Object.defineProperty(ref, 'nativeElement', {
35
- set: (newElement) => {
36
- if (newElement !== untracked(signalRef)) {
37
- signalRef.set(newElement);
38
- safeDetectChanges(cdr);
39
- }
40
- },
41
- get: () => readonlySignal(),
42
- });
43
- Object.defineProperty(ref, 'untracked', {
44
- get: () => untracked(readonlySignal),
45
- });
46
- return Object.assign(ref, { children });
47
- });
48
- }
49
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVmLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9hbmd1bGFyLXRocmVlL3NyYy9saWIvZGkvcmVmLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDSCxpQkFBaUIsRUFDakIsVUFBVSxFQUNWLFVBQVUsRUFHVixRQUFRLEVBQ1IsTUFBTSxFQUNOLHFCQUFxQixFQUNyQixTQUFTLEdBQ1osTUFBTSxlQUFlLENBQUM7QUFFdkIsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sc0NBQXNDLENBQUM7QUFDOUUsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQ2xELE9BQU8sRUFBRSxFQUFFLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFDakMsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFDakUsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBTy9DLE1BQU0sVUFBVSxZQUFZLENBQ3hCLFVBQTJDLElBQUssRUFDaEQsUUFBbUI7SUFFbkIsUUFBUSxHQUFHLHNCQUFzQixDQUFDLFlBQVksRUFBRSxRQUFRLENBQUMsQ0FBQztJQUMxRCxPQUFPLHFCQUFxQixDQUFDLFFBQVEsRUFBRSxHQUFHLEVBQUU7UUFDeEMsTUFBTSxHQUFHLEdBQUcsTUFBTSxDQUFDLGlCQUFpQixDQUFDLENBQUM7UUFDdEMsTUFBTSxHQUFHLEdBQUcsRUFBRSxDQUFDLEdBQUcsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxJQUFJLFVBQVUsQ0FBVyxPQUFtQixDQUFDLENBQUM7UUFDdEYsTUFBTSxTQUFTLEdBQUcsWUFBWSxDQUFDLEdBQUcsQ0FBQyxhQUFhLENBQUMsQ0FBQztRQUNsRCxNQUFNLGNBQWMsR0FBRyxTQUFTLENBQUMsVUFBVSxFQUFFLENBQUM7UUFDOUMsTUFBTSxNQUFNLEdBQUcsSUFBSSxHQUFHLEVBQUUsQ0FBQztRQUV6QixNQUFNLENBQUMsVUFBVSxDQUFDLENBQUMsU0FBUyxDQUFDLEdBQUcsRUFBRSxDQUFDLEtBQUssTUFBTSxDQUFDLEtBQUssRUFBRSxDQUFDLENBQUM7UUFFeEQsTUFBTSxRQUFRLEdBQUcsQ0FBQyxPQUEwQyxTQUFTLEVBQUUsRUFBRTtZQUNyRSxJQUFJLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsRUFBRTtnQkFDbkIsTUFBTSxDQUFDLEdBQUcsQ0FDTixJQUFJLEVBQ0osUUFBUSxDQUFDLEdBQUcsRUFBRTtvQkFDVixNQUFNLFFBQVEsR0FBRyxjQUFjLEVBQUUsQ0FBQztvQkFDbEMsSUFBSSxDQUFDLFFBQVE7d0JBQUUsT0FBTyxFQUFFLENBQUM7b0JBQ3pCLE1BQU0sVUFBVSxHQUFHLGFBQWEsQ0FBQyxRQUFRLENBQUMsQ0FBQztvQkFDM0MsSUFBSSxDQUFDLFVBQVUsQ0FBQyxPQUFPLElBQUksQ0FBQyxVQUFVLENBQUMsVUFBVTt3QkFBRSxPQUFPLEVBQUUsQ0FBQztvQkFDN0QsSUFBSSxJQUFJLEtBQUssU0FBUzt3QkFBRSxPQUFPLFVBQVUsQ0FBQyxPQUFPLEVBQUUsQ0FBQztvQkFDcEQsSUFBSSxJQUFJLEtBQUssWUFBWTt3QkFBRSxPQUFPLFVBQVUsQ0FBQyxVQUFVLEVBQUUsQ0FBQztvQkFDMUQsT0FBTyxDQUFDLEdBQUcsVUFBVSxDQUFDLE9BQU8sRUFBRSxFQUFFLEdBQUcsVUFBVSxDQUFDLFVBQVUsRUFBRSxDQUFDLENBQUM7Z0JBQ2pFLENBQUMsQ0FBQyxDQUNMLENBQUM7YUFDTDtZQUNELE9BQU8sTUFBTSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUUsQ0FBQztRQUM3QixDQUFDLENBQUM7UUFFRixNQUFNLENBQUMsY0FBYyxDQUFDLEdBQUcsRUFBRSxlQUFlLEVBQUU7WUFDeEMsR0FBRyxFQUFFLENBQUMsVUFBVSxFQUFFLEVBQUU7Z0JBQ2hCLElBQUksVUFBVSxLQUFLLFNBQVMsQ0FBQyxTQUFTLENBQUMsRUFBRTtvQkFDckMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxVQUFVLENBQUMsQ0FBQztvQkFDMUIsaUJBQWlCLENBQUMsR0FBRyxDQUFDLENBQUM7aUJBQzFCO1lBQ0wsQ0FBQztZQUNELEdBQUcsRUFBRSxHQUFHLEVBQUUsQ0FBQyxjQUFjLEVBQUU7U0FDOUIsQ0FBQyxDQUFDO1FBRUgsTUFBTSxDQUFDLGNBQWMsQ0FBQyxHQUFHLEVBQUUsV0FBVyxFQUFFO1lBQ3BDLEdBQUcsRUFBRSxHQUFHLEVBQUUsQ0FBQyxTQUFTLENBQUMsY0FBYyxDQUFDO1NBQ3ZDLENBQUMsQ0FBQztRQUVILE9BQU8sTUFBTSxDQUFDLE1BQU0sQ0FBQyxHQUFHLEVBQUUsRUFBRSxRQUFRLEVBQUUsQ0FBNkIsQ0FBQztJQUN4RSxDQUFDLENBQUMsQ0FBQztBQUNQLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICAgIENoYW5nZURldGVjdG9yUmVmLFxuICAgIERlc3Ryb3lSZWYsXG4gICAgRWxlbWVudFJlZixcbiAgICBJbmplY3RvcixcbiAgICBTaWduYWwsXG4gICAgY29tcHV0ZWQsXG4gICAgaW5qZWN0LFxuICAgIHJ1bkluSW5qZWN0aW9uQ29udGV4dCxcbiAgICB1bnRyYWNrZWQsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTmd0SW5zdGFuY2VOb2RlIH0gZnJvbSAnLi4vdHlwZXMnO1xuaW1wb3J0IHsgYXNzZXJ0SW5qZWN0aW9uQ29udGV4dCB9IGZyb20gJy4uL3V0aWxzL2Fzc2VydC1pbi1pbmplY3Rpb24tY29udGV4dCc7XG5pbXBvcnQgeyBnZXRMb2NhbFN0YXRlIH0gZnJvbSAnLi4vdXRpbHMvaW5zdGFuY2UnO1xuaW1wb3J0IHsgaXMgfSBmcm9tICcuLi91dGlscy9pcyc7XG5pbXBvcnQgeyBzYWZlRGV0ZWN0Q2hhbmdlcyB9IGZyb20gJy4uL3V0aWxzL3NhZmUtZGV0ZWN0LWNoYW5nZXMnO1xuaW1wb3J0IHsgY3JlYXRlU2lnbmFsIH0gZnJvbSAnLi4vdXRpbHMvc2lnbmFsJztcblxuZXhwb3J0IHR5cGUgTmd0SW5qZWN0ZWRSZWY8VEVsZW1lbnQ+ID0gRWxlbWVudFJlZjxURWxlbWVudD4gJiB7XG4gICAgY2hpbGRyZW46ICh0eXBlPzogJ29iamVjdHMnIHwgJ25vbk9iamVjdHMnIHwgJ2JvdGgnKSA9PiBTaWduYWw8Tmd0SW5zdGFuY2VOb2RlW10+O1xuICAgIHVudHJhY2tlZDogVEVsZW1lbnQ7XG59O1xuXG5leHBvcnQgZnVuY3Rpb24gaW5qZWN0Tmd0UmVmPFRFbGVtZW50PihcbiAgICBpbml0aWFsOiBFbGVtZW50UmVmPFRFbGVtZW50PiB8IFRFbGVtZW50ID0gbnVsbCEsXG4gICAgaW5qZWN0b3I/OiBJbmplY3RvclxuKTogTmd0SW5qZWN0ZWRSZWY8VEVsZW1lbnQ+IHtcbiAgICBpbmplY3RvciA9IGFzc2VydEluamVjdGlvbkNvbnRleHQoaW5qZWN0Tmd0UmVmLCBpbmplY3Rvcik7XG4gICAgcmV0dXJuIHJ1bkluSW5qZWN0aW9uQ29udGV4dChpbmplY3RvciwgKCkgPT4ge1xuICAgICAgICBjb25zdCBjZHIgPSBpbmplY3QoQ2hhbmdlRGV0ZWN0b3JSZWYpO1xuICAgICAgICBjb25zdCByZWYgPSBpcy5yZWYoaW5pdGlhbCkgPyBpbml0aWFsIDogbmV3IEVsZW1lbnRSZWY8VEVsZW1lbnQ+KGluaXRpYWwgYXMgVEVsZW1lbnQpO1xuICAgICAgICBjb25zdCBzaWduYWxSZWYgPSBjcmVhdGVTaWduYWwocmVmLm5hdGl2ZUVsZW1lbnQpO1xuICAgICAgICBjb25zdCByZWFkb25seVNpZ25hbCA9IHNpZ25hbFJlZi5hc1JlYWRvbmx5KCk7XG4gICAgICAgIGNvbnN0IGNhY2hlZCA9IG5ldyBNYXAoKTtcblxuICAgICAgICBpbmplY3QoRGVzdHJveVJlZikub25EZXN0cm95KCgpID0+IHZvaWQgY2FjaGVkLmNsZWFyKCkpO1xuXG4gICAgICAgIGNvbnN0IGNoaWxkcmVuID0gKHR5cGU6ICdvYmplY3RzJyB8ICdub25PYmplY3RzJyB8ICdib3RoJyA9ICdvYmplY3RzJykgPT4ge1xuICAgICAgICAgICAgaWYgKCFjYWNoZWQuaGFzKHR5cGUpKSB7XG4gICAgICAgICAgICAgICAgY2FjaGVkLnNldChcbiAgICAgICAgICAgICAgICAgICAgdHlwZSxcbiAgICAgICAgICAgICAgICAgICAgY29tcHV0ZWQoKCkgPT4ge1xuICAgICAgICAgICAgICAgICAgICAgICAgY29uc3QgaW5zdGFuY2UgPSByZWFkb25seVNpZ25hbCgpO1xuICAgICAgICAgICAgICAgICAgICAgICAgaWYgKCFpbnN0YW5jZSkgcmV0dXJuIFtdO1xuICAgICAgICAgICAgICAgICAgICAgICAgY29uc3QgbG9jYWxTdGF0ZSA9IGdldExvY2FsU3RhdGUoaW5zdGFuY2UpO1xuICAgICAgICAgICAgICAgICAgICAgICAgaWYgKCFsb2NhbFN0YXRlLm9iamVjdHMgfHwgIWxvY2FsU3RhdGUubm9uT2JqZWN0cykgcmV0dXJuIFtdO1xuICAgICAgICAgICAgICAgICAgICAgICAgaWYgKHR5cGUgPT09ICdvYmplY3RzJykgcmV0dXJuIGxvY2FsU3RhdGUub2JqZWN0cygpO1xuICAgICAgICAgICAgICAgICAgICAgICAgaWYgKHR5cGUgPT09ICdub25PYmplY3RzJykgcmV0dXJuIGxvY2FsU3RhdGUubm9uT2JqZWN0cygpO1xuICAgICAgICAgICAgICAgICAgICAgICAgcmV0dXJuIFsuLi5sb2NhbFN0YXRlLm9iamVjdHMoKSwgLi4ubG9jYWxTdGF0ZS5ub25PYmplY3RzKCldO1xuICAgICAgICAgICAgICAgICAgICB9KVxuICAgICAgICAgICAgICAgICk7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICByZXR1cm4gY2FjaGVkLmdldCh0eXBlKSE7XG4gICAgICAgIH07XG5cbiAgICAgICAgT2JqZWN0LmRlZmluZVByb3BlcnR5KHJlZiwgJ25hdGl2ZUVsZW1lbnQnLCB7XG4gICAgICAgICAgICBzZXQ6IChuZXdFbGVtZW50KSA9PiB7XG4gICAgICAgICAgICAgICAgaWYgKG5ld0VsZW1lbnQgIT09IHVudHJhY2tlZChzaWduYWxSZWYpKSB7XG4gICAgICAgICAgICAgICAgICAgIHNpZ25hbFJlZi5zZXQobmV3RWxlbWVudCk7XG4gICAgICAgICAgICAgICAgICAgIHNhZmVEZXRlY3RDaGFuZ2VzKGNkcik7XG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfSxcbiAgICAgICAgICAgIGdldDogKCkgPT4gcmVhZG9ubHlTaWduYWwoKSxcbiAgICAgICAgfSk7XG5cbiAgICAgICAgT2JqZWN0LmRlZmluZVByb3BlcnR5KHJlZiwgJ3VudHJhY2tlZCcsIHtcbiAgICAgICAgICAgIGdldDogKCkgPT4gdW50cmFja2VkKHJlYWRvbmx5U2lnbmFsKSxcbiAgICAgICAgfSk7XG5cbiAgICAgICAgcmV0dXJuIE9iamVjdC5hc3NpZ24ocmVmLCB7IGNoaWxkcmVuIH0pIGFzIE5ndEluamVjdGVkUmVmPFRFbGVtZW50PjtcbiAgICB9KTtcbn1cbiJdfQ==
@@ -1,3 +0,0 @@
1
- import { InjectionToken } from '@angular/core';
2
- export const NGT_COMPOUND_PREFIXES = new InjectionToken('NgtCompoundPrefixes');
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXItdGhyZWUvc3JjL2xpYi9yZW5kZXJlci9kaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRS9DLE1BQU0sQ0FBQyxNQUFNLHFCQUFxQixHQUFHLElBQUksY0FBYyxDQUFXLHFCQUFxQixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3Rpb25Ub2tlbiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5leHBvcnQgY29uc3QgTkdUX0NPTVBPVU5EX1BSRUZJWEVTID0gbmV3IEluamVjdGlvblRva2VuPHN0cmluZ1tdPignTmd0Q29tcG91bmRQcmVmaXhlcycpO1xuIl19
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW51bXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXItdGhyZWUvc3JjL2xpYi9yZW5kZXJlci9lbnVtcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNvbnN0IGVudW0gTmd0UmVuZGVyZXJDbGFzc0lkIHtcbiAgICB0eXBlLFxuICAgIHBhcmVudCxcbiAgICBpbmplY3RlZFBhcmVudCxcbiAgICBjaGlsZHJlbixcbiAgICBkZXN0cm95ZWQsXG4gICAgY29tcG91bmQsXG4gICAgY29tcG91bmRQYXJlbnQsXG4gICAgY29tcG91bmRlZCxcbiAgICBxdWV1ZU9wcyxcbiAgICBhdHRyaWJ1dGVzLFxuICAgIHByb3BlcnRpZXMsXG4gICAgcmF3VmFsdWUsXG4gICAgcmVmLFxuICAgIHBvcnRhbENvbnRhaW5lcixcbiAgICBpbmplY3RvckZhY3RvcnksXG59XG5cbmV4cG9ydCBjb25zdCBlbnVtIE5ndENvbXBvdW5kQ2xhc3NJZCB7XG4gICAgYXBwbHlGaXJzdCxcbiAgICBwcm9wcyxcbn1cblxuZXhwb3J0IGNvbnN0IGVudW0gTmd0UXVldWVPcENsYXNzSWQge1xuICAgIHR5cGUsXG4gICAgb3AsXG4gICAgZG9uZSxcbn1cbiJdfQ==
@@ -1,18 +0,0 @@
1
- import { ChangeDetectorRef, makeEnvironmentProviders, provideZoneChangeDetection, RendererFactory2, } from '@angular/core';
2
- import { NgtStore } from '../stores/store';
3
- import { NGT_COMPOUND_PREFIXES } from './di';
4
- import { NgtRendererFactory } from './renderer';
5
- export function provideNgtRenderer({ store, changeDetectorRef, compoundPrefixes = [] }) {
6
- if (!compoundPrefixes.includes('ngts'))
7
- compoundPrefixes.push('ngts');
8
- if (!compoundPrefixes.includes('ngtp'))
9
- compoundPrefixes.push('ngtp');
10
- return makeEnvironmentProviders([
11
- { provide: RendererFactory2, useClass: NgtRendererFactory },
12
- { provide: NgtStore, useValue: store },
13
- { provide: ChangeDetectorRef, useValue: changeDetectorRef },
14
- { provide: NGT_COMPOUND_PREFIXES, useValue: compoundPrefixes },
15
- provideZoneChangeDetection({ runCoalescing: true, eventCoalescing: true }),
16
- ]);
17
- }
18
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvdmlkZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXItdGhyZWUvc3JjL2xpYi9yZW5kZXJlci9wcm92aWRlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0gsaUJBQWlCLEVBQ2pCLHdCQUF3QixFQUN4QiwwQkFBMEIsRUFDMUIsZ0JBQWdCLEdBQ25CLE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMzQyxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFDN0MsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sWUFBWSxDQUFDO0FBUWhELE1BQU0sVUFBVSxrQkFBa0IsQ0FBQyxFQUFFLEtBQUssRUFBRSxpQkFBaUIsRUFBRSxnQkFBZ0IsR0FBRyxFQUFFLEVBQThCO0lBQzlHLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxRQUFRLENBQUMsTUFBTSxDQUFDO1FBQUUsZ0JBQWdCLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQ3RFLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxRQUFRLENBQUMsTUFBTSxDQUFDO1FBQUUsZ0JBQWdCLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBRXRFLE9BQU8sd0JBQXdCLENBQUM7UUFDNUIsRUFBRSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsUUFBUSxFQUFFLGtCQUFrQixFQUFFO1FBQzNELEVBQUUsT0FBTyxFQUFFLFFBQVEsRUFBRSxRQUFRLEVBQUUsS0FBSyxFQUFFO1FBQ3RDLEVBQUUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLFFBQVEsRUFBRSxpQkFBaUIsRUFBRTtRQUMzRCxFQUFFLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxRQUFRLEVBQUUsZ0JBQWdCLEVBQUU7UUFDOUQsMEJBQTBCLENBQUMsRUFBRSxhQUFhLEVBQUUsSUFBSSxFQUFFLGVBQWUsRUFBRSxJQUFJLEVBQUUsQ0FBQztLQUM3RSxDQUFDLENBQUM7QUFDUCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgICBDaGFuZ2VEZXRlY3RvclJlZixcbiAgICBtYWtlRW52aXJvbm1lbnRQcm92aWRlcnMsXG4gICAgcHJvdmlkZVpvbmVDaGFuZ2VEZXRlY3Rpb24sXG4gICAgUmVuZGVyZXJGYWN0b3J5Mixcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBOZ3RTdG9yZSB9IGZyb20gJy4uL3N0b3Jlcy9zdG9yZSc7XG5pbXBvcnQgeyBOR1RfQ09NUE9VTkRfUFJFRklYRVMgfSBmcm9tICcuL2RpJztcbmltcG9ydCB7IE5ndFJlbmRlcmVyRmFjdG9yeSB9IGZyb20gJy4vcmVuZGVyZXInO1xuXG5leHBvcnQgdHlwZSBOZ3RSZW5kZXJlclByb3ZpZGVyT3B0aW9ucyA9IHtcbiAgICBzdG9yZTogTmd0U3RvcmU7XG4gICAgY2hhbmdlRGV0ZWN0b3JSZWY6IENoYW5nZURldGVjdG9yUmVmO1xuICAgIGNvbXBvdW5kUHJlZml4ZXM/OiBzdHJpbmdbXTtcbn07XG5cbmV4cG9ydCBmdW5jdGlvbiBwcm92aWRlTmd0UmVuZGVyZXIoeyBzdG9yZSwgY2hhbmdlRGV0ZWN0b3JSZWYsIGNvbXBvdW5kUHJlZml4ZXMgPSBbXSB9OiBOZ3RSZW5kZXJlclByb3ZpZGVyT3B0aW9ucykge1xuICAgIGlmICghY29tcG91bmRQcmVmaXhlcy5pbmNsdWRlcygnbmd0cycpKSBjb21wb3VuZFByZWZpeGVzLnB1c2goJ25ndHMnKTtcbiAgICBpZiAoIWNvbXBvdW5kUHJlZml4ZXMuaW5jbHVkZXMoJ25ndHAnKSkgY29tcG91bmRQcmVmaXhlcy5wdXNoKCduZ3RwJyk7XG5cbiAgICByZXR1cm4gbWFrZUVudmlyb25tZW50UHJvdmlkZXJzKFtcbiAgICAgICAgeyBwcm92aWRlOiBSZW5kZXJlckZhY3RvcnkyLCB1c2VDbGFzczogTmd0UmVuZGVyZXJGYWN0b3J5IH0sXG4gICAgICAgIHsgcHJvdmlkZTogTmd0U3RvcmUsIHVzZVZhbHVlOiBzdG9yZSB9LFxuICAgICAgICB7IHByb3ZpZGU6IENoYW5nZURldGVjdG9yUmVmLCB1c2VWYWx1ZTogY2hhbmdlRGV0ZWN0b3JSZWYgfSxcbiAgICAgICAgeyBwcm92aWRlOiBOR1RfQ09NUE9VTkRfUFJFRklYRVMsIHVzZVZhbHVlOiBjb21wb3VuZFByZWZpeGVzIH0sXG4gICAgICAgIHByb3ZpZGVab25lQ2hhbmdlRGV0ZWN0aW9uKHsgcnVuQ29hbGVzY2luZzogdHJ1ZSwgZXZlbnRDb2FsZXNjaW5nOiB0cnVlIH0pLFxuICAgIF0pO1xufVxuIl19
@@ -1,365 +0,0 @@
1
- import { DOCUMENT } from '@angular/common';
2
- import { ChangeDetectorRef, Injectable, Injector, NgZone, RendererFactory2, effect, getDebugNode, inject, untracked, } from '@angular/core';
3
- import { NGT_CATALOGUE } from '../di/catalogue';
4
- import { NgtStore } from '../stores/store';
5
- import { getLocalState, prepare } from '../utils/instance';
6
- import { is } from '../utils/is';
7
- import { createSignal } from '../utils/signal';
8
- import { NGT_COMPOUND_PREFIXES } from './di';
9
- import { NgtRendererStore } from './store';
10
- import { ROUTED_SCENE, SPECIAL_DOM_TAG, attachThreeChild, kebabToPascal, processThreeEvent, removeThreeChild, } from './utils';
11
- import * as i0 from "@angular/core";
12
- class NgtRendererFactory {
13
- #delegateRendererFactory = inject(RendererFactory2, { skipSelf: true });
14
- #catalogue = inject(NGT_CATALOGUE);
15
- #zone = inject(NgZone);
16
- #cdr = inject(ChangeDetectorRef);
17
- #rendererMap = new Map();
18
- #routedSet = new Set();
19
- // all Renderer instances share the same Store
20
- #rendererStore = new NgtRendererStore({
21
- portals: [],
22
- store: inject(NgtStore),
23
- compoundPrefixes: inject(NGT_COMPOUND_PREFIXES),
24
- document: inject(DOCUMENT),
25
- });
26
- createRenderer(hostElement, type) {
27
- const delegateRenderer = this.#delegateRendererFactory.createRenderer(hostElement, type);
28
- if (!type)
29
- return delegateRenderer;
30
- // if ((type as NgtAnyRecord)['type']['isHtml']) {
31
- // return delegateRenderer;
32
- // }
33
- if (type['type'][ROUTED_SCENE]) {
34
- this.#routedSet.add(type.id);
35
- }
36
- let renderer = this.#rendererMap.get(type.id);
37
- if (!renderer) {
38
- renderer = new NgtRenderer(delegateRenderer, this.#rendererStore, this.#catalogue, this.#zone, this.#cdr,
39
- // setting root scene if there's no routed scene OR this component is the routed Scene
40
- !hostElement && (this.#routedSet.size === 0 || this.#routedSet.has(type.id)));
41
- this.#rendererMap.set(type.id, renderer);
42
- }
43
- return renderer;
44
- }
45
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NgtRendererFactory, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
46
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NgtRendererFactory }); }
47
- }
48
- export { NgtRendererFactory };
49
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NgtRendererFactory, decorators: [{
50
- type: Injectable
51
- }] });
52
- /**
53
- * Anything abbreviated with rS/RS stands for RendererState
54
- */
55
- export class NgtRenderer {
56
- constructor(delegate, store, catalogue, zone, cdr, root = true) {
57
- this.delegate = delegate;
58
- this.store = store;
59
- this.catalogue = catalogue;
60
- this.zone = zone;
61
- this.cdr = cdr;
62
- this.root = root;
63
- this.createText = this.delegate.createText.bind(this.delegate);
64
- this.destroy = this.delegate.destroy.bind(this.delegate);
65
- this.destroyNode = null;
66
- this.selectRootElement = this.delegate.selectRootElement.bind(this.delegate);
67
- this.nextSibling = this.delegate.nextSibling.bind(this.delegate);
68
- this.removeAttribute = this.delegate.removeAttribute.bind(this.delegate);
69
- this.addClass = this.delegate.addClass.bind(this.delegate);
70
- this.removeClass = this.delegate.removeClass.bind(this.delegate);
71
- this.setStyle = this.delegate.setStyle.bind(this.delegate);
72
- this.removeStyle = this.delegate.removeStyle.bind(this.delegate);
73
- this.setValue = this.delegate.setValue.bind(this.delegate);
74
- }
75
- createElement(name, namespace) {
76
- const element = this.delegate.createElement(name, namespace);
77
- // on first pass, we return the Root Scene as the root node
78
- if (this.root) {
79
- this.root = false;
80
- const node = this.store.createNode('three', this.store.rootScene);
81
- node.__ngt_renderer__[14 /* NgtRendererClassId.injectorFactory */] = () => getDebugNode(element).injector;
82
- return node;
83
- }
84
- // handle compound
85
- if (this.store.isCompound(name)) {
86
- return this.store.createNode('compound', element);
87
- }
88
- // handle portal
89
- if (name === SPECIAL_DOM_TAG.NGT_PORTAL) {
90
- return this.store.createNode('portal', element);
91
- }
92
- // handle raw value
93
- if (name === SPECIAL_DOM_TAG.NGT_VALUE) {
94
- return this.store.createNode('three', Object.assign({ __ngt_renderer__: { rawValue: undefined } }, { __ngt__: { isRaw: true, parent: createSignal(null) } }));
95
- }
96
- const { injectedArgs, injectedParent, store } = this.store.getCreationState();
97
- let parent = injectedParent;
98
- if (typeof injectedParent === 'string') {
99
- parent = store
100
- .get('scene')
101
- .getObjectByName(injectedParent);
102
- }
103
- // handle primitive
104
- if (name === SPECIAL_DOM_TAG.NGT_PRIMITIVE) {
105
- if (!injectedArgs[0])
106
- throw new Error(`[NGT] ngt-primitive without args is invalid`);
107
- const object = injectedArgs[0];
108
- let localState = getLocalState(object);
109
- if (!Object.keys(localState).length) {
110
- prepare(object, { store, args: injectedArgs, primitive: true });
111
- localState = getLocalState(object);
112
- }
113
- if (!localState.store)
114
- localState.store = store;
115
- const node = this.store.createNode('three', object);
116
- if (parent) {
117
- node.__ngt_renderer__[2 /* NgtRendererClassId.injectedParent */] = parent;
118
- }
119
- return node;
120
- }
121
- const threeTag = name.startsWith('ngt') ? name.slice(4) : name;
122
- const threeName = kebabToPascal(threeTag);
123
- const threeTarget = this.catalogue[threeName];
124
- // we have the THREE constructor here, handle it
125
- if (threeTarget) {
126
- const instance = prepare(new threeTarget(...injectedArgs), { store, args: injectedArgs });
127
- const node = this.store.createNode('three', instance);
128
- const localState = getLocalState(instance);
129
- // auto-attach for geometry and material
130
- if (is.geometry(instance)) {
131
- localState.attach = ['geometry'];
132
- }
133
- else if (is.material(instance)) {
134
- localState.attach = ['material'];
135
- }
136
- if (parent) {
137
- node.__ngt_renderer__[2 /* NgtRendererClassId.injectedParent */] = parent;
138
- }
139
- return node;
140
- }
141
- return this.store.createNode('dom', element);
142
- }
143
- createComment(value) {
144
- return this.store.createNode('comment', this.delegate.createComment(value));
145
- }
146
- appendChild(parent, newChild) {
147
- // TODO: just ignore text node for now
148
- if (newChild instanceof Text)
149
- return;
150
- const cRS = newChild.__ngt_renderer__;
151
- const pRS = parent.__ngt_renderer__;
152
- if (cRS[0 /* NgtRendererClassId.type */] === 'comment') {
153
- this.store.setParent(newChild, parent);
154
- return;
155
- }
156
- if (cRS[2 /* NgtRendererClassId.injectedParent */]) {
157
- if (is.ref(cRS[2 /* NgtRendererClassId.injectedParent */])) {
158
- const injector = cRS[14 /* NgtRendererClassId.injectorFactory */]().get(Injector, null);
159
- if (!injector) {
160
- console.warn(`[NGT] NgtRenderer is attempting to start an effect for injectedParent but no Injector is found.`);
161
- return;
162
- }
163
- const watcher = effect(() => {
164
- const injectedParent = cRS[2 /* NgtRendererClassId.injectedParent */].nativeElement;
165
- if (injectedParent && injectedParent !== parent) {
166
- this.appendChild(injectedParent, newChild);
167
- // only run this effect once
168
- // as soon as we re-run appendChild with the injectedParent, we stop the effect
169
- watcher.destroy();
170
- }
171
- }, { injector, manualCleanup: true });
172
- return;
173
- }
174
- else if (parent !== cRS[2 /* NgtRendererClassId.injectedParent */]) {
175
- this.appendChild(cRS[2 /* NgtRendererClassId.injectedParent */], newChild);
176
- return;
177
- }
178
- }
179
- this.store.setParent(newChild, parent);
180
- this.store.addChild(parent, newChild);
181
- // if new child is a portal
182
- if (cRS[0 /* NgtRendererClassId.type */] === 'portal') {
183
- this.store.processPortalContainer(newChild);
184
- if (cRS[13 /* NgtRendererClassId.portalContainer */]) {
185
- this.appendChild(parent, cRS[13 /* NgtRendererClassId.portalContainer */]);
186
- }
187
- return;
188
- }
189
- // if parent is a portal
190
- if (pRS[0 /* NgtRendererClassId.type */] === 'portal') {
191
- this.store.processPortalContainer(parent);
192
- if (pRS[13 /* NgtRendererClassId.portalContainer */]) {
193
- this.appendChild(pRS[13 /* NgtRendererClassId.portalContainer */], newChild);
194
- }
195
- return;
196
- }
197
- // if both are three instances, straightforward case
198
- if (pRS[0 /* NgtRendererClassId.type */] === 'three' && cRS[0 /* NgtRendererClassId.type */] === 'three') {
199
- // if child already attached to a parent, skip
200
- if (getLocalState(newChild).parent && untracked(getLocalState(newChild).parent))
201
- return;
202
- // attach THREE child
203
- attachThreeChild(parent, newChild);
204
- // here, we handle the special case of if the parent has a compoundParent, which means this child is part of a compound parent template
205
- if (!cRS[5 /* NgtRendererClassId.compound */])
206
- return;
207
- const closestGrandparentWithCompound = this.store.getClosestParentWithCompound(parent);
208
- if (!closestGrandparentWithCompound)
209
- return;
210
- this.appendChild(closestGrandparentWithCompound, newChild);
211
- return;
212
- }
213
- // if only the parent is the THREE instance
214
- if (pRS[0 /* NgtRendererClassId.type */] === 'three') {
215
- for (const renderChild of cRS[3 /* NgtRendererClassId.children */]) {
216
- this.appendChild(parent, renderChild);
217
- }
218
- }
219
- // if parent is a compound
220
- if (pRS[0 /* NgtRendererClassId.type */] === 'compound') {
221
- // if compound doesn't have a THREE instance set yet
222
- if (!pRS[7 /* NgtRendererClassId.compounded */] && cRS[0 /* NgtRendererClassId.type */] === 'three') {
223
- // if child is indeed an ngtCompound
224
- if (cRS[5 /* NgtRendererClassId.compound */])
225
- this.store.setCompound(parent, newChild);
226
- // if not, we track the parent (that is supposedly the compound component) on this three instance
227
- else if (!cRS[6 /* NgtRendererClassId.compoundParent */])
228
- cRS[6 /* NgtRendererClassId.compoundParent */] = parent;
229
- }
230
- // reset the compound if it's changed
231
- if (pRS[7 /* NgtRendererClassId.compounded */] &&
232
- cRS[0 /* NgtRendererClassId.type */] === 'three' &&
233
- cRS[5 /* NgtRendererClassId.compound */] &&
234
- pRS[7 /* NgtRendererClassId.compounded */] !== newChild) {
235
- this.store.setCompound(parent, newChild);
236
- }
237
- }
238
- const shouldFindGrandparentInstance =
239
- // if child is three but haven't been attached to a parent yet
240
- (cRS[0 /* NgtRendererClassId.type */] === 'three' && !untracked(getLocalState(newChild).parent)) ||
241
- // or both parent and child are DOM elements
242
- // or they are compound AND haven't had a THREE instance yet
243
- ((pRS[0 /* NgtRendererClassId.type */] === 'dom' ||
244
- (pRS[0 /* NgtRendererClassId.type */] === 'compound' && !pRS[7 /* NgtRendererClassId.compounded */])) &&
245
- (cRS[0 /* NgtRendererClassId.type */] === 'dom' ||
246
- (cRS[0 /* NgtRendererClassId.type */] === 'compound' && !cRS[7 /* NgtRendererClassId.compounded */])));
247
- if (shouldFindGrandparentInstance) {
248
- // we'll try to get the grandparent instance here so that we can run appendChild with both instances
249
- const closestGrandparentInstance = this.store.getClosestParentWithInstance(parent);
250
- if (closestGrandparentInstance)
251
- this.appendChild(closestGrandparentInstance, newChild);
252
- }
253
- }
254
- insertBefore(parent, newChild
255
- // TODO: we might need these?
256
- // refChild: NgtRendererNode
257
- // isMove?: boolean | undefined
258
- ) {
259
- if (parent == null || !parent.__ngt_renderer__ || parent === newChild)
260
- return;
261
- this.appendChild(parent, newChild);
262
- }
263
- removeChild(parent, oldChild, isHostElement) {
264
- const pRS = parent.__ngt_renderer__;
265
- const cRS = oldChild.__ngt_renderer__;
266
- if (pRS[0 /* NgtRendererClassId.type */] === 'three' && cRS[0 /* NgtRendererClassId.type */] === 'three') {
267
- removeThreeChild(parent, oldChild, true);
268
- this.store.destroy(oldChild, parent);
269
- return;
270
- }
271
- if (pRS[0 /* NgtRendererClassId.type */] === 'compound' && pRS[1 /* NgtRendererClassId.parent */]) {
272
- this.removeChild(pRS[1 /* NgtRendererClassId.parent */], oldChild, isHostElement);
273
- return;
274
- }
275
- if (pRS[0 /* NgtRendererClassId.type */] === 'three') {
276
- this.store.destroy(oldChild, parent);
277
- return;
278
- }
279
- const closestGrandparentInstance = this.store.getClosestParentWithInstance(parent);
280
- if (closestGrandparentInstance)
281
- this.removeChild(closestGrandparentInstance, oldChild, isHostElement);
282
- this.store.destroy(oldChild, closestGrandparentInstance);
283
- }
284
- parentNode(node) {
285
- const rS = node.__ngt_renderer__;
286
- if (rS?.[1 /* NgtRendererClassId.parent */])
287
- return rS[1 /* NgtRendererClassId.parent */];
288
- return this.delegate.parentNode(node);
289
- }
290
- setAttribute(el, name, value, namespace) {
291
- const rS = el.__ngt_renderer__;
292
- if (rS[0 /* NgtRendererClassId.type */] === 'compound') {
293
- // we don't have the compound instance yet
294
- rS[9 /* NgtRendererClassId.attributes */][name] = value;
295
- if (!rS[7 /* NgtRendererClassId.compounded */]) {
296
- this.store.queueOperation(el, ['op', () => this.setAttribute(el, name, value, namespace)]);
297
- return;
298
- }
299
- this.setAttribute(rS[7 /* NgtRendererClassId.compounded */], name, value, namespace);
300
- return;
301
- }
302
- if (rS[0 /* NgtRendererClassId.type */] === 'three')
303
- this.store.applyAttribute(el, name, value);
304
- }
305
- setProperty(el, name, value) {
306
- const rS = el.__ngt_renderer__;
307
- if (rS[0 /* NgtRendererClassId.type */] === 'compound') {
308
- // we don't have the compound instance yet
309
- rS[10 /* NgtRendererClassId.properties */][name] = value;
310
- if (!rS[7 /* NgtRendererClassId.compounded */]) {
311
- this.store.queueOperation(el, ['op', () => this.setProperty(el, name, value)]);
312
- return;
313
- }
314
- if (rS[7 /* NgtRendererClassId.compounded */].__ngt_renderer__[5 /* NgtRendererClassId.compound */]) {
315
- Object.assign(rS[7 /* NgtRendererClassId.compounded */].__ngt_renderer__[5 /* NgtRendererClassId.compound */], {
316
- props: Object.assign(rS[7 /* NgtRendererClassId.compounded */].__ngt_renderer__[5 /* NgtRendererClassId.compound */], { [name]: value }),
317
- });
318
- }
319
- this.setProperty(rS[7 /* NgtRendererClassId.compounded */], name, value);
320
- return;
321
- }
322
- if (rS[0 /* NgtRendererClassId.type */] === 'three')
323
- this.store.applyProperty(el, name, value);
324
- }
325
- listen(target, eventName, callback) {
326
- const rS = target.__ngt_renderer__;
327
- // if the target doesn't have __ngt_renderer__, we delegate
328
- // if target is DOM node, then we pass that to delegate Renderer
329
- if (!rS || this.store.isDOM(target)) {
330
- return this.delegate.listen(target, eventName, callback);
331
- }
332
- if (rS[0 /* NgtRendererClassId.type */] === 'three' ||
333
- (rS[0 /* NgtRendererClassId.type */] === 'compound' && rS[7 /* NgtRendererClassId.compounded */])) {
334
- const instance = rS[7 /* NgtRendererClassId.compounded */] || target;
335
- const priority = getLocalState(target).priority;
336
- const targetCdr = rS[14 /* NgtRendererClassId.injectorFactory */]?.().get(ChangeDetectorRef, null) ||
337
- rS[1 /* NgtRendererClassId.parent */]?.__ngt_renderer__?.[14 /* NgtRendererClassId.injectorFactory */]?.().get(ChangeDetectorRef, null);
338
- return processThreeEvent(instance, priority || 0, eventName, callback, this.zone, this.cdr, targetCdr);
339
- }
340
- if (rS[0 /* NgtRendererClassId.type */] === 'compound' && !rS[7 /* NgtRendererClassId.compounded */]) {
341
- this.store.queueOperation(target, [
342
- 'op',
343
- () => this.store.queueOperation(target, ['cleanUp', this.listen(target, eventName, callback)]),
344
- ]);
345
- return () => { };
346
- }
347
- // @ts-expect-error - we know that target is not DOM node
348
- if (target === this.store.rootScene) {
349
- let [domTarget, event] = eventName.split(':');
350
- if (event == null) {
351
- event = domTarget;
352
- domTarget = '';
353
- }
354
- const eventTarget = domTarget === 'window'
355
- ? target['ownerDocument']['defaultView']
356
- : target['ownerDocument'];
357
- return this.delegate.listen(eventTarget, event, callback);
358
- }
359
- return () => { };
360
- }
361
- get data() {
362
- return this.delegate.data;
363
- }
364
- }
365
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"renderer.js","sourceRoot":"","sources":["../../../../../../libs/angular-three/src/lib/renderer/renderer.ts"],"names":[],"mappings":"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","sourcesContent":["import { DOCUMENT } from '@angular/common';\nimport {\n    ChangeDetectorRef,\n    Injectable,\n    Injector,\n    NgZone,\n    Renderer2,\n    RendererFactory2,\n    effect,\n    getDebugNode,\n    inject,\n    untracked,\n    type RendererType2,\n} from '@angular/core';\nimport { NGT_CATALOGUE } from '../di/catalogue';\nimport type { NgtInjectedRef } from '../di/ref';\nimport { NgtStore } from '../stores/store';\nimport type { NgtAnyRecord } from '../types';\nimport { getLocalState, prepare } from '../utils/instance';\nimport { is } from '../utils/is';\nimport { createSignal } from '../utils/signal';\nimport { NGT_COMPOUND_PREFIXES } from './di';\nimport { NgtRendererClassId } from './enums';\nimport { NgtRendererStore, type NgtRendererNode, type NgtRendererState } from './store';\nimport {\n    ROUTED_SCENE,\n    SPECIAL_DOM_TAG,\n    attachThreeChild,\n    kebabToPascal,\n    processThreeEvent,\n    removeThreeChild,\n} from './utils';\n\n@Injectable()\nexport class NgtRendererFactory implements RendererFactory2 {\n    readonly #delegateRendererFactory = inject(RendererFactory2, { skipSelf: true });\n    readonly #catalogue = inject(NGT_CATALOGUE);\n    readonly #zone = inject(NgZone);\n    readonly #cdr = inject(ChangeDetectorRef);\n\n    readonly #rendererMap = new Map<string, Renderer2>();\n    readonly #routedSet = new Set<string>();\n\n    // all Renderer instances share the same Store\n    readonly #rendererStore = new NgtRendererStore({\n        portals: [],\n        store: inject(NgtStore),\n        compoundPrefixes: inject(NGT_COMPOUND_PREFIXES),\n        document: inject(DOCUMENT),\n    });\n\n    createRenderer(hostElement: any, type: RendererType2 | null): Renderer2 {\n        const delegateRenderer = this.#delegateRendererFactory.createRenderer(hostElement, type);\n        if (!type) return delegateRenderer;\n        // if ((type as NgtAnyRecord)['type']['isHtml']) {\n        // return delegateRenderer;\n        // }\n        if ((type as NgtAnyRecord)['type'][ROUTED_SCENE]) {\n            this.#routedSet.add(type.id);\n        }\n        let renderer = this.#rendererMap.get(type.id);\n        if (!renderer) {\n            renderer = new NgtRenderer(\n                delegateRenderer,\n                this.#rendererStore,\n                this.#catalogue,\n                this.#zone,\n                this.#cdr,\n                // setting root scene if there's no routed scene OR this component is the routed Scene\n                !hostElement && (this.#routedSet.size === 0 || this.#routedSet.has(type.id))\n            );\n            this.#rendererMap.set(type.id, renderer);\n        }\n        return renderer;\n    }\n}\n\n/**\n * Anything abbreviated with rS/RS stands for RendererState\n */\nexport class NgtRenderer implements Renderer2 {\n    constructor(\n        private readonly delegate: Renderer2,\n        private readonly store: NgtRendererStore,\n        private readonly catalogue: Record<string, new (...args: any[]) => any>,\n        private readonly zone: NgZone,\n        private readonly cdr: ChangeDetectorRef,\n        private root = true\n    ) {}\n\n    createElement(name: string, namespace?: string | null | undefined) {\n        const element = this.delegate.createElement(name, namespace);\n\n        // on first pass, we return the Root Scene as the root node\n        if (this.root) {\n            this.root = false;\n            const node = this.store.createNode('three', this.store.rootScene);\n            node.__ngt_renderer__[NgtRendererClassId.injectorFactory] = () => getDebugNode(element)!.injector;\n            return node;\n        }\n\n        // handle compound\n        if (this.store.isCompound(name)) {\n            return this.store.createNode('compound', element);\n        }\n\n        // handle portal\n        if (name === SPECIAL_DOM_TAG.NGT_PORTAL) {\n            return this.store.createNode('portal', element);\n        }\n\n        // handle raw value\n        if (name === SPECIAL_DOM_TAG.NGT_VALUE) {\n            return this.store.createNode(\n                'three',\n                Object.assign(\n                    { __ngt_renderer__: { rawValue: undefined } },\n                    { __ngt__: { isRaw: true, parent: createSignal(null) } }\n                )\n            );\n        }\n\n        const { injectedArgs, injectedParent, store } = this.store.getCreationState();\n\n        let parent = injectedParent as NgtRendererState[NgtRendererClassId.injectedParent];\n        if (typeof injectedParent === 'string') {\n            parent = store\n                .get('scene')\n                .getObjectByName(injectedParent) as unknown as NgtRendererState[NgtRendererClassId.injectedParent];\n        }\n\n        // handle primitive\n        if (name === SPECIAL_DOM_TAG.NGT_PRIMITIVE) {\n            if (!injectedArgs[0]) throw new Error(`[NGT] ngt-primitive without args is invalid`);\n            const object = injectedArgs[0];\n            let localState = getLocalState(object);\n            if (!Object.keys(localState).length) {\n                prepare(object, { store, args: injectedArgs, primitive: true });\n                localState = getLocalState(object);\n            }\n            if (!localState.store) localState.store = store;\n            const node = this.store.createNode('three', object);\n            if (parent) {\n                node.__ngt_renderer__[NgtRendererClassId.injectedParent] = parent;\n            }\n            return node;\n        }\n\n        const threeTag = name.startsWith('ngt') ? name.slice(4) : name;\n        const threeName = kebabToPascal(threeTag);\n        const threeTarget = this.catalogue[threeName];\n        // we have the THREE constructor here, handle it\n        if (threeTarget) {\n            const instance = prepare(new threeTarget(...injectedArgs), { store, args: injectedArgs });\n            const node = this.store.createNode('three', instance);\n            const localState = getLocalState(instance);\n\n            // auto-attach for geometry and material\n            if (is.geometry(instance)) {\n                localState.attach = ['geometry'];\n            } else if (is.material(instance)) {\n                localState.attach = ['material'];\n            }\n\n            if (parent) {\n                node.__ngt_renderer__[NgtRendererClassId.injectedParent] = parent;\n            }\n\n            return node;\n        }\n\n        return this.store.createNode('dom', element);\n    }\n\n    createComment(value: string) {\n        return this.store.createNode('comment', this.delegate.createComment(value));\n    }\n\n    appendChild(parent: NgtRendererNode, newChild: NgtRendererNode): void {\n        // TODO: just ignore text node for now\n        if (newChild instanceof Text) return;\n        const cRS = newChild.__ngt_renderer__;\n        const pRS = parent.__ngt_renderer__;\n\n        if (cRS[NgtRendererClassId.type] === 'comment') {\n            this.store.setParent(newChild, parent);\n            return;\n        }\n\n        if (cRS[NgtRendererClassId.injectedParent]) {\n            if (is.ref(cRS[NgtRendererClassId.injectedParent])) {\n                const injector = cRS[NgtRendererClassId.injectorFactory]().get(Injector, null);\n                if (!injector) {\n                    console.warn(\n                        `[NGT] NgtRenderer is attempting to start an effect for injectedParent but no Injector is found.`\n                    );\n                    return;\n                }\n                const watcher = effect(\n                    () => {\n                        const injectedParent = (\n                            cRS[NgtRendererClassId.injectedParent] as NgtInjectedRef<NgtRendererNode>\n                        ).nativeElement;\n                        if (injectedParent && injectedParent !== parent) {\n                            this.appendChild(injectedParent, newChild);\n                            // only run this effect once\n                            // as soon as we re-run appendChild with the injectedParent, we stop the effect\n                            watcher.destroy();\n                        }\n                    },\n                    { injector, manualCleanup: true }\n                );\n                return;\n            } else if (parent !== cRS[NgtRendererClassId.injectedParent]) {\n                this.appendChild(cRS[NgtRendererClassId.injectedParent], newChild);\n                return;\n            }\n        }\n\n        this.store.setParent(newChild, parent);\n        this.store.addChild(parent, newChild);\n\n        // if new child is a portal\n        if (cRS[NgtRendererClassId.type] === 'portal') {\n            this.store.processPortalContainer(newChild);\n            if (cRS[NgtRendererClassId.portalContainer]) {\n                this.appendChild(parent, cRS[NgtRendererClassId.portalContainer]);\n            }\n            return;\n        }\n\n        // if parent is a portal\n        if (pRS[NgtRendererClassId.type] === 'portal') {\n            this.store.processPortalContainer(parent);\n            if (pRS[NgtRendererClassId.portalContainer]) {\n                this.appendChild(pRS[NgtRendererClassId.portalContainer], newChild);\n            }\n            return;\n        }\n\n        // if both are three instances, straightforward case\n        if (pRS[NgtRendererClassId.type] === 'three' && cRS[NgtRendererClassId.type] === 'three') {\n            // if child already attached to a parent, skip\n            if (getLocalState(newChild).parent && untracked(getLocalState(newChild).parent)) return;\n            // attach THREE child\n            attachThreeChild(parent, newChild);\n            // 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            if (!cRS[NgtRendererClassId.compound]) return;\n            const closestGrandparentWithCompound = this.store.getClosestParentWithCompound(parent);\n            if (!closestGrandparentWithCompound) return;\n            this.appendChild(closestGrandparentWithCompound, newChild);\n            return;\n        }\n\n        // if only the parent is the THREE instance\n        if (pRS[NgtRendererClassId.type] === 'three') {\n            for (const renderChild of cRS[NgtRendererClassId.children]) {\n                this.appendChild(parent, renderChild);\n            }\n        }\n\n        // if parent is a compound\n        if (pRS[NgtRendererClassId.type] === 'compound') {\n            // if compound doesn't have a THREE instance set yet\n            if (!pRS[NgtRendererClassId.compounded] && cRS[NgtRendererClassId.type] === 'three') {\n                // if child is indeed an ngtCompound\n                if (cRS[NgtRendererClassId.compound]) this.store.setCompound(parent, newChild);\n                // if not, we track the parent (that is supposedly the compound component) on this three instance\n                else if (!cRS[NgtRendererClassId.compoundParent]) cRS[NgtRendererClassId.compoundParent] = parent;\n            }\n\n            // reset the compound if it's changed\n            if (\n                pRS[NgtRendererClassId.compounded] &&\n                cRS[NgtRendererClassId.type] === 'three' &&\n                cRS[NgtRendererClassId.compound] &&\n                pRS[NgtRendererClassId.compounded] !== newChild\n            ) {\n                this.store.setCompound(parent, newChild);\n            }\n        }\n\n        const shouldFindGrandparentInstance =\n            // if child is three but haven't been attached to a parent yet\n            (cRS[NgtRendererClassId.type] === 'three' && !untracked(getLocalState(newChild).parent)) ||\n            // or both parent and child are DOM elements\n            // or they are compound AND haven't had a THREE instance yet\n            ((pRS[NgtRendererClassId.type] === 'dom' ||\n                (pRS[NgtRendererClassId.type] === 'compound' && !pRS[NgtRendererClassId.compounded])) &&\n                (cRS[NgtRendererClassId.type] === 'dom' ||\n                    (cRS[NgtRendererClassId.type] === 'compound' && !cRS[NgtRendererClassId.compounded])));\n\n        if (shouldFindGrandparentInstance) {\n            // we'll try to get the grandparent instance here so that we can run appendChild with both instances\n            const closestGrandparentInstance = this.store.getClosestParentWithInstance(parent);\n            if (closestGrandparentInstance) this.appendChild(closestGrandparentInstance, newChild);\n        }\n    }\n\n    insertBefore(\n        parent: NgtRendererNode,\n        newChild: NgtRendererNode\n        // TODO: we might need these?\n        // refChild: NgtRendererNode\n        // isMove?: boolean | undefined\n    ): void {\n        if (parent == null || !parent.__ngt_renderer__ || parent === newChild) return;\n        this.appendChild(parent, newChild);\n    }\n\n    removeChild(parent: NgtRendererNode, oldChild: NgtRendererNode, isHostElement?: boolean | undefined): void {\n        const pRS = parent.__ngt_renderer__;\n        const cRS = oldChild.__ngt_renderer__;\n        if (pRS[NgtRendererClassId.type] === 'three' && cRS[NgtRendererClassId.type] === 'three') {\n            removeThreeChild(parent, oldChild, true);\n            this.store.destroy(oldChild, parent);\n            return;\n        }\n\n        if (pRS[NgtRendererClassId.type] === 'compound' && pRS[NgtRendererClassId.parent]) {\n            this.removeChild(pRS[NgtRendererClassId.parent], oldChild, isHostElement);\n            return;\n        }\n\n        if (pRS[NgtRendererClassId.type] === 'three') {\n            this.store.destroy(oldChild, parent);\n            return;\n        }\n\n        const closestGrandparentInstance = this.store.getClosestParentWithInstance(parent);\n        if (closestGrandparentInstance) this.removeChild(closestGrandparentInstance, oldChild, isHostElement);\n        this.store.destroy(oldChild, closestGrandparentInstance as NgtRendererNode);\n    }\n\n    parentNode(node: NgtRendererNode) {\n        const rS = node.__ngt_renderer__;\n        if (rS?.[NgtRendererClassId.parent]) return rS[NgtRendererClassId.parent];\n        return this.delegate.parentNode(node);\n    }\n\n    setAttribute(el: NgtRendererNode, name: string, value: string, namespace?: string | null | undefined): void {\n        const rS = el.__ngt_renderer__;\n        if (rS[NgtRendererClassId.type] === 'compound') {\n            // we don't have the compound instance yet\n            rS[NgtRendererClassId.attributes][name] = value;\n            if (!rS[NgtRendererClassId.compounded]) {\n                this.store.queueOperation(el, ['op', () => this.setAttribute(el, name, value, namespace)]);\n                return;\n            }\n\n            this.setAttribute(rS[NgtRendererClassId.compounded], name, value, namespace);\n            return;\n        }\n\n        if (rS[NgtRendererClassId.type] === 'three') this.store.applyAttribute(el, name, value);\n    }\n\n    setProperty(el: NgtRendererNode, name: string, value: any): void {\n        const rS = el.__ngt_renderer__;\n        if (rS[NgtRendererClassId.type] === 'compound') {\n            // we don't have the compound instance yet\n            rS[NgtRendererClassId.properties][name] = value;\n            if (!rS[NgtRendererClassId.compounded]) {\n                this.store.queueOperation(el, ['op', () => this.setProperty(el, name, value)]);\n                return;\n            }\n\n            if (rS[NgtRendererClassId.compounded].__ngt_renderer__[NgtRendererClassId.compound]) {\n                Object.assign(rS[NgtRendererClassId.compounded].__ngt_renderer__[NgtRendererClassId.compound], {\n                    props: Object.assign(\n                        rS[NgtRendererClassId.compounded].__ngt_renderer__[NgtRendererClassId.compound],\n                        { [name]: value }\n                    ),\n                });\n            }\n            this.setProperty(rS[NgtRendererClassId.compounded], name, value);\n            return;\n        }\n\n        if (rS[NgtRendererClassId.type] === 'three') this.store.applyProperty(el, name, value);\n    }\n\n    listen(target: NgtRendererNode, eventName: string, callback: (event: any) => boolean | void): () => void {\n        const rS = target.__ngt_renderer__;\n\n        // if the target doesn't have __ngt_renderer__, we delegate\n        // if target is DOM node, then we pass that to delegate Renderer\n        if (!rS || this.store.isDOM(target)) {\n            return this.delegate.listen(target, eventName, callback);\n        }\n\n        if (\n            rS[NgtRendererClassId.type] === 'three' ||\n            (rS[NgtRendererClassId.type] === 'compound' && rS[NgtRendererClassId.compounded])\n        ) {\n            const instance = rS[NgtRendererClassId.compounded] || target;\n            const priority = getLocalState(target).priority;\n            const targetCdr =\n                rS[NgtRendererClassId.injectorFactory]?.().get(ChangeDetectorRef, null) ||\n                rS[NgtRendererClassId.parent]?.__ngt_renderer__?.[NgtRendererClassId.injectorFactory]?.().get(\n                    ChangeDetectorRef,\n                    null\n                );\n            return processThreeEvent(instance, priority || 0, eventName, callback, this.zone, this.cdr, targetCdr);\n        }\n\n        if (rS[NgtRendererClassId.type] === 'compound' && !rS[NgtRendererClassId.compounded]) {\n            this.store.queueOperation(target, [\n                'op',\n                () => this.store.queueOperation(target, ['cleanUp', this.listen(target, eventName, callback)]),\n            ]);\n            return () => {};\n        }\n\n        // @ts-expect-error - we know that target is not DOM node\n        if (target === this.store.rootScene) {\n            let [domTarget, event] = eventName.split(':');\n            if (event == null) {\n                event = domTarget;\n                domTarget = '';\n            }\n            const eventTarget =\n                domTarget === 'window'\n                    ? (target as NgtAnyRecord)['ownerDocument']['defaultView']\n                    : (target as NgtAnyRecord)['ownerDocument'];\n            return this.delegate.listen(eventTarget, event, callback);\n        }\n\n        return () => {};\n    }\n\n    createText = this.delegate.createText.bind(this.delegate);\n    destroy = this.delegate.destroy.bind(this.delegate);\n    destroyNode: ((node: any) => void) | null = null;\n    selectRootElement = this.delegate.selectRootElement.bind(this.delegate);\n    nextSibling = this.delegate.nextSibling.bind(this.delegate);\n    removeAttribute = this.delegate.removeAttribute.bind(this.delegate);\n    addClass = this.delegate.addClass.bind(this.delegate);\n    removeClass = this.delegate.removeClass.bind(this.delegate);\n    setStyle = this.delegate.setStyle.bind(this.delegate);\n    removeStyle = this.delegate.removeStyle.bind(this.delegate);\n    setValue = this.delegate.setValue.bind(this.delegate);\n    get data(): { [key: string]: any } {\n        return this.delegate.data;\n    }\n}\n"]}