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.
- package/esm2020/angular-three.mjs +1 -1
- package/esm2020/index.mjs +2 -35
- package/esm2020/lib/canvas.mjs +141 -128
- package/esm2020/lib/di/catalogue.mjs +7 -0
- package/esm2020/lib/directives/args.mjs +37 -17
- package/esm2020/lib/directives/repeat.mjs +5 -8
- package/esm2020/lib/events.mjs +341 -52
- package/esm2020/lib/loader.mjs +55 -0
- package/esm2020/lib/loop.mjs +137 -0
- package/esm2020/lib/renderer/di.mjs +3 -0
- package/esm2020/lib/renderer/enums.mjs +2 -0
- package/esm2020/lib/renderer/provider.mjs +19 -0
- package/esm2020/lib/renderer/renderer.mjs +293 -0
- package/esm2020/lib/renderer/state.mjs +350 -0
- package/esm2020/lib/renderer/utils.mjs +177 -0
- package/esm2020/lib/stores/rx-store.mjs +99 -0
- package/esm2020/lib/stores/store.mjs +190 -239
- package/esm2020/lib/types.mjs +1 -1
- package/esm2020/lib/utils/apply-props.mjs +37 -80
- package/esm2020/lib/utils/attach.mjs +29 -0
- package/esm2020/lib/utils/instance.mjs +43 -28
- package/esm2020/lib/utils/is.mjs +7 -11
- package/esm2020/lib/utils/make.mjs +30 -10
- package/esm2020/lib/utils/update.mjs +37 -0
- package/esm2020/lib/web/events.mjs +68 -0
- package/fesm2015/angular-three.mjs +2053 -2046
- package/fesm2015/angular-three.mjs.map +1 -1
- package/fesm2020/angular-three.mjs +2003 -1990
- package/fesm2020/angular-three.mjs.map +1 -1
- package/index.d.ts +1 -34
- package/lib/canvas.d.ts +29 -28
- package/lib/di/catalogue.d.ts +3 -0
- package/lib/directives/args.d.ts +8 -12
- package/lib/events.d.ts +7 -2
- package/lib/loader.d.ts +15 -0
- package/lib/{utils/loop.d.ts → loop.d.ts} +7 -6
- package/lib/renderer/di.d.ts +2 -0
- package/lib/renderer/enums.d.ts +25 -0
- package/lib/renderer/provider.d.ts +25 -0
- package/lib/renderer/renderer.d.ts +49 -0
- package/lib/renderer/state.d.ts +59 -0
- package/lib/renderer/utils.d.ts +20 -0
- package/lib/stores/rx-store.d.ts +17 -0
- package/lib/stores/store.d.ts +6 -23
- package/lib/types.d.ts +182 -191
- package/lib/utils/apply-props.d.ts +2 -6
- package/lib/utils/attach.d.ts +3 -0
- package/lib/utils/instance.d.ts +3 -3
- package/lib/utils/is.d.ts +6 -10
- package/lib/utils/make.d.ts +5 -2
- package/lib/utils/update.d.ts +4 -0
- package/lib/web/events.d.ts +4 -0
- package/package.json +30 -99
- package/attributes/README.md +0 -3
- package/attributes/index.d.ts +0 -22
- package/attributes/lib/buffer-attribute/buffer-attribute.d.ts +0 -8
- package/attributes/lib/color-attribute/color-attribute.d.ts +0 -8
- package/attributes/lib/common.d.ts +0 -1
- package/attributes/lib/float16-buffer-attribute/float16-buffer-attribute.d.ts +0 -8
- package/attributes/lib/float32-buffer-attribute/float32-buffer-attribute.d.ts +0 -8
- package/attributes/lib/float64-buffer-attribute/float64-buffer-attribute.d.ts +0 -8
- package/attributes/lib/fog-attribute/fog-attribute.d.ts +0 -8
- package/attributes/lib/fog-exp2-attribute/fog-exp2-attribute.d.ts +0 -8
- package/attributes/lib/instanced-buffer-attribute/instanced-buffer-attribute.d.ts +0 -8
- package/attributes/lib/int16-buffer-attribute/int16-buffer-attribute.d.ts +0 -8
- package/attributes/lib/int32-buffer-attribute/int32-buffer-attribute.d.ts +0 -8
- package/attributes/lib/int8-buffer-attribute/int8-buffer-attribute.d.ts +0 -8
- package/attributes/lib/interleaved-buffer-attribute/interleaved-buffer-attribute.d.ts +0 -8
- package/attributes/lib/matrix3-attribute/matrix3-attribute.d.ts +0 -8
- package/attributes/lib/matrix4-attribute/matrix4-attribute.d.ts +0 -8
- package/attributes/lib/uint16-buffer-attribute/uint16-buffer-attribute.d.ts +0 -8
- package/attributes/lib/uint32-buffer-attribute/uint32-buffer-attribute.d.ts +0 -8
- package/attributes/lib/uint8-buffer-attribute/uint8-buffer-attribute.d.ts +0 -8
- package/attributes/lib/uint8-clamped-buffer-attribute/uint8-clamped-buffer-attribute.d.ts +0 -8
- package/attributes/lib/value-attribute/value-attribute.d.ts +0 -8
- package/attributes/lib/vector2-attribute/vector2-attribute.d.ts +0 -8
- package/attributes/lib/vector3-attribute/vector3-attribute.d.ts +0 -8
- package/attributes/lib/vector4-attribute/vector4-attribute.d.ts +0 -8
- package/audios/README.md +0 -3
- package/audios/index.d.ts +0 -3
- package/audios/lib/audio/audio.d.ts +0 -49
- package/audios/lib/audio-listener/audio-listener.d.ts +0 -35
- package/audios/lib/common.d.ts +0 -3
- package/audios/lib/positional-audio/positional-audio.d.ts +0 -49
- package/cameras/README.md +0 -3
- package/cameras/index.d.ts +0 -5
- package/cameras/lib/array-camera/array-camera.d.ts +0 -56
- package/cameras/lib/common.d.ts +0 -3
- package/cameras/lib/cube-camera/cube-camera.d.ts +0 -36
- package/cameras/lib/orthographic-camera/orthographic-camera.d.ts +0 -54
- package/cameras/lib/perspective-camera/perspective-camera.d.ts +0 -55
- package/cameras/lib/stereo-camera/stereo-camera.d.ts +0 -42
- package/esm2020/attributes/angular-three-attributes.mjs +0 -5
- package/esm2020/attributes/index.mjs +0 -24
- package/esm2020/attributes/lib/buffer-attribute/buffer-attribute.mjs +0 -26
- package/esm2020/attributes/lib/color-attribute/color-attribute.mjs +0 -26
- package/esm2020/attributes/lib/common.mjs +0 -13
- package/esm2020/attributes/lib/float16-buffer-attribute/float16-buffer-attribute.mjs +0 -26
- package/esm2020/attributes/lib/float32-buffer-attribute/float32-buffer-attribute.mjs +0 -26
- package/esm2020/attributes/lib/float64-buffer-attribute/float64-buffer-attribute.mjs +0 -26
- package/esm2020/attributes/lib/fog-attribute/fog-attribute.mjs +0 -26
- package/esm2020/attributes/lib/fog-exp2-attribute/fog-exp2-attribute.mjs +0 -26
- package/esm2020/attributes/lib/instanced-buffer-attribute/instanced-buffer-attribute.mjs +0 -26
- package/esm2020/attributes/lib/int16-buffer-attribute/int16-buffer-attribute.mjs +0 -26
- package/esm2020/attributes/lib/int32-buffer-attribute/int32-buffer-attribute.mjs +0 -26
- package/esm2020/attributes/lib/int8-buffer-attribute/int8-buffer-attribute.mjs +0 -26
- package/esm2020/attributes/lib/interleaved-buffer-attribute/interleaved-buffer-attribute.mjs +0 -30
- package/esm2020/attributes/lib/matrix3-attribute/matrix3-attribute.mjs +0 -26
- package/esm2020/attributes/lib/matrix4-attribute/matrix4-attribute.mjs +0 -26
- package/esm2020/attributes/lib/uint16-buffer-attribute/uint16-buffer-attribute.mjs +0 -26
- package/esm2020/attributes/lib/uint32-buffer-attribute/uint32-buffer-attribute.mjs +0 -26
- package/esm2020/attributes/lib/uint8-buffer-attribute/uint8-buffer-attribute.mjs +0 -26
- package/esm2020/attributes/lib/uint8-clamped-buffer-attribute/uint8-clamped-buffer-attribute.mjs +0 -26
- package/esm2020/attributes/lib/value-attribute/value-attribute.mjs +0 -28
- package/esm2020/attributes/lib/vector2-attribute/vector2-attribute.mjs +0 -26
- package/esm2020/attributes/lib/vector3-attribute/vector3-attribute.mjs +0 -26
- package/esm2020/attributes/lib/vector4-attribute/vector4-attribute.mjs +0 -26
- package/esm2020/audios/angular-three-audios.mjs +0 -5
- package/esm2020/audios/index.mjs +0 -5
- package/esm2020/audios/lib/audio/audio.mjs +0 -45
- package/esm2020/audios/lib/audio-listener/audio-listener.mjs +0 -38
- package/esm2020/audios/lib/common.mjs +0 -54
- package/esm2020/audios/lib/positional-audio/positional-audio.mjs +0 -45
- package/esm2020/cameras/angular-three-cameras.mjs +0 -5
- package/esm2020/cameras/index.mjs +0 -7
- package/esm2020/cameras/lib/array-camera/array-camera.mjs +0 -44
- package/esm2020/cameras/lib/common.mjs +0 -54
- package/esm2020/cameras/lib/cube-camera/cube-camera.mjs +0 -30
- package/esm2020/cameras/lib/orthographic-camera/orthographic-camera.mjs +0 -42
- package/esm2020/cameras/lib/perspective-camera/perspective-camera.mjs +0 -43
- package/esm2020/cameras/lib/stereo-camera/stereo-camera.mjs +0 -38
- package/esm2020/geometries/angular-three-geometries.mjs +0 -5
- package/esm2020/geometries/index.mjs +0 -25
- package/esm2020/geometries/lib/box-geometry/box-geometry.mjs +0 -26
- package/esm2020/geometries/lib/buffer-geometry/buffer-geometry.mjs +0 -26
- package/esm2020/geometries/lib/capsule-geometry/capsule-geometry.mjs +0 -26
- package/esm2020/geometries/lib/circle-geometry/circle-geometry.mjs +0 -26
- package/esm2020/geometries/lib/common.mjs +0 -13
- package/esm2020/geometries/lib/cone-geometry/cone-geometry.mjs +0 -26
- package/esm2020/geometries/lib/cylinder-geometry/cylinder-geometry.mjs +0 -26
- package/esm2020/geometries/lib/dodecahedron-geometry/dodecahedron-geometry.mjs +0 -26
- package/esm2020/geometries/lib/edges-geometry/edges-geometry.mjs +0 -26
- package/esm2020/geometries/lib/extrude-geometry/extrude-geometry.mjs +0 -26
- package/esm2020/geometries/lib/icosahedron-geometry/icosahedron-geometry.mjs +0 -26
- package/esm2020/geometries/lib/instanced-buffer-geometry/instanced-buffer-geometry.mjs +0 -26
- package/esm2020/geometries/lib/lathe-geometry/lathe-geometry.mjs +0 -26
- package/esm2020/geometries/lib/octahedron-geometry/octahedron-geometry.mjs +0 -26
- package/esm2020/geometries/lib/plane-geometry/plane-geometry.mjs +0 -26
- package/esm2020/geometries/lib/polyhedron-geometry/polyhedron-geometry.mjs +0 -26
- package/esm2020/geometries/lib/ring-geometry/ring-geometry.mjs +0 -26
- package/esm2020/geometries/lib/shape-geometry/shape-geometry.mjs +0 -26
- package/esm2020/geometries/lib/sphere-geometry/sphere-geometry.mjs +0 -26
- package/esm2020/geometries/lib/tetrahedron-geometry/tetrahedron-geometry.mjs +0 -26
- package/esm2020/geometries/lib/torus-geometry/torus-geometry.mjs +0 -26
- package/esm2020/geometries/lib/torus-knot-geometry/torus-knot-geometry.mjs +0 -26
- package/esm2020/geometries/lib/tube-geometry/tube-geometry.mjs +0 -26
- package/esm2020/geometries/lib/wireframe-geometry/wireframe-geometry.mjs +0 -26
- package/esm2020/helpers/angular-three-helpers.mjs +0 -5
- package/esm2020/helpers/index.mjs +0 -15
- package/esm2020/helpers/lib/arrow-helper/arrow-helper.mjs +0 -26
- package/esm2020/helpers/lib/axes-helper/axes-helper.mjs +0 -26
- package/esm2020/helpers/lib/box-helper/box-helper.mjs +0 -36
- package/esm2020/helpers/lib/box3-helper/box3-helper.mjs +0 -36
- package/esm2020/helpers/lib/camera-helper/camera-helper.mjs +0 -36
- package/esm2020/helpers/lib/common.mjs +0 -13
- package/esm2020/helpers/lib/directional-light-helper/directional-light-helper.mjs +0 -36
- package/esm2020/helpers/lib/grid-helper/grid-helper.mjs +0 -26
- package/esm2020/helpers/lib/hemisphere-light-helper/hemisphere-light-helper.mjs +0 -36
- package/esm2020/helpers/lib/plane-helper/plane-helper.mjs +0 -36
- package/esm2020/helpers/lib/point-light-helper/point-light-helper.mjs +0 -36
- package/esm2020/helpers/lib/polar-grid-helper/polar-grid-helper.mjs +0 -26
- package/esm2020/helpers/lib/skeleton-helper/skeleton-helper.mjs +0 -36
- package/esm2020/helpers/lib/spot-light-helper/spot-light-helper.mjs +0 -36
- package/esm2020/lib/di/resize.mjs +0 -19
- package/esm2020/lib/di/window.mjs +0 -13
- package/esm2020/lib/directives/cursor.mjs +0 -35
- package/esm2020/lib/instance.mjs +0 -368
- package/esm2020/lib/pipes/math.mjs +0 -15
- package/esm2020/lib/pipes/pi.mjs +0 -14
- package/esm2020/lib/pipes/radian.mjs +0 -14
- package/esm2020/lib/pipes/side.mjs +0 -22
- package/esm2020/lib/ref.mjs +0 -15
- package/esm2020/lib/services/loader.mjs +0 -45
- package/esm2020/lib/services/resize.mjs +0 -127
- package/esm2020/lib/stores/component-store.mjs +0 -137
- package/esm2020/lib/utils/build-graph.mjs +0 -15
- package/esm2020/lib/utils/camera.mjs +0 -28
- package/esm2020/lib/utils/capitalize.mjs +0 -4
- package/esm2020/lib/utils/check-update.mjs +0 -22
- package/esm2020/lib/utils/events.mjs +0 -353
- package/esm2020/lib/utils/get-instance-local-state.mjs +0 -6
- package/esm2020/lib/utils/inject.mjs +0 -18
- package/esm2020/lib/utils/loop.mjs +0 -139
- package/esm2020/lib/utils/mutate.mjs +0 -24
- package/esm2020/lib/utils/proxy.mjs +0 -99
- package/esm2020/lib/utils/renderer.mjs +0 -15
- package/esm2020/lights/angular-three-lights.mjs +0 -5
- package/esm2020/lights/index.mjs +0 -11
- package/esm2020/lights/lib/ambient-light/ambient-light.mjs +0 -30
- package/esm2020/lights/lib/ambient-light-probe/ambient-light-probe.mjs +0 -30
- package/esm2020/lights/lib/common.mjs +0 -54
- package/esm2020/lights/lib/directional-light/directional-light.mjs +0 -30
- package/esm2020/lights/lib/hemisphere-light/hemisphere-light.mjs +0 -30
- package/esm2020/lights/lib/hemisphere-light-probe/hemisphere-light-probe.mjs +0 -30
- package/esm2020/lights/lib/light-probe/light-probe.mjs +0 -30
- package/esm2020/lights/lib/point-light/point-light.mjs +0 -30
- package/esm2020/lights/lib/rect-area-light/rect-area-light.mjs +0 -30
- package/esm2020/lights/lib/spot-light/spot-light.mjs +0 -42
- package/esm2020/materials/angular-three-materials.mjs +0 -5
- package/esm2020/materials/index.mjs +0 -19
- package/esm2020/materials/lib/common.mjs +0 -13
- package/esm2020/materials/lib/line-basic-material/line-basic-material.mjs +0 -77
- package/esm2020/materials/lib/line-dashed-material/line-dashed-material.mjs +0 -80
- package/esm2020/materials/lib/mesh-basic-material/mesh-basic-material.mjs +0 -89
- package/esm2020/materials/lib/mesh-depth-material/mesh-depth-material.mjs +0 -80
- package/esm2020/materials/lib/mesh-distance-material/mesh-distance-material.mjs +0 -80
- package/esm2020/materials/lib/mesh-lambert-material/mesh-lambert-material.mjs +0 -100
- package/esm2020/materials/lib/mesh-matcap-material/mesh-matcap-material.mjs +0 -86
- package/esm2020/materials/lib/mesh-normal-material/mesh-normal-material.mjs +0 -83
- package/esm2020/materials/lib/mesh-phong-material/mesh-phong-material.mjs +0 -103
- package/esm2020/materials/lib/mesh-physical-material/mesh-physical-material.mjs +0 -119
- package/esm2020/materials/lib/mesh-standard-material/mesh-standard-material.mjs +0 -100
- package/esm2020/materials/lib/mesh-toon-material/mesh-toon-material.mjs +0 -96
- package/esm2020/materials/lib/points-material/points-material.mjs +0 -78
- package/esm2020/materials/lib/raw-shader-material/raw-shader-material.mjs +0 -83
- package/esm2020/materials/lib/shader-material/shader-material.mjs +0 -83
- package/esm2020/materials/lib/shadow-material/shadow-material.mjs +0 -74
- package/esm2020/materials/lib/sprite-material/sprite-material.mjs +0 -78
- package/esm2020/objects/angular-three-objects.mjs +0 -5
- package/esm2020/objects/index.mjs +0 -14
- package/esm2020/objects/lib/bone/bone.mjs +0 -27
- package/esm2020/objects/lib/common.mjs +0 -54
- package/esm2020/objects/lib/group/group.mjs +0 -27
- package/esm2020/objects/lib/instanced-mesh/instanced-mesh.mjs +0 -40
- package/esm2020/objects/lib/line/line.mjs +0 -30
- package/esm2020/objects/lib/line-loop/line-loop.mjs +0 -30
- package/esm2020/objects/lib/line-segments/line-segments.mjs +0 -30
- package/esm2020/objects/lib/lod/lod.mjs +0 -30
- package/esm2020/objects/lib/mesh/mesh.mjs +0 -30
- package/esm2020/objects/lib/points/points.mjs +0 -30
- package/esm2020/objects/lib/skeleton/skeleton.mjs +0 -41
- package/esm2020/objects/lib/skinned-mesh/skinned-mesh.mjs +0 -39
- package/esm2020/objects/lib/sprite/sprite.mjs +0 -30
- package/esm2020/primitives/angular-three-primitives.mjs +0 -5
- package/esm2020/primitives/index.mjs +0 -3
- package/esm2020/primitives/lib/common.mjs +0 -54
- package/esm2020/primitives/lib/object-primitive/object-primitive.mjs +0 -27
- package/esm2020/primitives/lib/primitive/primitive.mjs +0 -38
- package/esm2020/stats/angular-three-stats.mjs +0 -5
- package/esm2020/stats/index.mjs +0 -2
- package/esm2020/stats/lib/stats/stats.mjs +0 -54
- package/esm2020/textures/angular-three-textures.mjs +0 -5
- package/esm2020/textures/index.mjs +0 -12
- package/esm2020/textures/lib/canvas-texture/canvas-texture.mjs +0 -26
- package/esm2020/textures/lib/common.mjs +0 -13
- package/esm2020/textures/lib/compressed-array-texture/compressed-array-texture.mjs +0 -26
- package/esm2020/textures/lib/compressed-texture/compressed-texture.mjs +0 -26
- package/esm2020/textures/lib/cube-texture/cube-texture.mjs +0 -26
- package/esm2020/textures/lib/data-array-texture/data-array-texture.mjs +0 -26
- package/esm2020/textures/lib/data-texture/data-texture.mjs +0 -26
- package/esm2020/textures/lib/data3-dtexture/data3-dtexture.mjs +0 -26
- package/esm2020/textures/lib/depth-texture/depth-texture.mjs +0 -26
- package/esm2020/textures/lib/framebuffer-texture/framebuffer-texture.mjs +0 -26
- package/esm2020/textures/lib/video-texture/video-texture.mjs +0 -26
- package/fesm2015/angular-three-attributes.mjs +0 -475
- package/fesm2015/angular-three-attributes.mjs.map +0 -1
- package/fesm2015/angular-three-audios.mjs +0 -179
- package/fesm2015/angular-three-audios.mjs.map +0 -1
- package/fesm2015/angular-three-cameras.mjs +0 -236
- package/fesm2015/angular-three-cameras.mjs.map +0 -1
- package/fesm2015/angular-three-geometries.mjs +0 -488
- package/fesm2015/angular-three-geometries.mjs.map +0 -1
- package/fesm2015/angular-three-helpers.mjs +0 -378
- package/fesm2015/angular-three-helpers.mjs.map +0 -1
- package/fesm2015/angular-three-lights.mjs +0 -297
- package/fesm2015/angular-three-lights.mjs.map +0 -1
- package/fesm2015/angular-three-materials.mjs +0 -1415
- package/fesm2015/angular-three-materials.mjs.map +0 -1
- package/fesm2015/angular-three-objects.mjs +0 -381
- package/fesm2015/angular-three-objects.mjs.map +0 -1
- package/fesm2015/angular-three-primitives.mjs +0 -120
- package/fesm2015/angular-three-primitives.mjs.map +0 -1
- package/fesm2015/angular-three-stats.mjs +0 -62
- package/fesm2015/angular-three-stats.mjs.map +0 -1
- package/fesm2015/angular-three-textures.mjs +0 -228
- package/fesm2015/angular-three-textures.mjs.map +0 -1
- package/fesm2020/angular-three-attributes.mjs +0 -475
- package/fesm2020/angular-three-attributes.mjs.map +0 -1
- package/fesm2020/angular-three-audios.mjs +0 -179
- package/fesm2020/angular-three-audios.mjs.map +0 -1
- package/fesm2020/angular-three-cameras.mjs +0 -236
- package/fesm2020/angular-three-cameras.mjs.map +0 -1
- package/fesm2020/angular-three-geometries.mjs +0 -488
- package/fesm2020/angular-three-geometries.mjs.map +0 -1
- package/fesm2020/angular-three-helpers.mjs +0 -378
- package/fesm2020/angular-three-helpers.mjs.map +0 -1
- package/fesm2020/angular-three-lights.mjs +0 -297
- package/fesm2020/angular-three-lights.mjs.map +0 -1
- package/fesm2020/angular-three-materials.mjs +0 -1415
- package/fesm2020/angular-three-materials.mjs.map +0 -1
- package/fesm2020/angular-three-objects.mjs +0 -381
- package/fesm2020/angular-three-objects.mjs.map +0 -1
- package/fesm2020/angular-three-primitives.mjs +0 -120
- package/fesm2020/angular-three-primitives.mjs.map +0 -1
- package/fesm2020/angular-three-stats.mjs +0 -62
- package/fesm2020/angular-three-stats.mjs.map +0 -1
- package/fesm2020/angular-three-textures.mjs +0 -228
- package/fesm2020/angular-three-textures.mjs.map +0 -1
- package/geometries/README.md +0 -3
- package/geometries/index.d.ts +0 -23
- package/geometries/lib/box-geometry/box-geometry.d.ts +0 -8
- package/geometries/lib/buffer-geometry/buffer-geometry.d.ts +0 -8
- package/geometries/lib/capsule-geometry/capsule-geometry.d.ts +0 -8
- package/geometries/lib/circle-geometry/circle-geometry.d.ts +0 -8
- package/geometries/lib/common.d.ts +0 -1
- package/geometries/lib/cone-geometry/cone-geometry.d.ts +0 -8
- package/geometries/lib/cylinder-geometry/cylinder-geometry.d.ts +0 -8
- package/geometries/lib/dodecahedron-geometry/dodecahedron-geometry.d.ts +0 -8
- package/geometries/lib/edges-geometry/edges-geometry.d.ts +0 -8
- package/geometries/lib/extrude-geometry/extrude-geometry.d.ts +0 -8
- package/geometries/lib/icosahedron-geometry/icosahedron-geometry.d.ts +0 -8
- package/geometries/lib/instanced-buffer-geometry/instanced-buffer-geometry.d.ts +0 -8
- package/geometries/lib/lathe-geometry/lathe-geometry.d.ts +0 -8
- package/geometries/lib/octahedron-geometry/octahedron-geometry.d.ts +0 -8
- package/geometries/lib/plane-geometry/plane-geometry.d.ts +0 -8
- package/geometries/lib/polyhedron-geometry/polyhedron-geometry.d.ts +0 -8
- package/geometries/lib/ring-geometry/ring-geometry.d.ts +0 -8
- package/geometries/lib/shape-geometry/shape-geometry.d.ts +0 -8
- package/geometries/lib/sphere-geometry/sphere-geometry.d.ts +0 -8
- package/geometries/lib/tetrahedron-geometry/tetrahedron-geometry.d.ts +0 -8
- package/geometries/lib/torus-geometry/torus-geometry.d.ts +0 -8
- package/geometries/lib/torus-knot-geometry/torus-knot-geometry.d.ts +0 -8
- package/geometries/lib/tube-geometry/tube-geometry.d.ts +0 -8
- package/geometries/lib/wireframe-geometry/wireframe-geometry.d.ts +0 -8
- package/helpers/README.md +0 -3
- package/helpers/index.d.ts +0 -13
- package/helpers/lib/arrow-helper/arrow-helper.d.ts +0 -8
- package/helpers/lib/axes-helper/axes-helper.d.ts +0 -8
- package/helpers/lib/box-helper/box-helper.d.ts +0 -8
- package/helpers/lib/box3-helper/box3-helper.d.ts +0 -8
- package/helpers/lib/camera-helper/camera-helper.d.ts +0 -8
- package/helpers/lib/common.d.ts +0 -1
- package/helpers/lib/directional-light-helper/directional-light-helper.d.ts +0 -8
- package/helpers/lib/grid-helper/grid-helper.d.ts +0 -8
- package/helpers/lib/hemisphere-light-helper/hemisphere-light-helper.d.ts +0 -8
- package/helpers/lib/plane-helper/plane-helper.d.ts +0 -8
- package/helpers/lib/point-light-helper/point-light-helper.d.ts +0 -8
- package/helpers/lib/polar-grid-helper/polar-grid-helper.d.ts +0 -8
- package/helpers/lib/skeleton-helper/skeleton-helper.d.ts +0 -8
- package/helpers/lib/spot-light-helper/spot-light-helper.d.ts +0 -8
- package/lib/di/resize.d.ts +0 -12
- package/lib/di/window.d.ts +0 -1
- package/lib/directives/cursor.d.ts +0 -7
- package/lib/instance.d.ts +0 -81
- package/lib/pipes/math.d.ts +0 -7
- package/lib/pipes/pi.d.ts +0 -7
- package/lib/pipes/radian.d.ts +0 -7
- package/lib/pipes/side.d.ts +0 -8
- package/lib/ref.d.ts +0 -5
- package/lib/services/loader.d.ts +0 -11
- package/lib/services/resize.d.ts +0 -19
- package/lib/stores/component-store.d.ts +0 -69
- package/lib/utils/build-graph.d.ts +0 -3
- package/lib/utils/camera.d.ts +0 -4
- package/lib/utils/capitalize.d.ts +0 -1
- package/lib/utils/check-update.d.ts +0 -2
- package/lib/utils/events.d.ts +0 -6
- package/lib/utils/get-instance-local-state.d.ts +0 -2
- package/lib/utils/inject.d.ts +0 -9
- package/lib/utils/mutate.d.ts +0 -2
- package/lib/utils/proxy.d.ts +0 -7
- package/lib/utils/renderer.d.ts +0 -3
- package/lights/README.md +0 -3
- package/lights/index.d.ts +0 -9
- package/lights/lib/ambient-light/ambient-light.d.ts +0 -39
- package/lights/lib/ambient-light-probe/ambient-light-probe.d.ts +0 -40
- package/lights/lib/common.d.ts +0 -3
- package/lights/lib/directional-light/directional-light.d.ts +0 -40
- package/lights/lib/hemisphere-light/hemisphere-light.d.ts +0 -41
- package/lights/lib/hemisphere-light-probe/hemisphere-light-probe.d.ts +0 -42
- package/lights/lib/light-probe/light-probe.d.ts +0 -40
- package/lights/lib/point-light/point-light.d.ts +0 -42
- package/lights/lib/rect-area-light/rect-area-light.d.ts +0 -42
- package/lights/lib/spot-light/spot-light.d.ts +0 -45
- package/materials/README.md +0 -3
- package/materials/index.d.ts +0 -17
- package/materials/lib/common.d.ts +0 -1
- package/materials/lib/line-basic-material/line-basic-material.d.ts +0 -55
- package/materials/lib/line-dashed-material/line-dashed-material.d.ts +0 -58
- package/materials/lib/mesh-basic-material/mesh-basic-material.d.ts +0 -67
- package/materials/lib/mesh-depth-material/mesh-depth-material.d.ts +0 -58
- package/materials/lib/mesh-distance-material/mesh-distance-material.d.ts +0 -58
- package/materials/lib/mesh-lambert-material/mesh-lambert-material.d.ts +0 -78
- package/materials/lib/mesh-matcap-material/mesh-matcap-material.d.ts +0 -64
- package/materials/lib/mesh-normal-material/mesh-normal-material.d.ts +0 -61
- package/materials/lib/mesh-phong-material/mesh-phong-material.d.ts +0 -81
- package/materials/lib/mesh-physical-material/mesh-physical-material.d.ts +0 -97
- package/materials/lib/mesh-standard-material/mesh-standard-material.d.ts +0 -78
- package/materials/lib/mesh-toon-material/mesh-toon-material.d.ts +0 -74
- package/materials/lib/points-material/points-material.d.ts +0 -56
- package/materials/lib/raw-shader-material/raw-shader-material.d.ts +0 -68
- package/materials/lib/shader-material/shader-material.d.ts +0 -68
- package/materials/lib/shadow-material/shadow-material.d.ts +0 -52
- package/materials/lib/sprite-material/sprite-material.d.ts +0 -56
- package/objects/README.md +0 -3
- package/objects/index.d.ts +0 -12
- package/objects/lib/bone/bone.d.ts +0 -35
- package/objects/lib/common.d.ts +0 -3
- package/objects/lib/group/group.d.ts +0 -35
- package/objects/lib/instanced-mesh/instanced-mesh.d.ts +0 -44
- package/objects/lib/line/line.d.ts +0 -41
- package/objects/lib/line-loop/line-loop.d.ts +0 -41
- package/objects/lib/line-segments/line-segments.d.ts +0 -41
- package/objects/lib/lod/lod.d.ts +0 -40
- package/objects/lib/mesh/mesh.d.ts +0 -41
- package/objects/lib/points/points.d.ts +0 -41
- package/objects/lib/skeleton/skeleton.d.ts +0 -16
- package/objects/lib/skinned-mesh/skinned-mesh.d.ts +0 -45
- package/objects/lib/sprite/sprite.d.ts +0 -38
- package/primitives/README.md +0 -3
- package/primitives/index.d.ts +0 -2
- package/primitives/lib/common.d.ts +0 -3
- package/primitives/lib/object-primitive/object-primitive.d.ts +0 -35
- package/primitives/lib/primitive/primitive.d.ts +0 -10
- package/schematics/README.md +0 -11
- package/stats/README.md +0 -3
- package/stats/index.d.ts +0 -1
- package/stats/lib/stats/stats.d.ts +0 -16
- package/textures/README.md +0 -3
- package/textures/index.d.ts +0 -10
- package/textures/lib/canvas-texture/canvas-texture.d.ts +0 -8
- package/textures/lib/common.d.ts +0 -1
- package/textures/lib/compressed-array-texture/compressed-array-texture.d.ts +0 -8
- package/textures/lib/compressed-texture/compressed-texture.d.ts +0 -8
- package/textures/lib/cube-texture/cube-texture.d.ts +0 -8
- package/textures/lib/data-array-texture/data-array-texture.d.ts +0 -8
- package/textures/lib/data-texture/data-texture.d.ts +0 -8
- package/textures/lib/data3-dtexture/data3-dtexture.d.ts +0 -8
- package/textures/lib/depth-texture/depth-texture.d.ts +0 -8
- package/textures/lib/framebuffer-texture/framebuffer-texture.d.ts +0 -8
- 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"]}
|