angular-three-postprocessing 2.0.0-beta.9 → 2.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (98) hide show
  1. package/README.md +56 -4
  2. package/esm2022/lib/effect-composer.mjs +111 -171
  3. package/esm2022/lib/effect.mjs +43 -71
  4. package/esm2022/lib/effects/ascii.mjs +120 -0
  5. package/esm2022/lib/effects/bloom.mjs +39 -0
  6. package/esm2022/lib/effects/brightness-contrast.mjs +38 -0
  7. package/esm2022/lib/effects/chromatic-abberation.mjs +38 -0
  8. package/esm2022/lib/effects/color-average.mjs +33 -0
  9. package/esm2022/lib/effects/color-depth.mjs +38 -0
  10. package/esm2022/lib/effects/depth-of-field.mjs +56 -0
  11. package/esm2022/lib/effects/depth.mjs +38 -0
  12. package/esm2022/lib/effects/dot-screen.mjs +38 -0
  13. package/esm2022/lib/effects/fxaa.mjs +38 -0
  14. package/esm2022/lib/effects/glitch.mjs +63 -0
  15. package/esm2022/lib/effects/god-rays.mjs +41 -0
  16. package/esm2022/lib/effects/grid.mjs +42 -0
  17. package/esm2022/lib/effects/hue-saturation.mjs +38 -0
  18. package/esm2022/lib/effects/index.mjs +28 -18
  19. package/esm2022/lib/effects/lens-flare.mjs +195 -0
  20. package/esm2022/lib/effects/lut.mjs +50 -0
  21. package/esm2022/lib/effects/noise.mjs +39 -0
  22. package/esm2022/lib/effects/outline.mjs +143 -0
  23. package/esm2022/lib/effects/pixelation.mjs +30 -0
  24. package/esm2022/lib/effects/scanline.mjs +43 -0
  25. package/esm2022/lib/effects/sepia.mjs +38 -0
  26. package/esm2022/lib/effects/shock-wave.mjs +38 -0
  27. package/esm2022/lib/effects/smaa.mjs +38 -0
  28. package/esm2022/lib/effects/tilt-shift-2.mjs +121 -0
  29. package/esm2022/lib/effects/tilt-shift.mjs +39 -0
  30. package/esm2022/lib/effects/vignette.mjs +38 -0
  31. package/esm2022/lib/effects/water.mjs +64 -0
  32. package/fesm2022/angular-three-postprocessing.mjs +1280 -651
  33. package/fesm2022/angular-three-postprocessing.mjs.map +1 -1
  34. package/lib/effect-composer.d.ts +24 -76
  35. package/lib/effect.d.ts +52 -23
  36. package/lib/effects/ascii.d.ts +23 -0
  37. package/lib/effects/bloom.d.ts +10 -0
  38. package/lib/effects/brightness-contrast.d.ts +15 -0
  39. package/lib/effects/chromatic-abberation.d.ts +16 -0
  40. package/lib/effects/color-average.d.ts +11 -0
  41. package/lib/effects/color-depth.d.ts +14 -0
  42. package/lib/effects/depth-of-field.d.ts +22 -0
  43. package/lib/effects/depth.d.ts +14 -0
  44. package/lib/effects/dot-screen.d.ts +15 -0
  45. package/lib/effects/fxaa.d.ts +13 -0
  46. package/lib/effects/glitch.d.ts +29 -0
  47. package/lib/effects/god-rays.d.ts +30 -0
  48. package/lib/effects/grid.d.ts +18 -0
  49. package/lib/effects/hue-saturation.d.ts +15 -0
  50. package/lib/effects/index.d.ts +27 -17
  51. package/lib/effects/lens-flare.d.ts +96 -0
  52. package/lib/effects/lut.d.ts +19 -0
  53. package/lib/effects/noise.d.ts +14 -0
  54. package/lib/effects/outline.d.ts +74 -0
  55. package/lib/effects/pixelation.d.ts +16 -0
  56. package/lib/effects/scanline.d.ts +17 -0
  57. package/lib/effects/sepia.d.ts +14 -0
  58. package/lib/effects/shock-wave.d.ts +11 -0
  59. package/lib/effects/smaa.d.ts +15 -0
  60. package/lib/effects/tilt-shift-2.d.ts +35 -0
  61. package/lib/effects/tilt-shift.d.ts +22 -0
  62. package/lib/effects/vignette.d.ts +17 -0
  63. package/lib/effects/water.d.ts +20 -0
  64. package/package.json +12 -7
  65. package/esm2022/lib/effects/bloom/bloom.mjs +0 -33
  66. package/esm2022/lib/effects/brightness-contrast/brightness-contrast.mjs +0 -29
  67. package/esm2022/lib/effects/color-depth/color-depth.mjs +0 -29
  68. package/esm2022/lib/effects/depth/depth.mjs +0 -29
  69. package/esm2022/lib/effects/dot-screen/dot-screen.mjs +0 -29
  70. package/esm2022/lib/effects/hue-saturation/hue-saturation.mjs +0 -29
  71. package/esm2022/lib/effects/lut/lut.mjs +0 -70
  72. package/esm2022/lib/effects/noise/noise.mjs +0 -33
  73. package/esm2022/lib/effects/pixelation/pixelation.mjs +0 -33
  74. package/esm2022/lib/effects/scanline/scanline.mjs +0 -33
  75. package/esm2022/lib/effects/sepia/sepia.mjs +0 -29
  76. package/esm2022/lib/effects/shock-wave/shock-wave.mjs +0 -29
  77. package/esm2022/lib/effects/smaa/smaa.mjs +0 -29
  78. package/esm2022/lib/effects/ssao/ssao.mjs +0 -213
  79. package/esm2022/lib/effects/tilt-shift/tilt-shift.mjs +0 -33
  80. package/esm2022/lib/effects/tone-mapping/tone-mapping.mjs +0 -29
  81. package/esm2022/lib/effects/vignette/vignette.mjs +0 -29
  82. package/lib/effects/bloom/bloom.d.ts +0 -13
  83. package/lib/effects/brightness-contrast/brightness-contrast.d.ts +0 -15
  84. package/lib/effects/color-depth/color-depth.d.ts +0 -14
  85. package/lib/effects/depth/depth.d.ts +0 -14
  86. package/lib/effects/dot-screen/dot-screen.d.ts +0 -15
  87. package/lib/effects/hue-saturation/hue-saturation.d.ts +0 -15
  88. package/lib/effects/lut/lut.d.ts +0 -29
  89. package/lib/effects/noise/noise.d.ts +0 -15
  90. package/lib/effects/pixelation/pixelation.d.ts +0 -20
  91. package/lib/effects/scanline/scanline.d.ts +0 -15
  92. package/lib/effects/sepia/sepia.d.ts +0 -14
  93. package/lib/effects/shock-wave/shock-wave.d.ts +0 -17
  94. package/lib/effects/smaa/smaa.d.ts +0 -16
  95. package/lib/effects/ssao/ssao.d.ts +0 -42
  96. package/lib/effects/tilt-shift/tilt-shift.d.ts +0 -23
  97. package/lib/effects/tone-mapping/tone-mapping.d.ts +0 -22
  98. package/lib/effects/vignette/vignette.d.ts +0 -17
package/README.md CHANGED
@@ -1,7 +1,59 @@
1
- # postprocessing
1
+ # `angular-three-postprocessing`
2
2
 
3
- This library was generated with [Nx](https://nx.dev).
3
+ This is the main entry point for post-processing effects in Angular Three. It provides a way to apply various visual effects to your 3D scene after it has been rendered. This library relies on `maath`, `three-stdlib`, and `postprocessing` as dependencies.
4
4
 
5
- ## Running unit tests
5
+ ## Installation
6
6
 
7
- Run `nx test postprocessing` to execute the unit tests.
7
+ ```bash
8
+ npm install angular-three-postprocessing three-stdlib maath postprocessing
9
+ # yarn add angular-three-postprocessing three-stdlib maath postprocessing
10
+ # pnpm add angular-three-postprocessing three-stdlib maath postprocessing
11
+ ```
12
+
13
+ ## NgtpEffectComposer
14
+
15
+ This is a wrapper component that manages and applies post-processing effects to your scene. It takes content children of effects and applies them in the order they are provided.
16
+
17
+ ### Object Inputs (NgtpEffectComposerOptions)
18
+
19
+ | Property | Description | Default Value |
20
+ | ------------------ | ------------------------------------------------------------------------------------------------- | ------------- |
21
+ | `enabled` | Whether the effect composer is enabled. | true |
22
+ | `depthBuffer` | Whether to use a depth buffer. | undefined |
23
+ | `enableNormalPass` | Whether to enable the normal pass. This is only used for SSGI currently. | undefined |
24
+ | `stencilBuffer` | Whether to use a stencil buffer. | undefined |
25
+ | `autoClear` | Whether to automatically clear the output buffer before rendering. | true |
26
+ | `resolutionScale` | A scaling factor for the resolution of the effect composer. | undefined |
27
+ | `multisampling` | The number of samples to use for multisample anti-aliasing (MSAA). Set to 0 to disable MSAA. | 8 |
28
+ | `frameBufferType` | The data type to use for the frame buffer. | HalfFloatType |
29
+ | `renderPriority` | The render priority of the effect composer. | 1 |
30
+ | `camera` | The camera to use for rendering. If not provided, the default camera from the store will be used. | undefined |
31
+ | `scene` | The scene to render. If not provided, the default scene from the store will be used. | undefined |
32
+
33
+ ````html
34
+ <ngtp-effect-composer [options]="{ multisampling: 0, frameBufferType: FloatType, enableNormalPass: true }">
35
+ <ngtp-bloom />
36
+ </ngtp-effect-composer>
37
+ ```
38
+ ````
39
+
40
+ ### NgtpEffectComposerApi
41
+
42
+ This is an interface that provides access to the underlying `NgtpEffectComposer` instance, as well as the `camera` and `scene` being used. It also includes references to the `NormalPass` and `DepthDownsamplingPass` if they are enabled
43
+
44
+ ```ts
45
+ export interface NgtpEffectComposerApi {
46
+ composer: EffectComposer;
47
+ camera: Camera;
48
+ scene: Scene;
49
+ normalPass: NormalPass | null;
50
+ downSamplingPass: DepthDownsamplingPass | null;
51
+ resolutionScale?: number;
52
+ }
53
+ ```
54
+
55
+ To retrieve the `NgtpEffectComposerApi` for components within `<ngtp-effect-composer />`, you can use the `injectEffectComposerApi` function.
56
+
57
+ ## Effects
58
+
59
+ TBD
@@ -1,148 +1,144 @@
1
- import { CUSTOM_ELEMENTS_SCHEMA, Component, Injector, Input, computed, effect, forwardRef, inject, } from '@angular/core';
2
- import { createInjectionToken, extend, injectBeforeRender, injectNgtRef, injectNgtStore, signalStore, } from 'angular-three';
3
- import { DepthDownsamplingPass, Effect, EffectComposer, EffectPass, NormalPass, Pass, RenderPass, } from 'postprocessing';
4
- import * as THREE from 'three';
5
- import { Group } from 'three';
1
+ import { CUSTOM_ELEMENTS_SCHEMA, ChangeDetectionStrategy, Component, Injector, afterNextRender, computed, inject, input, viewChild, } from '@angular/core';
2
+ import { extend, getLocalState, injectBeforeRender, injectStore, pick } from 'angular-three';
3
+ import { injectAutoEffect } from 'ngxtension/auto-effect';
4
+ import { mergeInputs } from 'ngxtension/inject-inputs';
5
+ import { DepthDownsamplingPass, Effect, EffectAttribute, EffectComposer, EffectPass, NormalPass, Pass, RenderPass, } from 'postprocessing';
6
+ import { Group, HalfFloatType, NoToneMapping } from 'three';
6
7
  import { isWebGL2Available } from 'three-stdlib';
7
8
  import * as i0 from "@angular/core";
8
- extend({ Group });
9
- export const [injectNgtpEffectComposerApi, provideNgtpEffectComposerApi] = createInjectionToken((composer) => composer.api, { isRoot: false, deps: [forwardRef(() => NgtpEffectComposer)] });
9
+ const defaultOptions = {
10
+ enabled: true,
11
+ renderPriority: 1,
12
+ autoClear: true,
13
+ multisampling: 8,
14
+ frameBufferType: HalfFloatType,
15
+ };
16
+ function isConvolution(effect) {
17
+ return (effect.getAttributes() & EffectAttribute.CONVOLUTION) === EffectAttribute.CONVOLUTION;
18
+ }
10
19
  export class NgtpEffectComposer {
11
- set _enabled(enabled) {
12
- this.inputs.set({ enabled });
13
- }
14
- set _depthBuffer(depthBuffer) {
15
- this.inputs.set({ depthBuffer });
16
- }
17
- set _disableNormalPass(disableNormalPass) {
18
- this.inputs.set({ disableNormalPass });
19
- }
20
- set _stencilBuffer(stencilBuffer) {
21
- this.inputs.set({ stencilBuffer });
22
- }
23
- set _autoClear(autoClear) {
24
- this.inputs.set({ autoClear });
25
- }
26
- set _resolutionScale(resolutionScale) {
27
- this.inputs.set({ resolutionScale });
28
- }
29
- set _multisampling(multisampling) {
30
- this.inputs.set({ multisampling });
31
- }
32
- set _frameBufferType(frameBufferType) {
33
- this.inputs.set({ frameBufferType });
34
- }
35
- set _renderPriority(renderPriority) {
36
- this.inputs.set({ renderPriority });
37
- }
38
- set _camera(camera) {
39
- this.inputs.set({ camera });
40
- }
41
- set _scene(scene) {
42
- this.inputs.set({ scene });
43
- }
44
20
  constructor() {
45
- this.inputs = signalStore({
46
- enabled: true,
47
- renderPriority: 1,
48
- autoClear: true,
49
- multisampling: 8,
50
- frameBufferType: THREE.HalfFloatType,
51
- });
52
- this.composerRef = injectNgtRef();
21
+ this.options = input(defaultOptions, { transform: mergeInputs(defaultOptions) });
53
22
  this.injector = inject(Injector);
54
- this.store = injectNgtStore();
23
+ this.autoEffect = injectAutoEffect();
24
+ this.store = injectStore();
25
+ this.size = this.store.select('size');
55
26
  this.gl = this.store.select('gl');
56
27
  this.defaultScene = this.store.select('scene');
57
28
  this.defaultCamera = this.store.select('camera');
58
- this.size = this.store.select('size');
59
- this.depthBuffer = this.inputs.select('depthBuffer');
60
- this.stencilBuffer = this.inputs.select('stencilBuffer');
61
- this.multisampling = this.inputs.select('multisampling');
62
- this.frameBufferType = this.inputs.select('frameBufferType');
63
- this.scene = this.inputs.select('scene');
64
- this.camera = this.inputs.select('camera');
65
- this.disableNormalPass = this.inputs.select('disableNormalPass');
66
- this.resolutionScale = this.inputs.select('resolutionScale');
67
- this.autoClear = this.inputs.select('autoClear');
68
- this.activeScene = computed(() => this.scene() || this.defaultScene());
69
- this.activeCamera = computed(() => this.camera() || this.defaultCamera());
70
- this.composerEntities = computed(() => {
29
+ this.depthBuffer = pick(this.options, 'depthBuffer');
30
+ this.stencilBuffer = pick(this.options, 'stencilBuffer');
31
+ this.multisampling = pick(this.options, 'multisampling');
32
+ this.frameBufferType = pick(this.options, 'frameBufferType');
33
+ this.scene = computed(() => this.options().scene ?? this.defaultScene());
34
+ this.camera = computed(() => this.options().camera ?? this.defaultCamera());
35
+ this.enableNormalPass = pick(this.options, 'enableNormalPass');
36
+ this.resolutionScale = pick(this.options, 'resolutionScale');
37
+ this.groupRef = viewChild.required('group');
38
+ this.composerData = computed(() => {
71
39
  const webGL2Available = isWebGL2Available();
72
- const [gl, depthBuffer, stencilBuffer, multisampling, frameBufferType, scene, camera, disableNormalPass, resolutionScale,] = [
40
+ const [gl, scene, camera, depthBuffer, stencilBuffer, multisampling, frameBufferType, enableNormalPass, resolutionScale,] = [
73
41
  this.gl(),
42
+ this.scene(),
43
+ this.camera(),
74
44
  this.depthBuffer(),
75
45
  this.stencilBuffer(),
76
46
  this.multisampling(),
77
47
  this.frameBufferType(),
78
- this.activeScene(),
79
- this.activeCamera(),
80
- this.disableNormalPass(),
48
+ this.enableNormalPass(),
81
49
  this.resolutionScale(),
82
50
  ];
83
- // Initialize composer
84
- const effectComposer = new EffectComposer(gl, {
51
+ // initialize composer
52
+ const composer = new EffectComposer(gl, {
85
53
  depthBuffer,
86
54
  stencilBuffer,
87
55
  multisampling: multisampling > 0 && webGL2Available ? multisampling : 0,
88
56
  frameBufferType,
89
57
  });
90
- // Add render pass
91
- effectComposer.addPass(new RenderPass(scene, camera));
92
- // Create normal pass
58
+ // add render pass
59
+ composer.addPass(new RenderPass(scene, camera));
60
+ // create normal pass
93
61
  let downSamplingPass = null;
94
62
  let normalPass = null;
95
- if (!disableNormalPass) {
63
+ if (enableNormalPass) {
96
64
  normalPass = new NormalPass(scene, camera);
97
65
  normalPass.enabled = false;
98
- effectComposer.addPass(normalPass);
66
+ composer.addPass(normalPass);
99
67
  if (resolutionScale !== undefined && webGL2Available) {
100
68
  downSamplingPass = new DepthDownsamplingPass({ normalBuffer: normalPass.texture, resolutionScale });
101
69
  downSamplingPass.enabled = false;
102
- effectComposer.addPass(downSamplingPass);
70
+ composer.addPass(downSamplingPass);
103
71
  }
104
72
  }
105
- return { effectComposer, normalPass, downSamplingPass };
73
+ return { composer, normalPass, downSamplingPass };
106
74
  });
107
- this.composer = computed(() => this.composerEntities().effectComposer);
108
- this.api = computed(() => {
109
- const [{ effectComposer: composer, normalPass, downSamplingPass }, resolutionScale, camera, scene] = [
110
- this.composerEntities(),
111
- this.resolutionScale(),
112
- this.activeCamera(),
113
- this.activeScene(),
114
- ];
115
- return { composer, normalPass, downSamplingPass, resolutionScale, camera, scene };
75
+ extend({ Group });
76
+ afterNextRender(() => {
77
+ this.disableToneMapping();
78
+ this.setComposerSize();
79
+ this.updatePasses();
80
+ injectBeforeRender(({ delta }) => {
81
+ const [{ composer }, { enabled, autoClear, stencilBuffer }, gl] = [
82
+ this.composerData(),
83
+ this.options(),
84
+ this.gl(),
85
+ ];
86
+ if (enabled) {
87
+ const currentAutoClear = gl.autoClear;
88
+ gl.autoClear = autoClear;
89
+ if (stencilBuffer && !autoClear)
90
+ gl.clearStencil();
91
+ composer.render(delta);
92
+ gl.autoClear = currentAutoClear;
93
+ }
94
+ }, { injector: this.injector, priority: this.options().enabled ? this.options().renderPriority : 0 });
116
95
  });
117
- this.setComposerSize();
118
- this.updatePasses();
119
96
  }
120
- ngOnInit() {
121
- this.beforeRender();
97
+ // NOTE: Disable tone mapping because threejs disallows tonemapping on render targets
98
+ disableToneMapping() {
99
+ this.autoEffect(() => {
100
+ const gl = this.gl();
101
+ const currentTonemapping = gl.toneMapping;
102
+ gl.toneMapping = NoToneMapping;
103
+ return () => {
104
+ gl.toneMapping = currentTonemapping;
105
+ };
106
+ });
122
107
  }
123
108
  setComposerSize() {
124
- effect(() => {
125
- const [composer, size] = [this.composer(), this.size()];
126
- composer.setSize(size.width, size.height);
109
+ this.autoEffect(() => {
110
+ const [{ composer }, { width, height }] = [this.composerData(), this.size()];
111
+ if (composer) {
112
+ composer.setSize(width, height);
113
+ }
127
114
  });
128
115
  }
129
116
  updatePasses() {
130
- effect((onCleanup) => {
131
- const [{ effectComposer: composer, normalPass, downSamplingPass }, instance, children, camera] = [
132
- this.composerEntities(),
133
- this.composerRef.nativeElement,
134
- this.composerRef.children('nonObjects')(),
135
- this.activeCamera(),
117
+ this.autoEffect(() => {
118
+ const [group, { composer, normalPass, downSamplingPass }, camera] = [
119
+ this.groupRef(),
120
+ this.composerData(),
121
+ this.camera(),
136
122
  ];
137
123
  const passes = [];
138
- if (instance && composer && children.length) {
124
+ if (group.nativeElement && composer) {
125
+ const localState = getLocalState(group.nativeElement);
126
+ if (!localState)
127
+ return;
128
+ const children = localState.nonObjects();
139
129
  for (let i = 0; i < children.length; i++) {
140
130
  const child = children[i];
141
131
  if (child instanceof Effect) {
142
- const effects = [];
143
- while (children[i] instanceof Effect)
144
- effects.push(children[i++]);
145
- i--;
132
+ const effects = [child];
133
+ if (!isConvolution(child)) {
134
+ let next = null;
135
+ while ((next = children[i + 1]) instanceof Effect) {
136
+ if (isConvolution(next))
137
+ break;
138
+ effects.push(next);
139
+ i++;
140
+ }
141
+ }
146
142
  const pass = new EffectPass(camera, ...effects);
147
143
  passes.push(pass);
148
144
  }
@@ -150,99 +146,43 @@ export class NgtpEffectComposer {
150
146
  passes.push(child);
151
147
  }
152
148
  }
153
- for (const pass of passes)
149
+ for (const pass of passes) {
154
150
  composer.addPass(pass);
151
+ }
155
152
  if (normalPass)
156
153
  normalPass.enabled = true;
157
154
  if (downSamplingPass)
158
155
  downSamplingPass.enabled = true;
159
156
  }
160
- onCleanup(() => {
157
+ return () => {
161
158
  for (const pass of passes)
162
159
  composer?.removePass(pass);
163
160
  if (normalPass)
164
161
  normalPass.enabled = false;
165
162
  if (downSamplingPass)
166
163
  downSamplingPass.enabled = false;
167
- });
168
- });
169
- }
170
- beforeRender() {
171
- injectBeforeRender(({ delta }) => {
172
- const [enabled, gl, autoClear, stencilBuffer, composer] = [
173
- this.inputs.get('enabled'),
174
- this.gl(),
175
- this.autoClear(),
176
- this.stencilBuffer(),
177
- this.composer(),
178
- ];
179
- if (enabled) {
180
- const currentAutoClear = gl.autoClear;
181
- gl.autoClear = autoClear;
182
- if (stencilBuffer && !autoClear)
183
- gl.clearStencil();
184
- composer.render(delta);
185
- gl.autoClear = currentAutoClear;
186
- }
187
- }, {
188
- injector: this.injector,
189
- priority: this.inputs.get('enabled') ? this.inputs.get('renderPriority') : 0,
164
+ };
190
165
  });
191
166
  }
192
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: NgtpEffectComposer, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
193
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.7", type: NgtpEffectComposer, isStandalone: true, selector: "ngtp-effect-composer", inputs: { composerRef: "composerRef", _enabled: ["enabled", "_enabled"], _depthBuffer: ["depthBuffer", "_depthBuffer"], _disableNormalPass: ["disableNormalPass", "_disableNormalPass"], _stencilBuffer: ["stencilBuffer", "_stencilBuffer"], _autoClear: ["autoClear", "_autoClear"], _resolutionScale: ["resolutionScale", "_resolutionScale"], _multisampling: ["multisampling", "_multisampling"], _frameBufferType: ["frameBufferType", "_frameBufferType"], _renderPriority: ["renderPriority", "_renderPriority"], _camera: ["camera", "_camera"], _scene: ["scene", "_scene"] }, providers: [provideNgtpEffectComposerApi()], ngImport: i0, template: `
194
- <ngt-group [ref]="composerRef">
167
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: NgtpEffectComposer, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
168
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "18.2.0", type: NgtpEffectComposer, isStandalone: true, selector: "ngtp-effect-composer", inputs: { options: { classPropertyName: "options", publicName: "options", isSignal: true, isRequired: false, transformFunction: null } }, viewQueries: [{ propertyName: "groupRef", first: true, predicate: ["group"], descendants: true, isSignal: true }], ngImport: i0, template: `
169
+ <ngt-group #group>
195
170
  <ng-content />
196
171
  </ngt-group>
197
- `, isInline: true }); }
172
+ `, isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
198
173
  }
199
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: NgtpEffectComposer, decorators: [{
174
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: NgtpEffectComposer, decorators: [{
200
175
  type: Component,
201
176
  args: [{
202
177
  selector: 'ngtp-effect-composer',
203
178
  standalone: true,
204
179
  template: `
205
- <ngt-group [ref]="composerRef">
180
+ <ngt-group #group>
206
181
  <ng-content />
207
182
  </ngt-group>
208
183
  `,
209
- providers: [provideNgtpEffectComposerApi()],
210
184
  schemas: [CUSTOM_ELEMENTS_SCHEMA],
185
+ changeDetection: ChangeDetectionStrategy.OnPush,
211
186
  }]
212
- }], ctorParameters: function () { return []; }, propDecorators: { composerRef: [{
213
- type: Input
214
- }], _enabled: [{
215
- type: Input,
216
- args: [{ alias: 'enabled' }]
217
- }], _depthBuffer: [{
218
- type: Input,
219
- args: [{ alias: 'depthBuffer' }]
220
- }], _disableNormalPass: [{
221
- type: Input,
222
- args: [{ alias: 'disableNormalPass' }]
223
- }], _stencilBuffer: [{
224
- type: Input,
225
- args: [{ alias: 'stencilBuffer' }]
226
- }], _autoClear: [{
227
- type: Input,
228
- args: [{ alias: 'autoClear' }]
229
- }], _resolutionScale: [{
230
- type: Input,
231
- args: [{ alias: 'resolutionScale' }]
232
- }], _multisampling: [{
233
- type: Input,
234
- args: [{ alias: 'multisampling' }]
235
- }], _frameBufferType: [{
236
- type: Input,
237
- args: [{ alias: 'frameBufferType' }]
238
- }], _renderPriority: [{
239
- type: Input,
240
- args: [{ alias: 'renderPriority' }]
241
- }], _camera: [{
242
- type: Input,
243
- args: [{ alias: 'camera' }]
244
- }], _scene: [{
245
- type: Input,
246
- args: [{ alias: 'scene' }]
247
- }] } });
248
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"effect-composer.js","sourceRoot":"","sources":["../../../../../libs/postprocessing/src/lib/effect-composer.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n\tCUSTOM_ELEMENTS_SCHEMA,\n\tComponent,\n\tInjector,\n\tInput,\n\tcomputed,\n\teffect,\n\tforwardRef,\n\tinject,\n} from '@angular/core';\nimport {\n\tcreateInjectionToken,\n\textend,\n\tinjectBeforeRender,\n\tinjectNgtRef,\n\tinjectNgtStore,\n\tsignalStore,\n} from 'angular-three';\nimport {\n\tDepthDownsamplingPass,\n\tEffect,\n\tEffectComposer,\n\tEffectPass,\n\tNormalPass,\n\tPass,\n\tRenderPass,\n} from 'postprocessing';\nimport * as THREE from 'three';\nimport { Group } from 'three';\nimport { isWebGL2Available } from 'three-stdlib';\n\nextend({ Group });\n\nexport type NgtpEffectComposerState = {\n\tenabled: boolean;\n\tdepthBuffer?: boolean;\n\tdisableNormalPass?: boolean;\n\tstencilBuffer?: boolean;\n\tautoClear: boolean;\n\tresolutionScale?: number;\n\tmultisampling: number;\n\tframeBufferType: THREE.TextureDataType;\n\trenderPriority: number;\n\tcamera?: THREE.Camera;\n\tscene?: THREE.Scene;\n};\n\nexport const [injectNgtpEffectComposerApi, provideNgtpEffectComposerApi] = createInjectionToken(\n\t(composer: NgtpEffectComposer) => composer.api,\n\t{ isRoot: false, deps: [forwardRef(() => NgtpEffectComposer)] },\n);\n\n@Component({\n\tselector: 'ngtp-effect-composer',\n\tstandalone: true,\n\ttemplate: `\n\t\t<ngt-group [ref]=\"composerRef\">\n\t\t\t<ng-content />\n\t\t</ngt-group>\n\t`,\n\tproviders: [provideNgtpEffectComposerApi()],\n\tschemas: [CUSTOM_ELEMENTS_SCHEMA],\n})\nexport class NgtpEffectComposer {\n\tprivate inputs = signalStore<NgtpEffectComposerState>({\n\t\tenabled: true,\n\t\trenderPriority: 1,\n\t\tautoClear: true,\n\t\tmultisampling: 8,\n\t\tframeBufferType: THREE.HalfFloatType,\n\t});\n\n\t@Input() composerRef = injectNgtRef<Group>();\n\n\t@Input({ alias: 'enabled' }) set _enabled(enabled: boolean) {\n\t\tthis.inputs.set({ enabled });\n\t}\n\n\t@Input({ alias: 'depthBuffer' }) set _depthBuffer(depthBuffer: boolean) {\n\t\tthis.inputs.set({ depthBuffer });\n\t}\n\n\t@Input({ alias: 'disableNormalPass' }) set _disableNormalPass(disableNormalPass: boolean) {\n\t\tthis.inputs.set({ disableNormalPass });\n\t}\n\n\t@Input({ alias: 'stencilBuffer' }) set _stencilBuffer(stencilBuffer: boolean) {\n\t\tthis.inputs.set({ stencilBuffer });\n\t}\n\n\t@Input({ alias: 'autoClear' }) set _autoClear(autoClear: boolean) {\n\t\tthis.inputs.set({ autoClear });\n\t}\n\n\t@Input({ alias: 'resolutionScale' }) set _resolutionScale(resolutionScale: number) {\n\t\tthis.inputs.set({ resolutionScale });\n\t}\n\n\t@Input({ alias: 'multisampling' }) set _multisampling(multisampling: number) {\n\t\tthis.inputs.set({ multisampling });\n\t}\n\n\t@Input({ alias: 'frameBufferType' }) set _frameBufferType(frameBufferType: THREE.TextureDataType) {\n\t\tthis.inputs.set({ frameBufferType });\n\t}\n\n\t@Input({ alias: 'renderPriority' }) set _renderPriority(renderPriority: number) {\n\t\tthis.inputs.set({ renderPriority });\n\t}\n\n\t@Input({ alias: 'camera' }) set _camera(camera: THREE.Camera) {\n\t\tthis.inputs.set({ camera });\n\t}\n\n\t@Input({ alias: 'scene' }) set _scene(scene: THREE.Scene) {\n\t\tthis.inputs.set({ scene });\n\t}\n\n\tprivate injector = inject(Injector);\n\n\tprivate store = injectNgtStore();\n\tprivate gl = this.store.select('gl');\n\tprivate defaultScene = this.store.select('scene');\n\tprivate defaultCamera = this.store.select('camera');\n\tprivate size = this.store.select('size');\n\n\tprivate depthBuffer = this.inputs.select('depthBuffer');\n\tprivate stencilBuffer = this.inputs.select('stencilBuffer');\n\tprivate multisampling = this.inputs.select('multisampling');\n\tprivate frameBufferType = this.inputs.select('frameBufferType');\n\tprivate scene = this.inputs.select('scene');\n\tprivate camera = this.inputs.select('camera');\n\tprivate disableNormalPass = this.inputs.select('disableNormalPass');\n\tprivate resolutionScale = this.inputs.select('resolutionScale');\n\tprivate autoClear = this.inputs.select('autoClear');\n\n\tprivate activeScene = computed(() => this.scene() || this.defaultScene());\n\tprivate activeCamera = computed(() => this.camera() || this.defaultCamera());\n\n\tprivate composerEntities = computed(() => {\n\t\tconst webGL2Available = isWebGL2Available();\n\t\tconst [\n\t\t\tgl,\n\t\t\tdepthBuffer,\n\t\t\tstencilBuffer,\n\t\t\tmultisampling,\n\t\t\tframeBufferType,\n\t\t\tscene,\n\t\t\tcamera,\n\t\t\tdisableNormalPass,\n\t\t\tresolutionScale,\n\t\t] = [\n\t\t\tthis.gl(),\n\t\t\tthis.depthBuffer(),\n\t\t\tthis.stencilBuffer(),\n\t\t\tthis.multisampling(),\n\t\t\tthis.frameBufferType(),\n\t\t\tthis.activeScene(),\n\t\t\tthis.activeCamera(),\n\t\t\tthis.disableNormalPass(),\n\t\t\tthis.resolutionScale(),\n\t\t];\n\n\t\t// Initialize composer\n\t\tconst effectComposer = new EffectComposer(gl, {\n\t\t\tdepthBuffer,\n\t\t\tstencilBuffer,\n\t\t\tmultisampling: multisampling > 0 && webGL2Available ? multisampling : 0,\n\t\t\tframeBufferType,\n\t\t});\n\n\t\t// Add render pass\n\t\teffectComposer.addPass(new RenderPass(scene, camera));\n\n\t\t// Create normal pass\n\t\tlet downSamplingPass = null;\n\t\tlet normalPass = null;\n\t\tif (!disableNormalPass) {\n\t\t\tnormalPass = new NormalPass(scene, camera);\n\t\t\tnormalPass.enabled = false;\n\t\t\teffectComposer.addPass(normalPass);\n\t\t\tif (resolutionScale !== undefined && webGL2Available) {\n\t\t\t\tdownSamplingPass = new DepthDownsamplingPass({ normalBuffer: normalPass.texture, resolutionScale });\n\t\t\t\tdownSamplingPass.enabled = false;\n\t\t\t\teffectComposer.addPass(downSamplingPass);\n\t\t\t}\n\t\t}\n\n\t\treturn { effectComposer, normalPass, downSamplingPass };\n\t});\n\n\tprivate composer = computed(() => this.composerEntities().effectComposer);\n\n\tapi = computed(() => {\n\t\tconst [{ effectComposer: composer, normalPass, downSamplingPass }, resolutionScale, camera, scene] = [\n\t\t\tthis.composerEntities(),\n\t\t\tthis.resolutionScale(),\n\t\t\tthis.activeCamera(),\n\t\t\tthis.activeScene(),\n\t\t];\n\t\treturn { composer, normalPass, downSamplingPass, resolutionScale, camera, scene };\n\t});\n\n\tconstructor() {\n\t\tthis.setComposerSize();\n\t\tthis.updatePasses();\n\t}\n\n\tngOnInit() {\n\t\tthis.beforeRender();\n\t}\n\n\tprivate setComposerSize() {\n\t\teffect(() => {\n\t\t\tconst [composer, size] = [this.composer(), this.size()];\n\t\t\tcomposer.setSize(size.width, size.height);\n\t\t});\n\t}\n\n\tprivate updatePasses() {\n\t\teffect((onCleanup) => {\n\t\t\tconst [{ effectComposer: composer, normalPass, downSamplingPass }, instance, children, camera] = [\n\t\t\t\tthis.composerEntities(),\n\t\t\t\tthis.composerRef.nativeElement,\n\t\t\t\tthis.composerRef.children('nonObjects')(),\n\t\t\t\tthis.activeCamera(),\n\t\t\t];\n\n\t\t\tconst passes: Pass[] = [];\n\n\t\t\tif (instance && composer && children.length) {\n\t\t\t\tfor (let i = 0; i < children.length; i++) {\n\t\t\t\t\tconst child = children[i];\n\t\t\t\t\tif (child instanceof Effect) {\n\t\t\t\t\t\tconst effects: Effect[] = [];\n\n\t\t\t\t\t\twhile (children[i] instanceof Effect) effects.push(children[i++] as Effect);\n\t\t\t\t\t\ti--;\n\n\t\t\t\t\t\tconst pass = new EffectPass(camera, ...effects);\n\t\t\t\t\t\tpasses.push(pass);\n\t\t\t\t\t} else if (child instanceof Pass) {\n\t\t\t\t\t\tpasses.push(child);\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tfor (const pass of passes) composer.addPass(pass);\n\t\t\t\tif (normalPass) normalPass.enabled = true;\n\t\t\t\tif (downSamplingPass) downSamplingPass.enabled = true;\n\t\t\t}\n\n\t\t\tonCleanup(() => {\n\t\t\t\tfor (const pass of passes) composer?.removePass(pass);\n\t\t\t\tif (normalPass) normalPass.enabled = false;\n\t\t\t\tif (downSamplingPass) downSamplingPass.enabled = false;\n\t\t\t});\n\t\t});\n\t}\n\n\tprivate beforeRender() {\n\t\tinjectBeforeRender(\n\t\t\t({ delta }) => {\n\t\t\t\tconst [enabled, gl, autoClear, stencilBuffer, composer] = [\n\t\t\t\t\tthis.inputs.get('enabled'),\n\t\t\t\t\tthis.gl(),\n\t\t\t\t\tthis.autoClear(),\n\t\t\t\t\tthis.stencilBuffer(),\n\t\t\t\t\tthis.composer(),\n\t\t\t\t];\n\t\t\t\tif (enabled) {\n\t\t\t\t\tconst currentAutoClear = gl.autoClear;\n\t\t\t\t\tgl.autoClear = autoClear;\n\t\t\t\t\tif (stencilBuffer && !autoClear) gl.clearStencil();\n\t\t\t\t\tcomposer.render(delta);\n\t\t\t\t\tgl.autoClear = currentAutoClear;\n\t\t\t\t}\n\t\t\t},\n\t\t\t{\n\t\t\t\tinjector: this.injector,\n\t\t\t\tpriority: this.inputs.get('enabled') ? this.inputs.get('renderPriority') : 0,\n\t\t\t},\n\t\t);\n\t}\n}\n"]}
187
+ }], ctorParameters: () => [] });
188
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"effect-composer.js","sourceRoot":"","sources":["../../../../../libs/postprocessing/src/lib/effect-composer.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n\tCUSTOM_ELEMENTS_SCHEMA,\n\tChangeDetectionStrategy,\n\tComponent,\n\tElementRef,\n\tInjector,\n\tafterNextRender,\n\tcomputed,\n\tinject,\n\tinput,\n\tviewChild,\n} from '@angular/core';\nimport { extend, getLocalState, injectBeforeRender, injectStore, pick } from 'angular-three';\nimport { injectAutoEffect } from 'ngxtension/auto-effect';\nimport { mergeInputs } from 'ngxtension/inject-inputs';\nimport {\n\tDepthDownsamplingPass,\n\tEffect,\n\tEffectAttribute,\n\tEffectComposer,\n\tEffectPass,\n\tNormalPass,\n\tPass,\n\tRenderPass,\n} from 'postprocessing';\nimport { Camera, Group, HalfFloatType, NoToneMapping, Scene, TextureDataType } from 'three';\nimport { isWebGL2Available } from 'three-stdlib';\n\nexport interface NgtpEffectComposerOptions {\n\tenabled: boolean;\n\tdepthBuffer?: boolean;\n\t/** Only used for SSGI currently, leave it disabled for everything else unless it's needed */\n\tenableNormalPass?: boolean;\n\tstencilBuffer?: boolean;\n\tautoClear: boolean;\n\tresolutionScale?: number;\n\tmultisampling: number;\n\tframeBufferType: TextureDataType;\n\trenderPriority: number;\n\tcamera?: Camera;\n\tscene?: Scene;\n}\n\nconst defaultOptions: NgtpEffectComposerOptions = {\n\tenabled: true,\n\trenderPriority: 1,\n\tautoClear: true,\n\tmultisampling: 8,\n\tframeBufferType: HalfFloatType,\n};\n\nfunction isConvolution(effect: Effect) {\n\treturn (effect.getAttributes() & EffectAttribute.CONVOLUTION) === EffectAttribute.CONVOLUTION;\n}\n\n@Component({\n\tselector: 'ngtp-effect-composer',\n\tstandalone: true,\n\ttemplate: `\n\t\t<ngt-group #group>\n\t\t\t<ng-content />\n\t\t</ngt-group>\n\t`,\n\tschemas: [CUSTOM_ELEMENTS_SCHEMA],\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class NgtpEffectComposer {\n\toptions = input(defaultOptions, { transform: mergeInputs(defaultOptions) });\n\n\tprivate injector = inject(Injector);\n\tprivate autoEffect = injectAutoEffect();\n\tprivate store = injectStore();\n\tprivate size = this.store.select('size');\n\tprivate gl = this.store.select('gl');\n\tprivate defaultScene = this.store.select('scene');\n\tprivate defaultCamera = this.store.select('camera');\n\n\tdepthBuffer = pick(this.options, 'depthBuffer');\n\tstencilBuffer = pick(this.options, 'stencilBuffer');\n\tmultisampling = pick(this.options, 'multisampling');\n\tframeBufferType = pick(this.options, 'frameBufferType');\n\tscene = computed(() => this.options().scene ?? this.defaultScene());\n\tcamera = computed(() => this.options().camera ?? this.defaultCamera());\n\tenableNormalPass = pick(this.options, 'enableNormalPass');\n\tresolutionScale = pick(this.options, 'resolutionScale');\n\n\tgroupRef = viewChild.required<ElementRef<Group>>('group');\n\n\tcomposerData = computed(() => {\n\t\tconst webGL2Available = isWebGL2Available();\n\t\tconst [\n\t\t\tgl,\n\t\t\tscene,\n\t\t\tcamera,\n\t\t\tdepthBuffer,\n\t\t\tstencilBuffer,\n\t\t\tmultisampling,\n\t\t\tframeBufferType,\n\t\t\tenableNormalPass,\n\t\t\tresolutionScale,\n\t\t] = [\n\t\t\tthis.gl(),\n\t\t\tthis.scene(),\n\t\t\tthis.camera(),\n\t\t\tthis.depthBuffer(),\n\t\t\tthis.stencilBuffer(),\n\t\t\tthis.multisampling(),\n\t\t\tthis.frameBufferType(),\n\t\t\tthis.enableNormalPass(),\n\t\t\tthis.resolutionScale(),\n\t\t];\n\n\t\t// initialize composer\n\t\tconst composer = new EffectComposer(gl, {\n\t\t\tdepthBuffer,\n\t\t\tstencilBuffer,\n\t\t\tmultisampling: multisampling > 0 && webGL2Available ? multisampling : 0,\n\t\t\tframeBufferType,\n\t\t});\n\n\t\t// add render pass\n\t\tcomposer.addPass(new RenderPass(scene, camera));\n\n\t\t// create normal pass\n\t\tlet downSamplingPass = null;\n\t\tlet normalPass = null;\n\t\tif (enableNormalPass) {\n\t\t\tnormalPass = new NormalPass(scene, camera);\n\t\t\tnormalPass.enabled = false;\n\t\t\tcomposer.addPass(normalPass);\n\t\t\tif (resolutionScale !== undefined && webGL2Available) {\n\t\t\t\tdownSamplingPass = new DepthDownsamplingPass({ normalBuffer: normalPass.texture, resolutionScale });\n\t\t\t\tdownSamplingPass.enabled = false;\n\t\t\t\tcomposer.addPass(downSamplingPass);\n\t\t\t}\n\t\t}\n\n\t\treturn { composer, normalPass, downSamplingPass };\n\t});\n\n\tconstructor() {\n\t\textend({ Group });\n\n\t\tafterNextRender(() => {\n\t\t\tthis.disableToneMapping();\n\t\t\tthis.setComposerSize();\n\t\t\tthis.updatePasses();\n\n\t\t\tinjectBeforeRender(\n\t\t\t\t({ delta }) => {\n\t\t\t\t\tconst [{ composer }, { enabled, autoClear, stencilBuffer }, gl] = [\n\t\t\t\t\t\tthis.composerData(),\n\t\t\t\t\t\tthis.options(),\n\t\t\t\t\t\tthis.gl(),\n\t\t\t\t\t];\n\n\t\t\t\t\tif (enabled) {\n\t\t\t\t\t\tconst currentAutoClear = gl.autoClear;\n\t\t\t\t\t\tgl.autoClear = autoClear;\n\t\t\t\t\t\tif (stencilBuffer && !autoClear) gl.clearStencil();\n\t\t\t\t\t\tcomposer.render(delta);\n\t\t\t\t\t\tgl.autoClear = currentAutoClear;\n\t\t\t\t\t}\n\t\t\t\t},\n\t\t\t\t{ injector: this.injector, priority: this.options().enabled ? this.options().renderPriority : 0 },\n\t\t\t);\n\t\t});\n\t}\n\n\t// NOTE: Disable tone mapping because threejs disallows tonemapping on render targets\n\tprivate disableToneMapping() {\n\t\tthis.autoEffect(() => {\n\t\t\tconst gl = this.gl();\n\t\t\tconst currentTonemapping = gl.toneMapping;\n\t\t\tgl.toneMapping = NoToneMapping;\n\t\t\treturn () => {\n\t\t\t\tgl.toneMapping = currentTonemapping;\n\t\t\t};\n\t\t});\n\t}\n\n\tprivate setComposerSize() {\n\t\tthis.autoEffect(() => {\n\t\t\tconst [{ composer }, { width, height }] = [this.composerData(), this.size()];\n\t\t\tif (composer) {\n\t\t\t\tcomposer.setSize(width, height);\n\t\t\t}\n\t\t});\n\t}\n\n\tprivate updatePasses() {\n\t\tthis.autoEffect(() => {\n\t\t\tconst [group, { composer, normalPass, downSamplingPass }, camera] = [\n\t\t\t\tthis.groupRef(),\n\t\t\t\tthis.composerData(),\n\t\t\t\tthis.camera(),\n\t\t\t];\n\n\t\t\tconst passes: Pass[] = [];\n\n\t\t\tif (group.nativeElement && composer) {\n\t\t\t\tconst localState = getLocalState(group.nativeElement);\n\t\t\t\tif (!localState) return;\n\n\t\t\t\tconst children = localState.nonObjects();\n\t\t\t\tfor (let i = 0; i < children.length; i++) {\n\t\t\t\t\tconst child = children[i];\n\t\t\t\t\tif (child instanceof Effect) {\n\t\t\t\t\t\tconst effects: Effect[] = [child];\n\n\t\t\t\t\t\tif (!isConvolution(child)) {\n\t\t\t\t\t\t\tlet next: unknown = null;\n\t\t\t\t\t\t\twhile ((next = children[i + 1]) instanceof Effect) {\n\t\t\t\t\t\t\t\tif (isConvolution(next)) break;\n\t\t\t\t\t\t\t\teffects.push(next as Effect);\n\t\t\t\t\t\t\t\ti++;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tconst pass = new EffectPass(camera, ...effects);\n\t\t\t\t\t\tpasses.push(pass);\n\t\t\t\t\t} else if (child instanceof Pass) {\n\t\t\t\t\t\tpasses.push(child);\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tfor (const pass of passes) {\n\t\t\t\t\tcomposer.addPass(pass);\n\t\t\t\t}\n\n\t\t\t\tif (normalPass) normalPass.enabled = true;\n\t\t\t\tif (downSamplingPass) downSamplingPass.enabled = true;\n\t\t\t}\n\n\t\t\treturn () => {\n\t\t\t\tfor (const pass of passes) composer?.removePass(pass);\n\t\t\t\tif (normalPass) normalPass.enabled = false;\n\t\t\t\tif (downSamplingPass) downSamplingPass.enabled = false;\n\t\t\t};\n\t\t});\n\t}\n}\n"]}