angular-three 2.0.0-beta.22 → 2.0.0-beta.223

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 (109) hide show
  1. package/esm2022/index.mjs +4 -11
  2. package/esm2022/lib/canvas.mjs +81 -156
  3. package/esm2022/lib/directives/args.mjs +6 -6
  4. package/esm2022/lib/directives/common.mjs +15 -14
  5. package/esm2022/lib/directives/parent.mjs +6 -6
  6. package/esm2022/lib/dom/events.mjs +2 -2
  7. package/esm2022/lib/events.mjs +28 -25
  8. package/esm2022/lib/instance.mjs +39 -34
  9. package/esm2022/lib/loader.mjs +12 -14
  10. package/esm2022/lib/loop.mjs +9 -10
  11. package/esm2022/lib/portal.mjs +122 -135
  12. package/esm2022/lib/ref.mjs +18 -20
  13. package/esm2022/lib/renderer/catalogue.mjs +2 -2
  14. package/esm2022/lib/renderer/constants.mjs +2 -2
  15. package/esm2022/lib/renderer/index.mjs +58 -62
  16. package/esm2022/lib/renderer/store.mjs +129 -120
  17. package/esm2022/lib/renderer/utils.mjs +35 -42
  18. package/esm2022/lib/roots.mjs +41 -38
  19. package/esm2022/lib/routed-scene.mjs +6 -7
  20. package/esm2022/lib/store.mjs +163 -189
  21. package/esm2022/lib/utils/apply-props.mjs +12 -17
  22. package/esm2022/lib/utils/attach.mjs +6 -6
  23. package/esm2022/lib/utils/before-render.mjs +12 -0
  24. package/esm2022/lib/utils/cd-aware-signal.mjs +24 -0
  25. package/esm2022/lib/utils/create-api-token.mjs +13 -0
  26. package/esm2022/lib/utils/is.mjs +6 -5
  27. package/esm2022/lib/utils/make.mjs +15 -12
  28. package/esm2022/lib/utils/signal-store.mjs +67 -57
  29. package/esm2022/lib/utils/update.mjs +3 -2
  30. package/fesm2022/angular-three.mjs +1621 -1795
  31. package/fesm2022/angular-three.mjs.map +1 -1
  32. package/index.d.ts +6 -10
  33. package/lib/canvas.d.ts +24 -37
  34. package/lib/directives/common.d.ts +12 -1
  35. package/lib/events.d.ts +2 -2
  36. package/lib/instance.d.ts +19 -10
  37. package/lib/loader.d.ts +13 -4
  38. package/lib/loop.d.ts +6 -29
  39. package/lib/portal.d.ts +18 -26
  40. package/lib/ref.d.ts +0 -1
  41. package/lib/renderer/catalogue.d.ts +5 -1
  42. package/lib/renderer/constants.d.ts +1 -1
  43. package/lib/renderer/index.d.ts +55 -4
  44. package/lib/renderer/store.d.ts +18 -21
  45. package/lib/renderer/utils.d.ts +2 -3
  46. package/lib/roots.d.ts +4 -3
  47. package/lib/store.d.ts +9 -11
  48. package/lib/utils/apply-props.d.ts +0 -1
  49. package/lib/{before-render.d.ts → utils/before-render.d.ts} +1 -1
  50. package/lib/utils/cd-aware-signal.d.ts +4 -0
  51. package/lib/utils/create-api-token.d.ts +23 -0
  52. package/lib/utils/is.d.ts +11 -12
  53. package/lib/utils/make.d.ts +3 -2
  54. package/lib/utils/signal-store.d.ts +16 -3
  55. package/metadata.json +1 -1
  56. package/package.json +30 -11
  57. package/plugin/generators.json +0 -32
  58. package/plugin/src/generators/init/compat.d.ts +1 -3
  59. package/plugin/src/generators/init/files/experience/{experience.component.ts.__tmpl__ → experience.component.ts__tmpl__} +1 -0
  60. package/plugin/src/generators/init/generator.d.ts +2 -5
  61. package/plugin/src/generators/init/generator.js +87 -99
  62. package/plugin/src/generators/init/generator.js.map +1 -1
  63. package/plugin/src/generators/init/schema.json +1 -12
  64. package/plugin/src/generators/utils.js.map +1 -1
  65. package/plugin/src/generators/{versions.d.ts → version.d.ts} +5 -3
  66. package/plugin/src/generators/version.js +18 -0
  67. package/plugin/src/generators/version.js.map +1 -0
  68. package/plugin/src/index.d.ts +0 -3
  69. package/plugin/src/index.js +0 -9
  70. package/plugin/src/index.js.map +1 -1
  71. package/web-types.json +1 -1
  72. package/esm2022/lib/before-render.mjs +0 -13
  73. package/esm2022/lib/directives/key.mjs +0 -29
  74. package/esm2022/lib/directives/repeat.mjs +0 -17
  75. package/esm2022/lib/three-types.mjs +0 -2
  76. package/esm2022/lib/utils/assert-injection-context.mjs +0 -14
  77. package/esm2022/lib/utils/create-injection-token.mjs +0 -47
  78. package/esm2022/lib/utils/safe-detect-changes.mjs +0 -17
  79. package/lib/directives/key.d.ts +0 -10
  80. package/lib/directives/repeat.d.ts +0 -7
  81. package/lib/three-types.d.ts +0 -306
  82. package/lib/utils/assert-injection-context.d.ts +0 -2
  83. package/lib/utils/create-injection-token.d.ts +0 -27
  84. package/lib/utils/safe-detect-changes.d.ts +0 -2
  85. package/plugin/package.json +0 -6
  86. package/plugin/src/generators/init-cannon/compat.d.ts +0 -2
  87. package/plugin/src/generators/init-cannon/compat.js +0 -6
  88. package/plugin/src/generators/init-cannon/compat.js.map +0 -1
  89. package/plugin/src/generators/init-cannon/generator.d.ts +0 -2
  90. package/plugin/src/generators/init-cannon/generator.js +0 -22
  91. package/plugin/src/generators/init-cannon/generator.js.map +0 -1
  92. package/plugin/src/generators/init-cannon/schema.json +0 -6
  93. package/plugin/src/generators/init-postprocessing/compat.d.ts +0 -2
  94. package/plugin/src/generators/init-postprocessing/compat.js +0 -6
  95. package/plugin/src/generators/init-postprocessing/compat.js.map +0 -1
  96. package/plugin/src/generators/init-postprocessing/generator.d.ts +0 -2
  97. package/plugin/src/generators/init-postprocessing/generator.js +0 -20
  98. package/plugin/src/generators/init-postprocessing/generator.js.map +0 -1
  99. package/plugin/src/generators/init-postprocessing/schema.json +0 -6
  100. package/plugin/src/generators/init-soba/compat.d.ts +0 -2
  101. package/plugin/src/generators/init-soba/compat.js +0 -6
  102. package/plugin/src/generators/init-soba/compat.js.map +0 -1
  103. package/plugin/src/generators/init-soba/generator.d.ts +0 -2
  104. package/plugin/src/generators/init-soba/generator.js +0 -26
  105. package/plugin/src/generators/init-soba/generator.js.map +0 -1
  106. package/plugin/src/generators/init-soba/schema.json +0 -6
  107. package/plugin/src/generators/versions.js +0 -16
  108. package/plugin/src/generators/versions.js.map +0 -1
  109. /package/plugin/src/generators/init/files/experience/{experience.component.html.__tmpl__ → experience.component.html__tmpl__} +0 -0
package/esm2022/index.mjs CHANGED
@@ -1,10 +1,5 @@
1
- export * from './lib/before-render';
2
1
  export * from './lib/canvas';
3
2
  export * from './lib/directives/args';
4
- export * from './lib/directives/key';
5
- export * from './lib/directives/parent';
6
- export * from './lib/directives/repeat';
7
- export {} from './lib/events';
8
3
  export * from './lib/instance';
9
4
  export * from './lib/loader';
10
5
  export { addAfterEffect, addEffect, addTail } from './lib/loop';
@@ -13,15 +8,13 @@ export * from './lib/ref';
13
8
  export * from './lib/renderer';
14
9
  export * from './lib/routed-scene';
15
10
  export * from './lib/store';
16
- export * from './lib/three-types';
17
- export * from './lib/types';
18
11
  export * from './lib/utils/apply-props';
19
- export * from './lib/utils/assert-injection-context';
20
12
  export { createAttachFunction } from './lib/utils/attach';
21
- export * from './lib/utils/create-injection-token';
13
+ export * from './lib/utils/before-render';
14
+ export * from './lib/utils/cd-aware-signal';
15
+ export * from './lib/utils/create-api-token';
22
16
  export * from './lib/utils/is';
23
17
  export * from './lib/utils/make';
24
- export * from './lib/utils/safe-detect-changes';
25
18
  export * from './lib/utils/signal-store';
26
19
  export * from './lib/utils/update';
27
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9saWJzL2NvcmUvc3JjL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMscUJBQXFCLENBQUM7QUFDcEMsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyx1QkFBdUIsQ0FBQztBQUN0QyxjQUFjLHNCQUFzQixDQUFDO0FBQ3JDLGNBQWMseUJBQXlCLENBQUM7QUFDeEMsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxPQUFPLEVBQXNDLE1BQU0sY0FBYyxDQUFDO0FBQ2xFLGNBQWMsZ0JBQWdCLENBQUM7QUFDL0IsY0FBYyxjQUFjLENBQUM7QUFDN0IsT0FBTyxFQUFFLGNBQWMsRUFBRSxTQUFTLEVBQUUsT0FBTyxFQUFFLE1BQU0sWUFBWSxDQUFDO0FBQ2hFLE9BQU8sRUFBRSxTQUFTLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFDM0QsY0FBYyxXQUFXLENBQUM7QUFDMUIsY0FBYyxnQkFBZ0IsQ0FBQztBQUMvQixjQUFjLG9CQUFvQixDQUFDO0FBQ25DLGNBQWMsYUFBYSxDQUFDO0FBQzVCLGNBQWMsbUJBQW1CLENBQUM7QUFDbEMsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLHNDQUFzQyxDQUFDO0FBQ3JELE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBQzFELGNBQWMsb0NBQW9DLENBQUM7QUFDbkQsY0FBYyxnQkFBZ0IsQ0FBQztBQUMvQixjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsaUNBQWlDLENBQUM7QUFDaEQsY0FBYywwQkFBMEIsQ0FBQztBQUN6QyxjQUFjLG9CQUFvQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9saWIvYmVmb3JlLXJlbmRlcic7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jYW52YXMnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZGlyZWN0aXZlcy9hcmdzJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2RpcmVjdGl2ZXMva2V5JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2RpcmVjdGl2ZXMvcGFyZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2RpcmVjdGl2ZXMvcmVwZWF0JztcbmV4cG9ydCB7IHR5cGUgTmd0Q2FtZXJhLCB0eXBlIE5ndFRocmVlRXZlbnQgfSBmcm9tICcuL2xpYi9ldmVudHMnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvaW5zdGFuY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbG9hZGVyJztcbmV4cG9ydCB7IGFkZEFmdGVyRWZmZWN0LCBhZGRFZmZlY3QsIGFkZFRhaWwgfSBmcm9tICcuL2xpYi9sb29wJztcbmV4cG9ydCB7IE5ndFBvcnRhbCwgTmd0UG9ydGFsQ29udGVudCB9IGZyb20gJy4vbGliL3BvcnRhbCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9yZWYnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvcmVuZGVyZXInO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvcm91dGVkLXNjZW5lJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3N0b3JlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3RocmVlLXR5cGVzJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3R5cGVzJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3V0aWxzL2FwcGx5LXByb3BzJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3V0aWxzL2Fzc2VydC1pbmplY3Rpb24tY29udGV4dCc7XG5leHBvcnQgeyBjcmVhdGVBdHRhY2hGdW5jdGlvbiB9IGZyb20gJy4vbGliL3V0aWxzL2F0dGFjaCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi91dGlscy9jcmVhdGUtaW5qZWN0aW9uLXRva2VuJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3V0aWxzL2lzJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3V0aWxzL21ha2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdXRpbHMvc2FmZS1kZXRlY3QtY2hhbmdlcyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi91dGlscy9zaWduYWwtc3RvcmUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdXRpbHMvdXBkYXRlJztcbiJdfQ==
20
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9saWJzL2NvcmUvc3JjL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYyxnQkFBZ0IsQ0FBQztBQUMvQixjQUFjLGNBQWMsQ0FBQztBQUM3QixPQUFPLEVBQUUsY0FBYyxFQUFFLFNBQVMsRUFBRSxPQUFPLEVBQUUsTUFBTSxZQUFZLENBQUM7QUFDaEUsT0FBTyxFQUFFLFNBQVMsRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGNBQWMsQ0FBQztBQUMzRCxjQUFjLFdBQVcsQ0FBQztBQUMxQixjQUFjLGdCQUFnQixDQUFDO0FBQy9CLGNBQWMsb0JBQW9CLENBQUM7QUFDbkMsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUMxRCxjQUFjLDJCQUEyQixDQUFDO0FBQzFDLGNBQWMsNkJBQTZCLENBQUM7QUFDNUMsY0FBYyw4QkFBOEIsQ0FBQztBQUM3QyxjQUFjLGdCQUFnQixDQUFDO0FBQy9CLGNBQWMsa0JBQWtCLENBQUM7QUFDakMsY0FBYywwQkFBMEIsQ0FBQztBQUN6QyxjQUFjLG9CQUFvQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9saWIvY2FudmFzJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2RpcmVjdGl2ZXMvYXJncyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9pbnN0YW5jZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9sb2FkZXInO1xuZXhwb3J0IHsgYWRkQWZ0ZXJFZmZlY3QsIGFkZEVmZmVjdCwgYWRkVGFpbCB9IGZyb20gJy4vbGliL2xvb3AnO1xuZXhwb3J0IHsgTmd0UG9ydGFsLCBOZ3RQb3J0YWxDb250ZW50IH0gZnJvbSAnLi9saWIvcG9ydGFsJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3JlZic7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9yZW5kZXJlcic7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9yb3V0ZWQtc2NlbmUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvc3RvcmUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdXRpbHMvYXBwbHktcHJvcHMnO1xuZXhwb3J0IHsgY3JlYXRlQXR0YWNoRnVuY3Rpb24gfSBmcm9tICcuL2xpYi91dGlscy9hdHRhY2gnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdXRpbHMvYmVmb3JlLXJlbmRlcic7XG5leHBvcnQgKiBmcm9tICcuL2xpYi91dGlscy9jZC1hd2FyZS1zaWduYWwnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdXRpbHMvY3JlYXRlLWFwaS10b2tlbic7XG5leHBvcnQgKiBmcm9tICcuL2xpYi91dGlscy9pcyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi91dGlscy9tYWtlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3V0aWxzL3NpZ25hbC1zdG9yZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi91dGlscy91cGRhdGUnO1xuXG5leHBvcnQgdHlwZSB7IE5ndENhbWVyYSwgTmd0VGhyZWVFdmVudCB9IGZyb20gJy4vbGliL2V2ZW50cyc7XG5leHBvcnQgdHlwZSAqIGZyb20gJy4vbGliL3RocmVlLXR5cGVzJztcbmV4cG9ydCB0eXBlICogZnJvbSAnLi9saWIvdHlwZXMnO1xuIl19
@@ -1,27 +1,33 @@
1
- import { ChangeDetectionStrategy, ChangeDetectorRef, Component, DestroyRef, ElementRef, EnvironmentInjector, EventEmitter, Injector, Input, NgZone, Output, ViewChild, ViewContainerRef, computed, createEnvironmentInjector, effect, inject, } from '@angular/core';
2
- import { NgxResize, provideNgxResizeOptions } from 'ngx-resize';
1
+ import { ChangeDetectionStrategy, Component, DestroyRef, ElementRef, EnvironmentInjector, EventEmitter, Injector, Input, NgZone, Output, ViewChild, ViewContainerRef, afterNextRender, computed, createEnvironmentInjector, inject, signal, untracked, } from '@angular/core';
2
+ import { injectAutoEffect } from 'ngxtension/auto-effect';
3
+ import { NgxResize, provideResizeOptions } from 'ngxtension/resize';
3
4
  import * as THREE from 'three';
4
5
  import { createPointerEvents } from './dom/events';
5
- import { injectNgtLoader } from './loader';
6
6
  import { provideNgtRenderer } from './renderer';
7
7
  import { injectCanvasRootInitializer } from './roots';
8
8
  import { injectNgtStore, provideNgtStore, } from './store';
9
9
  import { is } from './utils/is';
10
- import { safeDetectChanges } from './utils/safe-detect-changes';
11
10
  import { signalStore } from './utils/signal-store';
12
11
  import * as i0 from "@angular/core";
13
12
  export class NgtCanvas {
13
+ set _sceneGraphInputs(value) {
14
+ this.sceneGraphInputs.set(value);
15
+ }
16
+ set _canvasInputs(value) {
17
+ this.canvasInputs.update(value);
18
+ }
14
19
  constructor() {
15
20
  this.store = injectNgtStore();
16
21
  this.initRoot = injectCanvasRootInitializer();
22
+ this.autoEffect = injectAutoEffect();
17
23
  this.host = inject(ElementRef);
18
24
  this.viewContainerRef = inject(ViewContainerRef);
19
- this.injector = inject(Injector);
20
- this.environmentInjector = inject(EnvironmentInjector);
21
25
  this.zone = inject(NgZone);
22
- this.destroyRef = inject(DestroyRef);
23
- this.cdr = inject(ChangeDetectorRef);
24
- this.inputs = signalStore({
26
+ this.environmentInjector = inject(EnvironmentInjector);
27
+ this.injector = inject(Injector);
28
+ this.compoundPrefixes = [];
29
+ this.sceneGraphInputs = signal({}, { equal: Object.is });
30
+ this.canvasInputs = signalStore({
25
31
  shadows: false,
26
32
  linear: false,
27
33
  flat: false,
@@ -31,102 +37,49 @@ export class NgtCanvas {
31
37
  dpr: [1, 2],
32
38
  events: createPointerEvents,
33
39
  });
34
- this.sceneGraphInputs = {};
35
- this.compoundPrefixes = [];
36
40
  this.created = new EventEmitter();
37
- this.inputsEventSource = this.inputs.select('eventSource');
38
- this.hbPointerEvents = computed(() => (!!this.inputsEventSource() ? 'none' : 'auto'));
39
- }
40
- set linear(linear) {
41
- this.inputs.set({ linear });
42
- }
43
- set legacy(legacy) {
44
- this.inputs.set({ legacy });
45
- }
46
- set flat(flat) {
47
- this.inputs.set({ flat });
48
- }
49
- set orthographic(orthographic) {
50
- this.inputs.set({ orthographic });
51
- }
52
- set frameloop(frameloop) {
53
- this.inputs.set({ frameloop });
54
- }
55
- set dpr(dpr) {
56
- this.inputs.set({ dpr });
57
- }
58
- set raycaster(raycaster) {
59
- this.inputs.set({ raycaster });
60
- }
61
- set shadows(shadows) {
62
- this.inputs.set({ shadows });
63
- }
64
- set camera(camera) {
65
- this.inputs.set({ camera });
66
- }
67
- set scene(scene) {
68
- this.inputs.set({ scene });
69
- }
70
- set gl(gl) {
71
- this.inputs.set({ gl });
72
- }
73
- set eventSource(eventSource) {
74
- this.inputs.set({ eventSource });
75
- }
76
- set eventPrefix(eventPrefix) {
77
- this.inputs.set({ eventPrefix });
78
- }
79
- set lookAt(lookAt) {
80
- this.inputs.set({ lookAt });
81
- }
82
- set performance(performance) {
83
- this.inputs.set({ performance });
84
- }
85
- ngOnChanges(changes) {
86
- if (changes['sceneGraphInputs'] && !changes['sceneGraphInputs'].firstChange && this.glRef) {
87
- this.setSceneGraphInputs();
88
- }
89
- }
90
- ngOnInit() {
91
- // NOTE: we resolve glCanvas at this point, setup the configurator
92
- this.configurator = this.initRoot(this.glCanvas.nativeElement);
93
- this.destroyRef.onDestroy(() => {
94
- this.glEnvironmentInjector?.destroy();
41
+ // NOTE: this signal is updated outside of Zone
42
+ this.resizeResult = signal({}, { equal: Object.is });
43
+ this.eventSource = this.canvasInputs.select('eventSource');
44
+ this.hbPointerEvents = computed(() => (this.eventSource() ? 'none' : 'auto'));
45
+ afterNextRender(() => {
46
+ this.zone.runOutsideAngular(() => {
47
+ this.configurator = this.initRoot(this.glCanvas.nativeElement);
48
+ this.noZoneResizeEffect();
49
+ this.noZoneSceneGraphInputsEffect();
50
+ });
51
+ });
52
+ inject(DestroyRef).onDestroy(() => {
95
53
  this.glRef?.destroy();
96
- this.resizeEffectRef?.destroy();
97
- injectNgtLoader.destroy();
54
+ this.glEnvironmentInjector?.destroy();
98
55
  this.configurator?.destroy();
99
56
  });
100
57
  }
101
- // NOTE: runs outside of Zone due to emitInZone: false
102
- onResize(result) {
103
- if (result.width > 0 && result.height > 0) {
104
- this.resizeEffectRef?.destroy();
105
- const inputs = this.inputs.select();
106
- // NOTE: go back into zone so that effect runs
107
- // TODO: Double-check when effect is made not depended on zone
108
- this.resizeEffectRef = this.zone.run(() => effect(() => {
109
- this.zone.runOutsideAngular(() => {
110
- if (!this.configurator)
111
- this.configurator = this.initRoot(this.glCanvas.nativeElement);
112
- this.configurator.configure({ ...inputs(), size: result });
58
+ noZoneResizeEffect() {
59
+ this.autoEffect(() => {
60
+ const resizeResult = this.resizeResult();
61
+ if (resizeResult.width > 0 && resizeResult.height > 0) {
62
+ if (!this.configurator)
63
+ this.configurator = this.initRoot(this.glCanvas.nativeElement);
64
+ this.configurator.configure({ ...this.canvasInputs.state(), size: resizeResult });
65
+ untracked(() => {
113
66
  if (this.glRef) {
114
- this.cdr.detectChanges();
67
+ this.glRef.changeDetectorRef.detectChanges();
115
68
  }
116
69
  else {
117
- this.render();
70
+ this.noZoneRender();
118
71
  }
119
72
  });
120
- }, { manualCleanup: true, injector: this.injector }));
121
- }
73
+ }
74
+ });
122
75
  }
123
- render() {
76
+ noZoneRender() {
77
+ // NOTE: destroy previous instances if existed
124
78
  this.glEnvironmentInjector?.destroy();
125
79
  this.glRef?.destroy();
126
- // Flag the canvas active, rendering will now begin
127
- this.store.set((state) => ({ internal: { ...state.internal, active: true } }));
128
- const inputs = this.inputs.get();
129
- const state = this.store.get();
80
+ // NOTE: Flag the canvas active, rendering will now begin
81
+ this.store.update((state) => ({ internal: { ...state.internal, active: true } }));
82
+ const [inputs, state] = [this.canvasInputs.snapshot, this.store.snapshot];
130
83
  // connect to event source
131
84
  state.events.connect?.(inputs.eventSource
132
85
  ? is.ref(inputs.eventSource)
@@ -137,115 +90,87 @@ export class NgtCanvas {
137
90
  if (inputs.eventPrefix) {
138
91
  state.setEvents({
139
92
  compute: (event, store) => {
140
- const innerState = store.get();
93
+ const { pointer, raycaster, camera, size } = store.snapshot;
141
94
  const x = event[(inputs.eventPrefix + 'X')];
142
95
  const y = event[(inputs.eventPrefix + 'Y')];
143
- innerState.pointer.set((x / innerState.size.width) * 2 - 1, -(y / innerState.size.height) * 2 + 1);
144
- innerState.raycaster.setFromCamera(innerState.pointer, innerState.camera);
96
+ pointer.set((x / size.width) * 2 - 1, -(y / size.height) * 2 + 1);
97
+ raycaster.setFromCamera(pointer, camera);
145
98
  },
146
99
  });
147
100
  }
148
101
  // emit created event if observed
149
102
  if (this.created.observed) {
150
- // but go back into zone to do so
151
- this.zone.run(() => {
152
- this.created.emit(this.store.get());
153
- });
103
+ this.created.emit(this.store.snapshot);
154
104
  }
155
105
  if (!this.store.get('events', 'connected')) {
156
106
  this.store.get('events').connect?.(this.glCanvas.nativeElement);
157
107
  }
158
- this.glEnvironmentInjector = createEnvironmentInjector([provideNgtRenderer(this.store, this.compoundPrefixes, this.cdr)], this.environmentInjector);
108
+ this.glEnvironmentInjector = createEnvironmentInjector([provideNgtRenderer(this.store, this.compoundPrefixes)], this.environmentInjector);
159
109
  this.glRef = this.viewContainerRef.createComponent(this.sceneGraph, {
160
110
  environmentInjector: this.glEnvironmentInjector,
161
111
  injector: this.injector,
162
112
  });
163
- this.overrideChangeDetectorRef();
164
- this.setSceneGraphInputs();
113
+ this.glRef.changeDetectorRef.detectChanges();
114
+ this.setSceneGraphInputs(untracked(this.sceneGraphInputs));
165
115
  }
166
- overrideChangeDetectorRef() {
167
- const originalDetectChanges = this.cdr.detectChanges.bind(this.cdr);
168
- this.cdr.detectChanges = () => {
169
- originalDetectChanges();
170
- safeDetectChanges(this.glRef?.changeDetectorRef);
171
- };
116
+ noZoneSceneGraphInputsEffect() {
117
+ this.autoEffect(() => {
118
+ this.setSceneGraphInputs(this.sceneGraphInputs());
119
+ });
172
120
  }
173
- setSceneGraphInputs() {
174
- this.zone.run(() => {
175
- if (this.glRef) {
176
- for (const [key, value] of Object.entries(this.sceneGraphInputs)) {
177
- this.glRef.setInput(key, value);
178
- }
179
- this.glRef.changeDetectorRef.detectChanges();
121
+ setSceneGraphInputs(sceneGraphInputs) {
122
+ if (this.glRef) {
123
+ for (const [key, value] of Object.entries(sceneGraphInputs)) {
124
+ this.glRef.setInput(key, value);
180
125
  }
181
- });
126
+ }
182
127
  }
183
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.2", ngImport: i0, type: NgtCanvas, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
184
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.2", type: NgtCanvas, isStandalone: true, selector: "ngt-canvas", inputs: { sceneGraph: "sceneGraph", sceneGraphInputs: "sceneGraphInputs", compoundPrefixes: "compoundPrefixes", linear: "linear", legacy: "legacy", flat: "flat", orthographic: "orthographic", frameloop: "frameloop", dpr: "dpr", raycaster: "raycaster", shadows: "shadows", camera: "camera", scene: "scene", gl: "gl", eventSource: "eventSource", eventPrefix: "eventPrefix", lookAt: "lookAt", performance: "performance" }, outputs: { created: "created" }, host: { properties: { "style.pointerEvents": "hbPointerEvents()" }, styleAttribute: "display: block;position: relative;width: 100%;height: 100%;overflow: hidden;" }, providers: [provideNgxResizeOptions({ emitInZone: false, emitInitialResult: true }), provideNgtStore()], viewQueries: [{ propertyName: "glCanvas", first: true, predicate: ["glCanvas"], descendants: true, static: true }], usesOnChanges: true, ngImport: i0, template: `
185
- <div (ngxResize)="onResize($event)" style="height: 100%; width: 100%;">
128
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type: NgtCanvas, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
129
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.1", type: NgtCanvas, isStandalone: true, selector: "ngt-canvas", inputs: { sceneGraph: "sceneGraph", compoundPrefixes: "compoundPrefixes", _sceneGraphInputs: ["sceneGraphInputs", "_sceneGraphInputs"], _canvasInputs: ["options", "_canvasInputs"] }, outputs: { created: "created" }, host: { properties: { "style.pointerEvents": "hbPointerEvents()" }, styleAttribute: "display: block;position: relative;width: 100%;height: 100%;overflow: hidden;" }, providers: [
130
+ provideResizeOptions({ emitInZone: false, emitInitialResult: true, debounce: 250 }),
131
+ provideNgtStore(),
132
+ ], viewQueries: [{ propertyName: "glCanvas", first: true, predicate: ["glCanvas"], descendants: true, static: true }], ngImport: i0, template: `
133
+ <div (ngxResize)="resizeResult.set($event)" style="height: 100%; width: 100%;">
186
134
  <canvas #glCanvas style="display: block;"></canvas>
187
135
  </div>
188
136
  `, isInline: true, dependencies: [{ kind: "directive", type: NgxResize, selector: "[ngxResize]", inputs: ["ngxResizeOptions"], outputs: ["ngxResize"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
189
137
  }
190
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.2", ngImport: i0, type: NgtCanvas, decorators: [{
138
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type: NgtCanvas, decorators: [{
191
139
  type: Component,
192
140
  args: [{
193
141
  selector: 'ngt-canvas',
194
142
  standalone: true,
195
143
  template: `
196
- <div (ngxResize)="onResize($event)" style="height: 100%; width: 100%;">
144
+ <div (ngxResize)="resizeResult.set($event)" style="height: 100%; width: 100%;">
197
145
  <canvas #glCanvas style="display: block;"></canvas>
198
146
  </div>
199
147
  `,
200
148
  imports: [NgxResize],
201
- providers: [provideNgxResizeOptions({ emitInZone: false, emitInitialResult: true }), provideNgtStore()],
149
+ providers: [
150
+ provideResizeOptions({ emitInZone: false, emitInitialResult: true, debounce: 250 }),
151
+ provideNgtStore(),
152
+ ],
202
153
  host: {
203
154
  style: 'display: block;position: relative;width: 100%;height: 100%;overflow: hidden;',
204
155
  '[style.pointerEvents]': 'hbPointerEvents()',
205
156
  },
206
157
  changeDetection: ChangeDetectionStrategy.OnPush,
207
158
  }]
208
- }], propDecorators: { sceneGraph: [{
159
+ }], ctorParameters: () => [], propDecorators: { sceneGraph: [{
209
160
  type: Input,
210
161
  args: [{ required: true }]
211
- }], sceneGraphInputs: [{
212
- type: Input
213
162
  }], compoundPrefixes: [{
214
163
  type: Input
215
- }], linear: [{
216
- type: Input
217
- }], legacy: [{
218
- type: Input
219
- }], flat: [{
220
- type: Input
221
- }], orthographic: [{
222
- type: Input
223
- }], frameloop: [{
224
- type: Input
225
- }], dpr: [{
226
- type: Input
227
- }], raycaster: [{
228
- type: Input
229
- }], shadows: [{
230
- type: Input
231
- }], camera: [{
232
- type: Input
233
- }], scene: [{
234
- type: Input
235
- }], gl: [{
236
- type: Input
237
- }], eventSource: [{
238
- type: Input
239
- }], eventPrefix: [{
240
- type: Input
241
- }], lookAt: [{
242
- type: Input
243
- }], performance: [{
244
- type: Input
164
+ }], _sceneGraphInputs: [{
165
+ type: Input,
166
+ args: [{ alias: 'sceneGraphInputs' }]
167
+ }], _canvasInputs: [{
168
+ type: Input,
169
+ args: [{ alias: 'options' }]
245
170
  }], created: [{
246
171
  type: Output
247
172
  }], glCanvas: [{
248
173
  type: ViewChild,
249
174
  args: ['glCanvas', { static: true }]
250
175
  }] } });
251
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"canvas.js","sourceRoot":"","sources":["../../../../../libs/core/src/lib/canvas.ts"],"names":[],"mappings":"AAAA,OAAO,EACN,uBAAuB,EACvB,iBAAiB,EACjB,SAAS,EACT,UAAU,EACV,UAAU,EACV,mBAAmB,EACnB,YAAY,EACZ,QAAQ,EACR,KAAK,EACL,MAAM,EACN,MAAM,EACN,SAAS,EACT,gBAAgB,EAChB,QAAQ,EACR,yBAAyB,EACzB,MAAM,EACN,MAAM,GAON,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,SAAS,EAAE,uBAAuB,EAAwB,MAAM,YAAY,CAAC;AACtF,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAC/B,OAAO,EAAE,mBAAmB,EAAE,MAAM,cAAc,CAAC;AAEnD,OAAO,EAAE,eAAe,EAAE,MAAM,UAAU,CAAC;AAC3C,OAAO,EAAE,kBAAkB,EAAE,MAAM,YAAY,CAAC;AAChD,OAAO,EAAE,2BAA2B,EAA8B,MAAM,SAAS,CAAC;AAClF,OAAO,EACN,cAAc,EACd,eAAe,GAMf,MAAM,SAAS,CAAC;AAGjB,OAAO,EAAE,EAAE,EAAE,MAAM,YAAY,CAAC;AAChC,OAAO,EAAE,iBAAiB,EAAE,MAAM,6BAA6B,CAAC;AAChE,OAAO,EAAE,WAAW,EAAuB,MAAM,sBAAsB,CAAC;;AAoFxE,MAAM,OAAO,SAAS;IAhBtB;QAiBS,UAAK,GAAG,cAAc,EAAE,CAAC;QACzB,aAAQ,GAAG,2BAA2B,EAAE,CAAC;QAEzC,SAAI,GAAG,MAAM,CAA0B,UAAU,CAAC,CAAC;QACnD,qBAAgB,GAAG,MAAM,CAAC,gBAAgB,CAAC,CAAC;QAC5C,aAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC,CAAC;QAC5B,wBAAmB,GAAG,MAAM,CAAC,mBAAmB,CAAC,CAAC;QAClD,SAAI,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC;QACtB,eAAU,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC;QAChC,QAAG,GAAG,MAAM,CAAC,iBAAiB,CAAC,CAAC;QAEhC,WAAM,GAAG,WAAW,CAAkB;YAC7C,OAAO,EAAE,KAAK;YACd,MAAM,EAAE,KAAK;YACb,IAAI,EAAE,KAAK;YACX,MAAM,EAAE,KAAK;YACb,YAAY,EAAE,KAAK;YACnB,SAAS,EAAE,QAAQ;YACnB,GAAG,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC;YACX,MAAM,EAAE,mBAAmB;SAC3B,CAAC,CAAC;QAGM,qBAAgB,GAAiB,EAAE,CAAC;QACpC,qBAAgB,GAAa,EAAE,CAAC;QA8D/B,YAAO,GAAG,IAAI,YAAY,EAAY,CAAC;QAEzC,sBAAiB,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC;QACpD,oBAAe,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,iBAAiB,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC;KAkI3F;IAjMA,IAAa,MAAM,CAAC,MAAe;QAClC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,MAAM,EAAE,CAAC,CAAC;IAC7B,CAAC;IAED,IAAa,MAAM,CAAC,MAAe;QAClC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,MAAM,EAAE,CAAC,CAAC;IAC7B,CAAC;IAED,IAAa,IAAI,CAAC,IAAa;QAC9B,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC;IAC3B,CAAC;IAED,IAAa,YAAY,CAAC,YAAqB;QAC9C,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,YAAY,EAAE,CAAC,CAAC;IACnC,CAAC;IAED,IAAa,SAAS,CAAC,SAAuC;QAC7D,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,SAAS,EAAE,CAAC,CAAC;IAChC,CAAC;IAED,IAAa,GAAG,CAAC,GAAW;QAC3B,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,GAAG,EAAE,CAAC,CAAC;IAC1B,CAAC;IAED,IAAa,SAAS,CAAC,SAAmC;QACzD,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,SAAS,EAAE,CAAC,CAAC;IAChC,CAAC;IAED,IAAa,OAAO,CAAC,OAAgD;QACpE,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,OAAO,EAAE,CAAC,CAAC;IAC9B,CAAC;IAED,IAAa,MAAM,CAAC,MAAiC;QACpD,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,MAAM,EAAE,CAAC,CAAC;IAC7B,CAAC;IAED,IAAa,KAAK,CAAC,KAA+B;QACjD,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,KAAK,EAAE,CAAC,CAAC;IAC5B,CAAC;IAED,IAAa,EAAE,CAAC,EAAyB;QACxC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC;IACzB,CAAC;IAED,IAAa,WAAW,CAAC,WAA2C;QACnE,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,WAAW,EAAE,CAAC,CAAC;IAClC,CAAC;IAED,IAAa,WAAW,CAAC,WAA2C;QACnE,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,WAAW,EAAE,CAAC,CAAC;IAClC,CAAC;IAED,IAAa,MAAM,CAAC,MAAiC;QACpD,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,MAAM,EAAE,CAAC,CAAC;IAC7B,CAAC;IAED,IAAa,WAAW,CAAC,WAA2C;QACnE,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,WAAW,EAAE,CAAC,CAAC;IAClC,CAAC;IAcD,WAAW,CAAC,OAAsB;QACjC,IAAI,OAAO,CAAC,kBAAkB,CAAC,IAAI,CAAC,OAAO,CAAC,kBAAkB,CAAC,CAAC,WAAW,IAAI,IAAI,CAAC,KAAK,EAAE;YAC1F,IAAI,CAAC,mBAAmB,EAAE,CAAC;SAC3B;IACF,CAAC;IAED,QAAQ;QACP,kEAAkE;QAClE,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAC;QAE/D,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,GAAG,EAAE;YAC9B,IAAI,CAAC,qBAAqB,EAAE,OAAO,EAAE,CAAC;YACtC,IAAI,CAAC,KAAK,EAAE,OAAO,EAAE,CAAC;YACtB,IAAI,CAAC,eAAe,EAAE,OAAO,EAAE,CAAC;YAChC,eAAe,CAAC,OAAO,EAAE,CAAC;YAC1B,IAAI,CAAC,YAAY,EAAE,OAAO,EAAE,CAAC;QAC9B,CAAC,CAAC,CAAC;IACJ,CAAC;IAED,sDAAsD;IACtD,QAAQ,CAAC,MAAuB;QAC/B,IAAI,MAAM,CAAC,KAAK,GAAG,CAAC,IAAI,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE;YAC1C,IAAI,CAAC,eAAe,EAAE,OAAO,EAAE,CAAC;YAEhC,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC;YACpC,8CAA8C;YAC9C,8DAA8D;YAC9D,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,CACzC,MAAM,CACL,GAAG,EAAE;gBACJ,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,GAAG,EAAE;oBAChC,IAAI,CAAC,IAAI,CAAC,YAAY;wBAAE,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAC;oBACvF,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,EAAE,GAAG,MAAM,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC,CAAC;oBAE3D,IAAI,IAAI,CAAC,KAAK,EAAE;wBACf,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;qBACzB;yBAAM;wBACN,IAAI,CAAC,MAAM,EAAE,CAAC;qBACd;gBACF,CAAC,CAAC,CAAC;YACJ,CAAC,EACD,EAAE,aAAa,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,CAChD,CACD,CAAC;SACF;IACF,CAAC;IAEO,MAAM;QACb,IAAI,CAAC,qBAAqB,EAAE,OAAO,EAAE,CAAC;QACtC,IAAI,CAAC,KAAK,EAAE,OAAO,EAAE,CAAC;QAEtB,mDAAmD;QACnD,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,EAAE,QAAQ,EAAE,EAAE,GAAG,KAAK,CAAC,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAE,EAAE,CAAC,CAAC,CAAC;QAE/E,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,EAAE,CAAC;QACjC,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC;QAE/B,0BAA0B;QAC1B,KAAK,CAAC,MAAM,CAAC,OAAO,EAAE,CACrB,MAAM,CAAC,WAAW;YACjB,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,MAAM,CAAC,WAAW,CAAC;gBAC3B,CAAC,CAAC,MAAM,CAAC,WAAW,CAAC,aAAa;gBAClC,CAAC,CAAC,MAAM,CAAC,WAAW;YACrB,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAC1B,CAAC;QAEF,gCAAgC;QAChC,IAAI,MAAM,CAAC,WAAW,EAAE;YACvB,KAAK,CAAC,SAAS,CAAC;gBACf,OAAO,EAAE,CAAC,KAAK,EAAE,KAAK,EAAE,EAAE;oBACzB,MAAM,UAAU,GAAG,KAAK,CAAC,GAAG,EAAE,CAAC;oBAC/B,MAAM,CAAC,GAAG,KAAK,CAAC,CAAC,MAAM,CAAC,WAAW,GAAG,GAAG,CAAsB,CAAW,CAAC;oBAC3E,MAAM,CAAC,GAAG,KAAK,CAAC,CAAC,MAAM,CAAC,WAAW,GAAG,GAAG,CAAsB,CAAW,CAAC;oBAC3E,UAAU,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC;oBACnG,UAAU,CAAC,SAAS,CAAC,aAAa,CAAC,UAAU,CAAC,OAAO,EAAE,UAAU,CAAC,MAAM,CAAC,CAAC;gBAC3E,CAAC;aACD,CAAC,CAAC;SACH;QAED,iCAAiC;QACjC,IAAI,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE;YAC1B,iCAAiC;YACjC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE;gBAClB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,CAAC;YACrC,CAAC,CAAC,CAAC;SACH;QAED,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,QAAQ,EAAE,WAAW,CAAC,EAAE;YAC3C,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC,OAAO,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAC;SAChE;QAED,IAAI,CAAC,qBAAqB,GAAG,yBAAyB,CACrD,CAAC,kBAAkB,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,gBAAgB,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,EACjE,IAAI,CAAC,mBAAmB,CACxB,CAAC;QACF,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,gBAAgB,CAAC,eAAe,CAAC,IAAI,CAAC,UAAU,EAAE;YACnE,mBAAmB,EAAE,IAAI,CAAC,qBAAqB;YAC/C,QAAQ,EAAE,IAAI,CAAC,QAAQ;SACvB,CAAC,CAAC;QACH,IAAI,CAAC,yBAAyB,EAAE,CAAC;QACjC,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAC5B,CAAC;IAEO,yBAAyB;QAChC,MAAM,qBAAqB,GAAG,IAAI,CAAC,GAAG,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QACpE,IAAI,CAAC,GAAG,CAAC,aAAa,GAAG,GAAG,EAAE;YAC7B,qBAAqB,EAAE,CAAC;YACxB,iBAAiB,CAAC,IAAI,CAAC,KAAK,EAAE,iBAAiB,CAAC,CAAC;QAClD,CAAC,CAAC;IACH,CAAC;IAEO,mBAAmB;QAC1B,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE;YAClB,IAAI,IAAI,CAAC,KAAK,EAAE;gBACf,KAAK,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,gBAAgB,CAAC,EAAE;oBACjE,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;iBAChC;gBACD,IAAI,CAAC,KAAK,CAAC,iBAAiB,CAAC,aAAa,EAAE,CAAC;aAC7C;QACF,CAAC,CAAC,CAAC;IACJ,CAAC;8GA3NW,SAAS;kGAAT,SAAS,oqBAPV,CAAC,uBAAuB,CAAC,EAAE,UAAU,EAAE,KAAK,EAAE,iBAAiB,EAAE,IAAI,EAAE,CAAC,EAAE,eAAe,EAAE,CAAC,mKAN7F;;;;EAIT,4DACS,SAAS;;2FAQP,SAAS;kBAhBrB,SAAS;mBAAC;oBACV,QAAQ,EAAE,YAAY;oBACtB,UAAU,EAAE,IAAI;oBAChB,QAAQ,EAAE;;;;EAIT;oBACD,OAAO,EAAE,CAAC,SAAS,CAAC;oBACpB,SAAS,EAAE,CAAC,uBAAuB,CAAC,EAAE,UAAU,EAAE,KAAK,EAAE,iBAAiB,EAAE,IAAI,EAAE,CAAC,EAAE,eAAe,EAAE,CAAC;oBACvG,IAAI,EAAE;wBACL,KAAK,EAAE,8EAA8E;wBACrF,uBAAuB,EAAE,mBAAmB;qBAC5C;oBACD,eAAe,EAAE,uBAAuB,CAAC,MAAM;iBAC/C;8BAwB2B,UAAU;sBAApC,KAAK;uBAAC,EAAE,QAAQ,EAAE,IAAI,EAAE;gBAChB,gBAAgB;sBAAxB,KAAK;gBACG,gBAAgB;sBAAxB,KAAK;gBAEO,MAAM;sBAAlB,KAAK;gBAIO,MAAM;sBAAlB,KAAK;gBAIO,IAAI;sBAAhB,KAAK;gBAIO,YAAY;sBAAxB,KAAK;gBAIO,SAAS;sBAArB,KAAK;gBAIO,GAAG;sBAAf,KAAK;gBAIO,SAAS;sBAArB,KAAK;gBAIO,OAAO;sBAAnB,KAAK;gBAIO,MAAM;sBAAlB,KAAK;gBAIO,KAAK;sBAAjB,KAAK;gBAIO,EAAE;sBAAd,KAAK;gBAIO,WAAW;sBAAvB,KAAK;gBAIO,WAAW;sBAAvB,KAAK;gBAIO,MAAM;sBAAlB,KAAK;gBAIO,WAAW;sBAAvB,KAAK;gBAII,OAAO;sBAAhB,MAAM;gBAKkC,QAAQ;sBAAhD,SAAS;uBAAC,UAAU,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE","sourcesContent":["import {\n\tChangeDetectionStrategy,\n\tChangeDetectorRef,\n\tComponent,\n\tDestroyRef,\n\tElementRef,\n\tEnvironmentInjector,\n\tEventEmitter,\n\tInjector,\n\tInput,\n\tNgZone,\n\tOutput,\n\tViewChild,\n\tViewContainerRef,\n\tcomputed,\n\tcreateEnvironmentInjector,\n\teffect,\n\tinject,\n\ttype ComponentRef,\n\ttype EffectRef,\n\ttype OnChanges,\n\ttype OnInit,\n\ttype SimpleChanges,\n\ttype Type,\n} from '@angular/core';\nimport { NgxResize, provideNgxResizeOptions, type NgxResizeResult } from 'ngx-resize';\nimport * as THREE from 'three';\nimport { createPointerEvents } from './dom/events';\nimport type { NgtCamera, NgtDomEvent, NgtEventManager } from './events';\nimport { injectNgtLoader } from './loader';\nimport { provideNgtRenderer } from './renderer';\nimport { injectCanvasRootInitializer, type NgtCanvasConfigurator } from './roots';\nimport {\n\tinjectNgtStore,\n\tprovideNgtStore,\n\ttype NgtDpr,\n\ttype NgtPerformance,\n\ttype NgtRenderer,\n\ttype NgtSize,\n\ttype NgtState,\n} from './store';\nimport type { NgtObject3DNode } from './three-types';\nimport type { NgtAnyRecord, NgtProperties } from './types';\nimport { is } from './utils/is';\nimport { safeDetectChanges } from './utils/safe-detect-changes';\nimport { signalStore, type NgtSignalStore } from './utils/signal-store';\n\nexport type NgtGLOptions =\n\t| NgtRenderer\n\t| ((canvas: HTMLCanvasElement) => NgtRenderer)\n\t| Partial<NgtProperties<THREE.WebGLRenderer> | THREE.WebGLRendererParameters>\n\t| undefined;\n\nexport type NgtCanvasInputs = {\n\t/** A threejs renderer instance or props that go into the default renderer */\n\tgl?: NgtGLOptions;\n\tsize?: NgtSize;\n\n\t/**\n\t * Enables shadows (by default PCFsoft). Can accept `gl.shadowMap` options for fine-tuning,\n\t * but also strings: 'basic' | 'percentage' | 'soft' | 'variance'.\n\t * @see https://threejs.org/docs/#api/en/renderers/WebGLRenderer.shadowMap\n\t */\n\tshadows?: boolean | 'basic' | 'percentage' | 'soft' | 'variance' | Partial<THREE.WebGLShadowMap>;\n\t/**\n\t * Disables three r139 color management.\n\t * @see https://threejs.org/docs/#manual/en/introduction/Color-management\n\t */\n\tlegacy?: boolean;\n\t/** Switch off automatic sRGB encoding and gamma correction */\n\tlinear?: boolean;\n\t/** Use `THREE.NoToneMapping` instead of `THREE.ACESFilmicToneMapping` */\n\tflat?: boolean;\n\t/** Creates an orthographic camera */\n\torthographic?: boolean;\n\t/**\n\t * R3F's render mode. Set to `demand` to only render on state change or `never` to take control.\n\t * @see https://docs.pmnd.rs/react-three-fiber/advanced/scaling-performance#on-demand-rendering\n\t */\n\tframeloop?: 'always' | 'demand' | 'never';\n\t/**\n\t * R3F performance options for adaptive performance.\n\t * @see https://docs.pmnd.rs/react-three-fiber/advanced/scaling-performance#movement-regression\n\t */\n\tperformance?: Partial<Omit<NgtPerformance, 'regress'>>;\n\t/** Target pixel ratio. Can clamp between a range: `[min, max]` */\n\tdpr?: NgtDpr;\n\t/** Props that go into the default raycaster */\n\traycaster?: Partial<THREE.Raycaster>;\n\t/** A `THREE.Scene` instance or props that go into the default scene */\n\tscene?: THREE.Scene | Partial<THREE.Scene>;\n\t/** A `Camera` instance or props that go into the default camera */\n\tcamera?: (\n\t\t| NgtCamera\n\t\t| Partial<\n\t\t\t\tNgtObject3DNode<THREE.Camera, typeof THREE.Camera> &\n\t\t\t\t\tNgtObject3DNode<THREE.PerspectiveCamera, typeof THREE.PerspectiveCamera> &\n\t\t\t\t\tNgtObject3DNode<THREE.OrthographicCamera, typeof THREE.OrthographicCamera>\n\t\t  >\n\t) & {\n\t\t/** Flags the camera as manual, putting projection into your own hands */\n\t\tmanual?: boolean;\n\t};\n\t/** An R3F event manager to manage elements' pointer events */\n\tevents?: (store: NgtSignalStore<NgtState>) => NgtEventManager<HTMLElement>;\n\t/** The target where events are being subscribed to, default: the div that wraps canvas */\n\teventSource?: HTMLElement | ElementRef<HTMLElement>;\n\t/** The event prefix that is cast into canvas pointer x/y events, default: \"offset\" */\n\teventPrefix?: 'offset' | 'client' | 'page' | 'layer' | 'screen';\n\t/** Default coordinate for the camera to look at */\n\tlookAt?: THREE.Vector3 | Parameters<THREE.Vector3['set']>;\n};\n\n@Component({\n\tselector: 'ngt-canvas',\n\tstandalone: true,\n\ttemplate: `\n\t\t<div (ngxResize)=\"onResize($event)\" style=\"height: 100%; width: 100%;\">\n\t\t\t<canvas #glCanvas style=\"display: block;\"></canvas>\n\t\t</div>\n\t`,\n\timports: [NgxResize],\n\tproviders: [provideNgxResizeOptions({ emitInZone: false, emitInitialResult: true }), provideNgtStore()],\n\thost: {\n\t\tstyle: 'display: block;position: relative;width: 100%;height: 100%;overflow: hidden;',\n\t\t'[style.pointerEvents]': 'hbPointerEvents()',\n\t},\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class NgtCanvas implements OnInit, OnChanges {\n\tprivate store = injectNgtStore();\n\tprivate initRoot = injectCanvasRootInitializer();\n\n\tprivate host = inject<ElementRef<HTMLElement>>(ElementRef);\n\tprivate viewContainerRef = inject(ViewContainerRef);\n\tprivate injector = inject(Injector);\n\tprivate environmentInjector = inject(EnvironmentInjector);\n\tprivate zone = inject(NgZone);\n\tprivate destroyRef = inject(DestroyRef);\n\tprivate cdr = inject(ChangeDetectorRef);\n\n\tprivate inputs = signalStore<NgtCanvasInputs>({\n\t\tshadows: false,\n\t\tlinear: false,\n\t\tflat: false,\n\t\tlegacy: false,\n\t\torthographic: false,\n\t\tframeloop: 'always',\n\t\tdpr: [1, 2],\n\t\tevents: createPointerEvents,\n\t});\n\n\t@Input({ required: true }) sceneGraph!: Type<unknown>;\n\t@Input() sceneGraphInputs: NgtAnyRecord = {};\n\t@Input() compoundPrefixes: string[] = [];\n\n\t@Input() set linear(linear: boolean) {\n\t\tthis.inputs.set({ linear });\n\t}\n\n\t@Input() set legacy(legacy: boolean) {\n\t\tthis.inputs.set({ legacy });\n\t}\n\n\t@Input() set flat(flat: boolean) {\n\t\tthis.inputs.set({ flat });\n\t}\n\n\t@Input() set orthographic(orthographic: boolean) {\n\t\tthis.inputs.set({ orthographic });\n\t}\n\n\t@Input() set frameloop(frameloop: NgtCanvasInputs['frameloop']) {\n\t\tthis.inputs.set({ frameloop });\n\t}\n\n\t@Input() set dpr(dpr: NgtDpr) {\n\t\tthis.inputs.set({ dpr });\n\t}\n\n\t@Input() set raycaster(raycaster: Partial<THREE.Raycaster>) {\n\t\tthis.inputs.set({ raycaster });\n\t}\n\n\t@Input() set shadows(shadows: boolean | Partial<THREE.WebGLShadowMap>) {\n\t\tthis.inputs.set({ shadows });\n\t}\n\n\t@Input() set camera(camera: NgtCanvasInputs['camera']) {\n\t\tthis.inputs.set({ camera });\n\t}\n\n\t@Input() set scene(scene: NgtCanvasInputs['scene']) {\n\t\tthis.inputs.set({ scene });\n\t}\n\n\t@Input() set gl(gl: NgtCanvasInputs['gl']) {\n\t\tthis.inputs.set({ gl });\n\t}\n\n\t@Input() set eventSource(eventSource: NgtCanvasInputs['eventSource']) {\n\t\tthis.inputs.set({ eventSource });\n\t}\n\n\t@Input() set eventPrefix(eventPrefix: NgtCanvasInputs['eventPrefix']) {\n\t\tthis.inputs.set({ eventPrefix });\n\t}\n\n\t@Input() set lookAt(lookAt: NgtCanvasInputs['lookAt']) {\n\t\tthis.inputs.set({ lookAt });\n\t}\n\n\t@Input() set performance(performance: NgtCanvasInputs['performance']) {\n\t\tthis.inputs.set({ performance });\n\t}\n\n\t@Output() created = new EventEmitter<NgtState>();\n\n\tprivate inputsEventSource = this.inputs.select('eventSource');\n\tprotected hbPointerEvents = computed(() => (!!this.inputsEventSource() ? 'none' : 'auto'));\n\n\t@ViewChild('glCanvas', { static: true }) glCanvas!: ElementRef<HTMLCanvasElement>;\n\n\tprivate resizeEffectRef?: EffectRef;\n\tprivate configurator?: NgtCanvasConfigurator;\n\tprivate glEnvironmentInjector?: EnvironmentInjector;\n\tprivate glRef?: ComponentRef<unknown>;\n\n\tngOnChanges(changes: SimpleChanges): void {\n\t\tif (changes['sceneGraphInputs'] && !changes['sceneGraphInputs'].firstChange && this.glRef) {\n\t\t\tthis.setSceneGraphInputs();\n\t\t}\n\t}\n\n\tngOnInit() {\n\t\t// NOTE: we resolve glCanvas at this point, setup the configurator\n\t\tthis.configurator = this.initRoot(this.glCanvas.nativeElement);\n\n\t\tthis.destroyRef.onDestroy(() => {\n\t\t\tthis.glEnvironmentInjector?.destroy();\n\t\t\tthis.glRef?.destroy();\n\t\t\tthis.resizeEffectRef?.destroy();\n\t\t\tinjectNgtLoader.destroy();\n\t\t\tthis.configurator?.destroy();\n\t\t});\n\t}\n\n\t// NOTE: runs outside of Zone due to emitInZone: false\n\tonResize(result: NgxResizeResult) {\n\t\tif (result.width > 0 && result.height > 0) {\n\t\t\tthis.resizeEffectRef?.destroy();\n\n\t\t\tconst inputs = this.inputs.select();\n\t\t\t// NOTE: go back into zone so that effect runs\n\t\t\t// TODO: Double-check when effect is made not depended on zone\n\t\t\tthis.resizeEffectRef = this.zone.run(() =>\n\t\t\t\teffect(\n\t\t\t\t\t() => {\n\t\t\t\t\t\tthis.zone.runOutsideAngular(() => {\n\t\t\t\t\t\t\tif (!this.configurator) this.configurator = this.initRoot(this.glCanvas.nativeElement);\n\t\t\t\t\t\t\tthis.configurator.configure({ ...inputs(), size: result });\n\n\t\t\t\t\t\t\tif (this.glRef) {\n\t\t\t\t\t\t\t\tthis.cdr.detectChanges();\n\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\tthis.render();\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t});\n\t\t\t\t\t},\n\t\t\t\t\t{ manualCleanup: true, injector: this.injector },\n\t\t\t\t),\n\t\t\t);\n\t\t}\n\t}\n\n\tprivate render() {\n\t\tthis.glEnvironmentInjector?.destroy();\n\t\tthis.glRef?.destroy();\n\n\t\t// Flag the canvas active, rendering will now begin\n\t\tthis.store.set((state) => ({ internal: { ...state.internal, active: true } }));\n\n\t\tconst inputs = this.inputs.get();\n\t\tconst state = this.store.get();\n\n\t\t// connect to event source\n\t\tstate.events.connect?.(\n\t\t\tinputs.eventSource\n\t\t\t\t? is.ref(inputs.eventSource)\n\t\t\t\t\t? inputs.eventSource.nativeElement\n\t\t\t\t\t: inputs.eventSource\n\t\t\t\t: this.host.nativeElement,\n\t\t);\n\n\t\t// setup compute for eventPrefix\n\t\tif (inputs.eventPrefix) {\n\t\t\tstate.setEvents({\n\t\t\t\tcompute: (event, store) => {\n\t\t\t\t\tconst innerState = store.get();\n\t\t\t\t\tconst x = event[(inputs.eventPrefix + 'X') as keyof NgtDomEvent] as number;\n\t\t\t\t\tconst y = event[(inputs.eventPrefix + 'Y') as keyof NgtDomEvent] as number;\n\t\t\t\t\tinnerState.pointer.set((x / innerState.size.width) * 2 - 1, -(y / innerState.size.height) * 2 + 1);\n\t\t\t\t\tinnerState.raycaster.setFromCamera(innerState.pointer, innerState.camera);\n\t\t\t\t},\n\t\t\t});\n\t\t}\n\n\t\t// emit created event if observed\n\t\tif (this.created.observed) {\n\t\t\t// but go back into zone to do so\n\t\t\tthis.zone.run(() => {\n\t\t\t\tthis.created.emit(this.store.get());\n\t\t\t});\n\t\t}\n\n\t\tif (!this.store.get('events', 'connected')) {\n\t\t\tthis.store.get('events').connect?.(this.glCanvas.nativeElement);\n\t\t}\n\n\t\tthis.glEnvironmentInjector = createEnvironmentInjector(\n\t\t\t[provideNgtRenderer(this.store, this.compoundPrefixes, this.cdr)],\n\t\t\tthis.environmentInjector,\n\t\t);\n\t\tthis.glRef = this.viewContainerRef.createComponent(this.sceneGraph, {\n\t\t\tenvironmentInjector: this.glEnvironmentInjector,\n\t\t\tinjector: this.injector,\n\t\t});\n\t\tthis.overrideChangeDetectorRef();\n\t\tthis.setSceneGraphInputs();\n\t}\n\n\tprivate overrideChangeDetectorRef() {\n\t\tconst originalDetectChanges = this.cdr.detectChanges.bind(this.cdr);\n\t\tthis.cdr.detectChanges = () => {\n\t\t\toriginalDetectChanges();\n\t\t\tsafeDetectChanges(this.glRef?.changeDetectorRef);\n\t\t};\n\t}\n\n\tprivate setSceneGraphInputs() {\n\t\tthis.zone.run(() => {\n\t\t\tif (this.glRef) {\n\t\t\t\tfor (const [key, value] of Object.entries(this.sceneGraphInputs)) {\n\t\t\t\t\tthis.glRef.setInput(key, value);\n\t\t\t\t}\n\t\t\t\tthis.glRef.changeDetectorRef.detectChanges();\n\t\t\t}\n\t\t});\n\t}\n}\n"]}
176
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"canvas.js","sourceRoot":"","sources":["../../../../../libs/core/src/lib/canvas.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n\tChangeDetectionStrategy,\n\tComponent,\n\tDestroyRef,\n\tElementRef,\n\tEnvironmentInjector,\n\tEventEmitter,\n\tInjector,\n\tInput,\n\tNgZone,\n\tOutput,\n\tViewChild,\n\tViewContainerRef,\n\tafterNextRender,\n\tcomputed,\n\tcreateEnvironmentInjector,\n\tinject,\n\tsignal,\n\tuntracked,\n\ttype ComponentRef,\n\ttype Type,\n} from '@angular/core';\nimport { injectAutoEffect } from 'ngxtension/auto-effect';\nimport { NgxResize, provideResizeOptions, type ResizeOptions, type ResizeResult } from 'ngxtension/resize';\nimport * as THREE from 'three';\nimport { createPointerEvents } from './dom/events';\nimport type { NgtCamera, NgtDomEvent, NgtEventManager } from './events';\nimport { provideNgtRenderer } from './renderer';\nimport { injectCanvasRootInitializer, type NgtCanvasConfigurator, type NgtCanvasElement } from './roots';\nimport {\n\tinjectNgtStore,\n\tprovideNgtStore,\n\ttype NgtDpr,\n\ttype NgtPerformance,\n\ttype NgtRendererLike,\n\ttype NgtSize,\n\ttype NgtState,\n} from './store';\nimport type { NgtObject3DNode } from './three-types';\nimport type { NgtAnyRecord, NgtProperties } from './types';\nimport { is } from './utils/is';\nimport { signalStore, type NgtSignalStore } from './utils/signal-store';\n\nexport type NgtGLOptions =\n\t| NgtRendererLike\n\t| ((canvas: NgtCanvasElement) => NgtRendererLike)\n\t| Partial<NgtProperties<THREE.WebGLRenderer> | THREE.WebGLRendererParameters>\n\t| undefined;\n\nexport type NgtCanvasInputs = {\n\t/** A threejs renderer instance or props that go into the default renderer */\n\tgl?: NgtGLOptions;\n\t/** Dimensions to fit the renderer to. Will measure canvas dimensions if omitted */\n\tsize?: NgtSize;\n\t/**\n\t * Enables shadows (by default PCFsoft). Can accept `gl.shadowMap` options for fine-tuning,\n\t * but also strings: 'basic' | 'percentage' | 'soft' | 'variance'.\n\t * @see https://threejs.org/docs/#api/en/renderers/WebGLRenderer.shadowMap\n\t */\n\tshadows?: boolean | 'basic' | 'percentage' | 'soft' | 'variance' | Partial<THREE.WebGLShadowMap>;\n\t/**\n\t * Disables three r139 color management.\n\t * @see https://threejs.org/docs/#manual/en/introduction/Color-management\n\t */\n\tlegacy?: boolean;\n\t/** Switch off automatic sRGB color space and gamma correction */\n\tlinear?: boolean;\n\t/** Use `THREE.NoToneMapping` instead of `THREE.ACESFilmicToneMapping` */\n\tflat?: boolean;\n\t/** Creates an orthographic camera */\n\torthographic?: boolean;\n\t/**\n\t * R3F's render mode. Set to `demand` to only render on state change or `never` to take control.\n\t * @see https://docs.pmnd.rs/react-three-fiber/advanced/scaling-performance#on-demand-rendering\n\t */\n\tframeloop?: 'always' | 'demand' | 'never';\n\t/**\n\t * R3F performance options for adaptive performance.\n\t * @see https://docs.pmnd.rs/react-three-fiber/advanced/scaling-performance#movement-regression\n\t */\n\tperformance?: Partial<Omit<NgtPerformance, 'regress'>>;\n\t/** Target pixel ratio. Can clamp between a range: `[min, max]` */\n\tdpr?: NgtDpr;\n\t/** Props that go into the default raycaster */\n\traycaster?: Partial<THREE.Raycaster>;\n\t/** A `THREE.Scene` instance or props that go into the default scene */\n\tscene?: THREE.Scene | Partial<THREE.Scene>;\n\t/** A `Camera` instance or props that go into the default camera */\n\tcamera?: (\n\t\t| NgtCamera\n\t\t| Partial<\n\t\t\t\tNgtObject3DNode<THREE.Camera, typeof THREE.Camera> &\n\t\t\t\t\tNgtObject3DNode<THREE.PerspectiveCamera, typeof THREE.PerspectiveCamera> &\n\t\t\t\t\tNgtObject3DNode<THREE.OrthographicCamera, typeof THREE.OrthographicCamera>\n\t\t  >\n\t) & {\n\t\t/** Flags the camera as manual, putting projection into your own hands */\n\t\tmanual?: boolean;\n\t};\n\t/** An R3F event manager to manage elements' pointer events */\n\tevents?: (store: NgtSignalStore<NgtState>) => NgtEventManager<HTMLElement>;\n\t/** The target where events are being subscribed to, default: the div that wraps canvas */\n\teventSource?: HTMLElement | ElementRef<HTMLElement>;\n\t/** The event prefix that is cast into canvas pointer x/y events, default: \"offset\" */\n\teventPrefix?: 'offset' | 'client' | 'page' | 'layer' | 'screen';\n\t/** Default coordinate for the camera to look at */\n\tlookAt?: THREE.Vector3 | Parameters<THREE.Vector3['set']>;\n};\n\n@Component({\n\tselector: 'ngt-canvas',\n\tstandalone: true,\n\ttemplate: `\n\t\t<div (ngxResize)=\"resizeResult.set($event)\" style=\"height: 100%; width: 100%;\">\n\t\t\t<canvas #glCanvas style=\"display: block;\"></canvas>\n\t\t</div>\n\t`,\n\timports: [NgxResize],\n\tproviders: [\n\t\tprovideResizeOptions({ emitInZone: false, emitInitialResult: true, debounce: 250 } as ResizeOptions),\n\t\tprovideNgtStore(),\n\t],\n\thost: {\n\t\tstyle: 'display: block;position: relative;width: 100%;height: 100%;overflow: hidden;',\n\t\t'[style.pointerEvents]': 'hbPointerEvents()',\n\t},\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class NgtCanvas {\n\tprivate store = injectNgtStore();\n\tprivate initRoot = injectCanvasRootInitializer();\n\tprivate autoEffect = injectAutoEffect();\n\n\tprivate host = inject<ElementRef<HTMLElement>>(ElementRef);\n\tprivate viewContainerRef = inject(ViewContainerRef);\n\tprivate zone = inject(NgZone);\n\tprivate environmentInjector = inject(EnvironmentInjector);\n\tprivate injector = inject(Injector);\n\n\t@Input({ required: true }) sceneGraph!: Type<any>;\n\t@Input() compoundPrefixes: string[] = [];\n\n\tprivate sceneGraphInputs = signal<NgtAnyRecord>({}, { equal: Object.is });\n\t@Input({ alias: 'sceneGraphInputs' }) set _sceneGraphInputs(value: NgtAnyRecord) {\n\t\tthis.sceneGraphInputs.set(value);\n\t}\n\n\tprivate canvasInputs = signalStore<NgtCanvasInputs>({\n\t\tshadows: false,\n\t\tlinear: false,\n\t\tflat: false,\n\t\tlegacy: false,\n\t\torthographic: false,\n\t\tframeloop: 'always',\n\t\tdpr: [1, 2],\n\t\tevents: createPointerEvents,\n\t});\n\t@Input({ alias: 'options' }) set _canvasInputs(value: Partial<NgtCanvasInputs>) {\n\t\tthis.canvasInputs.update(value);\n\t}\n\n\t@Output() created = new EventEmitter<NgtState>();\n\n\t@ViewChild('glCanvas', { static: true }) glCanvas!: ElementRef<HTMLCanvasElement>;\n\n\t// NOTE: this signal is updated outside of Zone\n\tprotected resizeResult = signal<ResizeResult>({} as ResizeResult, { equal: Object.is });\n\n\tprivate eventSource = this.canvasInputs.select('eventSource');\n\tprotected hbPointerEvents = computed(() => (this.eventSource() ? 'none' : 'auto'));\n\n\tprivate configurator?: NgtCanvasConfigurator;\n\tprivate glEnvironmentInjector?: EnvironmentInjector;\n\tprivate glRef?: ComponentRef<unknown>;\n\n\tconstructor() {\n\t\tafterNextRender(() => {\n\t\t\tthis.zone.runOutsideAngular(() => {\n\t\t\t\tthis.configurator = this.initRoot(this.glCanvas.nativeElement);\n\t\t\t\tthis.noZoneResizeEffect();\n\t\t\t\tthis.noZoneSceneGraphInputsEffect();\n\t\t\t});\n\t\t});\n\n\t\tinject(DestroyRef).onDestroy(() => {\n\t\t\tthis.glRef?.destroy();\n\t\t\tthis.glEnvironmentInjector?.destroy();\n\t\t\tthis.configurator?.destroy();\n\t\t});\n\t}\n\n\tprivate noZoneResizeEffect() {\n\t\tthis.autoEffect(() => {\n\t\t\tconst resizeResult = this.resizeResult();\n\t\t\tif (resizeResult.width > 0 && resizeResult.height > 0) {\n\t\t\t\tif (!this.configurator) this.configurator = this.initRoot(this.glCanvas.nativeElement);\n\t\t\t\tthis.configurator.configure({ ...this.canvasInputs.state(), size: resizeResult });\n\n\t\t\t\tuntracked(() => {\n\t\t\t\t\tif (this.glRef) {\n\t\t\t\t\t\tthis.glRef.changeDetectorRef.detectChanges();\n\t\t\t\t\t} else {\n\t\t\t\t\t\tthis.noZoneRender();\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t}\n\t\t});\n\t}\n\n\tprivate noZoneRender() {\n\t\t// NOTE: destroy previous instances if existed\n\t\tthis.glEnvironmentInjector?.destroy();\n\t\tthis.glRef?.destroy();\n\n\t\t// NOTE: Flag the canvas active, rendering will now begin\n\t\tthis.store.update((state) => ({ internal: { ...state.internal, active: true } }));\n\n\t\tconst [inputs, state] = [this.canvasInputs.snapshot, this.store.snapshot];\n\n\t\t// connect to event source\n\t\tstate.events.connect?.(\n\t\t\tinputs.eventSource\n\t\t\t\t? is.ref(inputs.eventSource)\n\t\t\t\t\t? inputs.eventSource.nativeElement\n\t\t\t\t\t: inputs.eventSource\n\t\t\t\t: this.host.nativeElement,\n\t\t);\n\n\t\t// setup compute for eventPrefix\n\t\tif (inputs.eventPrefix) {\n\t\t\tstate.setEvents({\n\t\t\t\tcompute: (event, store) => {\n\t\t\t\t\tconst { pointer, raycaster, camera, size } = store.snapshot;\n\t\t\t\t\tconst x = event[(inputs.eventPrefix + 'X') as keyof NgtDomEvent] as number;\n\t\t\t\t\tconst y = event[(inputs.eventPrefix + 'Y') as keyof NgtDomEvent] as number;\n\t\t\t\t\tpointer.set((x / size.width) * 2 - 1, -(y / size.height) * 2 + 1);\n\t\t\t\t\traycaster.setFromCamera(pointer, camera);\n\t\t\t\t},\n\t\t\t});\n\t\t}\n\n\t\t// emit created event if observed\n\t\tif (this.created.observed) {\n\t\t\tthis.created.emit(this.store.snapshot);\n\t\t}\n\n\t\tif (!this.store.get('events', 'connected')) {\n\t\t\tthis.store.get('events').connect?.(this.glCanvas.nativeElement);\n\t\t}\n\n\t\tthis.glEnvironmentInjector = createEnvironmentInjector(\n\t\t\t[provideNgtRenderer(this.store, this.compoundPrefixes)],\n\t\t\tthis.environmentInjector,\n\t\t);\n\t\tthis.glRef = this.viewContainerRef.createComponent(this.sceneGraph, {\n\t\t\tenvironmentInjector: this.glEnvironmentInjector,\n\t\t\tinjector: this.injector,\n\t\t});\n\n\t\tthis.glRef.changeDetectorRef.detectChanges();\n\t\tthis.setSceneGraphInputs(untracked(this.sceneGraphInputs));\n\t}\n\n\tprivate noZoneSceneGraphInputsEffect() {\n\t\tthis.autoEffect(() => {\n\t\t\tthis.setSceneGraphInputs(this.sceneGraphInputs());\n\t\t});\n\t}\n\n\tprivate setSceneGraphInputs(sceneGraphInputs: NgtAnyRecord) {\n\t\tif (this.glRef) {\n\t\t\tfor (const [key, value] of Object.entries(sceneGraphInputs)) {\n\t\t\t\tthis.glRef.setInput(key, value);\n\t\t\t}\n\t\t}\n\t}\n}\n"]}
@@ -1,5 +1,5 @@
1
1
  import { Directive, Input } from '@angular/core';
2
- import { NgtCommonDirective } from './common';
2
+ import { NgtCommonDirective, provideNodeType } from './common';
3
3
  import * as i0 from "@angular/core";
4
4
  export class NgtArgs extends NgtCommonDirective {
5
5
  constructor() {
@@ -23,13 +23,13 @@ export class NgtArgs extends NgtCommonDirective {
23
23
  validate() {
24
24
  return !this.injected && !!this.injectedArgs.length;
25
25
  }
26
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.2", ngImport: i0, type: NgtArgs, deps: null, target: i0.ɵɵFactoryTarget.Directive }); }
27
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.2", type: NgtArgs, isStandalone: true, selector: "ng-template[args]", inputs: { args: "args" }, usesInheritance: true, ngImport: i0 }); }
26
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type: NgtArgs, deps: null, target: i0.ɵɵFactoryTarget.Directive }); }
27
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.2.1", type: NgtArgs, isStandalone: true, selector: "ng-template[args]", inputs: { args: "args" }, providers: [provideNodeType('args')], usesInheritance: true, ngImport: i0 }); }
28
28
  }
29
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.2", ngImport: i0, type: NgtArgs, decorators: [{
29
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type: NgtArgs, decorators: [{
30
30
  type: Directive,
31
- args: [{ selector: 'ng-template[args]', standalone: true }]
31
+ args: [{ selector: 'ng-template[args]', standalone: true, providers: [provideNodeType('args')] }]
32
32
  }], propDecorators: { args: [{
33
33
  type: Input
34
34
  }] } });
35
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXJncy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29yZS9zcmMvbGliL2RpcmVjdGl2ZXMvYXJncy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNqRCxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxVQUFVLENBQUM7O0FBRzlDLE1BQU0sT0FBTyxPQUFxQyxTQUFRLGtCQUFrQjtJQUQ1RTs7UUFFUyxpQkFBWSxHQUFVLEVBQXNCLENBQUM7S0FvQnJEO0lBbEJBLElBQWEsSUFBSSxDQUFDLElBQWtCO1FBQ25DLElBQUksSUFBSSxJQUFJLElBQUksSUFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsTUFBTSxLQUFLLENBQUMsSUFBSSxJQUFJLENBQUMsQ0FBQyxDQUFDLEtBQUssSUFBSSxDQUFDO1lBQUUsT0FBTztRQUM1RixJQUFJLENBQUMsUUFBUSxHQUFHLEtBQUssQ0FBQztRQUN0QixJQUFJLENBQUMsWUFBWSxHQUFHLElBQUksQ0FBQztRQUN6QixJQUFJLENBQUMsVUFBVSxFQUFFLENBQUM7SUFDbkIsQ0FBQztJQUVELElBQUksSUFBSTtRQUNQLElBQUksSUFBSSxDQUFDLFFBQVEsRUFBRSxFQUFFO1lBQ3BCLElBQUksQ0FBQyxRQUFRLEdBQUcsSUFBSSxDQUFDO1lBQ3JCLE9BQU8sSUFBSSxDQUFDLFlBQVksQ0FBQztTQUN6QjtRQUNELE9BQU8sSUFBSSxDQUFDO0lBQ2IsQ0FBQztJQUVELFFBQVE7UUFDUCxPQUFPLENBQUMsSUFBSSxDQUFDLFFBQVEsSUFBSSxDQUFDLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxNQUFNLENBQUM7SUFDckQsQ0FBQzs4R0FwQlcsT0FBTztrR0FBUCxPQUFPOzsyRkFBUCxPQUFPO2tCQURuQixTQUFTO21CQUFDLEVBQUUsUUFBUSxFQUFFLG1CQUFtQixFQUFFLFVBQVUsRUFBRSxJQUFJLEVBQUU7OEJBSWhELElBQUk7c0JBQWhCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBOZ3RDb21tb25EaXJlY3RpdmUgfSBmcm9tICcuL2NvbW1vbic7XG5cbkBEaXJlY3RpdmUoeyBzZWxlY3RvcjogJ25nLXRlbXBsYXRlW2FyZ3NdJywgc3RhbmRhbG9uZTogdHJ1ZSB9KVxuZXhwb3J0IGNsYXNzIE5ndEFyZ3M8VEFyZ3MgZXh0ZW5kcyBhbnlbXSA9IGFueVtdPiBleHRlbmRzIE5ndENvbW1vbkRpcmVjdGl2ZSB7XG5cdHByaXZhdGUgaW5qZWN0ZWRBcmdzOiBUQXJncyA9IFtdIGFzIHVua25vd24gYXMgVEFyZ3M7XG5cblx0QElucHV0KCkgc2V0IGFyZ3MoYXJnczogVEFyZ3MgfCBudWxsKSB7XG5cdFx0aWYgKGFyZ3MgPT0gbnVsbCB8fCAhQXJyYXkuaXNBcnJheShhcmdzKSB8fCAoYXJncy5sZW5ndGggPT09IDEgJiYgYXJnc1swXSA9PT0gbnVsbCkpIHJldHVybjtcblx0XHR0aGlzLmluamVjdGVkID0gZmFsc2U7XG5cdFx0dGhpcy5pbmplY3RlZEFyZ3MgPSBhcmdzO1xuXHRcdHRoaXMuY3JlYXRlVmlldygpO1xuXHR9XG5cblx0Z2V0IGFyZ3MoKSB7XG5cdFx0aWYgKHRoaXMudmFsaWRhdGUoKSkge1xuXHRcdFx0dGhpcy5pbmplY3RlZCA9IHRydWU7XG5cdFx0XHRyZXR1cm4gdGhpcy5pbmplY3RlZEFyZ3M7XG5cdFx0fVxuXHRcdHJldHVybiBudWxsO1xuXHR9XG5cblx0dmFsaWRhdGUoKSB7XG5cdFx0cmV0dXJuICF0aGlzLmluamVjdGVkICYmICEhdGhpcy5pbmplY3RlZEFyZ3MubGVuZ3RoO1xuXHR9XG59XG4iXX0=
35
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXJncy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29yZS9zcmMvbGliL2RpcmVjdGl2ZXMvYXJncy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNqRCxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsZUFBZSxFQUFFLE1BQU0sVUFBVSxDQUFDOztBQUcvRCxNQUFNLE9BQU8sT0FBcUMsU0FBUSxrQkFBa0I7SUFENUU7O1FBRVMsaUJBQVksR0FBVSxFQUFzQixDQUFDO0tBb0JyRDtJQWxCQSxJQUFhLElBQUksQ0FBQyxJQUFrQjtRQUNuQyxJQUFJLElBQUksSUFBSSxJQUFJLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sS0FBSyxDQUFDLElBQUksSUFBSSxDQUFDLENBQUMsQ0FBQyxLQUFLLElBQUksQ0FBQztZQUFFLE9BQU87UUFDNUYsSUFBSSxDQUFDLFFBQVEsR0FBRyxLQUFLLENBQUM7UUFDdEIsSUFBSSxDQUFDLFlBQVksR0FBRyxJQUFJLENBQUM7UUFDekIsSUFBSSxDQUFDLFVBQVUsRUFBRSxDQUFDO0lBQ25CLENBQUM7SUFFRCxJQUFJLElBQUk7UUFDUCxJQUFJLElBQUksQ0FBQyxRQUFRLEVBQUUsRUFBRSxDQUFDO1lBQ3JCLElBQUksQ0FBQyxRQUFRLEdBQUcsSUFBSSxDQUFDO1lBQ3JCLE9BQU8sSUFBSSxDQUFDLFlBQVksQ0FBQztRQUMxQixDQUFDO1FBQ0QsT0FBTyxJQUFJLENBQUM7SUFDYixDQUFDO0lBRUQsUUFBUTtRQUNQLE9BQU8sQ0FBQyxJQUFJLENBQUMsUUFBUSxJQUFJLENBQUMsQ0FBQyxJQUFJLENBQUMsWUFBWSxDQUFDLE1BQU0sQ0FBQztJQUNyRCxDQUFDOzhHQXBCVyxPQUFPO2tHQUFQLE9BQU8sMEZBRHFELENBQUMsZUFBZSxDQUFDLE1BQU0sQ0FBQyxDQUFDOzsyRkFDckYsT0FBTztrQkFEbkIsU0FBUzttQkFBQyxFQUFFLFFBQVEsRUFBRSxtQkFBbUIsRUFBRSxVQUFVLEVBQUUsSUFBSSxFQUFFLFNBQVMsRUFBRSxDQUFDLGVBQWUsQ0FBQyxNQUFNLENBQUMsQ0FBQyxFQUFFOzhCQUl0RixJQUFJO3NCQUFoQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTmd0Q29tbW9uRGlyZWN0aXZlLCBwcm92aWRlTm9kZVR5cGUgfSBmcm9tICcuL2NvbW1vbic7XG5cbkBEaXJlY3RpdmUoeyBzZWxlY3RvcjogJ25nLXRlbXBsYXRlW2FyZ3NdJywgc3RhbmRhbG9uZTogdHJ1ZSwgcHJvdmlkZXJzOiBbcHJvdmlkZU5vZGVUeXBlKCdhcmdzJyldIH0pXG5leHBvcnQgY2xhc3MgTmd0QXJnczxUQXJncyBleHRlbmRzIGFueVtdID0gYW55W10+IGV4dGVuZHMgTmd0Q29tbW9uRGlyZWN0aXZlIHtcblx0cHJpdmF0ZSBpbmplY3RlZEFyZ3M6IFRBcmdzID0gW10gYXMgdW5rbm93biBhcyBUQXJncztcblxuXHRASW5wdXQoKSBzZXQgYXJncyhhcmdzOiBUQXJncyB8IG51bGwpIHtcblx0XHRpZiAoYXJncyA9PSBudWxsIHx8ICFBcnJheS5pc0FycmF5KGFyZ3MpIHx8IChhcmdzLmxlbmd0aCA9PT0gMSAmJiBhcmdzWzBdID09PSBudWxsKSkgcmV0dXJuO1xuXHRcdHRoaXMuaW5qZWN0ZWQgPSBmYWxzZTtcblx0XHR0aGlzLmluamVjdGVkQXJncyA9IGFyZ3M7XG5cdFx0dGhpcy5jcmVhdGVWaWV3KCk7XG5cdH1cblxuXHRnZXQgYXJncygpIHtcblx0XHRpZiAodGhpcy52YWxpZGF0ZSgpKSB7XG5cdFx0XHR0aGlzLmluamVjdGVkID0gdHJ1ZTtcblx0XHRcdHJldHVybiB0aGlzLmluamVjdGVkQXJncztcblx0XHR9XG5cdFx0cmV0dXJuIG51bGw7XG5cdH1cblxuXHR2YWxpZGF0ZSgpIHtcblx0XHRyZXR1cm4gIXRoaXMuaW5qZWN0ZWQgJiYgISF0aGlzLmluamVjdGVkQXJncy5sZW5ndGg7XG5cdH1cbn1cbiJdfQ==
@@ -1,21 +1,22 @@
1
1
  import { DestroyRef, Directive, NgZone, TemplateRef, ViewContainerRef, inject, } from '@angular/core';
2
+ import { createInjectionToken } from 'ngxtension/create-injection-token';
2
3
  import { SPECIAL_INTERNAL_ADD_COMMENT } from '../renderer/constants';
3
- import { safeDetectChanges } from '../utils/safe-detect-changes';
4
4
  import * as i0 from "@angular/core";
5
+ export const [injectNodeType, provideNodeType] = createInjectionToken(() => '', {
6
+ isRoot: false,
7
+ });
5
8
  export class NgtCommonDirective {
6
- static { this.processComment = true; }
7
9
  constructor() {
8
10
  this.vcr = inject(ViewContainerRef);
9
11
  this.zone = inject(NgZone);
10
12
  this.template = inject(TemplateRef);
13
+ this.nodeType = injectNodeType();
11
14
  this.injected = false;
12
15
  this.shouldCreateView = true;
13
- if (NgtCommonDirective.processComment) {
14
- const commentNode = this.vcr.element.nativeElement;
15
- if (commentNode[SPECIAL_INTERNAL_ADD_COMMENT]) {
16
- commentNode[SPECIAL_INTERNAL_ADD_COMMENT]();
17
- delete commentNode[SPECIAL_INTERNAL_ADD_COMMENT];
18
- }
16
+ const commentNode = this.vcr.element.nativeElement;
17
+ if (commentNode[SPECIAL_INTERNAL_ADD_COMMENT]) {
18
+ commentNode[SPECIAL_INTERNAL_ADD_COMMENT](this.nodeType);
19
+ delete commentNode[SPECIAL_INTERNAL_ADD_COMMENT];
19
20
  }
20
21
  inject(DestroyRef).onDestroy(() => {
21
22
  this.view?.destroy();
@@ -28,14 +29,14 @@ export class NgtCommonDirective {
28
29
  this.view.destroy();
29
30
  }
30
31
  this.view = this.vcr.createEmbeddedView(this.template);
31
- safeDetectChanges(this.view);
32
+ this.view.detectChanges();
32
33
  }
33
34
  });
34
35
  }
35
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.2", ngImport: i0, type: NgtCommonDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
36
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.2", type: NgtCommonDirective, ngImport: i0 }); }
36
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type: NgtCommonDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
37
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.2.1", type: NgtCommonDirective, ngImport: i0 }); }
37
38
  }
38
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.2", ngImport: i0, type: NgtCommonDirective, decorators: [{
39
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type: NgtCommonDirective, decorators: [{
39
40
  type: Directive
40
- }], ctorParameters: function () { return []; } });
41
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tbW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb3JlL3NyYy9saWIvZGlyZWN0aXZlcy9jb21tb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNOLFVBQVUsRUFDVixTQUFTLEVBQ1QsTUFBTSxFQUNOLFdBQVcsRUFDWCxnQkFBZ0IsRUFDaEIsTUFBTSxHQUVOLE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFBRSw0QkFBNEIsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQ3JFLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLDhCQUE4QixDQUFDOztBQUdqRSxNQUFNLE9BQWdCLGtCQUFrQjthQUN0QixtQkFBYyxHQUFHLElBQUksQUFBUCxDQUFRO0lBVXZDO1FBUlEsUUFBRyxHQUFHLE1BQU0sQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO1FBQy9CLFNBQUksR0FBRyxNQUFNLENBQUMsTUFBTSxDQUFDLENBQUM7UUFDdEIsYUFBUSxHQUFHLE1BQU0sQ0FBQyxXQUFXLENBQUMsQ0FBQztRQUU3QixhQUFRLEdBQUcsS0FBSyxDQUFDO1FBQ2pCLHFCQUFnQixHQUFHLElBQUksQ0FBQztRQUlqQyxJQUFJLGtCQUFrQixDQUFDLGNBQWMsRUFBRTtZQUN0QyxNQUFNLFdBQVcsR0FBRyxJQUFJLENBQUMsR0FBRyxDQUFDLE9BQU8sQ0FBQyxhQUFhLENBQUM7WUFDbkQsSUFBSSxXQUFXLENBQUMsNEJBQTRCLENBQUMsRUFBRTtnQkFDOUMsV0FBVyxDQUFDLDRCQUE0QixDQUFDLEVBQUUsQ0FBQztnQkFDNUMsT0FBTyxXQUFXLENBQUMsNEJBQTRCLENBQUMsQ0FBQzthQUNqRDtTQUNEO1FBRUQsTUFBTSxDQUFDLFVBQVUsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxHQUFHLEVBQUU7WUFDakMsSUFBSSxDQUFDLElBQUksRUFBRSxPQUFPLEVBQUUsQ0FBQztRQUN0QixDQUFDLENBQUMsQ0FBQztJQUNKLENBQUM7SUFJUyxVQUFVO1FBQ25CLElBQUksQ0FBQyxJQUFJLENBQUMsaUJBQWlCLENBQUMsR0FBRyxFQUFFO1lBQ2hDLElBQUksSUFBSSxDQUFDLGdCQUFnQixFQUFFO2dCQUMxQixJQUFJLElBQUksQ0FBQyxJQUFJLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLFNBQVMsRUFBRTtvQkFDdEMsSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQztpQkFDcEI7Z0JBQ0QsSUFBSSxDQUFDLElBQUksR0FBRyxJQUFJLENBQUMsR0FBRyxDQUFDLGtCQUFrQixDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQztnQkFDdkQsaUJBQWlCLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO2FBQzdCO1FBQ0YsQ0FBQyxDQUFDLENBQUM7SUFDSixDQUFDOzhHQXJDb0Isa0JBQWtCO2tHQUFsQixrQkFBa0I7OzJGQUFsQixrQkFBa0I7a0JBRHZDLFNBQVMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuXHREZXN0cm95UmVmLFxuXHREaXJlY3RpdmUsXG5cdE5nWm9uZSxcblx0VGVtcGxhdGVSZWYsXG5cdFZpZXdDb250YWluZXJSZWYsXG5cdGluamVjdCxcblx0dHlwZSBFbWJlZGRlZFZpZXdSZWYsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgU1BFQ0lBTF9JTlRFUk5BTF9BRERfQ09NTUVOVCB9IGZyb20gJy4uL3JlbmRlcmVyL2NvbnN0YW50cyc7XG5pbXBvcnQgeyBzYWZlRGV0ZWN0Q2hhbmdlcyB9IGZyb20gJy4uL3V0aWxzL3NhZmUtZGV0ZWN0LWNoYW5nZXMnO1xuXG5ARGlyZWN0aXZlKClcbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBOZ3RDb21tb25EaXJlY3RpdmUge1xuXHRwcm90ZWN0ZWQgc3RhdGljIHByb2Nlc3NDb21tZW50ID0gdHJ1ZTtcblxuXHRwcml2YXRlIHZjciA9IGluamVjdChWaWV3Q29udGFpbmVyUmVmKTtcblx0cHJpdmF0ZSB6b25lID0gaW5qZWN0KE5nWm9uZSk7XG5cdHByaXZhdGUgdGVtcGxhdGUgPSBpbmplY3QoVGVtcGxhdGVSZWYpO1xuXG5cdHByb3RlY3RlZCBpbmplY3RlZCA9IGZhbHNlO1xuXHRwcm90ZWN0ZWQgc2hvdWxkQ3JlYXRlVmlldyA9IHRydWU7XG5cdHByaXZhdGUgdmlldz86IEVtYmVkZGVkVmlld1JlZjx1bmtub3duPjtcblxuXHRjb25zdHJ1Y3RvcigpIHtcblx0XHRpZiAoTmd0Q29tbW9uRGlyZWN0aXZlLnByb2Nlc3NDb21tZW50KSB7XG5cdFx0XHRjb25zdCBjb21tZW50Tm9kZSA9IHRoaXMudmNyLmVsZW1lbnQubmF0aXZlRWxlbWVudDtcblx0XHRcdGlmIChjb21tZW50Tm9kZVtTUEVDSUFMX0lOVEVSTkFMX0FERF9DT01NRU5UXSkge1xuXHRcdFx0XHRjb21tZW50Tm9kZVtTUEVDSUFMX0lOVEVSTkFMX0FERF9DT01NRU5UXSgpO1xuXHRcdFx0XHRkZWxldGUgY29tbWVudE5vZGVbU1BFQ0lBTF9JTlRFUk5BTF9BRERfQ09NTUVOVF07XG5cdFx0XHR9XG5cdFx0fVxuXG5cdFx0aW5qZWN0KERlc3Ryb3lSZWYpLm9uRGVzdHJveSgoKSA9PiB7XG5cdFx0XHR0aGlzLnZpZXc/LmRlc3Ryb3koKTtcblx0XHR9KTtcblx0fVxuXG5cdGFic3RyYWN0IHZhbGlkYXRlKCk6IGJvb2xlYW47XG5cblx0cHJvdGVjdGVkIGNyZWF0ZVZpZXcoKSB7XG5cdFx0dGhpcy56b25lLnJ1bk91dHNpZGVBbmd1bGFyKCgpID0+IHtcblx0XHRcdGlmICh0aGlzLnNob3VsZENyZWF0ZVZpZXcpIHtcblx0XHRcdFx0aWYgKHRoaXMudmlldyAmJiAhdGhpcy52aWV3LmRlc3Ryb3llZCkge1xuXHRcdFx0XHRcdHRoaXMudmlldy5kZXN0cm95KCk7XG5cdFx0XHRcdH1cblx0XHRcdFx0dGhpcy52aWV3ID0gdGhpcy52Y3IuY3JlYXRlRW1iZWRkZWRWaWV3KHRoaXMudGVtcGxhdGUpO1xuXHRcdFx0XHRzYWZlRGV0ZWN0Q2hhbmdlcyh0aGlzLnZpZXcpO1xuXHRcdFx0fVxuXHRcdH0pO1xuXHR9XG59XG4iXX0=
41
+ }], ctorParameters: () => [] });
42
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tbW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb3JlL3NyYy9saWIvZGlyZWN0aXZlcy9jb21tb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNOLFVBQVUsRUFDVixTQUFTLEVBQ1QsTUFBTSxFQUNOLFdBQVcsRUFDWCxnQkFBZ0IsRUFDaEIsTUFBTSxHQUVOLE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLG1DQUFtQyxDQUFDO0FBQ3pFLE9BQU8sRUFBRSw0QkFBNEIsRUFBRSxNQUFNLHVCQUF1QixDQUFDOztBQUVyRSxNQUFNLENBQUMsTUFBTSxDQUFDLGNBQWMsRUFBRSxlQUFlLENBQUMsR0FBRyxvQkFBb0IsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxFQUE0QixFQUFFO0lBQ3pHLE1BQU0sRUFBRSxLQUFLO0NBQ2IsQ0FBQyxDQUFDO0FBR0gsTUFBTSxPQUFnQixrQkFBa0I7SUFVdkM7UUFUUSxRQUFHLEdBQUcsTUFBTSxDQUFDLGdCQUFnQixDQUFDLENBQUM7UUFDL0IsU0FBSSxHQUFHLE1BQU0sQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUN0QixhQUFRLEdBQUcsTUFBTSxDQUFDLFdBQVcsQ0FBQyxDQUFDO1FBQy9CLGFBQVEsR0FBRyxjQUFjLEVBQUUsQ0FBQztRQUUxQixhQUFRLEdBQUcsS0FBSyxDQUFDO1FBQ2pCLHFCQUFnQixHQUFHLElBQUksQ0FBQztRQUlqQyxNQUFNLFdBQVcsR0FBRyxJQUFJLENBQUMsR0FBRyxDQUFDLE9BQU8sQ0FBQyxhQUFhLENBQUM7UUFDbkQsSUFBSSxXQUFXLENBQUMsNEJBQTRCLENBQUMsRUFBRSxDQUFDO1lBQy9DLFdBQVcsQ0FBQyw0QkFBNEIsQ0FBQyxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQztZQUN6RCxPQUFPLFdBQVcsQ0FBQyw0QkFBNEIsQ0FBQyxDQUFDO1FBQ2xELENBQUM7UUFFRCxNQUFNLENBQUMsVUFBVSxDQUFDLENBQUMsU0FBUyxDQUFDLEdBQUcsRUFBRTtZQUNqQyxJQUFJLENBQUMsSUFBSSxFQUFFLE9BQU8sRUFBRSxDQUFDO1FBQ3RCLENBQUMsQ0FBQyxDQUFDO0lBQ0osQ0FBQztJQUlTLFVBQVU7UUFDbkIsSUFBSSxDQUFDLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxHQUFHLEVBQUU7WUFDaEMsSUFBSSxJQUFJLENBQUMsZ0JBQWdCLEVBQUUsQ0FBQztnQkFDM0IsSUFBSSxJQUFJLENBQUMsSUFBSSxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxTQUFTLEVBQUUsQ0FBQztvQkFDdkMsSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQztnQkFDckIsQ0FBQztnQkFDRCxJQUFJLENBQUMsSUFBSSxHQUFHLElBQUksQ0FBQyxHQUFHLENBQUMsa0JBQWtCLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDO2dCQUN2RCxJQUFJLENBQUMsSUFBSSxDQUFDLGFBQWEsRUFBRSxDQUFDO1lBQzNCLENBQUM7UUFDRixDQUFDLENBQUMsQ0FBQztJQUNKLENBQUM7OEdBbENvQixrQkFBa0I7a0dBQWxCLGtCQUFrQjs7MkZBQWxCLGtCQUFrQjtrQkFEdkMsU0FBUyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG5cdERlc3Ryb3lSZWYsXG5cdERpcmVjdGl2ZSxcblx0Tmdab25lLFxuXHRUZW1wbGF0ZVJlZixcblx0Vmlld0NvbnRhaW5lclJlZixcblx0aW5qZWN0LFxuXHR0eXBlIEVtYmVkZGVkVmlld1JlZixcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBjcmVhdGVJbmplY3Rpb25Ub2tlbiB9IGZyb20gJ25neHRlbnNpb24vY3JlYXRlLWluamVjdGlvbi10b2tlbic7XG5pbXBvcnQgeyBTUEVDSUFMX0lOVEVSTkFMX0FERF9DT01NRU5UIH0gZnJvbSAnLi4vcmVuZGVyZXIvY29uc3RhbnRzJztcblxuZXhwb3J0IGNvbnN0IFtpbmplY3ROb2RlVHlwZSwgcHJvdmlkZU5vZGVUeXBlXSA9IGNyZWF0ZUluamVjdGlvblRva2VuKCgpID0+ICcnIGFzICdhcmdzJyB8ICdwYXJlbnQnIHwgJycsIHtcblx0aXNSb290OiBmYWxzZSxcbn0pO1xuXG5ARGlyZWN0aXZlKClcbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBOZ3RDb21tb25EaXJlY3RpdmUge1xuXHRwcml2YXRlIHZjciA9IGluamVjdChWaWV3Q29udGFpbmVyUmVmKTtcblx0cHJpdmF0ZSB6b25lID0gaW5qZWN0KE5nWm9uZSk7XG5cdHByaXZhdGUgdGVtcGxhdGUgPSBpbmplY3QoVGVtcGxhdGVSZWYpO1xuXHRwcml2YXRlIG5vZGVUeXBlID0gaW5qZWN0Tm9kZVR5cGUoKTtcblxuXHRwcm90ZWN0ZWQgaW5qZWN0ZWQgPSBmYWxzZTtcblx0cHJvdGVjdGVkIHNob3VsZENyZWF0ZVZpZXcgPSB0cnVlO1xuXHRwcml2YXRlIHZpZXc/OiBFbWJlZGRlZFZpZXdSZWY8dW5rbm93bj47XG5cblx0Y29uc3RydWN0b3IoKSB7XG5cdFx0Y29uc3QgY29tbWVudE5vZGUgPSB0aGlzLnZjci5lbGVtZW50Lm5hdGl2ZUVsZW1lbnQ7XG5cdFx0aWYgKGNvbW1lbnROb2RlW1NQRUNJQUxfSU5URVJOQUxfQUREX0NPTU1FTlRdKSB7XG5cdFx0XHRjb21tZW50Tm9kZVtTUEVDSUFMX0lOVEVSTkFMX0FERF9DT01NRU5UXSh0aGlzLm5vZGVUeXBlKTtcblx0XHRcdGRlbGV0ZSBjb21tZW50Tm9kZVtTUEVDSUFMX0lOVEVSTkFMX0FERF9DT01NRU5UXTtcblx0XHR9XG5cblx0XHRpbmplY3QoRGVzdHJveVJlZikub25EZXN0cm95KCgpID0+IHtcblx0XHRcdHRoaXMudmlldz8uZGVzdHJveSgpO1xuXHRcdH0pO1xuXHR9XG5cblx0YWJzdHJhY3QgdmFsaWRhdGUoKTogYm9vbGVhbjtcblxuXHRwcm90ZWN0ZWQgY3JlYXRlVmlldygpIHtcblx0XHR0aGlzLnpvbmUucnVuT3V0c2lkZUFuZ3VsYXIoKCkgPT4ge1xuXHRcdFx0aWYgKHRoaXMuc2hvdWxkQ3JlYXRlVmlldykge1xuXHRcdFx0XHRpZiAodGhpcy52aWV3ICYmICF0aGlzLnZpZXcuZGVzdHJveWVkKSB7XG5cdFx0XHRcdFx0dGhpcy52aWV3LmRlc3Ryb3koKTtcblx0XHRcdFx0fVxuXHRcdFx0XHR0aGlzLnZpZXcgPSB0aGlzLnZjci5jcmVhdGVFbWJlZGRlZFZpZXcodGhpcy50ZW1wbGF0ZSk7XG5cdFx0XHRcdHRoaXMudmlldy5kZXRlY3RDaGFuZ2VzKCk7XG5cdFx0XHR9XG5cdFx0fSk7XG5cdH1cbn1cbiJdfQ==
@@ -1,5 +1,5 @@
1
1
  import { Directive, Input } from '@angular/core';
2
- import { NgtCommonDirective } from './common';
2
+ import { NgtCommonDirective, provideNodeType } from './common';
3
3
  import * as i0 from "@angular/core";
4
4
  export class NgtParent extends NgtCommonDirective {
5
5
  constructor() {
@@ -23,13 +23,13 @@ export class NgtParent extends NgtCommonDirective {
23
23
  validate() {
24
24
  return !this.injected && !!this.injectedParent;
25
25
  }
26
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.2", ngImport: i0, type: NgtParent, deps: null, target: i0.ɵɵFactoryTarget.Directive }); }
27
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.2", type: NgtParent, isStandalone: true, selector: "ng-template[parent]", inputs: { parent: "parent" }, usesInheritance: true, ngImport: i0 }); }
26
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type: NgtParent, deps: null, target: i0.ɵɵFactoryTarget.Directive }); }
27
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.2.1", type: NgtParent, isStandalone: true, selector: "ng-template[parent]", inputs: { parent: "parent" }, providers: [provideNodeType('parent')], usesInheritance: true, ngImport: i0 }); }
28
28
  }
29
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.2", ngImport: i0, type: NgtParent, decorators: [{
29
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type: NgtParent, decorators: [{
30
30
  type: Directive,
31
- args: [{ selector: 'ng-template[parent]', standalone: true }]
31
+ args: [{ selector: 'ng-template[parent]', standalone: true, providers: [provideNodeType('parent')] }]
32
32
  }], propDecorators: { parent: [{
33
33
  type: Input
34
34
  }] } });
35
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFyZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb3JlL3NyYy9saWIvZGlyZWN0aXZlcy9wYXJlbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFakQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sVUFBVSxDQUFDOztBQUc5QyxNQUFNLE9BQU8sU0FBVSxTQUFRLGtCQUFrQjtJQURqRDs7UUFFUyxtQkFBYyxHQUFvQyxJQUFLLENBQUM7S0FvQmhFO0lBbEJBLElBQWEsTUFBTSxDQUFDLE1BQXVDO1FBQzFELElBQUksQ0FBQyxNQUFNO1lBQUUsT0FBTztRQUNwQixJQUFJLENBQUMsUUFBUSxHQUFHLEtBQUssQ0FBQztRQUN0QixJQUFJLENBQUMsY0FBYyxHQUFHLE1BQU0sQ0FBQztRQUM3QixJQUFJLENBQUMsVUFBVSxFQUFFLENBQUM7SUFDbkIsQ0FBQztJQUVELElBQUksTUFBTTtRQUNULElBQUksSUFBSSxDQUFDLFFBQVEsRUFBRSxFQUFFO1lBQ3BCLElBQUksQ0FBQyxRQUFRLEdBQUcsSUFBSSxDQUFDO1lBQ3JCLE9BQU8sSUFBSSxDQUFDLGNBQWMsQ0FBQztTQUMzQjtRQUNELE9BQU8sSUFBSyxDQUFDO0lBQ2QsQ0FBQztJQUVELFFBQVE7UUFDUCxPQUFPLENBQUMsSUFBSSxDQUFDLFFBQVEsSUFBSSxDQUFDLENBQUMsSUFBSSxDQUFDLGNBQWMsQ0FBQztJQUNoRCxDQUFDOzhHQXBCVyxTQUFTO2tHQUFULFNBQVM7OzJGQUFULFNBQVM7a0JBRHJCLFNBQVM7bUJBQUMsRUFBRSxRQUFRLEVBQUUscUJBQXFCLEVBQUUsVUFBVSxFQUFFLElBQUksRUFBRTs4QkFJbEQsTUFBTTtzQkFBbEIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB0eXBlIHsgTmd0UmVmIH0gZnJvbSAnLi4vcmVmJztcbmltcG9ydCB7IE5ndENvbW1vbkRpcmVjdGl2ZSB9IGZyb20gJy4vY29tbW9uJztcblxuQERpcmVjdGl2ZSh7IHNlbGVjdG9yOiAnbmctdGVtcGxhdGVbcGFyZW50XScsIHN0YW5kYWxvbmU6IHRydWUgfSlcbmV4cG9ydCBjbGFzcyBOZ3RQYXJlbnQgZXh0ZW5kcyBOZ3RDb21tb25EaXJlY3RpdmUge1xuXHRwcml2YXRlIGluamVjdGVkUGFyZW50OiBzdHJpbmcgfCBOZ3RSZWY8VEhSRUUuT2JqZWN0M0Q+ID0gbnVsbCE7XG5cblx0QElucHV0KCkgc2V0IHBhcmVudChwYXJlbnQ6IHN0cmluZyB8IE5ndFJlZjxUSFJFRS5PYmplY3QzRD4pIHtcblx0XHRpZiAoIXBhcmVudCkgcmV0dXJuO1xuXHRcdHRoaXMuaW5qZWN0ZWQgPSBmYWxzZTtcblx0XHR0aGlzLmluamVjdGVkUGFyZW50ID0gcGFyZW50O1xuXHRcdHRoaXMuY3JlYXRlVmlldygpO1xuXHR9XG5cblx0Z2V0IHBhcmVudCgpIHtcblx0XHRpZiAodGhpcy52YWxpZGF0ZSgpKSB7XG5cdFx0XHR0aGlzLmluamVjdGVkID0gdHJ1ZTtcblx0XHRcdHJldHVybiB0aGlzLmluamVjdGVkUGFyZW50O1xuXHRcdH1cblx0XHRyZXR1cm4gbnVsbCE7XG5cdH1cblxuXHR2YWxpZGF0ZSgpOiBib29sZWFuIHtcblx0XHRyZXR1cm4gIXRoaXMuaW5qZWN0ZWQgJiYgISF0aGlzLmluamVjdGVkUGFyZW50O1xuXHR9XG59XG4iXX0=
35
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFyZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb3JlL3NyYy9saWIvZGlyZWN0aXZlcy9wYXJlbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFakQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLGVBQWUsRUFBRSxNQUFNLFVBQVUsQ0FBQzs7QUFHL0QsTUFBTSxPQUFPLFNBQVUsU0FBUSxrQkFBa0I7SUFEakQ7O1FBRVMsbUJBQWMsR0FBb0MsSUFBSyxDQUFDO0tBb0JoRTtJQWxCQSxJQUFhLE1BQU0sQ0FBQyxNQUF1QztRQUMxRCxJQUFJLENBQUMsTUFBTTtZQUFFLE9BQU87UUFDcEIsSUFBSSxDQUFDLFFBQVEsR0FBRyxLQUFLLENBQUM7UUFDdEIsSUFBSSxDQUFDLGNBQWMsR0FBRyxNQUFNLENBQUM7UUFDN0IsSUFBSSxDQUFDLFVBQVUsRUFBRSxDQUFDO0lBQ25CLENBQUM7SUFFRCxJQUFJLE1BQU07UUFDVCxJQUFJLElBQUksQ0FBQyxRQUFRLEVBQUUsRUFBRSxDQUFDO1lBQ3JCLElBQUksQ0FBQyxRQUFRLEdBQUcsSUFBSSxDQUFDO1lBQ3JCLE9BQU8sSUFBSSxDQUFDLGNBQWMsQ0FBQztRQUM1QixDQUFDO1FBQ0QsT0FBTyxJQUFLLENBQUM7SUFDZCxDQUFDO0lBRUQsUUFBUTtRQUNQLE9BQU8sQ0FBQyxJQUFJLENBQUMsUUFBUSxJQUFJLENBQUMsQ0FBQyxJQUFJLENBQUMsY0FBYyxDQUFDO0lBQ2hELENBQUM7OEdBcEJXLFNBQVM7a0dBQVQsU0FBUyxnR0FEcUQsQ0FBQyxlQUFlLENBQUMsUUFBUSxDQUFDLENBQUM7OzJGQUN6RixTQUFTO2tCQURyQixTQUFTO21CQUFDLEVBQUUsUUFBUSxFQUFFLHFCQUFxQixFQUFFLFVBQVUsRUFBRSxJQUFJLEVBQUUsU0FBUyxFQUFFLENBQUMsZUFBZSxDQUFDLFFBQVEsQ0FBQyxDQUFDLEVBQUU7OEJBSTFGLE1BQU07c0JBQWxCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgdHlwZSB7IE5ndFJlZiB9IGZyb20gJy4uL3JlZic7XG5pbXBvcnQgeyBOZ3RDb21tb25EaXJlY3RpdmUsIHByb3ZpZGVOb2RlVHlwZSB9IGZyb20gJy4vY29tbW9uJztcblxuQERpcmVjdGl2ZSh7IHNlbGVjdG9yOiAnbmctdGVtcGxhdGVbcGFyZW50XScsIHN0YW5kYWxvbmU6IHRydWUsIHByb3ZpZGVyczogW3Byb3ZpZGVOb2RlVHlwZSgncGFyZW50JyldIH0pXG5leHBvcnQgY2xhc3MgTmd0UGFyZW50IGV4dGVuZHMgTmd0Q29tbW9uRGlyZWN0aXZlIHtcblx0cHJpdmF0ZSBpbmplY3RlZFBhcmVudDogc3RyaW5nIHwgTmd0UmVmPFRIUkVFLk9iamVjdDNEPiA9IG51bGwhO1xuXG5cdEBJbnB1dCgpIHNldCBwYXJlbnQocGFyZW50OiBzdHJpbmcgfCBOZ3RSZWY8VEhSRUUuT2JqZWN0M0Q+KSB7XG5cdFx0aWYgKCFwYXJlbnQpIHJldHVybjtcblx0XHR0aGlzLmluamVjdGVkID0gZmFsc2U7XG5cdFx0dGhpcy5pbmplY3RlZFBhcmVudCA9IHBhcmVudDtcblx0XHR0aGlzLmNyZWF0ZVZpZXcoKTtcblx0fVxuXG5cdGdldCBwYXJlbnQoKSB7XG5cdFx0aWYgKHRoaXMudmFsaWRhdGUoKSkge1xuXHRcdFx0dGhpcy5pbmplY3RlZCA9IHRydWU7XG5cdFx0XHRyZXR1cm4gdGhpcy5pbmplY3RlZFBhcmVudDtcblx0XHR9XG5cdFx0cmV0dXJuIG51bGwhO1xuXHR9XG5cblx0dmFsaWRhdGUoKTogYm9vbGVhbiB7XG5cdFx0cmV0dXJuICF0aGlzLmluamVjdGVkICYmICEhdGhpcy5pbmplY3RlZFBhcmVudDtcblx0fVxufVxuIl19