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.
- package/README.md +7 -0
- package/esm2022/angular-three.mjs +5 -0
- package/esm2022/index.mjs +20 -0
- package/esm2022/lib/canvas.mjs +187 -0
- package/esm2022/lib/directives/args.mjs +35 -0
- package/esm2022/lib/directives/common.mjs +42 -0
- package/esm2022/lib/directives/parent.mjs +35 -0
- package/esm2022/lib/dom/events.mjs +73 -0
- package/esm2022/lib/events.mjs +362 -0
- package/esm2022/lib/instance.mjs +70 -0
- package/esm2022/lib/loader.mjs +64 -0
- package/esm2022/lib/loop.mjs +153 -0
- package/esm2022/lib/portal.mjs +208 -0
- package/esm2022/lib/ref.mjs +46 -0
- package/esm2022/lib/renderer/catalogue.mjs +7 -0
- package/esm2022/lib/renderer/constants.mjs +21 -0
- package/esm2022/lib/renderer/index.mjs +432 -0
- package/esm2022/lib/renderer/store.mjs +423 -0
- package/esm2022/lib/renderer/utils.mjs +201 -0
- package/esm2022/lib/roots.mjs +261 -0
- package/esm2022/lib/routed-scene.mjs +33 -0
- package/esm2022/lib/store.mjs +181 -0
- package/esm2022/lib/three-types.mjs +2 -0
- package/esm2022/lib/types.mjs +2 -0
- package/esm2022/lib/utils/apply-props.mjs +123 -0
- package/esm2022/lib/utils/attach.mjs +32 -0
- package/esm2022/lib/utils/before-render.mjs +12 -0
- package/esm2022/lib/utils/create-api-token.mjs +13 -0
- package/esm2022/lib/utils/inputs.mjs +18 -0
- package/esm2022/lib/utils/is.mjs +52 -0
- package/esm2022/lib/utils/make.mjs +53 -0
- package/esm2022/lib/utils/signal-store.mjs +101 -0
- package/esm2022/lib/utils/update.mjs +34 -0
- package/fesm2022/angular-three.mjs +3167 -0
- package/fesm2022/angular-three.mjs.map +1 -0
- package/index.d.ts +22 -0
- package/lib/canvas.d.ts +1170 -0
- package/lib/directives/args.d.ts +11 -0
- package/lib/directives/common.d.ts +26 -0
- package/lib/directives/parent.d.ts +13 -0
- package/lib/dom/events.d.ts +5 -0
- package/lib/events.d.ts +83 -0
- package/lib/instance.d.ts +46 -0
- package/lib/loader.d.ts +32 -0
- package/lib/loop.d.ts +68 -0
- package/lib/portal.d.ts +58 -0
- package/lib/ref.d.ts +7 -0
- package/lib/renderer/catalogue.d.ts +13 -0
- package/lib/renderer/constants.d.ts +20 -0
- package/lib/renderer/index.d.ts +56 -0
- package/lib/renderer/store.d.ts +64 -0
- package/lib/renderer/utils.d.ts +31 -0
- package/lib/roots.d.ts +12 -0
- package/lib/routed-scene.d.ts +10 -0
- package/lib/store.d.ts +141 -0
- package/lib/three-types.d.ts +302 -0
- package/lib/types.d.ts +12 -0
- package/lib/utils/apply-props.d.ts +3 -0
- package/lib/utils/attach.d.ts +11 -0
- package/lib/utils/before-render.d.ts +6 -0
- package/lib/utils/create-api-token.d.ts +23 -0
- package/lib/utils/inputs.d.ts +5 -0
- package/lib/utils/is.d.ts +23 -0
- package/lib/utils/make.d.ts +19 -0
- package/lib/utils/signal-store.d.ts +30 -0
- package/lib/utils/update.d.ts +4 -0
- package/metadata.json +1 -0
- package/package.json +73 -0
- package/plugin/README.md +11 -0
- package/plugin/generators.json +17 -0
- package/plugin/src/generators/init/compat.d.ts +2 -0
- package/plugin/src/generators/init/compat.js +6 -0
- package/plugin/src/generators/init/compat.js.map +1 -0
- package/plugin/src/generators/init/files/experience/experience.component.html__tmpl__ +4 -0
- package/plugin/src/generators/init/files/experience/experience.component.ts__tmpl__ +18 -0
- package/plugin/src/generators/init/generator.d.ts +3 -0
- package/plugin/src/generators/init/generator.js +143 -0
- package/plugin/src/generators/init/generator.js.map +1 -0
- package/plugin/src/generators/init/schema.json +6 -0
- package/plugin/src/generators/utils.d.ts +2 -0
- package/plugin/src/generators/utils.js +34 -0
- package/plugin/src/generators/utils.js.map +1 -0
- package/plugin/src/generators/version.d.ts +14 -0
- package/plugin/src/generators/version.js +18 -0
- package/plugin/src/generators/version.js.map +1 -0
- package/plugin/src/index.d.ts +0 -0
- package/plugin/src/index.js +1 -0
- package/plugin/src/index.js.map +1 -0
- 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==
|