angular-three 2.0.0-beta.236 → 2.0.0-beta.238
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/esm2022/index.mjs +2 -1
- package/esm2022/lib/loader.mjs +30 -19
- package/esm2022/lib/portal.mjs +38 -26
- package/esm2022/lib/renderer/index.mjs +8 -1
- package/esm2022/lib/renderer/store.mjs +10 -1
- package/esm2022/lib/utils/before-render.mjs +12 -2
- package/esm2022/lib/utils/parameters.mjs +14 -0
- package/fesm2022/angular-three.mjs +104 -41
- package/fesm2022/angular-three.mjs.map +1 -1
- package/index.d.ts +1 -0
- package/lib/loader.d.ts +4 -4
- package/lib/portal.d.ts +3 -1
- package/lib/utils/before-render.d.ts +4 -0
- package/lib/utils/parameters.d.ts +1 -0
- package/package.json +1 -1
package/esm2022/index.mjs
CHANGED
|
@@ -14,6 +14,7 @@ export * from './lib/utils/before-render';
|
|
|
14
14
|
export * from './lib/utils/create-api-token';
|
|
15
15
|
export * from './lib/utils/is';
|
|
16
16
|
export * from './lib/utils/make';
|
|
17
|
+
export * from './lib/utils/parameters';
|
|
17
18
|
export * from './lib/utils/signal-store';
|
|
18
19
|
export * from './lib/utils/update';
|
|
19
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9saWJzL2NvcmUvc3JjL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYyxnQkFBZ0IsQ0FBQztBQUMvQixjQUFjLGNBQWMsQ0FBQztBQUM3QixPQUFPLEVBQUUsY0FBYyxFQUFFLFNBQVMsRUFBRSxPQUFPLEVBQUUsTUFBTSxZQUFZLENBQUM7QUFDaEUsT0FBTyxFQUFFLFNBQVMsRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGNBQWMsQ0FBQztBQUMzRCxjQUFjLFdBQVcsQ0FBQztBQUMxQixjQUFjLGdCQUFnQixDQUFDO0FBQy9CLGNBQWMsb0JBQW9CLENBQUM7QUFDbkMsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUMxRCxjQUFjLDJCQUEyQixDQUFDO0FBQzFDLGNBQWMsOEJBQThCLENBQUM7QUFDN0MsY0FBYyxnQkFBZ0IsQ0FBQztBQUMvQixjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsd0JBQXdCLENBQUM7QUFDdkMsY0FBYywwQkFBMEIsQ0FBQztBQUN6QyxjQUFjLG9CQUFvQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9saWIvY2FudmFzJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2RpcmVjdGl2ZXMvYXJncyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9pbnN0YW5jZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9sb2FkZXInO1xuZXhwb3J0IHsgYWRkQWZ0ZXJFZmZlY3QsIGFkZEVmZmVjdCwgYWRkVGFpbCB9IGZyb20gJy4vbGliL2xvb3AnO1xuZXhwb3J0IHsgTmd0UG9ydGFsLCBOZ3RQb3J0YWxDb250ZW50IH0gZnJvbSAnLi9saWIvcG9ydGFsJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3JlZic7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9yZW5kZXJlcic7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9yb3V0ZWQtc2NlbmUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvc3RvcmUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdXRpbHMvYXBwbHktcHJvcHMnO1xuZXhwb3J0IHsgY3JlYXRlQXR0YWNoRnVuY3Rpb24gfSBmcm9tICcuL2xpYi91dGlscy9hdHRhY2gnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdXRpbHMvYmVmb3JlLXJlbmRlcic7XG5leHBvcnQgKiBmcm9tICcuL2xpYi91dGlscy9jcmVhdGUtYXBpLXRva2VuJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3V0aWxzL2lzJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3V0aWxzL21ha2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdXRpbHMvcGFyYW1ldGVycyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi91dGlscy9zaWduYWwtc3RvcmUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdXRpbHMvdXBkYXRlJztcblxuZXhwb3J0IHR5cGUgeyBOZ3RDYW1lcmEsIE5ndFRocmVlRXZlbnQgfSBmcm9tICcuL2xpYi9ldmVudHMnO1xuZXhwb3J0IHR5cGUgKiBmcm9tICcuL2xpYi90aHJlZS10eXBlcyc7XG5leHBvcnQgdHlwZSAqIGZyb20gJy4vbGliL3R5cGVzJztcbiJdfQ==
|
package/esm2022/lib/loader.mjs
CHANGED
|
@@ -12,6 +12,8 @@ function normalizeInputs(input) {
|
|
|
12
12
|
function load(loaderConstructorFactory, inputs, { extensions, onProgress, } = {}) {
|
|
13
13
|
return () => {
|
|
14
14
|
const urls = normalizeInputs(inputs());
|
|
15
|
+
if (urls.some((url) => url.includes('undefined')))
|
|
16
|
+
return null;
|
|
15
17
|
const loader = new (loaderConstructorFactory(urls))();
|
|
16
18
|
if (extensions)
|
|
17
19
|
extensions(loader);
|
|
@@ -31,34 +33,43 @@ function load(loaderConstructorFactory, inputs, { extensions, onProgress, } = {}
|
|
|
31
33
|
});
|
|
32
34
|
};
|
|
33
35
|
}
|
|
34
|
-
function
|
|
35
|
-
return assertInjector(
|
|
36
|
+
function _injectLoader(loaderConstructorFactory, inputs, { extensions, onProgress, injector, } = {}) {
|
|
37
|
+
return assertInjector(_injectLoader, injector, () => {
|
|
36
38
|
const response = signal(null);
|
|
37
39
|
const effector = load(loaderConstructorFactory, inputs, { extensions, onProgress });
|
|
38
40
|
effect(() => {
|
|
39
41
|
const originalUrls = inputs();
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
42
|
+
const cachedEffect = effector();
|
|
43
|
+
if (cachedEffect === null) {
|
|
44
|
+
response.set(null);
|
|
45
|
+
}
|
|
46
|
+
else {
|
|
47
|
+
Promise.all(cachedEffect).then((results) => {
|
|
48
|
+
response.update(() => {
|
|
49
|
+
if (Array.isArray(originalUrls))
|
|
50
|
+
return results;
|
|
51
|
+
if (typeof originalUrls === 'string')
|
|
52
|
+
return results[0];
|
|
53
|
+
const keys = Object.keys(originalUrls);
|
|
54
|
+
return keys.reduce((result, key) => {
|
|
55
|
+
result[key] = results[keys.indexOf(key)];
|
|
56
|
+
return result;
|
|
57
|
+
}, {});
|
|
58
|
+
});
|
|
51
59
|
});
|
|
52
|
-
}
|
|
60
|
+
}
|
|
53
61
|
});
|
|
54
62
|
return response.asReadonly();
|
|
55
63
|
});
|
|
56
64
|
}
|
|
57
|
-
|
|
58
|
-
|
|
65
|
+
_injectLoader.preload = (loaderConstructorFactory, inputs, extensions) => {
|
|
66
|
+
const effects = load(loaderConstructorFactory, inputs, { extensions })();
|
|
67
|
+
if (effects) {
|
|
68
|
+
void Promise.all(effects);
|
|
69
|
+
}
|
|
59
70
|
};
|
|
60
|
-
|
|
71
|
+
_injectLoader.destroy = () => {
|
|
61
72
|
cached.clear();
|
|
62
73
|
};
|
|
63
|
-
export const
|
|
64
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"loader.js","sourceRoot":"","sources":["../../../../../libs/core/src/lib/loader.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injector, Signal, effect, signal } from '@angular/core';\nimport { assertInjector } from 'ngxtension/assert-injector';\nimport { Loader, Object3D } from 'three';\nimport { NgtAnyRecord } from './types';\nimport { NgtObjectMap, makeObjectGraph } from './utils/make';\n\nexport type NgtGLTFLike = { scene: Object3D };\n\nexport interface NgtLoader<T> extends Loader {\n\tload(\n\t\turl: string,\n\t\tonLoad?: (result: T) => void,\n\t\tonProgress?: (event: ProgressEvent) => void,\n\t\tonError?: (event: unknown) => void,\n\t): unknown;\n\tloadAsync(url: string, onProgress?: (event: ProgressEvent) => void): Promise<T>;\n}\n\nexport type NgtLoaderProto<T> = new (...args: any) => NgtLoader<T extends unknown ? any : T>;\nexport type NgtLoaderReturnType<T, L extends NgtLoaderProto<T>> = T extends unknown\n\t? Awaited<ReturnType<InstanceType<L>['loadAsync']>>\n\t: T;\n\nexport type NgtLoaderExtensions<T extends { prototype: NgtLoaderProto<any> }> = (loader: T['prototype']) => void;\nexport type NgtConditionalType<Child, Parent, Truthy, Falsy> = Child extends Parent ? Truthy : Falsy;\nexport type NgtBranchingReturn<T, Parent, Coerced> = NgtConditionalType<T, Parent, Coerced, T>;\n\nexport type NgtLoaderResults<\n\tTInput extends string | string[] | Record<string, string>,\n\tTReturn,\n> = TInput extends string[] ? TReturn[] : TInput extends object ? { [key in keyof TInput]: TReturn } : TReturn;\n\nconst cached = new Map();\n\nfunction normalizeInputs(input: string | string[] | Record<string, string>) {\n\tif (Array.isArray(input)) return input;\n\tif (typeof input === 'string') return [input];\n\treturn Object.values(input);\n}\n\nfunction load<\n\tTData,\n\tTUrl extends string | string[] | Record<string, string>,\n\tTLoaderConstructor extends NgtLoaderProto<TData>,\n>(\n\tloaderConstructorFactory: (inputs: string[]) => TLoaderConstructor,\n\tinputs: () => TUrl,\n\t{\n\t\textensions,\n\t\tonProgress,\n\t}: { extensions?: NgtLoaderExtensions<TLoaderConstructor>; onProgress?: (event: ProgressEvent) => void } = {},\n) {\n\treturn (): Array<Promise<any>> => {\n\t\tconst urls = normalizeInputs(inputs());\n\t\tconst loader = new (loaderConstructorFactory(urls))();\n\t\tif (extensions) extensions(loader);\n\t\t// TODO: reevaluate this\n\t\treturn urls.map((url) => {\n\t\t\tif (!cached.has(url)) {\n\t\t\t\tcached.set(\n\t\t\t\t\turl,\n\t\t\t\t\tnew Promise<TData>((resolve, reject) => {\n\t\t\t\t\t\tloader.load(\n\t\t\t\t\t\t\turl,\n\t\t\t\t\t\t\t(data) => {\n\t\t\t\t\t\t\t\tif ('scene' in (data as NgtAnyRecord)) {\n\t\t\t\t\t\t\t\t\tObject.assign(data as NgtAnyRecord, makeObjectGraph((data as NgtAnyRecord)['scene']));\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\tresolve(data);\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\tonProgress,\n\t\t\t\t\t\t\t(error) => reject(new Error(`[NGT] Could not load ${url}: ${error}`)),\n\t\t\t\t\t\t);\n\t\t\t\t\t}),\n\t\t\t\t);\n\t\t\t}\n\t\t\treturn cached.get(url)!;\n\t\t});\n\t};\n}\n\nfunction _injectNgtLoader<\n\tTData,\n\tTUrl extends string | string[] | Record<string, string>,\n\tTLoaderConstructor extends NgtLoaderProto<TData>,\n\tTReturn = NgtLoaderReturnType<TData, TLoaderConstructor>,\n>(\n\tloaderConstructorFactory: (inputs: string[]) => TLoaderConstructor,\n\tinputs: () => TUrl,\n\t{\n\t\textensions,\n\t\tonProgress,\n\t\tinjector,\n\t}: {\n\t\textensions?: NgtLoaderExtensions<TLoaderConstructor>;\n\t\tonProgress?: (event: ProgressEvent) => void;\n\t\tinjector?: Injector;\n\t} = {},\n): Signal<NgtLoaderResults<TUrl, NgtBranchingReturn<TReturn, NgtGLTFLike, NgtGLTFLike & NgtObjectMap>> | null> {\n\treturn assertInjector(_injectNgtLoader, injector, () => {\n\t\tconst response = signal<NgtLoaderResults<\n\t\t\tTUrl,\n\t\t\tNgtBranchingReturn<TReturn, NgtGLTFLike, NgtGLTFLike & NgtObjectMap>\n\t\t> | null>(null);\n\t\tconst effector = load(loaderConstructorFactory, inputs, { extensions, onProgress });\n\n\t\teffect(() => {\n\t\t\tconst originalUrls = inputs();\n\t\t\tPromise.all(effector()).then((results) => {\n\t\t\t\tresponse.update(() => {\n\t\t\t\t\tif (Array.isArray(originalUrls)) return results;\n\t\t\t\t\tif (typeof originalUrls === 'string') return results[0];\n\t\t\t\t\tconst keys = Object.keys(originalUrls);\n\t\t\t\t\treturn keys.reduce(\n\t\t\t\t\t\t(result, key) => {\n\t\t\t\t\t\t\t(result as NgtAnyRecord)[key] = results[keys.indexOf(key)];\n\t\t\t\t\t\t\treturn result;\n\t\t\t\t\t\t},\n\t\t\t\t\t\t{} as { [key in keyof TUrl]: NgtBranchingReturn<TReturn, NgtGLTFLike, NgtGLTFLike & NgtObjectMap> },\n\t\t\t\t\t);\n\t\t\t\t});\n\t\t\t});\n\t\t});\n\n\t\treturn response.asReadonly();\n\t});\n}\n\n_injectNgtLoader.preload = <\n\tTData,\n\tTUrl extends string | string[] | Record<string, string>,\n\tTLoaderConstructor extends NgtLoaderProto<TData>,\n>(\n\tloaderConstructorFactory: (inputs: string[]) => TLoaderConstructor,\n\tinputs: () => TUrl,\n\textensions?: NgtLoaderExtensions<TLoaderConstructor>,\n) => {\n\tvoid Promise.all(load(loaderConstructorFactory, inputs, { extensions })());\n};\n\n_injectNgtLoader.destroy = () => {\n\tcached.clear();\n};\n\nexport type NgtInjectedLoader = typeof _injectNgtLoader;\nexport const injectNgtLoader: NgtInjectedLoader = _injectNgtLoader;\n"]}
|
|
74
|
+
export const injectLoader = _injectLoader;
|
|
75
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"loader.js","sourceRoot":"","sources":["../../../../../libs/core/src/lib/loader.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injector, Signal, effect, signal } from '@angular/core';\nimport { assertInjector } from 'ngxtension/assert-injector';\nimport { Loader, Object3D } from 'three';\nimport { NgtAnyRecord } from './types';\nimport { NgtObjectMap, makeObjectGraph } from './utils/make';\n\nexport type NgtGLTFLike = { scene: Object3D };\n\nexport interface NgtLoader<T> extends Loader {\n\tload(\n\t\turl: string,\n\t\tonLoad?: (result: T) => void,\n\t\tonProgress?: (event: ProgressEvent) => void,\n\t\tonError?: (event: unknown) => void,\n\t): unknown;\n\tloadAsync(url: string, onProgress?: (event: ProgressEvent) => void): Promise<T>;\n}\n\nexport type NgtLoaderProto<T> = new (...args: any) => NgtLoader<T extends unknown ? any : T>;\nexport type NgtLoaderReturnType<T, L extends NgtLoaderProto<T>> = T extends unknown\n\t? Awaited<ReturnType<InstanceType<L>['loadAsync']>>\n\t: T;\n\nexport type NgtLoaderExtensions<T extends { prototype: NgtLoaderProto<any> }> = (loader: T['prototype']) => void;\nexport type NgtConditionalType<Child, Parent, Truthy, Falsy> = Child extends Parent ? Truthy : Falsy;\nexport type NgtBranchingReturn<T, Parent, Coerced> = NgtConditionalType<T, Parent, Coerced, T>;\n\nexport type NgtLoaderResults<\n\tTInput extends string | string[] | Record<string, string>,\n\tTReturn,\n> = TInput extends string[] ? TReturn[] : TInput extends object ? { [key in keyof TInput]: TReturn } : TReturn;\n\nconst cached = new Map();\n\nfunction normalizeInputs(input: string | string[] | Record<string, string>) {\n\tif (Array.isArray(input)) return input;\n\tif (typeof input === 'string') return [input];\n\treturn Object.values(input);\n}\n\nfunction load<\n\tTData,\n\tTUrl extends string | string[] | Record<string, string>,\n\tTLoaderConstructor extends NgtLoaderProto<TData>,\n>(\n\tloaderConstructorFactory: (inputs: string[]) => TLoaderConstructor,\n\tinputs: () => TUrl,\n\t{\n\t\textensions,\n\t\tonProgress,\n\t}: { extensions?: NgtLoaderExtensions<TLoaderConstructor>; onProgress?: (event: ProgressEvent) => void } = {},\n) {\n\treturn (): Array<Promise<any>> | null => {\n\t\tconst urls = normalizeInputs(inputs());\n\n\t\tif (urls.some((url) => url.includes('undefined'))) return null;\n\n\t\tconst loader = new (loaderConstructorFactory(urls))();\n\t\tif (extensions) extensions(loader);\n\t\t// TODO: reevaluate this\n\t\treturn urls.map((url) => {\n\t\t\tif (!cached.has(url)) {\n\t\t\t\tcached.set(\n\t\t\t\t\turl,\n\t\t\t\t\tnew Promise<TData>((resolve, reject) => {\n\t\t\t\t\t\tloader.load(\n\t\t\t\t\t\t\turl,\n\t\t\t\t\t\t\t(data) => {\n\t\t\t\t\t\t\t\tif ('scene' in (data as NgtAnyRecord)) {\n\t\t\t\t\t\t\t\t\tObject.assign(data as NgtAnyRecord, makeObjectGraph((data as NgtAnyRecord)['scene']));\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\tresolve(data);\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\tonProgress,\n\t\t\t\t\t\t\t(error) => reject(new Error(`[NGT] Could not load ${url}: ${error}`)),\n\t\t\t\t\t\t);\n\t\t\t\t\t}),\n\t\t\t\t);\n\t\t\t}\n\t\t\treturn cached.get(url)!;\n\t\t});\n\t};\n}\n\nfunction _injectLoader<\n\tTData,\n\tTUrl extends string | string[] | Record<string, string>,\n\tTLoaderConstructor extends NgtLoaderProto<TData>,\n\tTReturn = NgtLoaderReturnType<TData, TLoaderConstructor>,\n>(\n\tloaderConstructorFactory: (inputs: string[]) => TLoaderConstructor,\n\tinputs: () => TUrl,\n\t{\n\t\textensions,\n\t\tonProgress,\n\t\tinjector,\n\t}: {\n\t\textensions?: NgtLoaderExtensions<TLoaderConstructor>;\n\t\tonProgress?: (event: ProgressEvent) => void;\n\t\tinjector?: Injector;\n\t} = {},\n): Signal<NgtLoaderResults<TUrl, NgtBranchingReturn<TReturn, NgtGLTFLike, NgtGLTFLike & NgtObjectMap>> | null> {\n\treturn assertInjector(_injectLoader, injector, () => {\n\t\tconst response = signal<NgtLoaderResults<\n\t\t\tTUrl,\n\t\t\tNgtBranchingReturn<TReturn, NgtGLTFLike, NgtGLTFLike & NgtObjectMap>\n\t\t> | null>(null);\n\t\tconst effector = load(loaderConstructorFactory, inputs, { extensions, onProgress });\n\n\t\teffect(() => {\n\t\t\tconst originalUrls = inputs();\n\t\t\tconst cachedEffect = effector();\n\t\t\tif (cachedEffect === null) {\n\t\t\t\tresponse.set(null);\n\t\t\t} else {\n\t\t\t\tPromise.all(cachedEffect).then((results) => {\n\t\t\t\t\tresponse.update(() => {\n\t\t\t\t\t\tif (Array.isArray(originalUrls)) return results;\n\t\t\t\t\t\tif (typeof originalUrls === 'string') return results[0];\n\t\t\t\t\t\tconst keys = Object.keys(originalUrls);\n\t\t\t\t\t\treturn keys.reduce(\n\t\t\t\t\t\t\t(result, key) => {\n\t\t\t\t\t\t\t\t(result as NgtAnyRecord)[key] = results[keys.indexOf(key)];\n\t\t\t\t\t\t\t\treturn result;\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t{} as { [key in keyof TUrl]: NgtBranchingReturn<TReturn, NgtGLTFLike, NgtGLTFLike & NgtObjectMap> },\n\t\t\t\t\t\t);\n\t\t\t\t\t});\n\t\t\t\t});\n\t\t\t}\n\t\t});\n\n\t\treturn response.asReadonly();\n\t});\n}\n\n_injectLoader.preload = <\n\tTData,\n\tTUrl extends string | string[] | Record<string, string>,\n\tTLoaderConstructor extends NgtLoaderProto<TData>,\n>(\n\tloaderConstructorFactory: (inputs: string[]) => TLoaderConstructor,\n\tinputs: () => TUrl,\n\textensions?: NgtLoaderExtensions<TLoaderConstructor>,\n) => {\n\tconst effects = load(loaderConstructorFactory, inputs, { extensions })();\n\tif (effects) {\n\t\tvoid Promise.all(effects);\n\t}\n};\n\n_injectLoader.destroy = () => {\n\tcached.clear();\n};\n\nexport type NgtInjectedLoader = typeof _injectLoader;\nexport const injectLoader: NgtInjectedLoader = _injectLoader;\n"]}
|
package/esm2022/lib/portal.mjs
CHANGED
|
@@ -1,11 +1,10 @@
|
|
|
1
1
|
import { afterNextRender, ChangeDetectionStrategy, Component, computed, contentChild, CUSTOM_ELEMENTS_SCHEMA, DestroyRef, Directive, inject, Injector, input, signal, SkipSelf, TemplateRef, untracked, viewChild, ViewContainerRef, } from '@angular/core';
|
|
2
2
|
import { injectAutoEffect } from 'ngxtension/auto-effect';
|
|
3
|
-
import { createInjectionToken } from 'ngxtension/create-injection-token';
|
|
4
3
|
import { Raycaster, Scene, Vector2, Vector3 } from 'three';
|
|
5
|
-
import { prepare } from './instance';
|
|
4
|
+
import { getLocalState, prepare } from './instance';
|
|
6
5
|
import { injectNgtRef } from './ref';
|
|
7
6
|
import { SPECIAL_INTERNAL_ADD_COMMENT } from './renderer/constants';
|
|
8
|
-
import { injectNgtStore,
|
|
7
|
+
import { injectNgtStore, provideNgtStore } from './store';
|
|
9
8
|
import { injectBeforeRender } from './utils/before-render';
|
|
10
9
|
import { is } from './utils/is';
|
|
11
10
|
import { signalStore } from './utils/signal-store';
|
|
@@ -24,21 +23,6 @@ const privateKeys = [
|
|
|
24
23
|
'size',
|
|
25
24
|
'viewport',
|
|
26
25
|
];
|
|
27
|
-
const [, providePortalStore] = createInjectionToken((parentStore) => {
|
|
28
|
-
const parentState = parentStore.snapshot;
|
|
29
|
-
const pointer = new Vector2();
|
|
30
|
-
const raycaster = new 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
26
|
export class NgtPortalBeforeRender {
|
|
43
27
|
constructor() {
|
|
44
28
|
this.portalStore = injectNgtStore();
|
|
@@ -95,11 +79,11 @@ export class NgtPortalContent {
|
|
|
95
79
|
}
|
|
96
80
|
}
|
|
97
81
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.3", 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.3", type: NgtPortalContent, isStandalone: true, selector: "ng-template[
|
|
82
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.0.3", type: NgtPortalContent, isStandalone: true, selector: "ng-template[portalContent]", ngImport: i0 }); }
|
|
99
83
|
}
|
|
100
84
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: NgtPortalContent, decorators: [{
|
|
101
85
|
type: Directive,
|
|
102
|
-
args: [{ selector: 'ng-template[
|
|
86
|
+
args: [{ selector: 'ng-template[portalContent]', standalone: true }]
|
|
103
87
|
}], ctorParameters: () => [{ type: i0.ViewContainerRef }, { type: i0.ViewContainerRef, decorators: [{
|
|
104
88
|
type: SkipSelf
|
|
105
89
|
}] }] });
|
|
@@ -120,14 +104,39 @@ export class NgtPortal {
|
|
|
120
104
|
this.renderAutoBeforeRender = computed(() => this.portalRendered() && this.autoRender());
|
|
121
105
|
this.parentScene = this.parentStore.get('scene');
|
|
122
106
|
this.parentCamera = this.parentStore.get('camera');
|
|
107
|
+
this.raycaster = new Raycaster();
|
|
108
|
+
this.pointer = new Vector2();
|
|
123
109
|
afterNextRender(() => {
|
|
124
110
|
const parentState = this.parentStore.snapshot;
|
|
125
|
-
const [
|
|
111
|
+
const [containerRef, state, autoRender, autoRenderPriority] = [
|
|
112
|
+
this.container(),
|
|
113
|
+
this.state(),
|
|
114
|
+
this.autoRender(),
|
|
115
|
+
this.autoRenderPriority(),
|
|
116
|
+
];
|
|
117
|
+
let stateFromInput = state;
|
|
118
|
+
if (!stateFromInput && autoRender) {
|
|
119
|
+
stateFromInput = { events: { priority: autoRenderPriority + 1 } };
|
|
120
|
+
}
|
|
121
|
+
const { events = {}, size = {}, ...rest } = stateFromInput || {};
|
|
122
|
+
let container = is.ref(containerRef) ? containerRef.nativeElement : containerRef;
|
|
123
|
+
if (!is.instance(container)) {
|
|
124
|
+
container = prepare(container);
|
|
125
|
+
}
|
|
126
|
+
const localState = getLocalState(container);
|
|
127
|
+
if (localState && !localState.store) {
|
|
128
|
+
localState.store = this.portalStore;
|
|
129
|
+
}
|
|
126
130
|
this.portalStore.update({
|
|
127
|
-
|
|
131
|
+
...parentState,
|
|
132
|
+
scene: container,
|
|
133
|
+
raycaster: this.raycaster,
|
|
134
|
+
pointer: this.pointer,
|
|
135
|
+
previousRoot: this.parentStore,
|
|
128
136
|
events: { ...parentState.events, ...events },
|
|
129
137
|
size: { ...parentState.size, ...size },
|
|
130
138
|
...rest,
|
|
139
|
+
setEvents: (events) => this.portalStore.update((state) => ({ ...state, events: { ...state.events, ...events } })),
|
|
131
140
|
});
|
|
132
141
|
this.autoEffect(() => {
|
|
133
142
|
const previous = this.parentStore.state();
|
|
@@ -136,7 +145,10 @@ export class NgtPortal {
|
|
|
136
145
|
untracked(() => {
|
|
137
146
|
const portalView = this.portalContentAnchor().createEmbeddedView(this.portalContentTemplate());
|
|
138
147
|
portalView.detectChanges();
|
|
139
|
-
this.destroyRef.onDestroy(
|
|
148
|
+
this.destroyRef.onDestroy(() => {
|
|
149
|
+
portalView.destroy();
|
|
150
|
+
console.log(this.portalStore.snapshot);
|
|
151
|
+
});
|
|
140
152
|
});
|
|
141
153
|
this.portalRendered.set(true);
|
|
142
154
|
});
|
|
@@ -169,7 +181,7 @@ export class NgtPortal {
|
|
|
169
181
|
};
|
|
170
182
|
}
|
|
171
183
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: NgtPortal, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
172
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.3", type: NgtPortal, isStandalone: true, selector: "ngt-portal", inputs: { container: { classPropertyName: "container", publicName: "container", isSignal: true, isRequired: false, transformFunction: null }, camera: { classPropertyName: "camera", publicName: "camera", isSignal: true, isRequired: false, transformFunction: null }, state: { classPropertyName: "state", publicName: "state", 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: [
|
|
184
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.3", type: NgtPortal, isStandalone: true, selector: "ngt-portal", inputs: { container: { classPropertyName: "container", publicName: "container", isSignal: true, isRequired: false, transformFunction: null }, camera: { classPropertyName: "camera", publicName: "camera", isSignal: true, isRequired: false, transformFunction: null }, state: { classPropertyName: "state", publicName: "state", 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: [provideNgtStore(signalStore({}))], 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: `
|
|
173
185
|
<ng-container #portalContentAnchor>
|
|
174
186
|
@if (renderAutoBeforeRender()) {
|
|
175
187
|
<ngt-portal-before-render
|
|
@@ -198,8 +210,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImpor
|
|
|
198
210
|
</ng-container>
|
|
199
211
|
`,
|
|
200
212
|
imports: [NgtPortalBeforeRender],
|
|
201
|
-
providers: [
|
|
213
|
+
providers: [provideNgtStore(signalStore({}))],
|
|
202
214
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
203
215
|
}]
|
|
204
216
|
}], ctorParameters: () => [] });
|
|
205
|
-
//# 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 { Camera, Object3D, Raycaster, Scene, Vector2, Vector3 } from 'three';\nimport { NgtEventManager } from './events';\nimport { prepare } from './instance';\nimport { injectNgtRef } from './ref';\nimport { SPECIAL_INTERNAL_ADD_COMMENT } from './renderer/constants';\nimport { injectNgtStore, NGT_STORE, NgtSize, NgtState } from './store';\nimport { injectBeforeRender } from './utils/before-render';\nimport { is } from './utils/is';\nimport { NgtSignalStore, signalStore } 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<Object3D> | Object3D;\n\tcamera: ElementRef<Camera> | 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 Vector2();\n\t\tconst raycaster = new 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<Scene>();\n\tparentCamera = input.required<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\tcontainer = input<ElementRef<Object3D> | Object3D>(injectNgtRef(prepare(new Scene())));\n\tcamera = input<ElementRef<Camera> | Camera>();\n\tstate = input<\n\t\tPartial<\n\t\t\tOmit<NgtState, PrivateKeys> & {\n\t\t\t\tevents: Partial<Pick<NgtEventManager<any>, 'enabled' | 'priority' | 'compute' | 'connected'>>;\n\t\t\t\tsize: NgtSize;\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, { events = {}, size = {}, ...rest } = {}] = [this.container(), this.state()];\n\n\t\t\tthis.portalStore.update({\n\t\t\t\tscene: (is.ref(container) ? container.nativeElement : container) as 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 container = untracked(this.container);\n\t\tconst { size, events, ...restInputsState } = untracked(this.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 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(container) ? container.nativeElement : 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"]}
|
|
217
|
+
//# 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 { Camera, Object3D, Raycaster, Scene, Vector2, Vector3 } from 'three';\nimport { NgtEventManager } from './events';\nimport { getLocalState, prepare } from './instance';\nimport { injectNgtRef } from './ref';\nimport { SPECIAL_INTERNAL_ADD_COMMENT } from './renderer/constants';\nimport { injectNgtStore, NgtSize, NgtState, provideNgtStore } from './store';\nimport { injectBeforeRender } from './utils/before-render';\nimport { is } from './utils/is';\nimport { signalStore } 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<Object3D> | Object3D;\n\tcamera: ElementRef<Camera> | 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\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<Scene>();\n\tparentCamera = input.required<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[portalContent]', 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: [provideNgtStore(signalStore<NgtState>({}))],\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class NgtPortal {\n\tcontainer = input<ElementRef<Object3D> | Object3D>(injectNgtRef(prepare(new Scene())));\n\tcamera = input<ElementRef<Camera> | Camera>();\n\tstate = input<\n\t\tPartial<\n\t\t\tOmit<NgtState, PrivateKeys> & {\n\t\t\t\tevents: Partial<Pick<NgtEventManager<any>, 'enabled' | 'priority' | 'compute' | 'connected'>>;\n\t\t\t\tsize: NgtSize;\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\tprivate raycaster = new Raycaster();\n\tprivate pointer = new Vector2();\n\n\tconstructor() {\n\t\tafterNextRender(() => {\n\t\t\tconst parentState = this.parentStore.snapshot;\n\t\t\tconst [containerRef, state, autoRender, autoRenderPriority] = [\n\t\t\t\tthis.container(),\n\t\t\t\tthis.state(),\n\t\t\t\tthis.autoRender(),\n\t\t\t\tthis.autoRenderPriority(),\n\t\t\t];\n\n\t\t\tlet stateFromInput = state;\n\n\t\t\tif (!stateFromInput && autoRender) {\n\t\t\t\tstateFromInput = { events: { priority: autoRenderPriority + 1 } };\n\t\t\t}\n\n\t\t\tconst { events = {}, size = {}, ...rest } = stateFromInput || {};\n\t\t\tlet container = is.ref(containerRef) ? containerRef.nativeElement : containerRef;\n\n\t\t\tif (!is.instance(container)) {\n\t\t\t\tcontainer = prepare(container);\n\t\t\t}\n\n\t\t\tconst localState = getLocalState(container);\n\t\t\tif (localState && !localState.store) {\n\t\t\t\tlocalState.store = this.portalStore;\n\t\t\t}\n\n\t\t\tthis.portalStore.update({\n\t\t\t\t...parentState,\n\t\t\t\tscene: container as Scene,\n\t\t\t\traycaster: this.raycaster,\n\t\t\t\tpointer: this.pointer,\n\t\t\t\tpreviousRoot: this.parentStore,\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\tsetEvents: (events) =>\n\t\t\t\t\tthis.portalStore.update((state) => ({ ...state, events: { ...state.events, ...events } })),\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(() => {\n\t\t\t\t\tportalView.destroy();\n\t\t\t\t\tconsole.log(this.portalStore.snapshot);\n\t\t\t\t});\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 container = untracked(this.container);\n\t\tconst { size, events, ...restInputsState } = untracked(this.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 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(container) ? container.nativeElement : 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"]}
|