angular-three-soba 2.0.0-beta.3 → 2.0.0-beta.5

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 (98) hide show
  1. package/abstractions/edges/edges.d.ts +1 -1
  2. package/abstractions/grid/grid.d.ts +59 -0
  3. package/abstractions/index.d.ts +1 -0
  4. package/abstractions/text/text.d.ts +0 -1
  5. package/abstractions/text-3d/text-3d.d.ts +1 -1
  6. package/esm2022/abstractions/billboard/billboard.mjs +3 -3
  7. package/esm2022/abstractions/catmull-rom-line/catmull-rom-line.mjs +3 -3
  8. package/esm2022/abstractions/cubic-bezier-line/cubic-bezier-line.mjs +3 -3
  9. package/esm2022/abstractions/edges/edges.mjs +3 -3
  10. package/esm2022/abstractions/gizmo-helper/gizmo-helper.mjs +8 -8
  11. package/esm2022/abstractions/gizmo-helper/gizmo-viewcube/gizmo-viewcube-edge.mjs +3 -3
  12. package/esm2022/abstractions/gizmo-helper/gizmo-viewcube/gizmo-viewcube-face.mjs +6 -6
  13. package/esm2022/abstractions/gizmo-helper/gizmo-viewcube/gizmo-viewcube-inputs.mjs +3 -3
  14. package/esm2022/abstractions/gizmo-helper/gizmo-viewcube/gizmo-viewcube.mjs +3 -3
  15. package/esm2022/abstractions/gizmo-helper/gizmo-viewport/gizmo-viewport-axis.mjs +6 -6
  16. package/esm2022/abstractions/gizmo-helper/gizmo-viewport/gizmo-viewport.mjs +3 -3
  17. package/esm2022/abstractions/grid/grid.mjs +150 -0
  18. package/esm2022/abstractions/index.mjs +2 -1
  19. package/esm2022/abstractions/line/line-input.mjs +3 -3
  20. package/esm2022/abstractions/line/line.mjs +3 -3
  21. package/esm2022/abstractions/quadratic-bezier-line/quadratic-bezier-line.mjs +3 -3
  22. package/esm2022/abstractions/text/text.mjs +5 -7
  23. package/esm2022/abstractions/text-3d/text-3d.mjs +3 -3
  24. package/esm2022/cameras/camera/camera-content.mjs +3 -3
  25. package/esm2022/cameras/camera/camera.mjs +3 -3
  26. package/esm2022/cameras/cube-camera/cube-camera.mjs +3 -3
  27. package/esm2022/cameras/orthographic-camera/orthographic-camera.mjs +3 -3
  28. package/esm2022/cameras/perspective-camera/perspective-camera.mjs +3 -3
  29. package/esm2022/controls/orbit-controls/orbit-controls.mjs +3 -3
  30. package/esm2022/loaders/loader/loader.mjs +3 -3
  31. package/esm2022/materials/mesh-distort-material/mesh-distort-material.mjs +3 -3
  32. package/esm2022/materials/mesh-reflector-material/mesh-reflector-material.mjs +3 -3
  33. package/esm2022/materials/mesh-refraction-material/mesh-refraction-material.mjs +7 -6
  34. package/esm2022/materials/mesh-transmission-material/mesh-transmission-material.mjs +3 -3
  35. package/esm2022/materials/mesh-wobble-material/mesh-wobble-material.mjs +3 -3
  36. package/esm2022/misc/animations/animations.mjs +20 -20
  37. package/esm2022/misc/bake-shadows/bake-shadows.mjs +3 -3
  38. package/esm2022/performance/adaptive/adaptive-dpr.mjs +3 -3
  39. package/esm2022/performance/adaptive/adaptive-events.mjs +3 -3
  40. package/esm2022/performance/detailed/detailed.mjs +3 -3
  41. package/esm2022/performance/instances/instance.mjs +3 -3
  42. package/esm2022/performance/instances/instances.mjs +3 -3
  43. package/esm2022/performance/stats/stats.mjs +3 -3
  44. package/esm2022/shaders/grid-material/grid-material.mjs +62 -0
  45. package/esm2022/shaders/index.mjs +2 -1
  46. package/esm2022/staging/accumulative-shadows/accumulative-shadows.mjs +5 -5
  47. package/esm2022/staging/accumulative-shadows/randomized-lights.mjs +3 -3
  48. package/esm2022/staging/bounds/bounds.mjs +3 -3
  49. package/esm2022/staging/camera-shake/camera-shake.mjs +3 -3
  50. package/esm2022/staging/caustics/caustisc.mjs +5 -5
  51. package/esm2022/staging/center/center.mjs +3 -3
  52. package/esm2022/staging/cloud/cloud.mjs +3 -3
  53. package/esm2022/staging/contact-shadows/contact-shadows.mjs +3 -3
  54. package/esm2022/staging/environment/environment-cube.mjs +3 -3
  55. package/esm2022/staging/environment/environment-ground.mjs +3 -3
  56. package/esm2022/staging/environment/environment-input.mjs +3 -3
  57. package/esm2022/staging/environment/environment-map.mjs +3 -3
  58. package/esm2022/staging/environment/environment-portal.mjs +5 -5
  59. package/esm2022/staging/environment/environment.mjs +6 -6
  60. package/esm2022/staging/float/float.mjs +3 -3
  61. package/esm2022/staging/sky/sky.mjs +3 -3
  62. package/esm2022/staging/sparkles/sparkles.mjs +3 -3
  63. package/esm2022/staging/spot-light/spot-light-input.mjs +3 -3
  64. package/esm2022/staging/spot-light/spot-light-shadow-mesh-input.mjs +3 -3
  65. package/esm2022/staging/spot-light/spot-light-shadow-mesh.mjs +13 -11
  66. package/esm2022/staging/spot-light/spot-light.mjs +3 -3
  67. package/esm2022/staging/spot-light/volumetric-mesh.mjs +3 -3
  68. package/esm2022/staging/stage/stage.mjs +6 -6
  69. package/esm2022/staging/stars/stars.mjs +3 -3
  70. package/fesm2022/angular-three-soba-abstractions.mjs +205 -63
  71. package/fesm2022/angular-three-soba-abstractions.mjs.map +1 -1
  72. package/fesm2022/angular-three-soba-cameras.mjs +15 -15
  73. package/fesm2022/angular-three-soba-controls.mjs +3 -3
  74. package/fesm2022/angular-three-soba-loaders.mjs +3 -3
  75. package/fesm2022/angular-three-soba-materials.mjs +18 -17
  76. package/fesm2022/angular-three-soba-materials.mjs.map +1 -1
  77. package/fesm2022/angular-three-soba-misc.mjs +22 -22
  78. package/fesm2022/angular-three-soba-misc.mjs.map +1 -1
  79. package/fesm2022/angular-three-soba-performance.mjs +18 -18
  80. package/fesm2022/angular-three-soba-shaders.mjs +61 -1
  81. package/fesm2022/angular-three-soba-shaders.mjs.map +1 -1
  82. package/fesm2022/angular-three-soba-staging.mjs +90 -88
  83. package/fesm2022/angular-three-soba-staging.mjs.map +1 -1
  84. package/misc/animations/animations.d.ts +1 -1
  85. package/package.json +16 -16
  86. package/performance/instances/instances.d.ts +2 -2
  87. package/performance/instances/position-mesh.d.ts +1 -1
  88. package/plugin/package.json +2 -2
  89. package/plugin/src/generators/init/init.d.ts +3 -0
  90. package/plugin/src/generators/init/init.js +7 -1
  91. package/plugin/src/generators/init/init.js.map +1 -1
  92. package/shaders/grid-material/grid-material.d.ts +4 -0
  93. package/shaders/index.d.ts +1 -0
  94. package/staging/caustics/caustisc.d.ts +1 -1
  95. package/staging/sparkles/sparkles.d.ts +1 -1
  96. package/staging/spot-light/spot-light-shadow-mesh.d.ts +2 -2
  97. package/staging/spot-light/volumetric-mesh.d.ts +1 -1
  98. package/staging/stars/stars.d.ts +1 -1
@@ -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.2", ngImport: i0, type: NgtsGrid, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
75
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.2", 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.2", 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
@@ -79,11 +79,11 @@ class NgtsLineInputs extends NgtSignalStore {
79
79
  worldUnits: this.#worldUnits(),
80
80
  }));
81
81
  }
82
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NgtsLineInputs, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
83
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.0.0", type: NgtsLineInputs, inputs: { vertexColors: "vertexColors", lineWidth: "lineWidth", alphaToCoverage: "alphaToCoverage", color: "color", dashed: "dashed", dashScale: "dashScale", dashSize: "dashSize", dashOffset: "dashOffset", gapSize: "gapSize", resolution: "resolution", wireframe: "wireframe", worldUnits: "worldUnits" }, usesInheritance: true, ngImport: i0 }); }
82
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: NgtsLineInputs, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
83
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.0.2", type: NgtsLineInputs, inputs: { vertexColors: "vertexColors", lineWidth: "lineWidth", alphaToCoverage: "alphaToCoverage", color: "color", dashed: "dashed", dashScale: "dashScale", dashSize: "dashSize", dashOffset: "dashOffset", gapSize: "gapSize", resolution: "resolution", wireframe: "wireframe", worldUnits: "worldUnits" }, usesInheritance: true, ngImport: i0 }); }
84
84
  }
85
85
  export { NgtsLineInputs };
86
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NgtsLineInputs, decorators: [{
86
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: NgtsLineInputs, decorators: [{
87
87
  type: Directive
88
88
  }], ctorParameters: function () { return []; }, propDecorators: { vertexColors: [{
89
89
  type: Input
@@ -101,8 +101,8 @@ class NgtsLine extends NgtsLineInputs {
101
101
  onCleanup(() => lineGeometry.dispose());
102
102
  });
103
103
  }
104
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NgtsLine, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
105
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.0", type: NgtsLine, isStandalone: true, selector: "ngts-line", inputs: { lineRef: "lineRef", points: "points", segments: "segments" }, usesInheritance: true, ngImport: i0, template: `
104
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: NgtsLine, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
105
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.2", type: NgtsLine, isStandalone: true, selector: "ngts-line", inputs: { lineRef: "lineRef", points: "points", segments: "segments" }, usesInheritance: true, ngImport: i0, template: `
106
106
  <ngt-primitive *args="[line()]" [ref]="lineRef" ngtCompound>
107
107
  <ngt-primitive *args="[lineGeometry()]" attach="geometry" />
108
108
  <ngt-primitive
@@ -125,7 +125,7 @@ class NgtsLine extends NgtsLineInputs {
125
125
  `, isInline: true, dependencies: [{ kind: "directive", type: NgtArgs, selector: "[args]", inputs: ["args"] }] }); }
126
126
  }
127
127
  export { NgtsLine };
128
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NgtsLine, decorators: [{
128
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: NgtsLine, decorators: [{
129
129
  type: Component,
130
130
  args: [{
131
131
  selector: 'ngts-line',
@@ -68,8 +68,8 @@ class NgtsQuadraticBezierLine extends NgtsLineInputs {
68
68
  }
69
69
  return this.#curve.getPoints(segments);
70
70
  }
71
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NgtsQuadraticBezierLine, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
72
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.0", type: NgtsQuadraticBezierLine, isStandalone: true, selector: "ngts-quadratic-bezier-line", inputs: { lineRef: "lineRef", start: "start", end: "end", mid: "mid", segments: "segments" }, usesInheritance: true, ngImport: i0, template: `
71
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: NgtsQuadraticBezierLine, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
72
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.2", type: NgtsQuadraticBezierLine, isStandalone: true, selector: "ngts-quadratic-bezier-line", inputs: { lineRef: "lineRef", start: "start", end: "end", mid: "mid", segments: "segments" }, usesInheritance: true, ngImport: i0, template: `
73
73
  <ngts-line
74
74
  [lineRef]="lineRef"
75
75
  [points]="points()"
@@ -89,7 +89,7 @@ class NgtsQuadraticBezierLine extends NgtsLineInputs {
89
89
  `, isInline: true, dependencies: [{ kind: "component", type: NgtsLine, selector: "ngts-line", inputs: ["lineRef", "points", "segments"] }] }); }
90
90
  }
91
91
  export { NgtsQuadraticBezierLine };
92
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NgtsQuadraticBezierLine, decorators: [{
92
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: NgtsQuadraticBezierLine, decorators: [{
93
93
  type: Component,
94
94
  args: [{
95
95
  selector: 'ngts-quadratic-bezier-line',
@@ -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();
@@ -125,8 +123,8 @@ class NgtsText extends NgtSignalStore {
125
123
  });
126
124
  });
127
125
  }
128
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NgtsText, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
129
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.0", type: NgtsText, isStandalone: true, selector: "ngts-text", inputs: { textRef: "textRef", text: "text", font: "font", fontSize: "fontSize", anchorX: "anchorX", anchorY: "anchorY", sdfGlyphSize: "sdfGlyphSize", characters: "characters", color: "color", maxWidth: "maxWidth", lineHeight: "lineHeight", letterSpacing: "letterSpacing", textAlign: "textAlign", clipRect: "clipRect", depthOffset: "depthOffset", direction: "direction", overflowWrap: "overflowWrap", whiteSpace: "whiteSpace", outlineWidth: "outlineWidth", outlineOffsetX: "outlineOffsetX", outlineOffsetY: "outlineOffsetY", outlineBlur: "outlineBlur", outlineColor: "outlineColor", outlineOpacity: "outlineOpacity", strokeWidth: "strokeWidth", strokeColor: "strokeColor", strokeOpacity: "strokeOpacity", fillOpacity: "fillOpacity", debugSDF: "debugSDF" }, outputs: { sync: "sync" }, usesInheritance: true, ngImport: i0, template: `
126
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: NgtsText, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
127
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.2", type: NgtsText, isStandalone: true, selector: "ngts-text", inputs: { textRef: "textRef", text: "text", font: "font", fontSize: "fontSize", anchorX: "anchorX", anchorY: "anchorY", sdfGlyphSize: "sdfGlyphSize", characters: "characters", color: "color", maxWidth: "maxWidth", lineHeight: "lineHeight", letterSpacing: "letterSpacing", textAlign: "textAlign", clipRect: "clipRect", depthOffset: "depthOffset", direction: "direction", overflowWrap: "overflowWrap", whiteSpace: "whiteSpace", outlineWidth: "outlineWidth", outlineOffsetX: "outlineOffsetX", outlineOffsetY: "outlineOffsetY", outlineBlur: "outlineBlur", outlineColor: "outlineColor", outlineOpacity: "outlineOpacity", strokeWidth: "strokeWidth", strokeColor: "strokeColor", strokeOpacity: "strokeOpacity", fillOpacity: "fillOpacity", debugSDF: "debugSDF" }, outputs: { sync: "sync" }, usesInheritance: true, ngImport: i0, template: `
130
128
  <ngt-primitive
131
129
  ngtCompound
132
130
  *args="[troikaText]"
@@ -165,7 +163,7 @@ class NgtsText extends NgtSignalStore {
165
163
  `, isInline: true, dependencies: [{ kind: "directive", type: NgtArgs, selector: "[args]", inputs: ["args"] }] }); }
166
164
  }
167
165
  export { NgtsText };
168
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NgtsText, decorators: [{
166
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: NgtsText, decorators: [{
169
167
  type: Component,
170
168
  args: [{
171
169
  selector: 'ngts-text',
@@ -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":"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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    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"]}
@@ -110,8 +110,8 @@ class NgtsText3D extends NgtSignalStore {
110
110
  #curveSegments;
111
111
  #letterSpacing;
112
112
  #lineHeight;
113
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NgtsText3D, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
114
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.0", type: NgtsText3D, isStandalone: true, selector: "ngts-text-3d", inputs: { textRef: "textRef", font: "font", text: "text", bevelEnabled: "bevelEnabled", bevelOffset: "bevelOffset", bevelSize: "bevelSize", bevelThickness: "bevelThickness", curveSegments: "curveSegments", bevelSegments: "bevelSegments", height: "height", size: "size", lineHeight: "lineHeight", letterSpacing: "letterSpacing", smooth: "smooth" }, usesInheritance: true, ngImport: i0, template: `
113
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: NgtsText3D, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
114
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.2", type: NgtsText3D, isStandalone: true, selector: "ngts-text-3d", inputs: { textRef: "textRef", font: "font", text: "text", bevelEnabled: "bevelEnabled", bevelOffset: "bevelOffset", bevelSize: "bevelSize", bevelThickness: "bevelThickness", curveSegments: "curveSegments", bevelSegments: "bevelSegments", height: "height", size: "size", lineHeight: "lineHeight", letterSpacing: "letterSpacing", smooth: "smooth" }, usesInheritance: true, ngImport: i0, template: `
115
115
  <ngt-mesh ngtCompound [ref]="textRef">
116
116
  <ngt-text-geometry *args="geometryArgs()" />
117
117
  <ng-content />
@@ -119,7 +119,7 @@ class NgtsText3D extends NgtSignalStore {
119
119
  `, isInline: true, dependencies: [{ kind: "directive", type: NgtArgs, selector: "[args]", inputs: ["args"] }] }); }
120
120
  }
121
121
  export { NgtsText3D };
122
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NgtsText3D, decorators: [{
122
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: NgtsText3D, decorators: [{
123
123
  type: Component,
124
124
  args: [{
125
125
  selector: 'ngts-text-3d',
@@ -8,11 +8,11 @@ class NgtsCameraContent {
8
8
  static ngTemplateContextGuard(_, ctx) {
9
9
  return true;
10
10
  }
11
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NgtsCameraContent, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
12
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.0.0", type: NgtsCameraContent, isStandalone: true, selector: "ng-template[ngtsCameraContent]", inputs: { ngtsCameraContent: "ngtsCameraContent" }, ngImport: i0 }); }
11
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: NgtsCameraContent, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
12
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.0.2", type: NgtsCameraContent, isStandalone: true, selector: "ng-template[ngtsCameraContent]", inputs: { ngtsCameraContent: "ngtsCameraContent" }, ngImport: i0 }); }
13
13
  }
14
14
  export { NgtsCameraContent };
15
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NgtsCameraContent, decorators: [{
15
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: NgtsCameraContent, decorators: [{
16
16
  type: Directive,
17
17
  args: [{ selector: 'ng-template[ngtsCameraContent]', standalone: true }]
18
18
  }], propDecorators: { ngtsCameraContent: [{
@@ -49,11 +49,11 @@ class NgtsCamera extends NgtSignalStore {
49
49
  camera.updateProjectionMatrix();
50
50
  });
51
51
  }
52
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NgtsCamera, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
53
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.0.0", type: NgtsCamera, inputs: { makeDefault: "makeDefault", manual: "manual", frames: "frames", resolution: "resolution", envMap: "envMap", cameraRef: "cameraRef" }, usesInheritance: true, ngImport: i0 }); }
52
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: NgtsCamera, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
53
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.0.2", type: NgtsCamera, inputs: { makeDefault: "makeDefault", manual: "manual", frames: "frames", resolution: "resolution", envMap: "envMap", cameraRef: "cameraRef" }, usesInheritance: true, ngImport: i0 }); }
54
54
  }
55
55
  export { NgtsCamera };
56
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NgtsCamera, decorators: [{
56
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: NgtsCamera, decorators: [{
57
57
  type: Directive
58
58
  }], ctorParameters: function () { return []; }, propDecorators: { makeDefault: [{
59
59
  type: Input
@@ -72,8 +72,8 @@ class NgtsCubeCamera extends NgtSignalStore {
72
72
  }
73
73
  });
74
74
  }
75
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NgtsCubeCamera, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
76
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.0", type: NgtsCubeCamera, isStandalone: true, selector: "ngts-cube-camera", inputs: { cameraRef: "cameraRef", frames: "frames", resolution: "resolution", near: "near", far: "far", envMap: "envMap", fog: "fog" }, queries: [{ propertyName: "cameraContent", first: true, predicate: NgtsCameraContent, descendants: true }], viewQueries: [{ propertyName: "groupRef", first: true, predicate: ["group"], descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: `
75
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: NgtsCubeCamera, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
76
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.2", type: NgtsCubeCamera, isStandalone: true, selector: "ngts-cube-camera", inputs: { cameraRef: "cameraRef", frames: "frames", resolution: "resolution", near: "near", far: "far", envMap: "envMap", fog: "fog" }, queries: [{ propertyName: "cameraContent", first: true, predicate: NgtsCameraContent, descendants: true }], viewQueries: [{ propertyName: "groupRef", first: true, predicate: ["group"], descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: `
77
77
  <ngt-group ngtCompound>
78
78
  <ngt-cube-camera [ref]="cameraRef" *args="cameraArgs()" />
79
79
  <ngt-group #group>
@@ -87,7 +87,7 @@ class NgtsCubeCamera extends NgtSignalStore {
87
87
  `, isInline: true, dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: NgtArgs, selector: "[args]", inputs: ["args"] }] }); }
88
88
  }
89
89
  export { NgtsCubeCamera };
90
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NgtsCubeCamera, decorators: [{
90
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: NgtsCubeCamera, decorators: [{
91
91
  type: Component,
92
92
  args: [{
93
93
  selector: 'ngts-cube-camera',
@@ -37,8 +37,8 @@ class NgtsOrthographicCamera extends NgtsCamera {
37
37
  this.cameraBottom = computed(() => this.#bottom() || this.#size().height / -2);
38
38
  this.set({ left: 0, right: 0, top: 0, bottom: 0 });
39
39
  }
40
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NgtsOrthographicCamera, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
41
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.0", type: NgtsOrthographicCamera, isStandalone: true, selector: "ngts-orthographic-camera", inputs: { left: "left", right: "right", top: "top", bottom: "bottom" }, queries: [{ propertyName: "cameraContent", first: true, predicate: NgtsCameraContent, descendants: true }], usesInheritance: true, ngImport: i0, template: `
40
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: NgtsOrthographicCamera, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
41
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.2", type: NgtsOrthographicCamera, isStandalone: true, selector: "ngts-orthographic-camera", inputs: { left: "left", right: "right", top: "top", bottom: "bottom" }, queries: [{ propertyName: "cameraContent", first: true, predicate: NgtsCameraContent, descendants: true }], usesInheritance: true, ngImport: i0, template: `
42
42
  <ngt-orthographic-camera
43
43
  ngtCompound
44
44
  [ref]="cameraRef"
@@ -58,7 +58,7 @@ class NgtsOrthographicCamera extends NgtsCamera {
58
58
  `, isInline: true, dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }] }); }
59
59
  }
60
60
  export { NgtsOrthographicCamera };
61
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NgtsOrthographicCamera, decorators: [{
61
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: NgtsOrthographicCamera, decorators: [{
62
62
  type: Component,
63
63
  args: [{
64
64
  selector: 'ngts-orthographic-camera',
@@ -7,8 +7,8 @@ import { NgtsCameraContent } from '../camera/camera-content';
7
7
  import * as i0 from "@angular/core";
8
8
  extend({ PerspectiveCamera, Group });
9
9
  class NgtsPerspectiveCamera extends NgtsCamera {
10
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NgtsPerspectiveCamera, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
11
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.0", type: NgtsPerspectiveCamera, isStandalone: true, selector: "ngts-perspective-camera", queries: [{ propertyName: "cameraContent", first: true, predicate: NgtsCameraContent, descendants: true }], usesInheritance: true, ngImport: i0, template: `
10
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: NgtsPerspectiveCamera, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
11
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.2", type: NgtsPerspectiveCamera, isStandalone: true, selector: "ngts-perspective-camera", queries: [{ propertyName: "cameraContent", first: true, predicate: NgtsCameraContent, descendants: true }], usesInheritance: true, ngImport: i0, template: `
12
12
  <ngt-perspective-camera [ref]="cameraRef" ngtCompound>
13
13
  <ng-container
14
14
  *ngIf="cameraContent && !cameraContent.ngtsCameraContent"
@@ -21,7 +21,7 @@ class NgtsPerspectiveCamera extends NgtsCamera {
21
21
  `, isInline: true, dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }] }); }
22
22
  }
23
23
  export { NgtsPerspectiveCamera };
24
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NgtsPerspectiveCamera, decorators: [{
24
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: NgtsPerspectiveCamera, decorators: [{
25
25
  type: Component,
26
26
  args: [{
27
27
  selector: 'ngts-perspective-camera',
@@ -128,11 +128,11 @@ class NgtsOrbitControls extends NgtSignalStore {
128
128
  });
129
129
  });
130
130
  }
131
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NgtsOrbitControls, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
132
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.0", type: NgtsOrbitControls, isStandalone: true, selector: "ngts-orbit-controls", inputs: { controlsRef: "controlsRef", camera: "camera", domElement: "domElement", makeDefault: "makeDefault", regress: "regress", target: "target", enableDamping: "enableDamping" }, outputs: { change: "change", start: "start", end: "end" }, usesInheritance: true, ngImport: i0, template: ` <ngt-primitive *args="args()" ngtCompound [enableDamping]="damping()" /> `, isInline: true, dependencies: [{ kind: "directive", type: NgtArgs, selector: "[args]", inputs: ["args"] }] }); }
131
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: NgtsOrbitControls, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
132
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.2", type: NgtsOrbitControls, isStandalone: true, selector: "ngts-orbit-controls", inputs: { controlsRef: "controlsRef", camera: "camera", domElement: "domElement", makeDefault: "makeDefault", regress: "regress", target: "target", enableDamping: "enableDamping" }, outputs: { change: "change", start: "start", end: "end" }, usesInheritance: true, ngImport: i0, template: ` <ngt-primitive *args="args()" ngtCompound [enableDamping]="damping()" /> `, isInline: true, dependencies: [{ kind: "directive", type: NgtArgs, selector: "[args]", inputs: ["args"] }] }); }
133
133
  }
134
134
  export { NgtsOrbitControls };
135
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NgtsOrbitControls, decorators: [{
135
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: NgtsOrbitControls, decorators: [{
136
136
  type: Component,
137
137
  args: [{
138
138
  selector: 'ngts-orbit-controls',
@@ -71,8 +71,8 @@ class NgtsLoader extends NgtSignalStore {
71
71
  onCleanup(() => cancelAnimationFrame(rafId));
72
72
  });
73
73
  }
74
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NgtsLoader, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
75
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.0", type: NgtsLoader, isStandalone: true, selector: "ngts-loader", inputs: { containerClass: "containerClass", innerClass: "innerClass", barClass: "barClass", dataClass: "dataClass", dataInterpolation: "dataInterpolation", initialState: "initialState" }, viewQueries: [{ propertyName: "progressSpanRef", first: true, predicate: ["progressSpanRef"], descendants: true }], usesInheritance: true, ngImport: i0, template: `
74
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: NgtsLoader, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
75
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.2", type: NgtsLoader, isStandalone: true, selector: "ngts-loader", inputs: { containerClass: "containerClass", innerClass: "innerClass", barClass: "barClass", dataClass: "dataClass", dataInterpolation: "dataInterpolation", initialState: "initialState" }, viewQueries: [{ propertyName: "progressSpanRef", first: true, predicate: ["progressSpanRef"], descendants: true }], usesInheritance: true, ngImport: i0, template: `
76
76
  <div
77
77
  *ngIf="shown()"
78
78
  class="ngts-loader-container"
@@ -93,7 +93,7 @@ class NgtsLoader extends NgtSignalStore {
93
93
  `, isInline: true, styles: [".ngts-loader-container{--ngts-loader-container-opacity: 0;position:absolute;top:0;left:0;width:100%;height:100%;background:#171717;display:flex;align-items:center;justify-content:center;transition:opacity .3s ease;z-index:1000;opacity:var(--ngts-loader-container-opacity)}.ngts-loader-inner{width:100px;height:3px;background:#272727;text-align:center}.ngts-loader-bar{--ngts-loader-bar-scale: 0;height:3px;width:100px;background:white;transition:transform .2s;transform-origin:left center;transform:scaleX(var(--ngts-loader-bar-scale))}.ngts-loader-data{display:inline-block;position:relative;font-feature-settings:\"tnum\";font-variant-numeric:tabular-nums;margin-top:.8em;color:#f0f0f0;font-size:.6em;font-family:-apple-system,BlinkMacSystemFont,Inter,Segoe UI,Helvetica Neue,Helvetica,Arial,Roboto,Ubuntu,sans-serif,\"Apple Color Emoji\",\"Segoe UI Emoji\",Segoe UI Symbol;white-space:nowrap}\n"], dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
94
94
  }
95
95
  export { NgtsLoader };
96
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NgtsLoader, decorators: [{
96
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: NgtsLoader, decorators: [{
97
97
  type: Component,
98
98
  args: [{ selector: 'ngts-loader', standalone: true, template: `
99
99
  <div
@@ -26,8 +26,8 @@ class NgtsMeshDistortMaterial extends NgtSignalStore {
26
26
  this.material.time = clock.getElapsedTime() * this.get('speed');
27
27
  });
28
28
  }
29
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NgtsMeshDistortMaterial, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
30
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.0", type: NgtsMeshDistortMaterial, isStandalone: true, selector: "ngts-mesh-distort-material", inputs: { materialRef: "materialRef", time: "time", distort: "distort", radius: "radius", speed: "speed" }, usesInheritance: true, ngImport: i0, template: `
29
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: NgtsMeshDistortMaterial, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
30
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.2", type: NgtsMeshDistortMaterial, isStandalone: true, selector: "ngts-mesh-distort-material", inputs: { materialRef: "materialRef", time: "time", distort: "distort", radius: "radius", speed: "speed" }, usesInheritance: true, ngImport: i0, template: `
31
31
  <ngt-primitive
32
32
  *args="[material]"
33
33
  [ref]="materialRef"
@@ -40,7 +40,7 @@ class NgtsMeshDistortMaterial extends NgtSignalStore {
40
40
  `, isInline: true, dependencies: [{ kind: "directive", type: NgtArgs, selector: "[args]", inputs: ["args"] }] }); }
41
41
  }
42
42
  export { NgtsMeshDistortMaterial };
43
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NgtsMeshDistortMaterial, decorators: [{
43
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: NgtsMeshDistortMaterial, decorators: [{
44
44
  type: Component,
45
45
  args: [{
46
46
  selector: 'ngts-mesh-distort-material',
@@ -288,8 +288,8 @@ class NgtsMeshReflectorMaterial extends NgtSignalStore {
288
288
  projectionMatrix.elements[10] = this.#clipPlane.z + 1.0;
289
289
  projectionMatrix.elements[14] = this.#clipPlane.w;
290
290
  }
291
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NgtsMeshReflectorMaterial, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
292
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.0", type: NgtsMeshReflectorMaterial, isStandalone: true, selector: "ngts-mesh-reflector-material", inputs: { materialRef: "materialRef", resolution: "resolution", mixBlur: "mixBlur", mixStrength: "mixStrength", blur: "blur", mirror: "mirror", minDepthThreshold: "minDepthThreshold", maxDepthThreshold: "maxDepthThreshold", depthScale: "depthScale", depthToBlurRatioBias: "depthToBlurRatioBias", distortionMap: "distortionMap", distortion: "distortion", mixContrast: "mixContrast", reflectorOffset: "reflectorOffset" }, usesInheritance: true, ngImport: i0, template: `
291
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: NgtsMeshReflectorMaterial, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
292
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.2", type: NgtsMeshReflectorMaterial, isStandalone: true, selector: "ngts-mesh-reflector-material", inputs: { materialRef: "materialRef", resolution: "resolution", mixBlur: "mixBlur", mixStrength: "mixStrength", blur: "blur", mirror: "mirror", minDepthThreshold: "minDepthThreshold", maxDepthThreshold: "maxDepthThreshold", depthScale: "depthScale", depthToBlurRatioBias: "depthToBlurRatioBias", distortionMap: "distortionMap", distortion: "distortion", mixContrast: "mixContrast", reflectorOffset: "reflectorOffset" }, usesInheritance: true, ngImport: i0, template: `
293
293
  <ngt-mesh-reflector-material
294
294
  ngtCompound
295
295
  attach="material"
@@ -317,7 +317,7 @@ class NgtsMeshReflectorMaterial extends NgtSignalStore {
317
317
  `, isInline: true, dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] }); }
318
318
  }
319
319
  export { NgtsMeshReflectorMaterial };
320
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NgtsMeshReflectorMaterial, decorators: [{
320
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: NgtsMeshReflectorMaterial, decorators: [{
321
321
  type: Component,
322
322
  args: [{
323
323
  selector: 'ngts-mesh-reflector-material',