angular-three 1.0.0-beta.8 → 1.0.0-beta.9

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/esm2020/index.mjs CHANGED
@@ -1,15 +1,16 @@
1
1
  export * from './lib/canvas';
2
- export * from './lib/types';
2
+ export * from './lib/di/before-render';
3
3
  export * from './lib/di/catalogue';
4
+ export * from './lib/di/destroy';
5
+ export * from './lib/di/ref';
4
6
  export * from './lib/directives/args';
5
7
  export * from './lib/directives/repeat';
6
- export * from './lib/stores/store';
8
+ export * from './lib/loader';
9
+ export * from './lib/pipes/push';
7
10
  export * from './lib/stores/rx-store';
11
+ export * from './lib/stores/store';
12
+ export * from './lib/types';
8
13
  export * from './lib/utils/instance';
9
- export * from './lib/utils/update';
10
14
  export * from './lib/utils/is';
11
- export * from './lib/loader';
12
- export * from './lib/di/ref';
13
- export * from './lib/di/destroy';
14
- export * from './lib/pipes/push';
15
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXItdGhyZWUvc3JjL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMsYUFBYSxDQUFDO0FBQzVCLGNBQWMsb0JBQW9CLENBQUM7QUFDbkMsY0FBYyx1QkFBdUIsQ0FBQztBQUN0QyxjQUFjLHlCQUF5QixDQUFDO0FBQ3hDLGNBQWMsb0JBQW9CLENBQUM7QUFDbkMsY0FBYyx1QkFBdUIsQ0FBQztBQUN0QyxjQUFjLHNCQUFzQixDQUFDO0FBQ3JDLGNBQWMsb0JBQW9CLENBQUM7QUFDbkMsY0FBYyxnQkFBZ0IsQ0FBQztBQUMvQixjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsa0JBQWtCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2xpYi9jYW52YXMnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdHlwZXMnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZGkvY2F0YWxvZ3VlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2RpcmVjdGl2ZXMvYXJncyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9kaXJlY3RpdmVzL3JlcGVhdCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9zdG9yZXMvc3RvcmUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvc3RvcmVzL3J4LXN0b3JlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3V0aWxzL2luc3RhbmNlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3V0aWxzL3VwZGF0ZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi91dGlscy9pcyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9sb2FkZXInO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZGkvcmVmJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2RpL2Rlc3Ryb3knO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvcGlwZXMvcHVzaCc7XG4iXX0=
15
+ export * from './lib/utils/update';
16
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXItdGhyZWUvc3JjL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMsd0JBQXdCLENBQUM7QUFDdkMsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLGFBQWEsQ0FBQztBQUM1QixjQUFjLHNCQUFzQixDQUFDO0FBQ3JDLGNBQWMsZ0JBQWdCLENBQUM7QUFDL0IsY0FBYyxvQkFBb0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbGliL2NhbnZhcyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9kaS9iZWZvcmUtcmVuZGVyJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2RpL2NhdGFsb2d1ZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9kaS9kZXN0cm95JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2RpL3JlZic7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9kaXJlY3RpdmVzL2FyZ3MnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZGlyZWN0aXZlcy9yZXBlYXQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbG9hZGVyJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3BpcGVzL3B1c2gnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvc3RvcmVzL3J4LXN0b3JlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3N0b3Jlcy9zdG9yZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi90eXBlcyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi91dGlscy9pbnN0YW5jZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi91dGlscy9pcyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi91dGlscy91cGRhdGUnO1xuIl19
@@ -1,26 +1,13 @@
1
1
  import { ChangeDetectorRef, Component, createEnvironmentInjector, ElementRef, EnvironmentInjector, EventEmitter, HostBinding, inject, Input, Output, Type, ViewChild, ViewContainerRef, } from '@angular/core';
2
- import { injectNgxResize, provideNgxResizeOptions } from 'ngx-resize';
2
+ import { NgxResize, provideNgxResizeOptions } from 'ngx-resize';
3
3
  import { filter } from 'rxjs';
4
+ import { injectNgtLoader } from './loader';
4
5
  import { provideNgtRenderer } from './renderer/provider';
5
6
  import { NgtRxStore } from './stores/rx-store';
6
7
  import { NgtStore, rootStateMap } from './stores/store';
7
8
  import { is } from './utils/is';
8
9
  import { createPointerEvents } from './web/events';
9
- import { injectNgtLoader } from './loader';
10
10
  import * as i0 from "@angular/core";
11
- export class NgtCanvasContainer {
12
- constructor() {
13
- this.canvasResize = injectNgxResize();
14
- }
15
- }
16
- NgtCanvasContainer.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.1", ngImport: i0, type: NgtCanvasContainer, deps: [], target: i0.ɵɵFactoryTarget.Component });
17
- NgtCanvasContainer.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.1", type: NgtCanvasContainer, isStandalone: true, selector: "ngt-canvas-container", outputs: { canvasResize: "canvasResize" }, providers: [provideNgxResizeOptions({ emitInZone: false })], ngImport: i0, template: '<ng-content />', isInline: true, styles: [":host{display:block;width:100%;height:100%}\n"] });
18
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.1", ngImport: i0, type: NgtCanvasContainer, decorators: [{
19
- type: Component,
20
- args: [{ selector: 'ngt-canvas-container', standalone: true, template: '<ng-content />', providers: [provideNgxResizeOptions({ emitInZone: false })], styles: [":host{display:block;width:100%;height:100%}\n"] }]
21
- }], propDecorators: { canvasResize: [{
22
- type: Output
23
- }] } });
24
11
  export class NgtCanvas extends NgtRxStore {
25
12
  constructor() {
26
13
  super(...arguments);
@@ -158,7 +145,9 @@ export class NgtCanvas extends NgtRxStore {
158
145
  compoundPrefixes: this.compoundPrefixes,
159
146
  }),
160
147
  ], this.envInjector);
161
- this.glRef = this.glAnchor.createComponent(this.sceneGraph, { environmentInjector: this.glEnvInjector });
148
+ this.glRef = this.glAnchor.createComponent(this.sceneGraph, {
149
+ environmentInjector: this.glEnvInjector,
150
+ });
162
151
  this.glRef.changeDetectorRef.detach();
163
152
  // here, we override the detectChanges to also call detectChanges on the ComponentRef
164
153
  this.overrideDetectChanges();
@@ -184,20 +173,18 @@ export class NgtCanvas extends NgtRxStore {
184
173
  }
185
174
  }
186
175
  NgtCanvas.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.1", ngImport: i0, type: NgtCanvas, deps: null, target: i0.ɵɵFactoryTarget.Component });
187
- NgtCanvas.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.1", type: NgtCanvas, isStandalone: true, selector: "ngt-canvas", inputs: { sceneGraph: "sceneGraph", compoundPrefixes: "compoundPrefixes", linear: "linear", legacy: "legacy", flat: "flat", orthographic: "orthographic", frameloop: "frameloop", dpr: "dpr", raycaster: "raycaster", shadows: "shadows", camera: "camera", gl: "gl", eventSource: "eventSource", eventPrefix: "eventPrefix", lookAt: "lookAt", performance: "performance" }, outputs: { created: "created", pointerMissed: "pointerMissed" }, host: { properties: { "class.ngt-canvas": "this.hostClass", "style.pointerEvents": "this.pointerEvents" } }, providers: [NgtStore], viewQueries: [{ propertyName: "glCanvas", first: true, predicate: ["glCanvas"], descendants: true, static: true }, { propertyName: "glAnchor", first: true, predicate: ["glAnchor"], descendants: true, read: ViewContainerRef, static: true }], usesInheritance: true, ngImport: i0, template: `
188
- <ngt-canvas-container (canvasResize)="onResize($event)">
176
+ NgtCanvas.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.1", type: NgtCanvas, isStandalone: true, selector: "ngt-canvas", inputs: { sceneGraph: "sceneGraph", compoundPrefixes: "compoundPrefixes", linear: "linear", legacy: "legacy", flat: "flat", orthographic: "orthographic", frameloop: "frameloop", dpr: "dpr", raycaster: "raycaster", shadows: "shadows", camera: "camera", gl: "gl", eventSource: "eventSource", eventPrefix: "eventPrefix", lookAt: "lookAt", performance: "performance" }, outputs: { created: "created", pointerMissed: "pointerMissed" }, host: { properties: { "class.ngt-canvas": "this.hostClass", "style.pointerEvents": "this.pointerEvents" } }, providers: [NgtStore, provideNgxResizeOptions({ emitInZone: false })], viewQueries: [{ propertyName: "glCanvas", first: true, predicate: ["glCanvas"], descendants: true, static: true }, { propertyName: "glAnchor", first: true, predicate: ["glCanvas"], descendants: true, read: ViewContainerRef, static: true }], usesInheritance: true, ngImport: i0, template: `
177
+ <div (ngxResize)="onResize($event)" style="height: 100%; width: 100%;">
189
178
  <canvas #glCanvas style="display: block;"></canvas>
190
- <ng-container #glAnchor />
191
- </ngt-canvas-container>
192
- `, isInline: true, styles: [":host{display:block;position:relative;width:100%;height:100%;overflow:hidden}\n"], dependencies: [{ kind: "component", type: NgtCanvasContainer, selector: "ngt-canvas-container", outputs: ["canvasResize"] }] });
179
+ </div>
180
+ `, isInline: true, styles: [":host{display:block;position:relative;width:100%;height:100%;overflow:hidden}\n"], dependencies: [{ kind: "directive", type: NgxResize, selector: "[ngxResize]", inputs: ["ngxResizeOptions"], outputs: ["ngxResize"] }] });
193
181
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.1", ngImport: i0, type: NgtCanvas, decorators: [{
194
182
  type: Component,
195
183
  args: [{ selector: 'ngt-canvas', standalone: true, template: `
196
- <ngt-canvas-container (canvasResize)="onResize($event)">
184
+ <div (ngxResize)="onResize($event)" style="height: 100%; width: 100%;">
197
185
  <canvas #glCanvas style="display: block;"></canvas>
198
- <ng-container #glAnchor />
199
- </ngt-canvas-container>
200
- `, imports: [NgtCanvasContainer], providers: [NgtStore], styles: [":host{display:block;position:relative;width:100%;height:100%;overflow:hidden}\n"] }]
186
+ </div>
187
+ `, imports: [NgxResize], providers: [NgtStore, provideNgxResizeOptions({ emitInZone: false })], styles: [":host{display:block;position:relative;width:100%;height:100%;overflow:hidden}\n"] }]
201
188
  }], propDecorators: { hostClass: [{
202
189
  type: HostBinding,
203
190
  args: ['class.ngt-canvas']
@@ -245,6 +232,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.1", ngImpor
245
232
  args: ['glCanvas', { static: true }]
246
233
  }], glAnchor: [{
247
234
  type: ViewChild,
248
- args: ['glAnchor', { static: true, read: ViewContainerRef }]
235
+ args: ['glCanvas', { static: true, read: ViewContainerRef }]
249
236
  }] } });
250
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"canvas.js","sourceRoot":"","sources":["../../../../../libs/angular-three/src/lib/canvas.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectorRef,\n    Component,\n    ComponentRef,\n    createEnvironmentInjector,\n    ElementRef,\n    EnvironmentInjector,\n    EventEmitter,\n    HostBinding,\n    inject,\n    Input,\n    OnDestroy,\n    OnInit,\n    Output,\n    Type,\n    ViewChild,\n    ViewContainerRef,\n} from '@angular/core';\nimport { injectNgxResize, NgxResizeResult, provideNgxResizeOptions } from 'ngx-resize';\nimport { filter } from 'rxjs';\nimport { provideNgtRenderer } from './renderer/provider';\nimport { NgtRxStore } from './stores/rx-store';\nimport { NgtStore, rootStateMap } from './stores/store';\nimport type { NgtCanvasInputs, NgtDomEvent, NgtDpr, NgtState } from './types';\nimport { is } from './utils/is';\nimport { createPointerEvents } from './web/events';\nimport { injectNgtLoader } from './loader';\n\n@Component({\n    selector: 'ngt-canvas-container',\n    standalone: true,\n    template: '<ng-content />',\n    styles: [\n        `\n            :host {\n                display: block;\n                width: 100%;\n                height: 100%;\n            }\n        `,\n    ],\n    providers: [provideNgxResizeOptions({ emitInZone: false })],\n})\nexport class NgtCanvasContainer {\n    @Output() canvasResize = injectNgxResize();\n}\n\n@Component({\n    selector: 'ngt-canvas',\n    standalone: true,\n    template: `\n        <ngt-canvas-container (canvasResize)=\"onResize($event)\">\n            <canvas #glCanvas style=\"display: block;\"></canvas>\n            <ng-container #glAnchor />\n        </ngt-canvas-container>\n    `,\n    imports: [NgtCanvasContainer],\n    providers: [NgtStore],\n    styles: [\n        `\n            :host {\n                display: block;\n                position: relative;\n                width: 100%;\n                height: 100%;\n                overflow: hidden;\n            }\n        `,\n    ],\n})\nexport class NgtCanvas extends NgtRxStore<NgtCanvasInputs> implements OnInit, OnDestroy {\n    private readonly cdr = inject(ChangeDetectorRef);\n    private readonly envInjector = inject(EnvironmentInjector);\n    private readonly host = inject(ElementRef) as ElementRef<HTMLElement>;\n    private readonly store = inject(NgtStore);\n\n    override initialize() {\n        super.initialize();\n        this.set({\n            shadows: false,\n            linear: false,\n            flat: false,\n            legacy: false,\n            orthographic: false,\n            frameloop: 'always',\n            dpr: [1, 2],\n            events: createPointerEvents,\n        });\n    }\n\n    @HostBinding('class.ngt-canvas') readonly hostClass = true;\n    @HostBinding('style.pointerEvents') get pointerEvents() {\n        return this.get('eventSource') !== this.host.nativeElement ? 'none' : 'auto';\n    }\n\n    @Input() sceneGraph!: Type<any>;\n    @Input() compoundPrefixes: string[] = [];\n\n    @Input() set linear(linear: boolean) {\n        this.set({ linear });\n    }\n\n    @Input() set legacy(legacy: boolean) {\n        this.set({ legacy });\n    }\n\n    @Input() set flat(flat: boolean) {\n        this.set({ flat });\n    }\n\n    @Input() set orthographic(orthographic: boolean) {\n        this.set({ orthographic });\n    }\n\n    @Input() set frameloop(frameloop: NgtCanvasInputs['frameloop']) {\n        this.set({ frameloop });\n    }\n\n    @Input() set dpr(dpr: NgtDpr) {\n        this.set({ dpr });\n    }\n\n    @Input() set raycaster(raycaster: Partial<THREE.Raycaster>) {\n        this.set({ raycaster });\n    }\n\n    @Input() set shadows(shadows: boolean | Partial<THREE.WebGLShadowMap>) {\n        this.set({\n            shadows: typeof shadows === 'object' ? (shadows as Partial<THREE.WebGLShadowMap>) : shadows,\n        });\n    }\n\n    @Input() set camera(camera: NgtCanvasInputs['camera']) {\n        this.set({ camera });\n    }\n\n    @Input() set gl(gl: NgtCanvasInputs['gl']) {\n        this.set({ gl });\n    }\n\n    @Input() set eventSource(eventSource: NgtCanvasInputs['eventSource']) {\n        this.set({ eventSource });\n    }\n\n    @Input() set eventPrefix(eventPrefix: NgtCanvasInputs['eventPrefix']) {\n        this.set({ eventPrefix });\n    }\n\n    @Input() set lookAt(lookAt: NgtCanvasInputs['lookAt']) {\n        this.set({ lookAt });\n    }\n\n    @Input() set performance(performance: NgtCanvasInputs['performance']) {\n        this.set({ performance });\n    }\n\n    @Output() created = new EventEmitter<NgtState>();\n    @Output() pointerMissed = new EventEmitter<MouseEvent>();\n\n    @ViewChild('glCanvas', { static: true }) glCanvas!: ElementRef<HTMLCanvasElement>;\n    @ViewChild('glAnchor', { static: true, read: ViewContainerRef }) glAnchor!: ViewContainerRef;\n\n    private glRef?: ComponentRef<unknown>;\n    private glEnvInjector?: EnvironmentInjector;\n\n    ngOnInit() {\n        if (!this.get('eventSource')) {\n            // set default event source to the host element\n            this.eventSource = this.host.nativeElement;\n        }\n\n        if (this.pointerMissed.observed) {\n            this.store.set({\n                onPointerMissed: (event: MouseEvent) => {\n                    this.pointerMissed.emit(event);\n                    this.cdr.detectChanges();\n                },\n            });\n        }\n\n        // setup NgtStore\n        this.store.init();\n\n        // set rootStateMap\n        rootStateMap.set(this.glCanvas.nativeElement, this.store);\n\n        // subscribe to store to listen for ready state\n        this.hold(this.store.select('ready').pipe(filter((ready) => ready)), () => {\n            this.storeReady();\n        });\n    }\n\n    onResize({ width, height }: NgxResizeResult) {\n        if (width > 0 && height > 0) {\n            if (!this.store.isInit) this.store.init();\n            this.store.configure(this.get(), this.glCanvas.nativeElement);\n        }\n    }\n\n    private storeReady() {\n        // canvas is ready, let's activate the loop\n        this.store.set((state) => ({ internal: { ...state.internal, active: true } }));\n\n        const inputs = this.get();\n        const state = this.store.get();\n\n        // connect to event source\n        state.events.connect?.(is.ref(inputs.eventSource) ? inputs.eventSource.nativeElement : inputs.eventSource);\n\n        // setup compute function for events\n        if (inputs.eventPrefix) {\n            state.setEvents({\n                compute: (event, store) => {\n                    const innerState = store.get();\n                    const x = event[(inputs.eventPrefix + 'X') as keyof NgtDomEvent] as number;\n                    const y = event[(inputs.eventPrefix + 'Y') as keyof NgtDomEvent] as number;\n                    innerState.pointer.set((x / innerState.size.width) * 2 - 1, -(y / innerState.size.height) * 2 + 1);\n                    innerState.raycaster.setFromCamera(innerState.pointer, innerState.camera);\n                },\n            });\n        }\n\n        // emit created event if observed\n        if (this.created.observed) {\n            this.created.emit(this.store.get());\n            this.cdr.detectChanges();\n        }\n\n        // render\n        if (this.glRef) {\n            this.glRef.destroy();\n        }\n\n        requestAnimationFrame(() => {\n            this.glEnvInjector = createEnvironmentInjector(\n                [\n                    provideNgtRenderer({\n                        store: this.store,\n                        changeDetectorRef: this.cdr,\n                        compoundPrefixes: this.compoundPrefixes,\n                    }),\n                ],\n                this.envInjector\n            );\n            this.glRef = this.glAnchor.createComponent(this.sceneGraph, { environmentInjector: this.glEnvInjector });\n            this.glRef.changeDetectorRef.detach();\n\n            // here, we override the detectChanges to also call detectChanges on the ComponentRef\n            this.overrideDetectChanges();\n            this.cdr.detectChanges();\n        });\n    }\n\n    override ngOnDestroy() {\n        if (this.glRef) {\n            this.glRef.destroy();\n        }\n        if (this.glEnvInjector) {\n            this.glEnvInjector.destroy();\n        }\n        injectNgtLoader.destroy();\n        super.ngOnDestroy();\n    }\n\n    private overrideDetectChanges() {\n        const originalDetectChanges = this.cdr.detectChanges.bind(this.cdr);\n        this.cdr.detectChanges = () => {\n            originalDetectChanges();\n            this.glRef?.changeDetectorRef.detectChanges();\n        };\n    }\n}\n"]}
237
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"canvas.js","sourceRoot":"","sources":["../../../../../libs/angular-three/src/lib/canvas.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectorRef,\n    Component,\n    ComponentRef,\n    createEnvironmentInjector,\n    ElementRef,\n    EnvironmentInjector,\n    EventEmitter,\n    HostBinding,\n    inject,\n    Input,\n    OnDestroy,\n    OnInit,\n    Output,\n    Type,\n    ViewChild,\n    ViewContainerRef,\n} from '@angular/core';\nimport { NgxResize, NgxResizeResult, provideNgxResizeOptions } from 'ngx-resize';\nimport { filter } from 'rxjs';\nimport { injectNgtLoader } from './loader';\nimport { provideNgtRenderer } from './renderer/provider';\nimport { NgtRxStore } from './stores/rx-store';\nimport { NgtStore, rootStateMap } from './stores/store';\nimport type { NgtCanvasInputs, NgtDomEvent, NgtDpr, NgtState } from './types';\nimport { is } from './utils/is';\nimport { createPointerEvents } from './web/events';\n\n@Component({\n    selector: 'ngt-canvas',\n    standalone: true,\n    template: `\n        <div (ngxResize)=\"onResize($event)\" style=\"height: 100%; width: 100%;\">\n            <canvas #glCanvas style=\"display: block;\"></canvas>\n        </div>\n    `,\n    imports: [NgxResize],\n    providers: [NgtStore, provideNgxResizeOptions({ emitInZone: false })],\n    styles: [\n        `\n            :host {\n                display: block;\n                position: relative;\n                width: 100%;\n                height: 100%;\n                overflow: hidden;\n            }\n        `,\n    ],\n})\nexport class NgtCanvas extends NgtRxStore<NgtCanvasInputs> implements OnInit, OnDestroy {\n    private readonly cdr = inject(ChangeDetectorRef);\n    private readonly envInjector = inject(EnvironmentInjector);\n    private readonly host = inject(ElementRef) as ElementRef<HTMLElement>;\n    private readonly store = inject(NgtStore);\n\n    override initialize() {\n        super.initialize();\n        this.set({\n            shadows: false,\n            linear: false,\n            flat: false,\n            legacy: false,\n            orthographic: false,\n            frameloop: 'always',\n            dpr: [1, 2],\n            events: createPointerEvents,\n        });\n    }\n\n    @HostBinding('class.ngt-canvas') readonly hostClass = true;\n    @HostBinding('style.pointerEvents') get pointerEvents() {\n        return this.get('eventSource') !== this.host.nativeElement ? 'none' : 'auto';\n    }\n\n    @Input() sceneGraph!: Type<any>;\n    @Input() compoundPrefixes: string[] = [];\n\n    @Input() set linear(linear: boolean) {\n        this.set({ linear });\n    }\n\n    @Input() set legacy(legacy: boolean) {\n        this.set({ legacy });\n    }\n\n    @Input() set flat(flat: boolean) {\n        this.set({ flat });\n    }\n\n    @Input() set orthographic(orthographic: boolean) {\n        this.set({ orthographic });\n    }\n\n    @Input() set frameloop(frameloop: NgtCanvasInputs['frameloop']) {\n        this.set({ frameloop });\n    }\n\n    @Input() set dpr(dpr: NgtDpr) {\n        this.set({ dpr });\n    }\n\n    @Input() set raycaster(raycaster: Partial<THREE.Raycaster>) {\n        this.set({ raycaster });\n    }\n\n    @Input() set shadows(shadows: boolean | Partial<THREE.WebGLShadowMap>) {\n        this.set({\n            shadows: typeof shadows === 'object' ? (shadows as Partial<THREE.WebGLShadowMap>) : shadows,\n        });\n    }\n\n    @Input() set camera(camera: NgtCanvasInputs['camera']) {\n        this.set({ camera });\n    }\n\n    @Input() set gl(gl: NgtCanvasInputs['gl']) {\n        this.set({ gl });\n    }\n\n    @Input() set eventSource(eventSource: NgtCanvasInputs['eventSource']) {\n        this.set({ eventSource });\n    }\n\n    @Input() set eventPrefix(eventPrefix: NgtCanvasInputs['eventPrefix']) {\n        this.set({ eventPrefix });\n    }\n\n    @Input() set lookAt(lookAt: NgtCanvasInputs['lookAt']) {\n        this.set({ lookAt });\n    }\n\n    @Input() set performance(performance: NgtCanvasInputs['performance']) {\n        this.set({ performance });\n    }\n\n    @Output() created = new EventEmitter<NgtState>();\n    @Output() pointerMissed = new EventEmitter<MouseEvent>();\n\n    @ViewChild('glCanvas', { static: true }) glCanvas!: ElementRef<HTMLCanvasElement>;\n    @ViewChild('glCanvas', { static: true, read: ViewContainerRef }) glAnchor!: ViewContainerRef;\n\n    private glRef?: ComponentRef<unknown>;\n    private glEnvInjector?: EnvironmentInjector;\n\n    ngOnInit() {\n        if (!this.get('eventSource')) {\n            // set default event source to the host element\n            this.eventSource = this.host.nativeElement;\n        }\n\n        if (this.pointerMissed.observed) {\n            this.store.set({\n                onPointerMissed: (event: MouseEvent) => {\n                    this.pointerMissed.emit(event);\n                    this.cdr.detectChanges();\n                },\n            });\n        }\n\n        // setup NgtStore\n        this.store.init();\n\n        // set rootStateMap\n        rootStateMap.set(this.glCanvas.nativeElement, this.store);\n\n        // subscribe to store to listen for ready state\n        this.hold(this.store.select('ready').pipe(filter((ready) => ready)), () => {\n            this.storeReady();\n        });\n    }\n\n    onResize({ width, height }: NgxResizeResult) {\n        if (width > 0 && height > 0) {\n            if (!this.store.isInit) this.store.init();\n            this.store.configure(this.get(), this.glCanvas.nativeElement);\n        }\n    }\n\n    private storeReady() {\n        // canvas is ready, let's activate the loop\n        this.store.set((state) => ({ internal: { ...state.internal, active: true } }));\n\n        const inputs = this.get();\n        const state = this.store.get();\n\n        // connect to event source\n        state.events.connect?.(is.ref(inputs.eventSource) ? inputs.eventSource.nativeElement : inputs.eventSource);\n\n        // setup compute function for events\n        if (inputs.eventPrefix) {\n            state.setEvents({\n                compute: (event, store) => {\n                    const innerState = store.get();\n                    const x = event[(inputs.eventPrefix + 'X') as keyof NgtDomEvent] as number;\n                    const y = event[(inputs.eventPrefix + 'Y') as keyof NgtDomEvent] as number;\n                    innerState.pointer.set((x / innerState.size.width) * 2 - 1, -(y / innerState.size.height) * 2 + 1);\n                    innerState.raycaster.setFromCamera(innerState.pointer, innerState.camera);\n                },\n            });\n        }\n\n        // emit created event if observed\n        if (this.created.observed) {\n            this.created.emit(this.store.get());\n            this.cdr.detectChanges();\n        }\n\n        // render\n        if (this.glRef) {\n            this.glRef.destroy();\n        }\n\n        requestAnimationFrame(() => {\n            this.glEnvInjector = createEnvironmentInjector(\n                [\n                    provideNgtRenderer({\n                        store: this.store,\n                        changeDetectorRef: this.cdr,\n                        compoundPrefixes: this.compoundPrefixes,\n                    }),\n                ],\n                this.envInjector\n            );\n            this.glRef = this.glAnchor.createComponent(this.sceneGraph, {\n                environmentInjector: this.glEnvInjector,\n            });\n            this.glRef.changeDetectorRef.detach();\n\n            // here, we override the detectChanges to also call detectChanges on the ComponentRef\n            this.overrideDetectChanges();\n            this.cdr.detectChanges();\n        });\n    }\n\n    override ngOnDestroy() {\n        if (this.glRef) {\n            this.glRef.destroy();\n        }\n        if (this.glEnvInjector) {\n            this.glEnvInjector.destroy();\n        }\n        injectNgtLoader.destroy();\n        super.ngOnDestroy();\n    }\n\n    private overrideDetectChanges() {\n        const originalDetectChanges = this.cdr.detectChanges.bind(this.cdr);\n        this.cdr.detectChanges = () => {\n            originalDetectChanges();\n            this.glRef?.changeDetectorRef.detectChanges();\n        };\n    }\n}\n"]}
@@ -0,0 +1,15 @@
1
+ import { inject } from '@angular/core';
2
+ import { NgtStore } from '../stores/store';
3
+ import { injectNgtDestroy } from './destroy';
4
+ export function injectBeforeRender(cb, priority = 0) {
5
+ try {
6
+ const store = inject(NgtStore);
7
+ const sub = store.get('internal').subscribe((state) => cb(state), priority, store);
8
+ injectNgtDestroy(() => void sub());
9
+ return sub;
10
+ }
11
+ catch (e) {
12
+ throw new Error(`[NGT] "injectBeforeRender" is invoked outside of Constructor Context`);
13
+ }
14
+ }
15
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmVmb3JlLXJlbmRlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvYW5ndWxhci10aHJlZS9zcmMvbGliL2RpL2JlZm9yZS1yZW5kZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN2QyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFFM0MsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sV0FBVyxDQUFDO0FBRTdDLE1BQU0sVUFBVSxrQkFBa0IsQ0FBQyxFQUFxQyxFQUFFLFFBQVEsR0FBRyxDQUFDO0lBQ2xGLElBQUk7UUFDQSxNQUFNLEtBQUssR0FBRyxNQUFNLENBQUMsUUFBUSxDQUFDLENBQUM7UUFDL0IsTUFBTSxHQUFHLEdBQUcsS0FBSyxDQUFDLEdBQUcsQ0FBQyxVQUFVLENBQUMsQ0FBQyxTQUFTLENBQUMsQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLEVBQUUsQ0FBQyxLQUFLLENBQUMsRUFBRSxRQUFRLEVBQUUsS0FBSyxDQUFDLENBQUM7UUFDbkYsZ0JBQWdCLENBQUMsR0FBRyxFQUFFLENBQUMsS0FBSyxHQUFHLEVBQUUsQ0FBQyxDQUFDO1FBQ25DLE9BQU8sR0FBRyxDQUFDO0tBQ2Q7SUFBQyxPQUFPLENBQUMsRUFBRTtRQUNSLE1BQU0sSUFBSSxLQUFLLENBQUMsc0VBQXNFLENBQUMsQ0FBQztLQUMzRjtBQUNMLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBpbmplY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE5ndFN0b3JlIH0gZnJvbSAnLi4vc3RvcmVzL3N0b3JlJztcbmltcG9ydCB7IE5ndEJlZm9yZVJlbmRlclJlY29yZCB9IGZyb20gJy4uL3R5cGVzJztcbmltcG9ydCB7IGluamVjdE5ndERlc3Ryb3kgfSBmcm9tICcuL2Rlc3Ryb3knO1xuXG5leHBvcnQgZnVuY3Rpb24gaW5qZWN0QmVmb3JlUmVuZGVyKGNiOiBOZ3RCZWZvcmVSZW5kZXJSZWNvcmRbJ2NhbGxiYWNrJ10sIHByaW9yaXR5ID0gMCkge1xuICAgIHRyeSB7XG4gICAgICAgIGNvbnN0IHN0b3JlID0gaW5qZWN0KE5ndFN0b3JlKTtcbiAgICAgICAgY29uc3Qgc3ViID0gc3RvcmUuZ2V0KCdpbnRlcm5hbCcpLnN1YnNjcmliZSgoc3RhdGUpID0+IGNiKHN0YXRlKSwgcHJpb3JpdHksIHN0b3JlKTtcbiAgICAgICAgaW5qZWN0Tmd0RGVzdHJveSgoKSA9PiB2b2lkIHN1YigpKTtcbiAgICAgICAgcmV0dXJuIHN1YjtcbiAgICB9IGNhdGNoIChlKSB7XG4gICAgICAgIHRocm93IG5ldyBFcnJvcihgW05HVF0gXCJpbmplY3RCZWZvcmVSZW5kZXJcIiBpcyBpbnZva2VkIG91dHNpZGUgb2YgQ29uc3RydWN0b3IgQ29udGV4dGApO1xuICAgIH1cbn1cbiJdfQ==
@@ -1,4 +1,4 @@
1
- import { isObservable, of, map, tap, from, retry, share, ReplaySubject, catchError, switchMap, forkJoin, take, } from 'rxjs';
1
+ import { catchError, forkJoin, from, isObservable, map, of, ReplaySubject, retry, share, switchMap, take, tap, } from 'rxjs';
2
2
  import { makeObjectGraph } from './utils/make';
3
3
  const cached = new Map();
4
4
  function injectLoader(loaderConstructorFactory, input, extensions, onProgress) {
@@ -52,4 +52,4 @@ injectLoader.preLoad = (loaderConstructorFactory, inputs, extensions) => {
52
52
  injectLoader(loaderConstructorFactory, inputs, extensions).pipe(take(1)).subscribe();
53
53
  };
54
54
  export const injectNgtLoader = injectLoader;
55
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"loader.js","sourceRoot":"","sources":["../../../../../libs/angular-three/src/lib/loader.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    isObservable,\n    Observable,\n    of,\n    map,\n    tap,\n    from,\n    retry,\n    share,\n    ReplaySubject,\n    catchError,\n    switchMap,\n    forkJoin,\n    take,\n} from 'rxjs';\nimport type { GLTF } from 'three/examples/jsm/loaders/GLTFLoader';\nimport type { NgtBranchingReturn, NgtLoaderExtensions, NgtLoaderResult, NgtObjectMap } from './types';\nimport { makeObjectGraph } from './utils/make';\n\ninterface NgtLoader {\n    <TReturnType, TUrl extends string | string[] | Record<string, string>>(\n        loaderConstructorFactory: (inputs: TUrl) => new (...args: any[]) => NgtLoaderResult<TReturnType>,\n        input: TUrl | Observable<TUrl>,\n        extensions?: NgtLoaderExtensions,\n        onProgress?: (event: ProgressEvent) => void\n    ): Observable<\n        TUrl extends string[]\n            ? Array<NgtBranchingReturn<TReturnType, GLTF, GLTF & NgtObjectMap>>\n            : TUrl extends object\n            ? { [key in keyof TUrl]: NgtBranchingReturn<TReturnType, GLTF, GLTF & NgtObjectMap> }\n            : NgtBranchingReturn<TReturnType, GLTF, GLTF & NgtObjectMap>\n    >;\n    destroy: () => void;\n    preLoad: <TReturnType, TUrl extends string | string[] | Record<string, string>>(\n        loaderConstructorFactory: (inputs: TUrl) => new (...args: any[]) => NgtLoaderResult<TReturnType>,\n        inputs: TUrl | Observable<TUrl>,\n        extensions?: NgtLoaderExtensions\n    ) => void;\n}\n\nexport type NgtLoaderResults<\n    TInput extends string | string[] | Record<string, string>,\n    TReturn\n> = TInput extends string[] ? TReturn[] : TInput extends object ? { [key in keyof TInput]: TReturn } : TReturn;\n\nconst cached = new Map<string, Observable<any>>();\n\nfunction injectLoader<TReturnType, TUrl extends string | string[] | Record<string, string>>(\n    loaderConstructorFactory: (inputs: TUrl) => new (...args: any[]) => NgtLoaderResult<TReturnType>,\n    input: TUrl | Observable<TUrl>,\n    extensions?: NgtLoaderExtensions,\n    onProgress?: (event: ProgressEvent) => void\n): Observable<NgtLoaderResults<TUrl, NgtBranchingReturn<TReturnType, GLTF, GLTF & NgtObjectMap>>> {\n    const urls$ = isObservable(input) ? input : of(input);\n\n    return urls$.pipe(\n        map((inputs) => {\n            const loaderConstructor = loaderConstructorFactory(inputs);\n            const loader = new loaderConstructor();\n            if (extensions) {\n                extensions(loader);\n            }\n            const urls = Array.isArray(inputs) ? inputs : typeof inputs === 'string' ? [inputs] : Object.values(inputs);\n            return [\n                urls.map((url) => {\n                    if (!cached.has(url)) {\n                        cached.set(\n                            url,\n                            from(loader.loadAsync(url, onProgress)).pipe(\n                                tap((data) => {\n                                    if (data.scene) {\n                                        Object.assign(data, makeObjectGraph(data.scene));\n                                    }\n                                }),\n                                retry(2),\n                                catchError((err) => {\n                                    console.error(`[NGT] Error loading ${url}: ${err.message}`);\n                                    return of([]);\n                                }),\n                                share({\n                                    connector: () => new ReplaySubject(1),\n                                    resetOnComplete: true,\n                                    resetOnError: true,\n                                    resetOnRefCountZero: true,\n                                })\n                            )\n                        );\n                    }\n                    return cached.get(url);\n                }),\n                inputs,\n            ] as [Array<Observable<any>>, TUrl | TUrl[]];\n        }),\n        switchMap(([observables$, inputs]) => {\n            return forkJoin(observables$).pipe(\n                map((results) => {\n                    if (Array.isArray(inputs)) return results;\n                    if (typeof inputs === 'string') return results[0];\n                    const keys = Object.keys(inputs);\n                    return keys.reduce((result, key) => {\n                        result[key as keyof typeof result] = results[keys.indexOf(key)];\n                        return result;\n                    }, {} as { [key in keyof TUrl]: NgtBranchingReturn<TReturnType, GLTF, GLTF & NgtObjectMap> });\n                })\n            );\n        })\n    );\n}\n\n(injectLoader as NgtLoader).destroy = () => {\n    cached.clear();\n};\n\n(injectLoader as NgtLoader).preLoad = (loaderConstructorFactory, inputs, extensions) => {\n    injectLoader(loaderConstructorFactory, inputs, extensions).pipe(take(1)).subscribe();\n};\n\nexport const injectNgtLoader = injectLoader as NgtLoader;\n"]}
55
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"loader.js","sourceRoot":"","sources":["../../../../../libs/angular-three/src/lib/loader.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    catchError,\n    forkJoin,\n    from,\n    isObservable,\n    map,\n    Observable,\n    of,\n    ReplaySubject,\n    retry,\n    share,\n    switchMap,\n    take,\n    tap,\n} from 'rxjs';\nimport type { GLTF } from 'three/examples/jsm/loaders/GLTFLoader';\nimport type { NgtBranchingReturn, NgtLoaderExtensions, NgtLoaderResult, NgtObjectMap } from './types';\nimport { makeObjectGraph } from './utils/make';\n\ninterface NgtLoader {\n    <TReturnType, TUrl extends string | string[] | Record<string, string>>(\n        loaderConstructorFactory: (inputs: TUrl) => new (...args: any[]) => NgtLoaderResult<TReturnType>,\n        input: TUrl | Observable<TUrl>,\n        extensions?: NgtLoaderExtensions,\n        onProgress?: (event: ProgressEvent) => void\n    ): Observable<\n        TUrl extends string[]\n            ? Array<NgtBranchingReturn<TReturnType, GLTF, GLTF & NgtObjectMap>>\n            : TUrl extends object\n            ? { [key in keyof TUrl]: NgtBranchingReturn<TReturnType, GLTF, GLTF & NgtObjectMap> }\n            : NgtBranchingReturn<TReturnType, GLTF, GLTF & NgtObjectMap>\n    >;\n    destroy: () => void;\n    preLoad: <TReturnType, TUrl extends string | string[] | Record<string, string>>(\n        loaderConstructorFactory: (inputs: TUrl) => new (...args: any[]) => NgtLoaderResult<TReturnType>,\n        inputs: TUrl | Observable<TUrl>,\n        extensions?: NgtLoaderExtensions\n    ) => void;\n}\n\nexport type NgtLoaderResults<\n    TInput extends string | string[] | Record<string, string>,\n    TReturn\n> = TInput extends string[] ? TReturn[] : TInput extends object ? { [key in keyof TInput]: TReturn } : TReturn;\n\nconst cached = new Map<string, Observable<any>>();\n\nfunction injectLoader<TReturnType, TUrl extends string | string[] | Record<string, string>>(\n    loaderConstructorFactory: (inputs: TUrl) => new (...args: any[]) => NgtLoaderResult<TReturnType>,\n    input: TUrl | Observable<TUrl>,\n    extensions?: NgtLoaderExtensions,\n    onProgress?: (event: ProgressEvent) => void\n): Observable<NgtLoaderResults<TUrl, NgtBranchingReturn<TReturnType, GLTF, GLTF & NgtObjectMap>>> {\n    const urls$ = isObservable(input) ? input : of(input);\n\n    return urls$.pipe(\n        map((inputs) => {\n            const loaderConstructor = loaderConstructorFactory(inputs);\n            const loader = new loaderConstructor();\n            if (extensions) {\n                extensions(loader);\n            }\n            const urls = Array.isArray(inputs) ? inputs : typeof inputs === 'string' ? [inputs] : Object.values(inputs);\n            return [\n                urls.map((url) => {\n                    if (!cached.has(url)) {\n                        cached.set(\n                            url,\n                            from(loader.loadAsync(url, onProgress)).pipe(\n                                tap((data) => {\n                                    if (data.scene) {\n                                        Object.assign(data, makeObjectGraph(data.scene));\n                                    }\n                                }),\n                                retry(2),\n                                catchError((err) => {\n                                    console.error(`[NGT] Error loading ${url}: ${err.message}`);\n                                    return of([]);\n                                }),\n                                share({\n                                    connector: () => new ReplaySubject(1),\n                                    resetOnComplete: true,\n                                    resetOnError: true,\n                                    resetOnRefCountZero: true,\n                                })\n                            )\n                        );\n                    }\n                    return cached.get(url);\n                }),\n                inputs,\n            ] as [Array<Observable<any>>, TUrl | TUrl[]];\n        }),\n        switchMap(([observables$, inputs]) => {\n            return forkJoin(observables$).pipe(\n                map((results) => {\n                    if (Array.isArray(inputs)) return results;\n                    if (typeof inputs === 'string') return results[0];\n                    const keys = Object.keys(inputs);\n                    return keys.reduce((result, key) => {\n                        result[key as keyof typeof result] = results[keys.indexOf(key)];\n                        return result;\n                    }, {} as { [key in keyof TUrl]: NgtBranchingReturn<TReturnType, GLTF, GLTF & NgtObjectMap> });\n                })\n            );\n        })\n    );\n}\n\n(injectLoader as NgtLoader).destroy = () => {\n    cached.clear();\n};\n\n(injectLoader as NgtLoader).preLoad = (loaderConstructorFactory, inputs, extensions) => {\n    injectLoader(loaderConstructorFactory, inputs, extensions).pipe(take(1)).subscribe();\n};\n\nexport const injectNgtLoader = injectLoader as NgtLoader;\n"]}
@@ -1,13 +1,109 @@
1
1
  import * as i0 from '@angular/core';
2
- import { ElementRef, Injectable, inject, InjectionToken, ViewContainerRef, TemplateRef, Directive, Input, EventEmitter, getDebugNode, ChangeDetectorRef, RendererFactory2, Component, Output, EnvironmentInjector, createEnvironmentInjector, HostBinding, ViewChild, Pipe } from '@angular/core';
3
- import { injectNgxResize, provideNgxResizeOptions } from 'ngx-resize';
4
- import { BehaviorSubject, startWith, tap, isObservable, of, map, from, retry, catchError, share, ReplaySubject, switchMap, forkJoin, take, filter, distinctUntilChanged, takeUntil, merge } from 'rxjs';
2
+ import { ElementRef, Injectable, inject, InjectionToken, ViewContainerRef, TemplateRef, Directive, Input, EventEmitter, getDebugNode, ChangeDetectorRef, RendererFactory2, EnvironmentInjector, createEnvironmentInjector, Component, HostBinding, Output, ViewChild, Pipe } from '@angular/core';
3
+ import { provideNgxResizeOptions, NgxResize } from 'ngx-resize';
4
+ import { isObservable, of, map, from, tap, retry, catchError, share, ReplaySubject, switchMap, forkJoin, take, BehaviorSubject, startWith, filter, distinctUntilChanged, takeUntil, merge } from 'rxjs';
5
+ import * as THREE from 'three';
5
6
  import { __rest } from 'tslib';
6
7
  import { DOCUMENT, NgForOf } from '@angular/common';
7
8
  import { RxState, selectSlice } from '@rx-angular/state';
8
- import * as THREE from 'three';
9
9
  import { ɵDomRendererFactory2 } from '@angular/platform-browser';
10
10
 
11
+ const idCache = {};
12
+ function makeId(event) {
13
+ if (event) {
14
+ return (event.eventObject || event.object).uuid + '/' + event.index + event.instanceId;
15
+ }
16
+ const newId = THREE.MathUtils.generateUUID();
17
+ // ensure not already used
18
+ if (!idCache[newId]) {
19
+ idCache[newId] = true;
20
+ return newId;
21
+ }
22
+ return makeId();
23
+ }
24
+ function makeDpr(dpr, window) {
25
+ const target = (window === null || window === void 0 ? void 0 : window.devicePixelRatio) || 1;
26
+ return Array.isArray(dpr) ? Math.min(Math.max(dpr[0], target), dpr[1]) : dpr;
27
+ }
28
+ function makeDefaultCamera(isOrthographic, size) {
29
+ if (isOrthographic)
30
+ return new THREE.OrthographicCamera(0, 0, 0, 0, 0.1, 1000);
31
+ return new THREE.PerspectiveCamera(75, size.width / size.height, 0.1, 1000);
32
+ }
33
+ function makeDefaultRenderer(glOptions, canvasElement) {
34
+ const customRenderer = (typeof glOptions === 'function' ? glOptions(canvasElement) : glOptions);
35
+ if ((customRenderer === null || customRenderer === void 0 ? void 0 : customRenderer.render) != null)
36
+ return customRenderer;
37
+ return new THREE.WebGLRenderer(Object.assign({ powerPreference: 'high-performance', canvas: canvasElement, antialias: true, alpha: true }, (glOptions || {})));
38
+ }
39
+ function makeObjectGraph(object) {
40
+ const data = { nodes: {}, materials: {} };
41
+ if (object) {
42
+ object.traverse((child) => {
43
+ if (child.name)
44
+ data.nodes[child.name] = child;
45
+ if ('material' in child && !data.materials[child.material.name]) {
46
+ data.materials[child.material.name] = child
47
+ .material;
48
+ }
49
+ });
50
+ }
51
+ return data;
52
+ }
53
+
54
+ const cached = new Map();
55
+ function injectLoader(loaderConstructorFactory, input, extensions, onProgress) {
56
+ const urls$ = isObservable(input) ? input : of(input);
57
+ return urls$.pipe(map((inputs) => {
58
+ const loaderConstructor = loaderConstructorFactory(inputs);
59
+ const loader = new loaderConstructor();
60
+ if (extensions) {
61
+ extensions(loader);
62
+ }
63
+ const urls = Array.isArray(inputs) ? inputs : typeof inputs === 'string' ? [inputs] : Object.values(inputs);
64
+ return [
65
+ urls.map((url) => {
66
+ if (!cached.has(url)) {
67
+ cached.set(url, from(loader.loadAsync(url, onProgress)).pipe(tap((data) => {
68
+ if (data.scene) {
69
+ Object.assign(data, makeObjectGraph(data.scene));
70
+ }
71
+ }), retry(2), catchError((err) => {
72
+ console.error(`[NGT] Error loading ${url}: ${err.message}`);
73
+ return of([]);
74
+ }), share({
75
+ connector: () => new ReplaySubject(1),
76
+ resetOnComplete: true,
77
+ resetOnError: true,
78
+ resetOnRefCountZero: true,
79
+ })));
80
+ }
81
+ return cached.get(url);
82
+ }),
83
+ inputs,
84
+ ];
85
+ }), switchMap(([observables$, inputs]) => {
86
+ return forkJoin(observables$).pipe(map((results) => {
87
+ if (Array.isArray(inputs))
88
+ return results;
89
+ if (typeof inputs === 'string')
90
+ return results[0];
91
+ const keys = Object.keys(inputs);
92
+ return keys.reduce((result, key) => {
93
+ result[key] = results[keys.indexOf(key)];
94
+ return result;
95
+ }, {});
96
+ }));
97
+ }));
98
+ }
99
+ injectLoader.destroy = () => {
100
+ cached.clear();
101
+ };
102
+ injectLoader.preLoad = (loaderConstructorFactory, inputs, extensions) => {
103
+ injectLoader(loaderConstructorFactory, inputs, extensions).pipe(take(1)).subscribe();
104
+ };
105
+ const injectNgtLoader = injectLoader;
106
+
11
107
  function createSubs(callback, subs) {
12
108
  const sub = { callback };
13
109
  subs.add(sub);
@@ -358,49 +454,6 @@ function applyProps(instance, props) {
358
454
  return instance;
359
455
  }
360
456
 
361
- const idCache = {};
362
- function makeId(event) {
363
- if (event) {
364
- return (event.eventObject || event.object).uuid + '/' + event.index + event.instanceId;
365
- }
366
- const newId = THREE.MathUtils.generateUUID();
367
- // ensure not already used
368
- if (!idCache[newId]) {
369
- idCache[newId] = true;
370
- return newId;
371
- }
372
- return makeId();
373
- }
374
- function makeDpr(dpr, window) {
375
- const target = (window === null || window === void 0 ? void 0 : window.devicePixelRatio) || 1;
376
- return Array.isArray(dpr) ? Math.min(Math.max(dpr[0], target), dpr[1]) : dpr;
377
- }
378
- function makeDefaultCamera(isOrthographic, size) {
379
- if (isOrthographic)
380
- return new THREE.OrthographicCamera(0, 0, 0, 0, 0.1, 1000);
381
- return new THREE.PerspectiveCamera(75, size.width / size.height, 0.1, 1000);
382
- }
383
- function makeDefaultRenderer(glOptions, canvasElement) {
384
- const customRenderer = (typeof glOptions === 'function' ? glOptions(canvasElement) : glOptions);
385
- if ((customRenderer === null || customRenderer === void 0 ? void 0 : customRenderer.render) != null)
386
- return customRenderer;
387
- return new THREE.WebGLRenderer(Object.assign({ powerPreference: 'high-performance', canvas: canvasElement, antialias: true, alpha: true }, (glOptions || {})));
388
- }
389
- function makeObjectGraph(object) {
390
- const data = { nodes: {}, materials: {} };
391
- if (object) {
392
- object.traverse((child) => {
393
- if (child.name)
394
- data.nodes[child.name] = child;
395
- if ('material' in child && !data.materials[child.material.name]) {
396
- data.materials[child.material.name] = child
397
- .material;
398
- }
399
- });
400
- }
401
- return data;
402
- }
403
-
404
457
  const startWithUndefined = () => startWith(undefined);
405
458
  /**
406
459
  * An extended `tap` operator that accepts an `effectFn` which:
@@ -2160,72 +2213,6 @@ function createPointerEvents(store) {
2160
2213
  };
2161
2214
  }
2162
2215
 
2163
- const cached = new Map();
2164
- function injectLoader(loaderConstructorFactory, input, extensions, onProgress) {
2165
- const urls$ = isObservable(input) ? input : of(input);
2166
- return urls$.pipe(map((inputs) => {
2167
- const loaderConstructor = loaderConstructorFactory(inputs);
2168
- const loader = new loaderConstructor();
2169
- if (extensions) {
2170
- extensions(loader);
2171
- }
2172
- const urls = Array.isArray(inputs) ? inputs : typeof inputs === 'string' ? [inputs] : Object.values(inputs);
2173
- return [
2174
- urls.map((url) => {
2175
- if (!cached.has(url)) {
2176
- cached.set(url, from(loader.loadAsync(url, onProgress)).pipe(tap((data) => {
2177
- if (data.scene) {
2178
- Object.assign(data, makeObjectGraph(data.scene));
2179
- }
2180
- }), retry(2), catchError((err) => {
2181
- console.error(`[NGT] Error loading ${url}: ${err.message}`);
2182
- return of([]);
2183
- }), share({
2184
- connector: () => new ReplaySubject(1),
2185
- resetOnComplete: true,
2186
- resetOnError: true,
2187
- resetOnRefCountZero: true,
2188
- })));
2189
- }
2190
- return cached.get(url);
2191
- }),
2192
- inputs,
2193
- ];
2194
- }), switchMap(([observables$, inputs]) => {
2195
- return forkJoin(observables$).pipe(map((results) => {
2196
- if (Array.isArray(inputs))
2197
- return results;
2198
- if (typeof inputs === 'string')
2199
- return results[0];
2200
- const keys = Object.keys(inputs);
2201
- return keys.reduce((result, key) => {
2202
- result[key] = results[keys.indexOf(key)];
2203
- return result;
2204
- }, {});
2205
- }));
2206
- }));
2207
- }
2208
- injectLoader.destroy = () => {
2209
- cached.clear();
2210
- };
2211
- injectLoader.preLoad = (loaderConstructorFactory, inputs, extensions) => {
2212
- injectLoader(loaderConstructorFactory, inputs, extensions).pipe(take(1)).subscribe();
2213
- };
2214
- const injectNgtLoader = injectLoader;
2215
-
2216
- class NgtCanvasContainer {
2217
- constructor() {
2218
- this.canvasResize = injectNgxResize();
2219
- }
2220
- }
2221
- NgtCanvasContainer.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.1", ngImport: i0, type: NgtCanvasContainer, deps: [], target: i0.ɵɵFactoryTarget.Component });
2222
- NgtCanvasContainer.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.1", type: NgtCanvasContainer, isStandalone: true, selector: "ngt-canvas-container", outputs: { canvasResize: "canvasResize" }, providers: [provideNgxResizeOptions({ emitInZone: false })], ngImport: i0, template: '<ng-content />', isInline: true, styles: [":host{display:block;width:100%;height:100%}\n"] });
2223
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.1", ngImport: i0, type: NgtCanvasContainer, decorators: [{
2224
- type: Component,
2225
- args: [{ selector: 'ngt-canvas-container', standalone: true, template: '<ng-content />', providers: [provideNgxResizeOptions({ emitInZone: false })], styles: [":host{display:block;width:100%;height:100%}\n"] }]
2226
- }], propDecorators: { canvasResize: [{
2227
- type: Output
2228
- }] } });
2229
2216
  class NgtCanvas extends NgtRxStore {
2230
2217
  constructor() {
2231
2218
  super(...arguments);
@@ -2364,7 +2351,9 @@ class NgtCanvas extends NgtRxStore {
2364
2351
  compoundPrefixes: this.compoundPrefixes,
2365
2352
  }),
2366
2353
  ], this.envInjector);
2367
- this.glRef = this.glAnchor.createComponent(this.sceneGraph, { environmentInjector: this.glEnvInjector });
2354
+ this.glRef = this.glAnchor.createComponent(this.sceneGraph, {
2355
+ environmentInjector: this.glEnvInjector,
2356
+ });
2368
2357
  this.glRef.changeDetectorRef.detach();
2369
2358
  // here, we override the detectChanges to also call detectChanges on the ComponentRef
2370
2359
  this.overrideDetectChanges();
@@ -2391,20 +2380,18 @@ class NgtCanvas extends NgtRxStore {
2391
2380
  }
2392
2381
  }
2393
2382
  NgtCanvas.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.1", ngImport: i0, type: NgtCanvas, deps: null, target: i0.ɵɵFactoryTarget.Component });
2394
- NgtCanvas.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.1", type: NgtCanvas, isStandalone: true, selector: "ngt-canvas", inputs: { sceneGraph: "sceneGraph", compoundPrefixes: "compoundPrefixes", linear: "linear", legacy: "legacy", flat: "flat", orthographic: "orthographic", frameloop: "frameloop", dpr: "dpr", raycaster: "raycaster", shadows: "shadows", camera: "camera", gl: "gl", eventSource: "eventSource", eventPrefix: "eventPrefix", lookAt: "lookAt", performance: "performance" }, outputs: { created: "created", pointerMissed: "pointerMissed" }, host: { properties: { "class.ngt-canvas": "this.hostClass", "style.pointerEvents": "this.pointerEvents" } }, providers: [NgtStore], viewQueries: [{ propertyName: "glCanvas", first: true, predicate: ["glCanvas"], descendants: true, static: true }, { propertyName: "glAnchor", first: true, predicate: ["glAnchor"], descendants: true, read: ViewContainerRef, static: true }], usesInheritance: true, ngImport: i0, template: `
2395
- <ngt-canvas-container (canvasResize)="onResize($event)">
2383
+ NgtCanvas.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.1", type: NgtCanvas, isStandalone: true, selector: "ngt-canvas", inputs: { sceneGraph: "sceneGraph", compoundPrefixes: "compoundPrefixes", linear: "linear", legacy: "legacy", flat: "flat", orthographic: "orthographic", frameloop: "frameloop", dpr: "dpr", raycaster: "raycaster", shadows: "shadows", camera: "camera", gl: "gl", eventSource: "eventSource", eventPrefix: "eventPrefix", lookAt: "lookAt", performance: "performance" }, outputs: { created: "created", pointerMissed: "pointerMissed" }, host: { properties: { "class.ngt-canvas": "this.hostClass", "style.pointerEvents": "this.pointerEvents" } }, providers: [NgtStore, provideNgxResizeOptions({ emitInZone: false })], viewQueries: [{ propertyName: "glCanvas", first: true, predicate: ["glCanvas"], descendants: true, static: true }, { propertyName: "glAnchor", first: true, predicate: ["glCanvas"], descendants: true, read: ViewContainerRef, static: true }], usesInheritance: true, ngImport: i0, template: `
2384
+ <div (ngxResize)="onResize($event)" style="height: 100%; width: 100%;">
2396
2385
  <canvas #glCanvas style="display: block;"></canvas>
2397
- <ng-container #glAnchor />
2398
- </ngt-canvas-container>
2399
- `, isInline: true, styles: [":host{display:block;position:relative;width:100%;height:100%;overflow:hidden}\n"], dependencies: [{ kind: "component", type: NgtCanvasContainer, selector: "ngt-canvas-container", outputs: ["canvasResize"] }] });
2386
+ </div>
2387
+ `, isInline: true, styles: [":host{display:block;position:relative;width:100%;height:100%;overflow:hidden}\n"], dependencies: [{ kind: "directive", type: NgxResize, selector: "[ngxResize]", inputs: ["ngxResizeOptions"], outputs: ["ngxResize"] }] });
2400
2388
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.1", ngImport: i0, type: NgtCanvas, decorators: [{
2401
2389
  type: Component,
2402
2390
  args: [{ selector: 'ngt-canvas', standalone: true, template: `
2403
- <ngt-canvas-container (canvasResize)="onResize($event)">
2391
+ <div (ngxResize)="onResize($event)" style="height: 100%; width: 100%;">
2404
2392
  <canvas #glCanvas style="display: block;"></canvas>
2405
- <ng-container #glAnchor />
2406
- </ngt-canvas-container>
2407
- `, imports: [NgtCanvasContainer], providers: [NgtStore], styles: [":host{display:block;position:relative;width:100%;height:100%;overflow:hidden}\n"] }]
2393
+ </div>
2394
+ `, imports: [NgxResize], providers: [NgtStore, provideNgxResizeOptions({ emitInZone: false })], styles: [":host{display:block;position:relative;width:100%;height:100%;overflow:hidden}\n"] }]
2408
2395
  }], propDecorators: { hostClass: [{
2409
2396
  type: HostBinding,
2410
2397
  args: ['class.ngt-canvas']
@@ -2452,21 +2439,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.1", ngImpor
2452
2439
  args: ['glCanvas', { static: true }]
2453
2440
  }], glAnchor: [{
2454
2441
  type: ViewChild,
2455
- args: ['glAnchor', { static: true, read: ViewContainerRef }]
2456
- }] } });
2457
-
2458
- class NgtRepeat extends NgForOf {
2459
- set ngForRepeat(count) {
2460
- this.ngForOf = Number.isInteger(count) ? Array.from({ length: count }, (_, i) => i) : [];
2461
- }
2462
- }
2463
- NgtRepeat.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.1", ngImport: i0, type: NgtRepeat, deps: null, target: i0.ɵɵFactoryTarget.Directive });
2464
- NgtRepeat.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.1.1", type: NgtRepeat, isStandalone: true, selector: "[ngFor][ngForRepeat]", inputs: { ngForRepeat: "ngForRepeat" }, usesInheritance: true, ngImport: i0 });
2465
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.1", ngImport: i0, type: NgtRepeat, decorators: [{
2466
- type: Directive,
2467
- args: [{ selector: '[ngFor][ngForRepeat]', standalone: true }]
2468
- }], propDecorators: { ngForRepeat: [{
2469
- type: Input
2442
+ args: ['glCanvas', { static: true, read: ViewContainerRef }]
2470
2443
  }] } });
2471
2444
 
2472
2445
  /**
@@ -2491,6 +2464,18 @@ function injectNgtDestroy(cb) {
2491
2464
  }
2492
2465
  }
2493
2466
 
2467
+ function injectBeforeRender(cb, priority = 0) {
2468
+ try {
2469
+ const store = inject(NgtStore);
2470
+ const sub = store.get('internal').subscribe((state) => cb(state), priority, store);
2471
+ injectNgtDestroy(() => void sub());
2472
+ return sub;
2473
+ }
2474
+ catch (e) {
2475
+ throw new Error(`[NGT] "injectBeforeRender" is invoked outside of Constructor Context`);
2476
+ }
2477
+ }
2478
+
2494
2479
  function injectNgtRef(initialValue = null) {
2495
2480
  let ref = new ElementRef(initialValue);
2496
2481
  if (is.ref(initialValue)) {
@@ -2557,6 +2542,20 @@ function injectNgtRef(initialValue = null) {
2557
2542
  return Object.assign(ref, { subscribe, $, children$, useCDR: (cdr) => void cdRefs.push(cdr) });
2558
2543
  }
2559
2544
 
2545
+ class NgtRepeat extends NgForOf {
2546
+ set ngForRepeat(count) {
2547
+ this.ngForOf = Number.isInteger(count) ? Array.from({ length: count }, (_, i) => i) : [];
2548
+ }
2549
+ }
2550
+ NgtRepeat.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.1", ngImport: i0, type: NgtRepeat, deps: null, target: i0.ɵɵFactoryTarget.Directive });
2551
+ NgtRepeat.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.1.1", type: NgtRepeat, isStandalone: true, selector: "[ngFor][ngForRepeat]", inputs: { ngForRepeat: "ngForRepeat" }, usesInheritance: true, ngImport: i0 });
2552
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.1", ngImport: i0, type: NgtRepeat, decorators: [{
2553
+ type: Directive,
2554
+ args: [{ selector: '[ngFor][ngForRepeat]', standalone: true }]
2555
+ }], propDecorators: { ngForRepeat: [{
2556
+ type: Input
2557
+ }] } });
2558
+
2560
2559
  function isPromise(value) {
2561
2560
  return ((value instanceof Promise || Object.prototype.toString.call(value) === '[object Promise]') &&
2562
2561
  typeof value['then'] === 'function');
@@ -2612,5 +2611,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.1", ngImpor
2612
2611
  * Generated bundle index. Do not edit.
2613
2612
  */
2614
2613
 
2615
- export { NGT_CATALOGUE, NgtArgs, NgtCanvas, NgtCanvasContainer, NgtPush, NgtRepeat, NgtRxStore, NgtStore, checkNeedsUpdate, checkUpdate, extend, getLocalState, injectNgtDestroy, injectNgtLoader, injectNgtRef, invalidateInstance, is, prepare, rootStateMap, startWithUndefined, updateCamera };
2614
+ export { NGT_CATALOGUE, NgtArgs, NgtCanvas, NgtPush, NgtRepeat, NgtRxStore, NgtStore, checkNeedsUpdate, checkUpdate, extend, getLocalState, injectBeforeRender, injectNgtDestroy, injectNgtLoader, injectNgtRef, invalidateInstance, is, prepare, rootStateMap, startWithUndefined, updateCamera };
2616
2615
  //# sourceMappingURL=angular-three.mjs.map