angular-three 0.0.0-replace

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 (89) hide show
  1. package/README.md +7 -0
  2. package/esm2022/angular-three.mjs +5 -0
  3. package/esm2022/index.mjs +20 -0
  4. package/esm2022/lib/canvas.mjs +187 -0
  5. package/esm2022/lib/directives/args.mjs +35 -0
  6. package/esm2022/lib/directives/common.mjs +42 -0
  7. package/esm2022/lib/directives/parent.mjs +35 -0
  8. package/esm2022/lib/dom/events.mjs +73 -0
  9. package/esm2022/lib/events.mjs +362 -0
  10. package/esm2022/lib/instance.mjs +70 -0
  11. package/esm2022/lib/loader.mjs +64 -0
  12. package/esm2022/lib/loop.mjs +153 -0
  13. package/esm2022/lib/portal.mjs +208 -0
  14. package/esm2022/lib/ref.mjs +46 -0
  15. package/esm2022/lib/renderer/catalogue.mjs +7 -0
  16. package/esm2022/lib/renderer/constants.mjs +21 -0
  17. package/esm2022/lib/renderer/index.mjs +432 -0
  18. package/esm2022/lib/renderer/store.mjs +423 -0
  19. package/esm2022/lib/renderer/utils.mjs +201 -0
  20. package/esm2022/lib/roots.mjs +261 -0
  21. package/esm2022/lib/routed-scene.mjs +33 -0
  22. package/esm2022/lib/store.mjs +181 -0
  23. package/esm2022/lib/three-types.mjs +2 -0
  24. package/esm2022/lib/types.mjs +2 -0
  25. package/esm2022/lib/utils/apply-props.mjs +123 -0
  26. package/esm2022/lib/utils/attach.mjs +32 -0
  27. package/esm2022/lib/utils/before-render.mjs +12 -0
  28. package/esm2022/lib/utils/create-api-token.mjs +13 -0
  29. package/esm2022/lib/utils/inputs.mjs +18 -0
  30. package/esm2022/lib/utils/is.mjs +52 -0
  31. package/esm2022/lib/utils/make.mjs +53 -0
  32. package/esm2022/lib/utils/signal-store.mjs +101 -0
  33. package/esm2022/lib/utils/update.mjs +34 -0
  34. package/fesm2022/angular-three.mjs +3167 -0
  35. package/fesm2022/angular-three.mjs.map +1 -0
  36. package/index.d.ts +22 -0
  37. package/lib/canvas.d.ts +1170 -0
  38. package/lib/directives/args.d.ts +11 -0
  39. package/lib/directives/common.d.ts +26 -0
  40. package/lib/directives/parent.d.ts +13 -0
  41. package/lib/dom/events.d.ts +5 -0
  42. package/lib/events.d.ts +83 -0
  43. package/lib/instance.d.ts +46 -0
  44. package/lib/loader.d.ts +32 -0
  45. package/lib/loop.d.ts +68 -0
  46. package/lib/portal.d.ts +58 -0
  47. package/lib/ref.d.ts +7 -0
  48. package/lib/renderer/catalogue.d.ts +13 -0
  49. package/lib/renderer/constants.d.ts +20 -0
  50. package/lib/renderer/index.d.ts +56 -0
  51. package/lib/renderer/store.d.ts +64 -0
  52. package/lib/renderer/utils.d.ts +31 -0
  53. package/lib/roots.d.ts +12 -0
  54. package/lib/routed-scene.d.ts +10 -0
  55. package/lib/store.d.ts +141 -0
  56. package/lib/three-types.d.ts +302 -0
  57. package/lib/types.d.ts +12 -0
  58. package/lib/utils/apply-props.d.ts +3 -0
  59. package/lib/utils/attach.d.ts +11 -0
  60. package/lib/utils/before-render.d.ts +6 -0
  61. package/lib/utils/create-api-token.d.ts +23 -0
  62. package/lib/utils/inputs.d.ts +5 -0
  63. package/lib/utils/is.d.ts +23 -0
  64. package/lib/utils/make.d.ts +19 -0
  65. package/lib/utils/signal-store.d.ts +30 -0
  66. package/lib/utils/update.d.ts +4 -0
  67. package/metadata.json +1 -0
  68. package/package.json +73 -0
  69. package/plugin/README.md +11 -0
  70. package/plugin/generators.json +17 -0
  71. package/plugin/src/generators/init/compat.d.ts +2 -0
  72. package/plugin/src/generators/init/compat.js +6 -0
  73. package/plugin/src/generators/init/compat.js.map +1 -0
  74. package/plugin/src/generators/init/files/experience/experience.component.html__tmpl__ +4 -0
  75. package/plugin/src/generators/init/files/experience/experience.component.ts__tmpl__ +18 -0
  76. package/plugin/src/generators/init/generator.d.ts +3 -0
  77. package/plugin/src/generators/init/generator.js +143 -0
  78. package/plugin/src/generators/init/generator.js.map +1 -0
  79. package/plugin/src/generators/init/schema.json +6 -0
  80. package/plugin/src/generators/utils.d.ts +2 -0
  81. package/plugin/src/generators/utils.js +34 -0
  82. package/plugin/src/generators/utils.js.map +1 -0
  83. package/plugin/src/generators/version.d.ts +14 -0
  84. package/plugin/src/generators/version.js +18 -0
  85. package/plugin/src/generators/version.js.map +1 -0
  86. package/plugin/src/index.d.ts +0 -0
  87. package/plugin/src/index.js +1 -0
  88. package/plugin/src/index.js.map +1 -0
  89. package/web-types.json +1 -0
@@ -0,0 +1,153 @@
1
+ import { createInjectionToken } from 'ngxtension/create-injection-token';
2
+ import { roots } from './roots';
3
+ function createSubs(callback, subs) {
4
+ const sub = { callback };
5
+ subs.add(sub);
6
+ return () => void subs.delete(sub);
7
+ }
8
+ const globalEffects = new Set();
9
+ const globalAfterEffects = new Set();
10
+ const globalTailEffects = new Set();
11
+ /**
12
+ * Adds a global render callback which is called each frame.
13
+ * @see https://docs.pmnd.rs/react-three-fiber/api/additional-exports#addEffect
14
+ */
15
+ export const addEffect = (callback) => createSubs(callback, globalEffects);
16
+ /**
17
+ * Adds a global after-render callback which is called each frame.
18
+ * @see https://docs.pmnd.rs/react-three-fiber/api/additional-exports#addAfterEffect
19
+ */
20
+ export const addAfterEffect = (callback) => createSubs(callback, globalAfterEffects);
21
+ /**
22
+ * Adds a global callback which is called when rendering stops.
23
+ * @see https://docs.pmnd.rs/react-three-fiber/api/additional-exports#addTail
24
+ */
25
+ export const addTail = (callback) => createSubs(callback, globalTailEffects);
26
+ function run(effects, timestamp) {
27
+ if (!effects.size)
28
+ return;
29
+ for (const { callback } of effects.values()) {
30
+ callback(timestamp);
31
+ }
32
+ }
33
+ export function flushGlobalEffects(type, timestamp) {
34
+ switch (type) {
35
+ case 'before':
36
+ return run(globalEffects, timestamp);
37
+ case 'after':
38
+ return run(globalAfterEffects, timestamp);
39
+ case 'tail':
40
+ return run(globalTailEffects, timestamp);
41
+ }
42
+ }
43
+ function render(timestamp, store, frame) {
44
+ const state = store.snapshot;
45
+ // Run local effects
46
+ let delta = state.clock.getDelta();
47
+ // In frameloop='never' mode, clock times are updated using the provided timestamp
48
+ if (state.frameloop === 'never' && typeof timestamp === 'number') {
49
+ delta = timestamp - state.clock.elapsedTime;
50
+ state.clock.oldTime = state.clock.elapsedTime;
51
+ state.clock.elapsedTime = timestamp;
52
+ }
53
+ // Call subscribers (beforeRender)
54
+ const subscribers = state.internal.subscribers;
55
+ for (let i = 0; i < subscribers.length; i++) {
56
+ const subscription = subscribers[i];
57
+ subscription.callback({ ...subscription.store.snapshot, delta, frame });
58
+ }
59
+ // Render content
60
+ if (!state.internal.priority && state.gl.render)
61
+ state.gl.render(state.scene, state.camera);
62
+ // Decrease frame count
63
+ state.internal.frames = Math.max(0, state.internal.frames - 1);
64
+ return state.frameloop === 'always' ? 1 : state.internal.frames;
65
+ }
66
+ function createLoop(roots) {
67
+ let running = false;
68
+ let injectBeforeRenderInProgress = false;
69
+ let repeat;
70
+ let frame;
71
+ function loop(timestamp) {
72
+ frame = requestAnimationFrame(loop);
73
+ running = true;
74
+ repeat = 0;
75
+ // Run effects
76
+ flushGlobalEffects('before', timestamp);
77
+ // Render all roots
78
+ injectBeforeRenderInProgress = true;
79
+ for (const root of roots.values()) {
80
+ const state = root.snapshot;
81
+ // If the frameloop is invalidated, do not run another frame
82
+ if (state.internal.active &&
83
+ (state.frameloop === 'always' || state.internal.frames > 0) &&
84
+ !state.gl.xr?.isPresenting) {
85
+ repeat += render(timestamp, root);
86
+ }
87
+ }
88
+ injectBeforeRenderInProgress = false;
89
+ // Run after-effects
90
+ flushGlobalEffects('after', timestamp);
91
+ // Stop the loop if nothing invalidates it
92
+ if (repeat === 0) {
93
+ // Tail call effects, they are called when rendering stops
94
+ flushGlobalEffects('tail', timestamp);
95
+ // Flag end of operation
96
+ running = false;
97
+ return cancelAnimationFrame(frame);
98
+ }
99
+ }
100
+ function invalidate(store, frames = 1) {
101
+ const state = store?.snapshot;
102
+ if (!state)
103
+ return roots.forEach((root) => invalidate(root, frames));
104
+ if (state.gl.xr?.isPresenting || !state.internal.active || state.frameloop === 'never')
105
+ return;
106
+ if (frames > 1) {
107
+ // legacy support for people using frames parameters
108
+ // Increase frames, do not go higher than 60
109
+ state.internal.frames = Math.min(60, state.internal.frames + frames);
110
+ }
111
+ else {
112
+ if (injectBeforeRenderInProgress) {
113
+ // called from within a injectBeforeRender, it means the user wants an additional frame
114
+ state.internal.frames = 2;
115
+ }
116
+ else {
117
+ // the user needs a new frame, no need to increment
118
+ state.internal.frames = 1;
119
+ }
120
+ }
121
+ // If the render-loop isn't active, start it
122
+ if (!running) {
123
+ running = true;
124
+ requestAnimationFrame(loop);
125
+ }
126
+ }
127
+ function advance(timestamp, runGlobalEffects = true, store, frame) {
128
+ if (runGlobalEffects)
129
+ flushGlobalEffects('before', timestamp);
130
+ if (!store)
131
+ for (const root of roots.values())
132
+ render(timestamp, root);
133
+ else
134
+ render(timestamp, store, frame);
135
+ if (runGlobalEffects)
136
+ flushGlobalEffects('after', timestamp);
137
+ }
138
+ return {
139
+ loop,
140
+ /**
141
+ * Invalidates the view, requesting a frame to be rendered. Will globally invalidate unless passed a root's state.
142
+ * @see https://docs.pmnd.rs/react-three-fiber/api/additional-exports#invalidate
143
+ */
144
+ invalidate,
145
+ /**
146
+ * Advances the frameloop and runs render effects, useful for when manually rendering via `frameloop="never"`.
147
+ * @see https://docs.pmnd.rs/react-three-fiber/api/additional-exports#advance
148
+ */
149
+ advance,
150
+ };
151
+ }
152
+ export const [injectNgtLoop] = createInjectionToken(() => createLoop(roots));
153
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"loop.js","sourceRoot":"","sources":["../../../../../libs/core/src/lib/loop.ts"],"names":[],"mappings":"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","sourcesContent":["import { createInjectionToken } from 'ngxtension/create-injection-token';\nimport { roots } from './roots';\nimport type { NgtState } from './store';\nimport type { NgtSignalStore } from './utils/signal-store';\n\nexport type NgtGlobalRenderCallback = (timeStamp: number) => void;\ntype SubItem = { callback: NgtGlobalRenderCallback };\n\nfunction createSubs(callback: NgtGlobalRenderCallback, subs: Set<SubItem>): () => void {\n\tconst sub = { callback };\n\tsubs.add(sub);\n\treturn () => void subs.delete(sub);\n}\n\nconst globalEffects: Set<SubItem> = new Set();\nconst globalAfterEffects: Set<SubItem> = new Set();\nconst globalTailEffects: Set<SubItem> = new Set();\n\n/**\n * Adds a global render callback which is called each frame.\n * @see https://docs.pmnd.rs/react-three-fiber/api/additional-exports#addEffect\n */\nexport const addEffect = (callback: NgtGlobalRenderCallback) => createSubs(callback, globalEffects);\n\n/**\n * Adds a global after-render callback which is called each frame.\n * @see https://docs.pmnd.rs/react-three-fiber/api/additional-exports#addAfterEffect\n */\nexport const addAfterEffect = (callback: NgtGlobalRenderCallback) => createSubs(callback, globalAfterEffects);\n\n/**\n * Adds a global callback which is called when rendering stops.\n * @see https://docs.pmnd.rs/react-three-fiber/api/additional-exports#addTail\n */\nexport const addTail = (callback: NgtGlobalRenderCallback) => createSubs(callback, globalTailEffects);\n\nfunction run(effects: Set<SubItem>, timestamp: number) {\n\tif (!effects.size) return;\n\tfor (const { callback } of effects.values()) {\n\t\tcallback(timestamp);\n\t}\n}\n\nexport type NgtGlobalEffectType = 'before' | 'after' | 'tail';\n\nexport function flushGlobalEffects(type: NgtGlobalEffectType, timestamp: number): void {\n\tswitch (type) {\n\t\tcase 'before':\n\t\t\treturn run(globalEffects, timestamp);\n\t\tcase 'after':\n\t\t\treturn run(globalAfterEffects, timestamp);\n\t\tcase 'tail':\n\t\t\treturn run(globalTailEffects, timestamp);\n\t}\n}\n\nfunction render(timestamp: number, store: NgtSignalStore<NgtState>, frame?: XRFrame) {\n\tconst state = store.snapshot;\n\t// Run local effects\n\tlet delta = state.clock.getDelta();\n\t// In frameloop='never' mode, clock times are updated using the provided timestamp\n\tif (state.frameloop === 'never' && typeof timestamp === 'number') {\n\t\tdelta = timestamp - state.clock.elapsedTime;\n\t\tstate.clock.oldTime = state.clock.elapsedTime;\n\t\tstate.clock.elapsedTime = timestamp;\n\t}\n\t// Call subscribers (beforeRender)\n\tconst subscribers = state.internal.subscribers;\n\tfor (let i = 0; i < subscribers.length; i++) {\n\t\tconst subscription = subscribers[i];\n\t\tsubscription.callback({ ...subscription.store.snapshot, delta, frame });\n\t}\n\t// Render content\n\tif (!state.internal.priority && state.gl.render) state.gl.render(state.scene, state.camera);\n\t// Decrease frame count\n\tstate.internal.frames = Math.max(0, state.internal.frames - 1);\n\treturn state.frameloop === 'always' ? 1 : state.internal.frames;\n}\n\nfunction createLoop<TCanvas>(roots: Map<TCanvas, NgtSignalStore<NgtState>>) {\n\tlet running = false;\n\tlet injectBeforeRenderInProgress = false;\n\tlet repeat: number;\n\tlet frame: number;\n\n\tfunction loop(timestamp: number): void {\n\t\tframe = requestAnimationFrame(loop);\n\t\trunning = true;\n\t\trepeat = 0;\n\n\t\t// Run effects\n\t\tflushGlobalEffects('before', timestamp);\n\n\t\t// Render all roots\n\t\tinjectBeforeRenderInProgress = true;\n\t\tfor (const root of roots.values()) {\n\t\t\tconst state = root.snapshot;\n\t\t\t// If the frameloop is invalidated, do not run another frame\n\t\t\tif (\n\t\t\t\tstate.internal.active &&\n\t\t\t\t(state.frameloop === 'always' || state.internal.frames > 0) &&\n\t\t\t\t!state.gl.xr?.isPresenting\n\t\t\t) {\n\t\t\t\trepeat += render(timestamp, root);\n\t\t\t}\n\t\t}\n\t\tinjectBeforeRenderInProgress = false;\n\n\t\t// Run after-effects\n\t\tflushGlobalEffects('after', timestamp);\n\n\t\t// Stop the loop if nothing invalidates it\n\t\tif (repeat === 0) {\n\t\t\t// Tail call effects, they are called when rendering stops\n\t\t\tflushGlobalEffects('tail', timestamp);\n\n\t\t\t// Flag end of operation\n\t\t\trunning = false;\n\t\t\treturn cancelAnimationFrame(frame);\n\t\t}\n\t}\n\n\tfunction invalidate(store?: NgtSignalStore<NgtState>, frames = 1): void {\n\t\tconst state = store?.snapshot;\n\t\tif (!state) return roots.forEach((root) => invalidate(root, frames));\n\t\tif (state.gl.xr?.isPresenting || !state.internal.active || state.frameloop === 'never') return;\n\n\t\tif (frames > 1) {\n\t\t\t// legacy support for people using frames parameters\n\t\t\t// Increase frames, do not go higher than 60\n\t\t\tstate.internal.frames = Math.min(60, state.internal.frames + frames);\n\t\t} else {\n\t\t\tif (injectBeforeRenderInProgress) {\n\t\t\t\t// called from within a injectBeforeRender, it means the user wants an additional frame\n\t\t\t\tstate.internal.frames = 2;\n\t\t\t} else {\n\t\t\t\t// the user needs a new frame, no need to increment\n\t\t\t\tstate.internal.frames = 1;\n\t\t\t}\n\t\t}\n\n\t\t// If the render-loop isn't active, start it\n\t\tif (!running) {\n\t\t\trunning = true;\n\t\t\trequestAnimationFrame(loop);\n\t\t}\n\t}\n\n\tfunction advance(\n\t\ttimestamp: number,\n\t\trunGlobalEffects = true,\n\t\tstore?: NgtSignalStore<NgtState>,\n\t\tframe?: XRFrame,\n\t): void {\n\t\tif (runGlobalEffects) flushGlobalEffects('before', timestamp);\n\t\tif (!store) for (const root of roots.values()) render(timestamp, root);\n\t\telse render(timestamp, store, frame);\n\t\tif (runGlobalEffects) flushGlobalEffects('after', timestamp);\n\t}\n\n\treturn {\n\t\tloop,\n\t\t/**\n\t\t * Invalidates the view, requesting a frame to be rendered. Will globally invalidate unless passed a root's state.\n\t\t * @see https://docs.pmnd.rs/react-three-fiber/api/additional-exports#invalidate\n\t\t */\n\t\tinvalidate,\n\t\t/**\n\t\t * Advances the frameloop and runs render effects, useful for when manually rendering via `frameloop=\"never\"`.\n\t\t * @see https://docs.pmnd.rs/react-three-fiber/api/additional-exports#advance\n\t\t */\n\t\tadvance,\n\t};\n}\n\nexport const [injectNgtLoop] = createInjectionToken(() => createLoop(roots));\n"]}
@@ -0,0 +1,208 @@
1
+ import { afterNextRender, ChangeDetectionStrategy, Component, computed, contentChild, CUSTOM_ELEMENTS_SCHEMA, DestroyRef, Directive, ElementRef, inject, Injector, input, signal, SkipSelf, TemplateRef, untracked, viewChild, ViewContainerRef, } from '@angular/core';
2
+ import { injectAutoEffect } from 'ngxtension/auto-effect';
3
+ import { createInjectionToken } from 'ngxtension/create-injection-token';
4
+ import * as THREE from 'three';
5
+ import { prepare } from './instance';
6
+ import { injectNgtRef } from './ref';
7
+ import { SPECIAL_INTERNAL_ADD_COMMENT } from './renderer/constants';
8
+ import { injectNgtStore, NGT_STORE } from './store';
9
+ import { injectBeforeRender } from './utils/before-render';
10
+ import { is } from './utils/is';
11
+ import { signalStore } from './utils/signal-store';
12
+ import { updateCamera } from './utils/update';
13
+ import * as i0 from "@angular/core";
14
+ const privateKeys = [
15
+ 'get',
16
+ 'set',
17
+ 'select',
18
+ 'setSize',
19
+ 'setDpr',
20
+ 'setFrameloop',
21
+ 'events',
22
+ 'invalidate',
23
+ 'advance',
24
+ 'size',
25
+ 'viewport',
26
+ ];
27
+ const [, providePortalStore] = createInjectionToken((parentStore) => {
28
+ const parentState = parentStore.snapshot;
29
+ const pointer = new THREE.Vector2();
30
+ const raycaster = new THREE.Raycaster();
31
+ return signalStore(({ update }) => {
32
+ return {
33
+ ...parentState,
34
+ pointer,
35
+ raycaster,
36
+ previousRoot: parentStore,
37
+ // Layers are allowed to override events
38
+ setEvents: (events) => update((state) => ({ ...state, events: { ...state.events, ...events } })),
39
+ };
40
+ });
41
+ }, { isRoot: false, token: NGT_STORE, deps: [[new SkipSelf(), NGT_STORE]] });
42
+ export class NgtPortalBeforeRender {
43
+ constructor() {
44
+ this.portalStore = injectNgtStore();
45
+ this.injector = inject(Injector);
46
+ this.renderPriority = input(1);
47
+ this.parentScene = input.required();
48
+ this.parentCamera = input.required();
49
+ afterNextRender(() => {
50
+ let oldClear;
51
+ injectBeforeRender(() => {
52
+ const { gl, scene, camera } = this.portalStore.get();
53
+ oldClear = gl.autoClear;
54
+ if (this.renderPriority() === 1) {
55
+ // clear scene and render with default
56
+ gl.autoClear = true;
57
+ gl.render(this.parentScene(), this.parentCamera());
58
+ }
59
+ // disable cleaning
60
+ gl.autoClear = false;
61
+ gl.clearDepth();
62
+ gl.render(scene, camera);
63
+ // restore
64
+ gl.autoClear = oldClear;
65
+ }, { priority: this.renderPriority(), injector: this.injector });
66
+ });
67
+ }
68
+ onPointerOver() {
69
+ /* noop */
70
+ }
71
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: NgtPortalBeforeRender, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
72
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.0.0", type: NgtPortalBeforeRender, isStandalone: true, selector: "ngt-portal-before-render", inputs: { renderPriority: { classPropertyName: "renderPriority", publicName: "renderPriority", isSignal: true, isRequired: false, transformFunction: null }, parentScene: { classPropertyName: "parentScene", publicName: "parentScene", isSignal: true, isRequired: true, transformFunction: null }, parentCamera: { classPropertyName: "parentCamera", publicName: "parentCamera", isSignal: true, isRequired: true, transformFunction: null } }, ngImport: i0, template: `
73
+ <!-- Without an element that receives pointer events state.pointer will always be 0/0 -->
74
+ <ngt-group (pointerover)="onPointerOver()" attach="none" />
75
+ `, isInline: true }); }
76
+ }
77
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: NgtPortalBeforeRender, decorators: [{
78
+ type: Component,
79
+ args: [{
80
+ selector: 'ngt-portal-before-render',
81
+ standalone: true,
82
+ template: `
83
+ <!-- Without an element that receives pointer events state.pointer will always be 0/0 -->
84
+ <ngt-group (pointerover)="onPointerOver()" attach="none" />
85
+ `,
86
+ schemas: [CUSTOM_ELEMENTS_SCHEMA],
87
+ }]
88
+ }], ctorParameters: () => [] });
89
+ export class NgtPortalContent {
90
+ constructor(vcr, parentVcr) {
91
+ const commentNode = vcr.element.nativeElement;
92
+ if (commentNode[SPECIAL_INTERNAL_ADD_COMMENT]) {
93
+ commentNode[SPECIAL_INTERNAL_ADD_COMMENT](parentVcr.element.nativeElement);
94
+ delete commentNode[SPECIAL_INTERNAL_ADD_COMMENT];
95
+ }
96
+ }
97
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: NgtPortalContent, deps: [{ token: i0.ViewContainerRef }, { token: i0.ViewContainerRef, skipSelf: true }], target: i0.ɵɵFactoryTarget.Directive }); }
98
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.0.0", type: NgtPortalContent, isStandalone: true, selector: "ng-template[ngtPortalContent]", ngImport: i0 }); }
99
+ }
100
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: NgtPortalContent, decorators: [{
101
+ type: Directive,
102
+ args: [{ selector: 'ng-template[ngtPortalContent]', standalone: true }]
103
+ }], ctorParameters: () => [{ type: i0.ViewContainerRef }, { type: i0.ViewContainerRef, decorators: [{
104
+ type: SkipSelf
105
+ }] }] });
106
+ export class NgtPortal {
107
+ constructor() {
108
+ this.options = input({ container: injectNgtRef(prepare(new THREE.Scene())) }, {
109
+ transform: (value) => ({
110
+ container: injectNgtRef(prepare(new THREE.Scene())),
111
+ ...value,
112
+ }),
113
+ });
114
+ this.autoRender = input(false);
115
+ this.autoRenderPriority = input(1);
116
+ this.portalContentTemplate = contentChild.required(NgtPortalContent, { read: TemplateRef });
117
+ this.portalContentAnchor = viewChild.required('portalContentAnchor', { read: ViewContainerRef });
118
+ this.destroyRef = inject(DestroyRef);
119
+ this.autoEffect = injectAutoEffect();
120
+ this.parentStore = injectNgtStore({ skipSelf: true });
121
+ this.portalStore = injectNgtStore({ self: true });
122
+ this.portalRendered = signal(false);
123
+ this.renderAutoBeforeRender = computed(() => this.portalRendered() && this.autoRender());
124
+ this.parentScene = this.parentStore.get('scene');
125
+ this.parentCamera = this.parentStore.get('camera');
126
+ afterNextRender(() => {
127
+ const parentState = this.parentStore.snapshot;
128
+ const { container, state: { events = {}, size = {}, ...rest } = {} } = untracked(this.options);
129
+ this.portalStore.update({
130
+ scene: (is.ref(container) ? container.nativeElement : container),
131
+ events: { ...parentState.events, ...events },
132
+ size: { ...parentState.size, ...size },
133
+ ...rest,
134
+ });
135
+ this.autoEffect(() => {
136
+ const previous = this.parentStore.state();
137
+ this.portalStore.update((state) => this.inject(previous, state));
138
+ });
139
+ untracked(() => {
140
+ const portalView = this.portalContentAnchor().createEmbeddedView(this.portalContentTemplate());
141
+ portalView.detectChanges();
142
+ this.destroyRef.onDestroy(portalView.destroy.bind(portalView));
143
+ });
144
+ this.portalRendered.set(true);
145
+ });
146
+ }
147
+ inject(rootState, injectState) {
148
+ const intersect = { ...rootState };
149
+ Object.keys(intersect).forEach((key) => {
150
+ if (privateKeys.includes(key) ||
151
+ rootState[key] !== injectState[key]) {
152
+ delete intersect[key];
153
+ }
154
+ });
155
+ const inputs = untracked(this.options);
156
+ const { size, events, ...restInputsState } = inputs.state || {};
157
+ let viewport = undefined;
158
+ if (injectState && size) {
159
+ const camera = injectState.camera;
160
+ viewport = rootState.viewport.getCurrentViewport(camera, new THREE.Vector3(), size);
161
+ if (camera !== rootState.camera)
162
+ updateCamera(camera, size);
163
+ }
164
+ return {
165
+ ...intersect,
166
+ scene: is.ref(inputs.container) ? inputs.container.nativeElement : inputs.container,
167
+ previousRoot: this.parentStore,
168
+ events: { ...rootState.events, ...(injectState?.events || {}), ...events },
169
+ size: { ...rootState.size, ...size },
170
+ viewport: { ...rootState.viewport, ...(viewport || {}) },
171
+ ...restInputsState,
172
+ };
173
+ }
174
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: NgtPortal, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
175
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.0", type: NgtPortal, isStandalone: true, selector: "ngt-portal", inputs: { options: { classPropertyName: "options", publicName: "options", isSignal: true, isRequired: false, transformFunction: null }, autoRender: { classPropertyName: "autoRender", publicName: "autoRender", isSignal: true, isRequired: false, transformFunction: null }, autoRenderPriority: { classPropertyName: "autoRenderPriority", publicName: "autoRenderPriority", isSignal: true, isRequired: false, transformFunction: null } }, providers: [providePortalStore()], queries: [{ propertyName: "portalContentTemplate", first: true, predicate: NgtPortalContent, descendants: true, read: TemplateRef, isSignal: true }], viewQueries: [{ propertyName: "portalContentAnchor", first: true, predicate: ["portalContentAnchor"], descendants: true, read: ViewContainerRef, isSignal: true }], ngImport: i0, template: `
176
+ <ng-container #portalContentAnchor>
177
+ @if (renderAutoBeforeRender()) {
178
+ <ngt-portal-before-render
179
+ [renderPriority]="autoRenderPriority()"
180
+ [parentScene]="parentScene"
181
+ [parentCamera]="parentCamera"
182
+ />
183
+ }
184
+ </ng-container>
185
+ `, isInline: true, dependencies: [{ kind: "component", type: NgtPortalBeforeRender, selector: "ngt-portal-before-render", inputs: ["renderPriority", "parentScene", "parentCamera"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
186
+ }
187
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: NgtPortal, decorators: [{
188
+ type: Component,
189
+ args: [{
190
+ selector: 'ngt-portal',
191
+ standalone: true,
192
+ template: `
193
+ <ng-container #portalContentAnchor>
194
+ @if (renderAutoBeforeRender()) {
195
+ <ngt-portal-before-render
196
+ [renderPriority]="autoRenderPriority()"
197
+ [parentScene]="parentScene"
198
+ [parentCamera]="parentCamera"
199
+ />
200
+ }
201
+ </ng-container>
202
+ `,
203
+ imports: [NgtPortalBeforeRender],
204
+ providers: [providePortalStore()],
205
+ changeDetection: ChangeDetectionStrategy.OnPush,
206
+ }]
207
+ }], ctorParameters: () => [] });
208
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"portal.js","sourceRoot":"","sources":["../../../../../libs/core/src/lib/portal.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n\tafterNextRender,\n\tChangeDetectionStrategy,\n\tComponent,\n\tcomputed,\n\tcontentChild,\n\tCUSTOM_ELEMENTS_SCHEMA,\n\tDestroyRef,\n\tDirective,\n\tElementRef,\n\tinject,\n\tInjector,\n\tinput,\n\tsignal,\n\tSkipSelf,\n\tTemplateRef,\n\tuntracked,\n\tviewChild,\n\tViewContainerRef,\n} from '@angular/core';\nimport { injectAutoEffect } from 'ngxtension/auto-effect';\nimport { createInjectionToken } from 'ngxtension/create-injection-token';\nimport * as THREE from 'three';\nimport type { NgtEventManager } from './events';\nimport { prepare } from './instance';\nimport { injectNgtRef } from './ref';\nimport { SPECIAL_INTERNAL_ADD_COMMENT } from './renderer/constants';\nimport { injectNgtStore, NGT_STORE, type NgtSize, type NgtState } from './store';\nimport { injectBeforeRender } from './utils/before-render';\nimport { is } from './utils/is';\nimport { signalStore, type NgtSignalStore } from './utils/signal-store';\nimport { updateCamera } from './utils/update';\n\nconst privateKeys = [\n\t'get',\n\t'set',\n\t'select',\n\t'setSize',\n\t'setDpr',\n\t'setFrameloop',\n\t'events',\n\t'invalidate',\n\t'advance',\n\t'size',\n\t'viewport',\n] as const;\ntype PrivateKeys = (typeof privateKeys)[number];\n\nexport interface NgtPortalInputs {\n\tcontainer: ElementRef<THREE.Object3D> | THREE.Object3D;\n\tcamera: ElementRef<THREE.Camera> | THREE.Camera;\n\tstate: Partial<\n\t\tOmit<NgtState, PrivateKeys> & {\n\t\t\tevents: Partial<Pick<NgtEventManager<any>, 'enabled' | 'priority' | 'compute' | 'connected'>>;\n\t\t\tsize: NgtSize;\n\t\t}\n\t>;\n}\n\nconst [, providePortalStore] = createInjectionToken(\n\t(parentStore: NgtSignalStore<NgtState>) => {\n\t\tconst parentState = parentStore.snapshot;\n\t\tconst pointer = new THREE.Vector2();\n\t\tconst raycaster = new THREE.Raycaster();\n\t\treturn signalStore<NgtState>(({ update }) => {\n\t\t\treturn {\n\t\t\t\t...parentState,\n\t\t\t\tpointer,\n\t\t\t\traycaster,\n\t\t\t\tpreviousRoot: parentStore,\n\t\t\t\t// Layers are allowed to override events\n\t\t\t\tsetEvents: (events) => update((state) => ({ ...state, events: { ...state.events, ...events } })),\n\t\t\t};\n\t\t});\n\t},\n\t{ isRoot: false, token: NGT_STORE, deps: [[new SkipSelf(), NGT_STORE]] },\n);\n\n@Component({\n\tselector: 'ngt-portal-before-render',\n\tstandalone: true,\n\ttemplate: `\n\t\t<!-- Without an element that receives pointer events state.pointer will always be 0/0 -->\n\t\t<ngt-group (pointerover)=\"onPointerOver()\" attach=\"none\" />\n\t`,\n\tschemas: [CUSTOM_ELEMENTS_SCHEMA],\n})\nexport class NgtPortalBeforeRender {\n\tprivate portalStore = injectNgtStore();\n\tprivate injector = inject(Injector);\n\n\trenderPriority = input(1);\n\tparentScene = input.required<THREE.Scene>();\n\tparentCamera = input.required<THREE.Camera>();\n\n\tconstructor() {\n\t\tafterNextRender(() => {\n\t\t\tlet oldClear: boolean;\n\t\t\tinjectBeforeRender(\n\t\t\t\t() => {\n\t\t\t\t\tconst { gl, scene, camera } = this.portalStore.get();\n\t\t\t\t\toldClear = gl.autoClear;\n\t\t\t\t\tif (this.renderPriority() === 1) {\n\t\t\t\t\t\t// clear scene and render with default\n\t\t\t\t\t\tgl.autoClear = true;\n\t\t\t\t\t\tgl.render(this.parentScene(), this.parentCamera());\n\t\t\t\t\t}\n\t\t\t\t\t// disable cleaning\n\t\t\t\t\tgl.autoClear = false;\n\t\t\t\t\tgl.clearDepth();\n\t\t\t\t\tgl.render(scene, camera);\n\t\t\t\t\t// restore\n\t\t\t\t\tgl.autoClear = oldClear;\n\t\t\t\t},\n\t\t\t\t{ priority: this.renderPriority(), injector: this.injector },\n\t\t\t);\n\t\t});\n\t}\n\n\tonPointerOver() {\n\t\t/* noop */\n\t}\n}\n\n@Directive({ selector: 'ng-template[ngtPortalContent]', standalone: true })\nexport class NgtPortalContent {\n\tconstructor(vcr: ViewContainerRef, @SkipSelf() parentVcr: ViewContainerRef) {\n\t\tconst commentNode = vcr.element.nativeElement;\n\t\tif (commentNode[SPECIAL_INTERNAL_ADD_COMMENT]) {\n\t\t\tcommentNode[SPECIAL_INTERNAL_ADD_COMMENT](parentVcr.element.nativeElement);\n\t\t\tdelete commentNode[SPECIAL_INTERNAL_ADD_COMMENT];\n\t\t}\n\t}\n}\n\n@Component({\n\tselector: 'ngt-portal',\n\tstandalone: true,\n\ttemplate: `\n\t\t<ng-container #portalContentAnchor>\n\t\t\t@if (renderAutoBeforeRender()) {\n\t\t\t\t<ngt-portal-before-render\n\t\t\t\t\t[renderPriority]=\"autoRenderPriority()\"\n\t\t\t\t\t[parentScene]=\"parentScene\"\n\t\t\t\t\t[parentCamera]=\"parentCamera\"\n\t\t\t\t/>\n\t\t\t}\n\t\t</ng-container>\n\t`,\n\timports: [NgtPortalBeforeRender],\n\tproviders: [providePortalStore()],\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class NgtPortal {\n\toptions = input(\n\t\t{ container: injectNgtRef<THREE.Scene>(prepare(new THREE.Scene())) },\n\t\t{\n\t\t\ttransform: (value: Partial<NgtPortalInputs>) => ({\n\t\t\t\tcontainer: injectNgtRef<THREE.Scene>(prepare(new THREE.Scene())),\n\t\t\t\t...value,\n\t\t\t}),\n\t\t},\n\t);\n\n\tautoRender = input(false);\n\tautoRenderPriority = input(1);\n\n\tportalContentTemplate = contentChild.required(NgtPortalContent, { read: TemplateRef });\n\tportalContentAnchor = viewChild.required('portalContentAnchor', { read: ViewContainerRef });\n\n\tprivate destroyRef = inject(DestroyRef);\n\tprivate autoEffect = injectAutoEffect();\n\tprivate parentStore = injectNgtStore({ skipSelf: true });\n\tprivate portalStore = injectNgtStore({ self: true });\n\n\tprivate portalRendered = signal(false);\n\n\tprotected renderAutoBeforeRender = computed(() => this.portalRendered() && this.autoRender());\n\tprotected parentScene = this.parentStore.get('scene');\n\tprotected parentCamera = this.parentStore.get('camera');\n\n\tconstructor() {\n\t\tafterNextRender(() => {\n\t\t\tconst parentState = this.parentStore.snapshot;\n\t\t\tconst { container, state: { events = {}, size = {}, ...rest } = {} } = untracked(this.options);\n\n\t\t\tthis.portalStore.update({\n\t\t\t\tscene: (is.ref(container) ? container.nativeElement : container) as THREE.Scene,\n\t\t\t\tevents: { ...parentState.events, ...events },\n\t\t\t\tsize: { ...parentState.size, ...size },\n\t\t\t\t...rest,\n\t\t\t});\n\n\t\t\tthis.autoEffect(() => {\n\t\t\t\tconst previous = this.parentStore.state();\n\t\t\t\tthis.portalStore.update((state) => this.inject(previous, state));\n\t\t\t});\n\n\t\t\tuntracked(() => {\n\t\t\t\tconst portalView = this.portalContentAnchor().createEmbeddedView(this.portalContentTemplate());\n\t\t\t\tportalView.detectChanges();\n\t\t\t\tthis.destroyRef.onDestroy(portalView.destroy.bind(portalView));\n\t\t\t});\n\n\t\t\tthis.portalRendered.set(true);\n\t\t});\n\t}\n\n\tprivate inject(rootState: NgtState, injectState: NgtState) {\n\t\tconst intersect: Partial<NgtState> = { ...rootState };\n\n\t\tObject.keys(intersect).forEach((key) => {\n\t\t\tif (\n\t\t\t\tprivateKeys.includes(key as PrivateKeys) ||\n\t\t\t\trootState[key as keyof NgtState] !== injectState[key as keyof NgtState]\n\t\t\t) {\n\t\t\t\tdelete intersect[key as keyof NgtState];\n\t\t\t}\n\t\t});\n\n\t\tconst inputs = untracked(this.options);\n\t\tconst { size, events, ...restInputsState } = inputs.state || {};\n\n\t\tlet viewport = undefined;\n\t\tif (injectState && size) {\n\t\t\tconst camera = injectState.camera;\n\t\t\tviewport = rootState.viewport.getCurrentViewport(camera, new THREE.Vector3(), size);\n\t\t\tif (camera !== rootState.camera) updateCamera(camera, size);\n\t\t}\n\n\t\treturn {\n\t\t\t...intersect,\n\t\t\tscene: is.ref(inputs.container) ? inputs.container.nativeElement : inputs.container,\n\t\t\tpreviousRoot: this.parentStore,\n\t\t\tevents: { ...rootState.events, ...(injectState?.events || {}), ...events },\n\t\t\tsize: { ...rootState.size, ...size },\n\t\t\tviewport: { ...rootState.viewport, ...(viewport || {}) },\n\t\t\t...restInputsState,\n\t\t} as NgtState;\n\t}\n}\n"]}
@@ -0,0 +1,46 @@
1
+ import { DestroyRef, ElementRef, computed, inject, signal, untracked } from '@angular/core';
2
+ import { assertInjector } from 'ngxtension/assert-injector';
3
+ import { getLocalState } from './instance';
4
+ import { is } from './utils/is';
5
+ export function injectNgtRef(initial = null, injector) {
6
+ return assertInjector(injectNgtRef, injector, () => {
7
+ const ref = is.ref(initial) ? initial : new ElementRef(initial);
8
+ const refSignal = signal(ref.nativeElement, { equal: Object.is });
9
+ const readonlyRef = refSignal.asReadonly();
10
+ const computedCached = new Map();
11
+ inject(DestroyRef).onDestroy(() => void computedCached.clear());
12
+ const children = (type = 'objects') => {
13
+ if (!computedCached.has(type)) {
14
+ computedCached.set(type, computed(() => {
15
+ const instance = readonlyRef();
16
+ if (!instance)
17
+ return [];
18
+ const localState = getLocalState(instance);
19
+ if (!localState?.instanceStore)
20
+ return [];
21
+ if (type === 'objects')
22
+ return localState.objects();
23
+ if (type === 'nonObjects')
24
+ return localState.nonObjects();
25
+ return [...localState.objects(), ...localState.nonObjects()];
26
+ }));
27
+ }
28
+ return computedCached.get(type);
29
+ };
30
+ Object.defineProperties(ref, {
31
+ nativeElement: {
32
+ set: (newElement) => {
33
+ untracked(() => {
34
+ if (newElement !== readonlyRef()) {
35
+ refSignal.set(newElement);
36
+ }
37
+ });
38
+ },
39
+ get: readonlyRef,
40
+ },
41
+ children: { value: children },
42
+ });
43
+ return ref;
44
+ });
45
+ }
46
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVmLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vbGlicy9jb3JlL3NyYy9saWIvcmVmLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsVUFBVSxFQUFFLFFBQVEsRUFBRSxNQUFNLEVBQUUsTUFBTSxFQUFFLFNBQVMsRUFBOEIsTUFBTSxlQUFlLENBQUM7QUFDeEgsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBQzVELE9BQU8sRUFBRSxhQUFhLEVBQXdCLE1BQU0sWUFBWSxDQUFDO0FBQ2pFLE9BQU8sRUFBRSxFQUFFLEVBQUUsTUFBTSxZQUFZLENBQUM7QUFTaEMsTUFBTSxVQUFVLFlBQVksQ0FDM0IsVUFBMkMsSUFBSyxFQUNoRCxRQUFtQjtJQUVuQixPQUFPLGNBQWMsQ0FBQyxZQUFZLEVBQUUsUUFBUSxFQUFFLEdBQUcsRUFBRTtRQUNsRCxNQUFNLEdBQUcsR0FBRyxFQUFFLENBQUMsR0FBRyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLElBQUksVUFBVSxDQUFDLE9BQW1CLENBQUMsQ0FBQztRQUM1RSxNQUFNLFNBQVMsR0FBRyxNQUFNLENBQUMsR0FBRyxDQUFDLGFBQWEsRUFBRSxFQUFFLEtBQUssRUFBRSxNQUFNLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQztRQUNsRSxNQUFNLFdBQVcsR0FBRyxTQUFTLENBQUMsVUFBVSxFQUFFLENBQUM7UUFDM0MsTUFBTSxjQUFjLEdBQUcsSUFBSSxHQUFHLEVBQUUsQ0FBQztRQUVqQyxNQUFNLENBQUMsVUFBVSxDQUFDLENBQUMsU0FBUyxDQUFDLEdBQUcsRUFBRSxDQUFDLEtBQUssY0FBYyxDQUFDLEtBQUssRUFBRSxDQUFDLENBQUM7UUFFaEUsTUFBTSxRQUFRLEdBQUcsQ0FBQyxPQUEwQyxTQUFTLEVBQUUsRUFBRTtZQUN4RSxJQUFJLENBQUMsY0FBYyxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDO2dCQUMvQixjQUFjLENBQUMsR0FBRyxDQUNqQixJQUFJLEVBQ0osUUFBUSxDQUFDLEdBQUcsRUFBRTtvQkFDYixNQUFNLFFBQVEsR0FBRyxXQUFXLEVBQUUsQ0FBQztvQkFDL0IsSUFBSSxDQUFDLFFBQVE7d0JBQUUsT0FBTyxFQUFFLENBQUM7b0JBQ3pCLE1BQU0sVUFBVSxHQUFHLGFBQWEsQ0FBQyxRQUFRLENBQUMsQ0FBQztvQkFDM0MsSUFBSSxDQUFDLFVBQVUsRUFBRSxhQUFhO3dCQUFFLE9BQU8sRUFBRSxDQUFDO29CQUMxQyxJQUFJLElBQUksS0FBSyxTQUFTO3dCQUFFLE9BQU8sVUFBVSxDQUFDLE9BQU8sRUFBRSxDQUFDO29CQUNwRCxJQUFJLElBQUksS0FBSyxZQUFZO3dCQUFFLE9BQU8sVUFBVSxDQUFDLFVBQVUsRUFBRSxDQUFDO29CQUMxRCxPQUFPLENBQUMsR0FBRyxVQUFVLENBQUMsT0FBTyxFQUFFLEVBQUUsR0FBRyxVQUFVLENBQUMsVUFBVSxFQUFFLENBQUMsQ0FBQztnQkFDOUQsQ0FBQyxDQUFDLENBQ0YsQ0FBQztZQUNILENBQUM7WUFDRCxPQUFPLGNBQWMsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFFLENBQUM7UUFDbEMsQ0FBQyxDQUFDO1FBRUYsTUFBTSxDQUFDLGdCQUFnQixDQUFDLEdBQUcsRUFBRTtZQUM1QixhQUFhLEVBQUU7Z0JBQ2QsR0FBRyxFQUFFLENBQUMsVUFBVSxFQUFFLEVBQUU7b0JBQ25CLFNBQVMsQ0FBQyxHQUFHLEVBQUU7d0JBQ2QsSUFBSSxVQUFVLEtBQUssV0FBVyxFQUFFLEVBQUUsQ0FBQzs0QkFDbEMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxVQUFVLENBQUMsQ0FBQzt3QkFDM0IsQ0FBQztvQkFDRixDQUFDLENBQUMsQ0FBQztnQkFDSixDQUFDO2dCQUNELEdBQUcsRUFBRSxXQUFXO2FBQ2hCO1lBQ0QsUUFBUSxFQUFFLEVBQUUsS0FBSyxFQUFFLFFBQVEsRUFBRTtTQUM3QixDQUFDLENBQUM7UUFFSCxPQUFPLEdBQStCLENBQUM7SUFDeEMsQ0FBQyxDQUFDLENBQUM7QUFDSixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGVzdHJveVJlZiwgRWxlbWVudFJlZiwgY29tcHV0ZWQsIGluamVjdCwgc2lnbmFsLCB1bnRyYWNrZWQsIHR5cGUgSW5qZWN0b3IsIHR5cGUgU2lnbmFsIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBhc3NlcnRJbmplY3RvciB9IGZyb20gJ25neHRlbnNpb24vYXNzZXJ0LWluamVjdG9yJztcbmltcG9ydCB7IGdldExvY2FsU3RhdGUsIHR5cGUgTmd0SW5zdGFuY2VOb2RlIH0gZnJvbSAnLi9pbnN0YW5jZSc7XG5pbXBvcnQgeyBpcyB9IGZyb20gJy4vdXRpbHMvaXMnO1xuXG5leHBvcnQgdHlwZSBOZ3RJbmplY3RlZFJlZjxURWxlbWVudD4gPSBFbGVtZW50UmVmPFRFbGVtZW50PiAmIHtcblx0LyogY29uc3VtZXJzIHNob3VsZCB1c2UgdGhpcyBmb3IgbGlzdGVudGluZyB0byBjaGlsZHJlbiBjaGFuZ2VzIG9uIHRoaXMgcmVmICovXG5cdGNoaWxkcmVuOiAodHlwZT86ICdvYmplY3RzJyB8ICdub25PYmplY3RzJyB8ICdib3RoJykgPT4gU2lnbmFsPE5ndEluc3RhbmNlTm9kZVtdPjtcbn07XG5cbmV4cG9ydCB0eXBlIE5ndFJlZjxURWxlbWVudD4gPSBURWxlbWVudCB8IE5ndEluamVjdGVkUmVmPFRFbGVtZW50PjtcblxuZXhwb3J0IGZ1bmN0aW9uIGluamVjdE5ndFJlZjxURWxlbWVudD4oXG5cdGluaXRpYWw6IEVsZW1lbnRSZWY8VEVsZW1lbnQ+IHwgVEVsZW1lbnQgPSBudWxsISxcblx0aW5qZWN0b3I/OiBJbmplY3Rvcixcbik6IE5ndEluamVjdGVkUmVmPFRFbGVtZW50PiB7XG5cdHJldHVybiBhc3NlcnRJbmplY3RvcihpbmplY3ROZ3RSZWYsIGluamVjdG9yLCAoKSA9PiB7XG5cdFx0Y29uc3QgcmVmID0gaXMucmVmKGluaXRpYWwpID8gaW5pdGlhbCA6IG5ldyBFbGVtZW50UmVmKGluaXRpYWwgYXMgVEVsZW1lbnQpO1xuXHRcdGNvbnN0IHJlZlNpZ25hbCA9IHNpZ25hbChyZWYubmF0aXZlRWxlbWVudCwgeyBlcXVhbDogT2JqZWN0LmlzIH0pO1xuXHRcdGNvbnN0IHJlYWRvbmx5UmVmID0gcmVmU2lnbmFsLmFzUmVhZG9ubHkoKTtcblx0XHRjb25zdCBjb21wdXRlZENhY2hlZCA9IG5ldyBNYXAoKTtcblxuXHRcdGluamVjdChEZXN0cm95UmVmKS5vbkRlc3Ryb3koKCkgPT4gdm9pZCBjb21wdXRlZENhY2hlZC5jbGVhcigpKTtcblxuXHRcdGNvbnN0IGNoaWxkcmVuID0gKHR5cGU6ICdvYmplY3RzJyB8ICdub25PYmplY3RzJyB8ICdib3RoJyA9ICdvYmplY3RzJykgPT4ge1xuXHRcdFx0aWYgKCFjb21wdXRlZENhY2hlZC5oYXModHlwZSkpIHtcblx0XHRcdFx0Y29tcHV0ZWRDYWNoZWQuc2V0KFxuXHRcdFx0XHRcdHR5cGUsXG5cdFx0XHRcdFx0Y29tcHV0ZWQoKCkgPT4ge1xuXHRcdFx0XHRcdFx0Y29uc3QgaW5zdGFuY2UgPSByZWFkb25seVJlZigpO1xuXHRcdFx0XHRcdFx0aWYgKCFpbnN0YW5jZSkgcmV0dXJuIFtdO1xuXHRcdFx0XHRcdFx0Y29uc3QgbG9jYWxTdGF0ZSA9IGdldExvY2FsU3RhdGUoaW5zdGFuY2UpO1xuXHRcdFx0XHRcdFx0aWYgKCFsb2NhbFN0YXRlPy5pbnN0YW5jZVN0b3JlKSByZXR1cm4gW107XG5cdFx0XHRcdFx0XHRpZiAodHlwZSA9PT0gJ29iamVjdHMnKSByZXR1cm4gbG9jYWxTdGF0ZS5vYmplY3RzKCk7XG5cdFx0XHRcdFx0XHRpZiAodHlwZSA9PT0gJ25vbk9iamVjdHMnKSByZXR1cm4gbG9jYWxTdGF0ZS5ub25PYmplY3RzKCk7XG5cdFx0XHRcdFx0XHRyZXR1cm4gWy4uLmxvY2FsU3RhdGUub2JqZWN0cygpLCAuLi5sb2NhbFN0YXRlLm5vbk9iamVjdHMoKV07XG5cdFx0XHRcdFx0fSksXG5cdFx0XHRcdCk7XG5cdFx0XHR9XG5cdFx0XHRyZXR1cm4gY29tcHV0ZWRDYWNoZWQuZ2V0KHR5cGUpITtcblx0XHR9O1xuXG5cdFx0T2JqZWN0LmRlZmluZVByb3BlcnRpZXMocmVmLCB7XG5cdFx0XHRuYXRpdmVFbGVtZW50OiB7XG5cdFx0XHRcdHNldDogKG5ld0VsZW1lbnQpID0+IHtcblx0XHRcdFx0XHR1bnRyYWNrZWQoKCkgPT4ge1xuXHRcdFx0XHRcdFx0aWYgKG5ld0VsZW1lbnQgIT09IHJlYWRvbmx5UmVmKCkpIHtcblx0XHRcdFx0XHRcdFx0cmVmU2lnbmFsLnNldChuZXdFbGVtZW50KTtcblx0XHRcdFx0XHRcdH1cblx0XHRcdFx0XHR9KTtcblx0XHRcdFx0fSxcblx0XHRcdFx0Z2V0OiByZWFkb25seVJlZixcblx0XHRcdH0sXG5cdFx0XHRjaGlsZHJlbjogeyB2YWx1ZTogY2hpbGRyZW4gfSxcblx0XHR9KTtcblxuXHRcdHJldHVybiByZWYgYXMgTmd0SW5qZWN0ZWRSZWY8VEVsZW1lbnQ+O1xuXHR9KTtcbn1cbiJdfQ==
@@ -0,0 +1,7 @@
1
+ import { createInjectionToken } from 'ngxtension/create-injection-token';
2
+ const catalogue = {};
3
+ export function extend(objects) {
4
+ Object.assign(catalogue, objects);
5
+ }
6
+ export const [injectNgtCatalogue] = createInjectionToken(() => catalogue);
7
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2F0YWxvZ3VlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb3JlL3NyYy9saWIvcmVuZGVyZXIvY2F0YWxvZ3VlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLG1DQUFtQyxDQUFDO0FBSXpFLE1BQU0sU0FBUyxHQUFzQyxFQUFFLENBQUM7QUFFeEQsTUFBTSxVQUFVLE1BQU0sQ0FBQyxPQUFlO0lBQ3JDLE1BQU0sQ0FBQyxNQUFNLENBQUMsU0FBUyxFQUFFLE9BQU8sQ0FBQyxDQUFDO0FBQ25DLENBQUM7QUFFRCxNQUFNLENBQUMsTUFBTSxDQUFDLGtCQUFrQixDQUFDLEdBQUcsb0JBQW9CLENBQUMsR0FBRyxFQUFFLENBQUMsU0FBUyxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjcmVhdGVJbmplY3Rpb25Ub2tlbiB9IGZyb20gJ25neHRlbnNpb24vY3JlYXRlLWluamVjdGlvbi10b2tlbic7XG5cbmV4cG9ydCB0eXBlIE5ndEFueUNvbnN0cnVjdG9yID0gbmV3ICguLi5hcmdzOiBhbnlbXSkgPT4gYW55O1xuXG5jb25zdCBjYXRhbG9ndWU6IFJlY29yZDxzdHJpbmcsIE5ndEFueUNvbnN0cnVjdG9yPiA9IHt9O1xuXG5leHBvcnQgZnVuY3Rpb24gZXh0ZW5kKG9iamVjdHM6IG9iamVjdCk6IHZvaWQge1xuXHRPYmplY3QuYXNzaWduKGNhdGFsb2d1ZSwgb2JqZWN0cyk7XG59XG5cbmV4cG9ydCBjb25zdCBbaW5qZWN0Tmd0Q2F0YWxvZ3VlXSA9IGNyZWF0ZUluamVjdGlvblRva2VuKCgpID0+IGNhdGFsb2d1ZSk7XG4iXX0=
@@ -0,0 +1,21 @@
1
+ export const ROUTED_SCENE = '__ngt_renderer_is_routed_scene__';
2
+ export const HTML = '__ngt_renderer_is_html';
3
+ export const SPECIAL_INTERNAL_ADD_COMMENT = '__ngt_renderer_add_comment__';
4
+ export const SPECIAL_DOM_TAG = {
5
+ NGT_PORTAL: 'ngt-portal',
6
+ NGT_PRIMITIVE: 'ngt-primitive',
7
+ NGT_VALUE: 'ngt-value',
8
+ };
9
+ export const SPECIAL_PROPERTIES = {
10
+ COMPOUND: 'ngtCompound',
11
+ RENDER_PRIORITY: 'priority',
12
+ ATTACH: 'attach',
13
+ RAW_VALUE: 'rawValue',
14
+ REF: 'ref',
15
+ };
16
+ export const SPECIAL_EVENTS = {
17
+ BEFORE_RENDER: 'beforeRender',
18
+ AFTER_UPDATE: 'afterUpdate',
19
+ AFTER_ATTACH: 'afterAttach',
20
+ };
21
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc3RhbnRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb3JlL3NyYy9saWIvcmVuZGVyZXIvY29uc3RhbnRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBQyxNQUFNLFlBQVksR0FBRyxrQ0FBa0MsQ0FBQztBQUMvRCxNQUFNLENBQUMsTUFBTSxJQUFJLEdBQUcsd0JBQXdCLENBQUM7QUFDN0MsTUFBTSxDQUFDLE1BQU0sNEJBQTRCLEdBQUcsOEJBQThCLENBQUM7QUFFM0UsTUFBTSxDQUFDLE1BQU0sZUFBZSxHQUFHO0lBQzlCLFVBQVUsRUFBRSxZQUFZO0lBQ3hCLGFBQWEsRUFBRSxlQUFlO0lBQzlCLFNBQVMsRUFBRSxXQUFXO0NBQ2IsQ0FBQztBQUVYLE1BQU0sQ0FBQyxNQUFNLGtCQUFrQixHQUFHO0lBQ2pDLFFBQVEsRUFBRSxhQUFhO0lBQ3ZCLGVBQWUsRUFBRSxVQUFVO0lBQzNCLE1BQU0sRUFBRSxRQUFRO0lBQ2hCLFNBQVMsRUFBRSxVQUFVO0lBQ3JCLEdBQUcsRUFBRSxLQUFLO0NBQ0QsQ0FBQztBQUVYLE1BQU0sQ0FBQyxNQUFNLGNBQWMsR0FBRztJQUM3QixhQUFhLEVBQUUsY0FBYztJQUM3QixZQUFZLEVBQUUsYUFBYTtJQUMzQixZQUFZLEVBQUUsYUFBYTtDQUNsQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNvbnN0IFJPVVRFRF9TQ0VORSA9ICdfX25ndF9yZW5kZXJlcl9pc19yb3V0ZWRfc2NlbmVfXyc7XG5leHBvcnQgY29uc3QgSFRNTCA9ICdfX25ndF9yZW5kZXJlcl9pc19odG1sJztcbmV4cG9ydCBjb25zdCBTUEVDSUFMX0lOVEVSTkFMX0FERF9DT01NRU5UID0gJ19fbmd0X3JlbmRlcmVyX2FkZF9jb21tZW50X18nO1xuXG5leHBvcnQgY29uc3QgU1BFQ0lBTF9ET01fVEFHID0ge1xuXHROR1RfUE9SVEFMOiAnbmd0LXBvcnRhbCcsXG5cdE5HVF9QUklNSVRJVkU6ICduZ3QtcHJpbWl0aXZlJyxcblx0TkdUX1ZBTFVFOiAnbmd0LXZhbHVlJyxcbn0gYXMgY29uc3Q7XG5cbmV4cG9ydCBjb25zdCBTUEVDSUFMX1BST1BFUlRJRVMgPSB7XG5cdENPTVBPVU5EOiAnbmd0Q29tcG91bmQnLFxuXHRSRU5ERVJfUFJJT1JJVFk6ICdwcmlvcml0eScsXG5cdEFUVEFDSDogJ2F0dGFjaCcsXG5cdFJBV19WQUxVRTogJ3Jhd1ZhbHVlJyxcblx0UkVGOiAncmVmJyxcbn0gYXMgY29uc3Q7XG5cbmV4cG9ydCBjb25zdCBTUEVDSUFMX0VWRU5UUyA9IHtcblx0QkVGT1JFX1JFTkRFUjogJ2JlZm9yZVJlbmRlcicsXG5cdEFGVEVSX1VQREFURTogJ2FmdGVyVXBkYXRlJyxcblx0QUZURVJfQVRUQUNIOiAnYWZ0ZXJBdHRhY2gnLFxufSBhcyBjb25zdDtcbiJdfQ==