angular-three 0.0.7 → 1.0.0-beta.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 (441) hide show
  1. package/esm2020/angular-three.mjs +1 -1
  2. package/esm2020/index.mjs +2 -35
  3. package/esm2020/lib/canvas.mjs +141 -128
  4. package/esm2020/lib/di/catalogue.mjs +7 -0
  5. package/esm2020/lib/directives/args.mjs +37 -17
  6. package/esm2020/lib/directives/repeat.mjs +5 -8
  7. package/esm2020/lib/events.mjs +341 -52
  8. package/esm2020/lib/loader.mjs +55 -0
  9. package/esm2020/lib/loop.mjs +137 -0
  10. package/esm2020/lib/renderer/di.mjs +3 -0
  11. package/esm2020/lib/renderer/enums.mjs +2 -0
  12. package/esm2020/lib/renderer/provider.mjs +19 -0
  13. package/esm2020/lib/renderer/renderer.mjs +293 -0
  14. package/esm2020/lib/renderer/state.mjs +350 -0
  15. package/esm2020/lib/renderer/utils.mjs +177 -0
  16. package/esm2020/lib/stores/rx-store.mjs +99 -0
  17. package/esm2020/lib/stores/store.mjs +190 -239
  18. package/esm2020/lib/types.mjs +1 -1
  19. package/esm2020/lib/utils/apply-props.mjs +37 -80
  20. package/esm2020/lib/utils/attach.mjs +29 -0
  21. package/esm2020/lib/utils/instance.mjs +43 -28
  22. package/esm2020/lib/utils/is.mjs +7 -11
  23. package/esm2020/lib/utils/make.mjs +30 -10
  24. package/esm2020/lib/utils/update.mjs +37 -0
  25. package/esm2020/lib/web/events.mjs +68 -0
  26. package/fesm2015/angular-three.mjs +2053 -2046
  27. package/fesm2015/angular-three.mjs.map +1 -1
  28. package/fesm2020/angular-three.mjs +2003 -1990
  29. package/fesm2020/angular-three.mjs.map +1 -1
  30. package/index.d.ts +1 -34
  31. package/lib/canvas.d.ts +29 -28
  32. package/lib/di/catalogue.d.ts +3 -0
  33. package/lib/directives/args.d.ts +8 -12
  34. package/lib/events.d.ts +7 -2
  35. package/lib/loader.d.ts +15 -0
  36. package/lib/{utils/loop.d.ts → loop.d.ts} +7 -6
  37. package/lib/renderer/di.d.ts +2 -0
  38. package/lib/renderer/enums.d.ts +25 -0
  39. package/lib/renderer/provider.d.ts +25 -0
  40. package/lib/renderer/renderer.d.ts +49 -0
  41. package/lib/renderer/state.d.ts +59 -0
  42. package/lib/renderer/utils.d.ts +20 -0
  43. package/lib/stores/rx-store.d.ts +17 -0
  44. package/lib/stores/store.d.ts +6 -23
  45. package/lib/types.d.ts +182 -191
  46. package/lib/utils/apply-props.d.ts +2 -6
  47. package/lib/utils/attach.d.ts +3 -0
  48. package/lib/utils/instance.d.ts +3 -3
  49. package/lib/utils/is.d.ts +6 -10
  50. package/lib/utils/make.d.ts +5 -2
  51. package/lib/utils/update.d.ts +4 -0
  52. package/lib/web/events.d.ts +4 -0
  53. package/package.json +30 -99
  54. package/attributes/README.md +0 -3
  55. package/attributes/index.d.ts +0 -22
  56. package/attributes/lib/buffer-attribute/buffer-attribute.d.ts +0 -8
  57. package/attributes/lib/color-attribute/color-attribute.d.ts +0 -8
  58. package/attributes/lib/common.d.ts +0 -1
  59. package/attributes/lib/float16-buffer-attribute/float16-buffer-attribute.d.ts +0 -8
  60. package/attributes/lib/float32-buffer-attribute/float32-buffer-attribute.d.ts +0 -8
  61. package/attributes/lib/float64-buffer-attribute/float64-buffer-attribute.d.ts +0 -8
  62. package/attributes/lib/fog-attribute/fog-attribute.d.ts +0 -8
  63. package/attributes/lib/fog-exp2-attribute/fog-exp2-attribute.d.ts +0 -8
  64. package/attributes/lib/instanced-buffer-attribute/instanced-buffer-attribute.d.ts +0 -8
  65. package/attributes/lib/int16-buffer-attribute/int16-buffer-attribute.d.ts +0 -8
  66. package/attributes/lib/int32-buffer-attribute/int32-buffer-attribute.d.ts +0 -8
  67. package/attributes/lib/int8-buffer-attribute/int8-buffer-attribute.d.ts +0 -8
  68. package/attributes/lib/interleaved-buffer-attribute/interleaved-buffer-attribute.d.ts +0 -8
  69. package/attributes/lib/matrix3-attribute/matrix3-attribute.d.ts +0 -8
  70. package/attributes/lib/matrix4-attribute/matrix4-attribute.d.ts +0 -8
  71. package/attributes/lib/uint16-buffer-attribute/uint16-buffer-attribute.d.ts +0 -8
  72. package/attributes/lib/uint32-buffer-attribute/uint32-buffer-attribute.d.ts +0 -8
  73. package/attributes/lib/uint8-buffer-attribute/uint8-buffer-attribute.d.ts +0 -8
  74. package/attributes/lib/uint8-clamped-buffer-attribute/uint8-clamped-buffer-attribute.d.ts +0 -8
  75. package/attributes/lib/value-attribute/value-attribute.d.ts +0 -8
  76. package/attributes/lib/vector2-attribute/vector2-attribute.d.ts +0 -8
  77. package/attributes/lib/vector3-attribute/vector3-attribute.d.ts +0 -8
  78. package/attributes/lib/vector4-attribute/vector4-attribute.d.ts +0 -8
  79. package/audios/README.md +0 -3
  80. package/audios/index.d.ts +0 -3
  81. package/audios/lib/audio/audio.d.ts +0 -49
  82. package/audios/lib/audio-listener/audio-listener.d.ts +0 -35
  83. package/audios/lib/common.d.ts +0 -3
  84. package/audios/lib/positional-audio/positional-audio.d.ts +0 -49
  85. package/cameras/README.md +0 -3
  86. package/cameras/index.d.ts +0 -5
  87. package/cameras/lib/array-camera/array-camera.d.ts +0 -56
  88. package/cameras/lib/common.d.ts +0 -3
  89. package/cameras/lib/cube-camera/cube-camera.d.ts +0 -36
  90. package/cameras/lib/orthographic-camera/orthographic-camera.d.ts +0 -54
  91. package/cameras/lib/perspective-camera/perspective-camera.d.ts +0 -55
  92. package/cameras/lib/stereo-camera/stereo-camera.d.ts +0 -42
  93. package/esm2020/attributes/angular-three-attributes.mjs +0 -5
  94. package/esm2020/attributes/index.mjs +0 -24
  95. package/esm2020/attributes/lib/buffer-attribute/buffer-attribute.mjs +0 -26
  96. package/esm2020/attributes/lib/color-attribute/color-attribute.mjs +0 -26
  97. package/esm2020/attributes/lib/common.mjs +0 -13
  98. package/esm2020/attributes/lib/float16-buffer-attribute/float16-buffer-attribute.mjs +0 -26
  99. package/esm2020/attributes/lib/float32-buffer-attribute/float32-buffer-attribute.mjs +0 -26
  100. package/esm2020/attributes/lib/float64-buffer-attribute/float64-buffer-attribute.mjs +0 -26
  101. package/esm2020/attributes/lib/fog-attribute/fog-attribute.mjs +0 -26
  102. package/esm2020/attributes/lib/fog-exp2-attribute/fog-exp2-attribute.mjs +0 -26
  103. package/esm2020/attributes/lib/instanced-buffer-attribute/instanced-buffer-attribute.mjs +0 -26
  104. package/esm2020/attributes/lib/int16-buffer-attribute/int16-buffer-attribute.mjs +0 -26
  105. package/esm2020/attributes/lib/int32-buffer-attribute/int32-buffer-attribute.mjs +0 -26
  106. package/esm2020/attributes/lib/int8-buffer-attribute/int8-buffer-attribute.mjs +0 -26
  107. package/esm2020/attributes/lib/interleaved-buffer-attribute/interleaved-buffer-attribute.mjs +0 -30
  108. package/esm2020/attributes/lib/matrix3-attribute/matrix3-attribute.mjs +0 -26
  109. package/esm2020/attributes/lib/matrix4-attribute/matrix4-attribute.mjs +0 -26
  110. package/esm2020/attributes/lib/uint16-buffer-attribute/uint16-buffer-attribute.mjs +0 -26
  111. package/esm2020/attributes/lib/uint32-buffer-attribute/uint32-buffer-attribute.mjs +0 -26
  112. package/esm2020/attributes/lib/uint8-buffer-attribute/uint8-buffer-attribute.mjs +0 -26
  113. package/esm2020/attributes/lib/uint8-clamped-buffer-attribute/uint8-clamped-buffer-attribute.mjs +0 -26
  114. package/esm2020/attributes/lib/value-attribute/value-attribute.mjs +0 -28
  115. package/esm2020/attributes/lib/vector2-attribute/vector2-attribute.mjs +0 -26
  116. package/esm2020/attributes/lib/vector3-attribute/vector3-attribute.mjs +0 -26
  117. package/esm2020/attributes/lib/vector4-attribute/vector4-attribute.mjs +0 -26
  118. package/esm2020/audios/angular-three-audios.mjs +0 -5
  119. package/esm2020/audios/index.mjs +0 -5
  120. package/esm2020/audios/lib/audio/audio.mjs +0 -45
  121. package/esm2020/audios/lib/audio-listener/audio-listener.mjs +0 -38
  122. package/esm2020/audios/lib/common.mjs +0 -54
  123. package/esm2020/audios/lib/positional-audio/positional-audio.mjs +0 -45
  124. package/esm2020/cameras/angular-three-cameras.mjs +0 -5
  125. package/esm2020/cameras/index.mjs +0 -7
  126. package/esm2020/cameras/lib/array-camera/array-camera.mjs +0 -44
  127. package/esm2020/cameras/lib/common.mjs +0 -54
  128. package/esm2020/cameras/lib/cube-camera/cube-camera.mjs +0 -30
  129. package/esm2020/cameras/lib/orthographic-camera/orthographic-camera.mjs +0 -42
  130. package/esm2020/cameras/lib/perspective-camera/perspective-camera.mjs +0 -43
  131. package/esm2020/cameras/lib/stereo-camera/stereo-camera.mjs +0 -38
  132. package/esm2020/geometries/angular-three-geometries.mjs +0 -5
  133. package/esm2020/geometries/index.mjs +0 -25
  134. package/esm2020/geometries/lib/box-geometry/box-geometry.mjs +0 -26
  135. package/esm2020/geometries/lib/buffer-geometry/buffer-geometry.mjs +0 -26
  136. package/esm2020/geometries/lib/capsule-geometry/capsule-geometry.mjs +0 -26
  137. package/esm2020/geometries/lib/circle-geometry/circle-geometry.mjs +0 -26
  138. package/esm2020/geometries/lib/common.mjs +0 -13
  139. package/esm2020/geometries/lib/cone-geometry/cone-geometry.mjs +0 -26
  140. package/esm2020/geometries/lib/cylinder-geometry/cylinder-geometry.mjs +0 -26
  141. package/esm2020/geometries/lib/dodecahedron-geometry/dodecahedron-geometry.mjs +0 -26
  142. package/esm2020/geometries/lib/edges-geometry/edges-geometry.mjs +0 -26
  143. package/esm2020/geometries/lib/extrude-geometry/extrude-geometry.mjs +0 -26
  144. package/esm2020/geometries/lib/icosahedron-geometry/icosahedron-geometry.mjs +0 -26
  145. package/esm2020/geometries/lib/instanced-buffer-geometry/instanced-buffer-geometry.mjs +0 -26
  146. package/esm2020/geometries/lib/lathe-geometry/lathe-geometry.mjs +0 -26
  147. package/esm2020/geometries/lib/octahedron-geometry/octahedron-geometry.mjs +0 -26
  148. package/esm2020/geometries/lib/plane-geometry/plane-geometry.mjs +0 -26
  149. package/esm2020/geometries/lib/polyhedron-geometry/polyhedron-geometry.mjs +0 -26
  150. package/esm2020/geometries/lib/ring-geometry/ring-geometry.mjs +0 -26
  151. package/esm2020/geometries/lib/shape-geometry/shape-geometry.mjs +0 -26
  152. package/esm2020/geometries/lib/sphere-geometry/sphere-geometry.mjs +0 -26
  153. package/esm2020/geometries/lib/tetrahedron-geometry/tetrahedron-geometry.mjs +0 -26
  154. package/esm2020/geometries/lib/torus-geometry/torus-geometry.mjs +0 -26
  155. package/esm2020/geometries/lib/torus-knot-geometry/torus-knot-geometry.mjs +0 -26
  156. package/esm2020/geometries/lib/tube-geometry/tube-geometry.mjs +0 -26
  157. package/esm2020/geometries/lib/wireframe-geometry/wireframe-geometry.mjs +0 -26
  158. package/esm2020/helpers/angular-three-helpers.mjs +0 -5
  159. package/esm2020/helpers/index.mjs +0 -15
  160. package/esm2020/helpers/lib/arrow-helper/arrow-helper.mjs +0 -26
  161. package/esm2020/helpers/lib/axes-helper/axes-helper.mjs +0 -26
  162. package/esm2020/helpers/lib/box-helper/box-helper.mjs +0 -36
  163. package/esm2020/helpers/lib/box3-helper/box3-helper.mjs +0 -36
  164. package/esm2020/helpers/lib/camera-helper/camera-helper.mjs +0 -36
  165. package/esm2020/helpers/lib/common.mjs +0 -13
  166. package/esm2020/helpers/lib/directional-light-helper/directional-light-helper.mjs +0 -36
  167. package/esm2020/helpers/lib/grid-helper/grid-helper.mjs +0 -26
  168. package/esm2020/helpers/lib/hemisphere-light-helper/hemisphere-light-helper.mjs +0 -36
  169. package/esm2020/helpers/lib/plane-helper/plane-helper.mjs +0 -36
  170. package/esm2020/helpers/lib/point-light-helper/point-light-helper.mjs +0 -36
  171. package/esm2020/helpers/lib/polar-grid-helper/polar-grid-helper.mjs +0 -26
  172. package/esm2020/helpers/lib/skeleton-helper/skeleton-helper.mjs +0 -36
  173. package/esm2020/helpers/lib/spot-light-helper/spot-light-helper.mjs +0 -36
  174. package/esm2020/lib/di/resize.mjs +0 -19
  175. package/esm2020/lib/di/window.mjs +0 -13
  176. package/esm2020/lib/directives/cursor.mjs +0 -35
  177. package/esm2020/lib/instance.mjs +0 -368
  178. package/esm2020/lib/pipes/math.mjs +0 -15
  179. package/esm2020/lib/pipes/pi.mjs +0 -14
  180. package/esm2020/lib/pipes/radian.mjs +0 -14
  181. package/esm2020/lib/pipes/side.mjs +0 -22
  182. package/esm2020/lib/ref.mjs +0 -15
  183. package/esm2020/lib/services/loader.mjs +0 -45
  184. package/esm2020/lib/services/resize.mjs +0 -127
  185. package/esm2020/lib/stores/component-store.mjs +0 -137
  186. package/esm2020/lib/utils/build-graph.mjs +0 -15
  187. package/esm2020/lib/utils/camera.mjs +0 -28
  188. package/esm2020/lib/utils/capitalize.mjs +0 -4
  189. package/esm2020/lib/utils/check-update.mjs +0 -22
  190. package/esm2020/lib/utils/events.mjs +0 -353
  191. package/esm2020/lib/utils/get-instance-local-state.mjs +0 -6
  192. package/esm2020/lib/utils/inject.mjs +0 -18
  193. package/esm2020/lib/utils/loop.mjs +0 -139
  194. package/esm2020/lib/utils/mutate.mjs +0 -24
  195. package/esm2020/lib/utils/proxy.mjs +0 -99
  196. package/esm2020/lib/utils/renderer.mjs +0 -15
  197. package/esm2020/lights/angular-three-lights.mjs +0 -5
  198. package/esm2020/lights/index.mjs +0 -11
  199. package/esm2020/lights/lib/ambient-light/ambient-light.mjs +0 -30
  200. package/esm2020/lights/lib/ambient-light-probe/ambient-light-probe.mjs +0 -30
  201. package/esm2020/lights/lib/common.mjs +0 -54
  202. package/esm2020/lights/lib/directional-light/directional-light.mjs +0 -30
  203. package/esm2020/lights/lib/hemisphere-light/hemisphere-light.mjs +0 -30
  204. package/esm2020/lights/lib/hemisphere-light-probe/hemisphere-light-probe.mjs +0 -30
  205. package/esm2020/lights/lib/light-probe/light-probe.mjs +0 -30
  206. package/esm2020/lights/lib/point-light/point-light.mjs +0 -30
  207. package/esm2020/lights/lib/rect-area-light/rect-area-light.mjs +0 -30
  208. package/esm2020/lights/lib/spot-light/spot-light.mjs +0 -42
  209. package/esm2020/materials/angular-three-materials.mjs +0 -5
  210. package/esm2020/materials/index.mjs +0 -19
  211. package/esm2020/materials/lib/common.mjs +0 -13
  212. package/esm2020/materials/lib/line-basic-material/line-basic-material.mjs +0 -77
  213. package/esm2020/materials/lib/line-dashed-material/line-dashed-material.mjs +0 -80
  214. package/esm2020/materials/lib/mesh-basic-material/mesh-basic-material.mjs +0 -89
  215. package/esm2020/materials/lib/mesh-depth-material/mesh-depth-material.mjs +0 -80
  216. package/esm2020/materials/lib/mesh-distance-material/mesh-distance-material.mjs +0 -80
  217. package/esm2020/materials/lib/mesh-lambert-material/mesh-lambert-material.mjs +0 -100
  218. package/esm2020/materials/lib/mesh-matcap-material/mesh-matcap-material.mjs +0 -86
  219. package/esm2020/materials/lib/mesh-normal-material/mesh-normal-material.mjs +0 -83
  220. package/esm2020/materials/lib/mesh-phong-material/mesh-phong-material.mjs +0 -103
  221. package/esm2020/materials/lib/mesh-physical-material/mesh-physical-material.mjs +0 -119
  222. package/esm2020/materials/lib/mesh-standard-material/mesh-standard-material.mjs +0 -100
  223. package/esm2020/materials/lib/mesh-toon-material/mesh-toon-material.mjs +0 -96
  224. package/esm2020/materials/lib/points-material/points-material.mjs +0 -78
  225. package/esm2020/materials/lib/raw-shader-material/raw-shader-material.mjs +0 -83
  226. package/esm2020/materials/lib/shader-material/shader-material.mjs +0 -83
  227. package/esm2020/materials/lib/shadow-material/shadow-material.mjs +0 -74
  228. package/esm2020/materials/lib/sprite-material/sprite-material.mjs +0 -78
  229. package/esm2020/objects/angular-three-objects.mjs +0 -5
  230. package/esm2020/objects/index.mjs +0 -14
  231. package/esm2020/objects/lib/bone/bone.mjs +0 -27
  232. package/esm2020/objects/lib/common.mjs +0 -54
  233. package/esm2020/objects/lib/group/group.mjs +0 -27
  234. package/esm2020/objects/lib/instanced-mesh/instanced-mesh.mjs +0 -40
  235. package/esm2020/objects/lib/line/line.mjs +0 -30
  236. package/esm2020/objects/lib/line-loop/line-loop.mjs +0 -30
  237. package/esm2020/objects/lib/line-segments/line-segments.mjs +0 -30
  238. package/esm2020/objects/lib/lod/lod.mjs +0 -30
  239. package/esm2020/objects/lib/mesh/mesh.mjs +0 -30
  240. package/esm2020/objects/lib/points/points.mjs +0 -30
  241. package/esm2020/objects/lib/skeleton/skeleton.mjs +0 -41
  242. package/esm2020/objects/lib/skinned-mesh/skinned-mesh.mjs +0 -39
  243. package/esm2020/objects/lib/sprite/sprite.mjs +0 -30
  244. package/esm2020/primitives/angular-three-primitives.mjs +0 -5
  245. package/esm2020/primitives/index.mjs +0 -3
  246. package/esm2020/primitives/lib/common.mjs +0 -54
  247. package/esm2020/primitives/lib/object-primitive/object-primitive.mjs +0 -27
  248. package/esm2020/primitives/lib/primitive/primitive.mjs +0 -38
  249. package/esm2020/stats/angular-three-stats.mjs +0 -5
  250. package/esm2020/stats/index.mjs +0 -2
  251. package/esm2020/stats/lib/stats/stats.mjs +0 -54
  252. package/esm2020/textures/angular-three-textures.mjs +0 -5
  253. package/esm2020/textures/index.mjs +0 -12
  254. package/esm2020/textures/lib/canvas-texture/canvas-texture.mjs +0 -26
  255. package/esm2020/textures/lib/common.mjs +0 -13
  256. package/esm2020/textures/lib/compressed-array-texture/compressed-array-texture.mjs +0 -26
  257. package/esm2020/textures/lib/compressed-texture/compressed-texture.mjs +0 -26
  258. package/esm2020/textures/lib/cube-texture/cube-texture.mjs +0 -26
  259. package/esm2020/textures/lib/data-array-texture/data-array-texture.mjs +0 -26
  260. package/esm2020/textures/lib/data-texture/data-texture.mjs +0 -26
  261. package/esm2020/textures/lib/data3-dtexture/data3-dtexture.mjs +0 -26
  262. package/esm2020/textures/lib/depth-texture/depth-texture.mjs +0 -26
  263. package/esm2020/textures/lib/framebuffer-texture/framebuffer-texture.mjs +0 -26
  264. package/esm2020/textures/lib/video-texture/video-texture.mjs +0 -26
  265. package/fesm2015/angular-three-attributes.mjs +0 -475
  266. package/fesm2015/angular-three-attributes.mjs.map +0 -1
  267. package/fesm2015/angular-three-audios.mjs +0 -179
  268. package/fesm2015/angular-three-audios.mjs.map +0 -1
  269. package/fesm2015/angular-three-cameras.mjs +0 -236
  270. package/fesm2015/angular-three-cameras.mjs.map +0 -1
  271. package/fesm2015/angular-three-geometries.mjs +0 -488
  272. package/fesm2015/angular-three-geometries.mjs.map +0 -1
  273. package/fesm2015/angular-three-helpers.mjs +0 -378
  274. package/fesm2015/angular-three-helpers.mjs.map +0 -1
  275. package/fesm2015/angular-three-lights.mjs +0 -297
  276. package/fesm2015/angular-three-lights.mjs.map +0 -1
  277. package/fesm2015/angular-three-materials.mjs +0 -1415
  278. package/fesm2015/angular-three-materials.mjs.map +0 -1
  279. package/fesm2015/angular-three-objects.mjs +0 -381
  280. package/fesm2015/angular-three-objects.mjs.map +0 -1
  281. package/fesm2015/angular-three-primitives.mjs +0 -120
  282. package/fesm2015/angular-three-primitives.mjs.map +0 -1
  283. package/fesm2015/angular-three-stats.mjs +0 -62
  284. package/fesm2015/angular-three-stats.mjs.map +0 -1
  285. package/fesm2015/angular-three-textures.mjs +0 -228
  286. package/fesm2015/angular-three-textures.mjs.map +0 -1
  287. package/fesm2020/angular-three-attributes.mjs +0 -475
  288. package/fesm2020/angular-three-attributes.mjs.map +0 -1
  289. package/fesm2020/angular-three-audios.mjs +0 -179
  290. package/fesm2020/angular-three-audios.mjs.map +0 -1
  291. package/fesm2020/angular-three-cameras.mjs +0 -236
  292. package/fesm2020/angular-three-cameras.mjs.map +0 -1
  293. package/fesm2020/angular-three-geometries.mjs +0 -488
  294. package/fesm2020/angular-three-geometries.mjs.map +0 -1
  295. package/fesm2020/angular-three-helpers.mjs +0 -378
  296. package/fesm2020/angular-three-helpers.mjs.map +0 -1
  297. package/fesm2020/angular-three-lights.mjs +0 -297
  298. package/fesm2020/angular-three-lights.mjs.map +0 -1
  299. package/fesm2020/angular-three-materials.mjs +0 -1415
  300. package/fesm2020/angular-three-materials.mjs.map +0 -1
  301. package/fesm2020/angular-three-objects.mjs +0 -381
  302. package/fesm2020/angular-three-objects.mjs.map +0 -1
  303. package/fesm2020/angular-three-primitives.mjs +0 -120
  304. package/fesm2020/angular-three-primitives.mjs.map +0 -1
  305. package/fesm2020/angular-three-stats.mjs +0 -62
  306. package/fesm2020/angular-three-stats.mjs.map +0 -1
  307. package/fesm2020/angular-three-textures.mjs +0 -228
  308. package/fesm2020/angular-three-textures.mjs.map +0 -1
  309. package/geometries/README.md +0 -3
  310. package/geometries/index.d.ts +0 -23
  311. package/geometries/lib/box-geometry/box-geometry.d.ts +0 -8
  312. package/geometries/lib/buffer-geometry/buffer-geometry.d.ts +0 -8
  313. package/geometries/lib/capsule-geometry/capsule-geometry.d.ts +0 -8
  314. package/geometries/lib/circle-geometry/circle-geometry.d.ts +0 -8
  315. package/geometries/lib/common.d.ts +0 -1
  316. package/geometries/lib/cone-geometry/cone-geometry.d.ts +0 -8
  317. package/geometries/lib/cylinder-geometry/cylinder-geometry.d.ts +0 -8
  318. package/geometries/lib/dodecahedron-geometry/dodecahedron-geometry.d.ts +0 -8
  319. package/geometries/lib/edges-geometry/edges-geometry.d.ts +0 -8
  320. package/geometries/lib/extrude-geometry/extrude-geometry.d.ts +0 -8
  321. package/geometries/lib/icosahedron-geometry/icosahedron-geometry.d.ts +0 -8
  322. package/geometries/lib/instanced-buffer-geometry/instanced-buffer-geometry.d.ts +0 -8
  323. package/geometries/lib/lathe-geometry/lathe-geometry.d.ts +0 -8
  324. package/geometries/lib/octahedron-geometry/octahedron-geometry.d.ts +0 -8
  325. package/geometries/lib/plane-geometry/plane-geometry.d.ts +0 -8
  326. package/geometries/lib/polyhedron-geometry/polyhedron-geometry.d.ts +0 -8
  327. package/geometries/lib/ring-geometry/ring-geometry.d.ts +0 -8
  328. package/geometries/lib/shape-geometry/shape-geometry.d.ts +0 -8
  329. package/geometries/lib/sphere-geometry/sphere-geometry.d.ts +0 -8
  330. package/geometries/lib/tetrahedron-geometry/tetrahedron-geometry.d.ts +0 -8
  331. package/geometries/lib/torus-geometry/torus-geometry.d.ts +0 -8
  332. package/geometries/lib/torus-knot-geometry/torus-knot-geometry.d.ts +0 -8
  333. package/geometries/lib/tube-geometry/tube-geometry.d.ts +0 -8
  334. package/geometries/lib/wireframe-geometry/wireframe-geometry.d.ts +0 -8
  335. package/helpers/README.md +0 -3
  336. package/helpers/index.d.ts +0 -13
  337. package/helpers/lib/arrow-helper/arrow-helper.d.ts +0 -8
  338. package/helpers/lib/axes-helper/axes-helper.d.ts +0 -8
  339. package/helpers/lib/box-helper/box-helper.d.ts +0 -8
  340. package/helpers/lib/box3-helper/box3-helper.d.ts +0 -8
  341. package/helpers/lib/camera-helper/camera-helper.d.ts +0 -8
  342. package/helpers/lib/common.d.ts +0 -1
  343. package/helpers/lib/directional-light-helper/directional-light-helper.d.ts +0 -8
  344. package/helpers/lib/grid-helper/grid-helper.d.ts +0 -8
  345. package/helpers/lib/hemisphere-light-helper/hemisphere-light-helper.d.ts +0 -8
  346. package/helpers/lib/plane-helper/plane-helper.d.ts +0 -8
  347. package/helpers/lib/point-light-helper/point-light-helper.d.ts +0 -8
  348. package/helpers/lib/polar-grid-helper/polar-grid-helper.d.ts +0 -8
  349. package/helpers/lib/skeleton-helper/skeleton-helper.d.ts +0 -8
  350. package/helpers/lib/spot-light-helper/spot-light-helper.d.ts +0 -8
  351. package/lib/di/resize.d.ts +0 -12
  352. package/lib/di/window.d.ts +0 -1
  353. package/lib/directives/cursor.d.ts +0 -7
  354. package/lib/instance.d.ts +0 -81
  355. package/lib/pipes/math.d.ts +0 -7
  356. package/lib/pipes/pi.d.ts +0 -7
  357. package/lib/pipes/radian.d.ts +0 -7
  358. package/lib/pipes/side.d.ts +0 -8
  359. package/lib/ref.d.ts +0 -5
  360. package/lib/services/loader.d.ts +0 -11
  361. package/lib/services/resize.d.ts +0 -19
  362. package/lib/stores/component-store.d.ts +0 -69
  363. package/lib/utils/build-graph.d.ts +0 -3
  364. package/lib/utils/camera.d.ts +0 -4
  365. package/lib/utils/capitalize.d.ts +0 -1
  366. package/lib/utils/check-update.d.ts +0 -2
  367. package/lib/utils/events.d.ts +0 -6
  368. package/lib/utils/get-instance-local-state.d.ts +0 -2
  369. package/lib/utils/inject.d.ts +0 -9
  370. package/lib/utils/mutate.d.ts +0 -2
  371. package/lib/utils/proxy.d.ts +0 -7
  372. package/lib/utils/renderer.d.ts +0 -3
  373. package/lights/README.md +0 -3
  374. package/lights/index.d.ts +0 -9
  375. package/lights/lib/ambient-light/ambient-light.d.ts +0 -39
  376. package/lights/lib/ambient-light-probe/ambient-light-probe.d.ts +0 -40
  377. package/lights/lib/common.d.ts +0 -3
  378. package/lights/lib/directional-light/directional-light.d.ts +0 -40
  379. package/lights/lib/hemisphere-light/hemisphere-light.d.ts +0 -41
  380. package/lights/lib/hemisphere-light-probe/hemisphere-light-probe.d.ts +0 -42
  381. package/lights/lib/light-probe/light-probe.d.ts +0 -40
  382. package/lights/lib/point-light/point-light.d.ts +0 -42
  383. package/lights/lib/rect-area-light/rect-area-light.d.ts +0 -42
  384. package/lights/lib/spot-light/spot-light.d.ts +0 -45
  385. package/materials/README.md +0 -3
  386. package/materials/index.d.ts +0 -17
  387. package/materials/lib/common.d.ts +0 -1
  388. package/materials/lib/line-basic-material/line-basic-material.d.ts +0 -55
  389. package/materials/lib/line-dashed-material/line-dashed-material.d.ts +0 -58
  390. package/materials/lib/mesh-basic-material/mesh-basic-material.d.ts +0 -67
  391. package/materials/lib/mesh-depth-material/mesh-depth-material.d.ts +0 -58
  392. package/materials/lib/mesh-distance-material/mesh-distance-material.d.ts +0 -58
  393. package/materials/lib/mesh-lambert-material/mesh-lambert-material.d.ts +0 -78
  394. package/materials/lib/mesh-matcap-material/mesh-matcap-material.d.ts +0 -64
  395. package/materials/lib/mesh-normal-material/mesh-normal-material.d.ts +0 -61
  396. package/materials/lib/mesh-phong-material/mesh-phong-material.d.ts +0 -81
  397. package/materials/lib/mesh-physical-material/mesh-physical-material.d.ts +0 -97
  398. package/materials/lib/mesh-standard-material/mesh-standard-material.d.ts +0 -78
  399. package/materials/lib/mesh-toon-material/mesh-toon-material.d.ts +0 -74
  400. package/materials/lib/points-material/points-material.d.ts +0 -56
  401. package/materials/lib/raw-shader-material/raw-shader-material.d.ts +0 -68
  402. package/materials/lib/shader-material/shader-material.d.ts +0 -68
  403. package/materials/lib/shadow-material/shadow-material.d.ts +0 -52
  404. package/materials/lib/sprite-material/sprite-material.d.ts +0 -56
  405. package/objects/README.md +0 -3
  406. package/objects/index.d.ts +0 -12
  407. package/objects/lib/bone/bone.d.ts +0 -35
  408. package/objects/lib/common.d.ts +0 -3
  409. package/objects/lib/group/group.d.ts +0 -35
  410. package/objects/lib/instanced-mesh/instanced-mesh.d.ts +0 -44
  411. package/objects/lib/line/line.d.ts +0 -41
  412. package/objects/lib/line-loop/line-loop.d.ts +0 -41
  413. package/objects/lib/line-segments/line-segments.d.ts +0 -41
  414. package/objects/lib/lod/lod.d.ts +0 -40
  415. package/objects/lib/mesh/mesh.d.ts +0 -41
  416. package/objects/lib/points/points.d.ts +0 -41
  417. package/objects/lib/skeleton/skeleton.d.ts +0 -16
  418. package/objects/lib/skinned-mesh/skinned-mesh.d.ts +0 -45
  419. package/objects/lib/sprite/sprite.d.ts +0 -38
  420. package/primitives/README.md +0 -3
  421. package/primitives/index.d.ts +0 -2
  422. package/primitives/lib/common.d.ts +0 -3
  423. package/primitives/lib/object-primitive/object-primitive.d.ts +0 -35
  424. package/primitives/lib/primitive/primitive.d.ts +0 -10
  425. package/schematics/README.md +0 -11
  426. package/stats/README.md +0 -3
  427. package/stats/index.d.ts +0 -1
  428. package/stats/lib/stats/stats.d.ts +0 -16
  429. package/textures/README.md +0 -3
  430. package/textures/index.d.ts +0 -10
  431. package/textures/lib/canvas-texture/canvas-texture.d.ts +0 -8
  432. package/textures/lib/common.d.ts +0 -1
  433. package/textures/lib/compressed-array-texture/compressed-array-texture.d.ts +0 -8
  434. package/textures/lib/compressed-texture/compressed-texture.d.ts +0 -8
  435. package/textures/lib/cube-texture/cube-texture.d.ts +0 -8
  436. package/textures/lib/data-array-texture/data-array-texture.d.ts +0 -8
  437. package/textures/lib/data-texture/data-texture.d.ts +0 -8
  438. package/textures/lib/data3-dtexture/data3-dtexture.d.ts +0 -8
  439. package/textures/lib/depth-texture/depth-texture.d.ts +0 -8
  440. package/textures/lib/framebuffer-texture/framebuffer-texture.d.ts +0 -8
  441. package/textures/lib/video-texture/video-texture.d.ts +0 -8
@@ -0,0 +1,137 @@
1
+ function createSubs(callback, subs) {
2
+ const sub = { callback };
3
+ subs.add(sub);
4
+ return () => void subs.delete(sub);
5
+ }
6
+ const globalEffects = new Set();
7
+ const globalAfterEffects = new Set();
8
+ const globalTailEffects = new Set();
9
+ /**
10
+ * Adds a global render callback which is called each frame.
11
+ * @see https://docs.pmnd.rs/react-three-fiber/api/additional-exports#addEffect
12
+ */
13
+ export const addEffect = (callback) => createSubs(callback, globalEffects);
14
+ /**
15
+ * Adds a global after-render callback which is called each frame.
16
+ * @see https://docs.pmnd.rs/react-three-fiber/api/additional-exports#addAfterEffect
17
+ */
18
+ export const addAfterEffect = (callback) => createSubs(callback, globalAfterEffects);
19
+ /**
20
+ * Adds a global callback which is called when rendering stops.
21
+ * @see https://docs.pmnd.rs/react-three-fiber/api/additional-exports#addTail
22
+ */
23
+ export const addTail = (callback) => createSubs(callback, globalTailEffects);
24
+ function run(effects, timestamp) {
25
+ if (!effects.size)
26
+ return;
27
+ for (const { callback } of effects.values()) {
28
+ callback(timestamp);
29
+ }
30
+ }
31
+ export function flushGlobalEffects(type, timestamp) {
32
+ switch (type) {
33
+ case 'before':
34
+ return run(globalEffects, timestamp);
35
+ case 'after':
36
+ return run(globalAfterEffects, timestamp);
37
+ case 'tail':
38
+ return run(globalTailEffects, timestamp);
39
+ }
40
+ }
41
+ function render(timestamp, store, frame) {
42
+ const state = store.get();
43
+ // Run local effects
44
+ let delta = state.clock.getDelta();
45
+ // In frameloop='never' mode, clock times are updated using the provided timestamp
46
+ if (state.frameloop === 'never' && typeof timestamp === 'number') {
47
+ delta = timestamp - state.clock.elapsedTime;
48
+ state.clock.oldTime = state.clock.elapsedTime;
49
+ state.clock.elapsedTime = timestamp;
50
+ }
51
+ // Call subscribers (useFrame)
52
+ // subscribers = state.internal.subscribers;
53
+ for (let i = 0; i < state.internal.subscribers.length; i++) {
54
+ const subscriber = state.internal.subscribers[i];
55
+ subscriber.callback({ ...state, delta, frame });
56
+ }
57
+ // Render content
58
+ if (!state.internal.priority && state.gl.render) {
59
+ state.gl.render(state.scene, state.camera);
60
+ }
61
+ // Decrease frame count
62
+ state.internal.frames = Math.max(0, state.internal.frames - 1);
63
+ return state.frameloop === 'always' ? 1 : state.internal.frames;
64
+ }
65
+ export function createLoop(roots) {
66
+ let running = false;
67
+ let repeat;
68
+ let frame;
69
+ function loop(timestamp) {
70
+ frame = requestAnimationFrame(loop);
71
+ running = true;
72
+ repeat = 0;
73
+ // Run effects
74
+ flushGlobalEffects('before', timestamp);
75
+ // Render all roots
76
+ for (const root of roots.values()) {
77
+ const state = root.get();
78
+ // If the frameloop is invalidated, do not run another frame
79
+ if (state.internal.active &&
80
+ (state.frameloop === 'always' || state.internal.frames > 0) &&
81
+ !state.gl.xr?.isPresenting) {
82
+ repeat += render(timestamp, root);
83
+ }
84
+ }
85
+ // Run after-effects
86
+ flushGlobalEffects('after', timestamp);
87
+ // Stop the loop if nothing invalidates it
88
+ if (repeat === 0) {
89
+ // Tail call effects, they are called when rendering stops
90
+ flushGlobalEffects('tail', timestamp);
91
+ // Flag end of operation
92
+ running = false;
93
+ return cancelAnimationFrame(frame);
94
+ }
95
+ }
96
+ function invalidate(store, frames = 1) {
97
+ const state = store?.get();
98
+ if (!state)
99
+ return roots.forEach((root) => invalidate(root, frames));
100
+ if (state.gl.xr?.isPresenting || !state.internal.active || state.frameloop === 'never')
101
+ return;
102
+ // Increase frames, do not go higher than 60
103
+ state.internal.frames = Math.min(60, state.internal.frames + frames);
104
+ // If the render-loop isn't active, start it
105
+ if (!running) {
106
+ running = true;
107
+ requestAnimationFrame(loop);
108
+ }
109
+ }
110
+ function advance(timestamp, runGlobalEffects = true, store, frame) {
111
+ const state = store?.get();
112
+ if (runGlobalEffects)
113
+ flushGlobalEffects('before', timestamp);
114
+ if (!state)
115
+ for (const root of roots.values())
116
+ render(timestamp, root);
117
+ // safe to assume store is available here
118
+ else
119
+ render(timestamp, store, frame);
120
+ if (runGlobalEffects)
121
+ flushGlobalEffects('after', timestamp);
122
+ }
123
+ return {
124
+ loop,
125
+ /**
126
+ * Invalidates the view, requesting a frame to be rendered. Will globally invalidate unless passed a root's state.
127
+ * @see https://docs.pmnd.rs/react-three-fiber/api/additional-exports#invalidate
128
+ */
129
+ invalidate,
130
+ /**
131
+ * Advances the frameloop and runs render effects, useful for when manually rendering via `frameloop="never"`.
132
+ * @see https://docs.pmnd.rs/react-three-fiber/api/additional-exports#advance
133
+ */
134
+ advance,
135
+ };
136
+ }
137
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"loop.js","sourceRoot":"","sources":["../../../../../libs/angular-three/src/lib/loop.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgtRxStore } from './stores/rx-store';\nimport type { NgtState } from './types';\n\nexport type NgtGlobalRenderCallback = (timestamp: number) => void;\ntype NgtSubItem = { callback: NgtGlobalRenderCallback };\n\nfunction createSubs(callback: NgtGlobalRenderCallback, subs: Set<NgtSubItem>): () => void {\n    const sub = { callback };\n    subs.add(sub);\n    return () => void subs.delete(sub);\n}\n\nconst globalEffects: Set<NgtSubItem> = new Set();\nconst globalAfterEffects: Set<NgtSubItem> = new Set();\nconst globalTailEffects: Set<NgtSubItem> = new Set();\n\n/**\n * Adds a global render callback which is called each frame.\n * @see https://docs.pmnd.rs/react-three-fiber/api/additional-exports#addEffect\n */\nexport const addEffect = (callback: NgtGlobalRenderCallback) => createSubs(callback, globalEffects);\n\n/**\n * Adds a global after-render callback which is called each frame.\n * @see https://docs.pmnd.rs/react-three-fiber/api/additional-exports#addAfterEffect\n */\nexport const addAfterEffect = (callback: NgtGlobalRenderCallback) => createSubs(callback, globalAfterEffects);\n\n/**\n * Adds a global callback which is called when rendering stops.\n * @see https://docs.pmnd.rs/react-three-fiber/api/additional-exports#addTail\n */\nexport const addTail = (callback: NgtGlobalRenderCallback) => createSubs(callback, globalTailEffects);\n\nfunction run(effects: Set<NgtSubItem>, timestamp: number) {\n    if (!effects.size) return;\n    for (const { callback } of effects.values()) {\n        callback(timestamp);\n    }\n}\n\nexport type GlobalEffectType = 'before' | 'after' | 'tail';\n\nexport function flushGlobalEffects(type: GlobalEffectType, timestamp: number): void {\n    switch (type) {\n        case 'before':\n            return run(globalEffects, timestamp);\n        case 'after':\n            return run(globalAfterEffects, timestamp);\n        case 'tail':\n            return run(globalTailEffects, timestamp);\n    }\n}\n\nfunction render(timestamp: number, store: NgtRxStore<NgtState>, frame?: XRFrame) {\n    const state = store.get();\n    // Run local effects\n    let delta = state.clock.getDelta();\n    // In frameloop='never' mode, clock times are updated using the provided timestamp\n    if (state.frameloop === 'never' && typeof timestamp === 'number') {\n        delta = timestamp - state.clock.elapsedTime;\n        state.clock.oldTime = state.clock.elapsedTime;\n        state.clock.elapsedTime = timestamp;\n    }\n    // Call subscribers (useFrame)\n    // subscribers = state.internal.subscribers;\n    for (let i = 0; i < state.internal.subscribers.length; i++) {\n        const subscriber = state.internal.subscribers[i];\n        subscriber.callback({ ...state, delta, frame });\n    }\n    // Render content\n    if (!state.internal.priority && state.gl.render) {\n        state.gl.render(state.scene, state.camera);\n    }\n    // Decrease frame count\n    state.internal.frames = Math.max(0, state.internal.frames - 1);\n    return state.frameloop === 'always' ? 1 : state.internal.frames;\n}\n\nexport function createLoop<TCanvas>(roots: Map<TCanvas, NgtRxStore<NgtState>>) {\n    let running = false;\n    let repeat: number;\n    let frame: number;\n\n    function loop(timestamp: number): void {\n        frame = requestAnimationFrame(loop);\n        running = true;\n        repeat = 0;\n\n        // Run effects\n        flushGlobalEffects('before', timestamp);\n\n        // Render all roots\n        for (const root of roots.values()) {\n            const state = root.get();\n            // If the frameloop is invalidated, do not run another frame\n            if (\n                state.internal.active &&\n                (state.frameloop === 'always' || state.internal.frames > 0) &&\n                !state.gl.xr?.isPresenting\n            ) {\n                repeat += render(timestamp, root);\n            }\n        }\n\n        // Run after-effects\n        flushGlobalEffects('after', timestamp);\n\n        // Stop the loop if nothing invalidates it\n        if (repeat === 0) {\n            // Tail call effects, they are called when rendering stops\n            flushGlobalEffects('tail', timestamp);\n\n            // Flag end of operation\n            running = false;\n            return cancelAnimationFrame(frame);\n        }\n    }\n\n    function invalidate(store?: NgtRxStore<NgtState>, frames = 1): void {\n        const state = store?.get();\n        if (!state) return roots.forEach((root) => invalidate(root, frames));\n        if (state.gl.xr?.isPresenting || !state.internal.active || state.frameloop === 'never') return;\n        // Increase frames, do not go higher than 60\n        state.internal.frames = Math.min(60, state.internal.frames + frames);\n        // If the render-loop isn't active, start it\n        if (!running) {\n            running = true;\n            requestAnimationFrame(loop);\n        }\n    }\n\n    function advance(\n        timestamp: number,\n        runGlobalEffects: boolean = true,\n        store?: NgtRxStore<NgtState>,\n        frame?: XRFrame\n    ): void {\n        const state = store?.get();\n        if (runGlobalEffects) flushGlobalEffects('before', timestamp);\n        if (!state) for (const root of roots.values()) render(timestamp, root);\n        // safe to assume store is available here\n        else render(timestamp, store!, frame);\n        if (runGlobalEffects) flushGlobalEffects('after', timestamp);\n    }\n\n    return {\n        loop,\n        /**\n         * Invalidates the view, requesting a frame to be rendered. Will globally invalidate unless passed a root's state.\n         * @see https://docs.pmnd.rs/react-three-fiber/api/additional-exports#invalidate\n         */\n        invalidate,\n        /**\n         * Advances the frameloop and runs render effects, useful for when manually rendering via `frameloop=\"never\"`.\n         * @see https://docs.pmnd.rs/react-three-fiber/api/additional-exports#advance\n         */\n        advance,\n    };\n}\n"]}
@@ -0,0 +1,3 @@
1
+ import { InjectionToken } from '@angular/core';
2
+ export const NGT_COMPOUND_PREFIXES = new InjectionToken('NgtCompoundPrefixes');
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXItdGhyZWUvc3JjL2xpYi9yZW5kZXJlci9kaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRS9DLE1BQU0sQ0FBQyxNQUFNLHFCQUFxQixHQUFHLElBQUksY0FBYyxDQUFXLHFCQUFxQixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3Rpb25Ub2tlbiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5leHBvcnQgY29uc3QgTkdUX0NPTVBPVU5EX1BSRUZJWEVTID0gbmV3IEluamVjdGlvblRva2VuPHN0cmluZ1tdPignTmd0Q29tcG91bmRQcmVmaXhlcycpO1xuIl19
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW51bXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXItdGhyZWUvc3JjL2xpYi9yZW5kZXJlci9lbnVtcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNvbnN0IGVudW0gTmd0UmVuZGVyZXJDbGFzc0lkIHtcbiAgICB0eXBlLFxuICAgIHBhcmVudCxcbiAgICBjaGlsZHJlbixcbiAgICBkZXN0cm95ZWQsXG4gICAgY29tcG91bmQsXG4gICAgY29tcG91bmRQYXJlbnQsXG4gICAgY29tcG91bmRlZCxcbiAgICBxdWV1ZU9wcyxcbiAgICBhdHRyaWJ1dGVzLFxuICAgIHByb3BlcnRpZXMsXG4gICAgcmF3VmFsdWUsXG4gICAgcmVmLFxuICAgIHBvcnRhbENvbnRhaW5lcixcbiAgICBpbmplY3RvckZhY3RvcnksXG59XG5cbmV4cG9ydCBjb25zdCBlbnVtIE5ndENvbXBvdW5kQ2xhc3NJZCB7XG4gICAgYXBwbHlGaXJzdCxcbiAgICBwcm9wcyxcbn1cblxuZXhwb3J0IGNvbnN0IGVudW0gTmd0UXVldWVPcENsYXNzSWQge1xuICAgIHR5cGUsXG4gICAgb3AsXG4gICAgZG9uZSxcbn1cbiJdfQ==
@@ -0,0 +1,19 @@
1
+ import { ChangeDetectorRef, RendererFactory2 } from '@angular/core';
2
+ import { NgtStore } from '../stores/store';
3
+ import { NGT_COMPOUND_PREFIXES } from './di';
4
+ import { NgtRendererFactory } from './renderer';
5
+ export function provideNgtRenderer({ store, changeDetectorRef, compoundPrefixes = [] }) {
6
+ if (!compoundPrefixes.includes('ngts')) {
7
+ compoundPrefixes.push('ngts');
8
+ }
9
+ if (!compoundPrefixes.includes('ngtp')) {
10
+ compoundPrefixes.push('ngtp');
11
+ }
12
+ return [
13
+ { provide: RendererFactory2, useClass: NgtRendererFactory },
14
+ { provide: NgtStore, useValue: store },
15
+ { provide: ChangeDetectorRef, useValue: changeDetectorRef },
16
+ { provide: NGT_COMPOUND_PREFIXES, useValue: compoundPrefixes },
17
+ ];
18
+ }
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvdmlkZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXItdGhyZWUvc3JjL2xpYi9yZW5kZXJlci9wcm92aWRlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDcEUsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQzNDLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUM3QyxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxZQUFZLENBQUM7QUFRaEQsTUFBTSxVQUFVLGtCQUFrQixDQUFDLEVBQUUsS0FBSyxFQUFFLGlCQUFpQixFQUFFLGdCQUFnQixHQUFHLEVBQUUsRUFBOEI7SUFDOUcsSUFBSSxDQUFDLGdCQUFnQixDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUMsRUFBRTtRQUNwQyxnQkFBZ0IsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7S0FDakM7SUFFRCxJQUFJLENBQUMsZ0JBQWdCLENBQUMsUUFBUSxDQUFDLE1BQU0sQ0FBQyxFQUFFO1FBQ3BDLGdCQUFnQixDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQztLQUNqQztJQUVELE9BQU87UUFDSCxFQUFFLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxRQUFRLEVBQUUsa0JBQWtCLEVBQUU7UUFDM0QsRUFBRSxPQUFPLEVBQUUsUUFBUSxFQUFFLFFBQVEsRUFBRSxLQUFLLEVBQUU7UUFDdEMsRUFBRSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsUUFBUSxFQUFFLGlCQUFpQixFQUFFO1FBQzNELEVBQUUsT0FBTyxFQUFFLHFCQUFxQixFQUFFLFFBQVEsRUFBRSxnQkFBZ0IsRUFBRTtLQUNqRSxDQUFDO0FBQ04sQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdG9yUmVmLCBSZW5kZXJlckZhY3RvcnkyIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBOZ3RTdG9yZSB9IGZyb20gJy4uL3N0b3Jlcy9zdG9yZSc7XG5pbXBvcnQgeyBOR1RfQ09NUE9VTkRfUFJFRklYRVMgfSBmcm9tICcuL2RpJztcbmltcG9ydCB7IE5ndFJlbmRlcmVyRmFjdG9yeSB9IGZyb20gJy4vcmVuZGVyZXInO1xuXG5leHBvcnQgdHlwZSBOZ3RSZW5kZXJlclByb3ZpZGVyT3B0aW9ucyA9IHtcbiAgICBzdG9yZTogTmd0U3RvcmU7XG4gICAgY2hhbmdlRGV0ZWN0b3JSZWY6IENoYW5nZURldGVjdG9yUmVmO1xuICAgIGNvbXBvdW5kUHJlZml4ZXM/OiBzdHJpbmdbXTtcbn07XG5cbmV4cG9ydCBmdW5jdGlvbiBwcm92aWRlTmd0UmVuZGVyZXIoeyBzdG9yZSwgY2hhbmdlRGV0ZWN0b3JSZWYsIGNvbXBvdW5kUHJlZml4ZXMgPSBbXSB9OiBOZ3RSZW5kZXJlclByb3ZpZGVyT3B0aW9ucykge1xuICAgIGlmICghY29tcG91bmRQcmVmaXhlcy5pbmNsdWRlcygnbmd0cycpKSB7XG4gICAgICAgIGNvbXBvdW5kUHJlZml4ZXMucHVzaCgnbmd0cycpO1xuICAgIH1cblxuICAgIGlmICghY29tcG91bmRQcmVmaXhlcy5pbmNsdWRlcygnbmd0cCcpKSB7XG4gICAgICAgIGNvbXBvdW5kUHJlZml4ZXMucHVzaCgnbmd0cCcpO1xuICAgIH1cblxuICAgIHJldHVybiBbXG4gICAgICAgIHsgcHJvdmlkZTogUmVuZGVyZXJGYWN0b3J5MiwgdXNlQ2xhc3M6IE5ndFJlbmRlcmVyRmFjdG9yeSB9LFxuICAgICAgICB7IHByb3ZpZGU6IE5ndFN0b3JlLCB1c2VWYWx1ZTogc3RvcmUgfSxcbiAgICAgICAgeyBwcm92aWRlOiBDaGFuZ2VEZXRlY3RvclJlZiwgdXNlVmFsdWU6IGNoYW5nZURldGVjdG9yUmVmIH0sXG4gICAgICAgIHsgcHJvdmlkZTogTkdUX0NPTVBPVU5EX1BSRUZJWEVTLCB1c2VWYWx1ZTogY29tcG91bmRQcmVmaXhlcyB9LFxuICAgIF07XG59XG4iXX0=
@@ -0,0 +1,293 @@
1
+ import { ChangeDetectorRef, inject, Injectable } from '@angular/core';
2
+ import { ɵDomRendererFactory2 as DomRendererFactory2 } from '@angular/platform-browser';
3
+ import { NGT_CATALOGUE } from '../di/catalogue';
4
+ import { NgtStore } from '../stores/store';
5
+ import { getLocalState, prepare } from '../utils/instance';
6
+ import { is } from '../utils/is';
7
+ import { NGT_COMPOUND_PREFIXES } from './di';
8
+ import { NgtRendererStore } from './state';
9
+ import { attachThreeChild, kebabToPascal, processThreeEvent, removeThreeChild, SPECIAL_DOM_TAG } from './utils';
10
+ import * as i0 from "@angular/core";
11
+ export class NgtRendererFactory {
12
+ constructor() {
13
+ this.domRendererFactory = inject(DomRendererFactory2);
14
+ this.cdr = inject(ChangeDetectorRef);
15
+ this.store = inject(NgtStore);
16
+ this.catalogue = inject(NGT_CATALOGUE);
17
+ this.compoundPrefixes = inject(NGT_COMPOUND_PREFIXES);
18
+ this.rendererStore = new NgtRendererStore({
19
+ store: this.store,
20
+ cdr: this.cdr,
21
+ compoundPrefixes: this.compoundPrefixes,
22
+ });
23
+ }
24
+ createRenderer(hostElement, type) {
25
+ // TODO we might need to check on "type" to return DomRenderer for that particular type to support HTML
26
+ if (!this.renderer) {
27
+ const domRenderer = this.domRendererFactory.createRenderer(hostElement, type);
28
+ this.renderer = new NgtRenderer(domRenderer, this.rendererStore, this.catalogue);
29
+ }
30
+ return this.renderer;
31
+ }
32
+ }
33
+ NgtRendererFactory.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.1", ngImport: i0, type: NgtRendererFactory, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
34
+ NgtRendererFactory.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.1.1", ngImport: i0, type: NgtRendererFactory });
35
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.1", ngImport: i0, type: NgtRendererFactory, decorators: [{
36
+ type: Injectable
37
+ }] });
38
+ export class NgtRenderer {
39
+ constructor(domRenderer, store, catalogue) {
40
+ this.domRenderer = domRenderer;
41
+ this.store = store;
42
+ this.catalogue = catalogue;
43
+ this.first = false;
44
+ this.createText = this.domRenderer.createText.bind(this.domRenderer);
45
+ this.destroy = this.domRenderer.destroy.bind(this.domRenderer);
46
+ this.destroyNode = null;
47
+ this.selectRootElement = this.domRenderer.selectRootElement.bind(this.domRenderer);
48
+ this.nextSibling = this.domRenderer.nextSibling.bind(this.domRenderer);
49
+ this.removeAttribute = this.domRenderer.removeAttribute.bind(this.domRenderer);
50
+ this.addClass = this.domRenderer.addClass.bind(this.domRenderer);
51
+ this.removeClass = this.domRenderer.removeClass.bind(this.domRenderer);
52
+ this.setStyle = this.domRenderer.setStyle.bind(this.domRenderer);
53
+ this.removeStyle = this.domRenderer.removeStyle.bind(this.domRenderer);
54
+ this.setValue = this.domRenderer.setValue.bind(this.domRenderer);
55
+ }
56
+ createElement(name, namespace) {
57
+ const element = this.domRenderer.createElement(name, namespace);
58
+ // on first pass, we return the Root Scene as the root node
59
+ if (!this.first) {
60
+ this.first = true;
61
+ return this.store.createNode('three', this.store.rootScene);
62
+ }
63
+ // handle compound
64
+ if (this.store.isCompound(name))
65
+ return this.store.createNode('compound', element);
66
+ // handle portal
67
+ if (name === SPECIAL_DOM_TAG.NGT_PORTAL) {
68
+ return this.store.createNode('portal', element);
69
+ }
70
+ // handle raw value
71
+ if (name === SPECIAL_DOM_TAG.NGT_VALUE) {
72
+ return this.store.createNode('three', Object.assign({ __ngt_renderer__: { rawValue: undefined } }, { __ngt__: { isRaw: true } }));
73
+ }
74
+ const { injectedArgs, store } = this.store.getCreationState();
75
+ // handle primitive
76
+ if (name === SPECIAL_DOM_TAG.NGT_PRIMITIVE) {
77
+ if (!injectedArgs[0])
78
+ throw new Error(`[NGT] ngt-primitive without args is invalid`);
79
+ const object = injectedArgs[0];
80
+ let localState = getLocalState(object);
81
+ if (!Object.keys(localState).length) {
82
+ prepare(object, { store, args: injectedArgs, primitive: true });
83
+ localState = getLocalState(object);
84
+ }
85
+ if (!localState.store)
86
+ localState.store = store;
87
+ return this.store.createNode('three', object);
88
+ }
89
+ const threeTag = name.startsWith('ngt') ? name.slice(4) : name;
90
+ const threeName = kebabToPascal(threeTag);
91
+ const threeTarget = this.catalogue[threeName];
92
+ // we have the THREE constructor here, handle it
93
+ if (threeTarget) {
94
+ const instance = prepare(new threeTarget(...injectedArgs), { store, args: injectedArgs });
95
+ const node = this.store.createNode('three', instance);
96
+ const localState = getLocalState(instance);
97
+ if (is.geometry(instance)) {
98
+ localState.attach = ['geometry'];
99
+ }
100
+ else if (is.material(instance)) {
101
+ localState.attach = ['material'];
102
+ }
103
+ return node;
104
+ }
105
+ return this.store.createNode('dom', element);
106
+ }
107
+ createComment(value) {
108
+ const comment = this.domRenderer.createComment(value);
109
+ return this.store.createNode('comment', comment);
110
+ }
111
+ appendChild(parent, newChild) {
112
+ // TODO: just ignore text node for now
113
+ if (newChild instanceof Text)
114
+ return;
115
+ if (newChild.__ngt_renderer__[0 /* NgtRendererClassId.type */] === 'comment') {
116
+ this.store.setParent(newChild, parent);
117
+ return;
118
+ }
119
+ this.store.setParent(newChild, parent);
120
+ this.store.addChild(parent, newChild);
121
+ // if new chlid is a portal
122
+ if (newChild.__ngt_renderer__[0 /* NgtRendererClassId.type */] === 'portal') {
123
+ this.store.processPortalContainer(newChild);
124
+ if (newChild.__ngt_renderer__[12 /* NgtRendererClassId.portalContainer */]) {
125
+ this.appendChild(parent, newChild.__ngt_renderer__[12 /* NgtRendererClassId.portalContainer */]);
126
+ }
127
+ return;
128
+ }
129
+ // if parent is a portal
130
+ if (parent.__ngt_renderer__[0 /* NgtRendererClassId.type */] === 'portal') {
131
+ this.store.processPortalContainer(parent);
132
+ if (parent.__ngt_renderer__[12 /* NgtRendererClassId.portalContainer */]) {
133
+ this.appendChild(parent.__ngt_renderer__[12 /* NgtRendererClassId.portalContainer */], newChild);
134
+ }
135
+ return;
136
+ }
137
+ // if both are three instances, straightforward case
138
+ if (parent.__ngt_renderer__[0 /* NgtRendererClassId.type */] === 'three' &&
139
+ newChild.__ngt_renderer__[0 /* NgtRendererClassId.type */] === 'three') {
140
+ attachThreeChild(parent, newChild);
141
+ // here, we handle the special case of if the parent has a compoundParent, which means this child is part of a compound parent template
142
+ if (!newChild.__ngt_renderer__[4 /* NgtRendererClassId.compound */])
143
+ return;
144
+ const closestGrandparentWithCompound = this.store.getClosestParentWithCompound(parent);
145
+ if (!closestGrandparentWithCompound)
146
+ return;
147
+ this.appendChild(closestGrandparentWithCompound, newChild);
148
+ return;
149
+ }
150
+ // if only the parent is the THREE instance
151
+ if (parent.__ngt_renderer__[0 /* NgtRendererClassId.type */] === 'three') {
152
+ if (newChild.__ngt_renderer__[2 /* NgtRendererClassId.children */].length) {
153
+ for (const renderChild of newChild.__ngt_renderer__[2 /* NgtRendererClassId.children */]) {
154
+ this.appendChild(parent, renderChild);
155
+ }
156
+ }
157
+ }
158
+ // if parent is a compound
159
+ if (parent.__ngt_renderer__[0 /* NgtRendererClassId.type */] === 'compound') {
160
+ // if compound doesn't have a THREE instance set yet
161
+ if (!parent.__ngt_renderer__[6 /* NgtRendererClassId.compounded */] &&
162
+ newChild.__ngt_renderer__[0 /* NgtRendererClassId.type */] === 'three') {
163
+ // if child is indeed an ngtCompound
164
+ if (newChild.__ngt_renderer__[4 /* NgtRendererClassId.compound */]) {
165
+ this.store.setCompound(parent, newChild);
166
+ }
167
+ else {
168
+ // if not, we track the parent (that is supposedly the compound component) on this three instance
169
+ if (!newChild.__ngt_renderer__[5 /* NgtRendererClassId.compoundParent */]) {
170
+ newChild.__ngt_renderer__[5 /* NgtRendererClassId.compoundParent */] = parent;
171
+ }
172
+ }
173
+ }
174
+ // reset the compound if it's changed
175
+ if (parent.__ngt_renderer__[6 /* NgtRendererClassId.compounded */] &&
176
+ newChild.__ngt_renderer__[0 /* NgtRendererClassId.type */] === 'three' &&
177
+ newChild.__ngt_renderer__[4 /* NgtRendererClassId.compound */] &&
178
+ parent.__ngt_renderer__[6 /* NgtRendererClassId.compounded */] !== newChild) {
179
+ this.store.setCompound(parent, newChild);
180
+ }
181
+ }
182
+ if (newChild.__ngt_renderer__[0 /* NgtRendererClassId.type */] === 'three' && !getLocalState(newChild).parent) {
183
+ // we'll try to get the grandparent instance here so that we can run appendChild with both instances
184
+ const closestGrandparentInstance = this.store.getClosestParentWithInstance(parent);
185
+ if (closestGrandparentInstance) {
186
+ this.appendChild(closestGrandparentInstance, newChild);
187
+ }
188
+ return;
189
+ }
190
+ if (parent.__ngt_renderer__[0 /* NgtRendererClassId.type */] === 'dom' &&
191
+ newChild.__ngt_renderer__[0 /* NgtRendererClassId.type */] === 'dom') {
192
+ const closestGrandparentInstance = this.store.getClosestParentWithInstance(parent);
193
+ if (closestGrandparentInstance) {
194
+ this.appendChild(closestGrandparentInstance, newChild);
195
+ }
196
+ }
197
+ }
198
+ insertBefore(parent, newChild
199
+ // TODO we might need these?
200
+ // refChild: NgtRendererNode,
201
+ // isMove?: boolean | undefined
202
+ ) {
203
+ if (!parent.__ngt_renderer__)
204
+ return;
205
+ this.appendChild(parent, newChild);
206
+ }
207
+ removeChild(parent, oldChild, isHostElement) {
208
+ if (parent.__ngt_renderer__[0 /* NgtRendererClassId.type */] === 'three' &&
209
+ oldChild.__ngt_renderer__[0 /* NgtRendererClassId.type */] === 'three') {
210
+ removeThreeChild(parent, oldChild, true);
211
+ this.store.destroy(oldChild, parent);
212
+ return;
213
+ }
214
+ if (parent.__ngt_renderer__[0 /* NgtRendererClassId.type */] === 'compound' &&
215
+ parent.__ngt_renderer__[1 /* NgtRendererClassId.parent */]) {
216
+ this.removeChild(parent.__ngt_renderer__[1 /* NgtRendererClassId.parent */], oldChild, isHostElement);
217
+ return;
218
+ }
219
+ if (parent.__ngt_renderer__[0 /* NgtRendererClassId.type */] === 'three') {
220
+ this.store.destroy(oldChild, parent);
221
+ return;
222
+ }
223
+ const closestGrandparentInstance = this.store.getClosestParentWithInstance(parent);
224
+ if (closestGrandparentInstance) {
225
+ this.removeChild(closestGrandparentInstance, oldChild, isHostElement);
226
+ }
227
+ this.store.destroy(oldChild, closestGrandparentInstance);
228
+ }
229
+ parentNode(node) {
230
+ if (node.__ngt_renderer__?.[1 /* NgtRendererClassId.parent */])
231
+ return node.__ngt_renderer__[1 /* NgtRendererClassId.parent */];
232
+ return this.domRenderer.parentNode(node);
233
+ }
234
+ setAttribute(el, name, value, namespace) {
235
+ if (el.__ngt_renderer__[0 /* NgtRendererClassId.type */] === 'compound') {
236
+ // we don't have the compound instance yet
237
+ el.__ngt_renderer__[8 /* NgtRendererClassId.attributes */][name] = value;
238
+ if (!el.__ngt_renderer__[6 /* NgtRendererClassId.compounded */]) {
239
+ this.store.queueOperation(el, ['op', () => this.setAttribute(el, name, value, namespace)]);
240
+ return;
241
+ }
242
+ this.setAttribute(el.__ngt_renderer__[6 /* NgtRendererClassId.compounded */], name, value, namespace);
243
+ return;
244
+ }
245
+ if (el.__ngt_renderer__[0 /* NgtRendererClassId.type */] === 'three') {
246
+ this.store.applyAttribute(el, name, value);
247
+ }
248
+ }
249
+ setProperty(el, name, value) {
250
+ if (el.__ngt_renderer__[0 /* NgtRendererClassId.type */] === 'compound') {
251
+ // we don't have the compound instance yet
252
+ el.__ngt_renderer__[9 /* NgtRendererClassId.properties */][name] = value;
253
+ if (!el.__ngt_renderer__[6 /* NgtRendererClassId.compounded */]) {
254
+ this.store.queueOperation(el, ['op', () => this.setProperty(el, name, value)]);
255
+ return;
256
+ }
257
+ if (el.__ngt_renderer__[6 /* NgtRendererClassId.compounded */].__ngt_renderer__[4 /* NgtRendererClassId.compound */]) {
258
+ Object.assign(el.__ngt_renderer__[6 /* NgtRendererClassId.compounded */].__ngt_renderer__[4 /* NgtRendererClassId.compound */], {
259
+ props: {
260
+ ...el.__ngt_renderer__[6 /* NgtRendererClassId.compounded */].__ngt_renderer__[4 /* NgtRendererClassId.compound */],
261
+ [name]: value,
262
+ },
263
+ });
264
+ }
265
+ this.setProperty(el.__ngt_renderer__[6 /* NgtRendererClassId.compounded */], name, value);
266
+ return;
267
+ }
268
+ if (el.__ngt_renderer__[0 /* NgtRendererClassId.type */] === 'three') {
269
+ this.store.applyProperty(el, name, value);
270
+ }
271
+ }
272
+ listen(target, eventName, callback) {
273
+ if (target.__ngt_renderer__[0 /* NgtRendererClassId.type */] === 'three' ||
274
+ (target.__ngt_renderer__[0 /* NgtRendererClassId.type */] === 'compound' &&
275
+ target.__ngt_renderer__[6 /* NgtRendererClassId.compounded */])) {
276
+ const instance = target.__ngt_renderer__[6 /* NgtRendererClassId.compounded */] || target;
277
+ const priority = getLocalState(target).priority;
278
+ return processThreeEvent(instance, priority || 0, eventName, callback, this.store.rootCdr);
279
+ }
280
+ if (target.__ngt_renderer__[0 /* NgtRendererClassId.type */] === 'compound' &&
281
+ !target.__ngt_renderer__[6 /* NgtRendererClassId.compounded */]) {
282
+ this.store.queueOperation(target, [
283
+ 'op',
284
+ () => this.store.queueOperation(target, ['cleanUp', this.listen(target, eventName, callback)]),
285
+ ]);
286
+ }
287
+ return () => { };
288
+ }
289
+ get data() {
290
+ return this.domRenderer.data;
291
+ }
292
+ }
293
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"renderer.js","sourceRoot":"","sources":["../../../../../../libs/angular-three/src/lib/renderer/renderer.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, inject, Injectable, Renderer2, RendererFactory2, RendererType2 } from '@angular/core';\nimport { ɵDomRendererFactory2 as DomRendererFactory2 } from '@angular/platform-browser';\nimport { NGT_CATALOGUE } from '../di/catalogue';\nimport { NgtStore } from '../stores/store';\nimport { getLocalState, prepare } from '../utils/instance';\nimport { is } from '../utils/is';\nimport { NGT_COMPOUND_PREFIXES } from './di';\nimport { NgtRendererClassId } from './enums';\nimport { NgtRendererNode, NgtRendererStore } from './state';\nimport { attachThreeChild, kebabToPascal, processThreeEvent, removeThreeChild, SPECIAL_DOM_TAG } from './utils';\n\n@Injectable()\nexport class NgtRendererFactory implements RendererFactory2 {\n    private readonly domRendererFactory = inject(DomRendererFactory2);\n    private readonly cdr = inject(ChangeDetectorRef);\n    private readonly store = inject(NgtStore);\n    private readonly catalogue = inject(NGT_CATALOGUE);\n    private readonly compoundPrefixes = inject(NGT_COMPOUND_PREFIXES);\n\n    private readonly rendererStore = new NgtRendererStore({\n        store: this.store,\n        cdr: this.cdr,\n        compoundPrefixes: this.compoundPrefixes,\n    });\n\n    private renderer?: NgtRenderer;\n\n    createRenderer(hostElement: any, type: RendererType2 | null): Renderer2 {\n        // TODO  we might need to check on \"type\" to return DomRenderer for that particular type to support HTML\n        if (!this.renderer) {\n            const domRenderer = this.domRendererFactory.createRenderer(hostElement, type);\n            this.renderer = new NgtRenderer(domRenderer, this.rendererStore, this.catalogue);\n        }\n        return this.renderer;\n    }\n}\n\nexport class NgtRenderer implements Renderer2 {\n    private first = false;\n\n    constructor(\n        private readonly domRenderer: Renderer2,\n        private readonly store: NgtRendererStore,\n        private readonly catalogue: Record<string, new (...args: any[]) => any>\n    ) {}\n\n    createElement(name: string, namespace?: string | null | undefined) {\n        const element = this.domRenderer.createElement(name, namespace);\n\n        // on first pass, we return the Root Scene as the root node\n        if (!this.first) {\n            this.first = true;\n            return this.store.createNode('three', this.store.rootScene);\n        }\n\n        // handle compound\n        if (this.store.isCompound(name)) return this.store.createNode('compound', element);\n\n        // handle portal\n        if (name === SPECIAL_DOM_TAG.NGT_PORTAL) {\n            return this.store.createNode('portal', element);\n        }\n\n        // handle raw value\n        if (name === SPECIAL_DOM_TAG.NGT_VALUE) {\n            return this.store.createNode(\n                'three',\n                Object.assign({ __ngt_renderer__: { rawValue: undefined } }, { __ngt__: { isRaw: true } })\n            );\n        }\n\n        const { injectedArgs, store } = this.store.getCreationState();\n\n        // handle primitive\n        if (name === SPECIAL_DOM_TAG.NGT_PRIMITIVE) {\n            if (!injectedArgs[0]) throw new Error(`[NGT] ngt-primitive without args is invalid`);\n            const object = injectedArgs[0];\n            let localState = getLocalState(object);\n            if (!Object.keys(localState).length) {\n                prepare(object, { store, args: injectedArgs, primitive: true });\n                localState = getLocalState(object);\n            }\n            if (!localState.store) localState.store = store;\n            return this.store.createNode('three', object);\n        }\n\n        const threeTag = name.startsWith('ngt') ? name.slice(4) : name;\n        const threeName = kebabToPascal(threeTag);\n        const threeTarget = this.catalogue[threeName];\n        // we have the THREE constructor here, handle it\n        if (threeTarget) {\n            const instance = prepare(new threeTarget(...injectedArgs), { store, args: injectedArgs });\n            const node = this.store.createNode('three', instance);\n            const localState = getLocalState(instance);\n            if (is.geometry(instance)) {\n                localState.attach = ['geometry'];\n            } else if (is.material(instance)) {\n                localState.attach = ['material'];\n            }\n\n            return node;\n        }\n\n        return this.store.createNode('dom', element);\n    }\n\n    createComment(value: string) {\n        const comment = this.domRenderer.createComment(value);\n        return this.store.createNode('comment', comment);\n    }\n\n    appendChild(parent: NgtRendererNode, newChild: NgtRendererNode): void {\n        // TODO: just ignore text node for now\n        if (newChild instanceof Text) return;\n\n        if (newChild.__ngt_renderer__[NgtRendererClassId.type] === 'comment') {\n            this.store.setParent(newChild, parent);\n            return;\n        }\n\n        this.store.setParent(newChild, parent);\n        this.store.addChild(parent, newChild);\n\n        // if new chlid is a portal\n        if (newChild.__ngt_renderer__[NgtRendererClassId.type] === 'portal') {\n            this.store.processPortalContainer(newChild);\n            if (newChild.__ngt_renderer__[NgtRendererClassId.portalContainer]) {\n                this.appendChild(parent, newChild.__ngt_renderer__[NgtRendererClassId.portalContainer]);\n            }\n            return;\n        }\n\n        // if parent is a portal\n        if (parent.__ngt_renderer__[NgtRendererClassId.type] === 'portal') {\n            this.store.processPortalContainer(parent);\n            if (parent.__ngt_renderer__[NgtRendererClassId.portalContainer]) {\n                this.appendChild(parent.__ngt_renderer__[NgtRendererClassId.portalContainer], newChild);\n            }\n            return;\n        }\n\n        // if both are three instances, straightforward case\n        if (\n            parent.__ngt_renderer__[NgtRendererClassId.type] === 'three' &&\n            newChild.__ngt_renderer__[NgtRendererClassId.type] === 'three'\n        ) {\n            attachThreeChild(parent, newChild);\n            // here, we handle the special case of if the parent has a compoundParent, which means this child is part of a compound parent template\n            if (!newChild.__ngt_renderer__[NgtRendererClassId.compound]) return;\n            const closestGrandparentWithCompound = this.store.getClosestParentWithCompound(parent);\n            if (!closestGrandparentWithCompound) return;\n            this.appendChild(closestGrandparentWithCompound, newChild);\n            return;\n        }\n\n        // if only the parent is the THREE instance\n        if (parent.__ngt_renderer__[NgtRendererClassId.type] === 'three') {\n            if (newChild.__ngt_renderer__[NgtRendererClassId.children].length) {\n                for (const renderChild of newChild.__ngt_renderer__[NgtRendererClassId.children]) {\n                    this.appendChild(parent, renderChild);\n                }\n            }\n        }\n\n        // if parent is a compound\n        if (parent.__ngt_renderer__[NgtRendererClassId.type] === 'compound') {\n            // if compound doesn't have a THREE instance set yet\n            if (\n                !parent.__ngt_renderer__[NgtRendererClassId.compounded] &&\n                newChild.__ngt_renderer__[NgtRendererClassId.type] === 'three'\n            ) {\n                // if child is indeed an ngtCompound\n                if (newChild.__ngt_renderer__[NgtRendererClassId.compound]) {\n                    this.store.setCompound(parent, newChild);\n                } else {\n                    // if not, we track the parent (that is supposedly the compound component) on this three instance\n                    if (!newChild.__ngt_renderer__[NgtRendererClassId.compoundParent]) {\n                        newChild.__ngt_renderer__[NgtRendererClassId.compoundParent] = parent;\n                    }\n                }\n            }\n\n            // reset the compound if it's changed\n            if (\n                parent.__ngt_renderer__[NgtRendererClassId.compounded] &&\n                newChild.__ngt_renderer__[NgtRendererClassId.type] === 'three' &&\n                newChild.__ngt_renderer__[NgtRendererClassId.compound] &&\n                parent.__ngt_renderer__[NgtRendererClassId.compounded] !== newChild\n            ) {\n                this.store.setCompound(parent, newChild);\n            }\n        }\n\n        if (newChild.__ngt_renderer__[NgtRendererClassId.type] === 'three' && !getLocalState(newChild).parent) {\n            // we'll try to get the grandparent instance here so that we can run appendChild with both instances\n            const closestGrandparentInstance = this.store.getClosestParentWithInstance(parent);\n            if (closestGrandparentInstance) {\n                this.appendChild(closestGrandparentInstance, newChild);\n            }\n            return;\n        }\n\n        if (\n            parent.__ngt_renderer__[NgtRendererClassId.type] === 'dom' &&\n            newChild.__ngt_renderer__[NgtRendererClassId.type] === 'dom'\n        ) {\n            const closestGrandparentInstance = this.store.getClosestParentWithInstance(parent);\n            if (closestGrandparentInstance) {\n                this.appendChild(closestGrandparentInstance, newChild);\n            }\n        }\n    }\n\n    insertBefore(\n        parent: NgtRendererNode,\n        newChild: NgtRendererNode\n        // TODO  we might need these?\n        // refChild: NgtRendererNode,\n        // isMove?: boolean | undefined\n    ): void {\n        if (!parent.__ngt_renderer__) return;\n        this.appendChild(parent, newChild);\n    }\n\n    removeChild(parent: NgtRendererNode, oldChild: NgtRendererNode, isHostElement?: boolean | undefined): void {\n        if (\n            parent.__ngt_renderer__[NgtRendererClassId.type] === 'three' &&\n            oldChild.__ngt_renderer__[NgtRendererClassId.type] === 'three'\n        ) {\n            removeThreeChild(parent, oldChild, true);\n            this.store.destroy(oldChild, parent);\n            return;\n        }\n\n        if (\n            parent.__ngt_renderer__[NgtRendererClassId.type] === 'compound' &&\n            parent.__ngt_renderer__[NgtRendererClassId.parent]\n        ) {\n            this.removeChild(parent.__ngt_renderer__[NgtRendererClassId.parent], oldChild, isHostElement);\n            return;\n        }\n\n        if (parent.__ngt_renderer__[NgtRendererClassId.type] === 'three') {\n            this.store.destroy(oldChild, parent);\n            return;\n        }\n\n        const closestGrandparentInstance = this.store.getClosestParentWithInstance(parent);\n        if (closestGrandparentInstance) {\n            this.removeChild(closestGrandparentInstance, oldChild, isHostElement);\n        }\n        this.store.destroy(oldChild, closestGrandparentInstance as NgtRendererNode);\n    }\n\n    parentNode(node: NgtRendererNode) {\n        if (node.__ngt_renderer__?.[NgtRendererClassId.parent]) return node.__ngt_renderer__[NgtRendererClassId.parent];\n        return this.domRenderer.parentNode(node);\n    }\n\n    setAttribute(el: NgtRendererNode, name: string, value: string, namespace?: string | null | undefined): void {\n        if (el.__ngt_renderer__[NgtRendererClassId.type] === 'compound') {\n            // we don't have the compound instance yet\n            el.__ngt_renderer__[NgtRendererClassId.attributes][name] = value;\n            if (!el.__ngt_renderer__[NgtRendererClassId.compounded]) {\n                this.store.queueOperation(el, ['op', () => this.setAttribute(el, name, value, namespace)]);\n                return;\n            }\n\n            this.setAttribute(el.__ngt_renderer__[NgtRendererClassId.compounded], name, value, namespace);\n            return;\n        }\n\n        if (el.__ngt_renderer__[NgtRendererClassId.type] === 'three') {\n            this.store.applyAttribute(el, name, value);\n        }\n    }\n\n    setProperty(el: NgtRendererNode, name: string, value: any): void {\n        if (el.__ngt_renderer__[NgtRendererClassId.type] === 'compound') {\n            // we don't have the compound instance yet\n            el.__ngt_renderer__[NgtRendererClassId.properties][name] = value;\n            if (!el.__ngt_renderer__[NgtRendererClassId.compounded]) {\n                this.store.queueOperation(el, ['op', () => this.setProperty(el, name, value)]);\n                return;\n            }\n\n            if (el.__ngt_renderer__[NgtRendererClassId.compounded].__ngt_renderer__[NgtRendererClassId.compound]) {\n                Object.assign(\n                    el.__ngt_renderer__[NgtRendererClassId.compounded].__ngt_renderer__[NgtRendererClassId.compound],\n                    {\n                        props: {\n                            ...el.__ngt_renderer__[NgtRendererClassId.compounded].__ngt_renderer__[\n                                NgtRendererClassId.compound\n                            ],\n                            [name]: value,\n                        },\n                    }\n                );\n            }\n            this.setProperty(el.__ngt_renderer__[NgtRendererClassId.compounded], name, value);\n            return;\n        }\n\n        if (el.__ngt_renderer__[NgtRendererClassId.type] === 'three') {\n            this.store.applyProperty(el, name, value);\n        }\n    }\n\n    listen(target: NgtRendererNode, eventName: string, callback: (event: any) => boolean | void): () => void {\n        if (\n            target.__ngt_renderer__[NgtRendererClassId.type] === 'three' ||\n            (target.__ngt_renderer__[NgtRendererClassId.type] === 'compound' &&\n                target.__ngt_renderer__[NgtRendererClassId.compounded])\n        ) {\n            const instance = target.__ngt_renderer__[NgtRendererClassId.compounded] || target;\n            const priority = getLocalState(target).priority;\n            return processThreeEvent(instance, priority || 0, eventName, callback, this.store.rootCdr);\n        }\n\n        if (\n            target.__ngt_renderer__[NgtRendererClassId.type] === 'compound' &&\n            !target.__ngt_renderer__[NgtRendererClassId.compounded]\n        ) {\n            this.store.queueOperation(target, [\n                'op',\n                () => this.store.queueOperation(target, ['cleanUp', this.listen(target, eventName, callback)]),\n            ]);\n        }\n        return () => {};\n    }\n\n    get data(): { [key: string]: any } {\n        return this.domRenderer.data;\n    }\n    createText = this.domRenderer.createText.bind(this.domRenderer);\n    destroy = this.domRenderer.destroy.bind(this.domRenderer);\n    destroyNode: ((node: any) => void) | null = null;\n    selectRootElement = this.domRenderer.selectRootElement.bind(this.domRenderer);\n    nextSibling = this.domRenderer.nextSibling.bind(this.domRenderer);\n    removeAttribute = this.domRenderer.removeAttribute.bind(this.domRenderer);\n    addClass = this.domRenderer.addClass.bind(this.domRenderer);\n    removeClass = this.domRenderer.removeClass.bind(this.domRenderer);\n    setStyle = this.domRenderer.setStyle.bind(this.domRenderer);\n    removeStyle = this.domRenderer.removeStyle.bind(this.domRenderer);\n    setValue = this.domRenderer.setValue.bind(this.domRenderer);\n}\n"]}