angular-three-soba 2.0.0-beta.242 → 2.0.0-beta.244

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 (68) hide show
  1. package/abstractions/lib/text.d.ts +3 -5
  2. package/cameras/lib/camera-content.d.ts +4 -4
  3. package/cameras/lib/orthographic-camera.d.ts +10 -6
  4. package/cameras/lib/perspective-camera.d.ts +6 -6
  5. package/controls/index.d.ts +1 -0
  6. package/controls/lib/camera-controls.d.ts +39 -0
  7. package/controls/lib/orbit-controls.d.ts +4 -6
  8. package/esm2022/abstractions/lib/text.mjs +17 -21
  9. package/esm2022/cameras/lib/camera-content.mjs +6 -6
  10. package/esm2022/cameras/lib/orthographic-camera.mjs +44 -36
  11. package/esm2022/cameras/lib/perspective-camera.mjs +24 -29
  12. package/esm2022/controls/index.mjs +2 -1
  13. package/esm2022/controls/lib/camera-controls.mjs +127 -0
  14. package/esm2022/controls/lib/orbit-controls.mjs +18 -25
  15. package/esm2022/loaders/lib/gltf-loader.mjs +6 -6
  16. package/esm2022/loaders/lib/loader.mjs +3 -3
  17. package/esm2022/loaders/lib/texture-loader.mjs +7 -7
  18. package/esm2022/materials/angular-three-soba-materials.mjs +5 -0
  19. package/esm2022/materials/index.mjs +2 -0
  20. package/esm2022/materials/lib/custom-shader-material.mjs +72 -0
  21. package/esm2022/misc/index.mjs +1 -2
  22. package/esm2022/misc/lib/bake-shadows.mjs +6 -6
  23. package/esm2022/misc/lib/fbo.mjs +6 -6
  24. package/esm2022/staging/index.mjs +3 -1
  25. package/esm2022/staging/lib/accumulative-shadows.mjs +11 -15
  26. package/esm2022/staging/lib/bb-anchor.mjs +10 -14
  27. package/esm2022/staging/lib/camera-shake.mjs +6 -6
  28. package/esm2022/staging/lib/contact-shadows.mjs +12 -14
  29. package/esm2022/staging/lib/environment.mjs +107 -109
  30. package/esm2022/staging/lib/float.mjs +12 -16
  31. package/esm2022/staging/lib/lightformer.mjs +107 -0
  32. package/esm2022/staging/lib/matcap-texture.mjs +6 -6
  33. package/esm2022/staging/lib/normal-texture.mjs +6 -6
  34. package/esm2022/staging/lib/randomized-lights.mjs +6 -6
  35. package/esm2022/staging/lib/render-texture.mjs +213 -0
  36. package/fesm2022/angular-three-soba-abstractions.mjs +16 -20
  37. package/fesm2022/angular-three-soba-abstractions.mjs.map +1 -1
  38. package/fesm2022/angular-three-soba-cameras.mjs +67 -64
  39. package/fesm2022/angular-three-soba-cameras.mjs.map +1 -1
  40. package/fesm2022/angular-three-soba-controls.mjs +142 -26
  41. package/fesm2022/angular-three-soba-controls.mjs.map +1 -1
  42. package/fesm2022/angular-three-soba-loaders.mjs +15 -15
  43. package/fesm2022/angular-three-soba-loaders.mjs.map +1 -1
  44. package/fesm2022/angular-three-soba-materials.mjs +79 -0
  45. package/fesm2022/angular-three-soba-materials.mjs.map +1 -0
  46. package/fesm2022/angular-three-soba-misc.mjs +10 -22
  47. package/fesm2022/angular-three-soba-misc.mjs.map +1 -1
  48. package/fesm2022/angular-three-soba-staging.mjs +476 -180
  49. package/fesm2022/angular-three-soba-staging.mjs.map +1 -1
  50. package/loaders/lib/gltf-loader.d.ts +4 -4
  51. package/loaders/lib/texture-loader.d.ts +4 -4
  52. package/materials/README.md +3 -0
  53. package/materials/index.d.ts +1 -0
  54. package/materials/lib/custom-shader-material.d.ts +19 -0
  55. package/misc/index.d.ts +0 -1
  56. package/package.json +110 -103
  57. package/staging/index.d.ts +2 -0
  58. package/staging/lib/accumulative-shadows.d.ts +3 -4
  59. package/staging/lib/bb-anchor.d.ts +3 -4
  60. package/staging/lib/contact-shadows.d.ts +2 -2
  61. package/staging/lib/environment.d.ts +24 -34
  62. package/staging/lib/float.d.ts +3 -4
  63. package/staging/lib/lightformer.d.ts +334 -0
  64. package/staging/lib/randomized-lights.d.ts +1 -1
  65. package/staging/lib/render-texture.d.ts +64 -0
  66. package/web-types.json +1 -1
  67. package/esm2022/misc/lib/content.mjs +0 -14
  68. package/misc/lib/content.d.ts +0 -8
@@ -1,4 +1,3 @@
1
- import { TemplateRef } from '@angular/core';
2
1
  import { NgtMesh } from 'angular-three';
3
2
  import { ColorRepresentation } from 'three';
4
3
  import * as i0 from "@angular/core";
@@ -37,9 +36,8 @@ export interface NgtsTextOptions extends Partial<NgtMesh> {
37
36
  export declare class NgtsText {
38
37
  text: import("@angular/core").InputSignal<string>;
39
38
  options: import("@angular/core").InputSignalWithTransform<NgtsTextOptions, "" | Partial<NgtsTextOptions>>;
40
- parameters: import("@angular/core").Signal<import("angular-three").Excluded<NgtsTextOptions, ("characters" | "fontSize" | "font" | "anchorX" | "anchorY" | "sdfGlyphSize")[]>>;
39
+ parameters: import("@angular/core").Signal<Omit<NgtsTextOptions, "characters" | "fontSize" | "font" | "anchorX" | "anchorY" | "sdfGlyphSize">>;
41
40
  synced: import("@angular/core").OutputEmitterRef<Text>;
42
- content: import("@angular/core").Signal<TemplateRef<any> | undefined>;
43
41
  private autoEffect;
44
42
  private store;
45
43
  private invalidate;
@@ -49,9 +47,9 @@ export declare class NgtsText {
49
47
  anchorY: import("@angular/core").Signal<number | "top" | "top-baseline" | "middle" | "bottom-baseline" | "bottom">;
50
48
  sdfGlyphSize: import("@angular/core").Signal<number>;
51
49
  fontSize: import("@angular/core").Signal<number>;
52
- troikaMesh: any;
50
+ troikaMesh: import("@angular/core").Signal<any>;
53
51
  args: import("@angular/core").Signal<any[]>;
54
52
  constructor();
55
53
  static ɵfac: i0.ɵɵFactoryDeclaration<NgtsText, never>;
56
- static ɵcmp: i0.ɵɵComponentDeclaration<NgtsText, "ngts-text", never, { "text": { "alias": "text"; "required": true; "isSignal": true; }; "options": { "alias": "options"; "required": false; "isSignal": true; }; }, { "synced": "synced"; }, ["content"], never, true, never>;
54
+ static ɵcmp: i0.ɵɵComponentDeclaration<NgtsText, "ngts-text", never, { "text": { "alias": "text"; "required": true; "isSignal": true; }; "options": { "alias": "options"; "required": false; "isSignal": true; }; }, { "synced": "synced"; }, never, ["*"], true, never>;
57
55
  }
@@ -1,10 +1,10 @@
1
1
  import { Signal } from '@angular/core';
2
2
  import { Texture } from 'three';
3
3
  import * as i0 from "@angular/core";
4
- export declare class NgtsCameraContentWithFboTexture {
5
- static ngTemplateContextGuard(_: NgtsCameraContentWithFboTexture, ctx: unknown): ctx is {
4
+ export declare class NgtsCameraContent {
5
+ static ngTemplateContextGuard(_: NgtsCameraContent, ctx: unknown): ctx is {
6
6
  $implicit: Signal<Texture>;
7
7
  };
8
- static ɵfac: i0.ɵɵFactoryDeclaration<NgtsCameraContentWithFboTexture, never>;
9
- static ɵdir: i0.ɵɵDirectiveDeclaration<NgtsCameraContentWithFboTexture, "ng-template[withTexture]", never, {}, {}, never, never, true, never>;
8
+ static ɵfac: i0.ɵɵFactoryDeclaration<NgtsCameraContent, never>;
9
+ static ɵdir: i0.ɵɵDirectiveDeclaration<NgtsCameraContent, "ng-template[cameraContent]", never, {}, {}, never, never, true, never>;
10
10
  }
@@ -1,4 +1,4 @@
1
- import { TemplateRef } from '@angular/core';
1
+ import { ElementRef, TemplateRef } from '@angular/core';
2
2
  import { NgtOrthographicCamera } from 'angular-three';
3
3
  import { Group, OrthographicCamera, Texture } from 'three';
4
4
  import * as i0 from "@angular/core";
@@ -15,16 +15,20 @@ export interface NgtsOrthographicCameraOptions extends Partial<NgtOrthographicCa
15
15
  envMap?: Texture;
16
16
  }
17
17
  export declare class NgtsOrthographicCamera {
18
- cameraRef: import("@angular/core").InputSignal<import("angular-three").NgtInjectedRef<OrthographicCamera>>;
19
18
  options: import("@angular/core").InputSignalWithTransform<NgtsOrthographicCameraOptions, "" | Partial<NgtsOrthographicCameraOptions>>;
20
- parameters: import("@angular/core").Signal<import("angular-three").Excluded<NgtsOrthographicCameraOptions, ("makeDefault" | "manual" | "frames" | "resolution" | "envMap")[]>>;
19
+ parameters: import("@angular/core").Signal<Omit<NgtsOrthographicCameraOptions, "left" | "right" | "top" | "bottom" | "makeDefault" | "manual" | "frames" | "resolution" | "envMap">>;
21
20
  content: import("@angular/core").Signal<TemplateRef<any> | undefined>;
22
- withTextureContent: import("@angular/core").Signal<TemplateRef<any> | undefined>;
23
- groupRef: import("angular-three").NgtInjectedRef<Group<import("three").Object3DEventMap>>;
21
+ cameraContent: import("@angular/core").Signal<TemplateRef<any> | undefined>;
22
+ cameraRef: import("@angular/core").Signal<ElementRef<OrthographicCamera>>;
23
+ groupRef: import("@angular/core").Signal<ElementRef<Group<import("three").Object3DEventMap>>>;
24
24
  private autoEffect;
25
25
  private store;
26
26
  private camera;
27
27
  size: import("@angular/core").Signal<import("angular-three").NgtSize>;
28
+ left: import("@angular/core").Signal<number>;
29
+ right: import("@angular/core").Signal<number>;
30
+ top: import("@angular/core").Signal<number>;
31
+ bottom: import("@angular/core").Signal<number>;
28
32
  private manual;
29
33
  private makeDefault;
30
34
  private resolution;
@@ -32,5 +36,5 @@ export declare class NgtsOrthographicCamera {
32
36
  texture: import("@angular/core").Signal<Texture>;
33
37
  constructor();
34
38
  static ɵfac: i0.ɵɵFactoryDeclaration<NgtsOrthographicCamera, never>;
35
- static ɵcmp: i0.ɵɵComponentDeclaration<NgtsOrthographicCamera, "ngts-orthographic-camera", never, { "cameraRef": { "alias": "cameraRef"; "required": false; "isSignal": true; }; "options": { "alias": "options"; "required": false; "isSignal": true; }; }, {}, ["content", "withTextureContent"], never, true, never>;
39
+ static ɵcmp: i0.ɵɵComponentDeclaration<NgtsOrthographicCamera, "ngts-orthographic-camera", never, { "options": { "alias": "options"; "required": false; "isSignal": true; }; }, {}, ["content", "cameraContent"], never, true, never>;
36
40
  }
@@ -1,4 +1,4 @@
1
- import { TemplateRef } from '@angular/core';
1
+ import { ElementRef, TemplateRef } from '@angular/core';
2
2
  import { NgtPerspectiveCamera } from 'angular-three';
3
3
  import { Group, PerspectiveCamera, Texture } from 'three';
4
4
  import * as i0 from "@angular/core";
@@ -15,12 +15,12 @@ export interface NgtsPerspectiveCameraOptions extends Partial<NgtPerspectiveCame
15
15
  envMap?: Texture;
16
16
  }
17
17
  export declare class NgtsPerspectiveCamera {
18
- cameraRef: import("@angular/core").InputSignal<import("angular-three").NgtInjectedRef<PerspectiveCamera>>;
19
18
  options: import("@angular/core").InputSignalWithTransform<NgtsPerspectiveCameraOptions, "" | Partial<NgtsPerspectiveCameraOptions>>;
20
- parameters: import("@angular/core").Signal<import("angular-three").Excluded<NgtsPerspectiveCameraOptions, ("makeDefault" | "manual" | "frames" | "resolution" | "envMap")[]>>;
19
+ parameters: import("@angular/core").Signal<Omit<NgtsPerspectiveCameraOptions, "makeDefault" | "manual" | "frames" | "resolution" | "envMap">>;
21
20
  content: import("@angular/core").Signal<TemplateRef<any> | undefined>;
22
- withTextureContent: import("@angular/core").Signal<TemplateRef<any> | undefined>;
23
- groupRef: import("angular-three").NgtInjectedRef<Group<import("three").Object3DEventMap>>;
21
+ cameraContent: import("@angular/core").Signal<TemplateRef<any> | undefined>;
22
+ cameraRef: import("@angular/core").Signal<ElementRef<PerspectiveCamera>>;
23
+ groupRef: import("@angular/core").Signal<ElementRef<Group<import("three").Object3DEventMap>>>;
24
24
  private autoEffect;
25
25
  private store;
26
26
  private camera;
@@ -32,5 +32,5 @@ export declare class NgtsPerspectiveCamera {
32
32
  texture: import("@angular/core").Signal<Texture>;
33
33
  constructor();
34
34
  static ɵfac: i0.ɵɵFactoryDeclaration<NgtsPerspectiveCamera, never>;
35
- static ɵcmp: i0.ɵɵComponentDeclaration<NgtsPerspectiveCamera, "ngts-perspective-camera", never, { "cameraRef": { "alias": "cameraRef"; "required": false; "isSignal": true; }; "options": { "alias": "options"; "required": false; "isSignal": true; }; }, {}, ["content", "withTextureContent"], never, true, never>;
35
+ static ɵcmp: i0.ɵɵComponentDeclaration<NgtsPerspectiveCamera, "ngts-perspective-camera", never, { "options": { "alias": "options"; "required": false; "isSignal": true; }; }, {}, ["content", "cameraContent"], never, true, never>;
36
36
  }
@@ -1 +1,2 @@
1
+ export * from './lib/camera-controls';
1
2
  export * from './lib/orbit-controls';
@@ -0,0 +1,39 @@
1
+ import { NgtCamera } from 'angular-three';
2
+ import CameraControls from 'camera-controls';
3
+ import * as i0 from "@angular/core";
4
+ export interface NgtsCameraControlsOptions {
5
+ camera?: NgtCamera;
6
+ domElement?: HTMLElement;
7
+ makeDefault: boolean;
8
+ events: boolean;
9
+ regress: boolean;
10
+ }
11
+ declare global {
12
+ interface HTMLElementTagNameMap {
13
+ /**
14
+ * @extends camera-controls|CameraControls
15
+ */
16
+ 'ngts-camera-controls': CameraControls & NgtsCameraControlsOptions;
17
+ }
18
+ }
19
+ export declare class NgtsCameraControls {
20
+ options: import("@angular/core").InputSignalWithTransform<Partial<CameraControls> & NgtsCameraControlsOptions, "" | Partial<Partial<CameraControls> & NgtsCameraControlsOptions>>;
21
+ parameters: import("@angular/core").Signal<Omit<Partial<CameraControls> & NgtsCameraControlsOptions, "camera" | "makeDefault" | "regress" | "domElement">>;
22
+ changed: import("@angular/core").OutputEmitterRef<any>;
23
+ started: import("@angular/core").OutputEmitterRef<any>;
24
+ ended: import("@angular/core").OutputEmitterRef<any>;
25
+ private store;
26
+ private invalidate;
27
+ private performanceRegress;
28
+ private defaultCamera;
29
+ private glDomElement;
30
+ private eventsElement;
31
+ private camera;
32
+ private regress;
33
+ private domElement;
34
+ private makeDefault;
35
+ controls: import("@angular/core").Signal<CameraControls>;
36
+ constructor();
37
+ static ɵfac: i0.ɵɵFactoryDeclaration<NgtsCameraControls, never>;
38
+ static ɵcmp: i0.ɵɵComponentDeclaration<NgtsCameraControls, "ngts-camera-controls", never, { "options": { "alias": "options"; "required": false; "isSignal": true; }; }, { "changed": "changed"; "started": "started"; "ended": "ended"; }, never, ["*"], true, never>;
39
+ }
@@ -1,4 +1,4 @@
1
- import { NgtInjectedRef, NgtVector3 } from 'angular-three';
1
+ import { NgtVector3 } from 'angular-three';
2
2
  import { Camera, Event } from 'three';
3
3
  import { OrbitControls } from 'three-stdlib';
4
4
  import * as i0 from "@angular/core";
@@ -21,8 +21,7 @@ declare global {
21
21
  }
22
22
  export declare class NgtsOrbitControls {
23
23
  options: import("@angular/core").InputSignalWithTransform<Partial<OrbitControls> & NgtsOrbitControlsOptions, "" | Partial<Partial<OrbitControls> & NgtsOrbitControlsOptions>>;
24
- parameters: import("@angular/core").Signal<import("angular-three").Excluded<Partial<OrbitControls> & NgtsOrbitControlsOptions, ("domElement" | "enableDamping" | "regress" | "makeDefault" | "keyEvents" | "camera")[]>>;
25
- controlsRef: import("@angular/core").InputSignal<NgtInjectedRef<OrbitControls>>;
24
+ parameters: import("@angular/core").Signal<Omit<Partial<OrbitControls> & NgtsOrbitControlsOptions, "camera" | "makeDefault" | "regress" | "domElement" | "enableDamping" | "keyEvents">>;
26
25
  changed: import("@angular/core").OutputEmitterRef<Event<string, unknown>>;
27
26
  started: import("@angular/core").OutputEmitterRef<Event<string, unknown>>;
28
27
  ended: import("@angular/core").OutputEmitterRef<Event<string, unknown>>;
@@ -36,13 +35,12 @@ export declare class NgtsOrbitControls {
36
35
  private keyEvents;
37
36
  private domElement;
38
37
  private makeDefault;
39
- protected args: import("@angular/core").Signal<OrbitControls[]>;
38
+ controls: import("@angular/core").Signal<OrbitControls>;
40
39
  protected enableDamping: import("@angular/core").Signal<boolean>;
41
40
  constructor();
42
- private setControls;
43
41
  private connectElement;
44
42
  private makeControlsDefault;
45
43
  private setEvents;
46
44
  static ɵfac: i0.ɵɵFactoryDeclaration<NgtsOrbitControls, never>;
47
- static ɵcmp: i0.ɵɵComponentDeclaration<NgtsOrbitControls, "ngts-orbit-controls", never, { "options": { "alias": "options"; "required": false; "isSignal": true; }; "controlsRef": { "alias": "controlsRef"; "required": false; "isSignal": true; }; }, { "changed": "changed"; "started": "started"; "ended": "ended"; }, never, ["*"], true, never>;
45
+ static ɵcmp: i0.ɵɵComponentDeclaration<NgtsOrbitControls, "ngts-orbit-controls", never, { "options": { "alias": "options"; "required": false; "isSignal": true; }; }, { "changed": "changed"; "started": "started"; "ended": "ended"; }, never, ["*"], true, never>;
48
46
  }
@@ -1,7 +1,6 @@
1
1
  import { NgTemplateOutlet } from '@angular/common';
2
- import { CUSTOM_ELEMENTS_SCHEMA, ChangeDetectionStrategy, Component, DestroyRef, TemplateRef, afterNextRender, computed, contentChild, inject, input, output, } from '@angular/core';
3
- import { NgtArgs, exclude, injectNgtStore, pick } from 'angular-three';
4
- import { NgtsContent } from 'angular-three-soba/misc';
2
+ import { CUSTOM_ELEMENTS_SCHEMA, ChangeDetectionStrategy, Component, DestroyRef, afterNextRender, computed, inject, input, output, } from '@angular/core';
3
+ import { NgtArgs, injectStore, omit, pick } from 'angular-three';
5
4
  import { injectAutoEffect } from 'ngxtension/auto-effect';
6
5
  import { mergeInputs } from 'ngxtension/inject-inputs';
7
6
  // @ts-expect-error - no type def
@@ -17,11 +16,10 @@ export class NgtsText {
17
16
  constructor() {
18
17
  this.text = input.required();
19
18
  this.options = input(defaultOptions, { transform: mergeInputs(defaultOptions) });
20
- this.parameters = exclude(this.options, ['font', 'fontSize', 'sdfGlyphSize', 'anchorX', 'anchorY', 'characters']);
19
+ this.parameters = omit(this.options, ['font', 'fontSize', 'sdfGlyphSize', 'anchorX', 'anchorY', 'characters']);
21
20
  this.synced = output();
22
- this.content = contentChild(NgtsContent, { read: TemplateRef });
23
21
  this.autoEffect = injectAutoEffect();
24
- this.store = injectNgtStore();
22
+ this.store = injectStore();
25
23
  this.invalidate = this.store.select('invalidate');
26
24
  this.characters = pick(this.options, 'characters');
27
25
  this.font = pick(this.options, 'font');
@@ -29,12 +27,10 @@ export class NgtsText {
29
27
  this.anchorY = pick(this.options, 'anchorY');
30
28
  this.sdfGlyphSize = pick(this.options, 'sdfGlyphSize');
31
29
  this.fontSize = pick(this.options, 'fontSize');
32
- this.troikaMesh = new Text();
33
- this.args = computed(() => [this.troikaMesh], {
34
- equal: (a, b) => Object.is(a[0], b[0]),
35
- });
30
+ this.troikaMesh = computed(() => new Text(), { equal: Object.is });
31
+ this.args = computed(() => [this.troikaMesh()]);
36
32
  inject(DestroyRef).onDestroy(() => {
37
- this.troikaMesh.dispose();
33
+ this.troikaMesh().dispose();
38
34
  });
39
35
  // NOTE: this could be just effect but autoEffect is used for consistency
40
36
  this.autoEffect(() => {
@@ -45,16 +41,16 @@ export class NgtsText {
45
41
  });
46
42
  afterNextRender(() => {
47
43
  this.autoEffect(() => {
48
- const [invalidate] = [this.invalidate(), this.text(), this.options()];
49
- this.troikaMesh.sync(() => {
44
+ const [invalidate, text] = [this.invalidate(), this.text(), this.options()];
45
+ this.troikaMesh().sync(() => {
50
46
  invalidate();
51
- this.synced.emit(this.troikaMesh);
47
+ this.synced.emit(this.troikaMesh());
52
48
  });
53
49
  });
54
50
  });
55
51
  }
56
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: NgtsText, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
57
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "18.0.3", type: NgtsText, isStandalone: true, selector: "ngts-text", inputs: { text: { classPropertyName: "text", publicName: "text", isSignal: true, isRequired: true, transformFunction: null }, options: { classPropertyName: "options", publicName: "options", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { synced: "synced" }, queries: [{ propertyName: "content", first: true, predicate: NgtsContent, descendants: true, read: TemplateRef, isSignal: true }], ngImport: i0, template: `
52
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: NgtsText, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
53
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.0.6", type: NgtsText, isStandalone: true, selector: "ngts-text", inputs: { text: { classPropertyName: "text", publicName: "text", isSignal: true, isRequired: true, transformFunction: null }, options: { classPropertyName: "options", publicName: "options", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { synced: "synced" }, ngImport: i0, template: `
58
54
  <ngt-primitive
59
55
  *args="args()"
60
56
  [text]="text()"
@@ -65,11 +61,11 @@ export class NgtsText {
65
61
  [fontSize]="fontSize()"
66
62
  [parameters]="parameters()"
67
63
  >
68
- <ng-container [ngTemplateOutlet]="content() ?? null" />
64
+ <ng-content />
69
65
  </ngt-primitive>
70
- `, isInline: true, dependencies: [{ kind: "directive", type: NgtArgs, selector: "ng-template[args]", inputs: ["args"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
66
+ `, isInline: true, dependencies: [{ kind: "directive", type: NgtArgs, selector: "ng-template[args]", inputs: ["args"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
71
67
  }
72
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: NgtsText, decorators: [{
68
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: NgtsText, decorators: [{
73
69
  type: Component,
74
70
  args: [{
75
71
  selector: 'ngts-text',
@@ -85,7 +81,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImpor
85
81
  [fontSize]="fontSize()"
86
82
  [parameters]="parameters()"
87
83
  >
88
- <ng-container [ngTemplateOutlet]="content() ?? null" />
84
+ <ng-content />
89
85
  </ngt-primitive>
90
86
  `,
91
87
  imports: [NgtArgs, NgTemplateOutlet],
@@ -93,4 +89,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImpor
93
89
  changeDetection: ChangeDetectionStrategy.OnPush,
94
90
  }]
95
91
  }], ctorParameters: () => [] });
96
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"text.js","sourceRoot":"","sources":["../../../../../../libs/soba/abstractions/src/lib/text.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgTemplateOutlet } from '@angular/common';\nimport {\n\tCUSTOM_ELEMENTS_SCHEMA,\n\tChangeDetectionStrategy,\n\tComponent,\n\tDestroyRef,\n\tTemplateRef,\n\tafterNextRender,\n\tcomputed,\n\tcontentChild,\n\tinject,\n\tinput,\n\toutput,\n} from '@angular/core';\nimport { NgtArgs, NgtMesh, exclude, injectNgtStore, pick } from 'angular-three';\nimport { NgtsContent } from 'angular-three-soba/misc';\nimport { injectAutoEffect } from 'ngxtension/auto-effect';\nimport { mergeInputs } from 'ngxtension/inject-inputs';\nimport { ColorRepresentation } from 'three';\n// @ts-expect-error - no type def\nimport { Text, preloadFont } from 'troika-three-text';\n\nexport interface NgtsTextOptions extends Partial<NgtMesh> {\n\tcharacters?: string;\n\tcolor?: ColorRepresentation;\n\t/** Font size, default: 1 */\n\tfontSize: number;\n\tfontWeight?: number | string;\n\tfontStyle?: 'italic' | 'normal';\n\tmaxWidth?: number;\n\tlineHeight?: number;\n\tletterSpacing?: number;\n\ttextAlign?: 'left' | 'right' | 'center' | 'justify';\n\tfont?: string;\n\tanchorX: number | 'left' | 'center' | 'right';\n\tanchorY: number | 'top' | 'top-baseline' | 'middle' | 'bottom-baseline' | 'bottom';\n\tclipRect?: [number, number, number, number];\n\tdepthOffset?: number;\n\tdirection?: 'auto' | 'ltr' | 'rtl';\n\toverflowWrap?: 'normal' | 'break-word';\n\twhiteSpace?: 'normal' | 'overflowWrap' | 'nowrap';\n\toutlineWidth?: number | string;\n\toutlineOffsetX?: number | string;\n\toutlineOffsetY?: number | string;\n\toutlineBlur?: number | string;\n\toutlineColor?: ColorRepresentation;\n\toutlineOpacity?: number;\n\tstrokeWidth?: number | string;\n\tstrokeColor?: ColorRepresentation;\n\tstrokeOpacity?: number;\n\tfillOpacity?: number;\n\tsdfGlyphSize: number;\n\tdebugSDF?: boolean;\n}\n\nconst defaultOptions: NgtsTextOptions = {\n\tsdfGlyphSize: 64,\n\tanchorX: 'center',\n\tanchorY: 'middle',\n\tfontSize: 1,\n};\n\n@Component({\n\tselector: 'ngts-text',\n\tstandalone: true,\n\ttemplate: `\n\t\t<ngt-primitive\n\t\t\t*args=\"args()\"\n\t\t\t[text]=\"text()\"\n\t\t\t[font]=\"font()\"\n\t\t\t[anchorX]=\"anchorX()\"\n\t\t\t[anchorY]=\"anchorY()\"\n\t\t\t[sdfGlyphSize]=\"sdfGlyphSize()\"\n\t\t\t[fontSize]=\"fontSize()\"\n\t\t\t[parameters]=\"parameters()\"\n\t\t>\n\t\t\t<ng-container [ngTemplateOutlet]=\"content() ?? null\" />\n\t\t</ngt-primitive>\n\t`,\n\timports: [NgtArgs, NgTemplateOutlet],\n\tschemas: [CUSTOM_ELEMENTS_SCHEMA],\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class NgtsText {\n\ttext = input.required<string>();\n\toptions = input(defaultOptions, { transform: mergeInputs(defaultOptions) });\n\tparameters = exclude(this.options, ['font', 'fontSize', 'sdfGlyphSize', 'anchorX', 'anchorY', 'characters']);\n\n\tsynced = output<Text>();\n\n\tcontent = contentChild(NgtsContent, { read: TemplateRef });\n\n\tprivate autoEffect = injectAutoEffect();\n\tprivate store = injectNgtStore();\n\tprivate invalidate = this.store.select('invalidate');\n\n\tprivate characters = pick(this.options, 'characters');\n\n\tfont = pick(this.options, 'font');\n\tanchorX = pick(this.options, 'anchorX');\n\tanchorY = pick(this.options, 'anchorY');\n\tsdfGlyphSize = pick(this.options, 'sdfGlyphSize');\n\tfontSize = pick(this.options, 'fontSize');\n\n\ttroikaMesh = new Text();\n\targs = computed(() => [this.troikaMesh], {\n\t\tequal: (a, b) => Object.is(a[0], b[0]),\n\t});\n\n\tconstructor() {\n\t\tinject(DestroyRef).onDestroy(() => {\n\t\t\tthis.troikaMesh.dispose();\n\t\t});\n\n\t\t// NOTE: this could be just effect but autoEffect is used for consistency\n\t\tthis.autoEffect(() => {\n\t\t\tconst [font, characters, invalidate] = [this.font(), this.characters(), this.invalidate()];\n\t\t\tif (font) {\n\t\t\t\tpreloadFont({ font, characters }, () => invalidate());\n\t\t\t}\n\t\t});\n\n\t\tafterNextRender(() => {\n\t\t\tthis.autoEffect(() => {\n\t\t\t\tconst [invalidate] = [this.invalidate(), this.text(), this.options()];\n\t\t\t\tthis.troikaMesh.sync(() => {\n\t\t\t\t\tinvalidate();\n\t\t\t\t\tthis.synced.emit(this.troikaMesh);\n\t\t\t\t});\n\t\t\t});\n\t\t});\n\t}\n}\n"]}
92
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"text.js","sourceRoot":"","sources":["../../../../../../libs/soba/abstractions/src/lib/text.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgTemplateOutlet } from '@angular/common';\nimport {\n\tCUSTOM_ELEMENTS_SCHEMA,\n\tChangeDetectionStrategy,\n\tComponent,\n\tDestroyRef,\n\tafterNextRender,\n\tcomputed,\n\tinject,\n\tinput,\n\toutput,\n} from '@angular/core';\nimport { NgtArgs, NgtMesh, injectStore, omit, pick } from 'angular-three';\nimport { injectAutoEffect } from 'ngxtension/auto-effect';\nimport { mergeInputs } from 'ngxtension/inject-inputs';\nimport { ColorRepresentation } from 'three';\n// @ts-expect-error - no type def\nimport { Text, preloadFont } from 'troika-three-text';\n\nexport interface NgtsTextOptions extends Partial<NgtMesh> {\n\tcharacters?: string;\n\tcolor?: ColorRepresentation;\n\t/** Font size, default: 1 */\n\tfontSize: number;\n\tfontWeight?: number | string;\n\tfontStyle?: 'italic' | 'normal';\n\tmaxWidth?: number;\n\tlineHeight?: number;\n\tletterSpacing?: number;\n\ttextAlign?: 'left' | 'right' | 'center' | 'justify';\n\tfont?: string;\n\tanchorX: number | 'left' | 'center' | 'right';\n\tanchorY: number | 'top' | 'top-baseline' | 'middle' | 'bottom-baseline' | 'bottom';\n\tclipRect?: [number, number, number, number];\n\tdepthOffset?: number;\n\tdirection?: 'auto' | 'ltr' | 'rtl';\n\toverflowWrap?: 'normal' | 'break-word';\n\twhiteSpace?: 'normal' | 'overflowWrap' | 'nowrap';\n\toutlineWidth?: number | string;\n\toutlineOffsetX?: number | string;\n\toutlineOffsetY?: number | string;\n\toutlineBlur?: number | string;\n\toutlineColor?: ColorRepresentation;\n\toutlineOpacity?: number;\n\tstrokeWidth?: number | string;\n\tstrokeColor?: ColorRepresentation;\n\tstrokeOpacity?: number;\n\tfillOpacity?: number;\n\tsdfGlyphSize: number;\n\tdebugSDF?: boolean;\n}\n\nconst defaultOptions: NgtsTextOptions = {\n\tsdfGlyphSize: 64,\n\tanchorX: 'center',\n\tanchorY: 'middle',\n\tfontSize: 1,\n};\n\n@Component({\n\tselector: 'ngts-text',\n\tstandalone: true,\n\ttemplate: `\n\t\t<ngt-primitive\n\t\t\t*args=\"args()\"\n\t\t\t[text]=\"text()\"\n\t\t\t[font]=\"font()\"\n\t\t\t[anchorX]=\"anchorX()\"\n\t\t\t[anchorY]=\"anchorY()\"\n\t\t\t[sdfGlyphSize]=\"sdfGlyphSize()\"\n\t\t\t[fontSize]=\"fontSize()\"\n\t\t\t[parameters]=\"parameters()\"\n\t\t>\n\t\t\t<ng-content />\n\t\t</ngt-primitive>\n\t`,\n\timports: [NgtArgs, NgTemplateOutlet],\n\tschemas: [CUSTOM_ELEMENTS_SCHEMA],\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class NgtsText {\n\ttext = input.required<string>();\n\toptions = input(defaultOptions, { transform: mergeInputs(defaultOptions) });\n\tparameters = omit(this.options, ['font', 'fontSize', 'sdfGlyphSize', 'anchorX', 'anchorY', 'characters']);\n\n\tsynced = output<Text>();\n\n\tprivate autoEffect = injectAutoEffect();\n\tprivate store = injectStore();\n\tprivate invalidate = this.store.select('invalidate');\n\n\tprivate characters = pick(this.options, 'characters');\n\n\tfont = pick(this.options, 'font');\n\tanchorX = pick(this.options, 'anchorX');\n\tanchorY = pick(this.options, 'anchorY');\n\tsdfGlyphSize = pick(this.options, 'sdfGlyphSize');\n\tfontSize = pick(this.options, 'fontSize');\n\n\ttroikaMesh = computed(() => new Text(), { equal: Object.is });\n\targs = computed(() => [this.troikaMesh()]);\n\n\tconstructor() {\n\t\tinject(DestroyRef).onDestroy(() => {\n\t\t\tthis.troikaMesh().dispose();\n\t\t});\n\n\t\t// NOTE: this could be just effect but autoEffect is used for consistency\n\t\tthis.autoEffect(() => {\n\t\t\tconst [font, characters, invalidate] = [this.font(), this.characters(), this.invalidate()];\n\t\t\tif (font) {\n\t\t\t\tpreloadFont({ font, characters }, () => invalidate());\n\t\t\t}\n\t\t});\n\n\t\tafterNextRender(() => {\n\t\t\tthis.autoEffect(() => {\n\t\t\t\tconst [invalidate, text] = [this.invalidate(), this.text(), this.options()];\n\t\t\t\tthis.troikaMesh().sync(() => {\n\t\t\t\t\tinvalidate();\n\t\t\t\t\tthis.synced.emit(this.troikaMesh());\n\t\t\t\t});\n\t\t\t});\n\t\t});\n\t}\n}\n"]}
@@ -1,14 +1,14 @@
1
1
  import { Directive } from '@angular/core';
2
2
  import * as i0 from "@angular/core";
3
- export class NgtsCameraContentWithFboTexture {
3
+ export class NgtsCameraContent {
4
4
  static ngTemplateContextGuard(_, ctx) {
5
5
  return true;
6
6
  }
7
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: NgtsCameraContentWithFboTexture, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
8
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.0.3", type: NgtsCameraContentWithFboTexture, isStandalone: true, selector: "ng-template[withTexture]", ngImport: i0 }); }
7
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: NgtsCameraContent, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
8
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.0.6", type: NgtsCameraContent, isStandalone: true, selector: "ng-template[cameraContent]", ngImport: i0 }); }
9
9
  }
10
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: NgtsCameraContentWithFboTexture, decorators: [{
10
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: NgtsCameraContent, decorators: [{
11
11
  type: Directive,
12
- args: [{ standalone: true, selector: 'ng-template[withTexture]' }]
12
+ args: [{ standalone: true, selector: 'ng-template[cameraContent]' }]
13
13
  }] });
14
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FtZXJhLWNvbnRlbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL3NvYmEvY2FtZXJhcy9zcmMvbGliL2NhbWVyYS1jb250ZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQVUsTUFBTSxlQUFlLENBQUM7O0FBSWxELE1BQU0sT0FBTywrQkFBK0I7SUFDM0MsTUFBTSxDQUFDLHNCQUFzQixDQUM1QixDQUFrQyxFQUNsQyxHQUFZO1FBRVosT0FBTyxJQUFJLENBQUM7SUFDYixDQUFDOzhHQU5XLCtCQUErQjtrR0FBL0IsK0JBQStCOzsyRkFBL0IsK0JBQStCO2tCQUQzQyxTQUFTO21CQUFDLEVBQUUsVUFBVSxFQUFFLElBQUksRUFBRSxRQUFRLEVBQUUsMEJBQTBCLEVBQUUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIFNpZ25hbCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgVGV4dHVyZSB9IGZyb20gJ3RocmVlJztcblxuQERpcmVjdGl2ZSh7IHN0YW5kYWxvbmU6IHRydWUsIHNlbGVjdG9yOiAnbmctdGVtcGxhdGVbd2l0aFRleHR1cmVdJyB9KVxuZXhwb3J0IGNsYXNzIE5ndHNDYW1lcmFDb250ZW50V2l0aEZib1RleHR1cmUge1xuXHRzdGF0aWMgbmdUZW1wbGF0ZUNvbnRleHRHdWFyZChcblx0XHRfOiBOZ3RzQ2FtZXJhQ29udGVudFdpdGhGYm9UZXh0dXJlLFxuXHRcdGN0eDogdW5rbm93bixcblx0KTogY3R4IGlzIHsgJGltcGxpY2l0OiBTaWduYWw8VGV4dHVyZT4gfSB7XG5cdFx0cmV0dXJuIHRydWU7XG5cdH1cbn1cbiJdfQ==
14
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FtZXJhLWNvbnRlbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL3NvYmEvY2FtZXJhcy9zcmMvbGliL2NhbWVyYS1jb250ZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQVUsTUFBTSxlQUFlLENBQUM7O0FBSWxELE1BQU0sT0FBTyxpQkFBaUI7SUFDN0IsTUFBTSxDQUFDLHNCQUFzQixDQUFDLENBQW9CLEVBQUUsR0FBWTtRQUMvRCxPQUFPLElBQUksQ0FBQztJQUNiLENBQUM7OEdBSFcsaUJBQWlCO2tHQUFqQixpQkFBaUI7OzJGQUFqQixpQkFBaUI7a0JBRDdCLFNBQVM7bUJBQUMsRUFBRSxVQUFVLEVBQUUsSUFBSSxFQUFFLFFBQVEsRUFBRSw0QkFBNEIsRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgU2lnbmFsIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBUZXh0dXJlIH0gZnJvbSAndGhyZWUnO1xuXG5ARGlyZWN0aXZlKHsgc3RhbmRhbG9uZTogdHJ1ZSwgc2VsZWN0b3I6ICduZy10ZW1wbGF0ZVtjYW1lcmFDb250ZW50XScgfSlcbmV4cG9ydCBjbGFzcyBOZ3RzQ2FtZXJhQ29udGVudCB7XG5cdHN0YXRpYyBuZ1RlbXBsYXRlQ29udGV4dEd1YXJkKF86IE5ndHNDYW1lcmFDb250ZW50LCBjdHg6IHVua25vd24pOiBjdHggaXMgeyAkaW1wbGljaXQ6IFNpZ25hbDxUZXh0dXJlPiB9IHtcblx0XHRyZXR1cm4gdHJ1ZTtcblx0fVxufVxuIl19
@@ -1,11 +1,11 @@
1
1
  import { NgTemplateOutlet } from '@angular/common';
2
- import { CUSTOM_ELEMENTS_SCHEMA, ChangeDetectionStrategy, Component, TemplateRef, afterNextRender, contentChild, input, untracked, } from '@angular/core';
3
- import { exclude, extend, injectBeforeRender, injectNgtRef, injectNgtStore, pick, } from 'angular-three';
4
- import { NgtsContent, injectFBO } from 'angular-three-soba/misc';
2
+ import { CUSTOM_ELEMENTS_SCHEMA, ChangeDetectionStrategy, Component, TemplateRef, afterNextRender, computed, contentChild, input, untracked, viewChild, } from '@angular/core';
3
+ import { extend, injectBeforeRender, injectStore, omit, pick } from 'angular-three';
4
+ import { injectFBO } from 'angular-three-soba/misc';
5
5
  import { injectAutoEffect } from 'ngxtension/auto-effect';
6
6
  import { mergeInputs } from 'ngxtension/inject-inputs';
7
7
  import { Group, OrthographicCamera } from 'three';
8
- import { NgtsCameraContentWithFboTexture } from './camera-content';
8
+ import { NgtsCameraContent } from './camera-content';
9
9
  import * as i0 from "@angular/core";
10
10
  extend({ OrthographicCamera, Group });
11
11
  const defaultOptions = {
@@ -16,16 +16,30 @@ const defaultOptions = {
16
16
  };
17
17
  export class NgtsOrthographicCamera {
18
18
  constructor() {
19
- this.cameraRef = input(injectNgtRef());
20
19
  this.options = input(defaultOptions, { transform: mergeInputs(defaultOptions) });
21
- this.parameters = exclude(this.options, ['envMap', 'makeDefault', 'manual', 'frames', 'resolution']);
22
- this.content = contentChild(NgtsContent, { read: TemplateRef });
23
- this.withTextureContent = contentChild(NgtsCameraContentWithFboTexture, { read: TemplateRef });
24
- this.groupRef = injectNgtRef();
20
+ this.parameters = omit(this.options, [
21
+ 'envMap',
22
+ 'makeDefault',
23
+ 'manual',
24
+ 'frames',
25
+ 'resolution',
26
+ 'left',
27
+ 'top',
28
+ 'bottom',
29
+ 'right',
30
+ ]);
31
+ this.content = contentChild(TemplateRef);
32
+ this.cameraContent = contentChild(NgtsCameraContent, { read: TemplateRef });
33
+ this.cameraRef = viewChild.required('camera');
34
+ this.groupRef = viewChild.required('group');
25
35
  this.autoEffect = injectAutoEffect();
26
- this.store = injectNgtStore();
36
+ this.store = injectStore();
27
37
  this.camera = this.store.select('camera');
28
38
  this.size = this.store.select('size');
39
+ this.left = computed(() => this.options().left ?? this.size().width / -2);
40
+ this.right = computed(() => this.options().right ?? this.size().width / 2);
41
+ this.top = computed(() => this.options().top ?? this.size().height / 2);
42
+ this.bottom = computed(() => this.options().bottom ?? this.size().height / -2);
29
43
  this.manual = pick(this.options, 'manual');
30
44
  this.makeDefault = pick(this.options, 'makeDefault');
31
45
  this.resolution = pick(this.options, 'resolution');
@@ -52,11 +66,11 @@ export class NgtsOrthographicCamera {
52
66
  injectBeforeRender(({ gl, scene }) => {
53
67
  const [{ frames, envMap }, group, camera, fbo] = [
54
68
  this.options(),
55
- this.groupRef.nativeElement,
69
+ this.groupRef().nativeElement,
56
70
  this.cameraRef().nativeElement,
57
71
  this.fbo(),
58
72
  ];
59
- if (this.withTextureContent() && group && camera && fbo && (frames === Infinity || count < frames)) {
73
+ if (this.cameraContent() && group && camera && fbo && (frames === Infinity || count < frames)) {
60
74
  group.visible = false;
61
75
  gl.setRenderTarget(fbo);
62
76
  oldEnvMap = scene.background;
@@ -70,49 +84,43 @@ export class NgtsOrthographicCamera {
70
84
  }
71
85
  });
72
86
  }
73
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: NgtsOrthographicCamera, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
74
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "18.0.3", type: NgtsOrthographicCamera, isStandalone: true, selector: "ngts-orthographic-camera", inputs: { cameraRef: { classPropertyName: "cameraRef", publicName: "cameraRef", isSignal: true, isRequired: false, transformFunction: null }, options: { classPropertyName: "options", publicName: "options", isSignal: true, isRequired: false, transformFunction: null } }, queries: [{ propertyName: "content", first: true, predicate: NgtsContent, descendants: true, read: TemplateRef, isSignal: true }, { propertyName: "withTextureContent", first: true, predicate: NgtsCameraContentWithFboTexture, descendants: true, read: TemplateRef, isSignal: true }], ngImport: i0, template: `
87
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: NgtsOrthographicCamera, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
88
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "18.0.6", type: NgtsOrthographicCamera, isStandalone: true, selector: "ngts-orthographic-camera", inputs: { options: { classPropertyName: "options", publicName: "options", isSignal: true, isRequired: false, transformFunction: null } }, queries: [{ propertyName: "content", first: true, predicate: TemplateRef, descendants: true, isSignal: true }, { propertyName: "cameraContent", first: true, predicate: NgtsCameraContent, descendants: true, read: TemplateRef, isSignal: true }], viewQueries: [{ propertyName: "cameraRef", first: true, predicate: ["camera"], descendants: true, isSignal: true }, { propertyName: "groupRef", first: true, predicate: ["group"], descendants: true, isSignal: true }], ngImport: i0, template: `
75
89
  <ngt-orthographic-camera
76
- [ref]="cameraRef()"
77
- [left]="size().width / -2"
78
- [right]="size().width / 2"
79
- [top]="size().height / 2"
80
- [bottom]="size().height / -2"
90
+ #camera
91
+ [left]="left()"
92
+ [right]="right()"
93
+ [top]="top()"
94
+ [bottom]="bottom()"
81
95
  [parameters]="parameters()"
82
96
  >
83
97
  <ng-container [ngTemplateOutlet]="content() ?? null" />
84
98
  </ngt-orthographic-camera>
85
99
 
86
- <ngt-group [ref]="groupRef">
87
- <ng-container
88
- [ngTemplateOutlet]="withTextureContent() ?? null"
89
- [ngTemplateOutletContext]="{ $implicit: texture }"
90
- />
100
+ <ngt-group #group>
101
+ <ng-container [ngTemplateOutlet]="cameraContent() ?? null" [ngTemplateOutletContext]="{ $implicit: texture }" />
91
102
  </ngt-group>
92
103
  `, isInline: true, dependencies: [{ kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
93
104
  }
94
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: NgtsOrthographicCamera, decorators: [{
105
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: NgtsOrthographicCamera, decorators: [{
95
106
  type: Component,
96
107
  args: [{
97
108
  selector: 'ngts-orthographic-camera',
98
109
  standalone: true,
99
110
  template: `
100
111
  <ngt-orthographic-camera
101
- [ref]="cameraRef()"
102
- [left]="size().width / -2"
103
- [right]="size().width / 2"
104
- [top]="size().height / 2"
105
- [bottom]="size().height / -2"
112
+ #camera
113
+ [left]="left()"
114
+ [right]="right()"
115
+ [top]="top()"
116
+ [bottom]="bottom()"
106
117
  [parameters]="parameters()"
107
118
  >
108
119
  <ng-container [ngTemplateOutlet]="content() ?? null" />
109
120
  </ngt-orthographic-camera>
110
121
 
111
- <ngt-group [ref]="groupRef">
112
- <ng-container
113
- [ngTemplateOutlet]="withTextureContent() ?? null"
114
- [ngTemplateOutletContext]="{ $implicit: texture }"
115
- />
122
+ <ngt-group #group>
123
+ <ng-container [ngTemplateOutlet]="cameraContent() ?? null" [ngTemplateOutletContext]="{ $implicit: texture }" />
116
124
  </ngt-group>
117
125
  `,
118
126
  imports: [NgTemplateOutlet],
@@ -120,4 +128,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImpor
120
128
  schemas: [CUSTOM_ELEMENTS_SCHEMA],
121
129
  }]
122
130
  }], ctorParameters: () => [] });
123
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"orthographic-camera.js","sourceRoot":"","sources":["../../../../../../libs/soba/cameras/src/lib/orthographic-camera.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgTemplateOutlet } from '@angular/common';\nimport {\n\tCUSTOM_ELEMENTS_SCHEMA,\n\tChangeDetectionStrategy,\n\tComponent,\n\tTemplateRef,\n\tafterNextRender,\n\tcontentChild,\n\tinput,\n\tuntracked,\n} from '@angular/core';\nimport {\n\tNgtOrthographicCamera,\n\texclude,\n\textend,\n\tinjectBeforeRender,\n\tinjectNgtRef,\n\tinjectNgtStore,\n\tpick,\n} from 'angular-three';\nimport { NgtsContent, injectFBO } from 'angular-three-soba/misc';\nimport { injectAutoEffect } from 'ngxtension/auto-effect';\nimport { mergeInputs } from 'ngxtension/inject-inputs';\nimport { Color, Group, OrthographicCamera, Texture } from 'three';\nimport { NgtsCameraContentWithFboTexture } from './camera-content';\n\nextend({ OrthographicCamera, Group });\n\nexport interface NgtsOrthographicCameraOptions extends Partial<NgtOrthographicCamera> {\n\t/** Registers the camera as the system default, fiber will start rendering with it */\n\tmakeDefault?: boolean;\n\t/** Making it manual will stop responsiveness and you have to calculate aspect ratio yourself. */\n\tmanual?: boolean;\n\t/** Number of frames to render, Infinity */\n\tframes: number;\n\t/** Resolution of the FBO, 256 */\n\tresolution: number;\n\t/** Optional environment map for functional use */\n\tenvMap?: Texture;\n}\n\nconst defaultOptions: NgtsOrthographicCameraOptions = {\n\tframes: Infinity,\n\tresolution: 256,\n\tmakeDefault: false,\n\tmanual: false,\n};\n\n@Component({\n\tselector: 'ngts-orthographic-camera',\n\tstandalone: true,\n\ttemplate: `\n\t\t<ngt-orthographic-camera\n\t\t\t[ref]=\"cameraRef()\"\n\t\t\t[left]=\"size().width / -2\"\n\t\t\t[right]=\"size().width / 2\"\n\t\t\t[top]=\"size().height / 2\"\n\t\t\t[bottom]=\"size().height / -2\"\n\t\t\t[parameters]=\"parameters()\"\n\t\t>\n\t\t\t<ng-container [ngTemplateOutlet]=\"content() ?? null\" />\n\t\t</ngt-orthographic-camera>\n\n\t\t<ngt-group [ref]=\"groupRef\">\n\t\t\t<ng-container\n\t\t\t\t[ngTemplateOutlet]=\"withTextureContent() ?? null\"\n\t\t\t\t[ngTemplateOutletContext]=\"{ $implicit: texture }\"\n\t\t\t/>\n\t\t</ngt-group>\n\t`,\n\timports: [NgTemplateOutlet],\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\tschemas: [CUSTOM_ELEMENTS_SCHEMA],\n})\nexport class NgtsOrthographicCamera {\n\tcameraRef = input(injectNgtRef<OrthographicCamera>());\n\toptions = input(defaultOptions, { transform: mergeInputs(defaultOptions) });\n\tparameters = exclude(this.options, ['envMap', 'makeDefault', 'manual', 'frames', 'resolution']);\n\n\tcontent = contentChild(NgtsContent, { read: TemplateRef });\n\twithTextureContent = contentChild(NgtsCameraContentWithFboTexture, { read: TemplateRef });\n\n\tgroupRef = injectNgtRef<Group>();\n\n\tprivate autoEffect = injectAutoEffect();\n\tprivate store = injectNgtStore();\n\n\tprivate camera = this.store.select('camera');\n\tsize = this.store.select('size');\n\n\tprivate manual = pick(this.options, 'manual');\n\tprivate makeDefault = pick(this.options, 'makeDefault');\n\tprivate resolution = pick(this.options, 'resolution');\n\tprivate fbo = injectFBO(() => ({ width: this.resolution() }));\n\ttexture = pick(this.fbo, 'texture');\n\n\tconstructor() {\n\t\tafterNextRender(() => {\n\t\t\tthis.autoEffect(() => {\n\t\t\t\tif (!this.manual()) {\n\t\t\t\t\tthis.cameraRef().nativeElement.updateProjectionMatrix();\n\t\t\t\t}\n\t\t\t});\n\n\t\t\tthis.autoEffect(() => {\n\t\t\t\tif (this.makeDefault()) {\n\t\t\t\t\tconst oldCam = untracked(this.camera);\n\t\t\t\t\tthis.store.update({ camera: this.cameraRef().nativeElement });\n\t\t\t\t\treturn () => this.store.update(() => ({ camera: oldCam }));\n\t\t\t\t}\n\t\t\t\treturn;\n\t\t\t});\n\n\t\t\tthis.cameraRef().nativeElement.updateProjectionMatrix();\n\t\t});\n\n\t\tlet count = 0;\n\t\tlet oldEnvMap: Color | Texture | null = null;\n\t\tinjectBeforeRender(({ gl, scene }) => {\n\t\t\tconst [{ frames, envMap }, group, camera, fbo] = [\n\t\t\t\tthis.options(),\n\t\t\t\tthis.groupRef.nativeElement,\n\t\t\t\tthis.cameraRef().nativeElement,\n\t\t\t\tthis.fbo(),\n\t\t\t];\n\t\t\tif (this.withTextureContent() && group && camera && fbo && (frames === Infinity || count < frames)) {\n\t\t\t\tgroup.visible = false;\n\t\t\t\tgl.setRenderTarget(fbo);\n\t\t\t\toldEnvMap = scene.background;\n\t\t\t\tif (envMap) scene.background = envMap;\n\t\t\t\tgl.render(scene, camera);\n\t\t\t\tscene.background = oldEnvMap;\n\t\t\t\tgl.setRenderTarget(null);\n\t\t\t\tgroup.visible = true;\n\t\t\t\tcount++;\n\t\t\t}\n\t\t});\n\t}\n}\n"]}
131
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"orthographic-camera.js","sourceRoot":"","sources":["../../../../../../libs/soba/cameras/src/lib/orthographic-camera.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgTemplateOutlet } from '@angular/common';\nimport {\n\tCUSTOM_ELEMENTS_SCHEMA,\n\tChangeDetectionStrategy,\n\tComponent,\n\tElementRef,\n\tTemplateRef,\n\tafterNextRender,\n\tcomputed,\n\tcontentChild,\n\tinput,\n\tuntracked,\n\tviewChild,\n} from '@angular/core';\nimport { NgtOrthographicCamera, extend, injectBeforeRender, injectStore, omit, pick } from 'angular-three';\nimport { injectFBO } from 'angular-three-soba/misc';\nimport { injectAutoEffect } from 'ngxtension/auto-effect';\nimport { mergeInputs } from 'ngxtension/inject-inputs';\nimport { Color, Group, OrthographicCamera, Texture } from 'three';\nimport { NgtsCameraContent } from './camera-content';\n\nextend({ OrthographicCamera, Group });\n\nexport interface NgtsOrthographicCameraOptions extends Partial<NgtOrthographicCamera> {\n\t/** Registers the camera as the system default, fiber will start rendering with it */\n\tmakeDefault?: boolean;\n\t/** Making it manual will stop responsiveness and you have to calculate aspect ratio yourself. */\n\tmanual?: boolean;\n\t/** Number of frames to render, Infinity */\n\tframes: number;\n\t/** Resolution of the FBO, 256 */\n\tresolution: number;\n\t/** Optional environment map for functional use */\n\tenvMap?: Texture;\n}\n\nconst defaultOptions: NgtsOrthographicCameraOptions = {\n\tframes: Infinity,\n\tresolution: 256,\n\tmakeDefault: false,\n\tmanual: false,\n};\n\n@Component({\n\tselector: 'ngts-orthographic-camera',\n\tstandalone: true,\n\ttemplate: `\n\t\t<ngt-orthographic-camera\n\t\t\t#camera\n\t\t\t[left]=\"left()\"\n\t\t\t[right]=\"right()\"\n\t\t\t[top]=\"top()\"\n\t\t\t[bottom]=\"bottom()\"\n\t\t\t[parameters]=\"parameters()\"\n\t\t>\n\t\t\t<ng-container [ngTemplateOutlet]=\"content() ?? null\" />\n\t\t</ngt-orthographic-camera>\n\n\t\t<ngt-group #group>\n\t\t\t<ng-container [ngTemplateOutlet]=\"cameraContent() ?? null\" [ngTemplateOutletContext]=\"{ $implicit: texture }\" />\n\t\t</ngt-group>\n\t`,\n\timports: [NgTemplateOutlet],\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\tschemas: [CUSTOM_ELEMENTS_SCHEMA],\n})\nexport class NgtsOrthographicCamera {\n\toptions = input(defaultOptions, { transform: mergeInputs(defaultOptions) });\n\tparameters = omit(this.options, [\n\t\t'envMap',\n\t\t'makeDefault',\n\t\t'manual',\n\t\t'frames',\n\t\t'resolution',\n\t\t'left',\n\t\t'top',\n\t\t'bottom',\n\t\t'right',\n\t]);\n\n\tcontent = contentChild(TemplateRef);\n\tcameraContent = contentChild(NgtsCameraContent, { read: TemplateRef });\n\n\tcameraRef = viewChild.required<ElementRef<OrthographicCamera>>('camera');\n\tgroupRef = viewChild.required<ElementRef<Group>>('group');\n\n\tprivate autoEffect = injectAutoEffect();\n\tprivate store = injectStore();\n\n\tprivate camera = this.store.select('camera');\n\tsize = this.store.select('size');\n\n\tleft = computed(() => this.options().left ?? this.size().width / -2);\n\tright = computed(() => this.options().right ?? this.size().width / 2);\n\ttop = computed(() => this.options().top ?? this.size().height / 2);\n\tbottom = computed(() => this.options().bottom ?? this.size().height / -2);\n\n\tprivate manual = pick(this.options, 'manual');\n\tprivate makeDefault = pick(this.options, 'makeDefault');\n\tprivate resolution = pick(this.options, 'resolution');\n\tprivate fbo = injectFBO(() => ({ width: this.resolution() }));\n\ttexture = pick(this.fbo, 'texture');\n\n\tconstructor() {\n\t\tafterNextRender(() => {\n\t\t\tthis.autoEffect(() => {\n\t\t\t\tif (!this.manual()) {\n\t\t\t\t\tthis.cameraRef().nativeElement.updateProjectionMatrix();\n\t\t\t\t}\n\t\t\t});\n\n\t\t\tthis.autoEffect(() => {\n\t\t\t\tif (this.makeDefault()) {\n\t\t\t\t\tconst oldCam = untracked(this.camera);\n\t\t\t\t\tthis.store.update({ camera: this.cameraRef().nativeElement });\n\t\t\t\t\treturn () => this.store.update(() => ({ camera: oldCam }));\n\t\t\t\t}\n\t\t\t\treturn;\n\t\t\t});\n\n\t\t\tthis.cameraRef().nativeElement.updateProjectionMatrix();\n\t\t});\n\n\t\tlet count = 0;\n\t\tlet oldEnvMap: Color | Texture | null = null;\n\t\tinjectBeforeRender(({ gl, scene }) => {\n\t\t\tconst [{ frames, envMap }, group, camera, fbo] = [\n\t\t\t\tthis.options(),\n\t\t\t\tthis.groupRef().nativeElement,\n\t\t\t\tthis.cameraRef().nativeElement,\n\t\t\t\tthis.fbo(),\n\t\t\t];\n\t\t\tif (this.cameraContent() && group && camera && fbo && (frames === Infinity || count < frames)) {\n\t\t\t\tgroup.visible = false;\n\t\t\t\tgl.setRenderTarget(fbo);\n\t\t\t\toldEnvMap = scene.background;\n\t\t\t\tif (envMap) scene.background = envMap;\n\t\t\t\tgl.render(scene, camera);\n\t\t\t\tscene.background = oldEnvMap;\n\t\t\t\tgl.setRenderTarget(null);\n\t\t\t\tgroup.visible = true;\n\t\t\t\tcount++;\n\t\t\t}\n\t\t});\n\t}\n}\n"]}