angular-three-soba 2.1.0 → 2.2.0

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 (65) hide show
  1. package/abstractions/lib/catmull-rom-line.d.ts +34 -34
  2. package/abstractions/lib/edges.d.ts +53 -53
  3. package/abstractions/lib/grid.d.ts +30 -30
  4. package/abstractions/lib/line.d.ts +1 -1
  5. package/abstractions/lib/prism-geometry.d.ts +4 -4
  6. package/abstractions/lib/rounded-box.d.ts +1 -1
  7. package/abstractions/lib/text-3d.d.ts +37 -37
  8. package/abstractions/lib/text.d.ts +1 -1
  9. package/cameras/lib/cube-camera.d.ts +1 -1
  10. package/cameras/lib/orthographic-camera.d.ts +1 -1
  11. package/cameras/lib/perspective-camera.d.ts +1 -1
  12. package/controls/index.d.ts +9 -1
  13. package/controls/lib/camera-controls.d.ts +1 -1
  14. package/controls/lib/orbit-controls.d.ts +1 -1
  15. package/esm2022/controls/index.mjs +6 -2
  16. package/esm2022/gizmos/angular-three-soba-gizmos.mjs +5 -0
  17. package/esm2022/gizmos/index.mjs +6 -0
  18. package/esm2022/gizmos/lib/gizmo-helper/gizmo-helper.mjs +187 -0
  19. package/esm2022/gizmos/lib/gizmo-helper/gizmo-viewcube.mjs +304 -0
  20. package/esm2022/gizmos/lib/gizmo-helper/gizmo-viewport.mjs +332 -0
  21. package/esm2022/gizmos/lib/pivot-controls/axis-arrow.mjs +263 -0
  22. package/esm2022/gizmos/lib/pivot-controls/axis-rotator.mjs +264 -0
  23. package/esm2022/gizmos/lib/pivot-controls/pivot-controls.mjs +340 -0
  24. package/esm2022/gizmos/lib/pivot-controls/plane-slider.mjs +266 -0
  25. package/esm2022/gizmos/lib/pivot-controls/scaling-sphere.mjs +232 -0
  26. package/esm2022/gizmos/lib/transform-controls.mjs +177 -0
  27. package/fesm2022/angular-three-soba-controls.mjs +14 -1337
  28. package/fesm2022/angular-three-soba-controls.mjs.map +1 -1
  29. package/fesm2022/angular-three-soba-gizmos.mjs +2319 -0
  30. package/fesm2022/angular-three-soba-gizmos.mjs.map +1 -0
  31. package/gizmos/README.md +3 -0
  32. package/gizmos/index.d.ts +5 -0
  33. package/gizmos/lib/gizmo-helper/gizmo-helper.d.ts +45 -0
  34. package/gizmos/lib/gizmo-helper/gizmo-viewcube.d.ts +74 -0
  35. package/gizmos/lib/gizmo-helper/gizmo-viewport.d.ts +64 -0
  36. package/{controls → gizmos}/lib/pivot-controls/pivot-controls.d.ts +1 -1
  37. package/gizmos/lib/transform-controls.d.ts +50 -0
  38. package/materials/lib/custom-shader-material.d.ts +3 -3
  39. package/materials/lib/mesh-refraction-material.d.ts +2 -2
  40. package/materials/lib/mesh-transmission-material.d.ts +1 -1
  41. package/misc/lib/computed-attribute.d.ts +5 -5
  42. package/misc/lib/html/html.d.ts +1 -1
  43. package/misc/lib/sampler.d.ts +1 -1
  44. package/package.json +13 -7
  45. package/performances/lib/instances/instances.d.ts +9 -9
  46. package/performances/lib/points/points.d.ts +19 -19
  47. package/performances/lib/segments/segments.d.ts +4 -4
  48. package/staging/lib/accumulative-shadows.d.ts +1 -1
  49. package/staging/lib/caustics.d.ts +1 -1
  50. package/staging/lib/center.d.ts +2 -2
  51. package/staging/lib/contact-shadows.d.ts +1 -1
  52. package/staging/lib/lightformer.d.ts +1 -1
  53. package/staging/lib/mask.d.ts +1 -1
  54. package/staging/lib/render-texture.d.ts +1 -1
  55. package/staging/lib/spot-light.d.ts +2 -2
  56. package/staging/lib/stage.d.ts +1 -1
  57. package/esm2022/controls/lib/pivot-controls/axis-arrow.mjs +0 -263
  58. package/esm2022/controls/lib/pivot-controls/axis-rotator.mjs +0 -264
  59. package/esm2022/controls/lib/pivot-controls/pivot-controls.mjs +0 -340
  60. package/esm2022/controls/lib/pivot-controls/plane-slider.mjs +0 -266
  61. package/esm2022/controls/lib/pivot-controls/scaling-sphere.mjs +0 -232
  62. /package/{controls → gizmos}/lib/pivot-controls/axis-arrow.d.ts +0 -0
  63. /package/{controls → gizmos}/lib/pivot-controls/axis-rotator.d.ts +0 -0
  64. /package/{controls → gizmos}/lib/pivot-controls/plane-slider.d.ts +0 -0
  65. /package/{controls → gizmos}/lib/pivot-controls/scaling-sphere.d.ts +0 -0
@@ -14,7 +14,7 @@ export interface NgtsRoundedBoxOptions extends Partial<NgtMesh> {
14
14
  }
15
15
  export declare class NgtsRoundedBox {
16
16
  options: import("@angular/core").InputSignalWithTransform<NgtsRoundedBoxOptions, "" | Partial<NgtsRoundedBoxOptions>>;
17
- parameters: import("@angular/core").Signal<Omit<NgtsRoundedBoxOptions, "width" | "height" | "depth" | "steps" | "bevelSegments" | "radius" | "smoothness" | "creaseAngle">>;
17
+ parameters: import("@angular/core").Signal<Omit<NgtsRoundedBoxOptions, "height" | "bevelSegments" | "width" | "depth" | "radius" | "smoothness" | "steps" | "creaseAngle">>;
18
18
  private width;
19
19
  private height;
20
20
  private depth;
@@ -15,7 +15,17 @@ export declare class NgtsText3D {
15
15
  addEventListener: (<TEventKey extends keyof import("angular-three").NgtNodeEventMap<Mesh<import("three").BufferGeometry<import("three").NormalBufferAttributes>, import("three").Material | import("three").Material[], import("three").Object3DEventMap>>>(type: TEventKey, listener: (this: import("angular-three").NgtNodeElement<Mesh<import("three").BufferGeometry<import("three").NormalBufferAttributes>, import("three").Material | import("three").Material[], import("three").Object3DEventMap>, typeof Mesh>, ev: import("angular-three").NgtNodeEventMap<Mesh<import("three").BufferGeometry<import("three").NormalBufferAttributes>, import("three").Material | import("three").Material[], import("three").Object3DEventMap>>[TEventKey]) => any) => void) & (<TEventKey extends keyof import("angular-three").NgtAllObject3DEventsMap>(type: TEventKey, listener: (this: any, ev: import("angular-three").NgtAllObject3DEventsMap[TEventKey]) => any) => void);
16
16
  removeEventListener: (<TEventKey extends keyof import("angular-three").NgtNodeEventMap<Mesh<import("three").BufferGeometry<import("three").NormalBufferAttributes>, import("three").Material | import("three").Material[], import("three").Object3DEventMap>>>(type: TEventKey, listener: (this: import("angular-three").NgtNodeElement<Mesh<import("three").BufferGeometry<import("three").NormalBufferAttributes>, import("three").Material | import("three").Material[], import("three").Object3DEventMap>, typeof Mesh>, ev: import("angular-three").NgtNodeEventMap<Mesh<import("three").BufferGeometry<import("three").NormalBufferAttributes>, import("three").Material | import("three").Material[], import("three").Object3DEventMap>>[TEventKey]) => any) => void) & (<TEventKey extends keyof import("angular-three").NgtAllObject3DEventsMap>(type: TEventKey, listener: (this: any, ev: import("angular-three").NgtAllObject3DEventsMap[TEventKey]) => any) => void);
17
17
  __ngt_args__: [geometry?: import("three").BufferGeometry<import("three").NormalBufferAttributes> | undefined, material?: import("three").Material | import("three").Material[] | undefined];
18
+ readonly isMesh?: true | undefined;
18
19
  readonly type?: string | undefined;
20
+ geometry?: import("three").BufferGeometry<import("three").NormalBufferAttributes> | undefined;
21
+ material?: import("three").Material | import("three").Material[] | undefined;
22
+ morphTargetInfluences?: number[] | undefined;
23
+ morphTargetDictionary?: {
24
+ [key: string]: number;
25
+ } | undefined;
26
+ updateMorphTargets?: (() => void) | undefined;
27
+ getVertexPosition?: ((index: number, target: import("three").Vector3) => import("three").Vector3) | undefined;
28
+ toJSON?: ((meta?: import("three").JSONMeta) => import("three").MeshJSON) | undefined;
19
29
  readonly isObject3D?: true | undefined;
20
30
  readonly id?: number | undefined;
21
31
  uuid?: string | undefined;
@@ -80,20 +90,10 @@ export declare class NgtsText3D {
80
90
  updateMatrix?: (() => void) | undefined;
81
91
  updateMatrixWorld?: ((force?: boolean) => void) | undefined;
82
92
  updateWorldMatrix?: ((updateParents: boolean, updateChildren: boolean) => void) | undefined;
83
- toJSON?: ((meta?: import("three").JSONMeta) => import("three").MeshJSON) | undefined;
84
93
  clone?: ((recursive?: boolean) => Mesh<import("three").BufferGeometry<import("three").NormalBufferAttributes>, import("three").Material | import("three").Material[], import("three").Object3DEventMap>) | undefined;
85
94
  copy?: ((object: import("three").Object3D, recursive?: boolean) => Mesh<import("three").BufferGeometry<import("three").NormalBufferAttributes>, import("three").Material | import("three").Material[], import("three").Object3DEventMap>) | undefined;
86
95
  hasEventListener?: (<T extends keyof import("three").Object3DEventMap>(type: T, listener: import("three").EventListener<import("three").Object3DEventMap[T], T, Mesh<import("three").BufferGeometry<import("three").NormalBufferAttributes>, import("three").Material | import("three").Material[], import("three").Object3DEventMap>>) => boolean) | undefined;
87
96
  dispatchEvent?: (<T extends keyof import("three").Object3DEventMap>(event: import("three").BaseEvent<T> & import("three").Object3DEventMap[T]) => void) | undefined;
88
- geometry?: import("three").BufferGeometry<import("three").NormalBufferAttributes> | undefined;
89
- material?: import("three").Material | import("three").Material[] | undefined;
90
- readonly isMesh?: true | undefined;
91
- morphTargetInfluences?: number[] | undefined;
92
- morphTargetDictionary?: {
93
- [key: string]: number;
94
- } | undefined;
95
- updateMorphTargets?: (() => void) | undefined;
96
- getVertexPosition?: ((index: number, target: import("three").Vector3) => import("three").Vector3) | undefined;
97
97
  position: import("angular-three").NgtVector3;
98
98
  up: import("angular-three").NgtVector3;
99
99
  scale: import("angular-three").NgtVector3;
@@ -108,7 +108,17 @@ export declare class NgtsText3D {
108
108
  addEventListener: (<TEventKey extends keyof import("angular-three").NgtNodeEventMap<Mesh<import("three").BufferGeometry<import("three").NormalBufferAttributes>, import("three").Material | import("three").Material[], import("three").Object3DEventMap>>>(type: TEventKey, listener: (this: import("angular-three").NgtNodeElement<Mesh<import("three").BufferGeometry<import("three").NormalBufferAttributes>, import("three").Material | import("three").Material[], import("three").Object3DEventMap>, typeof Mesh>, ev: import("angular-three").NgtNodeEventMap<Mesh<import("three").BufferGeometry<import("three").NormalBufferAttributes>, import("three").Material | import("three").Material[], import("three").Object3DEventMap>>[TEventKey]) => any) => void) & (<TEventKey extends keyof import("angular-three").NgtAllObject3DEventsMap>(type: TEventKey, listener: (this: any, ev: import("angular-three").NgtAllObject3DEventsMap[TEventKey]) => any) => void);
109
109
  removeEventListener: (<TEventKey extends keyof import("angular-three").NgtNodeEventMap<Mesh<import("three").BufferGeometry<import("three").NormalBufferAttributes>, import("three").Material | import("three").Material[], import("three").Object3DEventMap>>>(type: TEventKey, listener: (this: import("angular-three").NgtNodeElement<Mesh<import("three").BufferGeometry<import("three").NormalBufferAttributes>, import("three").Material | import("three").Material[], import("three").Object3DEventMap>, typeof Mesh>, ev: import("angular-three").NgtNodeEventMap<Mesh<import("three").BufferGeometry<import("three").NormalBufferAttributes>, import("three").Material | import("three").Material[], import("three").Object3DEventMap>>[TEventKey]) => any) => void) & (<TEventKey extends keyof import("angular-three").NgtAllObject3DEventsMap>(type: TEventKey, listener: (this: any, ev: import("angular-three").NgtAllObject3DEventsMap[TEventKey]) => any) => void);
110
110
  __ngt_args__: [geometry?: import("three").BufferGeometry<import("three").NormalBufferAttributes> | undefined, material?: import("three").Material | import("three").Material[] | undefined];
111
+ readonly isMesh?: true | undefined;
111
112
  readonly type?: string | undefined;
113
+ geometry?: import("three").BufferGeometry<import("three").NormalBufferAttributes> | undefined;
114
+ material?: import("three").Material | import("three").Material[] | undefined;
115
+ morphTargetInfluences?: number[] | undefined;
116
+ morphTargetDictionary?: {
117
+ [key: string]: number;
118
+ } | undefined;
119
+ updateMorphTargets?: (() => void) | undefined;
120
+ getVertexPosition?: ((index: number, target: import("three").Vector3) => import("three").Vector3) | undefined;
121
+ toJSON?: ((meta?: import("three").JSONMeta) => import("three").MeshJSON) | undefined;
112
122
  readonly isObject3D?: true | undefined;
113
123
  readonly id?: number | undefined;
114
124
  uuid?: string | undefined;
@@ -173,20 +183,10 @@ export declare class NgtsText3D {
173
183
  updateMatrix?: (() => void) | undefined;
174
184
  updateMatrixWorld?: ((force?: boolean) => void) | undefined;
175
185
  updateWorldMatrix?: ((updateParents: boolean, updateChildren: boolean) => void) | undefined;
176
- toJSON?: ((meta?: import("three").JSONMeta) => import("three").MeshJSON) | undefined;
177
186
  clone?: ((recursive?: boolean) => Mesh<import("three").BufferGeometry<import("three").NormalBufferAttributes>, import("three").Material | import("three").Material[], import("three").Object3DEventMap>) | undefined;
178
187
  copy?: ((object: import("three").Object3D, recursive?: boolean) => Mesh<import("three").BufferGeometry<import("three").NormalBufferAttributes>, import("three").Material | import("three").Material[], import("three").Object3DEventMap>) | undefined;
179
188
  hasEventListener?: (<T extends keyof import("three").Object3DEventMap>(type: T, listener: import("three").EventListener<import("three").Object3DEventMap[T], T, Mesh<import("three").BufferGeometry<import("three").NormalBufferAttributes>, import("three").Material | import("three").Material[], import("three").Object3DEventMap>>) => boolean) | undefined;
180
189
  dispatchEvent?: (<T extends keyof import("three").Object3DEventMap>(event: import("three").BaseEvent<T> & import("three").Object3DEventMap[T]) => void) | undefined;
181
- geometry?: import("three").BufferGeometry<import("three").NormalBufferAttributes> | undefined;
182
- material?: import("three").Material | import("three").Material[] | undefined;
183
- readonly isMesh?: true | undefined;
184
- morphTargetInfluences?: number[] | undefined;
185
- morphTargetDictionary?: {
186
- [key: string]: number;
187
- } | undefined;
188
- updateMorphTargets?: (() => void) | undefined;
189
- getVertexPosition?: ((index: number, target: import("three").Vector3) => import("three").Vector3) | undefined;
190
190
  position: import("angular-three").NgtVector3;
191
191
  up: import("angular-three").NgtVector3;
192
192
  scale: import("angular-three").NgtVector3;
@@ -202,7 +202,17 @@ export declare class NgtsText3D {
202
202
  addEventListener: (<TEventKey extends keyof import("angular-three").NgtNodeEventMap<Mesh<import("three").BufferGeometry<import("three").NormalBufferAttributes>, import("three").Material | import("three").Material[], import("three").Object3DEventMap>>>(type: TEventKey, listener: (this: import("angular-three").NgtNodeElement<Mesh<import("three").BufferGeometry<import("three").NormalBufferAttributes>, import("three").Material | import("three").Material[], import("three").Object3DEventMap>, typeof Mesh>, ev: import("angular-three").NgtNodeEventMap<Mesh<import("three").BufferGeometry<import("three").NormalBufferAttributes>, import("three").Material | import("three").Material[], import("three").Object3DEventMap>>[TEventKey]) => any) => void) & (<TEventKey extends keyof import("angular-three").NgtAllObject3DEventsMap>(type: TEventKey, listener: (this: any, ev: import("angular-three").NgtAllObject3DEventsMap[TEventKey]) => any) => void);
203
203
  removeEventListener: (<TEventKey extends keyof import("angular-three").NgtNodeEventMap<Mesh<import("three").BufferGeometry<import("three").NormalBufferAttributes>, import("three").Material | import("three").Material[], import("three").Object3DEventMap>>>(type: TEventKey, listener: (this: import("angular-three").NgtNodeElement<Mesh<import("three").BufferGeometry<import("three").NormalBufferAttributes>, import("three").Material | import("three").Material[], import("three").Object3DEventMap>, typeof Mesh>, ev: import("angular-three").NgtNodeEventMap<Mesh<import("three").BufferGeometry<import("three").NormalBufferAttributes>, import("three").Material | import("three").Material[], import("three").Object3DEventMap>>[TEventKey]) => any) => void) & (<TEventKey extends keyof import("angular-three").NgtAllObject3DEventsMap>(type: TEventKey, listener: (this: any, ev: import("angular-three").NgtAllObject3DEventsMap[TEventKey]) => any) => void);
204
204
  __ngt_args__: [geometry?: import("three").BufferGeometry<import("three").NormalBufferAttributes> | undefined, material?: import("three").Material | import("three").Material[] | undefined];
205
+ readonly isMesh?: true | undefined;
205
206
  readonly type?: string | undefined;
207
+ geometry?: import("three").BufferGeometry<import("three").NormalBufferAttributes> | undefined;
208
+ material?: import("three").Material | import("three").Material[] | undefined;
209
+ morphTargetInfluences?: number[] | undefined;
210
+ morphTargetDictionary?: {
211
+ [key: string]: number;
212
+ } | undefined;
213
+ updateMorphTargets?: (() => void) | undefined;
214
+ getVertexPosition?: ((index: number, target: import("three").Vector3) => import("three").Vector3) | undefined;
215
+ toJSON?: ((meta?: import("three").JSONMeta) => import("three").MeshJSON) | undefined;
206
216
  readonly isObject3D?: true | undefined;
207
217
  readonly id?: number | undefined;
208
218
  uuid?: string | undefined;
@@ -267,20 +277,10 @@ export declare class NgtsText3D {
267
277
  updateMatrix?: (() => void) | undefined;
268
278
  updateMatrixWorld?: ((force?: boolean) => void) | undefined;
269
279
  updateWorldMatrix?: ((updateParents: boolean, updateChildren: boolean) => void) | undefined;
270
- toJSON?: ((meta?: import("three").JSONMeta) => import("three").MeshJSON) | undefined;
271
280
  clone?: ((recursive?: boolean) => Mesh<import("three").BufferGeometry<import("three").NormalBufferAttributes>, import("three").Material | import("three").Material[], import("three").Object3DEventMap>) | undefined;
272
281
  copy?: ((object: import("three").Object3D, recursive?: boolean) => Mesh<import("three").BufferGeometry<import("three").NormalBufferAttributes>, import("three").Material | import("three").Material[], import("three").Object3DEventMap>) | undefined;
273
282
  hasEventListener?: (<T extends keyof import("three").Object3DEventMap>(type: T, listener: import("three").EventListener<import("three").Object3DEventMap[T], T, Mesh<import("three").BufferGeometry<import("three").NormalBufferAttributes>, import("three").Material | import("three").Material[], import("three").Object3DEventMap>>) => boolean) | undefined;
274
283
  dispatchEvent?: (<T extends keyof import("three").Object3DEventMap>(event: import("three").BaseEvent<T> & import("three").Object3DEventMap[T]) => void) | undefined;
275
- geometry?: import("three").BufferGeometry<import("three").NormalBufferAttributes> | undefined;
276
- material?: import("three").Material | import("three").Material[] | undefined;
277
- readonly isMesh?: true | undefined;
278
- morphTargetInfluences?: number[] | undefined;
279
- morphTargetDictionary?: {
280
- [key: string]: number;
281
- } | undefined;
282
- updateMorphTargets?: (() => void) | undefined;
283
- getVertexPosition?: ((index: number, target: import("three").Vector3) => import("three").Vector3) | undefined;
284
284
  position: import("angular-three").NgtVector3;
285
285
  up: import("angular-three").NgtVector3;
286
286
  scale: import("angular-three").NgtVector3;
@@ -290,22 +290,22 @@ export declare class NgtsText3D {
290
290
  layers: import("angular-three").NgtLayers;
291
291
  dispose: (() => void) | null;
292
292
  raycast: import("three").Object3D["raycast"] | null;
293
- }> & NgtsText3DOptions, "size" | "height" | "curveSegments" | "bevelEnabled" | "bevelThickness" | "bevelSize" | "bevelOffset" | "bevelSegments" | "lineHeight" | "letterSpacing" | "smooth">>;
293
+ }> & NgtsText3DOptions, "bevelEnabled" | "bevelOffset" | "bevelSize" | "bevelThickness" | "curveSegments" | "height" | "size" | "lineHeight" | "letterSpacing" | "bevelSegments" | "smooth">>;
294
294
  meshRef: import("@angular/core").Signal<ElementRef<Mesh<import("three").BufferGeometry<import("three").NormalBufferAttributes>, import("three").Material | import("three").Material[], import("three").Object3DEventMap>> | undefined>;
295
295
  loadedFont: import("@angular/core").Signal<import("three-stdlib").Font | null>;
296
296
  private smooth;
297
297
  private textOptions;
298
298
  textArgs: import("@angular/core").Signal<(string | {
299
- size?: number | undefined;
300
- height?: number | undefined;
301
- curveSegments?: number | undefined;
302
299
  bevelEnabled?: boolean | undefined;
303
- bevelThickness?: number | undefined;
304
- bevelSize?: number | undefined;
305
300
  bevelOffset?: number | undefined;
306
- bevelSegments: number;
301
+ bevelSize?: number | undefined;
302
+ bevelThickness?: number | undefined;
303
+ curveSegments?: number | undefined;
304
+ height?: number | undefined;
305
+ size?: number | undefined;
307
306
  lineHeight?: number | undefined;
308
307
  letterSpacing?: number | undefined;
308
+ bevelSegments: number;
309
309
  font: import("three-stdlib").Font;
310
310
  })[] | null>;
311
311
  constructor();
@@ -43,7 +43,7 @@ export declare class NgtsText {
43
43
  private invalidate;
44
44
  private characters;
45
45
  font: import("@angular/core").Signal<string | undefined>;
46
- anchorX: import("@angular/core").Signal<number | "center" | "left" | "right">;
46
+ anchorX: import("@angular/core").Signal<number | "left" | "center" | "right">;
47
47
  anchorY: import("@angular/core").Signal<number | "top" | "top-baseline" | "middle" | "bottom-baseline" | "bottom">;
48
48
  sdfGlyphSize: import("@angular/core").Signal<number>;
49
49
  fontSize: import("@angular/core").Signal<number>;
@@ -26,7 +26,7 @@ export interface NgtsCubeCameraOptions extends Partial<NgtGroup>, CubeCameraOpti
26
26
  }
27
27
  export declare class NgtsCubeCamera {
28
28
  options: import("@angular/core").InputSignalWithTransform<NgtsCubeCameraOptions, "" | Partial<NgtsCubeCameraOptions>>;
29
- parameters: import("@angular/core").Signal<Omit<NgtsCubeCameraOptions, "resolution" | "near" | "far" | "envMap" | "fog" | "frames">>;
29
+ parameters: import("@angular/core").Signal<Omit<NgtsCubeCameraOptions, "near" | "far" | "envMap" | "frames" | "resolution" | "fog">>;
30
30
  private cubeCamera;
31
31
  camera: import("@angular/core").Signal<CubeCamera>;
32
32
  texture: import("@angular/core").Signal<import("three").CubeTexture>;
@@ -16,7 +16,7 @@ export interface NgtsOrthographicCameraOptions extends Partial<NgtOrthographicCa
16
16
  }
17
17
  export declare class NgtsOrthographicCamera {
18
18
  options: import("@angular/core").InputSignalWithTransform<NgtsOrthographicCameraOptions, "" | Partial<NgtsOrthographicCameraOptions>>;
19
- parameters: import("@angular/core").Signal<Omit<NgtsOrthographicCameraOptions, "resolution" | "envMap" | "frames" | "left" | "right" | "top" | "bottom" | "makeDefault" | "manual">>;
19
+ parameters: import("@angular/core").Signal<Omit<NgtsOrthographicCameraOptions, "envMap" | "makeDefault" | "manual" | "frames" | "resolution" | "left" | "right" | "top" | "bottom">>;
20
20
  content: import("@angular/core").Signal<TemplateRef<any> | undefined>;
21
21
  cameraContent: import("@angular/core").Signal<TemplateRef<any> | undefined>;
22
22
  cameraRef: import("@angular/core").Signal<ElementRef<OrthographicCamera>>;
@@ -16,7 +16,7 @@ export interface NgtsPerspectiveCameraOptions extends Partial<NgtPerspectiveCame
16
16
  }
17
17
  export declare class NgtsPerspectiveCamera {
18
18
  options: import("@angular/core").InputSignalWithTransform<NgtsPerspectiveCameraOptions, "" | Partial<NgtsPerspectiveCameraOptions>>;
19
- parameters: import("@angular/core").Signal<Omit<NgtsPerspectiveCameraOptions, "resolution" | "envMap" | "frames" | "makeDefault" | "manual">>;
19
+ parameters: import("@angular/core").Signal<Omit<NgtsPerspectiveCameraOptions, "envMap" | "makeDefault" | "manual" | "frames" | "resolution">>;
20
20
  content: import("@angular/core").Signal<TemplateRef<any> | undefined>;
21
21
  cameraContent: import("@angular/core").Signal<TemplateRef<any> | undefined>;
22
22
  cameraRef: import("@angular/core").Signal<ElementRef<PerspectiveCamera>>;
@@ -1,4 +1,12 @@
1
1
  export * from './lib/camera-controls';
2
2
  export * from './lib/orbit-controls';
3
- export * from './lib/pivot-controls/pivot-controls';
4
3
  export * from './lib/scroll-controls';
4
+ import { NgtsPivotControls as GizmosPivotControls, NgtsPivotControlsOptions as GizmosPivotControlsOptions } from 'angular-three-soba/gizmos';
5
+ /**
6
+ * @deprecated Use `NgtsPivotControls` from `angular-three-soba/gizmos` instead.
7
+ */
8
+ export declare const NgtsPivotControls: typeof GizmosPivotControls;
9
+ /**
10
+ * @deprecated Use `NgtsPivotControlsOptions` from `angular-three-soba/gizmos` instead.
11
+ */
12
+ export type NgtsPivotControlsOptions = GizmosPivotControlsOptions;
@@ -10,7 +10,7 @@ export interface NgtsCameraControlsOptions {
10
10
  }
11
11
  export declare class NgtsCameraControls {
12
12
  options: import("@angular/core").InputSignalWithTransform<Partial<CameraControls> & NgtsCameraControlsOptions, "" | Partial<Partial<CameraControls> & NgtsCameraControlsOptions>>;
13
- parameters: import("@angular/core").Signal<Omit<Partial<CameraControls> & NgtsCameraControlsOptions, "camera" | "makeDefault" | "regress" | "domElement">>;
13
+ parameters: import("@angular/core").Signal<Omit<Partial<CameraControls> & NgtsCameraControlsOptions, "domElement" | "makeDefault" | "camera" | "regress">>;
14
14
  changed: import("@angular/core").OutputEmitterRef<any>;
15
15
  started: import("@angular/core").OutputEmitterRef<any>;
16
16
  ended: import("@angular/core").OutputEmitterRef<any>;
@@ -13,7 +13,7 @@ export interface NgtsOrbitControlsOptions {
13
13
  }
14
14
  export declare class NgtsOrbitControls {
15
15
  options: import("@angular/core").InputSignalWithTransform<Partial<OrbitControls> & NgtsOrbitControlsOptions, "" | Partial<Partial<OrbitControls> & NgtsOrbitControlsOptions>>;
16
- parameters: import("@angular/core").Signal<Omit<Partial<OrbitControls> & NgtsOrbitControlsOptions, "camera" | "makeDefault" | "regress" | "domElement" | "enableDamping" | "keyEvents">>;
16
+ parameters: import("@angular/core").Signal<Omit<Partial<OrbitControls> & NgtsOrbitControlsOptions, "domElement" | "enableDamping" | "makeDefault" | "camera" | "regress" | "keyEvents">>;
17
17
  changed: import("@angular/core").OutputEmitterRef<Event<string, unknown>>;
18
18
  started: import("@angular/core").OutputEmitterRef<Event<string, unknown>>;
19
19
  ended: import("@angular/core").OutputEmitterRef<Event<string, unknown>>;
@@ -1,5 +1,9 @@
1
1
  export * from './lib/camera-controls';
2
2
  export * from './lib/orbit-controls';
3
- export * from './lib/pivot-controls/pivot-controls';
4
3
  export * from './lib/scroll-controls';
5
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL3NvYmEvY29udHJvbHMvc3JjL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYyxzQkFBc0IsQ0FBQztBQUNyQyxjQUFjLHFDQUFxQyxDQUFDO0FBQ3BELGNBQWMsdUJBQXVCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2xpYi9jYW1lcmEtY29udHJvbHMnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvb3JiaXQtY29udHJvbHMnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvcGl2b3QtY29udHJvbHMvcGl2b3QtY29udHJvbHMnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvc2Nyb2xsLWNvbnRyb2xzJztcbiJdfQ==
4
+ import { NgtsPivotControls as GizmosPivotControls, } from 'angular-three-soba/gizmos';
5
+ /**
6
+ * @deprecated Use `NgtsPivotControls` from `angular-three-soba/gizmos` instead.
7
+ */
8
+ export const NgtsPivotControls = GizmosPivotControls;
9
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL3NvYmEvY29udHJvbHMvc3JjL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYyxzQkFBc0IsQ0FBQztBQUNyQyxjQUFjLHVCQUF1QixDQUFDO0FBRXRDLE9BQU8sRUFDTixpQkFBaUIsSUFBSSxtQkFBbUIsR0FFeEMsTUFBTSwyQkFBMkIsQ0FBQztBQUVuQzs7R0FFRztBQUNILE1BQU0sQ0FBQyxNQUFNLGlCQUFpQixHQUFHLG1CQUFtQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9saWIvY2FtZXJhLWNvbnRyb2xzJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL29yYml0LWNvbnRyb2xzJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3Njcm9sbC1jb250cm9scyc7XG5cbmltcG9ydCB7XG5cdE5ndHNQaXZvdENvbnRyb2xzIGFzIEdpem1vc1Bpdm90Q29udHJvbHMsXG5cdE5ndHNQaXZvdENvbnRyb2xzT3B0aW9ucyBhcyBHaXptb3NQaXZvdENvbnRyb2xzT3B0aW9ucyxcbn0gZnJvbSAnYW5ndWxhci10aHJlZS1zb2JhL2dpem1vcyc7XG5cbi8qKlxuICogQGRlcHJlY2F0ZWQgVXNlIGBOZ3RzUGl2b3RDb250cm9sc2AgZnJvbSBgYW5ndWxhci10aHJlZS1zb2JhL2dpem1vc2AgaW5zdGVhZC5cbiAqL1xuZXhwb3J0IGNvbnN0IE5ndHNQaXZvdENvbnRyb2xzID0gR2l6bW9zUGl2b3RDb250cm9scztcbi8qKlxuICogQGRlcHJlY2F0ZWQgVXNlIGBOZ3RzUGl2b3RDb250cm9sc09wdGlvbnNgIGZyb20gYGFuZ3VsYXItdGhyZWUtc29iYS9naXptb3NgIGluc3RlYWQuXG4gKi9cbmV4cG9ydCB0eXBlIE5ndHNQaXZvdENvbnRyb2xzT3B0aW9ucyA9IEdpem1vc1Bpdm90Q29udHJvbHNPcHRpb25zO1xuIl19
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
4
+ export * from './index';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5ndWxhci10aHJlZS1zb2JhLWdpem1vcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYnMvc29iYS9naXptb3Mvc3JjL2FuZ3VsYXItdGhyZWUtc29iYS1naXptb3MudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLFNBQVMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9pbmRleCc7XG4iXX0=
@@ -0,0 +1,6 @@
1
+ export * from './lib/gizmo-helper/gizmo-helper';
2
+ export { NgtsGizmoViewcube } from './lib/gizmo-helper/gizmo-viewcube';
3
+ export { NgtsGizmoViewport } from './lib/gizmo-helper/gizmo-viewport';
4
+ export * from './lib/pivot-controls/pivot-controls';
5
+ export * from './lib/transform-controls';
6
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL3NvYmEvZ2l6bW9zL3NyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGlDQUFpQyxDQUFDO0FBQ2hELE9BQU8sRUFBRSxpQkFBaUIsRUFBNEIsTUFBTSxtQ0FBbUMsQ0FBQztBQUNoRyxPQUFPLEVBQUUsaUJBQWlCLEVBQTRCLE1BQU0sbUNBQW1DLENBQUM7QUFDaEcsY0FBYyxxQ0FBcUMsQ0FBQztBQUNwRCxjQUFjLDBCQUEwQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9saWIvZ2l6bW8taGVscGVyL2dpem1vLWhlbHBlcic7XG5leHBvcnQgeyBOZ3RzR2l6bW9WaWV3Y3ViZSwgTmd0c0dpem1vVmlld2N1YmVPcHRpb25zIH0gZnJvbSAnLi9saWIvZ2l6bW8taGVscGVyL2dpem1vLXZpZXdjdWJlJztcbmV4cG9ydCB7IE5ndHNHaXptb1ZpZXdwb3J0LCBOZ3RzR2l6bW9WaWV3cG9ydE9wdGlvbnMgfSBmcm9tICcuL2xpYi9naXptby1oZWxwZXIvZ2l6bW8tdmlld3BvcnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvcGl2b3QtY29udHJvbHMvcGl2b3QtY29udHJvbHMnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdHJhbnNmb3JtLWNvbnRyb2xzJztcbiJdfQ==
@@ -0,0 +1,187 @@
1
+ import { NgTemplateOutlet } from '@angular/common';
2
+ import { ChangeDetectionStrategy, Component, computed, contentChild, CUSTOM_ELEMENTS_SCHEMA, Directive, effect, input, output, TemplateRef, viewChild, } from '@angular/core';
3
+ import { extend, hasListener, injectBeforeRender, injectStore, NgtPortal, NgtPortalContent, pick } from 'angular-three';
4
+ import { NgtsOrthographicCamera } from 'angular-three-soba/cameras';
5
+ import { mergeInputs } from 'ngxtension/inject-inputs';
6
+ import { Group, Matrix4, Object3D, Quaternion, Scene, Vector3 } from 'three';
7
+ import * as i0 from "@angular/core";
8
+ const turnRate = 2 * Math.PI; // turn rate in angles per second
9
+ const dummy = new Object3D();
10
+ const matrix = new Matrix4();
11
+ const [q1, q2] = [new Quaternion(), new Quaternion()];
12
+ const target = new Vector3();
13
+ const targetPosition = new Vector3();
14
+ export class NgtsGizmoHelperContent {
15
+ static ngTemplateContextGuard(_, ctx) {
16
+ return true;
17
+ }
18
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: NgtsGizmoHelperContent, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
19
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.0", type: NgtsGizmoHelperContent, isStandalone: true, selector: "ng-template[gizmoHelperContent]", ngImport: i0 }); }
20
+ }
21
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: NgtsGizmoHelperContent, decorators: [{
22
+ type: Directive,
23
+ args: [{ selector: 'ng-template[gizmoHelperContent]', standalone: true }]
24
+ }] });
25
+ const defaultOptions = {
26
+ alignment: 'bottom-right',
27
+ margin: [80, 80],
28
+ renderPriority: 1,
29
+ };
30
+ export class NgtsGizmoHelper {
31
+ constructor() {
32
+ this.options = input(defaultOptions, { transform: mergeInputs(defaultOptions) });
33
+ this.update = output();
34
+ this.renderPriority = pick(this.options, 'renderPriority');
35
+ this.margin = pick(this.options, 'margin');
36
+ this.alignment = pick(this.options, 'alignment');
37
+ this.scene = new Scene();
38
+ this.content = contentChild.required(NgtsGizmoHelperContent, { read: TemplateRef });
39
+ this.gizmoRef = viewChild('gizmo');
40
+ this.virtualCameraRef = viewChild(NgtsOrthographicCamera);
41
+ this.store = injectStore();
42
+ this.size = this.store.select('size');
43
+ this.mainCamera = this.store.select('camera');
44
+ this.defaultControls = this.store.select('controls');
45
+ this.invalidate = this.store.select('invalidate');
46
+ this.x = computed(() => {
47
+ const alignment = this.alignment();
48
+ if (alignment.endsWith('-center'))
49
+ return 0;
50
+ const [{ width }, [marginX]] = [this.size(), this.margin()];
51
+ return alignment.endsWith('-left') ? -width / 2 + marginX : width / 2 - marginX;
52
+ });
53
+ this.y = computed(() => {
54
+ const alignment = this.alignment();
55
+ if (alignment.startsWith('center-'))
56
+ return 0;
57
+ const [{ height }, [marginY]] = [this.size(), this.margin()];
58
+ return alignment.startsWith('top-') ? height / 2 - marginY : -height / 2 + marginY;
59
+ });
60
+ this.animating = false;
61
+ this.radius = 0;
62
+ this.focusPoint = new Vector3(0, 0, 0);
63
+ this.defaultUp = new Vector3(0, 0, 0);
64
+ extend({ Group });
65
+ effect(() => {
66
+ this.updateDefaultUpEffect();
67
+ });
68
+ injectBeforeRender(({ delta }) => {
69
+ const [virtualCamera, gizmo] = [
70
+ this.virtualCameraRef()?.cameraRef()?.nativeElement,
71
+ this.gizmoRef()?.nativeElement,
72
+ ];
73
+ if (!virtualCamera || !gizmo)
74
+ return;
75
+ const [defaultControls, mainCamera, invalidate] = [this.defaultControls(), this.mainCamera(), this.invalidate()];
76
+ // Animate step
77
+ if (this.animating) {
78
+ if (q1.angleTo(q2) < 0.01) {
79
+ this.animating = false;
80
+ // Orbit controls uses UP vector as the orbit axes,
81
+ // so we need to reset it after the animation is done
82
+ // moving it around for the controls to work correctly
83
+ if (this.isOrbitControls(defaultControls)) {
84
+ mainCamera.up.copy(this.defaultUp);
85
+ }
86
+ }
87
+ else {
88
+ const step = delta * turnRate;
89
+ // animate position by doing a slerp and then scaling the position on the unit sphere
90
+ q1.rotateTowards(q2, step);
91
+ // animate orientation
92
+ mainCamera.position.set(0, 0, 1).applyQuaternion(q1).multiplyScalar(this.radius).add(this.focusPoint);
93
+ mainCamera.up.set(0, 1, 0).applyQuaternion(q1).normalize();
94
+ mainCamera.quaternion.copy(q1);
95
+ if (this.isCameraControls(defaultControls)) {
96
+ void defaultControls.setPosition(mainCamera.position.x, mainCamera.position.y, mainCamera.position.z);
97
+ }
98
+ if (hasListener(this.update))
99
+ this.update.emit();
100
+ else if (defaultControls)
101
+ defaultControls.update(delta);
102
+ invalidate();
103
+ }
104
+ }
105
+ // Sync Gizmo with main camera orientation
106
+ matrix.copy(mainCamera.matrix).invert();
107
+ gizmo.quaternion.setFromRotationMatrix(matrix);
108
+ });
109
+ }
110
+ tweenCamera(direction) {
111
+ const [defaultControls, invalidate, mainCamera] = [this.defaultControls(), this.invalidate(), this.mainCamera()];
112
+ this.animating = true;
113
+ if (defaultControls) {
114
+ this.focusPoint = this.isCameraControls(defaultControls)
115
+ ? defaultControls.getTarget(this.focusPoint)
116
+ : defaultControls.target;
117
+ }
118
+ this.radius = mainCamera.position.distanceTo(target);
119
+ // Rotate from current camera orientation
120
+ q1.copy(mainCamera.quaternion);
121
+ // To new current camera orientation
122
+ targetPosition.copy(direction).multiplyScalar(this.radius).add(target);
123
+ dummy.lookAt(targetPosition);
124
+ q2.copy(dummy.quaternion);
125
+ invalidate();
126
+ }
127
+ updateDefaultUpEffect() {
128
+ const mainCamera = this.mainCamera();
129
+ this.defaultUp.copy(mainCamera.up);
130
+ }
131
+ isOrbitControls(controls) {
132
+ return 'minPolarAngle' in controls;
133
+ }
134
+ isCameraControls(controls) {
135
+ return 'getTarget' in controls;
136
+ }
137
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: NgtsGizmoHelper, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
138
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "18.2.0", type: NgtsGizmoHelper, isStandalone: true, selector: "ngts-gizmo-helper", inputs: { options: { classPropertyName: "options", publicName: "options", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { update: "update" }, queries: [{ propertyName: "content", first: true, predicate: NgtsGizmoHelperContent, descendants: true, read: TemplateRef, isSignal: true }], viewQueries: [{ propertyName: "gizmoRef", first: true, predicate: ["gizmo"], descendants: true, isSignal: true }, { propertyName: "virtualCameraRef", first: true, predicate: NgtsOrthographicCamera, descendants: true, isSignal: true }], ngImport: i0, template: `
139
+ <ngt-portal
140
+ [container]="scene"
141
+ [autoRender]="true"
142
+ [autoRenderPriority]="renderPriority()"
143
+ [state]="{ events: { priority: renderPriority() + 1 } }"
144
+ >
145
+ <ng-template portalContent let-injector="injector" let-container="container">
146
+ <ngts-orthographic-camera [options]="{ makeDefault: true, position: [0, 0, 200] }" />
147
+ <ngt-group #gizmo [position]="[x(), y(), 0]">
148
+ <ng-container
149
+ [ngTemplateOutlet]="content()"
150
+ [ngTemplateOutletContext]="{ container, injector }"
151
+ [ngTemplateOutletInjector]="injector"
152
+ />
153
+ </ngt-group>
154
+ </ng-template>
155
+ </ngt-portal>
156
+ `, isInline: true, dependencies: [{ kind: "component", type: NgtPortal, selector: "ngt-portal", inputs: ["container", "state", "autoRender", "autoRenderPriority"] }, { kind: "directive", type: NgtPortalContent, selector: "ng-template[portalContent]" }, { kind: "component", type: NgtsOrthographicCamera, selector: "ngts-orthographic-camera", inputs: ["options"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
157
+ }
158
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: NgtsGizmoHelper, decorators: [{
159
+ type: Component,
160
+ args: [{
161
+ selector: 'ngts-gizmo-helper',
162
+ standalone: true,
163
+ template: `
164
+ <ngt-portal
165
+ [container]="scene"
166
+ [autoRender]="true"
167
+ [autoRenderPriority]="renderPriority()"
168
+ [state]="{ events: { priority: renderPriority() + 1 } }"
169
+ >
170
+ <ng-template portalContent let-injector="injector" let-container="container">
171
+ <ngts-orthographic-camera [options]="{ makeDefault: true, position: [0, 0, 200] }" />
172
+ <ngt-group #gizmo [position]="[x(), y(), 0]">
173
+ <ng-container
174
+ [ngTemplateOutlet]="content()"
175
+ [ngTemplateOutletContext]="{ container, injector }"
176
+ [ngTemplateOutletInjector]="injector"
177
+ />
178
+ </ngt-group>
179
+ </ng-template>
180
+ </ngt-portal>
181
+ `,
182
+ schemas: [CUSTOM_ELEMENTS_SCHEMA],
183
+ changeDetection: ChangeDetectionStrategy.OnPush,
184
+ imports: [NgtPortal, NgtPortalContent, NgtsOrthographicCamera, NgTemplateOutlet],
185
+ }]
186
+ }], ctorParameters: () => [] });
187
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gizmo-helper.js","sourceRoot":"","sources":["../../../../../../../libs/soba/gizmos/src/lib/gizmo-helper/gizmo-helper.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgTemplateOutlet } from '@angular/common';\nimport {\n\tChangeDetectionStrategy,\n\tComponent,\n\tcomputed,\n\tcontentChild,\n\tCUSTOM_ELEMENTS_SCHEMA,\n\tDirective,\n\teffect,\n\tElementRef,\n\tinput,\n\toutput,\n\tSignal,\n\tTemplateRef,\n\tviewChild,\n} from '@angular/core';\nimport { extend, hasListener, injectBeforeRender, injectStore, NgtPortal, NgtPortalContent, pick } from 'angular-three';\nimport { NgtsOrthographicCamera } from 'angular-three-soba/cameras';\nimport CameraControls from 'camera-controls';\nimport { mergeInputs } from 'ngxtension/inject-inputs';\nimport { Group, Matrix4, Object3D, Quaternion, Scene, Vector3 } from 'three';\nimport { OrbitControls } from 'three-stdlib';\n\nconst turnRate = 2 * Math.PI; // turn rate in angles per second\nconst dummy = new Object3D();\nconst matrix = new Matrix4();\nconst [q1, q2] = [new Quaternion(), new Quaternion()];\nconst target = new Vector3();\nconst targetPosition = new Vector3();\n\n@Directive({ selector: 'ng-template[gizmoHelperContent]', standalone: true })\nexport class NgtsGizmoHelperContent {\n\tstatic ngTemplateContextGuard(_: NgtsGizmoHelperContent, ctx: unknown): ctx is { container: Object3D } {\n\t\treturn true;\n\t}\n}\n\ntype ControlsProto = { update(delta?: number): void; target: Vector3 };\n\nexport interface NgtsGizmoHelperOptions {\n\talignment:\n\t\t| 'top-left'\n\t\t| 'top-right'\n\t\t| 'bottom-right'\n\t\t| 'bottom-left'\n\t\t| 'bottom-center'\n\t\t| 'center-right'\n\t\t| 'center-left'\n\t\t| 'center-center'\n\t\t| 'top-center';\n\tmargin: [number, number];\n\trenderPriority: number;\n\tautoClear?: boolean;\n}\n\nconst defaultOptions: NgtsGizmoHelperOptions = {\n\talignment: 'bottom-right',\n\tmargin: [80, 80],\n\trenderPriority: 1,\n};\n\n@Component({\n\tselector: 'ngts-gizmo-helper',\n\tstandalone: true,\n\ttemplate: `\n\t\t<ngt-portal\n\t\t\t[container]=\"scene\"\n\t\t\t[autoRender]=\"true\"\n\t\t\t[autoRenderPriority]=\"renderPriority()\"\n\t\t\t[state]=\"{ events: { priority: renderPriority() + 1 } }\"\n\t\t>\n\t\t\t<ng-template portalContent let-injector=\"injector\" let-container=\"container\">\n\t\t\t\t<ngts-orthographic-camera [options]=\"{ makeDefault: true, position: [0, 0, 200] }\" />\n\t\t\t\t<ngt-group #gizmo [position]=\"[x(), y(), 0]\">\n\t\t\t\t\t<ng-container\n\t\t\t\t\t\t[ngTemplateOutlet]=\"content()\"\n\t\t\t\t\t\t[ngTemplateOutletContext]=\"{ container, injector }\"\n\t\t\t\t\t\t[ngTemplateOutletInjector]=\"injector\"\n\t\t\t\t\t/>\n\t\t\t\t</ngt-group>\n\t\t\t</ng-template>\n\t\t</ngt-portal>\n\t`,\n\tschemas: [CUSTOM_ELEMENTS_SCHEMA],\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\timports: [NgtPortal, NgtPortalContent, NgtsOrthographicCamera, NgTemplateOutlet],\n})\nexport class NgtsGizmoHelper {\n\toptions = input(defaultOptions, { transform: mergeInputs(defaultOptions) });\n\tupdate = output<void>();\n\n\tprotected renderPriority = pick(this.options, 'renderPriority');\n\tprotected margin = pick(this.options, 'margin');\n\tprotected alignment = pick(this.options, 'alignment');\n\n\tprotected scene = new Scene();\n\n\tprotected content = contentChild.required(NgtsGizmoHelperContent, { read: TemplateRef });\n\n\tprivate gizmoRef = viewChild<ElementRef<Group>>('gizmo');\n\tprivate virtualCameraRef = viewChild(NgtsOrthographicCamera);\n\n\tprivate store = injectStore();\n\tprivate size = this.store.select('size');\n\tprivate mainCamera = this.store.select('camera');\n\tprivate defaultControls = this.store.select('controls') as unknown as Signal<ControlsProto>;\n\tprivate invalidate = this.store.select('invalidate');\n\n\tprotected x = computed(() => {\n\t\tconst alignment = this.alignment();\n\t\tif (alignment.endsWith('-center')) return 0;\n\n\t\tconst [{ width }, [marginX]] = [this.size(), this.margin()];\n\t\treturn alignment.endsWith('-left') ? -width / 2 + marginX : width / 2 - marginX;\n\t});\n\tprotected y = computed(() => {\n\t\tconst alignment = this.alignment();\n\t\tif (alignment.startsWith('center-')) return 0;\n\n\t\tconst [{ height }, [marginY]] = [this.size(), this.margin()];\n\t\treturn alignment.startsWith('top-') ? height / 2 - marginY : -height / 2 + marginY;\n\t});\n\n\tprivate animating = false;\n\tprivate radius = 0;\n\tprivate focusPoint = new Vector3(0, 0, 0);\n\tprivate defaultUp = new Vector3(0, 0, 0);\n\n\tconstructor() {\n\t\textend({ Group });\n\t\teffect(() => {\n\t\t\tthis.updateDefaultUpEffect();\n\t\t});\n\n\t\tinjectBeforeRender(({ delta }) => {\n\t\t\tconst [virtualCamera, gizmo] = [\n\t\t\t\tthis.virtualCameraRef()?.cameraRef()?.nativeElement,\n\t\t\t\tthis.gizmoRef()?.nativeElement,\n\t\t\t];\n\n\t\t\tif (!virtualCamera || !gizmo) return;\n\n\t\t\tconst [defaultControls, mainCamera, invalidate] = [this.defaultControls(), this.mainCamera(), this.invalidate()];\n\n\t\t\t// Animate step\n\t\t\tif (this.animating) {\n\t\t\t\tif (q1.angleTo(q2) < 0.01) {\n\t\t\t\t\tthis.animating = false;\n\t\t\t\t\t// Orbit controls uses UP vector as the orbit axes,\n\t\t\t\t\t// so we need to reset it after the animation is done\n\t\t\t\t\t// moving it around for the controls to work correctly\n\t\t\t\t\tif (this.isOrbitControls(defaultControls)) {\n\t\t\t\t\t\tmainCamera.up.copy(this.defaultUp);\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\tconst step = delta * turnRate;\n\t\t\t\t\t// animate position by doing a slerp and then scaling the position on the unit sphere\n\t\t\t\t\tq1.rotateTowards(q2, step);\n\t\t\t\t\t// animate orientation\n\t\t\t\t\tmainCamera.position.set(0, 0, 1).applyQuaternion(q1).multiplyScalar(this.radius).add(this.focusPoint);\n\t\t\t\t\tmainCamera.up.set(0, 1, 0).applyQuaternion(q1).normalize();\n\t\t\t\t\tmainCamera.quaternion.copy(q1);\n\n\t\t\t\t\tif (this.isCameraControls(defaultControls)) {\n\t\t\t\t\t\tvoid defaultControls.setPosition(mainCamera.position.x, mainCamera.position.y, mainCamera.position.z);\n\t\t\t\t\t}\n\n\t\t\t\t\tif (hasListener(this.update)) this.update.emit();\n\t\t\t\t\telse if (defaultControls) defaultControls.update(delta);\n\n\t\t\t\t\tinvalidate();\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Sync Gizmo with main camera orientation\n\t\t\tmatrix.copy(mainCamera.matrix).invert();\n\t\t\tgizmo.quaternion.setFromRotationMatrix(matrix);\n\t\t});\n\t}\n\n\ttweenCamera(direction: Vector3) {\n\t\tconst [defaultControls, invalidate, mainCamera] = [this.defaultControls(), this.invalidate(), this.mainCamera()];\n\n\t\tthis.animating = true;\n\t\tif (defaultControls) {\n\t\t\tthis.focusPoint = this.isCameraControls(defaultControls)\n\t\t\t\t? defaultControls.getTarget(this.focusPoint)\n\t\t\t\t: defaultControls.target;\n\t\t}\n\t\tthis.radius = mainCamera.position.distanceTo(target);\n\n\t\t// Rotate from current camera orientation\n\t\tq1.copy(mainCamera.quaternion);\n\n\t\t// To new current camera orientation\n\t\ttargetPosition.copy(direction).multiplyScalar(this.radius).add(target);\n\t\tdummy.lookAt(targetPosition);\n\t\tq2.copy(dummy.quaternion);\n\n\t\tinvalidate();\n\t}\n\n\tprivate updateDefaultUpEffect() {\n\t\tconst mainCamera = this.mainCamera();\n\t\tthis.defaultUp.copy(mainCamera.up);\n\t}\n\n\tprivate isOrbitControls(controls: ControlsProto): controls is OrbitControls {\n\t\treturn 'minPolarAngle' in (controls as OrbitControls);\n\t}\n\n\tprivate isCameraControls(controls: CameraControls | ControlsProto): controls is CameraControls {\n\t\treturn 'getTarget' in (controls as CameraControls);\n\t}\n}\n"]}