angular-three-soba 2.0.0-beta.2 → 2.0.0-beta.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (32) hide show
  1. package/abstractions/grid/grid.d.ts +59 -0
  2. package/abstractions/index.d.ts +1 -0
  3. package/abstractions/text/text.d.ts +0 -1
  4. package/esm2022/abstractions/gizmo-helper/gizmo-helper.mjs +2 -2
  5. package/esm2022/abstractions/grid/grid.mjs +150 -0
  6. package/esm2022/abstractions/index.mjs +2 -1
  7. package/esm2022/abstractions/text/text.mjs +2 -4
  8. package/esm2022/materials/mesh-refraction-material/mesh-refraction-material.mjs +4 -3
  9. package/esm2022/misc/animations/animations.mjs +20 -20
  10. package/esm2022/shaders/grid-material/grid-material.mjs +62 -0
  11. package/esm2022/shaders/index.mjs +2 -1
  12. package/esm2022/staging/accumulative-shadows/accumulative-shadows.mjs +2 -2
  13. package/esm2022/staging/caustics/caustisc.mjs +2 -2
  14. package/esm2022/staging/environment/environment-portal.mjs +2 -2
  15. package/fesm2022/angular-three-soba-abstractions.mjs +148 -6
  16. package/fesm2022/angular-three-soba-abstractions.mjs.map +1 -1
  17. package/fesm2022/angular-three-soba-materials.mjs +3 -2
  18. package/fesm2022/angular-three-soba-materials.mjs.map +1 -1
  19. package/fesm2022/angular-three-soba-misc.mjs +19 -19
  20. package/fesm2022/angular-three-soba-misc.mjs.map +1 -1
  21. package/fesm2022/angular-three-soba-shaders.mjs +61 -1
  22. package/fesm2022/angular-three-soba-shaders.mjs.map +1 -1
  23. package/fesm2022/angular-three-soba-staging.mjs +3 -3
  24. package/fesm2022/angular-three-soba-staging.mjs.map +1 -1
  25. package/misc/animations/animations.d.ts +1 -1
  26. package/package.json +8 -10
  27. package/plugin/package.json +2 -2
  28. package/plugin/src/generators/init/init.d.ts +3 -0
  29. package/plugin/src/generators/init/init.js +7 -1
  30. package/plugin/src/generators/init/init.js.map +1 -1
  31. package/shaders/grid-material/grid-material.d.ts +4 -0
  32. package/shaders/index.d.ts +1 -0
@@ -0,0 +1,59 @@
1
+ import { NgtSignalStore } from 'angular-three';
2
+ import * as THREE from 'three';
3
+ import * as i0 from "@angular/core";
4
+ export interface NgtsGridState {
5
+ /** Cell size, default: 0.5 */
6
+ cellSize: number;
7
+ /** Cell thickness, default: 0.5 */
8
+ cellThickness: number;
9
+ /** Cell color, default: black */
10
+ cellColor: THREE.ColorRepresentation;
11
+ /** Section size, default: 1 */
12
+ sectionSize: number;
13
+ /** Section thickness, default: 1 */
14
+ sectionThickness: number;
15
+ /** Section color, default: #2080ff */
16
+ sectionColor: THREE.ColorRepresentation;
17
+ /** Follow camera, default: false */
18
+ followCamera: boolean;
19
+ /** Display the grid infinitely, default: false */
20
+ infiniteGrid: boolean;
21
+ /** Fade distance, default: 100 */
22
+ fadeDistance: number;
23
+ /** Fade strength, default: 1 */
24
+ fadeStrength: number;
25
+ /** Material side, default: THREE.BackSide */
26
+ side: THREE.Side;
27
+ /** Default plane-geometry arguments */
28
+ args: ConstructorParameters<typeof THREE.PlaneGeometry>;
29
+ }
30
+ export declare class NgtsGrid extends NgtSignalStore<NgtsGridState> {
31
+ gridRef: import("angular-three").NgtInjectedRef<THREE.Mesh<THREE.BufferGeometry, THREE.Material | THREE.Material[]>>;
32
+ set cellSize(cellSize: NgtsGridState['cellSize']);
33
+ set cellThickness(cellThickness: NgtsGridState['cellThickness']);
34
+ set cellColor(cellColor: NgtsGridState['cellColor']);
35
+ set sectionSize(sectionSize: NgtsGridState['sectionSize']);
36
+ set sectionThickness(sectionThickness: NgtsGridState['sectionThickness']);
37
+ set sectionColor(sectionColor: NgtsGridState['sectionColor']);
38
+ set followCamera(followCamera: NgtsGridState['followCamera']);
39
+ set infiniteGrid(infiniteGrid: NgtsGridState['infiniteGrid']);
40
+ set fadeDistance(fadeDistance: NgtsGridState['fadeDistance']);
41
+ set fadeStrength(fadeStrength: NgtsGridState['fadeStrength']);
42
+ set side(side: NgtsGridState['side']);
43
+ set args(args: NgtsGridState['args']);
44
+ readonly gridCellSize: import("@angular/core").Signal<number>;
45
+ readonly gridSectionSize: import("@angular/core").Signal<number>;
46
+ readonly gridFadeDistance: import("@angular/core").Signal<number>;
47
+ readonly gridFadeStrength: import("@angular/core").Signal<number>;
48
+ readonly gridCellThickness: import("@angular/core").Signal<number>;
49
+ readonly gridSectionThickness: import("@angular/core").Signal<number>;
50
+ readonly gridInfiniteGrid: import("@angular/core").Signal<boolean>;
51
+ readonly gridFollowCamera: import("@angular/core").Signal<boolean>;
52
+ readonly gridCellColor: import("@angular/core").Signal<THREE.ColorRepresentation>;
53
+ readonly gridSectionColor: import("@angular/core").Signal<THREE.ColorRepresentation>;
54
+ readonly gridSide: import("@angular/core").Signal<THREE.Side>;
55
+ readonly gridArgs: import("@angular/core").Signal<[width?: number | undefined, height?: number | undefined, widthSegments?: number | undefined, heightSegments?: number | undefined]>;
56
+ constructor();
57
+ static ɵfac: i0.ɵɵFactoryDeclaration<NgtsGrid, never>;
58
+ static ɵcmp: i0.ɵɵComponentDeclaration<NgtsGrid, "ngts-grid", never, { "gridRef": { "alias": "gridRef"; "required": false; }; "cellSize": { "alias": "cellSize"; "required": false; }; "cellThickness": { "alias": "cellThickness"; "required": false; }; "cellColor": { "alias": "cellColor"; "required": false; }; "sectionSize": { "alias": "sectionSize"; "required": false; }; "sectionThickness": { "alias": "sectionThickness"; "required": false; }; "sectionColor": { "alias": "sectionColor"; "required": false; }; "followCamera": { "alias": "followCamera"; "required": false; }; "infiniteGrid": { "alias": "infiniteGrid"; "required": false; }; "fadeDistance": { "alias": "fadeDistance"; "required": false; }; "fadeStrength": { "alias": "fadeStrength"; "required": false; }; "side": { "alias": "side"; "required": false; }; "args": { "alias": "args"; "required": false; }; }, {}, never, never, true, never>;
59
+ }
@@ -5,6 +5,7 @@ export * from './edges/edges';
5
5
  export * from './gizmo-helper/gizmo-helper';
6
6
  export * from './gizmo-helper/gizmo-viewcube/gizmo-viewcube';
7
7
  export * from './gizmo-helper/gizmo-viewport/gizmo-viewport';
8
+ export * from './grid/grid';
8
9
  export * from './line/line';
9
10
  export * from './quadratic-bezier-line/quadratic-bezier-line';
10
11
  export * from './text-3d/text-3d';
@@ -70,7 +70,6 @@ export declare class NgtsText extends NgtSignalStore<NgtsTextState> {
70
70
  set debugSDF(debugSDF: boolean);
71
71
  sync: EventEmitter<Text>;
72
72
  readonly troikaText: any;
73
- readonly state: import("@angular/core").Signal<NgtsTextState>;
74
73
  constructor();
75
74
  static ɵfac: i0.ɵɵFactoryDeclaration<NgtsText, never>;
76
75
  static ɵcmp: i0.ɵɵComponentDeclaration<NgtsText, "ngts-text", never, { "textRef": { "alias": "textRef"; "required": false; }; "text": { "alias": "text"; "required": true; }; "font": { "alias": "font"; "required": false; }; "fontSize": { "alias": "fontSize"; "required": false; }; "anchorX": { "alias": "anchorX"; "required": false; }; "anchorY": { "alias": "anchorY"; "required": false; }; "sdfGlyphSize": { "alias": "sdfGlyphSize"; "required": false; }; "characters": { "alias": "characters"; "required": false; }; "color": { "alias": "color"; "required": false; }; "maxWidth": { "alias": "maxWidth"; "required": false; }; "lineHeight": { "alias": "lineHeight"; "required": false; }; "letterSpacing": { "alias": "letterSpacing"; "required": false; }; "textAlign": { "alias": "textAlign"; "required": false; }; "clipRect": { "alias": "clipRect"; "required": false; }; "depthOffset": { "alias": "depthOffset"; "required": false; }; "direction": { "alias": "direction"; "required": false; }; "overflowWrap": { "alias": "overflowWrap"; "required": false; }; "whiteSpace": { "alias": "whiteSpace"; "required": false; }; "outlineWidth": { "alias": "outlineWidth"; "required": false; }; "outlineOffsetX": { "alias": "outlineOffsetX"; "required": false; }; "outlineOffsetY": { "alias": "outlineOffsetY"; "required": false; }; "outlineBlur": { "alias": "outlineBlur"; "required": false; }; "outlineColor": { "alias": "outlineColor"; "required": false; }; "outlineOpacity": { "alias": "outlineOpacity"; "required": false; }; "strokeWidth": { "alias": "strokeWidth"; "required": false; }; "strokeColor": { "alias": "strokeColor"; "required": false; }; "strokeOpacity": { "alias": "strokeOpacity"; "required": false; }; "fillOpacity": { "alias": "fillOpacity"; "required": false; }; "debugSDF": { "alias": "debugSDF"; "required": false; }; }, { "sync": "sync"; }, never, ["*"], true, never>;
@@ -165,7 +165,7 @@ class NgtsGizmoHelper extends NgtSignalStore {
165
165
  </ngt-group>
166
166
  </ng-template>
167
167
  </ngt-portal>
168
- `, isInline: true, dependencies: [{ kind: "component", type: NgtPortal, selector: "ngt-portal", inputs: ["container", "state", "autoRender", "autoRenderPriority"], outputs: ["beforeRender"] }, { kind: "directive", type: NgtPortalContent, selector: "ng-template[ngtPortalContent]" }, { kind: "component", type: NgtsOrthographicCamera, selector: "ngts-orthographic-camera", inputs: ["left", "right", "top", "bottom"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }] }); }
168
+ `, isInline: true, dependencies: [{ kind: "component", type: NgtPortal, selector: "ngt-portal", inputs: ["container", "portalState", "autoRender", "autoRenderPriority"], outputs: ["beforeRender"] }, { kind: "directive", type: NgtPortalContent, selector: "ng-template[ngtPortalContent]" }, { kind: "component", type: NgtsOrthographicCamera, selector: "ngts-orthographic-camera", inputs: ["left", "right", "top", "bottom"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }] }); }
169
169
  }
170
170
  export { NgtsGizmoHelper };
171
171
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NgtsGizmoHelper, decorators: [{
@@ -207,4 +207,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImpor
207
207
  type: ContentChild,
208
208
  args: [NgtsGizmoHelperContent, { static: true, read: TemplateRef }]
209
209
  }] } });
210
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gizmo-helper.js","sourceRoot":"","sources":["../../../../../../libs/soba/abstractions/src/gizmo-helper/gizmo-helper.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgTemplateOutlet } from '@angular/common';\nimport {\n    Component,\n    computed,\n    ContentChild,\n    CUSTOM_ELEMENTS_SCHEMA,\n    Directive,\n    effect,\n    EventEmitter,\n    inject,\n    InjectionToken,\n    Input,\n    Output,\n    Signal,\n    TemplateRef,\n} from '@angular/core';\nimport { extend, injectNgtRef, NgtPortal, NgtPortalContent, NgtSignalStore, NgtStore } from 'angular-three';\nimport { NgtsOrthographicCamera } from 'angular-three-soba/cameras';\nimport { Group, Matrix4, Object3D, OrthographicCamera, Quaternion, Vector3 } from 'three';\nimport { OrbitControls } from 'three-stdlib';\n\ntype ControlsProto = { update(): void; target: THREE.Vector3 };\n\nconst isOrbitControls = (controls: ControlsProto): controls is OrbitControls =>\n    'minPolarAngle' in (controls as OrbitControls);\n\nexport type NgtsGizmoHelperApi = (direction: Vector3) => void;\nexport const NGTS_GIZMO_HELPER_API = new InjectionToken<Signal<NgtsGizmoHelperApi>>('NgtsGizmoHelper API');\n\nextend({ Group });\n\nexport interface NgtsGizmoHelperState {\n    alignment:\n        | 'top-left'\n        | 'top-right'\n        | 'bottom-right'\n        | 'bottom-left'\n        | 'bottom-center'\n        | 'center-right'\n        | 'center-left'\n        | 'center-center'\n        | 'top-center';\n    margin: [number, number];\n    renderPriority: number;\n    autoClear: boolean;\n}\n\n@Directive({ selector: 'ng-template[ngtsGizmoHelperContent]', standalone: true })\nexport class NgtsGizmoHelperContent {}\n\n@Component({\n    selector: 'ngts-gizmo-helper',\n    standalone: true,\n    template: `\n        <ngt-portal [renderPriority]=\"priority()\">\n            <ng-template ngtPortalContent>\n                <ngts-orthographic-camera\n                    [cameraRef]=\"virtualCameraRef\"\n                    [makeDefault]=\"true\"\n                    [position]=\"[0, 0, 200]\"\n                />\n                <ngt-group [ref]=\"gizmoRef\" [position]=\"position()\" (beforeRender)=\"onBeforeRender($event.state.delta)\">\n                    <ng-container *ngTemplateOutlet=\"gizmoHelperContent\" />\n                </ngt-group>\n            </ng-template>\n        </ngt-portal>\n    `,\n    imports: [NgtPortal, NgtPortalContent, NgtsOrthographicCamera, NgTemplateOutlet],\n    providers: [\n        { provide: NGTS_GIZMO_HELPER_API, useFactory: (gizmo: NgtsGizmoHelper) => gizmo.api, deps: [NgtsGizmoHelper] },\n    ],\n    schemas: [CUSTOM_ELEMENTS_SCHEMA],\n})\nexport class NgtsGizmoHelper extends NgtSignalStore<NgtsGizmoHelperState> {\n    readonly gizmoRef = injectNgtRef<Group>();\n    readonly virtualCameraRef = injectNgtRef<OrthographicCamera>();\n\n    @Input() set alignment(\n        alignment:\n            | 'top-left'\n            | 'top-right'\n            | 'bottom-right'\n            | 'bottom-left'\n            | 'bottom-center'\n            | 'center-right'\n            | 'center-left'\n            | 'center-center'\n            | 'top-center'\n    ) {\n        this.set({ alignment });\n    }\n\n    @Input() set margin(margin: [number, number]) {\n        this.set({ margin });\n    }\n\n    @Input() set renderPriority(renderPriority: number) {\n        this.set({ renderPriority });\n    }\n\n    @Input() set autoClear(autoClear: boolean) {\n        this.set({ autoClear });\n    }\n\n    @Output() updated = new EventEmitter<void>();\n\n    @ContentChild(NgtsGizmoHelperContent, { static: true, read: TemplateRef })\n    gizmoHelperContent!: TemplateRef<unknown>;\n\n    readonly #store = inject(NgtStore);\n    readonly #camera = this.#store.select('camera');\n    readonly #size = this.#store.select('size');\n\n    readonly #alignment = this.select('alignment');\n    readonly #margin = this.select('margin');\n\n    #animating = false;\n    #radius = 0;\n    #focusPoint = new Vector3(0, 0, 0);\n    #q1 = new Quaternion();\n    #q2 = new Quaternion();\n    #target = new Vector3();\n    #targetPosition = new Vector3();\n    #dummy = new Object3D();\n\n    #defaultUp = new Vector3(0, 0, 0);\n    #turnRate = 2 * Math.PI; // turn rate in angles per sec\n    #matrix = new Matrix4();\n\n    readonly priority = this.select('renderPriority');\n\n    readonly position = computed(() => {\n        const size = this.#size();\n        const alignment = this.#alignment();\n        const margin = this.#margin();\n\n        const [marginX, marginY] = margin;\n        const x = alignment.endsWith('-center')\n            ? 0\n            : alignment.endsWith('-left')\n            ? -size.width / 2 + marginX\n            : size.width / 2 - marginX;\n        const y = alignment.startsWith('center-')\n            ? 0\n            : alignment.startsWith('top-')\n            ? size.height / 2 - marginY\n            : -size.height / 2 + marginY;\n\n        return [x, y, 0];\n    });\n\n    readonly api = computed(() => (direction: THREE.Vector3) => {\n        const { controls, camera, invalidate } = this.#store.get();\n        const defaultControls = controls as unknown as ControlsProto;\n\n        this.#animating = true;\n        if (defaultControls) this.#focusPoint = defaultControls.target;\n        this.#radius = camera.position.distanceTo(this.#target);\n        // rotate from current camera orientation\n        this.#q1.copy(camera.quaternion);\n        // to new current camera orientation\n        this.#targetPosition.copy(direction).multiplyScalar(this.#radius).add(this.#target);\n        this.#dummy.lookAt(this.#targetPosition);\n        this.#q2.copy(this.#dummy.quaternion);\n        invalidate();\n    });\n\n    constructor() {\n        super({ alignment: 'bottom-right', margin: [80, 80], renderPriority: 1 });\n        this.#updateDefaultUp();\n    }\n\n    onBeforeRender(delta: number) {\n        if (this.virtualCameraRef.nativeElement && this.gizmoRef.nativeElement) {\n            const { controls, camera: mainCamera, invalidate } = this.#store.get();\n            const defaultControls = controls as unknown as ControlsProto;\n            // Animate step\n            if (this.#animating) {\n                if (this.#q1.angleTo(this.#q2) < 0.01) {\n                    this.#animating = false;\n                    // Orbit controls uses UP vector as the orbit axes,\n                    // so we need to reset it after the animation is done\n                    // moving it around for the controls to work correctly\n                    if (isOrbitControls(defaultControls)) {\n                        mainCamera.up.copy(this.#defaultUp);\n                    }\n                } else {\n                    const step = delta * this.#turnRate;\n                    // animate position by doing a slerp and then scaling the position on the unit sphere\n                    this.#q1.rotateTowards(this.#q2, step);\n                    // animate orientation\n                    mainCamera.position\n                        .set(0, 0, 1)\n                        .applyQuaternion(this.#q1)\n                        .multiplyScalar(this.#radius)\n                        .add(this.#focusPoint);\n                    mainCamera.up.set(0, 1, 0).applyQuaternion(this.#q1).normalize();\n                    mainCamera.quaternion.copy(this.#q1);\n                    if (this.updated.observed) this.updated.emit();\n                    else if (defaultControls) {\n                        defaultControls.update();\n                    }\n                    invalidate();\n                }\n            }\n\n            // Sync Gizmo with main camera orientation\n            this.#matrix.copy(mainCamera.matrix).invert();\n            this.gizmoRef.nativeElement.quaternion.setFromRotationMatrix(this.#matrix);\n        }\n    }\n\n    #updateDefaultUp() {\n        effect(() => {\n            const camera = this.#camera();\n            if (!camera) return;\n            this.#defaultUp.copy(camera.up);\n        });\n    }\n}\n"]}
210
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gizmo-helper.js","sourceRoot":"","sources":["../../../../../../libs/soba/abstractions/src/gizmo-helper/gizmo-helper.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgTemplateOutlet } from '@angular/common';\nimport {\n    Component,\n    computed,\n    ContentChild,\n    CUSTOM_ELEMENTS_SCHEMA,\n    Directive,\n    effect,\n    EventEmitter,\n    inject,\n    InjectionToken,\n    Input,\n    Output,\n    Signal,\n    TemplateRef,\n} from '@angular/core';\nimport { extend, injectNgtRef, NgtPortal, NgtPortalContent, NgtSignalStore, NgtStore } from 'angular-three';\nimport { NgtsOrthographicCamera } from 'angular-three-soba/cameras';\nimport { Group, Matrix4, Object3D, OrthographicCamera, Quaternion, Vector3 } from 'three';\nimport { OrbitControls } from 'three-stdlib';\n\ntype ControlsProto = { update(): void; target: THREE.Vector3 };\n\nconst isOrbitControls = (controls: ControlsProto): controls is OrbitControls =>\n    'minPolarAngle' in (controls as OrbitControls);\n\nexport type NgtsGizmoHelperApi = (direction: Vector3) => void;\nexport const NGTS_GIZMO_HELPER_API = new InjectionToken<Signal<NgtsGizmoHelperApi>>('NgtsGizmoHelper API');\n\nextend({ Group });\n\nexport interface NgtsGizmoHelperState {\n    alignment:\n        | 'top-left'\n        | 'top-right'\n        | 'bottom-right'\n        | 'bottom-left'\n        | 'bottom-center'\n        | 'center-right'\n        | 'center-left'\n        | 'center-center'\n        | 'top-center';\n    margin: [number, number];\n    renderPriority: number;\n    autoClear: boolean;\n}\n\n@Directive({ selector: 'ng-template[ngtsGizmoHelperContent]', standalone: true })\nexport class NgtsGizmoHelperContent {}\n\n@Component({\n    selector: 'ngts-gizmo-helper',\n    standalone: true,\n    template: `\n        <ngt-portal [renderPriority]=\"priority()\">\n            <ng-template ngtPortalContent>\n                <ngts-orthographic-camera\n                    [cameraRef]=\"virtualCameraRef\"\n                    [makeDefault]=\"true\"\n                    [position]=\"[0, 0, 200]\"\n                />\n                <ngt-group [ref]=\"gizmoRef\" [position]=\"position()\" (beforeRender)=\"onBeforeRender($event.state.delta)\">\n                    <ng-container *ngTemplateOutlet=\"gizmoHelperContent\" />\n                </ngt-group>\n            </ng-template>\n        </ngt-portal>\n    `,\n    imports: [NgtPortal, NgtPortalContent, NgtsOrthographicCamera, NgTemplateOutlet],\n    providers: [\n        { provide: NGTS_GIZMO_HELPER_API, useFactory: (gizmo: NgtsGizmoHelper) => gizmo.api, deps: [NgtsGizmoHelper] },\n    ],\n    schemas: [CUSTOM_ELEMENTS_SCHEMA],\n})\nexport class NgtsGizmoHelper extends NgtSignalStore<NgtsGizmoHelperState> {\n    readonly gizmoRef = injectNgtRef<Group>();\n    readonly virtualCameraRef = injectNgtRef<OrthographicCamera>();\n\n    @Input() set alignment(\n        alignment:\n            | 'top-left'\n            | 'top-right'\n            | 'bottom-right'\n            | 'bottom-left'\n            | 'bottom-center'\n            | 'center-right'\n            | 'center-left'\n            | 'center-center'\n            | 'top-center'\n    ) {\n        this.set({ alignment });\n    }\n\n    @Input() set margin(margin: [number, number]) {\n        this.set({ margin });\n    }\n\n    @Input() set renderPriority(renderPriority: number) {\n        this.set({ renderPriority });\n    }\n\n    @Input() set autoClear(autoClear: boolean) {\n        this.set({ autoClear });\n    }\n\n    @Output() updated = new EventEmitter<void>();\n\n    @ContentChild(NgtsGizmoHelperContent, { static: true, read: TemplateRef })\n    gizmoHelperContent!: TemplateRef<unknown>;\n\n    readonly #store = inject(NgtStore);\n    readonly #camera = this.#store.select('camera');\n    readonly #size = this.#store.select('size');\n\n    readonly #alignment = this.select('alignment');\n    readonly #margin = this.select('margin');\n\n    #animating = false;\n    #radius = 0;\n    #focusPoint = new Vector3(0, 0, 0);\n    #q1 = new Quaternion();\n    #q2 = new Quaternion();\n    #target = new Vector3();\n    #targetPosition = new Vector3();\n    #dummy = new Object3D();\n\n    #defaultUp = new Vector3(0, 0, 0);\n    #turnRate = 2 * Math.PI; // turn rate in angles per sec\n    #matrix = new Matrix4();\n\n    readonly priority = this.select('renderPriority');\n\n    readonly position = computed(() => {\n        const size = this.#size();\n        const alignment = this.#alignment();\n        const margin = this.#margin();\n\n        const [marginX, marginY] = margin;\n        const x = alignment.endsWith('-center')\n            ? 0\n            : alignment.endsWith('-left')\n            ? -size.width / 2 + marginX\n            : size.width / 2 - marginX;\n        const y = alignment.startsWith('center-')\n            ? 0\n            : alignment.startsWith('top-')\n            ? size.height / 2 - marginY\n            : -size.height / 2 + marginY;\n\n        return [x, y, 0];\n    });\n\n    readonly api = computed(() => (direction: THREE.Vector3) => {\n        const { controls, camera, invalidate } = this.#store.get();\n        const defaultControls = controls as unknown as ControlsProto;\n\n        this.#animating = true;\n        if (defaultControls) this.#focusPoint = defaultControls.target;\n        this.#radius = camera.position.distanceTo(this.#target);\n        // rotate from current camera orientation\n        this.#q1.copy(camera.quaternion);\n        // to new current camera orientation\n        this.#targetPosition.copy(direction).multiplyScalar(this.#radius).add(this.#target);\n        this.#dummy.lookAt(this.#targetPosition);\n        this.#q2.copy(this.#dummy.quaternion);\n        invalidate();\n    });\n\n    constructor() {\n        super({ alignment: 'bottom-right', margin: [80, 80], renderPriority: 1 });\n        this.#updateDefaultUp();\n    }\n\n    onBeforeRender(delta: number) {\n        if (this.virtualCameraRef.nativeElement && this.gizmoRef.nativeElement) {\n            const { controls, camera: mainCamera, invalidate } = this.#store.get();\n            const defaultControls = controls as unknown as ControlsProto;\n            // Animate step\n            if (this.#animating) {\n                if (this.#q1.angleTo(this.#q2) < 0.01) {\n                    this.#animating = false;\n                    // Orbit controls uses UP vector as the orbit axes,\n                    // so we need to reset it after the animation is done\n                    // moving it around for the controls to work correctly\n                    if (isOrbitControls(defaultControls)) {\n                        mainCamera.up.copy(this.#defaultUp);\n                    }\n                } else {\n                    const step = delta * this.#turnRate;\n                    // animate position by doing a slerp and then scaling the position on the unit sphere\n                    this.#q1.rotateTowards(this.#q2, step);\n                    // animate orientation\n                    mainCamera.position\n                        .set(0, 0, 1)\n                        .applyQuaternion(this.#q1)\n                        .multiplyScalar(this.#radius)\n                        .add(this.#focusPoint);\n                    mainCamera.up.set(0, 1, 0).applyQuaternion(this.#q1).normalize();\n                    mainCamera.quaternion.copy(this.#q1);\n                    if (this.updated.observed) this.updated.emit();\n                    else if (defaultControls) {\n                        defaultControls.update();\n                    }\n                    invalidate();\n                }\n            }\n\n            // Sync Gizmo with main camera orientation\n            this.#matrix.copy(mainCamera.matrix).invert();\n            this.gizmoRef.nativeElement.quaternion.setFromRotationMatrix(this.#matrix);\n        }\n    }\n\n    #updateDefaultUp() {\n        effect(() => {\n            const camera = this.#camera();\n            if (!camera) return;\n            this.#defaultUp.copy(camera.up);\n        });\n    }\n}\n"]}
@@ -0,0 +1,150 @@
1
+ import { CUSTOM_ELEMENTS_SCHEMA, Component, Input } from '@angular/core';
2
+ import { NgtArgs, NgtSignalStore, extend, injectNgtRef } from 'angular-three';
3
+ import { GridMaterial } from 'angular-three-soba/shaders';
4
+ import * as THREE from 'three';
5
+ import { Mesh, PlaneGeometry } from 'three';
6
+ import * as i0 from "@angular/core";
7
+ extend({ Mesh, GridMaterial, PlaneGeometry });
8
+ class NgtsGrid extends NgtSignalStore {
9
+ set cellSize(cellSize) {
10
+ this.set({ cellSize });
11
+ }
12
+ set cellThickness(cellThickness) {
13
+ this.set({ cellThickness });
14
+ }
15
+ set cellColor(cellColor) {
16
+ this.set({ cellColor });
17
+ }
18
+ set sectionSize(sectionSize) {
19
+ this.set({ sectionSize });
20
+ }
21
+ set sectionThickness(sectionThickness) {
22
+ this.set({ sectionThickness });
23
+ }
24
+ set sectionColor(sectionColor) {
25
+ this.set({ sectionColor });
26
+ }
27
+ set followCamera(followCamera) {
28
+ this.set({ followCamera });
29
+ }
30
+ set infiniteGrid(infiniteGrid) {
31
+ this.set({ infiniteGrid });
32
+ }
33
+ set fadeDistance(fadeDistance) {
34
+ this.set({ fadeDistance });
35
+ }
36
+ set fadeStrength(fadeStrength) {
37
+ this.set({ fadeStrength });
38
+ }
39
+ set side(side) {
40
+ this.set({ side });
41
+ }
42
+ set args(args) {
43
+ this.set({ args });
44
+ }
45
+ constructor() {
46
+ super({
47
+ cellSize: 0.5,
48
+ sectionSize: 1,
49
+ fadeDistance: 100,
50
+ fadeStrength: 1,
51
+ cellThickness: 0.5,
52
+ sectionThickness: 1,
53
+ infiniteGrid: false,
54
+ followCamera: false,
55
+ cellColor: '#000000',
56
+ sectionColor: '#2080ff',
57
+ side: THREE.BackSide,
58
+ args: [1, 1, 1],
59
+ });
60
+ this.gridRef = injectNgtRef();
61
+ this.gridCellSize = this.select('cellSize');
62
+ this.gridSectionSize = this.select('sectionSize');
63
+ this.gridFadeDistance = this.select('fadeDistance');
64
+ this.gridFadeStrength = this.select('fadeStrength');
65
+ this.gridCellThickness = this.select('cellThickness');
66
+ this.gridSectionThickness = this.select('sectionThickness');
67
+ this.gridInfiniteGrid = this.select('infiniteGrid');
68
+ this.gridFollowCamera = this.select('followCamera');
69
+ this.gridCellColor = this.select('cellColor');
70
+ this.gridSectionColor = this.select('sectionColor');
71
+ this.gridSide = this.select('side');
72
+ this.gridArgs = this.select('args');
73
+ }
74
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NgtsGrid, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
75
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.0", type: NgtsGrid, isStandalone: true, selector: "ngts-grid", inputs: { gridRef: "gridRef", cellSize: "cellSize", cellThickness: "cellThickness", cellColor: "cellColor", sectionSize: "sectionSize", sectionThickness: "sectionThickness", sectionColor: "sectionColor", followCamera: "followCamera", infiniteGrid: "infiniteGrid", fadeDistance: "fadeDistance", fadeStrength: "fadeStrength", side: "side", args: "args" }, usesInheritance: true, ngImport: i0, template: `
76
+ <ngt-mesh ngtCompound [ref]="gridRef" [frustumCulled]="false">
77
+ <ngt-grid-material
78
+ [transparent]="true"
79
+ [side]="gridSide()"
80
+ [cellSize]="gridCellSize()"
81
+ [sectionSize]="gridSectionSize()"
82
+ [cellColor]="gridCellColor()"
83
+ [sectionColor]="gridSectionColor()"
84
+ [cellThickness]="gridCellThickness()"
85
+ [sectionThickness]="gridSectionThickness()"
86
+ [fadeDistance]="gridFadeDistance()"
87
+ [fadeStrength]="gridFadeStrength()"
88
+ [infiniteGrid]="gridInfiniteGrid()"
89
+ [followCamera]="gridFollowCamera()"
90
+ />
91
+ <ngt-plane-geometry *args="gridArgs()" />
92
+ </ngt-mesh>
93
+ `, isInline: true, dependencies: [{ kind: "directive", type: NgtArgs, selector: "[args]", inputs: ["args"] }] }); }
94
+ }
95
+ export { NgtsGrid };
96
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NgtsGrid, decorators: [{
97
+ type: Component,
98
+ args: [{
99
+ selector: 'ngts-grid',
100
+ standalone: true,
101
+ template: `
102
+ <ngt-mesh ngtCompound [ref]="gridRef" [frustumCulled]="false">
103
+ <ngt-grid-material
104
+ [transparent]="true"
105
+ [side]="gridSide()"
106
+ [cellSize]="gridCellSize()"
107
+ [sectionSize]="gridSectionSize()"
108
+ [cellColor]="gridCellColor()"
109
+ [sectionColor]="gridSectionColor()"
110
+ [cellThickness]="gridCellThickness()"
111
+ [sectionThickness]="gridSectionThickness()"
112
+ [fadeDistance]="gridFadeDistance()"
113
+ [fadeStrength]="gridFadeStrength()"
114
+ [infiniteGrid]="gridInfiniteGrid()"
115
+ [followCamera]="gridFollowCamera()"
116
+ />
117
+ <ngt-plane-geometry *args="gridArgs()" />
118
+ </ngt-mesh>
119
+ `,
120
+ imports: [NgtArgs],
121
+ schemas: [CUSTOM_ELEMENTS_SCHEMA],
122
+ }]
123
+ }], ctorParameters: function () { return []; }, propDecorators: { gridRef: [{
124
+ type: Input
125
+ }], cellSize: [{
126
+ type: Input
127
+ }], cellThickness: [{
128
+ type: Input
129
+ }], cellColor: [{
130
+ type: Input
131
+ }], sectionSize: [{
132
+ type: Input
133
+ }], sectionThickness: [{
134
+ type: Input
135
+ }], sectionColor: [{
136
+ type: Input
137
+ }], followCamera: [{
138
+ type: Input
139
+ }], infiniteGrid: [{
140
+ type: Input
141
+ }], fadeDistance: [{
142
+ type: Input
143
+ }], fadeStrength: [{
144
+ type: Input
145
+ }], side: [{
146
+ type: Input
147
+ }], args: [{
148
+ type: Input
149
+ }] } });
150
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"grid.js","sourceRoot":"","sources":["../../../../../../libs/soba/abstractions/src/grid/grid.ts"],"names":[],"mappings":"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","sourcesContent":["import { CUSTOM_ELEMENTS_SCHEMA, Component, Input } from '@angular/core';\nimport { NgtArgs, NgtSignalStore, extend, injectNgtRef } from 'angular-three';\nimport { GridMaterial } from 'angular-three-soba/shaders';\nimport * as THREE from 'three';\nimport { Mesh, PlaneGeometry } from 'three';\n\nextend({ Mesh, GridMaterial, PlaneGeometry });\n\nexport interface NgtsGridState {\n    /** Cell size, default: 0.5 */\n    cellSize: number;\n    /** Cell thickness, default: 0.5 */\n    cellThickness: number;\n    /** Cell color, default: black */\n    cellColor: THREE.ColorRepresentation;\n    /** Section size, default: 1 */\n    sectionSize: number;\n    /** Section thickness, default: 1 */\n    sectionThickness: number;\n    /** Section color, default: #2080ff */\n    sectionColor: THREE.ColorRepresentation;\n    /** Follow camera, default: false */\n    followCamera: boolean;\n    /** Display the grid infinitely, default: false */\n    infiniteGrid: boolean;\n    /** Fade distance, default: 100 */\n    fadeDistance: number;\n    /** Fade strength, default: 1 */\n    fadeStrength: number;\n    /** Material side, default: THREE.BackSide */\n    side: THREE.Side;\n    /** Default plane-geometry arguments */\n    args: ConstructorParameters<typeof THREE.PlaneGeometry>;\n}\n\n@Component({\n    selector: 'ngts-grid',\n    standalone: true,\n    template: `\n        <ngt-mesh ngtCompound [ref]=\"gridRef\" [frustumCulled]=\"false\">\n            <ngt-grid-material\n                [transparent]=\"true\"\n                [side]=\"gridSide()\"\n                [cellSize]=\"gridCellSize()\"\n                [sectionSize]=\"gridSectionSize()\"\n                [cellColor]=\"gridCellColor()\"\n                [sectionColor]=\"gridSectionColor()\"\n                [cellThickness]=\"gridCellThickness()\"\n                [sectionThickness]=\"gridSectionThickness()\"\n                [fadeDistance]=\"gridFadeDistance()\"\n                [fadeStrength]=\"gridFadeStrength()\"\n                [infiniteGrid]=\"gridInfiniteGrid()\"\n                [followCamera]=\"gridFollowCamera()\"\n            />\n            <ngt-plane-geometry *args=\"gridArgs()\" />\n        </ngt-mesh>\n    `,\n    imports: [NgtArgs],\n    schemas: [CUSTOM_ELEMENTS_SCHEMA],\n})\nexport class NgtsGrid extends NgtSignalStore<NgtsGridState> {\n    @Input() gridRef = injectNgtRef<THREE.Mesh>();\n    @Input() set cellSize(cellSize: NgtsGridState['cellSize']) {\n        this.set({ cellSize });\n    }\n\n    @Input() set cellThickness(cellThickness: NgtsGridState['cellThickness']) {\n        this.set({ cellThickness });\n    }\n\n    @Input() set cellColor(cellColor: NgtsGridState['cellColor']) {\n        this.set({ cellColor });\n    }\n\n    @Input() set sectionSize(sectionSize: NgtsGridState['sectionSize']) {\n        this.set({ sectionSize });\n    }\n\n    @Input() set sectionThickness(sectionThickness: NgtsGridState['sectionThickness']) {\n        this.set({ sectionThickness });\n    }\n\n    @Input() set sectionColor(sectionColor: NgtsGridState['sectionColor']) {\n        this.set({ sectionColor });\n    }\n\n    @Input() set followCamera(followCamera: NgtsGridState['followCamera']) {\n        this.set({ followCamera });\n    }\n\n    @Input() set infiniteGrid(infiniteGrid: NgtsGridState['infiniteGrid']) {\n        this.set({ infiniteGrid });\n    }\n\n    @Input() set fadeDistance(fadeDistance: NgtsGridState['fadeDistance']) {\n        this.set({ fadeDistance });\n    }\n\n    @Input() set fadeStrength(fadeStrength: NgtsGridState['fadeStrength']) {\n        this.set({ fadeStrength });\n    }\n\n    @Input() set side(side: NgtsGridState['side']) {\n        this.set({ side });\n    }\n\n    @Input() set args(args: NgtsGridState['args']) {\n        this.set({ args });\n    }\n\n    readonly gridCellSize = this.select('cellSize');\n    readonly gridSectionSize = this.select('sectionSize');\n    readonly gridFadeDistance = this.select('fadeDistance');\n    readonly gridFadeStrength = this.select('fadeStrength');\n    readonly gridCellThickness = this.select('cellThickness');\n    readonly gridSectionThickness = this.select('sectionThickness');\n    readonly gridInfiniteGrid = this.select('infiniteGrid');\n    readonly gridFollowCamera = this.select('followCamera');\n    readonly gridCellColor = this.select('cellColor');\n    readonly gridSectionColor = this.select('sectionColor');\n    readonly gridSide = this.select('side');\n    readonly gridArgs = this.select('args');\n\n    constructor() {\n        super({\n            cellSize: 0.5,\n            sectionSize: 1,\n            fadeDistance: 100,\n            fadeStrength: 1,\n            cellThickness: 0.5,\n            sectionThickness: 1,\n            infiniteGrid: false,\n            followCamera: false,\n            cellColor: '#000000',\n            sectionColor: '#2080ff',\n            side: THREE.BackSide,\n            args: [1, 1, 1],\n        });\n    }\n}\n"]}
@@ -5,8 +5,9 @@ export * from './edges/edges';
5
5
  export * from './gizmo-helper/gizmo-helper';
6
6
  export * from './gizmo-helper/gizmo-viewcube/gizmo-viewcube';
7
7
  export * from './gizmo-helper/gizmo-viewport/gizmo-viewport';
8
+ export * from './grid/grid';
8
9
  export * from './line/line';
9
10
  export * from './quadratic-bezier-line/quadratic-bezier-line';
10
11
  export * from './text-3d/text-3d';
11
12
  export * from './text/text';
12
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL3NvYmEvYWJzdHJhY3Rpb25zL3NyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLHVCQUF1QixDQUFDO0FBQ3RDLGNBQWMscUNBQXFDLENBQUM7QUFDcEQsY0FBYyx1Q0FBdUMsQ0FBQztBQUN0RCxjQUFjLGVBQWUsQ0FBQztBQUM5QixjQUFjLDZCQUE2QixDQUFDO0FBQzVDLGNBQWMsOENBQThDLENBQUM7QUFDN0QsY0FBYyw4Q0FBOEMsQ0FBQztBQUM3RCxjQUFjLGFBQWEsQ0FBQztBQUM1QixjQUFjLCtDQUErQyxDQUFDO0FBQzlELGNBQWMsbUJBQW1CLENBQUM7QUFDbEMsY0FBYyxhQUFhLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2JpbGxib2FyZC9iaWxsYm9hcmQnO1xuZXhwb3J0ICogZnJvbSAnLi9jYXRtdWxsLXJvbS1saW5lL2NhdG11bGwtcm9tLWxpbmUnO1xuZXhwb3J0ICogZnJvbSAnLi9jdWJpYy1iZXppZXItbGluZS9jdWJpYy1iZXppZXItbGluZSc7XG5leHBvcnQgKiBmcm9tICcuL2VkZ2VzL2VkZ2VzJztcbmV4cG9ydCAqIGZyb20gJy4vZ2l6bW8taGVscGVyL2dpem1vLWhlbHBlcic7XG5leHBvcnQgKiBmcm9tICcuL2dpem1vLWhlbHBlci9naXptby12aWV3Y3ViZS9naXptby12aWV3Y3ViZSc7XG5leHBvcnQgKiBmcm9tICcuL2dpem1vLWhlbHBlci9naXptby12aWV3cG9ydC9naXptby12aWV3cG9ydCc7XG5leHBvcnQgKiBmcm9tICcuL2xpbmUvbGluZSc7XG5leHBvcnQgKiBmcm9tICcuL3F1YWRyYXRpYy1iZXppZXItbGluZS9xdWFkcmF0aWMtYmV6aWVyLWxpbmUnO1xuZXhwb3J0ICogZnJvbSAnLi90ZXh0LTNkL3RleHQtM2QnO1xuZXhwb3J0ICogZnJvbSAnLi90ZXh0L3RleHQnO1xuIl19
13
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL3NvYmEvYWJzdHJhY3Rpb25zL3NyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLHVCQUF1QixDQUFDO0FBQ3RDLGNBQWMscUNBQXFDLENBQUM7QUFDcEQsY0FBYyx1Q0FBdUMsQ0FBQztBQUN0RCxjQUFjLGVBQWUsQ0FBQztBQUM5QixjQUFjLDZCQUE2QixDQUFDO0FBQzVDLGNBQWMsOENBQThDLENBQUM7QUFDN0QsY0FBYyw4Q0FBOEMsQ0FBQztBQUM3RCxjQUFjLGFBQWEsQ0FBQztBQUM1QixjQUFjLGFBQWEsQ0FBQztBQUM1QixjQUFjLCtDQUErQyxDQUFDO0FBQzlELGNBQWMsbUJBQW1CLENBQUM7QUFDbEMsY0FBYyxhQUFhLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2JpbGxib2FyZC9iaWxsYm9hcmQnO1xuZXhwb3J0ICogZnJvbSAnLi9jYXRtdWxsLXJvbS1saW5lL2NhdG11bGwtcm9tLWxpbmUnO1xuZXhwb3J0ICogZnJvbSAnLi9jdWJpYy1iZXppZXItbGluZS9jdWJpYy1iZXppZXItbGluZSc7XG5leHBvcnQgKiBmcm9tICcuL2VkZ2VzL2VkZ2VzJztcbmV4cG9ydCAqIGZyb20gJy4vZ2l6bW8taGVscGVyL2dpem1vLWhlbHBlcic7XG5leHBvcnQgKiBmcm9tICcuL2dpem1vLWhlbHBlci9naXptby12aWV3Y3ViZS9naXptby12aWV3Y3ViZSc7XG5leHBvcnQgKiBmcm9tICcuL2dpem1vLWhlbHBlci9naXptby12aWV3cG9ydC9naXptby12aWV3cG9ydCc7XG5leHBvcnQgKiBmcm9tICcuL2dyaWQvZ3JpZCc7XG5leHBvcnQgKiBmcm9tICcuL2xpbmUvbGluZSc7XG5leHBvcnQgKiBmcm9tICcuL3F1YWRyYXRpYy1iZXppZXItbGluZS9xdWFkcmF0aWMtYmV6aWVyLWxpbmUnO1xuZXhwb3J0ICogZnJvbSAnLi90ZXh0LTNkL3RleHQtM2QnO1xuZXhwb3J0ICogZnJvbSAnLi90ZXh0L3RleHQnO1xuIl19
@@ -95,7 +95,6 @@ class NgtsText extends NgtSignalStore {
95
95
  this.sync = new EventEmitter();
96
96
  this.troikaText = new Text();
97
97
  this.#store = inject(NgtStore);
98
- this.state = this.select();
99
98
  inject(DestroyRef).onDestroy(() => {
100
99
  this.troikaText.dispose();
101
100
  });
@@ -113,9 +112,8 @@ class NgtsText extends NgtSignalStore {
113
112
  });
114
113
  }
115
114
  #syncText() {
116
- const state = this.select();
117
115
  effect(() => {
118
- state();
116
+ this.state();
119
117
  const invalidate = this.#store.get('invalidate');
120
118
  this.troikaText.sync(() => {
121
119
  invalidate();
@@ -272,4 +270,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImpor
272
270
  }], sync: [{
273
271
  type: Output
274
272
  }] } });
275
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"text.js","sourceRoot":"","sources":["../../../../../../libs/soba/abstractions/src/text/text.ts"],"names":[],"mappings":"AAAA,OAAO,EACH,sBAAsB,EACtB,SAAS,EACT,UAAU,EACV,YAAY,EACZ,KAAK,EACL,MAAM,EACN,QAAQ,EACR,MAAM,EACN,MAAM,GACT,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,OAAO,EAAE,cAAc,EAAE,QAAQ,EAAE,YAAY,EAAgB,MAAM,eAAe,CAAC;AAE9F,sDAAsD;AACtD,OAAO,EAAE,IAAI,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;;AAwCtD,MA2Ca,QAAS,SAAQ,cAA6B;IAGvD,IAA+B,IAAI,CAAC,IAAY;QAC5C,IAAI,CAAC,GAAG,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC;IACvB,CAAC;IAED,IAAa,IAAI,CAAC,IAAY;QAC1B,IAAI,CAAC,GAAG,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC;IACvB,CAAC;IAED,IAAa,QAAQ,CAAC,QAAgB;QAClC,IAAI,CAAC,GAAG,CAAC,EAAE,QAAQ,EAAE,CAAC,CAAC;IAC3B,CAAC;IAED,IAAa,OAAO,CAAC,OAA6C;QAC9D,IAAI,CAAC,GAAG,CAAC,EAAE,OAAO,EAAE,CAAC,CAAC;IAC1B,CAAC;IAED,IAAa,OAAO,CAAC,OAAkF;QACnG,IAAI,CAAC,GAAG,CAAC,EAAE,OAAO,EAAE,CAAC,CAAC;IAC1B,CAAC;IAED,IAAa,YAAY,CAAC,YAAoB;QAC1C,IAAI,CAAC,GAAG,CAAC,EAAE,YAAY,EAAE,CAAC,CAAC;IAC/B,CAAC;IAED,IAAa,UAAU,CAAC,UAAkB;QACtC,IAAI,CAAC,GAAG,CAAC,EAAE,UAAU,EAAE,CAAC,CAAC;IAC7B,CAAC;IAED,IAAa,KAAK,CAAC,KAAgC;QAC/C,IAAI,CAAC,GAAG,CAAC,EAAE,KAAK,EAAE,CAAC,CAAC;IACxB,CAAC;IAED,IAAa,QAAQ,CAAC,QAAgB;QAClC,IAAI,CAAC,GAAG,CAAC,EAAE,QAAQ,EAAE,CAAC,CAAC;IAC3B,CAAC;IAED,IAAa,UAAU,CAAC,UAAkB;QACtC,IAAI,CAAC,GAAG,CAAC,EAAE,UAAU,EAAE,CAAC,CAAC;IAC7B,CAAC;IAED,IAAa,aAAa,CAAC,aAAqB;QAC5C,IAAI,CAAC,GAAG,CAAC,EAAE,aAAa,EAAE,CAAC,CAAC;IAChC,CAAC;IAED,IAAa,SAAS,CAAC,SAAkD;QACrE,IAAI,CAAC,GAAG,CAAC,EAAE,SAAS,EAAE,CAAC,CAAC;IAC5B,CAAC;IAED,IAAa,QAAQ,CAAC,QAA0C;QAC5D,IAAI,CAAC,GAAG,CAAC,EAAE,QAAQ,EAAE,CAAC,CAAC;IAC3B,CAAC;IAED,IAAa,WAAW,CAAC,WAAmB;QACxC,IAAI,CAAC,GAAG,CAAC,EAAE,WAAW,EAAE,CAAC,CAAC;IAC9B,CAAC;IAED,IAAa,SAAS,CAAC,SAAiC;QACpD,IAAI,CAAC,GAAG,CAAC,EAAE,SAAS,EAAE,CAAC,CAAC;IAC5B,CAAC;IAED,IAAa,YAAY,CAAC,YAAqC;QAC3D,IAAI,CAAC,GAAG,CAAC,EAAE,YAAY,EAAE,CAAC,CAAC;IAC/B,CAAC;IAED,IAAa,UAAU,CAAC,UAAgD;QACpE,IAAI,CAAC,GAAG,CAAC,EAAE,UAAU,EAAE,CAAC,CAAC;IAC7B,CAAC;IAED,IAAa,YAAY,CAAC,YAA6B;QACnD,IAAI,CAAC,GAAG,CAAC,EAAE,YAAY,EAAE,CAAC,CAAC;IAC/B,CAAC;IAED,IAAa,cAAc,CAAC,cAA+B;QACvD,IAAI,CAAC,GAAG,CAAC,EAAE,cAAc,EAAE,CAAC,CAAC;IACjC,CAAC;IAED,IAAa,cAAc,CAAC,cAA+B;QACvD,IAAI,CAAC,GAAG,CAAC,EAAE,cAAc,EAAE,CAAC,CAAC;IACjC,CAAC;IAED,IAAa,WAAW,CAAC,WAA4B;QACjD,IAAI,CAAC,GAAG,CAAC,EAAE,WAAW,EAAE,CAAC,CAAC;IAC9B,CAAC;IAED,IAAa,YAAY,CAAC,YAAuC;QAC7D,IAAI,CAAC,GAAG,CAAC,EAAE,YAAY,EAAE,CAAC,CAAC;IAC/B,CAAC;IAED,IAAa,cAAc,CAAC,cAAsB;QAC9C,IAAI,CAAC,GAAG,CAAC,EAAE,cAAc,EAAE,CAAC,CAAC;IACjC,CAAC;IAED,IAAa,WAAW,CAAC,WAA4B;QACjD,IAAI,CAAC,GAAG,CAAC,EAAE,WAAW,EAAE,CAAC,CAAC;IAC9B,CAAC;IAED,IAAa,WAAW,CAAC,WAAsC;QAC3D,IAAI,CAAC,GAAG,CAAC,EAAE,WAAW,EAAE,CAAC,CAAC;IAC9B,CAAC;IAED,IAAa,aAAa,CAAC,aAAqB;QAC5C,IAAI,CAAC,GAAG,CAAC,EAAE,aAAa,EAAE,CAAC,CAAC;IAChC,CAAC;IAED,IAAa,WAAW,CAAC,WAAmB;QACxC,IAAI,CAAC,GAAG,CAAC,EAAE,WAAW,EAAE,CAAC,CAAC;IAC9B,CAAC;IAED,IAAa,QAAQ,CAAC,QAAiB;QACnC,IAAI,CAAC,GAAG,CAAC,EAAE,QAAQ,EAAE,CAAC,CAAC;IAC3B,CAAC;IAMQ,MAAM,CAAoB;IAInC;QACI,KAAK,CAAC,EAAE,QAAQ,EAAE,CAAC,EAAE,YAAY,EAAE,EAAE,EAAE,OAAO,EAAE,QAAQ,EAAE,OAAO,EAAE,QAAQ,EAAE,CAAC,CAAC;QA3H1E,YAAO,GAAG,YAAY,EAAQ,CAAC;QAkH9B,SAAI,GAAG,IAAI,YAAY,EAAQ,CAAC;QAEjC,eAAU,GAAG,IAAI,IAAI,EAAE,CAAC;QAExB,WAAM,GAAG,MAAM,CAAC,QAAQ,CAAC,CAAC;QAE1B,UAAK,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC;QAI3B,MAAM,CAAC,UAAU,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;YAC9B,IAAI,CAAC,UAAU,CAAC,OAAO,EAAE,CAAC;QAC9B,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,YAAY,EAAE,CAAC;QACpB,IAAI,CAAC,SAAS,EAAE,CAAC;IACrB,CAAC;IAED,YAAY;QACR,MAAM,IAAI,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;QACjC,MAAM,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC;QAC7C,MAAM,OAAO,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,EAAE,UAAU,EAAE,UAAU,EAAE,EAAE,CAAC,CAAC,CAAC;QAE7E,MAAM,CAAC,GAAG,EAAE;YACR,MAAM,EAAE,IAAI,EAAE,UAAU,EAAE,GAAG,OAAO,EAAE,CAAC;YACvC,MAAM,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC;YACjD,WAAW,CAAC,EAAE,IAAI,EAAE,UAAU,EAAE,EAAE,GAAG,EAAE,CAAC,UAAU,EAAE,CAAC,CAAC;QAC1D,CAAC,CAAC,CAAC;IACP,CAAC;IAED,SAAS;QACL,MAAM,KAAK,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC;QAC5B,MAAM,CAAC,GAAG,EAAE;YACR,KAAK,EAAE,CAAC;YACR,MAAM,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC;YACjD,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,GAAG,EAAE;gBACtB,UAAU,EAAE,CAAC;gBACb,IAAI,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;oBACpB,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;iBACnC;YACL,CAAC,CAAC,CAAC;QACP,CAAC,CAAC,CAAC;IACP,CAAC;8GA5JQ,QAAQ;kGAAR,QAAQ,22BAxCP;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KAoCT,4DACS,OAAO;;SAGR,QAAQ;2FAAR,QAAQ;kBA3CpB,SAAS;mBAAC;oBACP,QAAQ,EAAE,WAAW;oBACrB,UAAU,EAAE,IAAI;oBAChB,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KAoCT;oBACD,OAAO,EAAE,CAAC,OAAO,CAAC;oBAClB,OAAO,EAAE,CAAC,sBAAsB,CAAC;iBACpC;0EAEY,OAAO;sBAAf,KAAK;gBAEyB,IAAI;sBAAlC,KAAK;uBAAC,EAAE,QAAQ,EAAE,IAAI,EAAE;gBAIZ,IAAI;sBAAhB,KAAK;gBAIO,QAAQ;sBAApB,KAAK;gBAIO,OAAO;sBAAnB,KAAK;gBAIO,OAAO;sBAAnB,KAAK;gBAIO,YAAY;sBAAxB,KAAK;gBAIO,UAAU;sBAAtB,KAAK;gBAIO,KAAK;sBAAjB,KAAK;gBAIO,QAAQ;sBAApB,KAAK;gBAIO,UAAU;sBAAtB,KAAK;gBAIO,aAAa;sBAAzB,KAAK;gBAIO,SAAS;sBAArB,KAAK;gBAIO,QAAQ;sBAApB,KAAK;gBAIO,WAAW;sBAAvB,KAAK;gBAIO,SAAS;sBAArB,KAAK;gBAIO,YAAY;sBAAxB,KAAK;gBAIO,UAAU;sBAAtB,KAAK;gBAIO,YAAY;sBAAxB,KAAK;gBAIO,cAAc;sBAA1B,KAAK;gBAIO,cAAc;sBAA1B,KAAK;gBAIO,WAAW;sBAAvB,KAAK;gBAIO,YAAY;sBAAxB,KAAK;gBAIO,cAAc;sBAA1B,KAAK;gBAIO,WAAW;sBAAvB,KAAK;gBAIO,WAAW;sBAAvB,KAAK;gBAIO,aAAa;sBAAzB,KAAK;gBAIO,WAAW;sBAAvB,KAAK;gBAIO,QAAQ;sBAApB,KAAK;gBAII,IAAI;sBAAb,MAAM","sourcesContent":["import {\n    CUSTOM_ELEMENTS_SCHEMA,\n    Component,\n    DestroyRef,\n    EventEmitter,\n    Input,\n    Output,\n    computed,\n    effect,\n    inject,\n} from '@angular/core';\nimport { NgtArgs, NgtSignalStore, NgtStore, injectNgtRef, type NgtMesh } from 'angular-three';\n\n// @ts-expect-error: no type def for troika-three-text\nimport { Text, preloadFont } from 'troika-three-text';\n\nexport type NgtsTextState = {\n    text: string;\n    /** Font size, default: 1 */\n    fontSize: number;\n    anchorX: number | 'left' | 'center' | 'right';\n    anchorY: number | 'top' | 'top-baseline' | 'middle' | 'bottom-baseline' | 'bottom';\n    sdfGlyphSize: number;\n    font?: string;\n    characters?: string;\n    color?: THREE.ColorRepresentation;\n    maxWidth?: number;\n    lineHeight?: number;\n    letterSpacing?: number;\n    textAlign?: 'left' | 'right' | 'center' | 'justify';\n    clipRect?: [number, number, number, number];\n    depthOffset?: number;\n    direction?: 'auto' | 'ltr' | 'rtl';\n    overflowWrap?: 'normal' | 'break-word';\n    whiteSpace?: 'normal' | 'overflowWrap' | 'nowrap';\n    outlineWidth?: number | string;\n    outlineOffsetX?: number | string;\n    outlineOffsetY?: number | string;\n    outlineBlur?: number | string;\n    outlineColor?: THREE.ColorRepresentation;\n    outlineOpacity?: number;\n    strokeWidth?: number | string;\n    strokeColor?: THREE.ColorRepresentation;\n    strokeOpacity?: number;\n    fillOpacity?: number;\n    debugSDF?: boolean;\n};\n\ndeclare global {\n    interface HTMLElementTagNameMap {\n        'ngts-text': NgtsTextState & NgtMesh;\n    }\n}\n\n@Component({\n    selector: 'ngts-text',\n    standalone: true,\n    template: `\n        <ngt-primitive\n            ngtCompound\n            *args=\"[troikaText]\"\n            [ref]=\"textRef\"\n            [text]=\"state().text\"\n            [anchorX]=\"state().anchorX\"\n            [anchorY]=\"state().anchorY\"\n            [font]=\"state().font\"\n            [fontSize]=\"state().fontSize\"\n            [sdfGlyphSize]=\"state().sdfGlyphSize\"\n            [characters]=\"state().characters\"\n            [color]=\"state().color\"\n            [maxWidth]=\"state().maxWidth\"\n            [lineHeight]=\"state().lineHeight\"\n            [letterSpacing]=\"state().letterSpacing\"\n            [textAlign]=\"state().textAlign\"\n            [clipRect]=\"state().clipRect\"\n            [depthOffset]=\"state().depthOffset\"\n            [direction]=\"state().direction\"\n            [overflowWrap]=\"state().overflowWrap\"\n            [whiteSpace]=\"state().whiteSpace\"\n            [outlineWidth]=\"state().outlineWidth\"\n            [outlineOffsetX]=\"state().outlineOffsetX\"\n            [outlineOffsetY]=\"state().outlineOffsetY\"\n            [outlineBlur]=\"state().outlineBlur\"\n            [outlineColor]=\"state().outlineColor\"\n            [outlineOpacity]=\"state().outlineOpacity\"\n            [strokeWidth]=\"state().strokeWidth\"\n            [strokeColor]=\"state().strokeColor\"\n            [strokeOpacity]=\"state().strokeOpacity\"\n            [fillOpacity]=\"state().fillOpacity\"\n            [debugSDF]=\"state().debugSDF\"\n        >\n            <ng-content />\n        </ngt-primitive>\n    `,\n    imports: [NgtArgs],\n    schemas: [CUSTOM_ELEMENTS_SCHEMA],\n})\nexport class NgtsText extends NgtSignalStore<NgtsTextState> {\n    @Input() textRef = injectNgtRef<Text>();\n\n    @Input({ required: true }) set text(text: string) {\n        this.set({ text });\n    }\n\n    @Input() set font(font: string) {\n        this.set({ font });\n    }\n\n    @Input() set fontSize(fontSize: number) {\n        this.set({ fontSize });\n    }\n\n    @Input() set anchorX(anchorX: number | 'left' | 'center' | 'right') {\n        this.set({ anchorX });\n    }\n\n    @Input() set anchorY(anchorY: number | 'top' | 'top-baseline' | 'middle' | 'bottom-baseline' | 'bottom') {\n        this.set({ anchorY });\n    }\n\n    @Input() set sdfGlyphSize(sdfGlyphSize: number) {\n        this.set({ sdfGlyphSize });\n    }\n\n    @Input() set characters(characters: string) {\n        this.set({ characters });\n    }\n\n    @Input() set color(color: THREE.ColorRepresentation) {\n        this.set({ color });\n    }\n\n    @Input() set maxWidth(maxWidth: number) {\n        this.set({ maxWidth });\n    }\n\n    @Input() set lineHeight(lineHeight: number) {\n        this.set({ lineHeight });\n    }\n\n    @Input() set letterSpacing(letterSpacing: number) {\n        this.set({ letterSpacing });\n    }\n\n    @Input() set textAlign(textAlign: 'left' | 'right' | 'center' | 'justify') {\n        this.set({ textAlign });\n    }\n\n    @Input() set clipRect(clipRect: [number, number, number, number]) {\n        this.set({ clipRect });\n    }\n\n    @Input() set depthOffset(depthOffset: number) {\n        this.set({ depthOffset });\n    }\n\n    @Input() set direction(direction: 'auto' | 'ltr' | 'rtl') {\n        this.set({ direction });\n    }\n\n    @Input() set overflowWrap(overflowWrap: 'normal' | 'break-word') {\n        this.set({ overflowWrap });\n    }\n\n    @Input() set whiteSpace(whiteSpace: 'normal' | 'overflowWrap' | 'nowrap') {\n        this.set({ whiteSpace });\n    }\n\n    @Input() set outlineWidth(outlineWidth: number | string) {\n        this.set({ outlineWidth });\n    }\n\n    @Input() set outlineOffsetX(outlineOffsetX: number | string) {\n        this.set({ outlineOffsetX });\n    }\n\n    @Input() set outlineOffsetY(outlineOffsetY: number | string) {\n        this.set({ outlineOffsetY });\n    }\n\n    @Input() set outlineBlur(outlineBlur: number | string) {\n        this.set({ outlineBlur });\n    }\n\n    @Input() set outlineColor(outlineColor: THREE.ColorRepresentation) {\n        this.set({ outlineColor });\n    }\n\n    @Input() set outlineOpacity(outlineOpacity: number) {\n        this.set({ outlineOpacity });\n    }\n\n    @Input() set strokeWidth(strokeWidth: number | string) {\n        this.set({ strokeWidth });\n    }\n\n    @Input() set strokeColor(strokeColor: THREE.ColorRepresentation) {\n        this.set({ strokeColor });\n    }\n\n    @Input() set strokeOpacity(strokeOpacity: number) {\n        this.set({ strokeOpacity });\n    }\n\n    @Input() set fillOpacity(fillOpacity: number) {\n        this.set({ fillOpacity });\n    }\n\n    @Input() set debugSDF(debugSDF: boolean) {\n        this.set({ debugSDF });\n    }\n\n    @Output() sync = new EventEmitter<Text>();\n\n    readonly troikaText = new Text();\n\n    readonly #store = inject(NgtStore);\n\n    readonly state = this.select();\n\n    constructor() {\n        super({ fontSize: 1, sdfGlyphSize: 64, anchorX: 'center', anchorY: 'middle' });\n        inject(DestroyRef).onDestroy(() => {\n            this.troikaText.dispose();\n        });\n        this.#preloadFont();\n        this.#syncText();\n    }\n\n    #preloadFont() {\n        const font = this.select('font');\n        const characters = this.select('characters');\n        const trigger = computed(() => ({ font: font(), characters: characters() }));\n\n        effect(() => {\n            const { font, characters } = trigger();\n            const invalidate = this.#store.get('invalidate');\n            preloadFont({ font, characters }, () => invalidate());\n        });\n    }\n\n    #syncText() {\n        const state = this.select();\n        effect(() => {\n            state();\n            const invalidate = this.#store.get('invalidate');\n            this.troikaText.sync(() => {\n                invalidate();\n                if (this.sync.observed) {\n                    this.sync.emit(this.troikaText);\n                }\n            });\n        });\n    }\n}\n"]}
273
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"text.js","sourceRoot":"","sources":["../../../../../../libs/soba/abstractions/src/text/text.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    CUSTOM_ELEMENTS_SCHEMA,\n    Component,\n    DestroyRef,\n    EventEmitter,\n    Input,\n    Output,\n    computed,\n    effect,\n    inject,\n} from '@angular/core';\nimport { NgtArgs, NgtSignalStore, NgtStore, injectNgtRef, type NgtMesh } from 'angular-three';\n\n// @ts-expect-error: no type def for troika-three-text\nimport { Text, preloadFont } from 'troika-three-text';\n\nexport type NgtsTextState = {\n    text: string;\n    /** Font size, default: 1 */\n    fontSize: number;\n    anchorX: number | 'left' | 'center' | 'right';\n    anchorY: number | 'top' | 'top-baseline' | 'middle' | 'bottom-baseline' | 'bottom';\n    sdfGlyphSize: number;\n    font?: string;\n    characters?: string;\n    color?: THREE.ColorRepresentation;\n    maxWidth?: number;\n    lineHeight?: number;\n    letterSpacing?: number;\n    textAlign?: 'left' | 'right' | 'center' | 'justify';\n    clipRect?: [number, number, number, number];\n    depthOffset?: number;\n    direction?: 'auto' | 'ltr' | 'rtl';\n    overflowWrap?: 'normal' | 'break-word';\n    whiteSpace?: 'normal' | 'overflowWrap' | 'nowrap';\n    outlineWidth?: number | string;\n    outlineOffsetX?: number | string;\n    outlineOffsetY?: number | string;\n    outlineBlur?: number | string;\n    outlineColor?: THREE.ColorRepresentation;\n    outlineOpacity?: number;\n    strokeWidth?: number | string;\n    strokeColor?: THREE.ColorRepresentation;\n    strokeOpacity?: number;\n    fillOpacity?: number;\n    debugSDF?: boolean;\n};\n\ndeclare global {\n    interface HTMLElementTagNameMap {\n        'ngts-text': NgtsTextState & NgtMesh;\n    }\n}\n\n@Component({\n    selector: 'ngts-text',\n    standalone: true,\n    template: `\n        <ngt-primitive\n            ngtCompound\n            *args=\"[troikaText]\"\n            [ref]=\"textRef\"\n            [text]=\"state().text\"\n            [anchorX]=\"state().anchorX\"\n            [anchorY]=\"state().anchorY\"\n            [font]=\"state().font\"\n            [fontSize]=\"state().fontSize\"\n            [sdfGlyphSize]=\"state().sdfGlyphSize\"\n            [characters]=\"state().characters\"\n            [color]=\"state().color\"\n            [maxWidth]=\"state().maxWidth\"\n            [lineHeight]=\"state().lineHeight\"\n            [letterSpacing]=\"state().letterSpacing\"\n            [textAlign]=\"state().textAlign\"\n            [clipRect]=\"state().clipRect\"\n            [depthOffset]=\"state().depthOffset\"\n            [direction]=\"state().direction\"\n            [overflowWrap]=\"state().overflowWrap\"\n            [whiteSpace]=\"state().whiteSpace\"\n            [outlineWidth]=\"state().outlineWidth\"\n            [outlineOffsetX]=\"state().outlineOffsetX\"\n            [outlineOffsetY]=\"state().outlineOffsetY\"\n            [outlineBlur]=\"state().outlineBlur\"\n            [outlineColor]=\"state().outlineColor\"\n            [outlineOpacity]=\"state().outlineOpacity\"\n            [strokeWidth]=\"state().strokeWidth\"\n            [strokeColor]=\"state().strokeColor\"\n            [strokeOpacity]=\"state().strokeOpacity\"\n            [fillOpacity]=\"state().fillOpacity\"\n            [debugSDF]=\"state().debugSDF\"\n        >\n            <ng-content />\n        </ngt-primitive>\n    `,\n    imports: [NgtArgs],\n    schemas: [CUSTOM_ELEMENTS_SCHEMA],\n})\nexport class NgtsText extends NgtSignalStore<NgtsTextState> {\n    @Input() textRef = injectNgtRef<Text>();\n\n    @Input({ required: true }) set text(text: string) {\n        this.set({ text });\n    }\n\n    @Input() set font(font: string) {\n        this.set({ font });\n    }\n\n    @Input() set fontSize(fontSize: number) {\n        this.set({ fontSize });\n    }\n\n    @Input() set anchorX(anchorX: number | 'left' | 'center' | 'right') {\n        this.set({ anchorX });\n    }\n\n    @Input() set anchorY(anchorY: number | 'top' | 'top-baseline' | 'middle' | 'bottom-baseline' | 'bottom') {\n        this.set({ anchorY });\n    }\n\n    @Input() set sdfGlyphSize(sdfGlyphSize: number) {\n        this.set({ sdfGlyphSize });\n    }\n\n    @Input() set characters(characters: string) {\n        this.set({ characters });\n    }\n\n    @Input() set color(color: THREE.ColorRepresentation) {\n        this.set({ color });\n    }\n\n    @Input() set maxWidth(maxWidth: number) {\n        this.set({ maxWidth });\n    }\n\n    @Input() set lineHeight(lineHeight: number) {\n        this.set({ lineHeight });\n    }\n\n    @Input() set letterSpacing(letterSpacing: number) {\n        this.set({ letterSpacing });\n    }\n\n    @Input() set textAlign(textAlign: 'left' | 'right' | 'center' | 'justify') {\n        this.set({ textAlign });\n    }\n\n    @Input() set clipRect(clipRect: [number, number, number, number]) {\n        this.set({ clipRect });\n    }\n\n    @Input() set depthOffset(depthOffset: number) {\n        this.set({ depthOffset });\n    }\n\n    @Input() set direction(direction: 'auto' | 'ltr' | 'rtl') {\n        this.set({ direction });\n    }\n\n    @Input() set overflowWrap(overflowWrap: 'normal' | 'break-word') {\n        this.set({ overflowWrap });\n    }\n\n    @Input() set whiteSpace(whiteSpace: 'normal' | 'overflowWrap' | 'nowrap') {\n        this.set({ whiteSpace });\n    }\n\n    @Input() set outlineWidth(outlineWidth: number | string) {\n        this.set({ outlineWidth });\n    }\n\n    @Input() set outlineOffsetX(outlineOffsetX: number | string) {\n        this.set({ outlineOffsetX });\n    }\n\n    @Input() set outlineOffsetY(outlineOffsetY: number | string) {\n        this.set({ outlineOffsetY });\n    }\n\n    @Input() set outlineBlur(outlineBlur: number | string) {\n        this.set({ outlineBlur });\n    }\n\n    @Input() set outlineColor(outlineColor: THREE.ColorRepresentation) {\n        this.set({ outlineColor });\n    }\n\n    @Input() set outlineOpacity(outlineOpacity: number) {\n        this.set({ outlineOpacity });\n    }\n\n    @Input() set strokeWidth(strokeWidth: number | string) {\n        this.set({ strokeWidth });\n    }\n\n    @Input() set strokeColor(strokeColor: THREE.ColorRepresentation) {\n        this.set({ strokeColor });\n    }\n\n    @Input() set strokeOpacity(strokeOpacity: number) {\n        this.set({ strokeOpacity });\n    }\n\n    @Input() set fillOpacity(fillOpacity: number) {\n        this.set({ fillOpacity });\n    }\n\n    @Input() set debugSDF(debugSDF: boolean) {\n        this.set({ debugSDF });\n    }\n\n    @Output() sync = new EventEmitter<Text>();\n\n    readonly troikaText = new Text();\n\n    readonly #store = inject(NgtStore);\n\n    constructor() {\n        super({ fontSize: 1, sdfGlyphSize: 64, anchorX: 'center', anchorY: 'middle' });\n        inject(DestroyRef).onDestroy(() => {\n            this.troikaText.dispose();\n        });\n        this.#preloadFont();\n        this.#syncText();\n    }\n\n    #preloadFont() {\n        const font = this.select('font');\n        const characters = this.select('characters');\n        const trigger = computed(() => ({ font: font(), characters: characters() }));\n\n        effect(() => {\n            const { font, characters } = trigger();\n            const invalidate = this.#store.get('invalidate');\n            preloadFont({ font, characters }, () => invalidate());\n        });\n    }\n\n    #syncText() {\n        effect(() => {\n            this.state();\n            const invalidate = this.#store.get('invalidate');\n            this.troikaText.sync(() => {\n                invalidate();\n                if (this.sync.observed) {\n                    this.sync.emit(this.troikaText);\n                }\n            });\n        });\n    }\n}\n"]}
@@ -2,7 +2,7 @@ import { NgIf } from '@angular/common';
2
2
  import { Component, computed, CUSTOM_ELEMENTS_SCHEMA, effect, inject, Input } from '@angular/core';
3
3
  import { extend, getLocalState, injectBeforeRender, injectNgtRef, NgtSignalStore, NgtStore } from 'angular-three';
4
4
  import { MeshRefractionMaterial } from 'angular-three-soba/shaders';
5
- import { MeshBVH, SAH } from 'three-mesh-bvh';
5
+ import { MeshBVH, MeshBVHUniformStruct, SAH } from 'three-mesh-bvh';
6
6
  import * as i0 from "@angular/core";
7
7
  extend({ MeshRefractionMaterial });
8
8
  const isCubeTexture = (def) => def && def.isCubeTexture;
@@ -94,7 +94,8 @@ class NgtsMeshRefractionMaterial extends NgtSignalStore {
94
94
  return;
95
95
  const geometry = getLocalState(material).parent()?.geometry;
96
96
  if (geometry) {
97
- material.bvh.updateFrom(new MeshBVH(geometry.toNonIndexed(), { lazyGeneration: false, strategy: SAH }));
97
+ material.bvh = new MeshBVHUniformStruct();
98
+ material.bvh.updateFrom(new MeshBVH(geometry.clone().toNonIndexed(), { lazyGeneration: false, strategy: SAH }));
98
99
  }
99
100
  });
100
101
  }
@@ -165,4 +166,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImpor
165
166
  }], fastChroma: [{
166
167
  type: Input
167
168
  }] } });
168
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mesh-refraction-material.js","sourceRoot":"","sources":["../../../../../../libs/soba/materials/src/mesh-refraction-material/mesh-refraction-material.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgIf } from '@angular/common';\nimport { Component, computed, CUSTOM_ELEMENTS_SCHEMA, effect, inject, Input } from '@angular/core';\nimport { extend, getLocalState, injectBeforeRender, injectNgtRef, NgtSignalStore, NgtStore } from 'angular-three';\nimport { MeshRefractionMaterial } from 'angular-three-soba/shaders';\nimport { MeshBVH, SAH } from 'three-mesh-bvh';\n\nextend({ MeshRefractionMaterial });\n\nexport interface NgtsMeshRefractionMaterialState {\n    /** Environment map */\n    envMap: THREE.CubeTexture | THREE.Texture;\n    /** Number of ray-cast bounces, it can be expensive to have too many, 2 */\n    bounces: number;\n    /** Refraction index, 2.4 */\n    ior: number;\n    /** Fresnel (strip light), 0 */\n    fresnel: number;\n    /** RGB shift intensity, can be expensive, 0 */\n    aberrationStrength: number;\n    /** Color, white */\n    color: THREE.ColorRepresentation;\n    /** If this is on it uses fewer ray casts for the RGB shift sacrificing physical accuracy, true */\n    fastChroma: boolean;\n}\n\nconst isCubeTexture = (def: THREE.CubeTexture | THREE.Texture): def is THREE.CubeTexture =>\n    def && (def as THREE.CubeTexture).isCubeTexture;\n\n@Component({\n    selector: 'ngts-mesh-refraction-material',\n    standalone: true,\n    template: `\n        <ngt-mesh-refraction-material\n            *ngIf=\"defines() as defines\"\n            [ref]=\"materialRef\"\n            [defines]=\"defines\"\n            [resolution]=\"resolution()\"\n            [aberrationStrength]=\"refractionAberrationStrength()\"\n            [envMap]=\"refractionEnvMap()\"\n            [bounces]=\"refractionBounces()\"\n            [ior]=\"refractionIor()\"\n            [fresnel]=\"refractionFresnel()\"\n            [color]=\"refractionColor()\"\n            [fastChroma]=\"refractionFastChroma()\"\n            ngtCompound\n            attach=\"material\"\n        >\n            <ng-content />\n        </ngt-mesh-refraction-material>\n    `,\n    imports: [NgIf],\n    schemas: [CUSTOM_ELEMENTS_SCHEMA],\n})\nexport class NgtsMeshRefractionMaterial extends NgtSignalStore<NgtsMeshRefractionMaterialState> {\n    @Input() materialRef = injectNgtRef<InstanceType<typeof MeshRefractionMaterial>>();\n    /** Environment map */\n    @Input({ required: true }) set envMap(envMap: THREE.CubeTexture | THREE.Texture) {\n        this.set({ envMap });\n    }\n    /** Number of ray-cast bounces, it can be expensive to have too many, 2 */\n    @Input() set bounces(bounces: number) {\n        this.set({ bounces });\n    }\n    /** Refraction index, 2.4 */\n    @Input() set ior(ior: number) {\n        this.set({ ior });\n    }\n    /** Fresnel (strip light), 0 */\n    @Input() set fresnel(fresnel: number) {\n        this.set({ fresnel });\n    }\n    /** RGB shift intensity, can be expensive, 0 */\n    @Input() set aberrationStrength(aberrationStrength: number) {\n        this.set({ aberrationStrength });\n    }\n    /** Color, white */\n    @Input() set color(color: THREE.ColorRepresentation) {\n        this.set({ color });\n    }\n    /** If this is on it uses fewer ray casts for the RGB shift sacrificing physical accuracy, true */\n    @Input() set fastChroma(fastChroma: boolean) {\n        this.set({ fastChroma });\n    }\n\n    readonly refractionEnvMap = this.select('envMap');\n    readonly refractionBounces = this.select('bounces');\n    readonly refractionIor = this.select('ior');\n    readonly refractionFresnel = this.select('fresnel');\n    readonly refractionAberrationStrength = this.select('aberrationStrength');\n    readonly refractionColor = this.select('color');\n    readonly refractionFastChroma = this.select('fastChroma');\n\n    readonly #store = inject(NgtStore);\n    readonly #size = this.#store.select('size');\n\n    readonly #envMap = this.select('envMap');\n\n    readonly defines = computed(() => {\n        const envMap = this.#envMap();\n        if (!envMap) return null;\n\n        const aberrationStrength = this.refractionAberrationStrength();\n        const fastChroma = this.refractionFastChroma();\n\n        const temp = {} as { [key: string]: string };\n        // Sampler2D and SamplerCube need different defines\n        const isCubeMap = isCubeTexture(envMap);\n        const w = (isCubeMap ? envMap.image[0]?.width : envMap.image.width) ?? 1024;\n        const cubeSize = w / 4;\n        const _lodMax = Math.floor(Math.log2(cubeSize));\n        const _cubeSize = Math.pow(2, _lodMax);\n        const width = 3 * Math.max(_cubeSize, 16 * 7);\n        const height = 4 * _cubeSize;\n        if (isCubeMap) temp['ENVMAP_TYPE_CUBEM'] = '';\n        temp['CUBEUV_TEXEL_WIDTH'] = `${1.0 / width}`;\n        temp['CUBEUV_TEXEL_HEIGHT'] = `${1.0 / height}`;\n        temp['CUBEUV_MAX_MIP'] = `${_lodMax}.0`;\n        // Add defines from chromatic aberration\n        if (aberrationStrength > 0) temp['CHROMATIC_ABERRATIONS'] = '';\n        if (fastChroma) temp['FAST_CHROMA'] = '';\n        return temp;\n    });\n    readonly resolution = computed(() => [this.#size().width, this.#size().height]);\n\n    constructor() {\n        super({ aberrationStrength: 0, fastChroma: true });\n        injectBeforeRender(({ camera }) => {\n            if (this.materialRef.nativeElement) {\n                (this.materialRef.nativeElement as any)!.viewMatrixInverse = camera.matrixWorld;\n                (this.materialRef.nativeElement as any)!.projectionMatrixInverse = camera.projectionMatrixInverse;\n            }\n        });\n        this.#setupGeometry();\n    }\n\n    #setupGeometry() {\n        effect(() => {\n            const material = this.materialRef.nativeElement;\n            if (!material) return;\n            const geometry = getLocalState(material).parent()?.geometry;\n            if (geometry) {\n                (material as any).bvh.updateFrom(\n                    new MeshBVH(geometry.toNonIndexed(), { lazyGeneration: false, strategy: SAH } as any)\n                );\n            }\n        });\n    }\n}\n"]}
169
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mesh-refraction-material.js","sourceRoot":"","sources":["../../../../../../libs/soba/materials/src/mesh-refraction-material/mesh-refraction-material.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgIf } from '@angular/common';\nimport { Component, computed, CUSTOM_ELEMENTS_SCHEMA, effect, inject, Input } from '@angular/core';\nimport { extend, getLocalState, injectBeforeRender, injectNgtRef, NgtSignalStore, NgtStore } from 'angular-three';\nimport { MeshRefractionMaterial } from 'angular-three-soba/shaders';\nimport { MeshBVH, MeshBVHUniformStruct, SAH } from 'three-mesh-bvh';\n\nextend({ MeshRefractionMaterial });\n\nexport interface NgtsMeshRefractionMaterialState {\n    /** Environment map */\n    envMap: THREE.CubeTexture | THREE.Texture;\n    /** Number of ray-cast bounces, it can be expensive to have too many, 2 */\n    bounces: number;\n    /** Refraction index, 2.4 */\n    ior: number;\n    /** Fresnel (strip light), 0 */\n    fresnel: number;\n    /** RGB shift intensity, can be expensive, 0 */\n    aberrationStrength: number;\n    /** Color, white */\n    color: THREE.ColorRepresentation;\n    /** If this is on it uses fewer ray casts for the RGB shift sacrificing physical accuracy, true */\n    fastChroma: boolean;\n}\n\nconst isCubeTexture = (def: THREE.CubeTexture | THREE.Texture): def is THREE.CubeTexture =>\n    def && (def as THREE.CubeTexture).isCubeTexture;\n\n@Component({\n    selector: 'ngts-mesh-refraction-material',\n    standalone: true,\n    template: `\n        <ngt-mesh-refraction-material\n            *ngIf=\"defines() as defines\"\n            [ref]=\"materialRef\"\n            [defines]=\"defines\"\n            [resolution]=\"resolution()\"\n            [aberrationStrength]=\"refractionAberrationStrength()\"\n            [envMap]=\"refractionEnvMap()\"\n            [bounces]=\"refractionBounces()\"\n            [ior]=\"refractionIor()\"\n            [fresnel]=\"refractionFresnel()\"\n            [color]=\"refractionColor()\"\n            [fastChroma]=\"refractionFastChroma()\"\n            ngtCompound\n            attach=\"material\"\n        >\n            <ng-content />\n        </ngt-mesh-refraction-material>\n    `,\n    imports: [NgIf],\n    schemas: [CUSTOM_ELEMENTS_SCHEMA],\n})\nexport class NgtsMeshRefractionMaterial extends NgtSignalStore<NgtsMeshRefractionMaterialState> {\n    @Input() materialRef = injectNgtRef<InstanceType<typeof MeshRefractionMaterial>>();\n    /** Environment map */\n    @Input({ required: true }) set envMap(envMap: THREE.CubeTexture | THREE.Texture) {\n        this.set({ envMap });\n    }\n    /** Number of ray-cast bounces, it can be expensive to have too many, 2 */\n    @Input() set bounces(bounces: number) {\n        this.set({ bounces });\n    }\n    /** Refraction index, 2.4 */\n    @Input() set ior(ior: number) {\n        this.set({ ior });\n    }\n    /** Fresnel (strip light), 0 */\n    @Input() set fresnel(fresnel: number) {\n        this.set({ fresnel });\n    }\n    /** RGB shift intensity, can be expensive, 0 */\n    @Input() set aberrationStrength(aberrationStrength: number) {\n        this.set({ aberrationStrength });\n    }\n    /** Color, white */\n    @Input() set color(color: THREE.ColorRepresentation) {\n        this.set({ color });\n    }\n    /** If this is on it uses fewer ray casts for the RGB shift sacrificing physical accuracy, true */\n    @Input() set fastChroma(fastChroma: boolean) {\n        this.set({ fastChroma });\n    }\n\n    readonly refractionEnvMap = this.select('envMap');\n    readonly refractionBounces = this.select('bounces');\n    readonly refractionIor = this.select('ior');\n    readonly refractionFresnel = this.select('fresnel');\n    readonly refractionAberrationStrength = this.select('aberrationStrength');\n    readonly refractionColor = this.select('color');\n    readonly refractionFastChroma = this.select('fastChroma');\n\n    readonly #store = inject(NgtStore);\n    readonly #size = this.#store.select('size');\n\n    readonly #envMap = this.select('envMap');\n\n    readonly defines = computed(() => {\n        const envMap = this.#envMap();\n        if (!envMap) return null;\n\n        const aberrationStrength = this.refractionAberrationStrength();\n        const fastChroma = this.refractionFastChroma();\n\n        const temp = {} as { [key: string]: string };\n        // Sampler2D and SamplerCube need different defines\n        const isCubeMap = isCubeTexture(envMap);\n        const w = (isCubeMap ? envMap.image[0]?.width : envMap.image.width) ?? 1024;\n        const cubeSize = w / 4;\n        const _lodMax = Math.floor(Math.log2(cubeSize));\n        const _cubeSize = Math.pow(2, _lodMax);\n        const width = 3 * Math.max(_cubeSize, 16 * 7);\n        const height = 4 * _cubeSize;\n        if (isCubeMap) temp['ENVMAP_TYPE_CUBEM'] = '';\n        temp['CUBEUV_TEXEL_WIDTH'] = `${1.0 / width}`;\n        temp['CUBEUV_TEXEL_HEIGHT'] = `${1.0 / height}`;\n        temp['CUBEUV_MAX_MIP'] = `${_lodMax}.0`;\n        // Add defines from chromatic aberration\n        if (aberrationStrength > 0) temp['CHROMATIC_ABERRATIONS'] = '';\n        if (fastChroma) temp['FAST_CHROMA'] = '';\n        return temp;\n    });\n    readonly resolution = computed(() => [this.#size().width, this.#size().height]);\n\n    constructor() {\n        super({ aberrationStrength: 0, fastChroma: true });\n        injectBeforeRender(({ camera }) => {\n            if (this.materialRef.nativeElement) {\n                (this.materialRef.nativeElement as any)!.viewMatrixInverse = camera.matrixWorld;\n                (this.materialRef.nativeElement as any)!.projectionMatrixInverse = camera.projectionMatrixInverse;\n            }\n        });\n        this.#setupGeometry();\n    }\n\n    #setupGeometry() {\n        effect(() => {\n            const material = this.materialRef.nativeElement;\n            if (!material) return;\n            const geometry = getLocalState(material).parent()?.geometry;\n            if (geometry) {\n                (material as any).bvh = new MeshBVHUniformStruct();\n                (material as any).bvh.updateFrom(\n                    new MeshBVH(geometry.clone().toNonIndexed(), { lazyGeneration: false, strategy: SAH } as any)\n                );\n            }\n        });\n    }\n}\n"]}