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.
- package/abstractions/edges/edges.d.ts +1 -1
- package/abstractions/grid/grid.d.ts +59 -0
- package/abstractions/index.d.ts +1 -0
- package/abstractions/text/text.d.ts +0 -1
- package/abstractions/text-3d/text-3d.d.ts +1 -1
- package/esm2022/abstractions/billboard/billboard.mjs +3 -3
- package/esm2022/abstractions/catmull-rom-line/catmull-rom-line.mjs +3 -3
- package/esm2022/abstractions/cubic-bezier-line/cubic-bezier-line.mjs +3 -3
- package/esm2022/abstractions/edges/edges.mjs +3 -3
- package/esm2022/abstractions/gizmo-helper/gizmo-helper.mjs +8 -8
- package/esm2022/abstractions/gizmo-helper/gizmo-viewcube/gizmo-viewcube-edge.mjs +3 -3
- package/esm2022/abstractions/gizmo-helper/gizmo-viewcube/gizmo-viewcube-face.mjs +6 -6
- package/esm2022/abstractions/gizmo-helper/gizmo-viewcube/gizmo-viewcube-inputs.mjs +3 -3
- package/esm2022/abstractions/gizmo-helper/gizmo-viewcube/gizmo-viewcube.mjs +3 -3
- package/esm2022/abstractions/gizmo-helper/gizmo-viewport/gizmo-viewport-axis.mjs +6 -6
- package/esm2022/abstractions/gizmo-helper/gizmo-viewport/gizmo-viewport.mjs +3 -3
- package/esm2022/abstractions/grid/grid.mjs +150 -0
- package/esm2022/abstractions/index.mjs +2 -1
- package/esm2022/abstractions/line/line-input.mjs +3 -3
- package/esm2022/abstractions/line/line.mjs +3 -3
- package/esm2022/abstractions/quadratic-bezier-line/quadratic-bezier-line.mjs +3 -3
- package/esm2022/abstractions/text/text.mjs +5 -7
- package/esm2022/abstractions/text-3d/text-3d.mjs +3 -3
- package/esm2022/cameras/camera/camera-content.mjs +3 -3
- package/esm2022/cameras/camera/camera.mjs +3 -3
- package/esm2022/cameras/cube-camera/cube-camera.mjs +3 -3
- package/esm2022/cameras/orthographic-camera/orthographic-camera.mjs +3 -3
- package/esm2022/cameras/perspective-camera/perspective-camera.mjs +3 -3
- package/esm2022/controls/orbit-controls/orbit-controls.mjs +3 -3
- package/esm2022/loaders/loader/loader.mjs +3 -3
- package/esm2022/materials/mesh-distort-material/mesh-distort-material.mjs +3 -3
- package/esm2022/materials/mesh-reflector-material/mesh-reflector-material.mjs +3 -3
- package/esm2022/materials/mesh-refraction-material/mesh-refraction-material.mjs +7 -6
- package/esm2022/materials/mesh-transmission-material/mesh-transmission-material.mjs +3 -3
- package/esm2022/materials/mesh-wobble-material/mesh-wobble-material.mjs +3 -3
- package/esm2022/misc/animations/animations.mjs +20 -20
- package/esm2022/misc/bake-shadows/bake-shadows.mjs +3 -3
- package/esm2022/performance/adaptive/adaptive-dpr.mjs +3 -3
- package/esm2022/performance/adaptive/adaptive-events.mjs +3 -3
- package/esm2022/performance/detailed/detailed.mjs +3 -3
- package/esm2022/performance/instances/instance.mjs +3 -3
- package/esm2022/performance/instances/instances.mjs +3 -3
- package/esm2022/performance/stats/stats.mjs +3 -3
- package/esm2022/shaders/grid-material/grid-material.mjs +62 -0
- package/esm2022/shaders/index.mjs +2 -1
- package/esm2022/staging/accumulative-shadows/accumulative-shadows.mjs +5 -5
- package/esm2022/staging/accumulative-shadows/randomized-lights.mjs +3 -3
- package/esm2022/staging/bounds/bounds.mjs +3 -3
- package/esm2022/staging/camera-shake/camera-shake.mjs +3 -3
- package/esm2022/staging/caustics/caustisc.mjs +5 -5
- package/esm2022/staging/center/center.mjs +3 -3
- package/esm2022/staging/cloud/cloud.mjs +3 -3
- package/esm2022/staging/contact-shadows/contact-shadows.mjs +3 -3
- package/esm2022/staging/environment/environment-cube.mjs +3 -3
- package/esm2022/staging/environment/environment-ground.mjs +3 -3
- package/esm2022/staging/environment/environment-input.mjs +3 -3
- package/esm2022/staging/environment/environment-map.mjs +3 -3
- package/esm2022/staging/environment/environment-portal.mjs +5 -5
- package/esm2022/staging/environment/environment.mjs +6 -6
- package/esm2022/staging/float/float.mjs +3 -3
- package/esm2022/staging/sky/sky.mjs +3 -3
- package/esm2022/staging/sparkles/sparkles.mjs +3 -3
- package/esm2022/staging/spot-light/spot-light-input.mjs +3 -3
- package/esm2022/staging/spot-light/spot-light-shadow-mesh-input.mjs +3 -3
- package/esm2022/staging/spot-light/spot-light-shadow-mesh.mjs +13 -11
- package/esm2022/staging/spot-light/spot-light.mjs +3 -3
- package/esm2022/staging/spot-light/volumetric-mesh.mjs +3 -3
- package/esm2022/staging/stage/stage.mjs +6 -6
- package/esm2022/staging/stars/stars.mjs +3 -3
- package/fesm2022/angular-three-soba-abstractions.mjs +205 -63
- package/fesm2022/angular-three-soba-abstractions.mjs.map +1 -1
- package/fesm2022/angular-three-soba-cameras.mjs +15 -15
- package/fesm2022/angular-three-soba-controls.mjs +3 -3
- package/fesm2022/angular-three-soba-loaders.mjs +3 -3
- package/fesm2022/angular-three-soba-materials.mjs +18 -17
- package/fesm2022/angular-three-soba-materials.mjs.map +1 -1
- package/fesm2022/angular-three-soba-misc.mjs +22 -22
- package/fesm2022/angular-three-soba-misc.mjs.map +1 -1
- package/fesm2022/angular-three-soba-performance.mjs +18 -18
- package/fesm2022/angular-three-soba-shaders.mjs +61 -1
- package/fesm2022/angular-three-soba-shaders.mjs.map +1 -1
- package/fesm2022/angular-three-soba-staging.mjs +90 -88
- package/fesm2022/angular-three-soba-staging.mjs.map +1 -1
- package/misc/animations/animations.d.ts +1 -1
- package/package.json +16 -16
- package/performance/instances/instances.d.ts +2 -2
- package/performance/instances/position-mesh.d.ts +1 -1
- package/plugin/package.json +2 -2
- package/plugin/src/generators/init/init.d.ts +3 -0
- package/plugin/src/generators/init/init.js +7 -1
- package/plugin/src/generators/init/init.js.map +1 -1
- package/shaders/grid-material/grid-material.d.ts +4 -0
- package/shaders/index.d.ts +1 -0
- package/staging/caustics/caustisc.d.ts +1 -1
- package/staging/sparkles/sparkles.d.ts +1 -1
- package/staging/spot-light/spot-light-shadow-mesh.d.ts +2 -2
- package/staging/spot-light/volumetric-mesh.d.ts +1 -1
- 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,
|
|
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.
|
|
83
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.0.
|
|
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.
|
|
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.
|
|
105
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.
|
|
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.
|
|
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.
|
|
72
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.
|
|
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.
|
|
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.
|
|
129
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.
|
|
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.
|
|
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.
|
|
114
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.
|
|
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.
|
|
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.
|
|
12
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.0.
|
|
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.
|
|
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.
|
|
53
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.0.
|
|
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.
|
|
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.
|
|
76
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.
|
|
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.
|
|
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.
|
|
41
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.
|
|
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.
|
|
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.
|
|
11
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.
|
|
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.
|
|
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.
|
|
132
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.
|
|
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.
|
|
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.
|
|
75
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.
|
|
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.
|
|
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.
|
|
30
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.
|
|
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.
|
|
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.
|
|
292
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.
|
|
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.
|
|
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',
|