angular-three-soba 2.1.0 → 2.2.1

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 (151) hide show
  1. package/abstractions/lib/catmull-rom-line.d.ts +139 -139
  2. package/abstractions/lib/edges.d.ts +164 -164
  3. package/abstractions/lib/grid.d.ts +39 -39
  4. package/abstractions/lib/line.d.ts +8 -7
  5. package/abstractions/lib/prism-geometry.d.ts +4 -4
  6. package/abstractions/lib/rounded-box.d.ts +3 -3
  7. package/abstractions/lib/text-3d.d.ts +46 -46
  8. package/abstractions/lib/text.d.ts +1 -2
  9. package/cameras/lib/cube-camera.d.ts +1 -1
  10. package/cameras/lib/orthographic-camera.d.ts +7 -8
  11. package/cameras/lib/perspective-camera.d.ts +2 -3
  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/abstractions/lib/billboard.mjs +3 -3
  16. package/esm2022/abstractions/lib/catmull-rom-line.mjs +3 -3
  17. package/esm2022/abstractions/lib/cubic-bezier-line.mjs +3 -3
  18. package/esm2022/abstractions/lib/edges.mjs +30 -34
  19. package/esm2022/abstractions/lib/gradient-texture.mjs +3 -3
  20. package/esm2022/abstractions/lib/grid.mjs +3 -3
  21. package/esm2022/abstractions/lib/helper.mjs +18 -20
  22. package/esm2022/abstractions/lib/line.mjs +25 -28
  23. package/esm2022/abstractions/lib/prism-geometry.mjs +3 -3
  24. package/esm2022/abstractions/lib/quadratic-bezier-line.mjs +3 -3
  25. package/esm2022/abstractions/lib/rounded-box.mjs +11 -17
  26. package/esm2022/abstractions/lib/text-3d.mjs +14 -17
  27. package/esm2022/abstractions/lib/text.mjs +11 -16
  28. package/esm2022/cameras/lib/camera-content.mjs +3 -3
  29. package/esm2022/cameras/lib/cube-camera.mjs +18 -27
  30. package/esm2022/cameras/lib/orthographic-camera.mjs +20 -20
  31. package/esm2022/cameras/lib/perspective-camera.mjs +21 -21
  32. package/esm2022/controls/index.mjs +6 -2
  33. package/esm2022/controls/lib/camera-controls.mjs +3 -3
  34. package/esm2022/controls/lib/orbit-controls.mjs +3 -3
  35. package/esm2022/controls/lib/scroll-controls.mjs +124 -130
  36. package/esm2022/gizmos/angular-three-soba-gizmos.mjs +5 -0
  37. package/esm2022/gizmos/index.mjs +6 -0
  38. package/esm2022/gizmos/lib/gizmo-helper/gizmo-helper.mjs +187 -0
  39. package/esm2022/gizmos/lib/gizmo-helper/gizmo-viewcube.mjs +304 -0
  40. package/esm2022/gizmos/lib/gizmo-helper/gizmo-viewport.mjs +332 -0
  41. package/esm2022/gizmos/lib/pivot-controls/axis-arrow.mjs +265 -0
  42. package/esm2022/gizmos/lib/pivot-controls/axis-rotator.mjs +264 -0
  43. package/esm2022/gizmos/lib/pivot-controls/pivot-controls.mjs +337 -0
  44. package/esm2022/gizmos/lib/pivot-controls/plane-slider.mjs +266 -0
  45. package/esm2022/gizmos/lib/pivot-controls/scaling-sphere.mjs +232 -0
  46. package/esm2022/gizmos/lib/transform-controls.mjs +177 -0
  47. package/esm2022/loaders/lib/loader.mjs +3 -3
  48. package/esm2022/materials/lib/custom-shader-material.mjs +8 -12
  49. package/esm2022/materials/lib/mesh-distort-material.mjs +3 -3
  50. package/esm2022/materials/lib/mesh-reflector-material.mjs +11 -15
  51. package/esm2022/materials/lib/mesh-refraction-material.mjs +26 -30
  52. package/esm2022/materials/lib/mesh-transmission-material.mjs +3 -3
  53. package/esm2022/materials/lib/mesh-wobble-material.mjs +3 -3
  54. package/esm2022/materials/lib/point-material.mjs +3 -3
  55. package/esm2022/misc/lib/bake-shadows.mjs +8 -10
  56. package/esm2022/misc/lib/computed-attribute.mjs +15 -19
  57. package/esm2022/misc/lib/decal.mjs +56 -53
  58. package/esm2022/misc/lib/fbo.mjs +10 -10
  59. package/esm2022/misc/lib/html/html-content.mjs +62 -67
  60. package/esm2022/misc/lib/html/html.mjs +3 -3
  61. package/esm2022/misc/lib/intersect.mjs +6 -9
  62. package/esm2022/misc/lib/sampler.mjs +48 -42
  63. package/esm2022/performances/lib/adaptive-dpr.mjs +29 -35
  64. package/esm2022/performances/lib/adaptive-events.mjs +12 -16
  65. package/esm2022/performances/lib/detailed.mjs +14 -18
  66. package/esm2022/performances/lib/instances/instances.mjs +16 -22
  67. package/esm2022/performances/lib/points/points.mjs +19 -25
  68. package/esm2022/performances/lib/segments/segments.mjs +11 -14
  69. package/esm2022/shaders/lib/mesh-refraction-material.mjs +1 -1
  70. package/esm2022/staging/index.mjs +3 -2
  71. package/esm2022/staging/lib/accumulative-shadows.mjs +19 -21
  72. package/esm2022/staging/lib/backdrop.mjs +19 -23
  73. package/esm2022/staging/lib/bb-anchor.mjs +3 -3
  74. package/esm2022/staging/lib/bounds.mjs +39 -43
  75. package/esm2022/staging/lib/camera-shake.mjs +14 -18
  76. package/esm2022/staging/lib/caustics.mjs +24 -28
  77. package/esm2022/staging/lib/center.mjs +28 -32
  78. package/esm2022/staging/lib/contact-shadows.mjs +3 -3
  79. package/esm2022/staging/lib/environment/environment.mjs +338 -0
  80. package/esm2022/staging/lib/environment/inject-environment.mjs +184 -0
  81. package/esm2022/staging/lib/float.mjs +3 -3
  82. package/esm2022/staging/lib/lightformer.mjs +18 -22
  83. package/esm2022/staging/lib/mask.mjs +8 -12
  84. package/esm2022/staging/lib/matcap-texture.mjs +9 -11
  85. package/esm2022/staging/lib/normal-texture.mjs +9 -11
  86. package/esm2022/staging/lib/randomized-lights.mjs +9 -13
  87. package/esm2022/staging/lib/render-texture.mjs +19 -20
  88. package/esm2022/staging/lib/sky.mjs +3 -3
  89. package/esm2022/staging/lib/spot-light.mjs +32 -40
  90. package/esm2022/staging/lib/stage.mjs +13 -17
  91. package/esm2022/stats/lib/stats.mjs +21 -27
  92. package/fesm2022/angular-three-soba-abstractions.mjs +119 -138
  93. package/fesm2022/angular-three-soba-abstractions.mjs.map +1 -1
  94. package/fesm2022/angular-three-soba-cameras.mjs +57 -64
  95. package/fesm2022/angular-three-soba-cameras.mjs.map +1 -1
  96. package/fesm2022/angular-three-soba-controls.mjs +141 -1470
  97. package/fesm2022/angular-three-soba-controls.mjs.map +1 -1
  98. package/fesm2022/angular-three-soba-gizmos.mjs +2318 -0
  99. package/fesm2022/angular-three-soba-gizmos.mjs.map +1 -0
  100. package/fesm2022/angular-three-soba-loaders.mjs +3 -3
  101. package/fesm2022/angular-three-soba-materials.mjs +52 -62
  102. package/fesm2022/angular-three-soba-materials.mjs.map +1 -1
  103. package/fesm2022/angular-three-soba-misc.mjs +194 -195
  104. package/fesm2022/angular-three-soba-misc.mjs.map +1 -1
  105. package/fesm2022/angular-three-soba-performances.mjs +90 -114
  106. package/fesm2022/angular-three-soba-performances.mjs.map +1 -1
  107. package/fesm2022/angular-three-soba-shaders.mjs.map +1 -1
  108. package/fesm2022/angular-three-soba-staging.mjs +427 -430
  109. package/fesm2022/angular-three-soba-staging.mjs.map +1 -1
  110. package/fesm2022/angular-three-soba-stats.mjs +20 -26
  111. package/fesm2022/angular-three-soba-stats.mjs.map +1 -1
  112. package/gizmos/README.md +3 -0
  113. package/gizmos/index.d.ts +5 -0
  114. package/gizmos/lib/gizmo-helper/gizmo-helper.d.ts +45 -0
  115. package/gizmos/lib/gizmo-helper/gizmo-viewcube.d.ts +74 -0
  116. package/gizmos/lib/gizmo-helper/gizmo-viewport.d.ts +64 -0
  117. package/{controls → gizmos}/lib/pivot-controls/pivot-controls.d.ts +1 -1
  118. package/gizmos/lib/transform-controls.d.ts +50 -0
  119. package/materials/lib/mesh-transmission-material.d.ts +1 -1
  120. package/misc/lib/computed-attribute.d.ts +2 -2
  121. package/misc/lib/decal.d.ts +4 -4
  122. package/misc/lib/html/html-content.d.ts +6 -6
  123. package/misc/lib/html/html.d.ts +1 -1
  124. package/misc/lib/sampler.d.ts +1 -3
  125. package/package.json +14 -8
  126. package/performances/lib/instances/instances.d.ts +3 -3
  127. package/shaders/lib/mesh-refraction-material.d.ts +2 -5
  128. package/staging/index.d.ts +2 -1
  129. package/staging/lib/camera-shake.d.ts +0 -1
  130. package/staging/lib/caustics.d.ts +1 -1
  131. package/staging/lib/center.d.ts +2 -2
  132. package/staging/lib/contact-shadows.d.ts +1 -1
  133. package/staging/lib/{environment.d.ts → environment/environment.d.ts} +20 -49
  134. package/staging/lib/environment/inject-environment.d.ts +33 -0
  135. package/staging/lib/lightformer.d.ts +1 -1
  136. package/staging/lib/mask.d.ts +1 -1
  137. package/staging/lib/matcap-texture.d.ts +0 -1
  138. package/staging/lib/normal-texture.d.ts +0 -1
  139. package/staging/lib/render-texture.d.ts +1 -1
  140. package/staging/lib/sky.d.ts +1 -1
  141. package/staging/lib/stage.d.ts +3 -2
  142. package/esm2022/controls/lib/pivot-controls/axis-arrow.mjs +0 -263
  143. package/esm2022/controls/lib/pivot-controls/axis-rotator.mjs +0 -264
  144. package/esm2022/controls/lib/pivot-controls/pivot-controls.mjs +0 -340
  145. package/esm2022/controls/lib/pivot-controls/plane-slider.mjs +0 -266
  146. package/esm2022/controls/lib/pivot-controls/scaling-sphere.mjs +0 -232
  147. package/esm2022/staging/lib/environment.mjs +0 -481
  148. /package/{controls → gizmos}/lib/pivot-controls/axis-arrow.d.ts +0 -0
  149. /package/{controls → gizmos}/lib/pivot-controls/axis-rotator.d.ts +0 -0
  150. /package/{controls → gizmos}/lib/pivot-controls/plane-slider.d.ts +0 -0
  151. /package/{controls → gizmos}/lib/pivot-controls/scaling-sphere.d.ts +0 -0
@@ -1,9 +1,8 @@
1
- import { afterNextRender, ChangeDetectionStrategy, Component, computed, CUSTOM_ELEMENTS_SCHEMA, input, viewChild, } from '@angular/core';
1
+ import { ChangeDetectionStrategy, Component, computed, CUSTOM_ELEMENTS_SCHEMA, effect, input, viewChild, } from '@angular/core';
2
2
  import { extend, getLocalState, injectBeforeRender, omit, pick, resolveRef } from 'angular-three';
3
3
  import { injectHelper, NgtsEdges } from 'angular-three-soba/abstractions';
4
4
  import { injectFBO } from 'angular-three-soba/misc';
5
5
  import { CausticsProjectionMaterial, createCausticsUpdate } from 'angular-three-soba/vanilla-exports';
6
- import { injectAutoEffect } from 'ngxtension/auto-effect';
7
6
  import { mergeInputs } from 'ngxtension/inject-inputs';
8
7
  import { CameraHelper, CustomBlending, FloatType, Group, LinearFilter, LinearMipmapLinearFilter, LineBasicMaterial, Mesh, OneFactor, OrthographicCamera, PlaneGeometry, Scene, SrcAlphaFactor, UnsignedByteType, Vector3, } from 'three';
9
8
  import * as i0 from "@angular/core";
@@ -76,7 +75,25 @@ export class NgtsCaustics {
76
75
  this.causticsTargetB = injectFBO(this.causticsTargetParams);
77
76
  this.cameraHelper = injectHelper(() => (this.debug() ? this.cameraRef().nativeElement : null), () => CameraHelper);
78
77
  extend({ CausticsProjectionMaterial, Group, Scene, Mesh, PlaneGeometry, LineBasicMaterial, OrthographicCamera });
79
- const autoEffect = injectAutoEffect();
78
+ effect(() => {
79
+ // track all changes
80
+ const [group, scene, plane] = [
81
+ this.groupRef().nativeElement,
82
+ this.sceneRef().nativeElement,
83
+ this.planeRef().nativeElement,
84
+ this.options(),
85
+ ];
86
+ const groupLocalState = getLocalState(group);
87
+ const sceneLocalState = getLocalState(scene);
88
+ const planeLocalState = getLocalState(plane);
89
+ if (!groupLocalState || !sceneLocalState || !planeLocalState)
90
+ return;
91
+ groupLocalState.objects();
92
+ sceneLocalState.objects();
93
+ planeLocalState.objects();
94
+ planeLocalState.nonObjects();
95
+ group.updateWorldMatrix(false, true);
96
+ });
80
97
  const update = createCausticsUpdate(() => {
81
98
  const { lightSource, ...rest } = this.options();
82
99
  return {
@@ -95,30 +112,9 @@ export class NgtsCaustics {
95
112
  };
96
113
  });
97
114
  injectBeforeRender(({ gl }) => update(gl));
98
- afterNextRender(() => {
99
- autoEffect(() => {
100
- // track all changes
101
- this.options();
102
- const [group, scene, plane] = [
103
- this.groupRef().nativeElement,
104
- this.sceneRef().nativeElement,
105
- this.planeRef().nativeElement,
106
- ];
107
- const groupLocalState = getLocalState(group);
108
- const sceneLocalState = getLocalState(scene);
109
- const planeLocalState = getLocalState(plane);
110
- if (!groupLocalState || !sceneLocalState || !planeLocalState)
111
- return;
112
- groupLocalState.objects();
113
- sceneLocalState.objects();
114
- planeLocalState.objects();
115
- planeLocalState.nonObjects();
116
- group.updateWorldMatrix(false, true);
117
- });
118
- });
119
115
  }
120
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: NgtsCaustics, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
121
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.0", type: NgtsCaustics, isStandalone: true, selector: "ngts-caustics", inputs: { options: { classPropertyName: "options", publicName: "options", isSignal: true, isRequired: false, transformFunction: null } }, viewQueries: [{ propertyName: "groupRef", first: true, predicate: ["group"], descendants: true, isSignal: true }, { propertyName: "sceneRef", first: true, predicate: ["scene"], descendants: true, isSignal: true }, { propertyName: "cameraRef", first: true, predicate: ["camera"], descendants: true, isSignal: true }, { propertyName: "planeRef", first: true, predicate: ["plane"], descendants: true, isSignal: true }], ngImport: i0, template: `
116
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.4", ngImport: i0, type: NgtsCaustics, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
117
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.4", type: NgtsCaustics, isStandalone: true, selector: "ngts-caustics", inputs: { options: { classPropertyName: "options", publicName: "options", isSignal: true, isRequired: false, transformFunction: null } }, viewQueries: [{ propertyName: "groupRef", first: true, predicate: ["group"], descendants: true, isSignal: true }, { propertyName: "sceneRef", first: true, predicate: ["scene"], descendants: true, isSignal: true }, { propertyName: "cameraRef", first: true, predicate: ["camera"], descendants: true, isSignal: true }, { propertyName: "planeRef", first: true, predicate: ["plane"], descendants: true, isSignal: true }], ngImport: i0, template: `
122
118
  <ngt-group #group [parameters]="parameters()">
123
119
  <ngt-scene #scene>
124
120
  <ngt-orthographic-camera #camera [up]="[0, 1, 0]" />
@@ -147,7 +143,7 @@ export class NgtsCaustics {
147
143
  </ngt-group>
148
144
  `, isInline: true, dependencies: [{ kind: "component", type: NgtsEdges, selector: "ngts-edges", inputs: ["options"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
149
145
  }
150
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: NgtsCaustics, decorators: [{
146
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.4", ngImport: i0, type: NgtsCaustics, decorators: [{
151
147
  type: Component,
152
148
  args: [{
153
149
  selector: 'ngts-caustics',
@@ -185,4 +181,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImpor
185
181
  imports: [NgtsEdges],
186
182
  }]
187
183
  }], ctorParameters: () => [] });
188
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"caustics.js","sourceRoot":"","sources":["../../../../../../libs/soba/staging/src/lib/caustics.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n\tafterNextRender,\n\tChangeDetectionStrategy,\n\tComponent,\n\tcomputed,\n\tCUSTOM_ELEMENTS_SCHEMA,\n\tElementRef,\n\tinput,\n\tviewChild,\n} from '@angular/core';\nimport { extend, getLocalState, injectBeforeRender, NgtGroup, omit, pick, resolveRef } from 'angular-three';\nimport { injectHelper, NgtsEdges } from 'angular-three-soba/abstractions';\nimport { injectFBO } from 'angular-three-soba/misc';\nimport { CausticsProjectionMaterial, createCausticsUpdate } from 'angular-three-soba/vanilla-exports';\nimport { injectAutoEffect } from 'ngxtension/auto-effect';\nimport { mergeInputs } from 'ngxtension/inject-inputs';\nimport {\n\tCameraHelper,\n\tColorRepresentation,\n\tCustomBlending,\n\tFloatType,\n\tGroup,\n\tLinearFilter,\n\tLinearMipmapLinearFilter,\n\tLineBasicMaterial,\n\tMesh,\n\tObject3D,\n\tOneFactor,\n\tOrthographicCamera,\n\tPlaneGeometry,\n\tScene,\n\tSrcAlphaFactor,\n\tUnsignedByteType,\n\tVector3,\n} from 'three';\n\nconst NORMAL_OPTIONS = {\n\tdepth: true,\n\tminFilter: LinearFilter,\n\tmagFilter: LinearFilter,\n\ttype: UnsignedByteType,\n};\n\nconst CAUSTIC_OPTIONS = {\n\tminFilter: LinearMipmapLinearFilter,\n\tmagFilter: LinearFilter,\n\ttype: FloatType,\n\tgenerateMipmaps: true,\n};\n\nexport interface NgtsCausticsOptions extends Partial<NgtGroup> {\n\t/** How many frames it will render, set it to Infinity for runtime, default: 1 */\n\tframes: number;\n\t/** Enables visual cues to help you stage your scene, default: false */\n\tdebug: boolean;\n\t/** Will display caustics only and skip the models, default: false */\n\tcausticsOnly: boolean;\n\t/** Will include back faces and enable the backsideIOR prop, default: false */\n\tbackside: boolean;\n\t/** The IOR refraction index, default: 1.1 */\n\tior: number;\n\t/** The IOR refraction index for back faces (only available when backside is enabled), default: 1.1 */\n\tbacksideIOR: number;\n\t/** The texel size, default: 0.3125 */\n\tworldRadius: number;\n\t/** Intensity of the prjected caustics, default: 0.05 */\n\tintensity: number;\n\t/** Caustics color, default: white */\n\tcolor: ColorRepresentation;\n\t/** Buffer resolution, default: 2048 */\n\tresolution: number;\n\t/** Camera position, it will point towards the contents bounds center, default: [5, 5, 5] */\n\tlightSource: [x: number, y: number, z: number] | ElementRef<Object3D> | Object3D;\n}\n\nconst defaultOptions: NgtsCausticsOptions = {\n\tframes: 1,\n\tdebug: false,\n\tcausticsOnly: false,\n\tbackside: false,\n\tior: 1.1,\n\tbacksideIOR: 1.1,\n\tworldRadius: 0.3125,\n\tintensity: 0.05,\n\tcolor: 'white',\n\tresolution: 2024,\n\tlightSource: [5, 5, 5],\n};\n\n@Component({\n\tselector: 'ngts-caustics',\n\tstandalone: true,\n\ttemplate: `\n\t\t<ngt-group #group [parameters]=\"parameters()\">\n\t\t\t<ngt-scene #scene>\n\t\t\t\t<ngt-orthographic-camera #camera [up]=\"[0, 1, 0]\" />\n\t\t\t\t<ng-content />\n\t\t\t</ngt-scene>\n\n\t\t\t<ngt-mesh #plane [renderOrder]=\"2\" [rotation]=\"[-Math.PI / 2, 0, 0]\">\n\t\t\t\t<ngt-plane-geometry />\n\t\t\t\t<ngt-caustics-projection-material\n\t\t\t\t\t[transparent]=\"true\"\n\t\t\t\t\t[color]=\"color()\"\n\t\t\t\t\t[causticsTexture]=\"causticsTarget().texture\"\n\t\t\t\t\t[causticsTextureB]=\"causticsTargetB().texture\"\n\t\t\t\t\t[blending]=\"CustomBlending\"\n\t\t\t\t\t[blendSrc]=\"OneFactor\"\n\t\t\t\t\t[blendDst]=\"SrcAlphaFactor\"\n\t\t\t\t\t[depthWrite]=\"false\"\n\t\t\t\t/>\n\n\t\t\t\t@if (debug()) {\n\t\t\t\t\t<ngts-edges>\n\t\t\t\t\t\t<ngt-line-basic-material color=\"#ffff00\" [toneMapped]=\"false\" />\n\t\t\t\t\t</ngts-edges>\n\t\t\t\t}\n\t\t\t</ngt-mesh>\n\t\t</ngt-group>\n\t`,\n\tschemas: [CUSTOM_ELEMENTS_SCHEMA],\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\timports: [NgtsEdges],\n})\nexport class NgtsCaustics {\n\tprotected readonly Math = Math;\n\tprotected readonly CustomBlending = CustomBlending;\n\tprotected readonly OneFactor = OneFactor;\n\tprotected readonly SrcAlphaFactor = SrcAlphaFactor;\n\n\toptions = input(defaultOptions, { transform: mergeInputs(defaultOptions) });\n\tparameters = omit(this.options, [\n\t\t'frames',\n\t\t'debug',\n\t\t'causticsOnly',\n\t\t'backside',\n\t\t'ior',\n\t\t'backsideIOR',\n\t\t'worldRadius',\n\t\t'intensity',\n\t\t'color',\n\t\t'resolution',\n\t\t'lightSource',\n\t]);\n\n\tdebug = pick(this.options, 'debug');\n\tcolor = pick(this.options, 'color');\n\tprivate resolution = pick(this.options, 'resolution');\n\n\tgroupRef = viewChild.required<ElementRef<Group>>('group');\n\tprivate sceneRef = viewChild.required<ElementRef<Scene>>('scene');\n\tprivate cameraRef = viewChild.required<ElementRef<OrthographicCamera>>('camera');\n\tprivate planeRef =\n\t\tviewChild.required<ElementRef<Mesh<PlaneGeometry, InstanceType<typeof CausticsProjectionMaterial>>>>('plane');\n\n\tprivate normalTargetParams = computed(() => ({\n\t\twidth: this.resolution(),\n\t\theight: this.resolution(),\n\t\tsettings: NORMAL_OPTIONS,\n\t}));\n\n\t// Buffers for front and back faces\n\tprivate normalTarget = injectFBO(this.normalTargetParams);\n\tprivate normalTargetB = injectFBO(this.normalTargetParams);\n\n\tprivate causticsTargetParams = computed(() => ({\n\t\twidth: this.resolution(),\n\t\theight: this.resolution(),\n\t\tsettings: CAUSTIC_OPTIONS,\n\t}));\n\tcausticsTarget = injectFBO(this.causticsTargetParams);\n\tcausticsTargetB = injectFBO(this.causticsTargetParams);\n\n\tprivate cameraHelper = injectHelper(\n\t\t() => (this.debug() ? this.cameraRef().nativeElement : null),\n\t\t() => CameraHelper,\n\t);\n\n\tconstructor() {\n\t\textend({ CausticsProjectionMaterial, Group, Scene, Mesh, PlaneGeometry, LineBasicMaterial, OrthographicCamera });\n\n\t\tconst autoEffect = injectAutoEffect();\n\n\t\tconst update = createCausticsUpdate(() => {\n\t\t\tconst { lightSource, ...rest } = this.options();\n\n\t\t\treturn {\n\t\t\t\tparams: Object.assign(rest, {\n\t\t\t\t\tlightSource: Array.isArray(lightSource) ? new Vector3(...lightSource) : resolveRef(lightSource),\n\t\t\t\t}),\n\t\t\t\tnormalTarget: this.normalTarget(),\n\t\t\t\tnormalTargetB: this.normalTargetB(),\n\t\t\t\tcausticsTarget: this.causticsTarget(),\n\t\t\t\tcausticsTargetB: this.causticsTargetB(),\n\t\t\t\tcamera: this.cameraRef().nativeElement,\n\t\t\t\tscene: this.sceneRef().nativeElement,\n\t\t\t\tgroup: this.groupRef().nativeElement,\n\t\t\t\tplane: this.planeRef().nativeElement,\n\t\t\t\thelper: this.cameraHelper(),\n\t\t\t};\n\t\t});\n\n\t\tinjectBeforeRender(({ gl }) => update(gl));\n\n\t\tafterNextRender(() => {\n\t\t\tautoEffect(() => {\n\t\t\t\t// track all changes\n\t\t\t\tthis.options();\n\t\t\t\tconst [group, scene, plane] = [\n\t\t\t\t\tthis.groupRef().nativeElement,\n\t\t\t\t\tthis.sceneRef().nativeElement,\n\t\t\t\t\tthis.planeRef().nativeElement,\n\t\t\t\t];\n\t\t\t\tconst groupLocalState = getLocalState(group);\n\t\t\t\tconst sceneLocalState = getLocalState(scene);\n\t\t\t\tconst planeLocalState = getLocalState(plane);\n\n\t\t\t\tif (!groupLocalState || !sceneLocalState || !planeLocalState) return;\n\n\t\t\t\tgroupLocalState.objects();\n\t\t\t\tsceneLocalState.objects();\n\t\t\t\tplaneLocalState.objects();\n\t\t\t\tplaneLocalState.nonObjects();\n\n\t\t\t\tgroup.updateWorldMatrix(false, true);\n\t\t\t});\n\t\t});\n\t}\n}\n"]}
184
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"caustics.js","sourceRoot":"","sources":["../../../../../../libs/soba/staging/src/lib/caustics.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n\tChangeDetectionStrategy,\n\tComponent,\n\tcomputed,\n\tCUSTOM_ELEMENTS_SCHEMA,\n\teffect,\n\tElementRef,\n\tinput,\n\tviewChild,\n} from '@angular/core';\nimport { extend, getLocalState, injectBeforeRender, NgtGroup, omit, pick, resolveRef } from 'angular-three';\nimport { injectHelper, NgtsEdges } from 'angular-three-soba/abstractions';\nimport { injectFBO } from 'angular-three-soba/misc';\nimport { CausticsProjectionMaterial, createCausticsUpdate } from 'angular-three-soba/vanilla-exports';\nimport { mergeInputs } from 'ngxtension/inject-inputs';\nimport {\n\tCameraHelper,\n\tColorRepresentation,\n\tCustomBlending,\n\tFloatType,\n\tGroup,\n\tLinearFilter,\n\tLinearMipmapLinearFilter,\n\tLineBasicMaterial,\n\tMesh,\n\tObject3D,\n\tOneFactor,\n\tOrthographicCamera,\n\tPlaneGeometry,\n\tScene,\n\tSrcAlphaFactor,\n\tUnsignedByteType,\n\tVector3,\n} from 'three';\n\nconst NORMAL_OPTIONS = {\n\tdepth: true,\n\tminFilter: LinearFilter,\n\tmagFilter: LinearFilter,\n\ttype: UnsignedByteType,\n};\n\nconst CAUSTIC_OPTIONS = {\n\tminFilter: LinearMipmapLinearFilter,\n\tmagFilter: LinearFilter,\n\ttype: FloatType,\n\tgenerateMipmaps: true,\n};\n\nexport interface NgtsCausticsOptions extends Partial<NgtGroup> {\n\t/** How many frames it will render, set it to Infinity for runtime, default: 1 */\n\tframes: number;\n\t/** Enables visual cues to help you stage your scene, default: false */\n\tdebug: boolean;\n\t/** Will display caustics only and skip the models, default: false */\n\tcausticsOnly: boolean;\n\t/** Will include back faces and enable the backsideIOR prop, default: false */\n\tbackside: boolean;\n\t/** The IOR refraction index, default: 1.1 */\n\tior: number;\n\t/** The IOR refraction index for back faces (only available when backside is enabled), default: 1.1 */\n\tbacksideIOR: number;\n\t/** The texel size, default: 0.3125 */\n\tworldRadius: number;\n\t/** Intensity of the prjected caustics, default: 0.05 */\n\tintensity: number;\n\t/** Caustics color, default: white */\n\tcolor: ColorRepresentation;\n\t/** Buffer resolution, default: 2048 */\n\tresolution: number;\n\t/** Camera position, it will point towards the contents bounds center, default: [5, 5, 5] */\n\tlightSource: [x: number, y: number, z: number] | ElementRef<Object3D> | Object3D;\n}\n\nconst defaultOptions: NgtsCausticsOptions = {\n\tframes: 1,\n\tdebug: false,\n\tcausticsOnly: false,\n\tbackside: false,\n\tior: 1.1,\n\tbacksideIOR: 1.1,\n\tworldRadius: 0.3125,\n\tintensity: 0.05,\n\tcolor: 'white',\n\tresolution: 2024,\n\tlightSource: [5, 5, 5],\n};\n\n@Component({\n\tselector: 'ngts-caustics',\n\tstandalone: true,\n\ttemplate: `\n\t\t<ngt-group #group [parameters]=\"parameters()\">\n\t\t\t<ngt-scene #scene>\n\t\t\t\t<ngt-orthographic-camera #camera [up]=\"[0, 1, 0]\" />\n\t\t\t\t<ng-content />\n\t\t\t</ngt-scene>\n\n\t\t\t<ngt-mesh #plane [renderOrder]=\"2\" [rotation]=\"[-Math.PI / 2, 0, 0]\">\n\t\t\t\t<ngt-plane-geometry />\n\t\t\t\t<ngt-caustics-projection-material\n\t\t\t\t\t[transparent]=\"true\"\n\t\t\t\t\t[color]=\"color()\"\n\t\t\t\t\t[causticsTexture]=\"causticsTarget().texture\"\n\t\t\t\t\t[causticsTextureB]=\"causticsTargetB().texture\"\n\t\t\t\t\t[blending]=\"CustomBlending\"\n\t\t\t\t\t[blendSrc]=\"OneFactor\"\n\t\t\t\t\t[blendDst]=\"SrcAlphaFactor\"\n\t\t\t\t\t[depthWrite]=\"false\"\n\t\t\t\t/>\n\n\t\t\t\t@if (debug()) {\n\t\t\t\t\t<ngts-edges>\n\t\t\t\t\t\t<ngt-line-basic-material color=\"#ffff00\" [toneMapped]=\"false\" />\n\t\t\t\t\t</ngts-edges>\n\t\t\t\t}\n\t\t\t</ngt-mesh>\n\t\t</ngt-group>\n\t`,\n\tschemas: [CUSTOM_ELEMENTS_SCHEMA],\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\timports: [NgtsEdges],\n})\nexport class NgtsCaustics {\n\tprotected readonly Math = Math;\n\tprotected readonly CustomBlending = CustomBlending;\n\tprotected readonly OneFactor = OneFactor;\n\tprotected readonly SrcAlphaFactor = SrcAlphaFactor;\n\n\toptions = input(defaultOptions, { transform: mergeInputs(defaultOptions) });\n\tparameters = omit(this.options, [\n\t\t'frames',\n\t\t'debug',\n\t\t'causticsOnly',\n\t\t'backside',\n\t\t'ior',\n\t\t'backsideIOR',\n\t\t'worldRadius',\n\t\t'intensity',\n\t\t'color',\n\t\t'resolution',\n\t\t'lightSource',\n\t]);\n\n\tdebug = pick(this.options, 'debug');\n\tcolor = pick(this.options, 'color');\n\tprivate resolution = pick(this.options, 'resolution');\n\n\tgroupRef = viewChild.required<ElementRef<Group>>('group');\n\tprivate sceneRef = viewChild.required<ElementRef<Scene>>('scene');\n\tprivate cameraRef = viewChild.required<ElementRef<OrthographicCamera>>('camera');\n\tprivate planeRef =\n\t\tviewChild.required<ElementRef<Mesh<PlaneGeometry, InstanceType<typeof CausticsProjectionMaterial>>>>('plane');\n\n\tprivate normalTargetParams = computed(() => ({\n\t\twidth: this.resolution(),\n\t\theight: this.resolution(),\n\t\tsettings: NORMAL_OPTIONS,\n\t}));\n\n\t// Buffers for front and back faces\n\tprivate normalTarget = injectFBO(this.normalTargetParams);\n\tprivate normalTargetB = injectFBO(this.normalTargetParams);\n\n\tprivate causticsTargetParams = computed(() => ({\n\t\twidth: this.resolution(),\n\t\theight: this.resolution(),\n\t\tsettings: CAUSTIC_OPTIONS,\n\t}));\n\tcausticsTarget = injectFBO(this.causticsTargetParams);\n\tcausticsTargetB = injectFBO(this.causticsTargetParams);\n\n\tprivate cameraHelper = injectHelper(\n\t\t() => (this.debug() ? this.cameraRef().nativeElement : null),\n\t\t() => CameraHelper,\n\t);\n\n\tconstructor() {\n\t\textend({ CausticsProjectionMaterial, Group, Scene, Mesh, PlaneGeometry, LineBasicMaterial, OrthographicCamera });\n\n\t\teffect(() => {\n\t\t\t// track all changes\n\t\t\tconst [group, scene, plane] = [\n\t\t\t\tthis.groupRef().nativeElement,\n\t\t\t\tthis.sceneRef().nativeElement,\n\t\t\t\tthis.planeRef().nativeElement,\n\t\t\t\tthis.options(),\n\t\t\t];\n\t\t\tconst groupLocalState = getLocalState(group);\n\t\t\tconst sceneLocalState = getLocalState(scene);\n\t\t\tconst planeLocalState = getLocalState(plane);\n\n\t\t\tif (!groupLocalState || !sceneLocalState || !planeLocalState) return;\n\n\t\t\tgroupLocalState.objects();\n\t\t\tsceneLocalState.objects();\n\t\t\tplaneLocalState.objects();\n\t\t\tplaneLocalState.nonObjects();\n\n\t\t\tgroup.updateWorldMatrix(false, true);\n\t\t});\n\n\t\tconst update = createCausticsUpdate(() => {\n\t\t\tconst { lightSource, ...rest } = this.options();\n\n\t\t\treturn {\n\t\t\t\tparams: Object.assign(rest, {\n\t\t\t\t\tlightSource: Array.isArray(lightSource) ? new Vector3(...lightSource) : resolveRef(lightSource),\n\t\t\t\t}),\n\t\t\t\tnormalTarget: this.normalTarget(),\n\t\t\t\tnormalTargetB: this.normalTargetB(),\n\t\t\t\tcausticsTarget: this.causticsTarget(),\n\t\t\t\tcausticsTargetB: this.causticsTargetB(),\n\t\t\t\tcamera: this.cameraRef().nativeElement,\n\t\t\t\tscene: this.sceneRef().nativeElement,\n\t\t\t\tgroup: this.groupRef().nativeElement,\n\t\t\t\tplane: this.planeRef().nativeElement,\n\t\t\t\thelper: this.cameraHelper(),\n\t\t\t};\n\t\t});\n\n\t\tinjectBeforeRender(({ gl }) => update(gl));\n\t}\n}\n"]}
@@ -1,6 +1,5 @@
1
- import { afterNextRender, ChangeDetectionStrategy, Component, CUSTOM_ELEMENTS_SCHEMA, input, output, viewChild, } from '@angular/core';
1
+ import { ChangeDetectionStrategy, Component, CUSTOM_ELEMENTS_SCHEMA, effect, input, output, untracked, viewChild, } from '@angular/core';
2
2
  import { extend, getLocalState, omit, pick } from 'angular-three';
3
- import { injectAutoEffect } from 'ngxtension/auto-effect';
4
3
  import { mergeInputs } from 'ngxtension/inject-inputs';
5
4
  import { Box3, Group, Sphere, Vector3 } from 'three';
6
5
  import * as i0 from "@angular/core";
@@ -44,32 +43,29 @@ export class NgtsCenter {
44
43
  'cacheKey',
45
44
  ]);
46
45
  extend({ Group });
47
- const autoEffect = injectAutoEffect();
48
- afterNextRender(() => {
49
- autoEffect(() => {
50
- const [{ precise, top, bottom, right, left, front, back, disable, disableZ, disableY, disableX }, group, outer, inner,] = [
51
- this.centerOptions(),
52
- this.groupRef().nativeElement,
53
- this.outerRef().nativeElement,
54
- this.innerRef().nativeElement,
55
- ];
56
- const localState = getLocalState(inner);
57
- const children = localState?.objects();
58
- if (!children?.length)
59
- return;
60
- outer.matrixWorld.identity();
61
- const box3 = new Box3().setFromObject(inner, precise);
62
- const center = new Vector3();
63
- const sphere = new Sphere();
64
- const width = box3.max.x - box3.min.x;
65
- const height = box3.max.y - box3.min.y;
66
- const depth = box3.max.z - box3.min.z;
67
- box3.getCenter(center);
68
- box3.getBoundingSphere(sphere);
69
- const vAlign = top ? height / 2 : bottom ? -height / 2 : 0;
70
- const hAlign = left ? -width / 2 : right ? width / 2 : 0;
71
- const dAlign = front ? depth / 2 : back ? -depth / 2 : 0;
72
- outer.position.set(disable || disableX ? 0 : -center.x + hAlign, disable || disableY ? 0 : -center.y + vAlign, disable || disableZ ? 0 : -center.z + dAlign);
46
+ effect(() => {
47
+ const inner = this.innerRef().nativeElement;
48
+ const localState = getLocalState(inner);
49
+ if (!localState)
50
+ return;
51
+ const children = [localState.objects(), localState.nonObjects()];
52
+ if (!children?.length)
53
+ return;
54
+ const [{ precise, top, bottom, right, left, front, back, disable, disableZ, disableY, disableX }, group, outer] = [this.centerOptions(), this.groupRef().nativeElement, this.outerRef().nativeElement];
55
+ outer.matrixWorld.identity();
56
+ const box3 = new Box3().setFromObject(inner, precise);
57
+ const center = new Vector3();
58
+ const sphere = new Sphere();
59
+ const width = box3.max.x - box3.min.x;
60
+ const height = box3.max.y - box3.min.y;
61
+ const depth = box3.max.z - box3.min.z;
62
+ box3.getCenter(center);
63
+ box3.getBoundingSphere(sphere);
64
+ const vAlign = top ? height / 2 : bottom ? -height / 2 : 0;
65
+ const hAlign = left ? -width / 2 : right ? width / 2 : 0;
66
+ const dAlign = front ? depth / 2 : back ? -depth / 2 : 0;
67
+ outer.position.set(disable || disableX ? 0 : -center.x + hAlign, disable || disableY ? 0 : -center.y + vAlign, disable || disableZ ? 0 : -center.z + dAlign);
68
+ untracked(() => {
73
69
  this.centered.emit({
74
70
  parent: group.parent,
75
71
  container: group,
@@ -86,8 +82,8 @@ export class NgtsCenter {
86
82
  });
87
83
  });
88
84
  }
89
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: NgtsCenter, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
90
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "18.2.0", type: NgtsCenter, isStandalone: true, selector: "ngts-center", inputs: { options: { classPropertyName: "options", publicName: "options", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { centered: "centered" }, viewQueries: [{ propertyName: "groupRef", first: true, predicate: ["group"], descendants: true, isSignal: true }, { propertyName: "outerRef", first: true, predicate: ["outer"], descendants: true, isSignal: true }, { propertyName: "innerRef", first: true, predicate: ["inner"], descendants: true, isSignal: true }], ngImport: i0, template: `
85
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.4", ngImport: i0, type: NgtsCenter, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
86
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "18.2.4", type: NgtsCenter, isStandalone: true, selector: "ngts-center", inputs: { options: { classPropertyName: "options", publicName: "options", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { centered: "centered" }, viewQueries: [{ propertyName: "groupRef", first: true, predicate: ["group"], descendants: true, isSignal: true }, { propertyName: "outerRef", first: true, predicate: ["outer"], descendants: true, isSignal: true }, { propertyName: "innerRef", first: true, predicate: ["inner"], descendants: true, isSignal: true }], ngImport: i0, template: `
91
87
  <ngt-group #group [parameters]="parameters()">
92
88
  <ngt-group #outer>
93
89
  <ngt-group #inner>
@@ -97,7 +93,7 @@ export class NgtsCenter {
97
93
  </ngt-group>
98
94
  `, isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
99
95
  }
100
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: NgtsCenter, decorators: [{
96
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.4", ngImport: i0, type: NgtsCenter, decorators: [{
101
97
  type: Component,
102
98
  args: [{
103
99
  selector: 'ngts-center',
@@ -115,4 +111,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImpor
115
111
  changeDetection: ChangeDetectionStrategy.OnPush,
116
112
  }]
117
113
  }], ctorParameters: () => [] });
118
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"center.js","sourceRoot":"","sources":["../../../../../../libs/soba/staging/src/lib/center.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n\tafterNextRender,\n\tChangeDetectionStrategy,\n\tComponent,\n\tCUSTOM_ELEMENTS_SCHEMA,\n\tElementRef,\n\tinput,\n\toutput,\n\tviewChild,\n} from '@angular/core';\nimport { extend, getLocalState, NgtGroup, omit, pick } from 'angular-three';\nimport { injectAutoEffect } from 'ngxtension/auto-effect';\nimport { mergeInputs } from 'ngxtension/inject-inputs';\nimport { Box3, Group, Object3D, Sphere, Vector3 } from 'three';\n\nexport interface NgtsCenterState {\n\t/** The next parent above <Center> */\n\tparent: Object3D;\n\t/** The outmost container group of the <Center> component */\n\tcontainer: Object3D;\n\twidth: number;\n\theight: number;\n\tdepth: number;\n\tboundingBox: Box3;\n\tboundingSphere: Sphere;\n\tcenter: Vector3;\n\tverticalAlignment: number;\n\thorizontalAlignment: number;\n\tdepthAlignment: number;\n}\n\nexport interface NgtsCenterOptions {\n\ttop?: boolean;\n\tright?: boolean;\n\tbottom?: boolean;\n\tleft?: boolean;\n\tfront?: boolean;\n\tback?: boolean;\n\t/** Disable all axes */\n\tdisable?: boolean;\n\t/** Disable x-axis centering */\n\tdisableX?: boolean;\n\t/** Disable y-axis centering */\n\tdisableY?: boolean;\n\t/** Disable z-axis centering */\n\tdisableZ?: boolean;\n\t/** See https://threejs.org/docs/index.html?q=box3#api/en/math/Box3.setFromObject */\n\tprecise: boolean;\n\t/** Optional cacheKey to keep the component from recalculating on every render */\n\tcacheKey: any;\n}\n\nconst defaultOptions: Partial<NgtGroup> & NgtsCenterOptions = {\n\tprecise: true,\n\tcacheKey: 0,\n};\n\n@Component({\n\tselector: 'ngts-center',\n\tstandalone: true,\n\ttemplate: `\n\t\t<ngt-group #group [parameters]=\"parameters()\">\n\t\t\t<ngt-group #outer>\n\t\t\t\t<ngt-group #inner>\n\t\t\t\t\t<ng-content />\n\t\t\t\t</ngt-group>\n\t\t\t</ngt-group>\n\t\t</ngt-group>\n\t`,\n\tschemas: [CUSTOM_ELEMENTS_SCHEMA],\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class NgtsCenter {\n\toptions = input(defaultOptions, { transform: mergeInputs(defaultOptions) });\n\tparameters = omit(this.options, [\n\t\t'top',\n\t\t'right',\n\t\t'bottom',\n\t\t'left',\n\t\t'front',\n\t\t'back',\n\t\t'disable',\n\t\t'disableX',\n\t\t'disableY',\n\t\t'disableZ',\n\t\t'precise',\n\t\t'cacheKey',\n\t]);\n\n\tcentered = output<NgtsCenterState>();\n\n\tgroupRef = viewChild.required<ElementRef<Group>>('group');\n\tprivate outerRef = viewChild.required<ElementRef<Group>>('outer');\n\tprivate innerRef = viewChild.required<ElementRef<Group>>('inner');\n\n\tcenterOptions = pick(this.options, [\n\t\t'top',\n\t\t'right',\n\t\t'bottom',\n\t\t'left',\n\t\t'front',\n\t\t'back',\n\t\t'disable',\n\t\t'disableX',\n\t\t'disableY',\n\t\t'disableZ',\n\t\t'precise',\n\t\t'cacheKey',\n\t]);\n\n\tconstructor() {\n\t\textend({ Group });\n\n\t\tconst autoEffect = injectAutoEffect();\n\n\t\tafterNextRender(() => {\n\t\t\tautoEffect(() => {\n\t\t\t\tconst [\n\t\t\t\t\t{ precise, top, bottom, right, left, front, back, disable, disableZ, disableY, disableX },\n\t\t\t\t\tgroup,\n\t\t\t\t\touter,\n\t\t\t\t\tinner,\n\t\t\t\t] = [\n\t\t\t\t\tthis.centerOptions(),\n\t\t\t\t\tthis.groupRef().nativeElement,\n\t\t\t\t\tthis.outerRef().nativeElement,\n\t\t\t\t\tthis.innerRef().nativeElement,\n\t\t\t\t];\n\n\t\t\t\tconst localState = getLocalState(inner);\n\t\t\t\tconst children = localState?.objects();\n\t\t\t\tif (!children?.length) return;\n\n\t\t\t\touter.matrixWorld.identity();\n\t\t\t\tconst box3 = new Box3().setFromObject(inner, precise);\n\t\t\t\tconst center = new Vector3();\n\t\t\t\tconst sphere = new Sphere();\n\n\t\t\t\tconst width = box3.max.x - box3.min.x;\n\t\t\t\tconst height = box3.max.y - box3.min.y;\n\t\t\t\tconst depth = box3.max.z - box3.min.z;\n\n\t\t\t\tbox3.getCenter(center);\n\t\t\t\tbox3.getBoundingSphere(sphere);\n\n\t\t\t\tconst vAlign = top ? height / 2 : bottom ? -height / 2 : 0;\n\t\t\t\tconst hAlign = left ? -width / 2 : right ? width / 2 : 0;\n\t\t\t\tconst dAlign = front ? depth / 2 : back ? -depth / 2 : 0;\n\n\t\t\t\touter.position.set(\n\t\t\t\t\tdisable || disableX ? 0 : -center.x + hAlign,\n\t\t\t\t\tdisable || disableY ? 0 : -center.y + vAlign,\n\t\t\t\t\tdisable || disableZ ? 0 : -center.z + dAlign,\n\t\t\t\t);\n\n\t\t\t\tthis.centered.emit({\n\t\t\t\t\tparent: group.parent!,\n\t\t\t\t\tcontainer: group,\n\t\t\t\t\twidth,\n\t\t\t\t\theight,\n\t\t\t\t\tdepth,\n\t\t\t\t\tboundingBox: box3,\n\t\t\t\t\tboundingSphere: sphere,\n\t\t\t\t\tcenter,\n\t\t\t\t\tverticalAlignment: vAlign,\n\t\t\t\t\thorizontalAlignment: hAlign,\n\t\t\t\t\tdepthAlignment: dAlign,\n\t\t\t\t});\n\t\t\t});\n\t\t});\n\t}\n}\n"]}
114
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"center.js","sourceRoot":"","sources":["../../../../../../libs/soba/staging/src/lib/center.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n\tChangeDetectionStrategy,\n\tComponent,\n\tCUSTOM_ELEMENTS_SCHEMA,\n\teffect,\n\tElementRef,\n\tinput,\n\toutput,\n\tuntracked,\n\tviewChild,\n} from '@angular/core';\nimport { extend, getLocalState, NgtGroup, omit, pick } from 'angular-three';\nimport { mergeInputs } from 'ngxtension/inject-inputs';\nimport { Box3, Group, Object3D, Sphere, Vector3 } from 'three';\n\nexport interface NgtsCenterState {\n\t/** The next parent above <Center> */\n\tparent: Object3D;\n\t/** The outmost container group of the <Center> component */\n\tcontainer: Object3D;\n\twidth: number;\n\theight: number;\n\tdepth: number;\n\tboundingBox: Box3;\n\tboundingSphere: Sphere;\n\tcenter: Vector3;\n\tverticalAlignment: number;\n\thorizontalAlignment: number;\n\tdepthAlignment: number;\n}\n\nexport interface NgtsCenterOptions {\n\ttop?: boolean;\n\tright?: boolean;\n\tbottom?: boolean;\n\tleft?: boolean;\n\tfront?: boolean;\n\tback?: boolean;\n\t/** Disable all axes */\n\tdisable?: boolean;\n\t/** Disable x-axis centering */\n\tdisableX?: boolean;\n\t/** Disable y-axis centering */\n\tdisableY?: boolean;\n\t/** Disable z-axis centering */\n\tdisableZ?: boolean;\n\t/** See https://threejs.org/docs/index.html?q=box3#api/en/math/Box3.setFromObject */\n\tprecise: boolean;\n\t/** Optional cacheKey to keep the component from recalculating on every render */\n\tcacheKey: any;\n}\n\nconst defaultOptions: Partial<NgtGroup> & NgtsCenterOptions = {\n\tprecise: true,\n\tcacheKey: 0,\n};\n\n@Component({\n\tselector: 'ngts-center',\n\tstandalone: true,\n\ttemplate: `\n\t\t<ngt-group #group [parameters]=\"parameters()\">\n\t\t\t<ngt-group #outer>\n\t\t\t\t<ngt-group #inner>\n\t\t\t\t\t<ng-content />\n\t\t\t\t</ngt-group>\n\t\t\t</ngt-group>\n\t\t</ngt-group>\n\t`,\n\tschemas: [CUSTOM_ELEMENTS_SCHEMA],\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class NgtsCenter {\n\toptions = input(defaultOptions, { transform: mergeInputs(defaultOptions) });\n\tparameters = omit(this.options, [\n\t\t'top',\n\t\t'right',\n\t\t'bottom',\n\t\t'left',\n\t\t'front',\n\t\t'back',\n\t\t'disable',\n\t\t'disableX',\n\t\t'disableY',\n\t\t'disableZ',\n\t\t'precise',\n\t\t'cacheKey',\n\t]);\n\n\tcentered = output<NgtsCenterState>();\n\n\tgroupRef = viewChild.required<ElementRef<Group>>('group');\n\tprivate outerRef = viewChild.required<ElementRef<Group>>('outer');\n\tprivate innerRef = viewChild.required<ElementRef<Group>>('inner');\n\n\tcenterOptions = pick(this.options, [\n\t\t'top',\n\t\t'right',\n\t\t'bottom',\n\t\t'left',\n\t\t'front',\n\t\t'back',\n\t\t'disable',\n\t\t'disableX',\n\t\t'disableY',\n\t\t'disableZ',\n\t\t'precise',\n\t\t'cacheKey',\n\t]);\n\n\tconstructor() {\n\t\textend({ Group });\n\n\t\teffect(() => {\n\t\t\tconst inner = this.innerRef().nativeElement;\n\t\t\tconst localState = getLocalState(inner);\n\t\t\tif (!localState) return;\n\n\t\t\tconst children = [localState.objects(), localState.nonObjects()];\n\t\t\tif (!children?.length) return;\n\n\t\t\tconst [{ precise, top, bottom, right, left, front, back, disable, disableZ, disableY, disableX }, group, outer] =\n\t\t\t\t[this.centerOptions(), this.groupRef().nativeElement, this.outerRef().nativeElement];\n\n\t\t\touter.matrixWorld.identity();\n\t\t\tconst box3 = new Box3().setFromObject(inner, precise);\n\t\t\tconst center = new Vector3();\n\t\t\tconst sphere = new Sphere();\n\n\t\t\tconst width = box3.max.x - box3.min.x;\n\t\t\tconst height = box3.max.y - box3.min.y;\n\t\t\tconst depth = box3.max.z - box3.min.z;\n\n\t\t\tbox3.getCenter(center);\n\t\t\tbox3.getBoundingSphere(sphere);\n\n\t\t\tconst vAlign = top ? height / 2 : bottom ? -height / 2 : 0;\n\t\t\tconst hAlign = left ? -width / 2 : right ? width / 2 : 0;\n\t\t\tconst dAlign = front ? depth / 2 : back ? -depth / 2 : 0;\n\n\t\t\touter.position.set(\n\t\t\t\tdisable || disableX ? 0 : -center.x + hAlign,\n\t\t\t\tdisable || disableY ? 0 : -center.y + vAlign,\n\t\t\t\tdisable || disableZ ? 0 : -center.z + dAlign,\n\t\t\t);\n\n\t\t\tuntracked(() => {\n\t\t\t\tthis.centered.emit({\n\t\t\t\t\tparent: group.parent!,\n\t\t\t\t\tcontainer: group,\n\t\t\t\t\twidth,\n\t\t\t\t\theight,\n\t\t\t\t\tdepth,\n\t\t\t\t\tboundingBox: box3,\n\t\t\t\t\tboundingSphere: sphere,\n\t\t\t\t\tcenter,\n\t\t\t\t\tverticalAlignment: vAlign,\n\t\t\t\t\thorizontalAlignment: hAlign,\n\t\t\t\t\tdepthAlignment: dAlign,\n\t\t\t\t});\n\t\t\t});\n\t\t});\n\t}\n}\n"]}
@@ -163,8 +163,8 @@ export class NgtsContactShadows {
163
163
  renderTarget.texture.generateMipmaps = false;
164
164
  return renderTarget;
165
165
  }
166
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: NgtsContactShadows, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
167
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "18.2.0", type: NgtsContactShadows, isStandalone: true, selector: "ngts-contact-shadows", inputs: { options: { classPropertyName: "options", publicName: "options", isSignal: true, isRequired: false, transformFunction: null } }, viewQueries: [{ propertyName: "contactShadowsRef", first: true, predicate: ["contactShadows"], descendants: true, isSignal: true }, { propertyName: "shadowsCameraRef", first: true, predicate: ["shadowsCamera"], descendants: true, isSignal: true }], ngImport: i0, template: `
166
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.4", ngImport: i0, type: NgtsContactShadows, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
167
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "18.2.4", type: NgtsContactShadows, isStandalone: true, selector: "ngts-contact-shadows", inputs: { options: { classPropertyName: "options", publicName: "options", isSignal: true, isRequired: false, transformFunction: null } }, viewQueries: [{ propertyName: "contactShadowsRef", first: true, predicate: ["contactShadows"], descendants: true, isSignal: true }, { propertyName: "shadowsCameraRef", first: true, predicate: ["shadowsCamera"], descendants: true, isSignal: true }], ngImport: i0, template: `
168
168
  <ngt-group #contactShadows [rotation]="[Math.PI / 2, 0, 0]" [parameters]="parameters()">
169
169
  <ngt-mesh
170
170
  [scale]="[1, -1, 1]"
@@ -183,7 +183,7 @@ export class NgtsContactShadows {
183
183
  </ngt-group>
184
184
  `, isInline: true, dependencies: [{ kind: "directive", type: NgtArgs, selector: "ng-template[args]", inputs: ["args"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
185
185
  }
186
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: NgtsContactShadows, decorators: [{
186
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.4", ngImport: i0, type: NgtsContactShadows, decorators: [{
187
187
  type: Component,
188
188
  args: [{
189
189
  selector: 'ngts-contact-shadows',