angular-three 2.0.0-beta.9 → 2.1.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 (160) hide show
  1. package/README.md +221 -4
  2. package/esm2022/index.mjs +13 -14
  3. package/esm2022/lib/canvas.mjs +130 -197
  4. package/esm2022/lib/directives/args.mjs +46 -20
  5. package/esm2022/lib/directives/selection.mjs +65 -0
  6. package/esm2022/lib/dom/events.mjs +2 -2
  7. package/esm2022/lib/events.mjs +33 -31
  8. package/esm2022/lib/html.mjs +40 -0
  9. package/esm2022/lib/instance.mjs +43 -36
  10. package/esm2022/lib/loader.mjs +72 -36
  11. package/esm2022/lib/loop.mjs +29 -26
  12. package/esm2022/lib/pipes/hexify.mjs +67 -0
  13. package/esm2022/lib/portal.mjs +173 -193
  14. package/esm2022/lib/renderer/catalogue.mjs +3 -3
  15. package/esm2022/lib/renderer/constants.mjs +6 -6
  16. package/esm2022/lib/renderer/index.mjs +356 -217
  17. package/esm2022/lib/renderer/state.mjs +54 -0
  18. package/esm2022/lib/renderer/utils.mjs +120 -64
  19. package/esm2022/lib/roots.mjs +86 -62
  20. package/esm2022/lib/routed-scene.mjs +11 -8
  21. package/esm2022/lib/store.mjs +164 -195
  22. package/esm2022/lib/three-types.mjs +1 -1
  23. package/esm2022/lib/types.mjs +1 -1
  24. package/esm2022/lib/utils/apply-props.mjs +31 -28
  25. package/esm2022/lib/utils/attach.mjs +26 -12
  26. package/esm2022/lib/utils/before-render.mjs +12 -0
  27. package/esm2022/lib/utils/is.mjs +6 -5
  28. package/esm2022/lib/utils/make.mjs +19 -17
  29. package/esm2022/lib/utils/non-nullish.mjs +7 -0
  30. package/esm2022/lib/utils/object-events.mjs +91 -0
  31. package/esm2022/lib/utils/parameters.mjs +70 -0
  32. package/esm2022/lib/utils/resolve-ref.mjs +8 -0
  33. package/esm2022/lib/utils/signal-store.mjs +59 -60
  34. package/esm2022/lib/utils/update.mjs +8 -4
  35. package/esm2022/nativescript/angular-three-nativescript.mjs +5 -0
  36. package/esm2022/nativescript/index.mjs +2 -0
  37. package/esm2022/nativescript/lib/canvas.mjs +127 -0
  38. package/esm2022/testing/angular-three-testing.mjs +5 -0
  39. package/esm2022/testing/index.mjs +3 -0
  40. package/esm2022/testing/lib/test-bed.mjs +130 -0
  41. package/esm2022/testing/lib/test-canvas.mjs +45 -0
  42. package/esm2022/testing/lib/utils/mock-canvas.mjs +37 -0
  43. package/esm2022/testing/lib/utils/web-gl-rendering-context.mjs +752 -0
  44. package/fesm2022/angular-three-nativescript.mjs +134 -0
  45. package/fesm2022/angular-three-nativescript.mjs.map +1 -0
  46. package/fesm2022/angular-three-testing.mjs +966 -0
  47. package/fesm2022/angular-three-testing.mjs.map +1 -0
  48. package/fesm2022/angular-three.mjs +2271 -2306
  49. package/fesm2022/angular-three.mjs.map +1 -1
  50. package/index.d.ts +14 -14
  51. package/lib/canvas.d.ts +357 -96
  52. package/lib/directives/args.d.ts +14 -7
  53. package/lib/directives/selection.d.ts +17 -0
  54. package/lib/dom/events.d.ts +2 -3
  55. package/lib/events.d.ts +4 -80
  56. package/lib/html.d.ts +17 -0
  57. package/lib/instance.d.ts +3 -35
  58. package/lib/loader.d.ts +19 -7
  59. package/lib/loop.d.ts +11 -59
  60. package/lib/pipes/hexify.d.ts +20 -0
  61. package/lib/portal.d.ts +54 -48
  62. package/lib/renderer/catalogue.d.ts +7 -3
  63. package/lib/renderer/constants.d.ts +5 -5
  64. package/lib/renderer/index.d.ts +63 -4
  65. package/lib/renderer/state.d.ts +25 -0
  66. package/lib/renderer/utils.d.ts +10 -27
  67. package/lib/roots.d.ts +9 -7
  68. package/lib/store.d.ts +13 -141
  69. package/lib/three-types.d.ts +528 -147
  70. package/lib/types.d.ts +291 -0
  71. package/lib/utils/apply-props.d.ts +2 -3
  72. package/lib/utils/attach.d.ts +4 -6
  73. package/lib/{before-render.d.ts → utils/before-render.d.ts} +1 -1
  74. package/lib/utils/is.d.ts +13 -14
  75. package/lib/utils/make.d.ts +7 -13
  76. package/lib/utils/non-nullish.d.ts +4 -0
  77. package/lib/utils/object-events.d.ts +32 -0
  78. package/lib/utils/parameters.d.ts +20 -0
  79. package/lib/utils/resolve-ref.d.ts +2 -0
  80. package/lib/utils/signal-store.d.ts +13 -4
  81. package/lib/utils/update.d.ts +1 -1
  82. package/metadata.json +1 -1
  83. package/nativescript/README.md +5 -0
  84. package/nativescript/index.d.ts +1 -0
  85. package/nativescript/lib/canvas.d.ts +359 -0
  86. package/nativescript/package.json +3 -0
  87. package/package.json +65 -14
  88. package/plugin/generators.json +8 -30
  89. package/plugin/package.json +3 -3
  90. package/plugin/src/generators/add-soba/compat.js.map +1 -0
  91. package/plugin/src/generators/add-soba/generator.d.ts +3 -0
  92. package/plugin/src/generators/add-soba/generator.js +77 -0
  93. package/plugin/src/generators/add-soba/generator.js.map +1 -0
  94. package/plugin/src/generators/add-soba/schema.json +4 -0
  95. package/plugin/src/generators/init/compat.d.ts +1 -1
  96. package/plugin/src/generators/init/files/experience/experience.component.ts__tmpl__ +29 -0
  97. package/plugin/src/generators/init/generator.d.ts +5 -1
  98. package/plugin/src/generators/init/generator.js +131 -25
  99. package/plugin/src/generators/init/generator.js.map +1 -1
  100. package/plugin/src/generators/init/schema.json +9 -2
  101. package/plugin/src/generators/utils.d.ts +2 -0
  102. package/plugin/src/generators/utils.js +35 -0
  103. package/plugin/src/generators/utils.js.map +1 -0
  104. package/plugin/src/generators/version.d.ts +17 -0
  105. package/plugin/src/generators/version.js +21 -0
  106. package/plugin/src/generators/version.js.map +1 -0
  107. package/plugin/src/index.d.ts +0 -3
  108. package/plugin/src/index.js +0 -9
  109. package/plugin/src/index.js.map +1 -1
  110. package/testing/README.md +3 -0
  111. package/testing/index.d.ts +2 -0
  112. package/testing/lib/test-bed.d.ts +38 -0
  113. package/testing/lib/test-canvas.d.ts +11 -0
  114. package/testing/lib/utils/mock-canvas.d.ts +5 -0
  115. package/testing/lib/utils/web-gl-rendering-context.d.ts +16 -0
  116. package/testing/package.json +3 -0
  117. package/web-types.json +1 -1
  118. package/esm2022/lib/before-render.mjs +0 -13
  119. package/esm2022/lib/directives/common.mjs +0 -41
  120. package/esm2022/lib/directives/key.mjs +0 -29
  121. package/esm2022/lib/directives/parent.mjs +0 -35
  122. package/esm2022/lib/directives/repeat.mjs +0 -17
  123. package/esm2022/lib/ref.mjs +0 -48
  124. package/esm2022/lib/renderer/store.mjs +0 -405
  125. package/esm2022/lib/utils/assert-injection-context.mjs +0 -14
  126. package/esm2022/lib/utils/create-injection-token.mjs +0 -47
  127. package/esm2022/lib/utils/safe-detect-changes.mjs +0 -17
  128. package/lib/directives/common.d.ts +0 -15
  129. package/lib/directives/key.d.ts +0 -10
  130. package/lib/directives/parent.d.ts +0 -11
  131. package/lib/directives/repeat.d.ts +0 -7
  132. package/lib/ref.d.ts +0 -8
  133. package/lib/renderer/store.d.ts +0 -67
  134. package/lib/utils/assert-injection-context.d.ts +0 -2
  135. package/lib/utils/create-injection-token.d.ts +0 -27
  136. package/lib/utils/safe-detect-changes.d.ts +0 -2
  137. package/plugin/src/generators/init-cannon/compat.js.map +0 -1
  138. package/plugin/src/generators/init-cannon/generator.d.ts +0 -2
  139. package/plugin/src/generators/init-cannon/generator.js +0 -22
  140. package/plugin/src/generators/init-cannon/generator.js.map +0 -1
  141. package/plugin/src/generators/init-cannon/schema.json +0 -6
  142. package/plugin/src/generators/init-postprocessing/compat.d.ts +0 -2
  143. package/plugin/src/generators/init-postprocessing/compat.js +0 -6
  144. package/plugin/src/generators/init-postprocessing/compat.js.map +0 -1
  145. package/plugin/src/generators/init-postprocessing/generator.d.ts +0 -2
  146. package/plugin/src/generators/init-postprocessing/generator.js +0 -20
  147. package/plugin/src/generators/init-postprocessing/generator.js.map +0 -1
  148. package/plugin/src/generators/init-postprocessing/schema.json +0 -6
  149. package/plugin/src/generators/init-soba/compat.d.ts +0 -2
  150. package/plugin/src/generators/init-soba/compat.js +0 -6
  151. package/plugin/src/generators/init-soba/compat.js.map +0 -1
  152. package/plugin/src/generators/init-soba/generator.d.ts +0 -2
  153. package/plugin/src/generators/init-soba/generator.js +0 -24
  154. package/plugin/src/generators/init-soba/generator.js.map +0 -1
  155. package/plugin/src/generators/init-soba/schema.json +0 -6
  156. package/plugin/src/generators/versions.d.ts +0 -12
  157. package/plugin/src/generators/versions.js +0 -16
  158. package/plugin/src/generators/versions.js.map +0 -1
  159. /package/plugin/src/generators/{init-cannon → add-soba}/compat.d.ts +0 -0
  160. /package/plugin/src/generators/{init-cannon → add-soba}/compat.js +0 -0
@@ -1,242 +1,222 @@
1
- import { NgIf } from '@angular/common';
2
- import { Component, ContentChild, DestroyRef, Directive, EventEmitter, Injector, Input, NgZone, Output, SkipSelf, TemplateRef, ViewChild, ViewContainerRef, effect, inject, } from '@angular/core';
3
- import * as THREE from 'three';
4
- import { injectBeforeRender } from './before-render';
1
+ import { afterNextRender, ChangeDetectionStrategy, Component, computed, contentChild, CUSTOM_ELEMENTS_SCHEMA, DestroyRef, Directive, inject, Injector, input, signal, TemplateRef, untracked, viewChild, ViewContainerRef, } from '@angular/core';
2
+ import { injectAutoEffect } from 'ngxtension/auto-effect';
3
+ import { Raycaster, Vector2, Vector3 } from 'three';
5
4
  import { getLocalState, prepare } from './instance';
6
- import { injectNgtRef } from './ref';
7
5
  import { SPECIAL_INTERNAL_ADD_COMMENT } from './renderer/constants';
8
- import { NGT_STORE, injectNgtStore } from './store';
6
+ import { injectStore, provideStore } from './store';
7
+ import { injectBeforeRender } from './utils/before-render';
9
8
  import { is } from './utils/is';
10
- import { safeDetectChanges } from './utils/safe-detect-changes';
11
9
  import { signalStore } from './utils/signal-store';
12
10
  import { updateCamera } from './utils/update';
13
11
  import * as i0 from "@angular/core";
14
- const privateKeys = [
15
- 'get',
16
- 'set',
17
- 'select',
18
- 'setSize',
19
- 'setDpr',
20
- 'setFrameloop',
21
- 'events',
22
- 'invalidate',
23
- 'advance',
24
- 'size',
25
- 'viewport',
26
- ];
27
12
  export class NgtPortalBeforeRender {
28
13
  constructor() {
29
- this.portalStore = injectNgtStore();
30
- this.injector = inject(Injector);
31
- this.renderPriority = 1;
32
- this.beforeRender = new EventEmitter();
14
+ this.portalStore = injectStore();
15
+ this.renderPriority = input(1);
16
+ this.parentScene = input.required();
17
+ this.parentCamera = input.required();
18
+ injectAutoEffect()((injector) => {
19
+ // track state
20
+ this.portalStore.state();
21
+ const priority = this.renderPriority();
22
+ let oldClear;
23
+ return injectBeforeRender(() => {
24
+ const { gl, scene, camera } = this.portalStore.snapshot;
25
+ oldClear = gl.autoClear;
26
+ if (this.renderPriority() === 1) {
27
+ // clear scene and render with default
28
+ gl.autoClear = true;
29
+ gl.render(this.parentScene(), this.parentCamera());
30
+ }
31
+ // disable cleaning
32
+ gl.autoClear = false;
33
+ gl.clearDepth();
34
+ gl.render(scene, camera);
35
+ // restore
36
+ gl.autoClear = oldClear;
37
+ }, { priority, injector });
38
+ });
33
39
  }
34
- ngOnInit() {
35
- let oldClear;
36
- injectBeforeRender(({ delta, frame }) => {
37
- this.beforeRender.emit({ ...this.portalStore.get(), delta, frame });
38
- const { gl, scene, camera } = this.portalStore.get();
39
- oldClear = gl.autoClear;
40
- if (this.renderPriority === 1) {
41
- // clear scene and render with default
42
- gl.autoClear = true;
43
- gl.render(this.parentScene, this.parentCamera);
44
- }
45
- // disable cleaning
46
- gl.autoClear = false;
47
- gl.clearDepth();
48
- gl.render(scene, camera);
49
- // restore
50
- gl.autoClear = oldClear;
51
- }, { priority: this.renderPriority, injector: this.injector });
40
+ onPointerOver() {
41
+ /* noop */
52
42
  }
53
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: NgtPortalBeforeRender, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
54
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.1.7", type: NgtPortalBeforeRender, isStandalone: true, selector: "[ngtPortalBeforeRender]", inputs: { renderPriority: "renderPriority", parentScene: "parentScene", parentCamera: "parentCamera" }, outputs: { beforeRender: "beforeRender" }, ngImport: i0 }); }
43
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: NgtPortalBeforeRender, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
44
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.0", type: NgtPortalBeforeRender, isStandalone: true, selector: "ngt-portal-before-render", inputs: { renderPriority: { classPropertyName: "renderPriority", publicName: "renderPriority", isSignal: true, isRequired: false, transformFunction: null }, parentScene: { classPropertyName: "parentScene", publicName: "parentScene", isSignal: true, isRequired: true, transformFunction: null }, parentCamera: { classPropertyName: "parentCamera", publicName: "parentCamera", isSignal: true, isRequired: true, transformFunction: null } }, ngImport: i0, template: `
45
+ <!-- Without an element that receives pointer events state.pointer will always be 0/0 -->
46
+ <ngt-group (pointerover)="onPointerOver()" attach="none" />
47
+ `, isInline: true }); }
55
48
  }
56
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: NgtPortalBeforeRender, decorators: [{
57
- type: Directive,
58
- args: [{ selector: '[ngtPortalBeforeRender]', standalone: true }]
59
- }], propDecorators: { renderPriority: [{
60
- type: Input
61
- }], parentScene: [{
62
- type: Input,
63
- args: [{ required: true }]
64
- }], parentCamera: [{
65
- type: Input,
66
- args: [{ required: true }]
67
- }], beforeRender: [{
68
- type: Output
69
- }] } });
49
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: NgtPortalBeforeRender, decorators: [{
50
+ type: Component,
51
+ args: [{
52
+ selector: 'ngt-portal-before-render',
53
+ standalone: true,
54
+ template: `
55
+ <!-- Without an element that receives pointer events state.pointer will always be 0/0 -->
56
+ <ngt-group (pointerover)="onPointerOver()" attach="none" />
57
+ `,
58
+ schemas: [CUSTOM_ELEMENTS_SCHEMA],
59
+ }]
60
+ }], ctorParameters: () => [] });
70
61
  export class NgtPortalContent {
71
- constructor(vcr, parentVcr) {
72
- const commentNode = vcr.element.nativeElement;
62
+ constructor() {
63
+ const { element: comment } = inject(ViewContainerRef);
64
+ const { element: parentComment } = inject(ViewContainerRef, { skipSelf: true });
65
+ const commentNode = comment.nativeElement;
73
66
  if (commentNode[SPECIAL_INTERNAL_ADD_COMMENT]) {
74
- commentNode[SPECIAL_INTERNAL_ADD_COMMENT](parentVcr.element.nativeElement);
67
+ commentNode[SPECIAL_INTERNAL_ADD_COMMENT](parentComment.nativeElement);
75
68
  delete commentNode[SPECIAL_INTERNAL_ADD_COMMENT];
76
69
  }
77
70
  }
78
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: NgtPortalContent, deps: [{ token: i0.ViewContainerRef }, { token: i0.ViewContainerRef, skipSelf: true }], target: i0.ɵɵFactoryTarget.Directive }); }
79
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.1.7", type: NgtPortalContent, isStandalone: true, selector: "ng-template[ngtPortalContent]", ngImport: i0 }); }
71
+ static ngTemplateContextGuard(_, ctx) {
72
+ return true;
73
+ }
74
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: NgtPortalContent, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
75
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.0", type: NgtPortalContent, isStandalone: true, selector: "ng-template[portalContent]", ngImport: i0 }); }
80
76
  }
81
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: NgtPortalContent, decorators: [{
77
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: NgtPortalContent, decorators: [{
82
78
  type: Directive,
83
- args: [{ selector: 'ng-template[ngtPortalContent]', standalone: true }]
84
- }], ctorParameters: function () { return [{ type: i0.ViewContainerRef }, { type: i0.ViewContainerRef, decorators: [{
85
- type: SkipSelf
86
- }] }]; } });
79
+ args: [{ selector: 'ng-template[portalContent]', standalone: true }]
80
+ }], ctorParameters: () => [] });
81
+ // Keys that shouldn't be copied between stores
82
+ export const privateKeys = [
83
+ 'setSize',
84
+ 'setFrameloop',
85
+ 'setDpr',
86
+ 'events',
87
+ 'setEvents',
88
+ 'invalidate',
89
+ 'advance',
90
+ 'size',
91
+ 'viewport',
92
+ ];
87
93
  export class NgtPortal {
88
- set container(container) {
89
- this.inputs.set({ container });
90
- }
91
- set portalState(state) {
92
- this.inputs.set({ state });
93
- }
94
94
  constructor() {
95
- this.inputs = signalStore({ container: injectNgtRef(prepare(new THREE.Scene())) });
96
- this.autoRender = true;
97
- this.autoRenderPriority = 1;
98
- this.beforeRender = new EventEmitter();
99
- this.parentStore = injectNgtStore({ skipSelf: true });
100
- this.parentScene = this.parentStore.get('scene');
101
- this.parentCamera = this.parentStore.get('camera');
102
- this.portalStore = injectNgtStore({ self: true });
95
+ this.container = input.required();
96
+ this.state = input({});
97
+ /**
98
+ * @decsription turn this on to enable "HUD" like rendering
99
+ */
100
+ this.autoRender = input(false);
101
+ this.autoRenderPriority = input(1);
102
+ this.portalContent = contentChild.required(NgtPortalContent, { read: TemplateRef });
103
+ this.portalAnchor = viewChild.required('anchor', { read: ViewContainerRef });
103
104
  this.injector = inject(Injector);
104
- this.zone = inject(NgZone);
105
- this.raycaster = new THREE.Raycaster();
106
- this.pointer = new THREE.Vector2();
107
- this.portalContentRendered = false;
108
- inject(DestroyRef).onDestroy(() => {
109
- if (this.portalContentView && !this.portalContentView.destroyed) {
110
- this.portalContentView.destroy();
111
- }
112
- });
113
- }
114
- ngOnInit() {
115
- const previousState = this.parentStore.get();
116
- const inputsState = this.inputs.get();
117
- if (!inputsState.state && this.autoRender) {
118
- inputsState.state = { events: { priority: this.autoRenderPriority + 1 } };
119
- }
120
- const { events, size, ...restInputsState } = inputsState.state || {};
121
- const containerState = inputsState.container;
122
- let container = is.ref(containerState) ? containerState.nativeElement : containerState;
123
- if (!is.instance(container)) {
124
- container = prepare(container);
125
- }
126
- const localState = getLocalState(container);
127
- if (!localState.store) {
128
- localState.store = this.portalStore;
129
- }
130
- this.portalStore.set({
131
- ...previousState,
132
- scene: container,
133
- raycaster: this.raycaster,
134
- pointer: this.pointer,
135
- previousRoot: this.parentStore,
136
- events: { ...previousState.events, ...(events || {}) },
137
- size: { ...previousState.size, ...(size || {}) },
138
- ...restInputsState,
139
- setEvents: (events) => this.portalStore.set((state) => ({ ...state, events: { ...state.events, ...events } })),
140
- });
105
+ this.portalStore = injectStore({ self: true });
106
+ this.parentStore = injectStore({ skipSelf: true });
107
+ this.parentScene = this.parentStore.select('scene');
108
+ this.parentCamera = this.parentStore.select('camera');
109
+ this.raycaster = new Raycaster();
110
+ this.pointer = new Vector2();
111
+ this.portalRendered = signal(false);
112
+ this.renderAutoBeforeRender = computed(() => this.portalRendered() && this.autoRender());
113
+ const autoEffect = injectAutoEffect();
141
114
  const parentState = this.parentStore.select();
142
- effect(() => {
143
- const previous = parentState();
144
- this.zone.runOutsideAngular(() => {
145
- this.portalStore.set((state) => this.inject(previous, state));
115
+ afterNextRender(() => {
116
+ const previousState = this.parentStore.snapshot;
117
+ const { events = {}, size = {}, ...rest } = this.state();
118
+ let container = this.container();
119
+ if (!is.instance(container)) {
120
+ container = prepare(container, { store: this.portalStore });
121
+ }
122
+ const localState = getLocalState(container);
123
+ if (localState && !localState.store) {
124
+ localState.store = this.portalStore;
125
+ }
126
+ this.portalStore.update({
127
+ ...previousState,
128
+ scene: container,
129
+ raycaster: this.raycaster,
130
+ pointer: this.pointer,
131
+ events: { ...previousState.events, ...events },
132
+ size: { ...previousState.size, ...size },
133
+ previousRoot: this.parentStore,
134
+ ...rest,
135
+ setEvents: (events) => this.portalStore.update((state) => ({ ...state, events: { ...state.events, ...events } })),
136
+ });
137
+ autoEffect(() => {
138
+ const state = this.state();
139
+ const _parentState = parentState();
140
+ this.portalStore.update((prev) => this.inject(_parentState, prev, state, untracked(this.container)));
141
+ untracked(() => {
142
+ if (this.portalView) {
143
+ this.portalView.detectChanges();
144
+ return;
145
+ }
146
+ this.portalView = this.portalAnchor().createEmbeddedView(this.portalContent(), { container: this.container(), injector: this.injector }, { injector: this.injector });
147
+ this.portalView.detectChanges();
148
+ this.portalRendered.set(true);
149
+ });
146
150
  });
147
- }, { injector: this.injector });
148
- requestAnimationFrame(() => {
149
- this.portalStore.set((injectState) => this.inject(this.parentStore.get(), injectState));
150
151
  });
151
- this.portalContentView = this.portalContentAnchor.createEmbeddedView(this.portalContentTemplate);
152
- safeDetectChanges(this.portalContentView);
153
- this.portalContentRendered = true;
154
- }
155
- onBeforeRender(portal) {
156
- this.beforeRender.emit({
157
- root: { ...this.parentStore.get(), delta: portal.delta, frame: portal.frame },
158
- portal,
152
+ inject(DestroyRef).onDestroy(() => {
153
+ this.portalView?.destroy();
159
154
  });
160
155
  }
161
- inject(rootState, injectState) {
162
- const intersect = { ...rootState };
163
- Object.keys(intersect).forEach((key) => {
156
+ inject(parentState, portalState, injectedState, container) {
157
+ const { events = {}, size, ...rest } = injectedState;
158
+ const intersect = { ...parentState }; // all prev state props
159
+ Object.keys(parentState).forEach((key) => {
164
160
  if (privateKeys.includes(key) ||
165
- rootState[key] !== injectState[key]) {
161
+ (parentState[key] !== portalState[key] &&
162
+ portalState[key])) {
166
163
  delete intersect[key];
167
164
  }
168
165
  });
169
- const inputs = this.inputs.get();
170
- const { size, events, ...restInputsState } = inputs.state || {};
171
166
  let viewport = undefined;
172
- if (injectState && size) {
173
- const camera = injectState.camera;
174
- viewport = rootState.viewport.getCurrentViewport(camera, new THREE.Vector3(), size);
175
- if (camera !== rootState.camera)
167
+ if (portalState && size) {
168
+ const camera = portalState.camera;
169
+ // Calculate the override viewport, if present
170
+ viewport = parentState.viewport.getCurrentViewport(camera, new Vector3(), size);
171
+ // Update the portal camera, if it differs from the previous layer
172
+ if (camera !== parentState.camera) {
176
173
  updateCamera(camera, size);
174
+ }
177
175
  }
178
176
  return {
179
177
  ...intersect,
180
- scene: is.ref(inputs.container) ? inputs.container.nativeElement : inputs.container,
178
+ scene: container,
181
179
  raycaster: this.raycaster,
182
180
  pointer: this.pointer,
183
- previousRoot: this.parentStore,
184
- events: { ...rootState.events, ...(injectState?.events || {}), ...events },
185
- size: { ...rootState.size, ...size },
186
- viewport: { ...rootState.viewport, ...(viewport || {}) },
187
- ...restInputsState,
181
+ events: { ...parentState.events, ...(portalState.events || {}), ...(events || {}) },
182
+ size: { ...parentState.size, ...(size || {}) },
183
+ viewport: { ...parentState.viewport, ...(viewport || {}) },
184
+ ...rest,
188
185
  };
189
186
  }
190
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: NgtPortal, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
191
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.7", type: NgtPortal, isStandalone: true, selector: "ngt-portal", inputs: { container: "container", portalState: ["state", "portalState"], autoRender: "autoRender", autoRenderPriority: "autoRenderPriority" }, outputs: { beforeRender: "beforeRender" }, providers: [{ provide: NGT_STORE, useFactory: () => signalStore({}) }], queries: [{ propertyName: "portalContentTemplate", first: true, predicate: NgtPortalContent, descendants: true, read: TemplateRef, static: true }], viewQueries: [{ propertyName: "portalContentAnchor", first: true, predicate: ["portalContentAnchor"], descendants: true, read: ViewContainerRef, static: true }], ngImport: i0, template: `
192
- <ng-container #portalContentAnchor>
193
- <ng-container
194
- *ngIf="autoRender && portalContentRendered"
195
- ngtPortalBeforeRender
196
- [renderPriority]="autoRenderPriority"
197
- [parentScene]="parentScene"
198
- [parentCamera]="parentCamera"
199
- (beforeRender)="onBeforeRender($event)"
187
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: NgtPortal, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
188
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.0", type: NgtPortal, isStandalone: true, selector: "ngt-portal", inputs: { container: { classPropertyName: "container", publicName: "container", isSignal: true, isRequired: true, transformFunction: null }, state: { classPropertyName: "state", publicName: "state", isSignal: true, isRequired: false, transformFunction: null }, autoRender: { classPropertyName: "autoRender", publicName: "autoRender", isSignal: true, isRequired: false, transformFunction: null }, autoRenderPriority: { classPropertyName: "autoRenderPriority", publicName: "autoRenderPriority", isSignal: true, isRequired: false, transformFunction: null } }, providers: [provideStore(() => signalStore({}))], queries: [{ propertyName: "portalContent", first: true, predicate: NgtPortalContent, descendants: true, read: TemplateRef, isSignal: true }], viewQueries: [{ propertyName: "portalAnchor", first: true, predicate: ["anchor"], descendants: true, read: ViewContainerRef, isSignal: true }], ngImport: i0, template: `
189
+ <ng-container #anchor />
190
+
191
+ @if (renderAutoBeforeRender()) {
192
+ <ngt-portal-before-render
193
+ [renderPriority]="autoRenderPriority()"
194
+ [parentScene]="parentScene()"
195
+ [parentCamera]="parentCamera()"
200
196
  />
201
- </ng-container>
202
- `, isInline: true, dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgtPortalBeforeRender, selector: "[ngtPortalBeforeRender]", inputs: ["renderPriority", "parentScene", "parentCamera"], outputs: ["beforeRender"] }] }); }
197
+ }
198
+ `, isInline: true, dependencies: [{ kind: "component", type: NgtPortalBeforeRender, selector: "ngt-portal-before-render", inputs: ["renderPriority", "parentScene", "parentCamera"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
203
199
  }
204
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: NgtPortal, decorators: [{
200
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: NgtPortal, decorators: [{
205
201
  type: Component,
206
202
  args: [{
207
203
  selector: 'ngt-portal',
208
204
  standalone: true,
209
205
  template: `
210
- <ng-container #portalContentAnchor>
211
- <ng-container
212
- *ngIf="autoRender && portalContentRendered"
213
- ngtPortalBeforeRender
214
- [renderPriority]="autoRenderPriority"
215
- [parentScene]="parentScene"
216
- [parentCamera]="parentCamera"
217
- (beforeRender)="onBeforeRender($event)"
206
+ <ng-container #anchor />
207
+
208
+ @if (renderAutoBeforeRender()) {
209
+ <ngt-portal-before-render
210
+ [renderPriority]="autoRenderPriority()"
211
+ [parentScene]="parentScene()"
212
+ [parentCamera]="parentCamera()"
218
213
  />
219
- </ng-container>
214
+ }
220
215
  `,
221
- imports: [NgIf, NgtPortalBeforeRender],
222
- providers: [{ provide: NGT_STORE, useFactory: () => signalStore({}) }],
216
+ imports: [NgtPortalBeforeRender],
217
+ schemas: [CUSTOM_ELEMENTS_SCHEMA],
218
+ changeDetection: ChangeDetectionStrategy.OnPush,
219
+ providers: [provideStore(() => signalStore({}))],
223
220
  }]
224
- }], ctorParameters: function () { return []; }, propDecorators: { container: [{
225
- type: Input
226
- }], portalState: [{
227
- type: Input,
228
- args: ['state']
229
- }], autoRender: [{
230
- type: Input
231
- }], autoRenderPriority: [{
232
- type: Input
233
- }], beforeRender: [{
234
- type: Output
235
- }], portalContentTemplate: [{
236
- type: ContentChild,
237
- args: [NgtPortalContent, { read: TemplateRef, static: true }]
238
- }], portalContentAnchor: [{
239
- type: ViewChild,
240
- args: ['portalContentAnchor', { read: ViewContainerRef, static: true }]
241
- }] } });
242
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"portal.js","sourceRoot":"","sources":["../../../../../libs/core/src/lib/portal.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgIf } from '@angular/common';\nimport {\n\tComponent,\n\tContentChild,\n\tDestroyRef,\n\tDirective,\n\tEventEmitter,\n\tInjector,\n\tInput,\n\tNgZone,\n\tOutput,\n\tSkipSelf,\n\tTemplateRef,\n\tViewChild,\n\tViewContainerRef,\n\teffect,\n\tinject,\n\ttype ElementRef,\n\ttype EmbeddedViewRef,\n\ttype OnInit,\n} from '@angular/core';\nimport * as THREE from 'three';\nimport { injectBeforeRender } from './before-render';\nimport type { NgtEventManager } from './events';\nimport { getLocalState, prepare } from './instance';\nimport { injectNgtRef } from './ref';\nimport { SPECIAL_INTERNAL_ADD_COMMENT } from './renderer/constants';\nimport { NGT_STORE, NgtRenderState, injectNgtStore, type NgtSize, type NgtState } from './store';\nimport { is } from './utils/is';\nimport { safeDetectChanges } from './utils/safe-detect-changes';\nimport { signalStore } from './utils/signal-store';\nimport { updateCamera } from './utils/update';\n\nconst privateKeys = [\n\t'get',\n\t'set',\n\t'select',\n\t'setSize',\n\t'setDpr',\n\t'setFrameloop',\n\t'events',\n\t'invalidate',\n\t'advance',\n\t'size',\n\t'viewport',\n] as const;\ntype PrivateKeys = (typeof privateKeys)[number];\n\nexport interface NgtPortalInputs {\n\tcontainer: ElementRef<THREE.Object3D> | THREE.Object3D;\n\tcamera: ElementRef<THREE.Camera> | THREE.Camera;\n\tstate: Partial<\n\t\tOmit<NgtState, PrivateKeys> & {\n\t\t\tevents: Partial<Pick<NgtEventManager<any>, 'enabled' | 'priority' | 'compute' | 'connected'>>;\n\t\t\tsize: NgtSize;\n\t\t}\n\t>;\n}\n\n@Directive({ selector: '[ngtPortalBeforeRender]', standalone: true })\nexport class NgtPortalBeforeRender implements OnInit {\n\tprivate portalStore = injectNgtStore();\n\tprivate injector = inject(Injector);\n\n\t@Input() renderPriority = 1;\n\t@Input({ required: true }) parentScene!: THREE.Scene;\n\t@Input({ required: true }) parentCamera!: THREE.Camera;\n\n\t@Output() beforeRender = new EventEmitter<NgtRenderState>();\n\n\tngOnInit() {\n\t\tlet oldClear: boolean;\n\t\tinjectBeforeRender(\n\t\t\t({ delta, frame }) => {\n\t\t\t\tthis.beforeRender.emit({ ...this.portalStore.get(), delta, frame });\n\t\t\t\tconst { gl, scene, camera } = this.portalStore.get();\n\t\t\t\toldClear = gl.autoClear;\n\t\t\t\tif (this.renderPriority === 1) {\n\t\t\t\t\t// clear scene and render with default\n\t\t\t\t\tgl.autoClear = true;\n\t\t\t\t\tgl.render(this.parentScene, this.parentCamera);\n\t\t\t\t}\n\t\t\t\t// disable cleaning\n\t\t\t\tgl.autoClear = false;\n\t\t\t\tgl.clearDepth();\n\t\t\t\tgl.render(scene, camera);\n\t\t\t\t// restore\n\t\t\t\tgl.autoClear = oldClear;\n\t\t\t},\n\t\t\t{ priority: this.renderPriority, injector: this.injector },\n\t\t);\n\t}\n}\n\n@Directive({ selector: 'ng-template[ngtPortalContent]', standalone: true })\nexport class NgtPortalContent {\n\tconstructor(vcr: ViewContainerRef, @SkipSelf() parentVcr: ViewContainerRef) {\n\t\tconst commentNode = vcr.element.nativeElement;\n\t\tif (commentNode[SPECIAL_INTERNAL_ADD_COMMENT]) {\n\t\t\tcommentNode[SPECIAL_INTERNAL_ADD_COMMENT](parentVcr.element.nativeElement);\n\t\t\tdelete commentNode[SPECIAL_INTERNAL_ADD_COMMENT];\n\t\t}\n\t}\n}\n\n@Component({\n\tselector: 'ngt-portal',\n\tstandalone: true,\n\ttemplate: `\n\t\t<ng-container #portalContentAnchor>\n\t\t\t<ng-container\n\t\t\t\t*ngIf=\"autoRender && portalContentRendered\"\n\t\t\t\tngtPortalBeforeRender\n\t\t\t\t[renderPriority]=\"autoRenderPriority\"\n\t\t\t\t[parentScene]=\"parentScene\"\n\t\t\t\t[parentCamera]=\"parentCamera\"\n\t\t\t\t(beforeRender)=\"onBeforeRender($event)\"\n\t\t\t/>\n\t\t</ng-container>\n\t`,\n\timports: [NgIf, NgtPortalBeforeRender],\n\tproviders: [{ provide: NGT_STORE, useFactory: () => signalStore<NgtState>({}) }],\n})\nexport class NgtPortal implements OnInit {\n\tprivate inputs = signalStore<NgtPortalInputs>({ container: injectNgtRef<THREE.Scene>(prepare(new THREE.Scene())) });\n\n\t@Input() set container(container: NgtPortalInputs['container']) {\n\t\tthis.inputs.set({ container });\n\t}\n\n\t@Input('state') set portalState(state: NgtPortalInputs['state']) {\n\t\tthis.inputs.set({ state });\n\t}\n\n\t@Input() autoRender = true;\n\t@Input() autoRenderPriority = 1;\n\n\t@Output() beforeRender = new EventEmitter<{ root: NgtRenderState; portal: NgtRenderState }>();\n\n\t@ContentChild(NgtPortalContent, { read: TemplateRef, static: true })\n\tportalContentTemplate!: TemplateRef<unknown>;\n\n\t@ViewChild('portalContentAnchor', { read: ViewContainerRef, static: true })\n\tportalContentAnchor!: ViewContainerRef;\n\n\tprivate parentStore = injectNgtStore({ skipSelf: true });\n\tparentScene = this.parentStore.get('scene');\n\tparentCamera = this.parentStore.get('camera');\n\n\tprivate portalStore = injectNgtStore({ self: true });\n\tprivate injector = inject(Injector);\n\tprivate zone = inject(NgZone);\n\n\tprivate raycaster = new THREE.Raycaster();\n\tprivate pointer = new THREE.Vector2();\n\n\tportalContentRendered = false;\n\tprivate portalContentView?: EmbeddedViewRef<unknown>;\n\n\tconstructor() {\n\t\tinject(DestroyRef).onDestroy(() => {\n\t\t\tif (this.portalContentView && !this.portalContentView.destroyed) {\n\t\t\t\tthis.portalContentView.destroy();\n\t\t\t}\n\t\t});\n\t}\n\n\tngOnInit() {\n\t\tconst previousState = this.parentStore.get();\n\t\tconst inputsState = this.inputs.get();\n\n\t\tif (!inputsState.state && this.autoRender) {\n\t\t\tinputsState.state = { events: { priority: this.autoRenderPriority + 1 } };\n\t\t}\n\n\t\tconst { events, size, ...restInputsState } = inputsState.state || {};\n\n\t\tconst containerState = inputsState.container;\n\t\tlet container = is.ref(containerState) ? containerState.nativeElement : containerState;\n\n\t\tif (!is.instance(container)) {\n\t\t\tcontainer = prepare(container);\n\t\t}\n\n\t\tconst localState = getLocalState(container);\n\t\tif (!localState.store) {\n\t\t\tlocalState.store = this.portalStore;\n\t\t}\n\n\t\tthis.portalStore.set({\n\t\t\t...previousState,\n\t\t\tscene: container as THREE.Scene,\n\t\t\traycaster: this.raycaster,\n\t\t\tpointer: this.pointer,\n\t\t\tpreviousRoot: this.parentStore,\n\t\t\tevents: { ...previousState.events, ...(events || {}) },\n\t\t\tsize: { ...previousState.size, ...(size || {}) },\n\t\t\t...restInputsState,\n\t\t\tsetEvents: (events) =>\n\t\t\t\tthis.portalStore.set((state) => ({ ...state, events: { ...state.events, ...events } })),\n\t\t});\n\n\t\tconst parentState = this.parentStore.select();\n\t\teffect(\n\t\t\t() => {\n\t\t\t\tconst previous = parentState();\n\t\t\t\tthis.zone.runOutsideAngular(() => {\n\t\t\t\t\tthis.portalStore.set((state) => this.inject(previous, state));\n\t\t\t\t});\n\t\t\t},\n\t\t\t{ injector: this.injector },\n\t\t);\n\n\t\trequestAnimationFrame(() => {\n\t\t\tthis.portalStore.set((injectState) => this.inject(this.parentStore.get(), injectState));\n\t\t});\n\t\tthis.portalContentView = this.portalContentAnchor.createEmbeddedView(this.portalContentTemplate);\n\t\tsafeDetectChanges(this.portalContentView);\n\t\tthis.portalContentRendered = true;\n\t}\n\n\tonBeforeRender(portal: NgtRenderState) {\n\t\tthis.beforeRender.emit({\n\t\t\troot: { ...this.parentStore.get(), delta: portal.delta, frame: portal.frame },\n\t\t\tportal,\n\t\t});\n\t}\n\n\tprivate inject(rootState: NgtState, injectState: NgtState) {\n\t\tconst intersect: Partial<NgtState> = { ...rootState };\n\n\t\tObject.keys(intersect).forEach((key) => {\n\t\t\tif (\n\t\t\t\tprivateKeys.includes(key as PrivateKeys) ||\n\t\t\t\trootState[key as keyof NgtState] !== injectState[key as keyof NgtState]\n\t\t\t) {\n\t\t\t\tdelete intersect[key as keyof NgtState];\n\t\t\t}\n\t\t});\n\n\t\tconst inputs = this.inputs.get();\n\t\tconst { size, events, ...restInputsState } = inputs.state || {};\n\n\t\tlet viewport = undefined;\n\t\tif (injectState && size) {\n\t\t\tconst camera = injectState.camera;\n\t\t\tviewport = rootState.viewport.getCurrentViewport(camera, new THREE.Vector3(), size);\n\t\t\tif (camera !== rootState.camera) updateCamera(camera, size);\n\t\t}\n\n\t\treturn {\n\t\t\t...intersect,\n\t\t\tscene: is.ref(inputs.container) ? inputs.container.nativeElement : inputs.container,\n\t\t\traycaster: this.raycaster,\n\t\t\tpointer: this.pointer,\n\t\t\tpreviousRoot: this.parentStore,\n\t\t\tevents: { ...rootState.events, ...(injectState?.events || {}), ...events },\n\t\t\tsize: { ...rootState.size, ...size },\n\t\t\tviewport: { ...rootState.viewport, ...(viewport || {}) },\n\t\t\t...restInputsState,\n\t\t} as NgtState;\n\t}\n}\n"]}
221
+ }], ctorParameters: () => [] });
222
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"portal.js","sourceRoot":"","sources":["../../../../../libs/core/src/lib/portal.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n\tafterNextRender,\n\tChangeDetectionStrategy,\n\tComponent,\n\tcomputed,\n\tcontentChild,\n\tCUSTOM_ELEMENTS_SCHEMA,\n\tDestroyRef,\n\tDirective,\n\tEmbeddedViewRef,\n\tinject,\n\tInjector,\n\tinput,\n\tsignal,\n\tTemplateRef,\n\tuntracked,\n\tviewChild,\n\tViewContainerRef,\n} from '@angular/core';\nimport { injectAutoEffect } from 'ngxtension/auto-effect';\nimport { Camera, Object3D, Raycaster, Scene, Vector2, Vector3 } from 'three';\nimport { getLocalState, prepare } from './instance';\nimport { SPECIAL_INTERNAL_ADD_COMMENT } from './renderer/constants';\nimport { injectStore, provideStore } from './store';\nimport { NgtComputeFunction, NgtSize, NgtState } from './types';\nimport { injectBeforeRender } from './utils/before-render';\nimport { is } from './utils/is';\nimport { signalStore } from './utils/signal-store';\nimport { updateCamera } from './utils/update';\n\n@Component({\n\tselector: 'ngt-portal-before-render',\n\tstandalone: true,\n\ttemplate: `\n\t\t<!-- Without an element that receives pointer events state.pointer will always be 0/0 -->\n\t\t<ngt-group (pointerover)=\"onPointerOver()\" attach=\"none\" />\n\t`,\n\tschemas: [CUSTOM_ELEMENTS_SCHEMA],\n})\nexport class NgtPortalBeforeRender {\n\tprivate portalStore = injectStore();\n\n\trenderPriority = input(1);\n\tparentScene = input.required<Scene>();\n\tparentCamera = input.required<Camera>();\n\n\tconstructor() {\n\t\tinjectAutoEffect()((injector) => {\n\t\t\t// track state\n\t\t\tthis.portalStore.state();\n\t\t\tconst priority = this.renderPriority();\n\n\t\t\tlet oldClear: boolean;\n\t\t\treturn injectBeforeRender(\n\t\t\t\t() => {\n\t\t\t\t\tconst { gl, scene, camera } = this.portalStore.snapshot;\n\t\t\t\t\toldClear = gl.autoClear;\n\t\t\t\t\tif (this.renderPriority() === 1) {\n\t\t\t\t\t\t// clear scene and render with default\n\t\t\t\t\t\tgl.autoClear = true;\n\t\t\t\t\t\tgl.render(this.parentScene(), this.parentCamera());\n\t\t\t\t\t}\n\t\t\t\t\t// disable cleaning\n\t\t\t\t\tgl.autoClear = false;\n\t\t\t\t\tgl.clearDepth();\n\t\t\t\t\tgl.render(scene, camera);\n\t\t\t\t\t// restore\n\t\t\t\t\tgl.autoClear = oldClear;\n\t\t\t\t},\n\t\t\t\t{ priority, injector },\n\t\t\t);\n\t\t});\n\t}\n\n\tonPointerOver() {\n\t\t/* noop */\n\t}\n}\n\n@Directive({ selector: 'ng-template[portalContent]', standalone: true })\nexport class NgtPortalContent {\n\tconstructor() {\n\t\tconst { element: comment } = inject(ViewContainerRef);\n\t\tconst { element: parentComment } = inject(ViewContainerRef, { skipSelf: true });\n\n\t\tconst commentNode = comment.nativeElement;\n\t\tif (commentNode[SPECIAL_INTERNAL_ADD_COMMENT]) {\n\t\t\tcommentNode[SPECIAL_INTERNAL_ADD_COMMENT](parentComment.nativeElement);\n\t\t\tdelete commentNode[SPECIAL_INTERNAL_ADD_COMMENT];\n\t\t}\n\t}\n\n\tstatic ngTemplateContextGuard(_: NgtPortalContent, ctx: unknown): ctx is { container: Object3D; injector: Injector } {\n\t\treturn true;\n\t}\n}\n// Keys that shouldn't be copied between stores\nexport const privateKeys = [\n\t'setSize',\n\t'setFrameloop',\n\t'setDpr',\n\t'events',\n\t'setEvents',\n\t'invalidate',\n\t'advance',\n\t'size',\n\t'viewport',\n] as const;\n\nexport type NgtPortalPrivateKeys = (typeof privateKeys)[number];\n\nexport type NgtPortalInjectableState = Partial<\n\tOmit<NgtState, NgtPortalPrivateKeys> & {\n\t\tevents?: {\n\t\t\tenabled?: boolean;\n\t\t\tpriority?: number;\n\t\t\tcompute?: NgtComputeFunction;\n\t\t\tconnected?: any;\n\t\t};\n\t\tsize?: NgtSize;\n\t}\n>;\n\n@Component({\n\tselector: 'ngt-portal',\n\tstandalone: true,\n\ttemplate: `\n\t\t<ng-container #anchor />\n\n\t\t@if (renderAutoBeforeRender()) {\n\t\t\t<ngt-portal-before-render\n\t\t\t\t[renderPriority]=\"autoRenderPriority()\"\n\t\t\t\t[parentScene]=\"parentScene()\"\n\t\t\t\t[parentCamera]=\"parentCamera()\"\n\t\t\t/>\n\t\t}\n\t`,\n\timports: [NgtPortalBeforeRender],\n\tschemas: [CUSTOM_ELEMENTS_SCHEMA],\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\tproviders: [provideStore(() => signalStore({}))],\n})\nexport class NgtPortal {\n\tcontainer = input.required<Object3D>();\n\tstate = input<NgtPortalInjectableState>({});\n\n\t/**\n\t * @decsription turn this on to enable \"HUD\" like rendering\n\t */\n\tautoRender = input(false);\n\tautoRenderPriority = input(1);\n\n\tprivate portalContent = contentChild.required(NgtPortalContent, { read: TemplateRef });\n\tprivate portalAnchor = viewChild.required('anchor', { read: ViewContainerRef });\n\n\tprivate injector = inject(Injector);\n\tprivate portalStore = injectStore({ self: true });\n\tprivate parentStore = injectStore({ skipSelf: true });\n\tprotected parentScene = this.parentStore.select('scene');\n\tprotected parentCamera = this.parentStore.select('camera');\n\n\tprivate raycaster = new Raycaster();\n\tprivate pointer = new Vector2();\n\tprivate portalRendered = signal(false);\n\n\tprotected renderAutoBeforeRender = computed(() => this.portalRendered() && this.autoRender());\n\n\tprivate portalView?: EmbeddedViewRef<unknown>;\n\n\tconstructor() {\n\t\tconst autoEffect = injectAutoEffect();\n\n\t\tconst parentState = this.parentStore.select();\n\n\t\tafterNextRender(() => {\n\t\t\tconst previousState = this.parentStore.snapshot;\n\n\t\t\tconst { events = {}, size = {}, ...rest } = this.state();\n\t\t\tlet container = this.container();\n\n\t\t\tif (!is.instance(container)) {\n\t\t\t\tcontainer = prepare(container, { store: this.portalStore });\n\t\t\t}\n\n\t\t\tconst localState = getLocalState(container);\n\t\t\tif (localState && !localState.store) {\n\t\t\t\tlocalState.store = this.portalStore;\n\t\t\t}\n\n\t\t\tthis.portalStore.update({\n\t\t\t\t...previousState,\n\t\t\t\tscene: container as Scene,\n\t\t\t\traycaster: this.raycaster,\n\t\t\t\tpointer: this.pointer,\n\t\t\t\tevents: { ...previousState.events, ...events },\n\t\t\t\tsize: { ...previousState.size, ...size },\n\t\t\t\tpreviousRoot: this.parentStore,\n\t\t\t\t...rest,\n\t\t\t\tsetEvents: (events) =>\n\t\t\t\t\tthis.portalStore.update((state) => ({ ...state, events: { ...state.events, ...events } })),\n\t\t\t});\n\n\t\t\tautoEffect(() => {\n\t\t\t\tconst state = this.state();\n\t\t\t\tconst _parentState = parentState();\n\t\t\t\tthis.portalStore.update((prev) => this.inject(_parentState, prev, state, untracked(this.container)));\n\t\t\t\tuntracked(() => {\n\t\t\t\t\tif (this.portalView) {\n\t\t\t\t\t\tthis.portalView.detectChanges();\n\t\t\t\t\t\treturn;\n\t\t\t\t\t}\n\n\t\t\t\t\tthis.portalView = this.portalAnchor().createEmbeddedView(\n\t\t\t\t\t\tthis.portalContent(),\n\t\t\t\t\t\t{ container: this.container(), injector: this.injector },\n\t\t\t\t\t\t{ injector: this.injector },\n\t\t\t\t\t);\n\t\t\t\t\tthis.portalView.detectChanges();\n\t\t\t\t\tthis.portalRendered.set(true);\n\t\t\t\t});\n\t\t\t});\n\t\t});\n\n\t\tinject(DestroyRef).onDestroy(() => {\n\t\t\tthis.portalView?.destroy();\n\t\t});\n\t}\n\n\tprivate inject(\n\t\tparentState: NgtState,\n\t\tportalState: NgtState,\n\t\tinjectedState: NgtPortalInjectableState,\n\t\tcontainer: Object3D,\n\t) {\n\t\tconst { events = {}, size, ...rest } = injectedState;\n\t\tconst intersect: Partial<NgtState> = { ...parentState }; // all prev state props\n\n\t\tObject.keys(parentState).forEach((key) => {\n\t\t\tif (\n\t\t\t\tprivateKeys.includes(key as NgtPortalPrivateKeys) ||\n\t\t\t\t(parentState[key as keyof NgtState] !== portalState[key as keyof NgtState] &&\n\t\t\t\t\tportalState[key as keyof NgtState])\n\t\t\t) {\n\t\t\t\tdelete intersect[key as keyof NgtState];\n\t\t\t}\n\t\t});\n\n\t\tlet viewport = undefined;\n\t\tif (portalState && size) {\n\t\t\tconst camera = portalState.camera;\n\t\t\t// Calculate the override viewport, if present\n\t\t\tviewport = parentState.viewport.getCurrentViewport(camera, new Vector3(), size);\n\t\t\t// Update the portal camera, if it differs from the previous layer\n\t\t\tif (camera !== parentState.camera) {\n\t\t\t\tupdateCamera(camera, size);\n\t\t\t}\n\t\t}\n\n\t\treturn {\n\t\t\t...intersect,\n\t\t\tscene: container as Scene,\n\t\t\traycaster: this.raycaster,\n\t\t\tpointer: this.pointer,\n\t\t\tevents: { ...parentState.events, ...(portalState.events || {}), ...(events || {}) },\n\t\t\tsize: { ...parentState.size, ...(size || {}) },\n\t\t\tviewport: { ...parentState.viewport, ...(viewport || {}) },\n\t\t\t...rest,\n\t\t};\n\t}\n}\n"]}
@@ -1,7 +1,7 @@
1
- import { createInjectionToken } from '../utils/create-injection-token';
1
+ import { createInjectionToken } from 'ngxtension/create-injection-token';
2
2
  const catalogue = {};
3
3
  export function extend(objects) {
4
4
  Object.assign(catalogue, objects);
5
5
  }
6
- export const [injectNgtCatalogue] = createInjectionToken(() => catalogue);
7
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2F0YWxvZ3VlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb3JlL3NyYy9saWIvcmVuZGVyZXIvY2F0YWxvZ3VlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLGlDQUFpQyxDQUFDO0FBSXZFLE1BQU0sU0FBUyxHQUFzQyxFQUFFLENBQUM7QUFFeEQsTUFBTSxVQUFVLE1BQU0sQ0FBQyxPQUFlO0lBQ3JDLE1BQU0sQ0FBQyxNQUFNLENBQUMsU0FBUyxFQUFFLE9BQU8sQ0FBQyxDQUFDO0FBQ25DLENBQUM7QUFFRCxNQUFNLENBQUMsTUFBTSxDQUFDLGtCQUFrQixDQUFDLEdBQUcsb0JBQW9CLENBQUMsR0FBRyxFQUFFLENBQUMsU0FBUyxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjcmVhdGVJbmplY3Rpb25Ub2tlbiB9IGZyb20gJy4uL3V0aWxzL2NyZWF0ZS1pbmplY3Rpb24tdG9rZW4nO1xuXG5leHBvcnQgdHlwZSBOZ3RBbnlDb25zdHJ1Y3RvciA9IG5ldyAoLi4uYXJnczogYW55W10pID0+IGFueTtcblxuY29uc3QgY2F0YWxvZ3VlOiBSZWNvcmQ8c3RyaW5nLCBOZ3RBbnlDb25zdHJ1Y3Rvcj4gPSB7fTtcblxuZXhwb3J0IGZ1bmN0aW9uIGV4dGVuZChvYmplY3RzOiBvYmplY3QpOiB2b2lkIHtcblx0T2JqZWN0LmFzc2lnbihjYXRhbG9ndWUsIG9iamVjdHMpO1xufVxuXG5leHBvcnQgY29uc3QgW2luamVjdE5ndENhdGFsb2d1ZV0gPSBjcmVhdGVJbmplY3Rpb25Ub2tlbigoKSA9PiBjYXRhbG9ndWUpO1xuIl19
6
+ export const [injectCatalogue] = createInjectionToken(() => catalogue);
7
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2F0YWxvZ3VlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb3JlL3NyYy9saWIvcmVuZGVyZXIvY2F0YWxvZ3VlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLG1DQUFtQyxDQUFDO0FBSXpFLE1BQU0sU0FBUyxHQUFzQyxFQUFFLENBQUM7QUFFeEQsTUFBTSxVQUFVLE1BQU0sQ0FBQyxPQUFlO0lBQ3JDLE1BQU0sQ0FBQyxNQUFNLENBQUMsU0FBUyxFQUFFLE9BQU8sQ0FBQyxDQUFDO0FBQ25DLENBQUM7QUFFRCxNQUFNLENBQUMsTUFBTSxDQUFDLGVBQWUsQ0FBQyxHQUFHLG9CQUFvQixDQUFDLEdBQUcsRUFBRSxDQUFDLFNBQVMsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3JlYXRlSW5qZWN0aW9uVG9rZW4gfSBmcm9tICduZ3h0ZW5zaW9uL2NyZWF0ZS1pbmplY3Rpb24tdG9rZW4nO1xuXG5leHBvcnQgdHlwZSBOZ3RBbnlDb25zdHJ1Y3RvciA9IG5ldyAoLi4uYXJnczogYW55W10pID0+IGFueTtcblxuY29uc3QgY2F0YWxvZ3VlOiBSZWNvcmQ8c3RyaW5nLCBOZ3RBbnlDb25zdHJ1Y3Rvcj4gPSB7fTtcblxuZXhwb3J0IGZ1bmN0aW9uIGV4dGVuZChvYmplY3RzOiBvYmplY3QpOiB2b2lkIHtcblx0T2JqZWN0LmFzc2lnbihjYXRhbG9ndWUsIG9iamVjdHMpO1xufVxuXG5leHBvcnQgY29uc3QgW2luamVjdENhdGFsb2d1ZV0gPSBjcmVhdGVJbmplY3Rpb25Ub2tlbigoKSA9PiBjYXRhbG9ndWUpO1xuIl19
@@ -7,15 +7,15 @@ export const SPECIAL_DOM_TAG = {
7
7
  NGT_VALUE: 'ngt-value',
8
8
  };
9
9
  export const SPECIAL_PROPERTIES = {
10
- COMPOUND: 'ngtCompound',
11
10
  RENDER_PRIORITY: 'priority',
12
11
  ATTACH: 'attach',
13
- VALUE: 'rawValue',
14
- REF: 'ref',
12
+ RAW_VALUE: 'rawValue',
13
+ PARAMETERS: 'parameters',
15
14
  };
16
15
  export const SPECIAL_EVENTS = {
17
16
  BEFORE_RENDER: 'beforeRender',
18
- AFTER_UPDATE: 'afterUpdate',
19
- AFTER_ATTACH: 'afterAttach',
17
+ UPDATED: 'updated',
18
+ ATTACHED: 'attached',
20
19
  };
21
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc3RhbnRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb3JlL3NyYy9saWIvcmVuZGVyZXIvY29uc3RhbnRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBQyxNQUFNLFlBQVksR0FBRyxrQ0FBa0MsQ0FBQztBQUMvRCxNQUFNLENBQUMsTUFBTSxJQUFJLEdBQUcsd0JBQXdCLENBQUM7QUFDN0MsTUFBTSxDQUFDLE1BQU0sNEJBQTRCLEdBQUcsOEJBQThCLENBQUM7QUFFM0UsTUFBTSxDQUFDLE1BQU0sZUFBZSxHQUFHO0lBQzlCLFVBQVUsRUFBRSxZQUFZO0lBQ3hCLGFBQWEsRUFBRSxlQUFlO0lBQzlCLFNBQVMsRUFBRSxXQUFXO0NBQ2IsQ0FBQztBQUVYLE1BQU0sQ0FBQyxNQUFNLGtCQUFrQixHQUFHO0lBQ2pDLFFBQVEsRUFBRSxhQUFhO0lBQ3ZCLGVBQWUsRUFBRSxVQUFVO0lBQzNCLE1BQU0sRUFBRSxRQUFRO0lBQ2hCLEtBQUssRUFBRSxVQUFVO0lBQ2pCLEdBQUcsRUFBRSxLQUFLO0NBQ0QsQ0FBQztBQUVYLE1BQU0sQ0FBQyxNQUFNLGNBQWMsR0FBRztJQUM3QixhQUFhLEVBQUUsY0FBYztJQUM3QixZQUFZLEVBQUUsYUFBYTtJQUMzQixZQUFZLEVBQUUsYUFBYTtDQUNsQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNvbnN0IFJPVVRFRF9TQ0VORSA9ICdfX25ndF9yZW5kZXJlcl9pc19yb3V0ZWRfc2NlbmVfXyc7XG5leHBvcnQgY29uc3QgSFRNTCA9ICdfX25ndF9yZW5kZXJlcl9pc19odG1sJztcbmV4cG9ydCBjb25zdCBTUEVDSUFMX0lOVEVSTkFMX0FERF9DT01NRU5UID0gJ19fbmd0X3JlbmRlcmVyX2FkZF9jb21tZW50X18nO1xuXG5leHBvcnQgY29uc3QgU1BFQ0lBTF9ET01fVEFHID0ge1xuXHROR1RfUE9SVEFMOiAnbmd0LXBvcnRhbCcsXG5cdE5HVF9QUklNSVRJVkU6ICduZ3QtcHJpbWl0aXZlJyxcblx0TkdUX1ZBTFVFOiAnbmd0LXZhbHVlJyxcbn0gYXMgY29uc3Q7XG5cbmV4cG9ydCBjb25zdCBTUEVDSUFMX1BST1BFUlRJRVMgPSB7XG5cdENPTVBPVU5EOiAnbmd0Q29tcG91bmQnLFxuXHRSRU5ERVJfUFJJT1JJVFk6ICdwcmlvcml0eScsXG5cdEFUVEFDSDogJ2F0dGFjaCcsXG5cdFZBTFVFOiAncmF3VmFsdWUnLFxuXHRSRUY6ICdyZWYnLFxufSBhcyBjb25zdDtcblxuZXhwb3J0IGNvbnN0IFNQRUNJQUxfRVZFTlRTID0ge1xuXHRCRUZPUkVfUkVOREVSOiAnYmVmb3JlUmVuZGVyJyxcblx0QUZURVJfVVBEQVRFOiAnYWZ0ZXJVcGRhdGUnLFxuXHRBRlRFUl9BVFRBQ0g6ICdhZnRlckF0dGFjaCcsXG59IGFzIGNvbnN0O1xuIl19
20
+ export const THREE_NATIVE_EVENTS = ['added', 'removed', 'childadded', 'childremoved', 'disposed'];
21
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc3RhbnRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb3JlL3NyYy9saWIvcmVuZGVyZXIvY29uc3RhbnRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBQyxNQUFNLFlBQVksR0FBRyxrQ0FBa0MsQ0FBQztBQUMvRCxNQUFNLENBQUMsTUFBTSxJQUFJLEdBQUcsd0JBQXdCLENBQUM7QUFDN0MsTUFBTSxDQUFDLE1BQU0sNEJBQTRCLEdBQUcsOEJBQThCLENBQUM7QUFFM0UsTUFBTSxDQUFDLE1BQU0sZUFBZSxHQUFHO0lBQzlCLFVBQVUsRUFBRSxZQUFZO0lBQ3hCLGFBQWEsRUFBRSxlQUFlO0lBQzlCLFNBQVMsRUFBRSxXQUFXO0NBQ2IsQ0FBQztBQUVYLE1BQU0sQ0FBQyxNQUFNLGtCQUFrQixHQUFHO0lBQ2pDLGVBQWUsRUFBRSxVQUFVO0lBQzNCLE1BQU0sRUFBRSxRQUFRO0lBQ2hCLFNBQVMsRUFBRSxVQUFVO0lBQ3JCLFVBQVUsRUFBRSxZQUFZO0NBQ2YsQ0FBQztBQUVYLE1BQU0sQ0FBQyxNQUFNLGNBQWMsR0FBRztJQUM3QixhQUFhLEVBQUUsY0FBYztJQUM3QixPQUFPLEVBQUUsU0FBUztJQUNsQixRQUFRLEVBQUUsVUFBVTtDQUNYLENBQUM7QUFFWCxNQUFNLENBQUMsTUFBTSxtQkFBbUIsR0FBRyxDQUFDLE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLGNBQWMsRUFBRSxVQUFVLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjb25zdCBST1VURURfU0NFTkUgPSAnX19uZ3RfcmVuZGVyZXJfaXNfcm91dGVkX3NjZW5lX18nO1xuZXhwb3J0IGNvbnN0IEhUTUwgPSAnX19uZ3RfcmVuZGVyZXJfaXNfaHRtbCc7XG5leHBvcnQgY29uc3QgU1BFQ0lBTF9JTlRFUk5BTF9BRERfQ09NTUVOVCA9ICdfX25ndF9yZW5kZXJlcl9hZGRfY29tbWVudF9fJztcblxuZXhwb3J0IGNvbnN0IFNQRUNJQUxfRE9NX1RBRyA9IHtcblx0TkdUX1BPUlRBTDogJ25ndC1wb3J0YWwnLFxuXHROR1RfUFJJTUlUSVZFOiAnbmd0LXByaW1pdGl2ZScsXG5cdE5HVF9WQUxVRTogJ25ndC12YWx1ZScsXG59IGFzIGNvbnN0O1xuXG5leHBvcnQgY29uc3QgU1BFQ0lBTF9QUk9QRVJUSUVTID0ge1xuXHRSRU5ERVJfUFJJT1JJVFk6ICdwcmlvcml0eScsXG5cdEFUVEFDSDogJ2F0dGFjaCcsXG5cdFJBV19WQUxVRTogJ3Jhd1ZhbHVlJyxcblx0UEFSQU1FVEVSUzogJ3BhcmFtZXRlcnMnLFxufSBhcyBjb25zdDtcblxuZXhwb3J0IGNvbnN0IFNQRUNJQUxfRVZFTlRTID0ge1xuXHRCRUZPUkVfUkVOREVSOiAnYmVmb3JlUmVuZGVyJyxcblx0VVBEQVRFRDogJ3VwZGF0ZWQnLFxuXHRBVFRBQ0hFRDogJ2F0dGFjaGVkJyxcbn0gYXMgY29uc3Q7XG5cbmV4cG9ydCBjb25zdCBUSFJFRV9OQVRJVkVfRVZFTlRTID0gWydhZGRlZCcsICdyZW1vdmVkJywgJ2NoaWxkYWRkZWQnLCAnY2hpbGRyZW1vdmVkJywgJ2Rpc3Bvc2VkJ107XG4iXX0=