angular-three 2.0.0-beta.4 → 2.0.0-beta.41
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +4 -147
- package/esm2022/angular-three.mjs +1 -1
- package/esm2022/index.mjs +10 -11
- package/esm2022/lib/before-render.mjs +13 -0
- package/esm2022/lib/canvas.mjs +137 -161
- package/esm2022/lib/directives/args.mjs +13 -11
- package/esm2022/lib/directives/common.mjs +28 -27
- package/esm2022/lib/directives/key.mjs +29 -0
- package/esm2022/lib/directives/parent.mjs +13 -11
- package/esm2022/lib/dom/events.mjs +6 -1
- package/esm2022/lib/events.mjs +77 -60
- package/esm2022/lib/instance.mjs +65 -0
- package/esm2022/lib/loader.mjs +35 -41
- package/esm2022/lib/loop.mjs +6 -3
- package/esm2022/lib/portal.mjs +103 -112
- package/esm2022/lib/ref.mjs +48 -0
- package/esm2022/lib/renderer/catalogue.mjs +7 -0
- package/esm2022/lib/renderer/constants.mjs +21 -0
- package/esm2022/lib/renderer/index.mjs +419 -0
- package/esm2022/lib/renderer/store.mjs +148 -112
- package/esm2022/lib/renderer/utils.mjs +63 -48
- package/esm2022/lib/roots.mjs +249 -0
- package/esm2022/lib/routed-scene.mjs +11 -8
- package/esm2022/lib/store.mjs +207 -0
- package/esm2022/lib/three-types.mjs +2 -2
- package/esm2022/lib/types.mjs +1 -1
- package/esm2022/lib/utils/apply-props.mjs +23 -11
- package/esm2022/lib/utils/attach.mjs +2 -2
- package/esm2022/lib/utils/is.mjs +1 -1
- package/esm2022/lib/utils/make.mjs +1 -1
- package/esm2022/lib/utils/safe-detect-changes.mjs +15 -13
- package/esm2022/lib/utils/signal-store.mjs +99 -0
- package/esm2022/lib/utils/update.mjs +1 -1
- package/fesm2022/angular-three.mjs +2014 -1882
- package/fesm2022/angular-three.mjs.map +1 -1
- package/index.d.ts +9 -10
- package/lib/{di/before-render.d.ts → before-render.d.ts} +1 -1
- package/lib/canvas.d.ts +82 -12
- package/lib/directives/args.d.ts +2 -2
- package/lib/directives/common.d.ts +5 -1
- package/lib/directives/key.d.ts +10 -0
- package/lib/directives/parent.d.ts +5 -5
- package/lib/dom/events.d.ts +3 -2
- package/lib/events.d.ts +78 -2
- package/lib/instance.d.ts +36 -0
- package/lib/loader.d.ts +21 -3
- package/lib/loop.d.ts +68 -6
- package/lib/portal.d.ts +21 -12
- package/lib/{di/ref.d.ts → ref.d.ts} +3 -2
- package/lib/renderer/catalogue.d.ts +13 -0
- package/lib/renderer/constants.d.ts +20 -0
- package/lib/renderer/index.d.ts +5 -0
- package/lib/renderer/store.d.ts +21 -15
- package/lib/renderer/utils.d.ts +29 -19
- package/lib/roots.d.ts +11 -0
- package/lib/routed-scene.d.ts +1 -1
- package/lib/store.d.ts +147 -0
- package/lib/three-types.d.ts +5 -5
- package/lib/types.d.ts +1 -309
- package/lib/utils/apply-props.d.ts +4 -2
- package/lib/utils/attach.d.ts +5 -3
- package/lib/utils/is.d.ts +5 -4
- package/lib/utils/make.d.ts +12 -1
- package/lib/utils/safe-detect-changes.d.ts +2 -2
- package/lib/utils/signal-store.d.ts +17 -0
- package/lib/utils/update.d.ts +1 -1
- package/metadata.json +1 -1
- package/package.json +24 -5
- package/plugin/generators.json +57 -17
- package/plugin/migrations.json +27 -0
- package/plugin/package.json +22 -4
- package/plugin/src/generators/init/compat.d.ts +3 -1
- package/plugin/src/generators/init/compat.js +2 -2
- package/plugin/src/generators/init/compat.js.map +1 -1
- package/plugin/src/generators/init/files/experience/experience.component.html__tmpl__ +4 -0
- package/plugin/src/generators/init/files/experience/experience.component.ts__tmpl__ +18 -0
- package/plugin/src/generators/init/generator.d.ts +6 -0
- package/plugin/src/generators/init/generator.js +160 -0
- package/plugin/src/generators/init/generator.js.map +1 -0
- package/plugin/src/generators/init/schema.json +15 -4
- package/plugin/src/generators/init-cannon/compat.d.ts +2 -0
- package/plugin/src/generators/init-cannon/compat.js +6 -0
- package/plugin/src/generators/init-cannon/compat.js.map +1 -0
- package/plugin/src/generators/init-cannon/generator.d.ts +2 -0
- package/plugin/src/generators/init-cannon/generator.js +23 -0
- package/plugin/src/generators/init-cannon/generator.js.map +1 -0
- package/plugin/src/generators/init-cannon/schema.json +6 -0
- package/plugin/src/generators/init-postprocessing/compat.d.ts +2 -0
- package/plugin/src/generators/init-postprocessing/compat.js +6 -0
- package/plugin/src/generators/init-postprocessing/compat.js.map +1 -0
- package/plugin/src/generators/init-postprocessing/generator.d.ts +2 -0
- package/plugin/src/generators/init-postprocessing/generator.js +21 -0
- package/plugin/src/generators/init-postprocessing/generator.js.map +1 -0
- package/plugin/src/generators/init-postprocessing/schema.json +6 -0
- package/plugin/src/generators/init-rapier/compat.d.ts +2 -0
- package/plugin/src/generators/init-rapier/compat.js +6 -0
- package/plugin/src/generators/init-rapier/compat.js.map +1 -0
- package/plugin/src/generators/init-rapier/generator.d.ts +2 -0
- package/plugin/src/generators/init-rapier/generator.js +22 -0
- package/plugin/src/generators/init-rapier/generator.js.map +1 -0
- package/plugin/src/generators/init-rapier/schema.json +6 -0
- package/plugin/src/generators/init-soba/compat.d.ts +2 -0
- package/plugin/src/generators/init-soba/compat.js +6 -0
- package/plugin/src/generators/init-soba/compat.js.map +1 -0
- package/plugin/src/generators/init-soba/generator.d.ts +2 -0
- package/plugin/src/generators/init-soba/generator.js +27 -0
- package/plugin/src/generators/init-soba/generator.js.map +1 -0
- package/plugin/src/generators/init-soba/schema.json +6 -0
- package/plugin/src/generators/utils.d.ts +2 -0
- package/plugin/src/generators/utils.js +34 -0
- package/plugin/src/generators/utils.js.map +1 -0
- package/plugin/src/generators/versions.d.ts +14 -0
- package/plugin/src/generators/versions.js +18 -0
- package/plugin/src/generators/versions.js.map +1 -0
- package/plugin/src/index.d.ts +5 -1
- package/plugin/src/index.js +11 -3
- package/plugin/src/index.js.map +1 -1
- package/plugin/src/migrations/migrate-to-ngxtension/compat.d.ts +2 -0
- package/plugin/src/migrations/migrate-to-ngxtension/compat.js +6 -0
- package/plugin/src/migrations/migrate-to-ngxtension/compat.js.map +1 -0
- package/plugin/src/migrations/migrate-to-ngxtension/migrate-to-ngxtension.d.ts +2 -0
- package/plugin/src/migrations/migrate-to-ngxtension/migrate-to-ngxtension.js +55 -0
- package/plugin/src/migrations/migrate-to-ngxtension/migrate-to-ngxtension.js.map +1 -0
- package/web-types.json +1 -1
- package/esm2022/lib/di/before-render.mjs +0 -13
- package/esm2022/lib/di/catalogue.mjs +0 -7
- package/esm2022/lib/di/ref.mjs +0 -49
- package/esm2022/lib/directives/repeat.mjs +0 -18
- package/esm2022/lib/renderer/di.mjs +0 -3
- package/esm2022/lib/renderer/enums.mjs +0 -2
- package/esm2022/lib/renderer/provider.mjs +0 -18
- package/esm2022/lib/renderer/renderer.mjs +0 -368
- package/esm2022/lib/stores/signal.store.mjs +0 -79
- package/esm2022/lib/stores/store.mjs +0 -420
- package/esm2022/lib/utils/assert-in-injection-context.mjs +0 -14
- package/esm2022/lib/utils/instance.mjs +0 -63
- package/esm2022/lib/utils/signal.mjs +0 -24
- package/esm2022/lib/utils/timing.mjs +0 -21
- package/lib/di/catalogue.d.ts +0 -3
- package/lib/directives/repeat.d.ts +0 -7
- package/lib/renderer/di.d.ts +0 -2
- package/lib/renderer/enums.d.ts +0 -26
- package/lib/renderer/provider.d.ts +0 -8
- package/lib/renderer/renderer.d.ts +0 -49
- package/lib/stores/signal.store.d.ts +0 -21
- package/lib/stores/store.d.ts +0 -13
- package/lib/utils/assert-in-injection-context.d.ts +0 -2
- package/lib/utils/instance.d.ts +0 -4
- package/lib/utils/signal.d.ts +0 -2
- package/lib/utils/timing.d.ts +0 -4
- package/plugin/src/generators/init/init.d.ts +0 -5
- package/plugin/src/generators/init/init.js +0 -56
- package/plugin/src/generators/init/init.js.map +0 -1
|
@@ -1,79 +0,0 @@
|
|
|
1
|
-
import { Inject, Injectable, Optional, computed, untracked, } from '@angular/core';
|
|
2
|
-
import { createSignal } from '../utils/signal';
|
|
3
|
-
import * as i0 from "@angular/core";
|
|
4
|
-
const STORE_COMPUTED_KEY = '__ngt_store_computed__';
|
|
5
|
-
class NgtSignalStore {
|
|
6
|
-
#state;
|
|
7
|
-
#computedCache = new Map();
|
|
8
|
-
constructor(initialState = {}) {
|
|
9
|
-
initialState ??= {};
|
|
10
|
-
this.#state = createSignal(Object.assign(initialState, { __ngt_dummy_state__: Date.now() }));
|
|
11
|
-
this.state = this.#state.asReadonly();
|
|
12
|
-
}
|
|
13
|
-
select(...keysAndOptions) {
|
|
14
|
-
if (keysAndOptions.length === 0)
|
|
15
|
-
return this.state;
|
|
16
|
-
if (keysAndOptions.length === 1 && typeof keysAndOptions[0] === 'object') {
|
|
17
|
-
if (!this.#computedCache.has(STORE_COMPUTED_KEY)) {
|
|
18
|
-
this.#computedCache.set(STORE_COMPUTED_KEY, computed(this.state, keysAndOptions));
|
|
19
|
-
return this.#computedCache.get(STORE_COMPUTED_KEY);
|
|
20
|
-
}
|
|
21
|
-
}
|
|
22
|
-
const [keys, options] = parseOptions(keysAndOptions);
|
|
23
|
-
const joinedKeys = keys.join('-');
|
|
24
|
-
if (!this.#computedCache.has(joinedKeys)) {
|
|
25
|
-
this.#computedCache.set(joinedKeys, computed(() => keys.reduce((value, key) => value[key], this.state()), options));
|
|
26
|
-
}
|
|
27
|
-
return this.#computedCache.get(joinedKeys);
|
|
28
|
-
}
|
|
29
|
-
get(...keys) {
|
|
30
|
-
const state = untracked(this.state);
|
|
31
|
-
if (keys.length === 0)
|
|
32
|
-
return state;
|
|
33
|
-
return keys.reduce((value, key) => value[key], state);
|
|
34
|
-
}
|
|
35
|
-
set(state) {
|
|
36
|
-
const updater = (previous) => {
|
|
37
|
-
const partial = typeof state === 'function' ? state(previous) : state;
|
|
38
|
-
Object.keys(partial).forEach((key) => {
|
|
39
|
-
const partialKey = key;
|
|
40
|
-
if (partial[partialKey] === undefined && previous[partialKey] != null) {
|
|
41
|
-
partial[partialKey] = previous[partialKey];
|
|
42
|
-
}
|
|
43
|
-
});
|
|
44
|
-
return partial;
|
|
45
|
-
};
|
|
46
|
-
this.#state.update((previous) => ({ ...previous, ...updater(previous) }));
|
|
47
|
-
// this.#state.update(previous => ({...previous, ...(typeof state === 'function' ? state(previous) : state)}))
|
|
48
|
-
}
|
|
49
|
-
patch(state) {
|
|
50
|
-
const updater = (previous) => {
|
|
51
|
-
Object.keys(state).forEach((key) => {
|
|
52
|
-
const partialKey = key;
|
|
53
|
-
if (state[partialKey] === undefined && previous[partialKey] != null) {
|
|
54
|
-
state[partialKey] = previous[partialKey];
|
|
55
|
-
}
|
|
56
|
-
});
|
|
57
|
-
return state;
|
|
58
|
-
};
|
|
59
|
-
this.#state.update((previous) => ({ ...updater(previous), ...previous }));
|
|
60
|
-
}
|
|
61
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NgtSignalStore, deps: [{ token: 'INITIAL_STATE', optional: true }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
62
|
-
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NgtSignalStore }); }
|
|
63
|
-
}
|
|
64
|
-
export { NgtSignalStore };
|
|
65
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NgtSignalStore, decorators: [{
|
|
66
|
-
type: Injectable
|
|
67
|
-
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
68
|
-
type: Optional
|
|
69
|
-
}, {
|
|
70
|
-
type: Inject,
|
|
71
|
-
args: ['INITIAL_STATE']
|
|
72
|
-
}] }]; } });
|
|
73
|
-
function parseOptions(keysAndOptions) {
|
|
74
|
-
if (typeof keysAndOptions.at(-1) === 'object') {
|
|
75
|
-
return [keysAndOptions.slice(0, -1), keysAndOptions.at(-1)];
|
|
76
|
-
}
|
|
77
|
-
return [keysAndOptions];
|
|
78
|
-
}
|
|
79
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"signal.store.js","sourceRoot":"","sources":["../../../../../../libs/angular-three/src/lib/stores/signal.store.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    Inject,\n    Injectable,\n    Optional,\n    computed,\n    untracked,\n    type CreateComputedOptions,\n    type Signal,\n    type WritableSignal,\n} from '@angular/core';\nimport type { NgtAnyRecord } from '../types';\nimport { createSignal } from '../utils/signal';\n\nconst STORE_COMPUTED_KEY = '__ngt_store_computed__' as const;\n\n@Injectable()\nexport class NgtSignalStore<TState extends object> {\n    readonly #state: WritableSignal<TState>;\n    readonly #computedCache = new Map();\n    readonly state: Signal<TState>;\n\n    constructor(\n        @Optional()\n        @Inject('INITIAL_STATE')\n        initialState: Partial<TState> = {} as unknown as Partial<TState>\n    ) {\n        initialState ??= {};\n        this.#state = createSignal(Object.assign(initialState, { __ngt_dummy_state__: Date.now() }) as TState);\n        this.state = this.#state.asReadonly();\n    }\n\n    select<\n        TKey1 extends keyof TState,\n        TKey2 extends keyof TState[TKey1],\n        TKey3 extends keyof TState[TKey1][TKey2],\n        TKey4 extends keyof TState[TKey1][TKey2][TKey3]\n    >(\n        key1: TKey1,\n        key2: TKey2,\n        key3: TKey3,\n        key4: TKey4,\n        options?: CreateComputedOptions<TState[TKey1][TKey2][TKey3][TKey4]>\n    ): Signal<TState[TKey1][TKey2][TKey3][TKey4]>;\n    select<TKey1 extends keyof TState, TKey2 extends keyof TState[TKey1], TKey3 extends keyof TState[TKey1][TKey2]>(\n        key1: TKey1,\n        key2: TKey2,\n        key3: TKey3,\n        options?: CreateComputedOptions<TState[TKey1][TKey2][TKey3]>\n    ): Signal<TState[TKey1][TKey2][TKey3]>;\n    select<TKey1 extends keyof TState, TKey2 extends keyof TState[TKey1]>(\n        key1: TKey1,\n        key2: TKey2,\n        options?: CreateComputedOptions<TState[TKey1][TKey2]>\n    ): Signal<TState[TKey1][TKey2]>;\n    select<TKey extends keyof TState>(key: TKey, options?: CreateComputedOptions<TState[TKey]>): Signal<TState[TKey]>;\n    select(options?: CreateComputedOptions<TState>): Signal<TState>;\n    select(...keysAndOptions: any[]) {\n        if (keysAndOptions.length === 0) return this.state;\n        if (keysAndOptions.length === 1 && typeof keysAndOptions[0] === 'object') {\n            if (!this.#computedCache.has(STORE_COMPUTED_KEY)) {\n                this.#computedCache.set(\n                    STORE_COMPUTED_KEY,\n                    computed(this.state, keysAndOptions as CreateComputedOptions<TState>)\n                );\n                return this.#computedCache.get(STORE_COMPUTED_KEY)!;\n            }\n        }\n        const [keys, options] = parseOptions(keysAndOptions);\n\n        const joinedKeys = keys.join('-');\n\n        if (!this.#computedCache.has(joinedKeys)) {\n            this.#computedCache.set(\n                joinedKeys,\n                computed(() => keys.reduce((value, key) => (value as NgtAnyRecord)[key], this.state()), options)\n            );\n        }\n\n        return this.#computedCache.get(joinedKeys)!;\n    }\n\n    get<\n        TKey1 extends keyof TState,\n        TKey2 extends keyof TState[TKey1],\n        TKey3 extends keyof TState[TKey1][TKey2],\n        TKey4 extends keyof TState[TKey1][TKey2][TKey3]\n    >(key1: TKey1, key2: TKey2, key3: TKey3, key4: TKey4): TState[TKey1][TKey2][TKey3][TKey4];\n    get<TKey1 extends keyof TState, TKey2 extends keyof TState[TKey1], TKey3 extends keyof TState[TKey1][TKey2]>(\n        key1: TKey1,\n        key2: TKey2,\n        key3: TKey3\n    ): TState[TKey1][TKey2][TKey3];\n    get<TKey1 extends keyof TState, TKey2 extends keyof TState[TKey1]>(key1: TKey1, key2: TKey2): TState[TKey1][TKey2];\n    get<TKey extends keyof TState>(key: TKey): TState[TKey];\n    get(): TState;\n    get(...keys: string[]) {\n        const state = untracked(this.state);\n        if (keys.length === 0) return state;\n        return keys.reduce((value, key) => (value as NgtAnyRecord)[key], state);\n    }\n\n    set(state: Partial<TState> | ((previous: TState) => Partial<TState>)) {\n        const updater = (previous: TState) => {\n            const partial = typeof state === 'function' ? state(previous) : state;\n            Object.keys(partial).forEach((key) => {\n                const partialKey = key as keyof TState;\n                if (partial[partialKey] === undefined && previous[partialKey] != null) {\n                    partial[partialKey] = previous[partialKey];\n                }\n            });\n            return partial;\n        };\n        this.#state.update((previous) => ({ ...previous, ...updater(previous) }));\n        // this.#state.update(previous => ({...previous, ...(typeof state === 'function' ? state(previous) : state)}))\n    }\n\n    patch(state: Partial<TState>) {\n        const updater = (previous: TState) => {\n            Object.keys(state).forEach((key) => {\n                const partialKey = key as keyof TState;\n                if (state[partialKey] === undefined && previous[partialKey] != null) {\n                    state[partialKey] = previous[partialKey];\n                }\n            });\n            return state;\n        };\n        this.#state.update((previous) => ({ ...updater(previous), ...previous }));\n    }\n}\n\nfunction parseOptions(keysAndOptions: any[]): [string[], CreateComputedOptions<any>?] {\n    if (typeof keysAndOptions.at(-1) === 'object') {\n        return [keysAndOptions.slice(0, -1), keysAndOptions.at(-1)];\n    }\n\n    return [keysAndOptions];\n}\n"]}
|
|
@@ -1,420 +0,0 @@
|
|
|
1
|
-
import { DOCUMENT } from '@angular/common';
|
|
2
|
-
import { ElementRef, Injectable, Injector, computed, effect, inject } from '@angular/core';
|
|
3
|
-
import * as THREE from 'three';
|
|
4
|
-
import { createLoop } from '../loop';
|
|
5
|
-
import { applyProps } from '../utils/apply-props';
|
|
6
|
-
import { prepare } from '../utils/instance';
|
|
7
|
-
import { is } from '../utils/is';
|
|
8
|
-
import { makeDefaultCamera, makeDefaultRenderer, makeDpr } from '../utils/make';
|
|
9
|
-
import { checkNeedsUpdate, updateCamera } from '../utils/update';
|
|
10
|
-
import { NgtSignalStore } from './signal.store';
|
|
11
|
-
import * as i0 from "@angular/core";
|
|
12
|
-
export const rootStateMap = new Map();
|
|
13
|
-
const { invalidate, advance } = createLoop(rootStateMap);
|
|
14
|
-
const shallowLoose = { objects: 'shallow', strict: false };
|
|
15
|
-
class NgtStore extends NgtSignalStore {
|
|
16
|
-
constructor() {
|
|
17
|
-
super(...arguments);
|
|
18
|
-
this.#parentStore = inject(NgtStore, { optional: true, skipSelf: true });
|
|
19
|
-
this.#window = inject(DOCUMENT).defaultView;
|
|
20
|
-
this.#injector = inject(Injector);
|
|
21
|
-
this.isInit = false;
|
|
22
|
-
}
|
|
23
|
-
#parentStore;
|
|
24
|
-
#window;
|
|
25
|
-
#injector;
|
|
26
|
-
init() {
|
|
27
|
-
if (!this.isInit) {
|
|
28
|
-
const position = new THREE.Vector3();
|
|
29
|
-
const defaultTarget = new THREE.Vector3();
|
|
30
|
-
const tempTarget = new THREE.Vector3();
|
|
31
|
-
const getCurrentViewport = (camera = this.get('camera'), target = defaultTarget, size = this.get('size')) => {
|
|
32
|
-
const { width, height, top, left } = size;
|
|
33
|
-
const aspect = width / height;
|
|
34
|
-
if (target instanceof THREE.Vector3)
|
|
35
|
-
tempTarget.copy(target);
|
|
36
|
-
else
|
|
37
|
-
tempTarget.set(...target);
|
|
38
|
-
const distance = camera.getWorldPosition(position).distanceTo(tempTarget);
|
|
39
|
-
if (is.orthographicCamera(camera)) {
|
|
40
|
-
return {
|
|
41
|
-
width: width / camera.zoom,
|
|
42
|
-
height: height / camera.zoom,
|
|
43
|
-
top,
|
|
44
|
-
left,
|
|
45
|
-
factor: 1,
|
|
46
|
-
distance,
|
|
47
|
-
aspect,
|
|
48
|
-
};
|
|
49
|
-
}
|
|
50
|
-
const fov = (camera.fov * Math.PI) / 180; // convert vertical fov to radians
|
|
51
|
-
const h = 2 * Math.tan(fov / 2) * distance; // visible height
|
|
52
|
-
const w = h * aspect;
|
|
53
|
-
return { width: w, height: h, top, left, factor: width / w, distance, aspect };
|
|
54
|
-
};
|
|
55
|
-
let performanceTimeout;
|
|
56
|
-
const setPerformanceCurrent = (current) => {
|
|
57
|
-
this.set((state) => ({ performance: { ...state.performance, current } }));
|
|
58
|
-
};
|
|
59
|
-
this.set({
|
|
60
|
-
get: this.get.bind(this),
|
|
61
|
-
set: this.set.bind(this),
|
|
62
|
-
ready: false,
|
|
63
|
-
events: { priority: 1, enabled: true, connected: false },
|
|
64
|
-
invalidate: (frames = 1) => invalidate(this, frames),
|
|
65
|
-
advance: (timestamp, runGlobalEffects) => advance(timestamp, runGlobalEffects, this),
|
|
66
|
-
legacy: false,
|
|
67
|
-
linear: false,
|
|
68
|
-
flat: false,
|
|
69
|
-
controls: null,
|
|
70
|
-
clock: new THREE.Clock(),
|
|
71
|
-
pointer: new THREE.Vector2(),
|
|
72
|
-
frameloop: 'always',
|
|
73
|
-
performance: {
|
|
74
|
-
current: 1,
|
|
75
|
-
min: 0.5,
|
|
76
|
-
max: 1,
|
|
77
|
-
debounce: 200,
|
|
78
|
-
regress: () => {
|
|
79
|
-
const state = this.get();
|
|
80
|
-
// clear timeout
|
|
81
|
-
if (performanceTimeout)
|
|
82
|
-
clearTimeout(performanceTimeout);
|
|
83
|
-
// set lower bound
|
|
84
|
-
if (state.performance.current !== state.performance.min)
|
|
85
|
-
setPerformanceCurrent(state.performance.min);
|
|
86
|
-
// go back to upper bound
|
|
87
|
-
performanceTimeout = setTimeout(() => {
|
|
88
|
-
setPerformanceCurrent(this.get('performance', 'max') || 1);
|
|
89
|
-
}, state.performance.debounce);
|
|
90
|
-
},
|
|
91
|
-
},
|
|
92
|
-
size: { width: 0, height: 0, top: 0, left: 0 },
|
|
93
|
-
viewport: {
|
|
94
|
-
initialDpr: 0,
|
|
95
|
-
dpr: 0,
|
|
96
|
-
width: 0,
|
|
97
|
-
height: 0,
|
|
98
|
-
top: 0,
|
|
99
|
-
left: 0,
|
|
100
|
-
aspect: 0,
|
|
101
|
-
distance: 0,
|
|
102
|
-
factor: 0,
|
|
103
|
-
getCurrentViewport,
|
|
104
|
-
},
|
|
105
|
-
previousStore: this.#parentStore,
|
|
106
|
-
internal: {
|
|
107
|
-
active: false,
|
|
108
|
-
priority: 0,
|
|
109
|
-
frames: 0,
|
|
110
|
-
lastEvent: new ElementRef(null),
|
|
111
|
-
interaction: [],
|
|
112
|
-
hovered: new Map(),
|
|
113
|
-
subscribers: [],
|
|
114
|
-
initialClick: [0, 0],
|
|
115
|
-
initialHits: [],
|
|
116
|
-
capturedMap: new Map(),
|
|
117
|
-
subscribe: (callback, priority = 0, store = this) => {
|
|
118
|
-
const internal = this.get('internal');
|
|
119
|
-
// If this subscription was given a priority, it takes rendering into its own hands
|
|
120
|
-
// For that reason we switch off automatic rendering and increase the manual flag
|
|
121
|
-
// As long as this flag is positive there can be no internal rendering at all
|
|
122
|
-
// because there could be multiple render subscriptions
|
|
123
|
-
internal.priority = internal.priority + (priority > 0 ? 1 : 0);
|
|
124
|
-
internal.subscribers.push({ priority, store, callback });
|
|
125
|
-
// Register subscriber and sort layers from lowest to highest, meaning,
|
|
126
|
-
// highest priority renders last (on top of the other frames)
|
|
127
|
-
internal.subscribers.sort((a, b) => (a.priority || 0) - (b.priority || 0));
|
|
128
|
-
return () => {
|
|
129
|
-
const internal = this.get('internal');
|
|
130
|
-
if (internal?.subscribers) {
|
|
131
|
-
// Decrease manual flag if this subscription had a priority
|
|
132
|
-
internal.priority = internal.priority - (priority > 0 ? 1 : 0);
|
|
133
|
-
// Remove subscriber from list
|
|
134
|
-
internal.subscribers = internal.subscribers.filter((s) => s.callback !== callback);
|
|
135
|
-
}
|
|
136
|
-
};
|
|
137
|
-
},
|
|
138
|
-
},
|
|
139
|
-
setEvents: (events) => {
|
|
140
|
-
this.set((state) => ({ events: { ...state.events, ...events } }));
|
|
141
|
-
},
|
|
142
|
-
setSize: (width, height, top, left) => {
|
|
143
|
-
const camera = this.get('camera');
|
|
144
|
-
const size = { width, height, top: top || 0, left: left || 0 };
|
|
145
|
-
this.set((state) => ({
|
|
146
|
-
size,
|
|
147
|
-
viewport: { ...state.viewport, ...getCurrentViewport(camera, defaultTarget, size) },
|
|
148
|
-
}));
|
|
149
|
-
},
|
|
150
|
-
setDpr: (dpr) => {
|
|
151
|
-
const resolved = makeDpr(dpr, this.#window);
|
|
152
|
-
this.set((state) => ({
|
|
153
|
-
viewport: {
|
|
154
|
-
...state.viewport,
|
|
155
|
-
dpr: resolved,
|
|
156
|
-
initialDpr: state.viewport.initialDpr || resolved,
|
|
157
|
-
},
|
|
158
|
-
}));
|
|
159
|
-
},
|
|
160
|
-
setFrameloop: (frameloop = 'always') => {
|
|
161
|
-
const clock = this.get('clock');
|
|
162
|
-
clock.stop();
|
|
163
|
-
clock.elapsedTime = 0;
|
|
164
|
-
if (frameloop !== 'never') {
|
|
165
|
-
clock.start();
|
|
166
|
-
clock.elapsedTime = 0;
|
|
167
|
-
}
|
|
168
|
-
this.set({ frameloop });
|
|
169
|
-
},
|
|
170
|
-
});
|
|
171
|
-
this.isInit = true;
|
|
172
|
-
this.#resize();
|
|
173
|
-
}
|
|
174
|
-
}
|
|
175
|
-
configure(inputs, canvasElement) {
|
|
176
|
-
const { gl: glOptions, size: sizeOptions, camera: cameraOptions, raycaster: raycasterOptions, scene: sceneOptions, events, orthographic, lookAt, shadows, linear, legacy, flat, dpr, frameloop, performance, } = inputs;
|
|
177
|
-
const state = this.get();
|
|
178
|
-
const stateToUpdate = {};
|
|
179
|
-
// setup renderer
|
|
180
|
-
let gl = state.gl;
|
|
181
|
-
if (!state.gl)
|
|
182
|
-
stateToUpdate.gl = gl = makeDefaultRenderer(glOptions, canvasElement);
|
|
183
|
-
// setup raycaster
|
|
184
|
-
let raycaster = state.raycaster;
|
|
185
|
-
if (!raycaster)
|
|
186
|
-
stateToUpdate.raycaster = raycaster = new THREE.Raycaster();
|
|
187
|
-
// set raycaster options
|
|
188
|
-
const { params, ...options } = raycasterOptions || {};
|
|
189
|
-
if (!is.equ(options, raycaster, shallowLoose))
|
|
190
|
-
applyProps(raycaster, { ...options });
|
|
191
|
-
if (!is.equ(params, raycaster.params, shallowLoose)) {
|
|
192
|
-
applyProps(raycaster, { params: { ...raycaster.params, ...(params || {}) } });
|
|
193
|
-
}
|
|
194
|
-
// create default camera
|
|
195
|
-
if (!state.camera) {
|
|
196
|
-
const isCamera = is.camera(cameraOptions);
|
|
197
|
-
let camera = isCamera ? cameraOptions : makeDefaultCamera(orthographic || false, state.size);
|
|
198
|
-
if (!isCamera) {
|
|
199
|
-
if (cameraOptions)
|
|
200
|
-
applyProps(camera, cameraOptions);
|
|
201
|
-
// set position.z
|
|
202
|
-
if (!cameraOptions?.position)
|
|
203
|
-
camera.position.z = 5;
|
|
204
|
-
// always look at center or passed-in lookAt by default
|
|
205
|
-
if (!cameraOptions?.rotation && !cameraOptions?.quaternion) {
|
|
206
|
-
if (Array.isArray(lookAt))
|
|
207
|
-
camera.lookAt(lookAt[0], lookAt[1], lookAt[2]);
|
|
208
|
-
else if (lookAt instanceof THREE.Vector3)
|
|
209
|
-
camera.lookAt(lookAt);
|
|
210
|
-
else
|
|
211
|
-
camera.lookAt(0, 0, 0);
|
|
212
|
-
}
|
|
213
|
-
// update projection matrix after applyprops
|
|
214
|
-
camera.updateProjectionMatrix?.();
|
|
215
|
-
}
|
|
216
|
-
if (!is.instance(camera))
|
|
217
|
-
camera = prepare(camera, { store: this });
|
|
218
|
-
stateToUpdate.camera = camera;
|
|
219
|
-
}
|
|
220
|
-
// Set up scene (one time only!)
|
|
221
|
-
if (!state.scene) {
|
|
222
|
-
let scene;
|
|
223
|
-
if (sceneOptions instanceof THREE.Scene) {
|
|
224
|
-
scene = prepare(sceneOptions, { store: this });
|
|
225
|
-
}
|
|
226
|
-
else {
|
|
227
|
-
scene = prepare(new THREE.Scene(), { store: this });
|
|
228
|
-
if (sceneOptions)
|
|
229
|
-
applyProps(scene, sceneOptions);
|
|
230
|
-
}
|
|
231
|
-
stateToUpdate.scene = scene;
|
|
232
|
-
}
|
|
233
|
-
// Set up XR (one time only!)
|
|
234
|
-
if (!state.xr) {
|
|
235
|
-
// Handle frame behavior in WebXR
|
|
236
|
-
const handleXRFrame = (timestamp, frame) => {
|
|
237
|
-
const state = this.get();
|
|
238
|
-
if (state.frameloop === 'never')
|
|
239
|
-
return;
|
|
240
|
-
advance(timestamp, true, this, frame);
|
|
241
|
-
};
|
|
242
|
-
// Toggle render switching on session
|
|
243
|
-
const handleSessionChange = () => {
|
|
244
|
-
const state = this.get();
|
|
245
|
-
state.gl.xr.enabled = state.gl.xr.isPresenting;
|
|
246
|
-
state.gl.xr.setAnimationLoop(state.gl.xr.isPresenting ? handleXRFrame : null);
|
|
247
|
-
if (!state.gl.xr.isPresenting)
|
|
248
|
-
state.invalidate();
|
|
249
|
-
};
|
|
250
|
-
// WebXR session manager
|
|
251
|
-
const xr = {
|
|
252
|
-
connect: () => {
|
|
253
|
-
gl.xr.addEventListener('sessionstart', handleSessionChange);
|
|
254
|
-
gl.xr.addEventListener('sessionend', handleSessionChange);
|
|
255
|
-
},
|
|
256
|
-
disconnect: () => {
|
|
257
|
-
gl.xr.removeEventListener('sessionstart', handleSessionChange);
|
|
258
|
-
gl.xr.removeEventListener('sessionend', handleSessionChange);
|
|
259
|
-
},
|
|
260
|
-
};
|
|
261
|
-
// Subscribe to WebXR session events
|
|
262
|
-
if (gl.xr)
|
|
263
|
-
xr.connect();
|
|
264
|
-
stateToUpdate.xr = xr;
|
|
265
|
-
}
|
|
266
|
-
// Set shadowmap
|
|
267
|
-
if (gl.shadowMap) {
|
|
268
|
-
const oldEnabled = gl.shadowMap.enabled;
|
|
269
|
-
const oldType = gl.shadowMap.type;
|
|
270
|
-
gl.shadowMap.enabled = !!shadows;
|
|
271
|
-
if (typeof shadows === 'boolean') {
|
|
272
|
-
gl.shadowMap.type = THREE.PCFSoftShadowMap;
|
|
273
|
-
}
|
|
274
|
-
else if (typeof shadows === 'string') {
|
|
275
|
-
const types = {
|
|
276
|
-
basic: THREE.BasicShadowMap,
|
|
277
|
-
percentage: THREE.PCFShadowMap,
|
|
278
|
-
soft: THREE.PCFSoftShadowMap,
|
|
279
|
-
variance: THREE.VSMShadowMap,
|
|
280
|
-
};
|
|
281
|
-
gl.shadowMap.type = types[shadows] ?? THREE.PCFSoftShadowMap;
|
|
282
|
-
}
|
|
283
|
-
else if (is.obj(shadows)) {
|
|
284
|
-
Object.assign(gl.shadowMap, shadows);
|
|
285
|
-
}
|
|
286
|
-
if (oldEnabled !== gl.shadowMap.enabled || oldType !== gl.shadowMap.type)
|
|
287
|
-
checkNeedsUpdate(gl.shadowMap);
|
|
288
|
-
}
|
|
289
|
-
// Safely set color management if available.
|
|
290
|
-
// Avoid accessing THREE.ColorManagement to play nice with older versions
|
|
291
|
-
if (THREE.ColorManagement) {
|
|
292
|
-
const ColorManagement = THREE.ColorManagement;
|
|
293
|
-
if ('enabled' in ColorManagement)
|
|
294
|
-
ColorManagement['enabled'] = !legacy ?? false;
|
|
295
|
-
else if ('legacyMode' in ColorManagement)
|
|
296
|
-
ColorManagement['legacyMode'] = legacy ?? true;
|
|
297
|
-
}
|
|
298
|
-
// set color space and tonemapping preferences
|
|
299
|
-
const LinearEncoding = 3000;
|
|
300
|
-
const sRGBEncoding = 3001;
|
|
301
|
-
applyProps(gl, {
|
|
302
|
-
outputEncoding: linear ? LinearEncoding : sRGBEncoding,
|
|
303
|
-
toneMapping: flat ? THREE.NoToneMapping : THREE.ACESFilmicToneMapping,
|
|
304
|
-
});
|
|
305
|
-
// Update color management state
|
|
306
|
-
if (state.legacy !== legacy)
|
|
307
|
-
stateToUpdate.legacy = legacy;
|
|
308
|
-
if (state.linear !== linear)
|
|
309
|
-
stateToUpdate.linear = linear;
|
|
310
|
-
if (state.flat !== flat)
|
|
311
|
-
stateToUpdate.flat = flat;
|
|
312
|
-
// Set gl props
|
|
313
|
-
gl.setClearAlpha(0);
|
|
314
|
-
gl.setPixelRatio(makeDpr(state.viewport.dpr));
|
|
315
|
-
gl.setSize(state.size.width, state.size.height);
|
|
316
|
-
if (is.obj(glOptions) &&
|
|
317
|
-
!(typeof glOptions === 'function') &&
|
|
318
|
-
!is.renderer(glOptions) &&
|
|
319
|
-
!is.equ(glOptions, gl, shallowLoose)) {
|
|
320
|
-
applyProps(gl, glOptions);
|
|
321
|
-
}
|
|
322
|
-
// Store events internally
|
|
323
|
-
if (events && !state.events.handlers)
|
|
324
|
-
stateToUpdate.events = events(this);
|
|
325
|
-
// Check performance
|
|
326
|
-
if (performance && !is.equ(performance, state.performance, shallowLoose)) {
|
|
327
|
-
stateToUpdate.performance = { ...state.performance, ...performance };
|
|
328
|
-
}
|
|
329
|
-
this.set(stateToUpdate);
|
|
330
|
-
// Check pixelratio
|
|
331
|
-
if (dpr && state.viewport.dpr !== makeDpr(dpr))
|
|
332
|
-
state.setDpr(dpr);
|
|
333
|
-
// Check size, allow it to take on container bounds initially
|
|
334
|
-
const size = computeInitialSize(canvasElement, sizeOptions);
|
|
335
|
-
if (!is.equ(size, state.size, shallowLoose))
|
|
336
|
-
state.setSize(size.width, size.height, size.top, size.left);
|
|
337
|
-
// Check frameloop
|
|
338
|
-
if (state.frameloop !== frameloop)
|
|
339
|
-
state.setFrameloop(frameloop);
|
|
340
|
-
if (!this.get('ready'))
|
|
341
|
-
this.set({ ready: true });
|
|
342
|
-
this.#invalidate();
|
|
343
|
-
}
|
|
344
|
-
destroy(canvas) {
|
|
345
|
-
this.set((state) => ({ internal: { ...state.internal, active: false } }));
|
|
346
|
-
setTimeout(() => {
|
|
347
|
-
const { gl, xr, events } = this.get();
|
|
348
|
-
if (gl) {
|
|
349
|
-
if (events.disconnect) {
|
|
350
|
-
events.disconnect();
|
|
351
|
-
}
|
|
352
|
-
gl.renderLists.dispose();
|
|
353
|
-
gl.forceContextLoss();
|
|
354
|
-
if (gl.xr && gl.xr.enabled) {
|
|
355
|
-
gl.xr.setAnimationLoop(null);
|
|
356
|
-
xr.disconnect();
|
|
357
|
-
}
|
|
358
|
-
dispose(this.get());
|
|
359
|
-
rootStateMap.delete(canvas);
|
|
360
|
-
}
|
|
361
|
-
}, 500);
|
|
362
|
-
}
|
|
363
|
-
#resize() {
|
|
364
|
-
const state = this.get();
|
|
365
|
-
let oldSize = state.size;
|
|
366
|
-
let oldDpr = state.viewport.dpr;
|
|
367
|
-
let oldCamera = state.camera;
|
|
368
|
-
const camera = this.select('camera');
|
|
369
|
-
const size = this.select('size');
|
|
370
|
-
const viewport = this.select('viewport');
|
|
371
|
-
const triggers = computed(() => ({ camera: camera(), size: size(), viewport: viewport(), gl: this.get('gl') }));
|
|
372
|
-
effect(() => {
|
|
373
|
-
const { camera, size, viewport, gl } = triggers();
|
|
374
|
-
// resize camera and renderer on changes to size and dpr
|
|
375
|
-
if (size !== oldSize || viewport.dpr !== oldDpr) {
|
|
376
|
-
oldSize = size;
|
|
377
|
-
oldDpr = viewport.dpr;
|
|
378
|
-
// update camera
|
|
379
|
-
updateCamera(camera, size);
|
|
380
|
-
gl.setPixelRatio(viewport.dpr);
|
|
381
|
-
gl.setSize(size.width, size.height);
|
|
382
|
-
}
|
|
383
|
-
// update viewport when camera changes
|
|
384
|
-
if (camera !== oldCamera) {
|
|
385
|
-
oldCamera = camera;
|
|
386
|
-
updateCamera(camera, size);
|
|
387
|
-
this.set((state) => ({
|
|
388
|
-
viewport: { ...state.viewport, ...state.viewport.getCurrentViewport(camera) },
|
|
389
|
-
}));
|
|
390
|
-
}
|
|
391
|
-
}, { injector: this.#injector, allowSignalWrites: true });
|
|
392
|
-
}
|
|
393
|
-
#invalidate() {
|
|
394
|
-
effect(() => void this.state().invalidate(), { injector: this.#injector });
|
|
395
|
-
}
|
|
396
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NgtStore, deps: null, target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
397
|
-
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NgtStore }); }
|
|
398
|
-
}
|
|
399
|
-
export { NgtStore };
|
|
400
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NgtStore, decorators: [{
|
|
401
|
-
type: Injectable
|
|
402
|
-
}] });
|
|
403
|
-
function computeInitialSize(canvas, defaultSize) {
|
|
404
|
-
if (defaultSize)
|
|
405
|
-
return defaultSize;
|
|
406
|
-
if (canvas instanceof HTMLCanvasElement && canvas.parentElement) {
|
|
407
|
-
return canvas.parentElement.getBoundingClientRect();
|
|
408
|
-
}
|
|
409
|
-
return { width: 0, height: 0, top: 0, left: 0 };
|
|
410
|
-
}
|
|
411
|
-
// Disposes an object and all its properties
|
|
412
|
-
function dispose(obj) {
|
|
413
|
-
if (obj.dispose && !is.scene(obj))
|
|
414
|
-
obj.dispose();
|
|
415
|
-
for (const p in obj) {
|
|
416
|
-
p.dispose?.();
|
|
417
|
-
delete obj[p];
|
|
418
|
-
}
|
|
419
|
-
}
|
|
420
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"store.js","sourceRoot":"","sources":["../../../../../../libs/angular-three/src/lib/stores/store.ts"],"names":[],"mappings":"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","sourcesContent":["import { DOCUMENT } from '@angular/common';\nimport { ElementRef, Injectable, Injector, computed, effect, inject } from '@angular/core';\nimport * as THREE from 'three';\nimport { createLoop } from '../loop';\nimport type {\n    NgtAnyRecord,\n    NgtBeforeRenderRecord,\n    NgtCanvasInputs,\n    NgtDpr,\n    NgtEquConfig,\n    NgtEventManager,\n    NgtSize,\n    NgtState,\n    NgtViewport,\n} from '../types';\nimport { applyProps } from '../utils/apply-props';\nimport { prepare } from '../utils/instance';\nimport { is } from '../utils/is';\nimport { makeDefaultCamera, makeDefaultRenderer, makeDpr } from '../utils/make';\nimport { checkNeedsUpdate, updateCamera } from '../utils/update';\nimport { NgtSignalStore } from './signal.store';\n\nexport const rootStateMap = new Map<Element, NgtSignalStore<NgtState>>();\nconst { invalidate, advance } = createLoop(rootStateMap);\nconst shallowLoose = { objects: 'shallow', strict: false } as NgtEquConfig;\n\n@Injectable()\nexport class NgtStore extends NgtSignalStore<NgtState> {\n    readonly #parentStore = inject(NgtStore, { optional: true, skipSelf: true });\n    readonly #window = inject(DOCUMENT).defaultView;\n    readonly #injector = inject(Injector);\n\n    isInit = false;\n\n    init() {\n        if (!this.isInit) {\n            const position = new THREE.Vector3();\n            const defaultTarget = new THREE.Vector3();\n            const tempTarget = new THREE.Vector3();\n\n            const getCurrentViewport = (\n                camera = this.get('camera'),\n                target: THREE.Vector3 | Parameters<THREE.Vector3['set']> = defaultTarget,\n                size = this.get('size')\n            ): Omit<NgtViewport, 'dpr' | 'initialDpr'> => {\n                const { width, height, top, left } = size;\n                const aspect = width / height;\n                if (target instanceof THREE.Vector3) tempTarget.copy(target);\n                else tempTarget.set(...target);\n\n                const distance = camera.getWorldPosition(position).distanceTo(tempTarget);\n\n                if (is.orthographicCamera(camera)) {\n                    return {\n                        width: width / camera.zoom,\n                        height: height / camera.zoom,\n                        top,\n                        left,\n                        factor: 1,\n                        distance,\n                        aspect,\n                    };\n                }\n\n                const fov = (camera.fov * Math.PI) / 180; // convert vertical fov to radians\n                const h = 2 * Math.tan(fov / 2) * distance; // visible height\n                const w = h * aspect;\n                return { width: w, height: h, top, left, factor: width / w, distance, aspect };\n            };\n\n            let performanceTimeout: ReturnType<typeof setTimeout>;\n            const setPerformanceCurrent = (current: number) => {\n                this.set((state) => ({ performance: { ...state.performance, current } }));\n            };\n\n            this.set({\n                get: this.get.bind(this),\n                set: this.set.bind(this),\n                ready: false,\n\n                events: { priority: 1, enabled: true, connected: false },\n\n                invalidate: (frames = 1) => invalidate(this, frames),\n                advance: (timestamp: number, runGlobalEffects?: boolean) => advance(timestamp, runGlobalEffects, this),\n\n                legacy: false,\n                linear: false,\n                flat: false,\n\n                controls: null,\n                clock: new THREE.Clock(),\n                pointer: new THREE.Vector2(),\n\n                frameloop: 'always',\n                performance: {\n                    current: 1,\n                    min: 0.5,\n                    max: 1,\n                    debounce: 200,\n                    regress: () => {\n                        const state = this.get();\n                        // clear timeout\n                        if (performanceTimeout) clearTimeout(performanceTimeout);\n                        // set lower bound\n                        if (state.performance.current !== state.performance.min)\n                            setPerformanceCurrent(state.performance.min);\n                        // go back to upper bound\n                        performanceTimeout = setTimeout(() => {\n                            setPerformanceCurrent(this.get('performance', 'max') || 1);\n                        }, state.performance.debounce);\n                    },\n                },\n                size: { width: 0, height: 0, top: 0, left: 0 },\n                viewport: {\n                    initialDpr: 0,\n                    dpr: 0,\n                    width: 0,\n                    height: 0,\n                    top: 0,\n                    left: 0,\n                    aspect: 0,\n                    distance: 0,\n                    factor: 0,\n                    getCurrentViewport,\n                },\n                previousStore: this.#parentStore as NgtStore,\n                internal: {\n                    active: false,\n                    priority: 0,\n                    frames: 0,\n                    lastEvent: new ElementRef(null),\n                    interaction: [],\n                    hovered: new Map(),\n                    subscribers: [],\n                    initialClick: [0, 0],\n                    initialHits: [],\n                    capturedMap: new Map(),\n                    subscribe: (callback: NgtBeforeRenderRecord['callback'], priority = 0, store = this) => {\n                        const internal = this.get('internal');\n                        // If this subscription was given a priority, it takes rendering into its own hands\n                        // For that reason we switch off automatic rendering and increase the manual flag\n                        // As long as this flag is positive there can be no internal rendering at all\n                        // because there could be multiple render subscriptions\n                        internal.priority = internal.priority + (priority > 0 ? 1 : 0);\n                        internal.subscribers.push({ priority, store, callback });\n                        // Register subscriber and sort layers from lowest to highest, meaning,\n                        // highest priority renders last (on top of the other frames)\n                        internal.subscribers.sort((a, b) => (a.priority || 0) - (b.priority || 0));\n\n                        return () => {\n                            const internal = this.get('internal');\n                            if (internal?.subscribers) {\n                                // Decrease manual flag if this subscription had a priority\n                                internal.priority = internal.priority - (priority > 0 ? 1 : 0);\n                                // Remove subscriber from list\n                                internal.subscribers = internal.subscribers.filter((s) => s.callback !== callback);\n                            }\n                        };\n                    },\n                },\n                setEvents: (events: Partial<NgtEventManager<any>>) => {\n                    this.set((state) => ({ events: { ...state.events, ...events } }));\n                },\n                setSize: (width: number, height: number, top?: number, left?: number) => {\n                    const camera = this.get('camera');\n                    const size = { width, height, top: top || 0, left: left || 0 };\n\n                    this.set((state) => ({\n                        size,\n                        viewport: { ...state.viewport, ...getCurrentViewport(camera, defaultTarget, size) },\n                    }));\n                },\n                setDpr: (dpr: NgtDpr) => {\n                    const resolved = makeDpr(dpr, this.#window as Window & typeof globalThis);\n                    this.set((state) => ({\n                        viewport: {\n                            ...state.viewport,\n                            dpr: resolved,\n                            initialDpr: state.viewport.initialDpr || resolved,\n                        },\n                    }));\n                },\n                setFrameloop: (frameloop: 'always' | 'demand' | 'never' = 'always') => {\n                    const clock = this.get('clock');\n                    clock.stop();\n                    clock.elapsedTime = 0;\n\n                    if (frameloop !== 'never') {\n                        clock.start();\n                        clock.elapsedTime = 0;\n                    }\n\n                    this.set({ frameloop });\n                },\n            });\n\n            this.isInit = true;\n            this.#resize();\n        }\n    }\n\n    configure(inputs: NgtCanvasInputs, canvasElement: HTMLCanvasElement) {\n        const {\n            gl: glOptions,\n            size: sizeOptions,\n            camera: cameraOptions,\n            raycaster: raycasterOptions,\n            scene: sceneOptions,\n            events,\n            orthographic,\n            lookAt,\n            shadows,\n            linear,\n            legacy,\n            flat,\n            dpr,\n            frameloop,\n            performance,\n        } = inputs;\n\n        const state = this.get();\n        const stateToUpdate: Partial<NgtState> = {};\n\n        // setup renderer\n        let gl = state.gl;\n        if (!state.gl) stateToUpdate.gl = gl = makeDefaultRenderer(glOptions, canvasElement);\n\n        // setup raycaster\n        let raycaster = state.raycaster;\n        if (!raycaster) stateToUpdate.raycaster = raycaster = new THREE.Raycaster();\n\n        // set raycaster options\n        const { params, ...options } = raycasterOptions || {};\n        if (!is.equ(options, raycaster, shallowLoose)) applyProps(raycaster, { ...options });\n        if (!is.equ(params, raycaster.params, shallowLoose)) {\n            applyProps(raycaster, { params: { ...raycaster.params, ...(params || {}) } });\n        }\n\n        // create default camera\n        if (!state.camera) {\n            const isCamera = is.camera(cameraOptions);\n            let camera = isCamera ? cameraOptions : makeDefaultCamera(orthographic || false, state.size);\n\n            if (!isCamera) {\n                if (cameraOptions) applyProps(camera, cameraOptions);\n\n                // set position.z\n                if (!cameraOptions?.position) camera.position.z = 5;\n\n                // always look at center or passed-in lookAt by default\n                if (!cameraOptions?.rotation && !cameraOptions?.quaternion) {\n                    if (Array.isArray(lookAt)) camera.lookAt(lookAt[0], lookAt[1], lookAt[2]);\n                    else if (lookAt instanceof THREE.Vector3) camera.lookAt(lookAt);\n                    else camera.lookAt(0, 0, 0);\n                }\n\n                // update projection matrix after applyprops\n                camera.updateProjectionMatrix?.();\n            }\n\n            if (!is.instance(camera)) camera = prepare(camera, { store: this });\n\n            stateToUpdate.camera = camera;\n        }\n        // Set up scene (one time only!)\n        if (!state.scene) {\n            let scene: THREE.Scene;\n\n            if (sceneOptions instanceof THREE.Scene) {\n                scene = prepare(sceneOptions, { store: this });\n            } else {\n                scene = prepare(new THREE.Scene(), { store: this });\n                if (sceneOptions) applyProps(scene, sceneOptions);\n            }\n\n            stateToUpdate.scene = scene;\n        }\n\n        // Set up XR (one time only!)\n        if (!state.xr) {\n            // Handle frame behavior in WebXR\n            const handleXRFrame: XRFrameRequestCallback = (timestamp: number, frame?: XRFrame) => {\n                const state = this.get();\n                if (state.frameloop === 'never') return;\n                advance(timestamp, true, this, frame);\n            };\n\n            // Toggle render switching on session\n            const handleSessionChange = () => {\n                const state = this.get();\n                state.gl.xr.enabled = state.gl.xr.isPresenting;\n\n                state.gl.xr.setAnimationLoop(state.gl.xr.isPresenting ? handleXRFrame : null);\n                if (!state.gl.xr.isPresenting) state.invalidate();\n            };\n\n            // WebXR session manager\n            const xr = {\n                connect: () => {\n                    gl.xr.addEventListener('sessionstart', handleSessionChange);\n                    gl.xr.addEventListener('sessionend', handleSessionChange);\n                },\n                disconnect: () => {\n                    gl.xr.removeEventListener('sessionstart', handleSessionChange);\n                    gl.xr.removeEventListener('sessionend', handleSessionChange);\n                },\n            };\n\n            // Subscribe to WebXR session events\n            if (gl.xr) xr.connect();\n            stateToUpdate.xr = xr;\n        }\n\n        // Set shadowmap\n        if (gl.shadowMap) {\n            const oldEnabled = gl.shadowMap.enabled;\n            const oldType = gl.shadowMap.type;\n            gl.shadowMap.enabled = !!shadows;\n\n            if (typeof shadows === 'boolean') {\n                gl.shadowMap.type = THREE.PCFSoftShadowMap;\n            } else if (typeof shadows === 'string') {\n                const types = {\n                    basic: THREE.BasicShadowMap,\n                    percentage: THREE.PCFShadowMap,\n                    soft: THREE.PCFSoftShadowMap,\n                    variance: THREE.VSMShadowMap,\n                };\n                gl.shadowMap.type = types[shadows] ?? THREE.PCFSoftShadowMap;\n            } else if (is.obj(shadows)) {\n                Object.assign(gl.shadowMap, shadows);\n            }\n\n            if (oldEnabled !== gl.shadowMap.enabled || oldType !== gl.shadowMap.type) checkNeedsUpdate(gl.shadowMap);\n        }\n\n        // Safely set color management if available.\n        // Avoid accessing THREE.ColorManagement to play nice with older versions\n        if (THREE.ColorManagement) {\n            const ColorManagement = THREE.ColorManagement as NgtAnyRecord;\n            if ('enabled' in ColorManagement) ColorManagement['enabled'] = !legacy ?? false;\n            else if ('legacyMode' in ColorManagement) ColorManagement['legacyMode'] = legacy ?? true;\n        }\n\n        // set color space and tonemapping preferences\n        const LinearEncoding = 3000;\n        const sRGBEncoding = 3001;\n        applyProps(gl, {\n            outputEncoding: linear ? LinearEncoding : sRGBEncoding,\n            toneMapping: flat ? THREE.NoToneMapping : THREE.ACESFilmicToneMapping,\n        });\n\n        // Update color management state\n        if (state.legacy !== legacy) stateToUpdate.legacy = legacy;\n        if (state.linear !== linear) stateToUpdate.linear = linear;\n        if (state.flat !== flat) stateToUpdate.flat = flat;\n\n        // Set gl props\n        gl.setClearAlpha(0);\n        gl.setPixelRatio(makeDpr(state.viewport.dpr));\n        gl.setSize(state.size.width, state.size.height);\n\n        if (\n            is.obj(glOptions) &&\n            !(typeof glOptions === 'function') &&\n            !is.renderer(glOptions) &&\n            !is.equ(glOptions, gl, shallowLoose)\n        ) {\n            applyProps(gl, glOptions);\n        }\n\n        // Store events internally\n        if (events && !state.events.handlers) stateToUpdate.events = events(this);\n\n        // Check performance\n        if (performance && !is.equ(performance, state.performance, shallowLoose)) {\n            stateToUpdate.performance = { ...state.performance, ...performance };\n        }\n\n        this.set(stateToUpdate);\n\n        // Check pixelratio\n        if (dpr && state.viewport.dpr !== makeDpr(dpr)) state.setDpr(dpr);\n        // Check size, allow it to take on container bounds initially\n        const size = computeInitialSize(canvasElement, sizeOptions);\n        if (!is.equ(size, state.size, shallowLoose)) state.setSize(size.width, size.height, size.top, size.left);\n\n        // Check frameloop\n        if (state.frameloop !== frameloop) state.setFrameloop(frameloop);\n\n        if (!this.get('ready')) this.set({ ready: true });\n\n        this.#invalidate();\n    }\n\n    destroy(canvas: HTMLCanvasElement) {\n        this.set((state) => ({ internal: { ...state.internal, active: false } }));\n\n        setTimeout(() => {\n            const { gl, xr, events } = this.get();\n            if (gl) {\n                if (events.disconnect) {\n                    events.disconnect();\n                }\n\n                gl.renderLists.dispose();\n                gl.forceContextLoss();\n\n                if (gl.xr && gl.xr.enabled) {\n                    gl.xr.setAnimationLoop(null);\n                    xr.disconnect();\n                }\n\n                dispose(this.get());\n\n                rootStateMap.delete(canvas);\n            }\n        }, 500);\n    }\n\n    #resize() {\n        const state = this.get();\n        let oldSize = state.size;\n        let oldDpr = state.viewport.dpr;\n        let oldCamera = state.camera;\n\n        const camera = this.select('camera');\n        const size = this.select('size');\n        const viewport = this.select('viewport');\n\n        const triggers = computed(() => ({ camera: camera(), size: size(), viewport: viewport(), gl: this.get('gl') }));\n\n        effect(\n            () => {\n                const { camera, size, viewport, gl } = triggers();\n                // resize camera and renderer on changes to size and dpr\n                if (size !== oldSize || viewport.dpr !== oldDpr) {\n                    oldSize = size;\n                    oldDpr = viewport.dpr;\n                    // update camera\n                    updateCamera(camera, size);\n                    gl.setPixelRatio(viewport.dpr);\n                    gl.setSize(size.width, size.height);\n                }\n\n                // update viewport when camera changes\n                if (camera !== oldCamera) {\n                    oldCamera = camera;\n                    updateCamera(camera, size);\n                    this.set((state) => ({\n                        viewport: { ...state.viewport, ...state.viewport.getCurrentViewport(camera) },\n                    }));\n                }\n            },\n            { injector: this.#injector, allowSignalWrites: true }\n        );\n    }\n\n    #invalidate() {\n        effect(() => void this.state().invalidate(), { injector: this.#injector });\n    }\n}\n\nfunction computeInitialSize(canvas: HTMLCanvasElement | THREE.OffscreenCanvas, defaultSize?: NgtSize): NgtSize {\n    if (defaultSize) return defaultSize;\n\n    if (canvas instanceof HTMLCanvasElement && canvas.parentElement) {\n        return canvas.parentElement.getBoundingClientRect();\n    }\n\n    return { width: 0, height: 0, top: 0, left: 0 };\n}\n\n// Disposes an object and all its properties\nfunction dispose<TObj extends { dispose?: () => void; type?: string; [key: string]: any }>(obj: TObj) {\n    if (obj.dispose && !is.scene(obj)) obj.dispose();\n    for (const p in obj) {\n        (p as any).dispose?.();\n        delete obj[p];\n    }\n}\n"]}
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
import { Injector, assertInInjectionContext, inject } from '@angular/core';
|
|
2
|
-
export function assertInjectionContext(fn, injector) {
|
|
3
|
-
try {
|
|
4
|
-
if (!injector) {
|
|
5
|
-
return inject(Injector);
|
|
6
|
-
}
|
|
7
|
-
return injector;
|
|
8
|
-
}
|
|
9
|
-
catch {
|
|
10
|
-
!injector && assertInInjectionContext(fn);
|
|
11
|
-
return null;
|
|
12
|
-
}
|
|
13
|
-
}
|
|
14
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXNzZXJ0LWluLWluamVjdGlvbi1jb250ZXh0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9hbmd1bGFyLXRocmVlL3NyYy9saWIvdXRpbHMvYXNzZXJ0LWluLWluamVjdGlvbi1jb250ZXh0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRTNFLE1BQU0sVUFBVSxzQkFBc0IsQ0FBQyxFQUFZLEVBQUUsUUFBbUI7SUFDcEUsSUFBSTtRQUNBLElBQUksQ0FBQyxRQUFRLEVBQUU7WUFDWCxPQUFPLE1BQU0sQ0FBQyxRQUFRLENBQUMsQ0FBQztTQUMzQjtRQUNELE9BQU8sUUFBUSxDQUFDO0tBQ25CO0lBQUMsTUFBTTtRQUNKLENBQUMsUUFBUSxJQUFJLHdCQUF3QixDQUFDLEVBQUUsQ0FBQyxDQUFDO1FBQzFDLE9BQU8sSUFBSyxDQUFDO0tBQ2hCO0FBQ0wsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdG9yLCBhc3NlcnRJbkluamVjdGlvbkNvbnRleHQsIGluamVjdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5leHBvcnQgZnVuY3Rpb24gYXNzZXJ0SW5qZWN0aW9uQ29udGV4dChmbjogRnVuY3Rpb24sIGluamVjdG9yPzogSW5qZWN0b3IpOiBJbmplY3RvciB7XG4gICAgdHJ5IHtcbiAgICAgICAgaWYgKCFpbmplY3Rvcikge1xuICAgICAgICAgICAgcmV0dXJuIGluamVjdChJbmplY3Rvcik7XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIGluamVjdG9yO1xuICAgIH0gY2F0Y2gge1xuICAgICAgICAhaW5qZWN0b3IgJiYgYXNzZXJ0SW5JbmplY3Rpb25Db250ZXh0KGZuKTtcbiAgICAgICAgcmV0dXJuIG51bGwhO1xuICAgIH1cbn1cbiJdfQ==
|