angular-three-soba 1.10.0 → 1.11.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 (77) hide show
  1. package/abstractions/index.d.ts +1 -0
  2. package/abstractions/lib/edges/edges.d.ts +18 -0
  3. package/cameras/index.d.ts +1 -0
  4. package/cameras/lib/camera/camera-content.d.ts +1 -1
  5. package/cameras/lib/cube-camera/cube-camera.d.ts +27 -0
  6. package/esm2020/abstractions/index.mjs +2 -1
  7. package/esm2020/abstractions/lib/edges/edges.mjs +95 -0
  8. package/esm2020/abstractions/lib/gizmo-helper/gizmo-helper.mjs +8 -3
  9. package/esm2020/abstractions/lib/text-3d/text-3d.mjs +1 -1
  10. package/esm2020/cameras/index.mjs +2 -1
  11. package/esm2020/cameras/lib/camera/camera-content.mjs +1 -1
  12. package/esm2020/cameras/lib/cube-camera/cube-camera.mjs +130 -0
  13. package/esm2020/materials/index.mjs +3 -1
  14. package/esm2020/materials/lib/mesh-refraction-material/mesh-refraction-material.mjs +157 -0
  15. package/esm2020/materials/lib/mesh-transmission-material/mesh-transmission-material.mjs +237 -0
  16. package/esm2020/misc/lib/fbo/fbo.mjs +5 -4
  17. package/esm2020/performance/lib/detailed/detailed.mjs +6 -3
  18. package/esm2020/shaders/index.mjs +6 -1
  19. package/esm2020/shaders/lib/caustics-material/caustics-material.mjs +128 -0
  20. package/esm2020/shaders/lib/caustics-projection-material/caustics-projection-material.mjs +33 -0
  21. package/esm2020/shaders/lib/discard-material/discard-material.mjs +3 -0
  22. package/esm2020/shaders/lib/mesh-transmission-material/mesh-transmission-material.mjs +268 -0
  23. package/esm2020/shaders/lib/soft-shadow-material/soft-shadow-material.mjs +33 -0
  24. package/esm2020/staging/index.mjs +2 -1
  25. package/esm2020/staging/lib/accumulative-shadows/accumulative-shadows.mjs +7 -38
  26. package/esm2020/staging/lib/accumulative-shadows/progressive-light-map.mjs +2 -3
  27. package/esm2020/staging/lib/accumulative-shadows/randomized-lights.mjs +6 -6
  28. package/esm2020/staging/lib/caustics/caustics.mjs +363 -0
  29. package/esm2020/staging/lib/center/center.mjs +6 -6
  30. package/fesm2015/angular-three-soba-abstractions.mjs +98 -4
  31. package/fesm2015/angular-three-soba-abstractions.mjs.map +1 -1
  32. package/fesm2015/angular-three-soba-cameras.mjs +127 -4
  33. package/fesm2015/angular-three-soba-cameras.mjs.map +1 -1
  34. package/fesm2015/angular-three-soba-materials.mjs +386 -2
  35. package/fesm2015/angular-three-soba-materials.mjs.map +1 -1
  36. package/fesm2015/angular-three-soba-misc.mjs +4 -3
  37. package/fesm2015/angular-three-soba-misc.mjs.map +1 -1
  38. package/fesm2015/angular-three-soba-performance.mjs +5 -2
  39. package/fesm2015/angular-three-soba-performance.mjs.map +1 -1
  40. package/fesm2015/angular-three-soba-shaders.mjs +485 -31
  41. package/fesm2015/angular-three-soba-shaders.mjs.map +1 -1
  42. package/fesm2015/angular-three-soba-staging.mjs +376 -53
  43. package/fesm2015/angular-three-soba-staging.mjs.map +1 -1
  44. package/fesm2020/angular-three-soba-abstractions.mjs +98 -4
  45. package/fesm2020/angular-three-soba-abstractions.mjs.map +1 -1
  46. package/fesm2020/angular-three-soba-cameras.mjs +127 -4
  47. package/fesm2020/angular-three-soba-cameras.mjs.map +1 -1
  48. package/fesm2020/angular-three-soba-materials.mjs +384 -2
  49. package/fesm2020/angular-three-soba-materials.mjs.map +1 -1
  50. package/fesm2020/angular-three-soba-misc.mjs +4 -3
  51. package/fesm2020/angular-three-soba-misc.mjs.map +1 -1
  52. package/fesm2020/angular-three-soba-performance.mjs +5 -2
  53. package/fesm2020/angular-three-soba-performance.mjs.map +1 -1
  54. package/fesm2020/angular-three-soba-shaders.mjs +491 -34
  55. package/fesm2020/angular-three-soba-shaders.mjs.map +1 -1
  56. package/fesm2020/angular-three-soba-staging.mjs +375 -53
  57. package/fesm2020/angular-three-soba-staging.mjs.map +1 -1
  58. package/materials/index.d.ts +2 -0
  59. package/materials/lib/mesh-refraction-material/mesh-refraction-material.d.ts +28 -0
  60. package/materials/lib/mesh-transmission-material/mesh-transmission-material.d.ts +46 -0
  61. package/misc/lib/fbo/fbo.d.ts +8 -6
  62. package/package.json +3 -4
  63. package/performance/lib/detailed/detailed.d.ts +2 -1
  64. package/plugin/package.json +1 -1
  65. package/shaders/index.d.ts +5 -0
  66. package/shaders/lib/caustics-material/caustics-material.d.ts +4 -0
  67. package/shaders/lib/caustics-projection-material/caustics-projection-material.d.ts +4 -0
  68. package/shaders/lib/discard-material/discard-material.d.ts +3 -0
  69. package/shaders/lib/mesh-transmission-material/mesh-transmission-material.d.ts +25 -0
  70. package/shaders/lib/soft-shadow-material/soft-shadow-material.d.ts +10 -0
  71. package/staging/index.d.ts +1 -0
  72. package/staging/lib/accumulative-shadows/accumulative-shadows.d.ts +2 -8
  73. package/staging/lib/accumulative-shadows/randomized-lights.d.ts +1 -1
  74. package/staging/lib/caustics/caustics.d.ts +47 -0
  75. package/staging/lib/environment/environment-cube.d.ts +1 -1
  76. package/staging/lib/environment/environment-ground.d.ts +1 -1
  77. package/staging/lib/environment/utils.d.ts +1 -1
@@ -1,6 +1,7 @@
1
1
  export * from './lib/billboard/billboard';
2
2
  export * from './lib/catmull-rom-line/catmull-rom-line';
3
3
  export * from './lib/cubic-bezier-line/cubic-bezier-line';
4
+ export * from './lib/edges/edges';
4
5
  export * from './lib/gizmo-helper/gizmo-helper';
5
6
  export * from './lib/gizmo-helper/gizmo-viewcube/gizmo-viewcube';
6
7
  export * from './lib/gizmo-helper/gizmo-viewport/gizmo-viewport';
@@ -0,0 +1,18 @@
1
+ import { OnInit } from '@angular/core';
2
+ import { NgtAnyRecord, NgtRxStore } from 'angular-three';
3
+ import * as THREE from 'three';
4
+ import * as i0 from "@angular/core";
5
+ export declare class NgtsEdges extends NgtRxStore implements OnInit {
6
+ edgesRef: import("angular-three").NgtInjectedRef<THREE.LineSegments<THREE.BufferGeometry, THREE.Material | THREE.Material[]>>;
7
+ set threshold(threshold: number);
8
+ set color(color: THREE.ColorRepresentation);
9
+ set geometry(geometry: THREE.BufferGeometry);
10
+ set userData(userData: NgtAnyRecord);
11
+ withChildren: boolean;
12
+ readonly noop: () => null;
13
+ initialize(): void;
14
+ ngOnInit(): void;
15
+ private setupGeometry;
16
+ static ɵfac: i0.ɵɵFactoryDeclaration<NgtsEdges, never>;
17
+ static ɵcmp: i0.ɵɵComponentDeclaration<NgtsEdges, "ngts-edges", never, { "edgesRef": "edgesRef"; "threshold": "threshold"; "color": "color"; "geometry": "geometry"; "userData": "userData"; "withChildren": "withChildren"; }, {}, never, ["*"], true, never>;
18
+ }
@@ -1,3 +1,4 @@
1
1
  export * from './lib/camera/camera-content';
2
+ export * from './lib/cube-camera/cube-camera';
2
3
  export * from './lib/orthographic-camera/orthographic-camera';
3
4
  export * from './lib/perspective-camera/perspective-camera';
@@ -5,7 +5,7 @@ export declare class NgtsCameraContent {
5
5
  readonly template: TemplateRef<any>;
6
6
  ngtsCameraContent: boolean | '';
7
7
  static ngTemplateContextGuard(_: NgtsCameraContent, ctx: unknown): ctx is {
8
- target: THREE.WebGLRenderTarget;
8
+ fbo: THREE.WebGLRenderTarget;
9
9
  group?: THREE.Group;
10
10
  };
11
11
  static ɵfac: i0.ɵɵFactoryDeclaration<NgtsCameraContent, never>;
@@ -0,0 +1,27 @@
1
+ import { ElementRef } from '@angular/core';
2
+ import { NgtRxStore } from 'angular-three';
3
+ import * as THREE from 'three';
4
+ import { NgtsCameraContent } from '../camera/camera-content';
5
+ import * as i0 from "@angular/core";
6
+ export declare class NgtsCubeCamera extends NgtRxStore {
7
+ groupRef: ElementRef<THREE.Group>;
8
+ cameraContent?: NgtsCameraContent;
9
+ readonly cameraRef: import("angular-three").NgtInjectedRef<THREE.CubeCamera>;
10
+ /** Number of frames to render, Infinity */
11
+ set frames(frames: number);
12
+ /** Resolution of the FBO, 256 */
13
+ set resolution(resolution: number);
14
+ /** Camera near, 0.1 */
15
+ set near(near: number);
16
+ /** Camera far, 1000 */
17
+ set far(far: number);
18
+ /** Custom environment map that is temporarily set as the scenes background */
19
+ set envMap(envMap: THREE.Texture);
20
+ /** Custom fog that is temporarily set as the scenes fog */
21
+ set fog(fog: THREE.Fog | THREE.FogExp2);
22
+ private readonly store;
23
+ initialize(): void;
24
+ constructor();
25
+ static ɵfac: i0.ɵɵFactoryDeclaration<NgtsCubeCamera, never>;
26
+ static ɵcmp: i0.ɵɵComponentDeclaration<NgtsCubeCamera, "ngts-cube-camera", never, { "frames": "frames"; "resolution": "resolution"; "near": "near"; "far": "far"; "envMap": "envMap"; "fog": "fog"; }, {}, ["cameraContent"], never, true, never>;
27
+ }
@@ -1,6 +1,7 @@
1
1
  export * from './lib/billboard/billboard';
2
2
  export * from './lib/catmull-rom-line/catmull-rom-line';
3
3
  export * from './lib/cubic-bezier-line/cubic-bezier-line';
4
+ export * from './lib/edges/edges';
4
5
  export * from './lib/gizmo-helper/gizmo-helper';
5
6
  export * from './lib/gizmo-helper/gizmo-viewcube/gizmo-viewcube';
6
7
  export * from './lib/gizmo-helper/gizmo-viewport/gizmo-viewport';
@@ -8,4 +9,4 @@ export * from './lib/line/line';
8
9
  export * from './lib/quadratic-bezier-line/quadratic-bezier-line';
9
10
  export * from './lib/text-3d/text-3d';
10
11
  export * from './lib/text/text';
11
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXItdGhyZWUtc29iYS9hYnN0cmFjdGlvbnMvc3JjL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsMkJBQTJCLENBQUM7QUFDMUMsY0FBYyx5Q0FBeUMsQ0FBQztBQUN4RCxjQUFjLDJDQUEyQyxDQUFDO0FBQzFELGNBQWMsaUNBQWlDLENBQUM7QUFDaEQsY0FBYyxrREFBa0QsQ0FBQztBQUNqRSxjQUFjLGtEQUFrRCxDQUFDO0FBQ2pFLGNBQWMsaUJBQWlCLENBQUM7QUFDaEMsY0FBYyxtREFBbUQsQ0FBQztBQUNsRSxjQUFjLHVCQUF1QixDQUFDO0FBQ3RDLGNBQWMsaUJBQWlCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2xpYi9iaWxsYm9hcmQvYmlsbGJvYXJkJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NhdG11bGwtcm9tLWxpbmUvY2F0bXVsbC1yb20tbGluZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jdWJpYy1iZXppZXItbGluZS9jdWJpYy1iZXppZXItbGluZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9naXptby1oZWxwZXIvZ2l6bW8taGVscGVyJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2dpem1vLWhlbHBlci9naXptby12aWV3Y3ViZS9naXptby12aWV3Y3ViZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9naXptby1oZWxwZXIvZ2l6bW8tdmlld3BvcnQvZ2l6bW8tdmlld3BvcnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbGluZS9saW5lJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3F1YWRyYXRpYy1iZXppZXItbGluZS9xdWFkcmF0aWMtYmV6aWVyLWxpbmUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdGV4dC0zZC90ZXh0LTNkJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3RleHQvdGV4dCc7XG4iXX0=
12
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXItdGhyZWUtc29iYS9hYnN0cmFjdGlvbnMvc3JjL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsMkJBQTJCLENBQUM7QUFDMUMsY0FBYyx5Q0FBeUMsQ0FBQztBQUN4RCxjQUFjLDJDQUEyQyxDQUFDO0FBQzFELGNBQWMsbUJBQW1CLENBQUM7QUFDbEMsY0FBYyxpQ0FBaUMsQ0FBQztBQUNoRCxjQUFjLGtEQUFrRCxDQUFDO0FBQ2pFLGNBQWMsa0RBQWtELENBQUM7QUFDakUsY0FBYyxpQkFBaUIsQ0FBQztBQUNoQyxjQUFjLG1EQUFtRCxDQUFDO0FBQ2xFLGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYyxpQkFBaUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbGliL2JpbGxib2FyZC9iaWxsYm9hcmQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY2F0bXVsbC1yb20tbGluZS9jYXRtdWxsLXJvbS1saW5lJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2N1YmljLWJlemllci1saW5lL2N1YmljLWJlemllci1saW5lJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2VkZ2VzL2VkZ2VzJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2dpem1vLWhlbHBlci9naXptby1oZWxwZXInO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZ2l6bW8taGVscGVyL2dpem1vLXZpZXdjdWJlL2dpem1vLXZpZXdjdWJlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2dpem1vLWhlbHBlci9naXptby12aWV3cG9ydC9naXptby12aWV3cG9ydCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9saW5lL2xpbmUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvcXVhZHJhdGljLWJlemllci1saW5lL3F1YWRyYXRpYy1iZXppZXItbGluZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi90ZXh0LTNkL3RleHQtM2QnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdGV4dC90ZXh0JztcbiJdfQ==
@@ -0,0 +1,95 @@
1
+ import { NgIf } from '@angular/common';
2
+ import { Component, CUSTOM_ELEMENTS_SCHEMA, Input } from '@angular/core';
3
+ import { extend, injectNgtRef, NgtRxStore } from 'angular-three';
4
+ import * as THREE from 'three';
5
+ import { LineBasicMaterial, LineSegments } from 'three';
6
+ import * as i0 from "@angular/core";
7
+ extend({ LineSegments, LineBasicMaterial });
8
+ export class NgtsEdges extends NgtRxStore {
9
+ constructor() {
10
+ super(...arguments);
11
+ this.edgesRef = injectNgtRef();
12
+ this.withChildren = false;
13
+ this.noop = () => null;
14
+ }
15
+ set threshold(threshold) {
16
+ this.set({ threshold });
17
+ }
18
+ set color(color) {
19
+ this.set({ color });
20
+ }
21
+ set geometry(geometry) {
22
+ this.set({ geometry });
23
+ }
24
+ set userData(userData) {
25
+ this.set({ userData });
26
+ }
27
+ initialize() {
28
+ super.initialize();
29
+ this.set({
30
+ threshold: 15,
31
+ color: 'black',
32
+ userData: {},
33
+ });
34
+ }
35
+ ngOnInit() {
36
+ this.setupGeometry();
37
+ }
38
+ setupGeometry() {
39
+ this.hold(this.edgesRef.$, (segments) => {
40
+ const parent = segments.parent;
41
+ if (parent) {
42
+ const geom = this.get('geometry') || parent.geometry;
43
+ const threshold = this.get('threshold');
44
+ if (geom !== segments.userData['currentGeom'] || threshold !== segments.userData['currentThreshold']) {
45
+ segments.userData['currentGeom'] = geom;
46
+ segments.userData['currentThreshold'] = threshold;
47
+ segments.geometry = new THREE.EdgesGeometry(geom, threshold);
48
+ }
49
+ }
50
+ });
51
+ }
52
+ }
53
+ NgtsEdges.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.0", ngImport: i0, type: NgtsEdges, deps: null, target: i0.ɵɵFactoryTarget.Component });
54
+ NgtsEdges.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.0", type: NgtsEdges, isStandalone: true, selector: "ngts-edges", inputs: { edgesRef: "edgesRef", threshold: "threshold", color: "color", geometry: "geometry", userData: "userData", withChildren: "withChildren" }, usesInheritance: true, ngImport: i0, template: `
55
+ <ngt-line-segments [ref]="edgesRef" [raycast]="noop" ngtCompound>
56
+ <ng-container *ngIf="withChildren; else noChildren">
57
+ <ng-content />
58
+ </ng-container>
59
+ <ng-template #noChildren>
60
+ <ngt-line-basic-material [color]="color" />
61
+ </ng-template>
62
+ </ngt-line-segments>
63
+ `, isInline: true, dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
64
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.0", ngImport: i0, type: NgtsEdges, decorators: [{
65
+ type: Component,
66
+ args: [{
67
+ selector: 'ngts-edges',
68
+ standalone: true,
69
+ template: `
70
+ <ngt-line-segments [ref]="edgesRef" [raycast]="noop" ngtCompound>
71
+ <ng-container *ngIf="withChildren; else noChildren">
72
+ <ng-content />
73
+ </ng-container>
74
+ <ng-template #noChildren>
75
+ <ngt-line-basic-material [color]="color" />
76
+ </ng-template>
77
+ </ngt-line-segments>
78
+ `,
79
+ imports: [NgIf],
80
+ schemas: [CUSTOM_ELEMENTS_SCHEMA],
81
+ }]
82
+ }], propDecorators: { edgesRef: [{
83
+ type: Input
84
+ }], threshold: [{
85
+ type: Input
86
+ }], color: [{
87
+ type: Input
88
+ }], geometry: [{
89
+ type: Input
90
+ }], userData: [{
91
+ type: Input
92
+ }], withChildren: [{
93
+ type: Input
94
+ }] } });
95
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWRnZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXItdGhyZWUtc29iYS9hYnN0cmFjdGlvbnMvc3JjL2xpYi9lZGdlcy9lZGdlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsSUFBSSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDdkMsT0FBTyxFQUFFLFNBQVMsRUFBRSxzQkFBc0IsRUFBRSxLQUFLLEVBQVUsTUFBTSxlQUFlLENBQUM7QUFDakYsT0FBTyxFQUFFLE1BQU0sRUFBRSxZQUFZLEVBQWdCLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMvRSxPQUFPLEtBQUssS0FBSyxNQUFNLE9BQU8sQ0FBQztBQUMvQixPQUFPLEVBQUUsaUJBQWlCLEVBQUUsWUFBWSxFQUFFLE1BQU0sT0FBTyxDQUFDOztBQUV4RCxNQUFNLENBQUMsRUFBRSxZQUFZLEVBQUUsaUJBQWlCLEVBQUUsQ0FBQyxDQUFDO0FBa0I1QyxNQUFNLE9BQU8sU0FBVSxTQUFRLFVBQVU7SUFoQnpDOztRQWlCYSxhQUFRLEdBQUcsWUFBWSxFQUFzQixDQUFDO1FBa0I5QyxpQkFBWSxHQUFHLEtBQUssQ0FBQztRQUVyQixTQUFJLEdBQUcsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDO0tBNkI5QjtJQS9DRyxJQUFhLFNBQVMsQ0FBQyxTQUFpQjtRQUNwQyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsU0FBUyxFQUFFLENBQUMsQ0FBQztJQUM1QixDQUFDO0lBRUQsSUFBYSxLQUFLLENBQUMsS0FBZ0M7UUFDL0MsSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLEtBQUssRUFBRSxDQUFDLENBQUM7SUFDeEIsQ0FBQztJQUVELElBQWEsUUFBUSxDQUFDLFFBQThCO1FBQ2hELElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxRQUFRLEVBQUUsQ0FBQyxDQUFDO0lBQzNCLENBQUM7SUFFRCxJQUFhLFFBQVEsQ0FBQyxRQUFzQjtRQUN4QyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsUUFBUSxFQUFFLENBQUMsQ0FBQztJQUMzQixDQUFDO0lBTVEsVUFBVTtRQUNmLEtBQUssQ0FBQyxVQUFVLEVBQUUsQ0FBQztRQUNuQixJQUFJLENBQUMsR0FBRyxDQUFDO1lBQ0wsU0FBUyxFQUFFLEVBQUU7WUFDYixLQUFLLEVBQUUsT0FBTztZQUNkLFFBQVEsRUFBRSxFQUFFO1NBQ2YsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztJQUVELFFBQVE7UUFDSixJQUFJLENBQUMsYUFBYSxFQUFFLENBQUM7SUFDekIsQ0FBQztJQUVPLGFBQWE7UUFDakIsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUMsRUFBRSxDQUFDLFFBQVEsRUFBRSxFQUFFO1lBQ3BDLE1BQU0sTUFBTSxHQUFHLFFBQVEsQ0FBQyxNQUFvQixDQUFDO1lBQzdDLElBQUksTUFBTSxFQUFFO2dCQUNSLE1BQU0sSUFBSSxHQUFHLElBQUksQ0FBQyxHQUFHLENBQUMsVUFBVSxDQUFDLElBQUksTUFBTSxDQUFDLFFBQVEsQ0FBQztnQkFDckQsTUFBTSxTQUFTLEdBQUcsSUFBSSxDQUFDLEdBQUcsQ0FBQyxXQUFXLENBQUMsQ0FBQztnQkFDeEMsSUFBSSxJQUFJLEtBQUssUUFBUSxDQUFDLFFBQVEsQ0FBQyxhQUFhLENBQUMsSUFBSSxTQUFTLEtBQUssUUFBUSxDQUFDLFFBQVEsQ0FBQyxrQkFBa0IsQ0FBQyxFQUFFO29CQUNsRyxRQUFRLENBQUMsUUFBUSxDQUFDLGFBQWEsQ0FBQyxHQUFHLElBQUksQ0FBQztvQkFDeEMsUUFBUSxDQUFDLFFBQVEsQ0FBQyxrQkFBa0IsQ0FBQyxHQUFHLFNBQVMsQ0FBQztvQkFDbEQsUUFBUSxDQUFDLFFBQVEsR0FBRyxJQUFJLEtBQUssQ0FBQyxhQUFhLENBQUMsSUFBSSxFQUFFLFNBQVMsQ0FBQyxDQUFDO2lCQUNoRTthQUNKO1FBQ0wsQ0FBQyxDQUFDLENBQUM7SUFDUCxDQUFDOztzR0FqRFEsU0FBUzswRkFBVCxTQUFTLGlQQWJSOzs7Ozs7Ozs7S0FTVCw0REFDUyxJQUFJOzJGQUdMLFNBQVM7a0JBaEJyQixTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSxZQUFZO29CQUN0QixVQUFVLEVBQUUsSUFBSTtvQkFDaEIsUUFBUSxFQUFFOzs7Ozs7Ozs7S0FTVDtvQkFDRCxPQUFPLEVBQUUsQ0FBQyxJQUFJLENBQUM7b0JBQ2YsT0FBTyxFQUFFLENBQUMsc0JBQXNCLENBQUM7aUJBQ3BDOzhCQUVZLFFBQVE7c0JBQWhCLEtBQUs7Z0JBRU8sU0FBUztzQkFBckIsS0FBSztnQkFJTyxLQUFLO3NCQUFqQixLQUFLO2dCQUlPLFFBQVE7c0JBQXBCLEtBQUs7Z0JBSU8sUUFBUTtzQkFBcEIsS0FBSztnQkFJRyxZQUFZO3NCQUFwQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdJZiB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBDb21wb25lbnQsIENVU1RPTV9FTEVNRU5UU19TQ0hFTUEsIElucHV0LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IGV4dGVuZCwgaW5qZWN0Tmd0UmVmLCBOZ3RBbnlSZWNvcmQsIE5ndFJ4U3RvcmUgfSBmcm9tICdhbmd1bGFyLXRocmVlJztcbmltcG9ydCAqIGFzIFRIUkVFIGZyb20gJ3RocmVlJztcbmltcG9ydCB7IExpbmVCYXNpY01hdGVyaWFsLCBMaW5lU2VnbWVudHMgfSBmcm9tICd0aHJlZSc7XG5cbmV4dGVuZCh7IExpbmVTZWdtZW50cywgTGluZUJhc2ljTWF0ZXJpYWwgfSk7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnbmd0cy1lZGdlcycsXG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICB0ZW1wbGF0ZTogYFxuICAgICAgICA8bmd0LWxpbmUtc2VnbWVudHMgW3JlZl09XCJlZGdlc1JlZlwiIFtyYXljYXN0XT1cIm5vb3BcIiBuZ3RDb21wb3VuZD5cbiAgICAgICAgICAgIDxuZy1jb250YWluZXIgKm5nSWY9XCJ3aXRoQ2hpbGRyZW47IGVsc2Ugbm9DaGlsZHJlblwiPlxuICAgICAgICAgICAgICAgIDxuZy1jb250ZW50IC8+XG4gICAgICAgICAgICA8L25nLWNvbnRhaW5lcj5cbiAgICAgICAgICAgIDxuZy10ZW1wbGF0ZSAjbm9DaGlsZHJlbj5cbiAgICAgICAgICAgICAgICA8bmd0LWxpbmUtYmFzaWMtbWF0ZXJpYWwgW2NvbG9yXT1cImNvbG9yXCIgLz5cbiAgICAgICAgICAgIDwvbmctdGVtcGxhdGU+XG4gICAgICAgIDwvbmd0LWxpbmUtc2VnbWVudHM+XG4gICAgYCxcbiAgICBpbXBvcnRzOiBbTmdJZl0sXG4gICAgc2NoZW1hczogW0NVU1RPTV9FTEVNRU5UU19TQ0hFTUFdLFxufSlcbmV4cG9ydCBjbGFzcyBOZ3RzRWRnZXMgZXh0ZW5kcyBOZ3RSeFN0b3JlIGltcGxlbWVudHMgT25Jbml0IHtcbiAgICBASW5wdXQoKSBlZGdlc1JlZiA9IGluamVjdE5ndFJlZjxUSFJFRS5MaW5lU2VnbWVudHM+KCk7XG5cbiAgICBASW5wdXQoKSBzZXQgdGhyZXNob2xkKHRocmVzaG9sZDogbnVtYmVyKSB7XG4gICAgICAgIHRoaXMuc2V0KHsgdGhyZXNob2xkIH0pO1xuICAgIH1cblxuICAgIEBJbnB1dCgpIHNldCBjb2xvcihjb2xvcjogVEhSRUUuQ29sb3JSZXByZXNlbnRhdGlvbikge1xuICAgICAgICB0aGlzLnNldCh7IGNvbG9yIH0pO1xuICAgIH1cblxuICAgIEBJbnB1dCgpIHNldCBnZW9tZXRyeShnZW9tZXRyeTogVEhSRUUuQnVmZmVyR2VvbWV0cnkpIHtcbiAgICAgICAgdGhpcy5zZXQoeyBnZW9tZXRyeSB9KTtcbiAgICB9XG5cbiAgICBASW5wdXQoKSBzZXQgdXNlckRhdGEodXNlckRhdGE6IE5ndEFueVJlY29yZCkge1xuICAgICAgICB0aGlzLnNldCh7IHVzZXJEYXRhIH0pO1xuICAgIH1cblxuICAgIEBJbnB1dCgpIHdpdGhDaGlsZHJlbiA9IGZhbHNlO1xuXG4gICAgcmVhZG9ubHkgbm9vcCA9ICgpID0+IG51bGw7XG5cbiAgICBvdmVycmlkZSBpbml0aWFsaXplKCk6IHZvaWQge1xuICAgICAgICBzdXBlci5pbml0aWFsaXplKCk7XG4gICAgICAgIHRoaXMuc2V0KHtcbiAgICAgICAgICAgIHRocmVzaG9sZDogMTUsXG4gICAgICAgICAgICBjb2xvcjogJ2JsYWNrJyxcbiAgICAgICAgICAgIHVzZXJEYXRhOiB7fSxcbiAgICAgICAgfSk7XG4gICAgfVxuXG4gICAgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgICAgIHRoaXMuc2V0dXBHZW9tZXRyeSgpO1xuICAgIH1cblxuICAgIHByaXZhdGUgc2V0dXBHZW9tZXRyeSgpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5ob2xkKHRoaXMuZWRnZXNSZWYuJCwgKHNlZ21lbnRzKSA9PiB7XG4gICAgICAgICAgICBjb25zdCBwYXJlbnQgPSBzZWdtZW50cy5wYXJlbnQgYXMgVEhSRUUuTWVzaDtcbiAgICAgICAgICAgIGlmIChwYXJlbnQpIHtcbiAgICAgICAgICAgICAgICBjb25zdCBnZW9tID0gdGhpcy5nZXQoJ2dlb21ldHJ5JykgfHwgcGFyZW50Lmdlb21ldHJ5O1xuICAgICAgICAgICAgICAgIGNvbnN0IHRocmVzaG9sZCA9IHRoaXMuZ2V0KCd0aHJlc2hvbGQnKTtcbiAgICAgICAgICAgICAgICBpZiAoZ2VvbSAhPT0gc2VnbWVudHMudXNlckRhdGFbJ2N1cnJlbnRHZW9tJ10gfHwgdGhyZXNob2xkICE9PSBzZWdtZW50cy51c2VyRGF0YVsnY3VycmVudFRocmVzaG9sZCddKSB7XG4gICAgICAgICAgICAgICAgICAgIHNlZ21lbnRzLnVzZXJEYXRhWydjdXJyZW50R2VvbSddID0gZ2VvbTtcbiAgICAgICAgICAgICAgICAgICAgc2VnbWVudHMudXNlckRhdGFbJ2N1cnJlbnRUaHJlc2hvbGQnXSA9IHRocmVzaG9sZDtcbiAgICAgICAgICAgICAgICAgICAgc2VnbWVudHMuZ2VvbWV0cnkgPSBuZXcgVEhSRUUuRWRnZXNHZW9tZXRyeShnZW9tLCB0aHJlc2hvbGQpO1xuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH1cbiAgICAgICAgfSk7XG4gICAgfVxufVxuIl19
@@ -1,6 +1,5 @@
1
1
  import { NgTemplateOutlet } from '@angular/common';
2
2
  import { Component, ContentChild, CUSTOM_ELEMENTS_SCHEMA, Directive, EventEmitter, inject, InjectionToken, Input, Output, TemplateRef, } from '@angular/core';
3
- import { selectSlice } from '@rx-angular/state';
4
3
  import { extend, injectNgtRef, NgtPortal, NgtPortalContent, NgtRxStore, NgtStore } from 'angular-three';
5
4
  import { NgtsOrthographicCamera } from 'angular-three-soba/cameras';
6
5
  import { combineLatest, map } from 'rxjs';
@@ -122,7 +121,13 @@ export class NgtsGizmoHelper extends NgtRxStore {
122
121
  }
123
122
  }
124
123
  setGizmoPosition() {
125
- this.connect('gizmoPosition', combineLatest([this.store.select('size'), this.select(selectSlice(['alignment', 'margin']))]).pipe(map(([size, { alignment, margin }]) => {
124
+ this.connect('gizmoPosition', combineLatest([
125
+ this.store.select('size'),
126
+ combineLatest({
127
+ alignment: this.select('alignment'),
128
+ margin: this.select('margin'),
129
+ }),
130
+ ]).pipe(map(([size, { alignment, margin }]) => {
126
131
  const [marginX, marginY] = margin;
127
132
  const x = alignment.endsWith('-center')
128
133
  ? 0
@@ -203,4 +208,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.0", ngImpor
203
208
  type: ContentChild,
204
209
  args: [NgtsGizmoHelperContent, { static: true, read: TemplateRef }]
205
210
  }] } });
206
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gizmo-helper.js","sourceRoot":"","sources":["../../../../../../../libs/angular-three-soba/abstractions/src/lib/gizmo-helper/gizmo-helper.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AACnD,OAAO,EACH,SAAS,EACT,YAAY,EACZ,sBAAsB,EACtB,SAAS,EACT,YAAY,EACZ,MAAM,EACN,cAAc,EACd,KAAK,EAEL,MAAM,EACN,WAAW,GACd,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAChD,OAAO,EAAE,MAAM,EAAE,YAAY,EAAE,SAAS,EAAE,gBAAgB,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AACxG,OAAO,EAAE,sBAAsB,EAAE,MAAM,4BAA4B,CAAC;AACpE,OAAO,EAAE,aAAa,EAAE,GAAG,EAAE,MAAM,MAAM,CAAC;AAC1C,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAsB,UAAU,EAAE,OAAO,EAAE,MAAM,OAAO,CAAC;;AAK1F,MAAM,eAAe,GAAG,CAAC,QAAuB,EAA6B,EAAE;IAC3E,OAAO,eAAe,IAAK,QAA0B,CAAC;AAC1D,CAAC,CAAC;AAMF,MAAM,CAAC,MAAM,qBAAqB,GAAG,IAAI,cAAc,CAAqB,qBAAqB,CAAC,CAAC;AAEnG,SAAS,qBAAqB,CAAC,KAAsB;IACjD,MAAM,KAAK,GAAG,MAAM,CAAC,QAAQ,CAAC,CAAC;IAE/B,OAAO;QACH,WAAW,EAAE,CAAC,SAAkB,EAAE,EAAE;YAChC,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,UAAU,EAAE,GAAG,KAAK,CAAC,GAAG,EAAE,CAAC;YACrD,MAAM,eAAe,GAAG,QAAoC,CAAC;YAE7D,KAAK,CAAC,SAAS,GAAG,IAAI,CAAC;YACvB,IAAI,eAAe;gBAAE,KAAK,CAAC,UAAU,GAAG,eAAe,CAAC,MAAM,CAAC;YAC/D,KAAK,CAAC,MAAM,GAAG,MAAM,CAAC,QAAQ,CAAC,UAAU,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;YACxD,yCAAyC;YACzC,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;YACjC,oCAAoC;YACpC,KAAK,CAAC,cAAc,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;YACpF,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,cAAc,CAAC,CAAC;YACzC,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;YACtC,UAAU,EAAE,CAAC;QACjB,CAAC;KACJ,CAAC;AACN,CAAC;AAED,MAAM,CAAC,EAAE,KAAK,EAAE,CAAC,CAAC;AAMlB,MAAM,OAAO,sBAAsB;;mHAAtB,sBAAsB;uGAAtB,sBAAsB;2FAAtB,sBAAsB;kBAJlC,SAAS;mBAAC;oBACP,QAAQ,EAAE,qCAAqC;oBAC/C,UAAU,EAAE,IAAI;iBACnB;;AA4BD,MAAM,OAAO,eAAgB,SAAQ,UAAU;IAzB/C;;QA0BqB,UAAK,GAAG,MAAM,CAAC,QAAQ,CAAC,CAAC;QAEjC,aAAQ,GAAG,YAAY,EAAS,CAAC;QACjC,qBAAgB,GAAG,YAAY,EAAsB,CAAC;QAE/D,cAAS,GAAG,KAAK,CAAC;QAClB,WAAM,GAAG,CAAC,CAAC;QACX,eAAU,GAAG,IAAI,OAAO,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QAClC,OAAE,GAAG,IAAI,UAAU,EAAE,CAAC;QACtB,OAAE,GAAG,IAAI,UAAU,EAAE,CAAC;QAEtB,WAAM,GAAG,IAAI,OAAO,EAAE,CAAC;QACvB,mBAAc,GAAG,IAAI,OAAO,EAAE,CAAC;QAC/B,UAAK,GAAG,IAAI,QAAQ,EAAE,CAAC;QAEf,cAAS,GAAG,IAAI,OAAO,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QACjC,aAAQ,GAAG,CAAC,GAAG,IAAI,CAAC,EAAE,CAAC,CAAC,8BAA8B;QACtD,WAAM,GAAG,IAAI,OAAO,EAAE,CAAC;QA6BrB,YAAO,GAAG,IAAI,YAAY,EAAQ,CAAC;KAkFhD;IA7GG,IAAa,SAAS,CAClB,SASkB;QAElB,IAAI,CAAC,GAAG,CAAC,EAAE,SAAS,EAAE,CAAC,CAAC;IAC5B,CAAC;IAED,IAAa,MAAM,CAAC,MAAwB;QACxC,IAAI,CAAC,GAAG,CAAC,EAAE,MAAM,EAAE,CAAC,CAAC;IACzB,CAAC;IAED,IAAa,cAAc,CAAC,cAAsB;QAC9C,IAAI,CAAC,GAAG,CAAC,EAAE,cAAc,EAAE,CAAC,CAAC;IACjC,CAAC;IAED,IAAa,SAAS,CAAC,SAAkB;QACrC,IAAI,CAAC,GAAG,CAAC,EAAE,SAAS,EAAE,CAAC,CAAC;IAC5B,CAAC;IAOQ,UAAU;QACf,KAAK,CAAC,UAAU,EAAE,CAAC;QACnB,IAAI,CAAC,GAAG,CAAC,EAAE,SAAS,EAAE,cAAc,EAAE,MAAM,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,cAAc,EAAE,CAAC,EAAE,CAAC,CAAC;IACjF,CAAC;IAED,QAAQ;QACJ,IAAI,CAAC,eAAe,EAAE,CAAC;QACvB,IAAI,CAAC,gBAAgB,EAAE,CAAC;IAC5B,CAAC;IAED,cAAc,CAAC,KAAa;QACxB,IAAI,IAAI,CAAC,gBAAgB,CAAC,aAAa,IAAI,IAAI,CAAC,QAAQ,CAAC,aAAa,EAAE;YACpE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,UAAU,EAAE,UAAU,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC;YACtE,MAAM,eAAe,GAAG,QAAoC,CAAC;YAC7D,eAAe;YACf,IAAI,IAAI,CAAC,SAAS,EAAE;gBAChB,IAAI,IAAI,CAAC,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,GAAG,IAAI,EAAE;oBACjC,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;oBACvB,mDAAmD;oBACnD,qDAAqD;oBACrD,sDAAsD;oBACtD,IAAI,eAAe,CAAC,eAAe,CAAC,EAAE;wBAClC,UAAU,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;qBACtC;iBACJ;qBAAM;oBACH,MAAM,IAAI,GAAG,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC;oBACnC,qFAAqF;oBACrF,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,IAAI,CAAC,EAAE,EAAE,IAAI,CAAC,CAAC;oBACrC,sBAAsB;oBACtB,UAAU,CAAC,QAAQ;yBACd,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;yBACZ,eAAe,CAAC,IAAI,CAAC,EAAE,CAAC;yBACxB,cAAc,CAAC,IAAI,CAAC,MAAM,CAAC;yBAC3B,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;oBAC1B,UAAU,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,eAAe,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,SAAS,EAAE,CAAC;oBAChE,UAAU,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;oBACpC,IAAI,IAAI,CAAC,OAAO,CAAC,QAAQ;wBAAE,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC;yBAC1C,IAAI,eAAe,EAAE;wBACtB,eAAe,CAAC,MAAM,EAAE,CAAC;qBAC5B;oBACD,UAAU,EAAE,CAAC;iBAChB;aACJ;YAED,0CAA0C;YAC1C,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,MAAM,EAAE,CAAC;YAC7C,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,UAAU,CAAC,qBAAqB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;SAC7E;IACL,CAAC;IAEO,gBAAgB;QACpB,IAAI,CAAC,OAAO,CACR,eAAe,EACf,aAAa,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAC9F,GAAG,CAAC,CAAC,CAAC,IAAI,EAAE,EAAE,SAAS,EAAE,MAAM,EAAE,CAAC,EAAE,EAAE;YAClC,MAAM,CAAC,OAAO,EAAE,OAAO,CAAC,GAAG,MAAM,CAAC;YAClC,MAAM,CAAC,GAAG,SAAS,CAAC,QAAQ,CAAC,SAAS,CAAC;gBACnC,CAAC,CAAC,CAAC;gBACH,CAAC,CAAC,SAAS,CAAC,QAAQ,CAAC,OAAO,CAAC;oBAC7B,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,GAAG,CAAC,GAAG,OAAO;oBAC3B,CAAC,CAAC,IAAI,CAAC,KAAK,GAAG,CAAC,GAAG,OAAO,CAAC;YAC/B,MAAM,CAAC,GAAG,SAAS,CAAC,UAAU,CAAC,SAAS,CAAC;gBACrC,CAAC,CAAC,CAAC;gBACH,CAAC,CAAC,SAAS,CAAC,UAAU,CAAC,MAAM,CAAC;oBAC9B,CAAC,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,GAAG,OAAO;oBAC3B,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,GAAG,OAAO,CAAC;YACjC,OAAO,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QACrB,CAAC,CAAC,CACL,CACJ,CAAC;IACN,CAAC;IAEO,eAAe;QACnB,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,QAAQ,CAAC,EAAE,CAAC,MAAM,EAAE,EAAE;YAC9C,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;QACnC,CAAC,CAAC,CAAC;IACP,CAAC;;4GAhIQ,eAAe;gGAAf,eAAe,iNAHb,CAAC,EAAE,OAAO,EAAE,qBAAqB,EAAE,UAAU,EAAE,qBAAqB,EAAE,IAAI,EAAE,CAAC,eAAe,CAAC,EAAE,CAAC,0EAoD7F,sBAAsB,2BAAwB,WAAW,kEAvE7D;;;;;;;;;;;;;;;;;KAiBT,4DACS,SAAS,sJAAE,gBAAgB,0EAAE,sBAAsB,iHAAE,gBAAgB;2FAItE,eAAe;kBAzB3B,SAAS;mBAAC;oBACP,QAAQ,EAAE,mBAAmB;oBAC7B,UAAU,EAAE,IAAI;oBAChB,QAAQ,EAAE;;;;;;;;;;;;;;;;;KAiBT;oBACD,OAAO,EAAE,CAAC,SAAS,EAAE,gBAAgB,EAAE,sBAAsB,EAAE,gBAAgB,CAAC;oBAChF,SAAS,EAAE,CAAC,EAAE,OAAO,EAAE,qBAAqB,EAAE,UAAU,EAAE,qBAAqB,EAAE,IAAI,EAAE,iBAAiB,EAAE,CAAC;oBAC3G,OAAO,EAAE,CAAC,sBAAsB,CAAC;iBACpC;8BAqBgB,SAAS;sBAArB,KAAK;gBAeO,MAAM;sBAAlB,KAAK;gBAIO,cAAc;sBAA1B,KAAK;gBAIO,SAAS;sBAArB,KAAK;gBAII,OAAO;sBAAhB,MAAM;gBAGP,kBAAkB;sBADjB,YAAY;uBAAC,sBAAsB,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,WAAW,EAAE","sourcesContent":["import { NgTemplateOutlet } from '@angular/common';\nimport {\n    Component,\n    ContentChild,\n    CUSTOM_ELEMENTS_SCHEMA,\n    Directive,\n    EventEmitter,\n    inject,\n    InjectionToken,\n    Input,\n    OnInit,\n    Output,\n    TemplateRef,\n} from '@angular/core';\nimport { selectSlice } from '@rx-angular/state';\nimport { extend, injectNgtRef, NgtPortal, NgtPortalContent, NgtRxStore, NgtStore } from 'angular-three';\nimport { NgtsOrthographicCamera } from 'angular-three-soba/cameras';\nimport { combineLatest, map } from 'rxjs';\nimport { Group, Matrix4, Object3D, OrthographicCamera, Quaternion, Vector3 } from 'three';\nimport { OrbitControls } from 'three-stdlib';\n\ntype ControlsProto = { update(): void; target: THREE.Vector3 };\n\nconst isOrbitControls = (controls: ControlsProto): controls is OrbitControls => {\n    return 'minPolarAngle' in (controls as OrbitControls);\n};\n\nexport interface NgtsGizmoHelperApi {\n    tweenCamera: (direction: Vector3) => void;\n}\n\nexport const NGTS_GIZMO_HELPER_API = new InjectionToken<NgtsGizmoHelperApi>('NgtsGizmoHelper API');\n\nfunction gizmoHelperApiFactory(gizmo: NgtsGizmoHelper) {\n    const store = inject(NgtStore);\n\n    return {\n        tweenCamera: (direction: Vector3) => {\n            const { controls, camera, invalidate } = store.get();\n            const defaultControls = controls as unknown as ControlsProto;\n\n            gizmo.animating = true;\n            if (defaultControls) gizmo.focusPoint = defaultControls.target;\n            gizmo.radius = camera.position.distanceTo(gizmo.target);\n            // rotate from current camera orientation\n            gizmo.q1.copy(camera.quaternion);\n            // to new current camera orientation\n            gizmo.targetPosition.copy(direction).multiplyScalar(gizmo.radius).add(gizmo.target);\n            gizmo.dummy.lookAt(gizmo.targetPosition);\n            gizmo.q2.copy(gizmo.dummy.quaternion);\n            invalidate();\n        },\n    };\n}\n\nextend({ Group });\n\n@Directive({\n    selector: 'ng-template[ngtsGizmoHelperContent]',\n    standalone: true,\n})\nexport class NgtsGizmoHelperContent {}\n\n@Component({\n    selector: 'ngts-gizmo-helper',\n    standalone: true,\n    template: `\n        <ngt-portal [renderPriority]=\"get('renderPriority')\">\n            <ng-template ngtPortalContent>\n                <ngts-orthographic-camera\n                    [cameraRef]=\"virtualCameraRef\"\n                    [makeDefault]=\"true\"\n                    [position]=\"[0, 0, 200]\"\n                />\n                <ngt-group\n                    [ref]=\"gizmoRef\"\n                    [position]=\"get('gizmoPosition')\"\n                    (beforeRender)=\"onBeforeRender($any($event).state.delta)\"\n                >\n                    <ng-container *ngTemplateOutlet=\"gizmoHelperContent\" />\n                </ngt-group>\n            </ng-template>\n        </ngt-portal>\n    `,\n    imports: [NgtPortal, NgtPortalContent, NgtsOrthographicCamera, NgTemplateOutlet],\n    providers: [{ provide: NGTS_GIZMO_HELPER_API, useFactory: gizmoHelperApiFactory, deps: [NgtsGizmoHelper] }],\n    schemas: [CUSTOM_ELEMENTS_SCHEMA],\n})\nexport class NgtsGizmoHelper extends NgtRxStore implements OnInit {\n    private readonly store = inject(NgtStore);\n\n    readonly gizmoRef = injectNgtRef<Group>();\n    readonly virtualCameraRef = injectNgtRef<OrthographicCamera>();\n\n    animating = false;\n    radius = 0;\n    focusPoint = new Vector3(0, 0, 0);\n    q1 = new Quaternion();\n    q2 = new Quaternion();\n\n    target = new Vector3();\n    targetPosition = new Vector3();\n    dummy = new Object3D();\n\n    private defaultUp = new Vector3(0, 0, 0);\n    private turnRate = 2 * Math.PI; // turn rate in angles per sec\n    private matrix = new Matrix4();\n\n    @Input() set alignment(\n        alignment:\n            | 'top-left'\n            | 'top-right'\n            | 'bottom-right'\n            | 'bottom-left'\n            | 'bottom-center'\n            | 'center-right'\n            | 'center-left'\n            | 'center-center'\n            | 'top-center'\n    ) {\n        this.set({ alignment });\n    }\n\n    @Input() set margin(margin: [number, number]) {\n        this.set({ margin });\n    }\n\n    @Input() set renderPriority(renderPriority: number) {\n        this.set({ renderPriority });\n    }\n\n    @Input() set autoClear(autoClear: boolean) {\n        this.set({ autoClear });\n    }\n\n    @Output() updated = new EventEmitter<void>();\n\n    @ContentChild(NgtsGizmoHelperContent, { static: true, read: TemplateRef })\n    gizmoHelperContent!: TemplateRef<unknown>;\n\n    override initialize(): void {\n        super.initialize();\n        this.set({ alignment: 'bottom-right', margin: [80, 80], renderPriority: 1 });\n    }\n\n    ngOnInit() {\n        this.updateDefaultUp();\n        this.setGizmoPosition();\n    }\n\n    onBeforeRender(delta: number) {\n        if (this.virtualCameraRef.nativeElement && this.gizmoRef.nativeElement) {\n            const { controls, camera: mainCamera, invalidate } = this.store.get();\n            const defaultControls = controls as unknown as ControlsProto;\n            // Animate step\n            if (this.animating) {\n                if (this.q1.angleTo(this.q2) < 0.01) {\n                    this.animating = false;\n                    // Orbit controls uses UP vector as the orbit axes,\n                    // so we need to reset it after the animation is done\n                    // moving it around for the controls to work correctly\n                    if (isOrbitControls(defaultControls)) {\n                        mainCamera.up.copy(this.defaultUp);\n                    }\n                } else {\n                    const step = delta * this.turnRate;\n                    // animate position by doing a slerp and then scaling the position on the unit sphere\n                    this.q1.rotateTowards(this.q2, step);\n                    // animate orientation\n                    mainCamera.position\n                        .set(0, 0, 1)\n                        .applyQuaternion(this.q1)\n                        .multiplyScalar(this.radius)\n                        .add(this.focusPoint);\n                    mainCamera.up.set(0, 1, 0).applyQuaternion(this.q1).normalize();\n                    mainCamera.quaternion.copy(this.q1);\n                    if (this.updated.observed) this.updated.emit();\n                    else if (defaultControls) {\n                        defaultControls.update();\n                    }\n                    invalidate();\n                }\n            }\n\n            // Sync Gizmo with main camera orientation\n            this.matrix.copy(mainCamera.matrix).invert();\n            this.gizmoRef.nativeElement.quaternion.setFromRotationMatrix(this.matrix);\n        }\n    }\n\n    private setGizmoPosition() {\n        this.connect(\n            'gizmoPosition',\n            combineLatest([this.store.select('size'), this.select(selectSlice(['alignment', 'margin']))]).pipe(\n                map(([size, { alignment, margin }]) => {\n                    const [marginX, marginY] = margin;\n                    const x = alignment.endsWith('-center')\n                        ? 0\n                        : alignment.endsWith('-left')\n                        ? -size.width / 2 + marginX\n                        : size.width / 2 - marginX;\n                    const y = alignment.startsWith('center-')\n                        ? 0\n                        : alignment.startsWith('top-')\n                        ? size.height / 2 - marginY\n                        : -size.height / 2 + marginY;\n                    return [x, y, 0];\n                })\n            )\n        );\n    }\n\n    private updateDefaultUp() {\n        this.hold(this.store.select('camera'), (camera) => {\n            this.defaultUp.copy(camera.up);\n        });\n    }\n}\n"]}
211
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gizmo-helper.js","sourceRoot":"","sources":["../../../../../../../libs/angular-three-soba/abstractions/src/lib/gizmo-helper/gizmo-helper.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgTemplateOutlet } from '@angular/common';\nimport {\n    Component,\n    ContentChild,\n    CUSTOM_ELEMENTS_SCHEMA,\n    Directive,\n    EventEmitter,\n    inject,\n    InjectionToken,\n    Input,\n    OnInit,\n    Output,\n    TemplateRef,\n} from '@angular/core';\nimport { extend, injectNgtRef, NgtPortal, NgtPortalContent, NgtRxStore, NgtStore } from 'angular-three';\nimport { NgtsOrthographicCamera } from 'angular-three-soba/cameras';\nimport { combineLatest, map } from 'rxjs';\nimport { Group, Matrix4, Object3D, OrthographicCamera, Quaternion, Vector3 } from 'three';\nimport { OrbitControls } from 'three-stdlib';\n\ntype ControlsProto = { update(): void; target: THREE.Vector3 };\n\nconst isOrbitControls = (controls: ControlsProto): controls is OrbitControls => {\n    return 'minPolarAngle' in (controls as OrbitControls);\n};\n\nexport interface NgtsGizmoHelperApi {\n    tweenCamera: (direction: Vector3) => void;\n}\n\nexport const NGTS_GIZMO_HELPER_API = new InjectionToken<NgtsGizmoHelperApi>('NgtsGizmoHelper API');\n\nfunction gizmoHelperApiFactory(gizmo: NgtsGizmoHelper) {\n    const store = inject(NgtStore);\n\n    return {\n        tweenCamera: (direction: Vector3) => {\n            const { controls, camera, invalidate } = store.get();\n            const defaultControls = controls as unknown as ControlsProto;\n\n            gizmo.animating = true;\n            if (defaultControls) gizmo.focusPoint = defaultControls.target;\n            gizmo.radius = camera.position.distanceTo(gizmo.target);\n            // rotate from current camera orientation\n            gizmo.q1.copy(camera.quaternion);\n            // to new current camera orientation\n            gizmo.targetPosition.copy(direction).multiplyScalar(gizmo.radius).add(gizmo.target);\n            gizmo.dummy.lookAt(gizmo.targetPosition);\n            gizmo.q2.copy(gizmo.dummy.quaternion);\n            invalidate();\n        },\n    };\n}\n\nextend({ Group });\n\n@Directive({\n    selector: 'ng-template[ngtsGizmoHelperContent]',\n    standalone: true,\n})\nexport class NgtsGizmoHelperContent {}\n\n@Component({\n    selector: 'ngts-gizmo-helper',\n    standalone: true,\n    template: `\n        <ngt-portal [renderPriority]=\"get('renderPriority')\">\n            <ng-template ngtPortalContent>\n                <ngts-orthographic-camera\n                    [cameraRef]=\"virtualCameraRef\"\n                    [makeDefault]=\"true\"\n                    [position]=\"[0, 0, 200]\"\n                />\n                <ngt-group\n                    [ref]=\"gizmoRef\"\n                    [position]=\"get('gizmoPosition')\"\n                    (beforeRender)=\"onBeforeRender($any($event).state.delta)\"\n                >\n                    <ng-container *ngTemplateOutlet=\"gizmoHelperContent\" />\n                </ngt-group>\n            </ng-template>\n        </ngt-portal>\n    `,\n    imports: [NgtPortal, NgtPortalContent, NgtsOrthographicCamera, NgTemplateOutlet],\n    providers: [{ provide: NGTS_GIZMO_HELPER_API, useFactory: gizmoHelperApiFactory, deps: [NgtsGizmoHelper] }],\n    schemas: [CUSTOM_ELEMENTS_SCHEMA],\n})\nexport class NgtsGizmoHelper extends NgtRxStore implements OnInit {\n    private readonly store = inject(NgtStore);\n\n    readonly gizmoRef = injectNgtRef<Group>();\n    readonly virtualCameraRef = injectNgtRef<OrthographicCamera>();\n\n    animating = false;\n    radius = 0;\n    focusPoint = new Vector3(0, 0, 0);\n    q1 = new Quaternion();\n    q2 = new Quaternion();\n\n    target = new Vector3();\n    targetPosition = new Vector3();\n    dummy = new Object3D();\n\n    private defaultUp = new Vector3(0, 0, 0);\n    private turnRate = 2 * Math.PI; // turn rate in angles per sec\n    private matrix = new Matrix4();\n\n    @Input() set alignment(\n        alignment:\n            | 'top-left'\n            | 'top-right'\n            | 'bottom-right'\n            | 'bottom-left'\n            | 'bottom-center'\n            | 'center-right'\n            | 'center-left'\n            | 'center-center'\n            | 'top-center'\n    ) {\n        this.set({ alignment });\n    }\n\n    @Input() set margin(margin: [number, number]) {\n        this.set({ margin });\n    }\n\n    @Input() set renderPriority(renderPriority: number) {\n        this.set({ renderPriority });\n    }\n\n    @Input() set autoClear(autoClear: boolean) {\n        this.set({ autoClear });\n    }\n\n    @Output() updated = new EventEmitter<void>();\n\n    @ContentChild(NgtsGizmoHelperContent, { static: true, read: TemplateRef })\n    gizmoHelperContent!: TemplateRef<unknown>;\n\n    override initialize(): void {\n        super.initialize();\n        this.set({ alignment: 'bottom-right', margin: [80, 80], renderPriority: 1 });\n    }\n\n    ngOnInit() {\n        this.updateDefaultUp();\n        this.setGizmoPosition();\n    }\n\n    onBeforeRender(delta: number) {\n        if (this.virtualCameraRef.nativeElement && this.gizmoRef.nativeElement) {\n            const { controls, camera: mainCamera, invalidate } = this.store.get();\n            const defaultControls = controls as unknown as ControlsProto;\n            // Animate step\n            if (this.animating) {\n                if (this.q1.angleTo(this.q2) < 0.01) {\n                    this.animating = false;\n                    // Orbit controls uses UP vector as the orbit axes,\n                    // so we need to reset it after the animation is done\n                    // moving it around for the controls to work correctly\n                    if (isOrbitControls(defaultControls)) {\n                        mainCamera.up.copy(this.defaultUp);\n                    }\n                } else {\n                    const step = delta * this.turnRate;\n                    // animate position by doing a slerp and then scaling the position on the unit sphere\n                    this.q1.rotateTowards(this.q2, step);\n                    // animate orientation\n                    mainCamera.position\n                        .set(0, 0, 1)\n                        .applyQuaternion(this.q1)\n                        .multiplyScalar(this.radius)\n                        .add(this.focusPoint);\n                    mainCamera.up.set(0, 1, 0).applyQuaternion(this.q1).normalize();\n                    mainCamera.quaternion.copy(this.q1);\n                    if (this.updated.observed) this.updated.emit();\n                    else if (defaultControls) {\n                        defaultControls.update();\n                    }\n                    invalidate();\n                }\n            }\n\n            // Sync Gizmo with main camera orientation\n            this.matrix.copy(mainCamera.matrix).invert();\n            this.gizmoRef.nativeElement.quaternion.setFromRotationMatrix(this.matrix);\n        }\n    }\n\n    private setGizmoPosition() {\n        this.connect(\n            'gizmoPosition',\n            combineLatest([\n                this.store.select('size'),\n                combineLatest({\n                    alignment: this.select('alignment'),\n                    margin: this.select('margin'),\n                }),\n            ]).pipe(\n                map(([size, { alignment, margin }]) => {\n                    const [marginX, marginY] = margin;\n                    const x = alignment.endsWith('-center')\n                        ? 0\n                        : alignment.endsWith('-left')\n                        ? -size.width / 2 + marginX\n                        : size.width / 2 - marginX;\n                    const y = alignment.startsWith('center-')\n                        ? 0\n                        : alignment.startsWith('top-')\n                        ? size.height / 2 - marginY\n                        : -size.height / 2 + marginY;\n                    return [x, y, 0];\n                })\n            )\n        );\n    }\n\n    private updateDefaultUp() {\n        this.hold(this.store.select('camera'), (camera) => {\n            this.defaultUp.copy(camera.up);\n        });\n    }\n}\n"]}
@@ -141,4 +141,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.0", ngImpor
141
141
  }], letterSpacing: [{
142
142
  type: Input
143
143
  }] } });
144
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"text-3d.js","sourceRoot":"","sources":["../../../../../../../libs/angular-three-soba/abstractions/src/lib/text-3d/text-3d.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, CUSTOM_ELEMENTS_SCHEMA, Input } from '@angular/core';\nimport { extend, NgtArgs, NgtPush, NgtRxStore } from 'angular-three';\nimport { combineLatest, map, of, switchMap } from 'rxjs';\nimport { Mesh } from 'three';\nimport { FontLoader, TextGeometry } from 'three-stdlib';\n\ndeclare type Glyph = {\n    _cachedOutline: string[];\n    ha: number;\n    o: string;\n};\n\ndeclare type FontData = {\n    boundingBox: {\n        yMax: number;\n        yMin: number;\n    };\n    familyName: string;\n    glyphs: {\n        [k: string]: Glyph;\n    };\n    resolution: number;\n    underlineThickness: number;\n};\n\nextend({ Mesh, TextGeometry });\n\n@Component({\n    selector: 'ngts-text-3d[font]',\n    standalone: true,\n    template: `\n        <ngt-mesh ngtCompound>\n            <ngt-text-geometry *args=\"geometryArgs$ | ngtPush : null\" />\n            <ng-content />\n        </ngt-mesh>\n    `,\n    imports: [NgtArgs, NgtPush],\n    schemas: [CUSTOM_ELEMENTS_SCHEMA],\n})\nexport class NgtsText3D extends NgtRxStore {\n    @Input() set font(font: FontData | string) {\n        this.set({ font });\n    }\n\n    @Input() set text(text: string) {\n        this.set({ text });\n    }\n\n    @Input() set bevelEnabled(bevelEnabled: boolean) {\n        this.set({ bevelEnabled });\n    }\n\n    @Input() set bevelOffset(bevelOffset: number) {\n        this.set({ bevelOffset });\n    }\n\n    @Input() set bevelSize(bevelSize: number) {\n        this.set({ bevelSize });\n    }\n\n    @Input() set bevelThickness(bevelThickness: number) {\n        this.set({ bevelThickness });\n    }\n\n    @Input() set curveSegments(curveSegments: number) {\n        this.set({ curveSegments });\n    }\n\n    @Input() set bevelSegments(bevelSegments: number) {\n        this.set({ bevelSegments });\n    }\n\n    @Input() set height(height: number) {\n        this.set({ height });\n    }\n\n    @Input() set size(size: number) {\n        this.set({ size });\n    }\n\n    @Input() set lineHeight(lineHeight: number) {\n        this.set({ lineHeight });\n    }\n\n    @Input() set letterSpacing(letterSpacing: number) {\n        this.set({ letterSpacing });\n    }\n\n    override initialize(): void {\n        super.initialize();\n        this.set({\n            letterSpacing: 0,\n            lineHeight: 1,\n            size: 1,\n            height: 0.2,\n            bevelThickness: 0.1,\n            bevelSize: 0.01,\n            bevelEnabled: false,\n            bevelOffset: 0,\n            bevelSegments: 4,\n            curveSegments: 8,\n        });\n    }\n\n    private readonly font$ = this.select('font').pipe(\n        switchMap((font) => {\n            if (typeof font === 'string') return fetch(font).then((res) => res.json()) as Promise<FontData>;\n            return of(font as FontData);\n        }),\n        map((fontData) => new FontLoader().parse(fontData))\n    );\n\n    readonly geometryArgs$ = combineLatest([\n        this.font$,\n        this.select('text'),\n        this.select('size'),\n        this.select('height'),\n        this.select('bevelThickness'),\n        this.select('bevelSize'),\n        this.select('bevelEnabled'),\n        this.select('bevelSegments'),\n        this.select('bevelOffset'),\n        this.select('curveSegments'),\n        this.select('letterSpacing'),\n        this.select('lineHeight'),\n    ]).pipe(\n        map(\n            ([\n                font,\n                text,\n                size,\n                height,\n                bevelThickness,\n                bevelSize,\n                bevelEnabled,\n                bevelSegments,\n                bevelOffset,\n                curveSegments,\n                letterSpacing,\n                lineHeight,\n            ]) => [\n                text,\n                {\n                    font,\n                    size,\n                    height,\n                    bevelThickness,\n                    bevelSize,\n                    bevelSegments,\n                    bevelEnabled,\n                    bevelOffset,\n                    curveSegments,\n                    letterSpacing,\n                    lineHeight,\n                },\n            ]\n        )\n    );\n}\n"]}
144
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"text-3d.js","sourceRoot":"","sources":["../../../../../../../libs/angular-three-soba/abstractions/src/lib/text-3d/text-3d.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, CUSTOM_ELEMENTS_SCHEMA, Input } from '@angular/core';\nimport { extend, NgtArgs, NgtPush, NgtRxStore } from 'angular-three';\nimport { combineLatest, map, of, switchMap } from 'rxjs';\nimport { Mesh } from 'three';\nimport { FontLoader, TextGeometry } from 'three-stdlib';\n\ndeclare type Glyph = { _cachedOutline: string[]; ha: number; o: string };\n\ndeclare type FontData = {\n    boundingBox: { yMax: number; yMin: number };\n    familyName: string;\n    glyphs: { [k: string]: Glyph };\n    resolution: number;\n    underlineThickness: number;\n};\n\nextend({ Mesh, TextGeometry });\n\n@Component({\n    selector: 'ngts-text-3d[font]',\n    standalone: true,\n    template: `\n        <ngt-mesh ngtCompound>\n            <ngt-text-geometry *args=\"geometryArgs$ | ngtPush : null\" />\n            <ng-content />\n        </ngt-mesh>\n    `,\n    imports: [NgtArgs, NgtPush],\n    schemas: [CUSTOM_ELEMENTS_SCHEMA],\n})\nexport class NgtsText3D extends NgtRxStore {\n    @Input() set font(font: FontData | string) {\n        this.set({ font });\n    }\n\n    @Input() set text(text: string) {\n        this.set({ text });\n    }\n\n    @Input() set bevelEnabled(bevelEnabled: boolean) {\n        this.set({ bevelEnabled });\n    }\n\n    @Input() set bevelOffset(bevelOffset: number) {\n        this.set({ bevelOffset });\n    }\n\n    @Input() set bevelSize(bevelSize: number) {\n        this.set({ bevelSize });\n    }\n\n    @Input() set bevelThickness(bevelThickness: number) {\n        this.set({ bevelThickness });\n    }\n\n    @Input() set curveSegments(curveSegments: number) {\n        this.set({ curveSegments });\n    }\n\n    @Input() set bevelSegments(bevelSegments: number) {\n        this.set({ bevelSegments });\n    }\n\n    @Input() set height(height: number) {\n        this.set({ height });\n    }\n\n    @Input() set size(size: number) {\n        this.set({ size });\n    }\n\n    @Input() set lineHeight(lineHeight: number) {\n        this.set({ lineHeight });\n    }\n\n    @Input() set letterSpacing(letterSpacing: number) {\n        this.set({ letterSpacing });\n    }\n\n    override initialize(): void {\n        super.initialize();\n        this.set({\n            letterSpacing: 0,\n            lineHeight: 1,\n            size: 1,\n            height: 0.2,\n            bevelThickness: 0.1,\n            bevelSize: 0.01,\n            bevelEnabled: false,\n            bevelOffset: 0,\n            bevelSegments: 4,\n            curveSegments: 8,\n        });\n    }\n\n    private readonly font$ = this.select('font').pipe(\n        switchMap((font) => {\n            if (typeof font === 'string') return fetch(font).then((res) => res.json()) as Promise<FontData>;\n            return of(font as FontData);\n        }),\n        map((fontData) => new FontLoader().parse(fontData))\n    );\n\n    readonly geometryArgs$ = combineLatest([\n        this.font$,\n        this.select('text'),\n        this.select('size'),\n        this.select('height'),\n        this.select('bevelThickness'),\n        this.select('bevelSize'),\n        this.select('bevelEnabled'),\n        this.select('bevelSegments'),\n        this.select('bevelOffset'),\n        this.select('curveSegments'),\n        this.select('letterSpacing'),\n        this.select('lineHeight'),\n    ]).pipe(\n        map(\n            ([\n                font,\n                text,\n                size,\n                height,\n                bevelThickness,\n                bevelSize,\n                bevelEnabled,\n                bevelSegments,\n                bevelOffset,\n                curveSegments,\n                letterSpacing,\n                lineHeight,\n            ]) => [\n                text,\n                {\n                    font,\n                    size,\n                    height,\n                    bevelThickness,\n                    bevelSize,\n                    bevelSegments,\n                    bevelEnabled,\n                    bevelOffset,\n                    curveSegments,\n                    letterSpacing,\n                    lineHeight,\n                },\n            ]\n        )\n    );\n}\n"]}
@@ -1,4 +1,5 @@
1
1
  export * from './lib/camera/camera-content';
2
+ export * from './lib/cube-camera/cube-camera';
2
3
  export * from './lib/orthographic-camera/orthographic-camera';
3
4
  export * from './lib/perspective-camera/perspective-camera';
4
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXItdGhyZWUtc29iYS9jYW1lcmFzL3NyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLDZCQUE2QixDQUFDO0FBQzVDLGNBQWMsK0NBQStDLENBQUM7QUFDOUQsY0FBYyw2Q0FBNkMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbGliL2NhbWVyYS9jYW1lcmEtY29udGVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9vcnRob2dyYXBoaWMtY2FtZXJhL29ydGhvZ3JhcGhpYy1jYW1lcmEnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvcGVyc3BlY3RpdmUtY2FtZXJhL3BlcnNwZWN0aXZlLWNhbWVyYSc7XG4iXX0=
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXItdGhyZWUtc29iYS9jYW1lcmFzL3NyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLDZCQUE2QixDQUFDO0FBQzVDLGNBQWMsK0JBQStCLENBQUM7QUFDOUMsY0FBYywrQ0FBK0MsQ0FBQztBQUM5RCxjQUFjLDZDQUE2QyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9saWIvY2FtZXJhL2NhbWVyYS1jb250ZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2N1YmUtY2FtZXJhL2N1YmUtY2FtZXJhJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL29ydGhvZ3JhcGhpYy1jYW1lcmEvb3J0aG9ncmFwaGljLWNhbWVyYSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9wZXJzcGVjdGl2ZS1jYW1lcmEvcGVyc3BlY3RpdmUtY2FtZXJhJztcbiJdfQ==
@@ -17,4 +17,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.0", ngImpor
17
17
  }], propDecorators: { ngtsCameraContent: [{
18
18
  type: Input
19
19
  }] } });
20
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FtZXJhLWNvbnRlbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXItdGhyZWUtc29iYS9jYW1lcmFzL3NyYy9saWIvY2FtZXJhL2NhbWVyYS1jb250ZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxXQUFXLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBSXRFLE1BQU0sT0FBTyxpQkFBaUI7SUFEOUI7UUFFYSxhQUFRLEdBQUcsTUFBTSxDQUFDLFdBQVcsQ0FBQyxDQUFDO1FBQy9CLHNCQUFpQixHQUFpQixFQUFFLENBQUM7S0FRakQ7SUFORyxNQUFNLENBQUMsc0JBQXNCLENBQ3pCLENBQW9CLEVBQ3BCLEdBQVk7UUFFWixPQUFPLElBQUksQ0FBQztJQUNoQixDQUFDOzs4R0FUUSxpQkFBaUI7a0dBQWpCLGlCQUFpQjsyRkFBakIsaUJBQWlCO2tCQUQ3QixTQUFTO21CQUFDLEVBQUUsUUFBUSxFQUFFLGdDQUFnQyxFQUFFLFVBQVUsRUFBRSxJQUFJLEVBQUU7OEJBRzlELGlCQUFpQjtzQkFBekIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgaW5qZWN0LCBJbnB1dCwgVGVtcGxhdGVSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCAqIGFzIFRIUkVFIGZyb20gJ3RocmVlJztcblxuQERpcmVjdGl2ZSh7IHNlbGVjdG9yOiAnbmctdGVtcGxhdGVbbmd0c0NhbWVyYUNvbnRlbnRdJywgc3RhbmRhbG9uZTogdHJ1ZSB9KVxuZXhwb3J0IGNsYXNzIE5ndHNDYW1lcmFDb250ZW50IHtcbiAgICByZWFkb25seSB0ZW1wbGF0ZSA9IGluamVjdChUZW1wbGF0ZVJlZik7XG4gICAgQElucHV0KCkgbmd0c0NhbWVyYUNvbnRlbnQ6IGJvb2xlYW4gfCAnJyA9ICcnO1xuXG4gICAgc3RhdGljIG5nVGVtcGxhdGVDb250ZXh0R3VhcmQoXG4gICAgICAgIF86IE5ndHNDYW1lcmFDb250ZW50LFxuICAgICAgICBjdHg6IHVua25vd25cbiAgICApOiBjdHggaXMgeyB0YXJnZXQ6IFRIUkVFLldlYkdMUmVuZGVyVGFyZ2V0OyBncm91cD86IFRIUkVFLkdyb3VwIH0ge1xuICAgICAgICByZXR1cm4gdHJ1ZTtcbiAgICB9XG59XG4iXX0=
20
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FtZXJhLWNvbnRlbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXItdGhyZWUtc29iYS9jYW1lcmFzL3NyYy9saWIvY2FtZXJhL2NhbWVyYS1jb250ZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxXQUFXLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBSXRFLE1BQU0sT0FBTyxpQkFBaUI7SUFEOUI7UUFFYSxhQUFRLEdBQUcsTUFBTSxDQUFDLFdBQVcsQ0FBQyxDQUFDO1FBQy9CLHNCQUFpQixHQUFpQixFQUFFLENBQUM7S0FRakQ7SUFORyxNQUFNLENBQUMsc0JBQXNCLENBQ3pCLENBQW9CLEVBQ3BCLEdBQVk7UUFFWixPQUFPLElBQUksQ0FBQztJQUNoQixDQUFDOzs4R0FUUSxpQkFBaUI7a0dBQWpCLGlCQUFpQjsyRkFBakIsaUJBQWlCO2tCQUQ3QixTQUFTO21CQUFDLEVBQUUsUUFBUSxFQUFFLGdDQUFnQyxFQUFFLFVBQVUsRUFBRSxJQUFJLEVBQUU7OEJBRzlELGlCQUFpQjtzQkFBekIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgaW5qZWN0LCBJbnB1dCwgVGVtcGxhdGVSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCAqIGFzIFRIUkVFIGZyb20gJ3RocmVlJztcblxuQERpcmVjdGl2ZSh7IHNlbGVjdG9yOiAnbmctdGVtcGxhdGVbbmd0c0NhbWVyYUNvbnRlbnRdJywgc3RhbmRhbG9uZTogdHJ1ZSB9KVxuZXhwb3J0IGNsYXNzIE5ndHNDYW1lcmFDb250ZW50IHtcbiAgICByZWFkb25seSB0ZW1wbGF0ZSA9IGluamVjdChUZW1wbGF0ZVJlZik7XG4gICAgQElucHV0KCkgbmd0c0NhbWVyYUNvbnRlbnQ6IGJvb2xlYW4gfCAnJyA9ICcnO1xuXG4gICAgc3RhdGljIG5nVGVtcGxhdGVDb250ZXh0R3VhcmQoXG4gICAgICAgIF86IE5ndHNDYW1lcmFDb250ZW50LFxuICAgICAgICBjdHg6IHVua25vd25cbiAgICApOiBjdHggaXMgeyBmYm86IFRIUkVFLldlYkdMUmVuZGVyVGFyZ2V0OyBncm91cD86IFRIUkVFLkdyb3VwIH0ge1xuICAgICAgICByZXR1cm4gdHJ1ZTtcbiAgICB9XG59XG4iXX0=
@@ -0,0 +1,130 @@
1
+ import { NgIf, NgTemplateOutlet } from '@angular/common';
2
+ import { Component, ContentChild, CUSTOM_ELEMENTS_SCHEMA, ElementRef, inject, Input, ViewChild } from '@angular/core';
3
+ import { extend, injectBeforeRender, injectNgtRef, NgtArgs, NgtRxStore, NgtStore } from 'angular-three';
4
+ import { combineLatest, map } from 'rxjs';
5
+ import * as THREE from 'three';
6
+ import { CubeCamera, Group } from 'three';
7
+ import { NgtsCameraContent } from '../camera/camera-content';
8
+ import * as i0 from "@angular/core";
9
+ extend({ Group, CubeCamera });
10
+ export class NgtsCubeCamera extends NgtRxStore {
11
+ /** Number of frames to render, Infinity */
12
+ set frames(frames) {
13
+ this.set({ frames });
14
+ }
15
+ /** Resolution of the FBO, 256 */
16
+ set resolution(resolution) {
17
+ this.set({ resolution });
18
+ }
19
+ /** Camera near, 0.1 */
20
+ set near(near) {
21
+ this.set({ near });
22
+ }
23
+ /** Camera far, 1000 */
24
+ set far(far) {
25
+ this.set({ far });
26
+ }
27
+ /** Custom environment map that is temporarily set as the scenes background */
28
+ set envMap(envMap) {
29
+ this.set({ envMap });
30
+ }
31
+ /** Custom fog that is temporarily set as the scenes fog */
32
+ set fog(fog) {
33
+ this.set({ fog });
34
+ }
35
+ initialize() {
36
+ super.initialize();
37
+ this.set({
38
+ frames: Infinity,
39
+ resolution: 256,
40
+ near: 0.1,
41
+ far: 1000,
42
+ });
43
+ }
44
+ constructor() {
45
+ super();
46
+ this.cameraRef = injectNgtRef();
47
+ this.store = inject(NgtStore);
48
+ this.connect('fbo', this.select('resolution').pipe(map((resolution) => {
49
+ const fbo = new THREE.WebGLCubeRenderTarget(resolution);
50
+ fbo.texture.encoding = this.store.get('gl').outputEncoding;
51
+ fbo.texture.type = THREE.HalfFloatType;
52
+ return fbo;
53
+ })));
54
+ this.connect('cameraArgs', combineLatest([this.select('near'), this.select('far'), this.select('fbo')]));
55
+ let count = 0;
56
+ let originalFog;
57
+ let originalBackground;
58
+ injectBeforeRender(({ scene, gl }) => {
59
+ const { frames, envMap, fog } = this.get();
60
+ if (envMap &&
61
+ this.cameraRef.nativeElement &&
62
+ this.groupRef.nativeElement &&
63
+ (frames === Infinity || count < frames)) {
64
+ this.groupRef.nativeElement.visible = false;
65
+ originalFog = scene.fog;
66
+ originalBackground = scene.background;
67
+ scene.background = envMap || originalBackground;
68
+ scene.fog = fog || originalFog;
69
+ this.cameraRef.nativeElement.update(gl, scene);
70
+ scene.fog = originalFog;
71
+ scene.background = originalBackground;
72
+ this.groupRef.nativeElement.visible = true;
73
+ count++;
74
+ }
75
+ });
76
+ }
77
+ }
78
+ NgtsCubeCamera.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.0", ngImport: i0, type: NgtsCubeCamera, deps: [], target: i0.ɵɵFactoryTarget.Component });
79
+ NgtsCubeCamera.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.0", type: NgtsCubeCamera, isStandalone: true, selector: "ngts-cube-camera", inputs: { frames: "frames", resolution: "resolution", near: "near", far: "far", envMap: "envMap", fog: "fog" }, queries: [{ propertyName: "cameraContent", first: true, predicate: NgtsCameraContent, descendants: true }], viewQueries: [{ propertyName: "groupRef", first: true, predicate: ["group"], descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: `
80
+ <ngt-group ngtCompound>
81
+ <ngt-cube-camera [ref]="cameraRef" *args="get('cameraArgs')" />
82
+ <ngt-group #group>
83
+ <ng-container
84
+ *ngIf="cameraContent && cameraContent.ngtsCameraContent && get('fbo')"
85
+ [ngTemplateOutlet]="cameraContent.template"
86
+ [ngTemplateOutletContext]="{ fbo: get('fbo').texture, group }"
87
+ />
88
+ </ngt-group>
89
+ </ngt-group>
90
+ `, isInline: true, dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: NgtArgs, selector: "[args]", inputs: ["args"] }] });
91
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.0", ngImport: i0, type: NgtsCubeCamera, decorators: [{
92
+ type: Component,
93
+ args: [{
94
+ selector: 'ngts-cube-camera',
95
+ standalone: true,
96
+ template: `
97
+ <ngt-group ngtCompound>
98
+ <ngt-cube-camera [ref]="cameraRef" *args="get('cameraArgs')" />
99
+ <ngt-group #group>
100
+ <ng-container
101
+ *ngIf="cameraContent && cameraContent.ngtsCameraContent && get('fbo')"
102
+ [ngTemplateOutlet]="cameraContent.template"
103
+ [ngTemplateOutletContext]="{ fbo: get('fbo').texture, group }"
104
+ />
105
+ </ngt-group>
106
+ </ngt-group>
107
+ `,
108
+ imports: [NgIf, NgTemplateOutlet, NgtArgs],
109
+ schemas: [CUSTOM_ELEMENTS_SCHEMA],
110
+ }]
111
+ }], ctorParameters: function () { return []; }, propDecorators: { groupRef: [{
112
+ type: ViewChild,
113
+ args: ['group', { static: true }]
114
+ }], cameraContent: [{
115
+ type: ContentChild,
116
+ args: [NgtsCameraContent]
117
+ }], frames: [{
118
+ type: Input
119
+ }], resolution: [{
120
+ type: Input
121
+ }], near: [{
122
+ type: Input
123
+ }], far: [{
124
+ type: Input
125
+ }], envMap: [{
126
+ type: Input
127
+ }], fog: [{
128
+ type: Input
129
+ }] } });
130
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cube-camera.js","sourceRoot":"","sources":["../../../../../../../libs/angular-three-soba/cameras/src/lib/cube-camera/cube-camera.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgIf, NgTemplateOutlet } from '@angular/common';\nimport { Component, ContentChild, CUSTOM_ELEMENTS_SCHEMA, ElementRef, inject, Input, ViewChild } from '@angular/core';\nimport { extend, injectBeforeRender, injectNgtRef, NgtArgs, NgtRxStore, NgtStore } from 'angular-three';\nimport { combineLatest, map } from 'rxjs';\nimport * as THREE from 'three';\nimport { CubeCamera, Group } from 'three';\nimport { NgtsCameraContent } from '../camera/camera-content';\n\nextend({ Group, CubeCamera });\n\n@Component({\n    selector: 'ngts-cube-camera',\n    standalone: true,\n    template: `\n        <ngt-group ngtCompound>\n            <ngt-cube-camera [ref]=\"cameraRef\" *args=\"get('cameraArgs')\" />\n            <ngt-group #group>\n                <ng-container\n                    *ngIf=\"cameraContent && cameraContent.ngtsCameraContent && get('fbo')\"\n                    [ngTemplateOutlet]=\"cameraContent.template\"\n                    [ngTemplateOutletContext]=\"{ fbo: get('fbo').texture, group }\"\n                />\n            </ngt-group>\n        </ngt-group>\n    `,\n    imports: [NgIf, NgTemplateOutlet, NgtArgs],\n    schemas: [CUSTOM_ELEMENTS_SCHEMA],\n})\nexport class NgtsCubeCamera extends NgtRxStore {\n    @ViewChild('group', { static: true }) groupRef!: ElementRef<THREE.Group>;\n    @ContentChild(NgtsCameraContent) cameraContent?: NgtsCameraContent;\n\n    readonly cameraRef = injectNgtRef<THREE.CubeCamera>();\n\n    /** Number of frames to render, Infinity */\n    @Input() set frames(frames: number) {\n        this.set({ frames });\n    }\n    /** Resolution of the FBO, 256 */\n    @Input() set resolution(resolution: number) {\n        this.set({ resolution });\n    }\n    /** Camera near, 0.1 */\n    @Input() set near(near: number) {\n        this.set({ near });\n    }\n    /** Camera far, 1000 */\n    @Input() set far(far: number) {\n        this.set({ far });\n    }\n    /** Custom environment map that is temporarily set as the scenes background */\n    @Input() set envMap(envMap: THREE.Texture) {\n        this.set({ envMap });\n    }\n    /** Custom fog that is temporarily set as the scenes fog */\n    @Input() set fog(fog: THREE.Fog | THREE.FogExp2) {\n        this.set({ fog });\n    }\n\n    private readonly store = inject(NgtStore);\n\n    override initialize(): void {\n        super.initialize();\n        this.set({\n            frames: Infinity,\n            resolution: 256,\n            near: 0.1,\n            far: 1000,\n        });\n    }\n\n    constructor() {\n        super();\n        this.connect(\n            'fbo',\n            this.select('resolution').pipe(\n                map((resolution) => {\n                    const fbo = new THREE.WebGLCubeRenderTarget(resolution);\n                    fbo.texture.encoding = this.store.get('gl').outputEncoding;\n                    fbo.texture.type = THREE.HalfFloatType;\n                    return fbo;\n                })\n            )\n        );\n        this.connect('cameraArgs', combineLatest([this.select('near'), this.select('far'), this.select('fbo')]));\n\n        let count = 0;\n        let originalFog: THREE.Scene['fog'];\n        let originalBackground: THREE.Scene['background'];\n        injectBeforeRender(({ scene, gl }) => {\n            const { frames, envMap, fog } = this.get();\n            if (\n                envMap &&\n                this.cameraRef.nativeElement &&\n                this.groupRef.nativeElement &&\n                (frames === Infinity || count < frames)\n            ) {\n                this.groupRef.nativeElement.visible = false;\n                originalFog = scene.fog;\n                originalBackground = scene.background;\n                scene.background = envMap || originalBackground;\n                scene.fog = fog || originalFog;\n                this.cameraRef.nativeElement.update(gl, scene);\n                scene.fog = originalFog;\n                scene.background = originalBackground;\n                this.groupRef.nativeElement.visible = true;\n                count++;\n            }\n        });\n    }\n}\n"]}
@@ -1,4 +1,6 @@
1
1
  export * from './lib/mesh-distort-material/mesh-distort-material';
2
2
  export * from './lib/mesh-reflector-material/mesh-reflector-material';
3
+ export * from './lib/mesh-refraction-material/mesh-refraction-material';
4
+ export * from './lib/mesh-transmission-material/mesh-transmission-material';
3
5
  export * from './lib/mesh-wobble-material/mesh-wobble-material';
4
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXItdGhyZWUtc29iYS9tYXRlcmlhbHMvc3JjL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsbURBQW1ELENBQUM7QUFDbEUsY0FBYyx1REFBdUQsQ0FBQztBQUN0RSxjQUFjLGlEQUFpRCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9saWIvbWVzaC1kaXN0b3J0LW1hdGVyaWFsL21lc2gtZGlzdG9ydC1tYXRlcmlhbCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9tZXNoLXJlZmxlY3Rvci1tYXRlcmlhbC9tZXNoLXJlZmxlY3Rvci1tYXRlcmlhbCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9tZXNoLXdvYmJsZS1tYXRlcmlhbC9tZXNoLXdvYmJsZS1tYXRlcmlhbCc7XG4iXX0=
6
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXItdGhyZWUtc29iYS9tYXRlcmlhbHMvc3JjL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsbURBQW1ELENBQUM7QUFDbEUsY0FBYyx1REFBdUQsQ0FBQztBQUN0RSxjQUFjLHlEQUF5RCxDQUFDO0FBQ3hFLGNBQWMsNkRBQTZELENBQUM7QUFDNUUsY0FBYyxpREFBaUQsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbGliL21lc2gtZGlzdG9ydC1tYXRlcmlhbC9tZXNoLWRpc3RvcnQtbWF0ZXJpYWwnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbWVzaC1yZWZsZWN0b3ItbWF0ZXJpYWwvbWVzaC1yZWZsZWN0b3ItbWF0ZXJpYWwnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbWVzaC1yZWZyYWN0aW9uLW1hdGVyaWFsL21lc2gtcmVmcmFjdGlvbi1tYXRlcmlhbCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9tZXNoLXRyYW5zbWlzc2lvbi1tYXRlcmlhbC9tZXNoLXRyYW5zbWlzc2lvbi1tYXRlcmlhbCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9tZXNoLXdvYmJsZS1tYXRlcmlhbC9tZXNoLXdvYmJsZS1tYXRlcmlhbCc7XG4iXX0=