fraxel 0.1.0-alpha.1
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/dist/animation/easing.d.ts +29 -0
- package/dist/animation/easing.d.ts.map +1 -0
- package/dist/animation/easing.js +50 -0
- package/dist/animation/easing.js.map +1 -0
- package/dist/animation/index.d.ts +7 -0
- package/dist/animation/index.d.ts.map +1 -0
- package/dist/animation/index.js +7 -0
- package/dist/animation/index.js.map +1 -0
- package/dist/animation/multiple.d.ts +26 -0
- package/dist/animation/multiple.d.ts.map +1 -0
- package/dist/animation/multiple.js +27 -0
- package/dist/animation/multiple.js.map +1 -0
- package/dist/animation/properties.d.ts +30 -0
- package/dist/animation/properties.d.ts.map +1 -0
- package/dist/animation/properties.js +32 -0
- package/dist/animation/properties.js.map +1 -0
- package/dist/animation/sequences.d.ts +30 -0
- package/dist/animation/sequences.d.ts.map +1 -0
- package/dist/animation/sequences.js +50 -0
- package/dist/animation/sequences.js.map +1 -0
- package/dist/animation/sprite-sheet.d.ts +81 -0
- package/dist/animation/sprite-sheet.d.ts.map +1 -0
- package/dist/animation/sprite-sheet.js +103 -0
- package/dist/animation/sprite-sheet.js.map +1 -0
- package/dist/animation/tween.d.ts +78 -0
- package/dist/animation/tween.d.ts.map +1 -0
- package/dist/animation/tween.js +103 -0
- package/dist/animation/tween.js.map +1 -0
- package/dist/assets/index.d.ts +6 -0
- package/dist/assets/index.d.ts.map +1 -0
- package/dist/assets/index.js +5 -0
- package/dist/assets/index.js.map +1 -0
- package/dist/assets/load-sound.d.ts +17 -0
- package/dist/assets/load-sound.d.ts.map +1 -0
- package/dist/assets/load-sound.js +35 -0
- package/dist/assets/load-sound.js.map +1 -0
- package/dist/assets/load-texture.d.ts +12 -0
- package/dist/assets/load-texture.d.ts.map +1 -0
- package/dist/assets/load-texture.js +40 -0
- package/dist/assets/load-texture.js.map +1 -0
- package/dist/assets/loader.d.ts +59 -0
- package/dist/assets/loader.d.ts.map +1 -0
- package/dist/assets/loader.js +65 -0
- package/dist/assets/loader.js.map +1 -0
- package/dist/assets/texture.d.ts +36 -0
- package/dist/assets/texture.d.ts.map +1 -0
- package/dist/assets/texture.js +49 -0
- package/dist/assets/texture.js.map +1 -0
- package/dist/audio/audio-context.d.ts +14 -0
- package/dist/audio/audio-context.d.ts.map +1 -0
- package/dist/audio/audio-context.js +20 -0
- package/dist/audio/audio-context.js.map +1 -0
- package/dist/audio/index.d.ts +2 -0
- package/dist/audio/index.d.ts.map +1 -0
- package/dist/audio/index.js +2 -0
- package/dist/audio/index.js.map +1 -0
- package/dist/collision/broadphase/spatial-hash.d.ts +32 -0
- package/dist/collision/broadphase/spatial-hash.d.ts.map +1 -0
- package/dist/collision/broadphase/spatial-hash.js +87 -0
- package/dist/collision/broadphase/spatial-hash.js.map +1 -0
- package/dist/collision/collision-system.d.ts +52 -0
- package/dist/collision/collision-system.d.ts.map +1 -0
- package/dist/collision/collision-system.js +278 -0
- package/dist/collision/collision-system.js.map +1 -0
- package/dist/collision/events/collision-emitter.d.ts +38 -0
- package/dist/collision/events/collision-emitter.d.ts.map +1 -0
- package/dist/collision/events/collision-emitter.js +47 -0
- package/dist/collision/events/collision-emitter.js.map +1 -0
- package/dist/collision/index.d.ts +13 -0
- package/dist/collision/index.d.ts.map +1 -0
- package/dist/collision/index.js +11 -0
- package/dist/collision/index.js.map +1 -0
- package/dist/collision/narrowphase/detector.d.ts +26 -0
- package/dist/collision/narrowphase/detector.d.ts.map +1 -0
- package/dist/collision/narrowphase/detector.js +70 -0
- package/dist/collision/narrowphase/detector.js.map +1 -0
- package/dist/collision/narrowphase/shapes.d.ts +91 -0
- package/dist/collision/narrowphase/shapes.d.ts.map +1 -0
- package/dist/collision/narrowphase/shapes.js +52 -0
- package/dist/collision/narrowphase/shapes.js.map +1 -0
- package/dist/collision/physics/physics-body.d.ts +38 -0
- package/dist/collision/physics/physics-body.d.ts.map +1 -0
- package/dist/collision/physics/physics-body.js +53 -0
- package/dist/collision/physics/physics-body.js.map +1 -0
- package/dist/collision/physics/physics-system.d.ts +23 -0
- package/dist/collision/physics/physics-system.d.ts.map +1 -0
- package/dist/collision/physics/physics-system.js +86 -0
- package/dist/collision/physics/physics-system.js.map +1 -0
- package/dist/collision/physics/resolver.d.ts +16 -0
- package/dist/collision/physics/resolver.d.ts.map +1 -0
- package/dist/collision/physics/resolver.js +91 -0
- package/dist/collision/physics/resolver.js.map +1 -0
- package/dist/collision/types.d.ts +22 -0
- package/dist/collision/types.d.ts.map +1 -0
- package/dist/collision/types.js +2 -0
- package/dist/collision/types.js.map +1 -0
- package/dist/core/game-config.d.ts +34 -0
- package/dist/core/game-config.d.ts.map +1 -0
- package/dist/core/game-config.js +31 -0
- package/dist/core/game-config.js.map +1 -0
- package/dist/core/game.d.ts +86 -0
- package/dist/core/game.d.ts.map +1 -0
- package/dist/core/game.js +166 -0
- package/dist/core/game.js.map +1 -0
- package/dist/core/index.d.ts +6 -0
- package/dist/core/index.d.ts.map +1 -0
- package/dist/core/index.js +6 -0
- package/dist/core/index.js.map +1 -0
- package/dist/core/scene-manager.d.ts +28 -0
- package/dist/core/scene-manager.d.ts.map +1 -0
- package/dist/core/scene-manager.js +65 -0
- package/dist/core/scene-manager.js.map +1 -0
- package/dist/core/scene.d.ts +43 -0
- package/dist/core/scene.d.ts.map +1 -0
- package/dist/core/scene.js +48 -0
- package/dist/core/scene.js.map +1 -0
- package/dist/core/theme.d.ts +63 -0
- package/dist/core/theme.d.ts.map +1 -0
- package/dist/core/theme.js +59 -0
- package/dist/core/theme.js.map +1 -0
- package/dist/errors/animation.d.ts +24 -0
- package/dist/errors/animation.d.ts.map +1 -0
- package/dist/errors/animation.js +29 -0
- package/dist/errors/animation.js.map +1 -0
- package/dist/errors/assets.d.ts +34 -0
- package/dist/errors/assets.d.ts.map +1 -0
- package/dist/errors/assets.js +41 -0
- package/dist/errors/assets.js.map +1 -0
- package/dist/errors/base.d.ts +12 -0
- package/dist/errors/base.d.ts.map +1 -0
- package/dist/errors/base.js +15 -0
- package/dist/errors/base.js.map +1 -0
- package/dist/errors/env.d.ts +24 -0
- package/dist/errors/env.d.ts.map +1 -0
- package/dist/errors/env.js +29 -0
- package/dist/errors/env.js.map +1 -0
- package/dist/errors/hook.d.ts +46 -0
- package/dist/errors/hook.d.ts.map +1 -0
- package/dist/errors/hook.js +55 -0
- package/dist/errors/hook.js.map +1 -0
- package/dist/errors/index.d.ts +11 -0
- package/dist/errors/index.d.ts.map +1 -0
- package/dist/errors/index.js +11 -0
- package/dist/errors/index.js.map +1 -0
- package/dist/errors/jsx.d.ts +26 -0
- package/dist/errors/jsx.d.ts.map +1 -0
- package/dist/errors/jsx.js +45 -0
- package/dist/errors/jsx.js.map +1 -0
- package/dist/errors/lifecycle.d.ts +35 -0
- package/dist/errors/lifecycle.d.ts.map +1 -0
- package/dist/errors/lifecycle.js +42 -0
- package/dist/errors/lifecycle.js.map +1 -0
- package/dist/errors/math.d.ts +24 -0
- package/dist/errors/math.d.ts.map +1 -0
- package/dist/errors/math.js +34 -0
- package/dist/errors/math.js.map +1 -0
- package/dist/errors/node.d.ts +68 -0
- package/dist/errors/node.d.ts.map +1 -0
- package/dist/errors/node.js +87 -0
- package/dist/errors/node.js.map +1 -0
- package/dist/errors/scene.d.ts +35 -0
- package/dist/errors/scene.d.ts.map +1 -0
- package/dist/errors/scene.js +42 -0
- package/dist/errors/scene.js.map +1 -0
- package/dist/events/event.d.ts +106 -0
- package/dist/events/event.d.ts.map +1 -0
- package/dist/events/event.js +125 -0
- package/dist/events/event.js.map +1 -0
- package/dist/events/index.d.ts +2 -0
- package/dist/events/index.d.ts.map +1 -0
- package/dist/events/index.js +2 -0
- package/dist/events/index.js.map +1 -0
- package/dist/events/types.d.ts +20 -0
- package/dist/events/types.d.ts.map +1 -0
- package/dist/events/types.js +2 -0
- package/dist/events/types.js.map +1 -0
- package/dist/hooks/context.d.ts +15 -0
- package/dist/hooks/context.d.ts.map +1 -0
- package/dist/hooks/context.js +26 -0
- package/dist/hooks/context.js.map +1 -0
- package/dist/hooks/deriveds/by-nodes/index.d.ts +7 -0
- package/dist/hooks/deriveds/by-nodes/index.d.ts.map +1 -0
- package/dist/hooks/deriveds/by-nodes/index.js +7 -0
- package/dist/hooks/deriveds/by-nodes/index.js.map +1 -0
- package/dist/hooks/deriveds/by-nodes/use-animation.d.ts +44 -0
- package/dist/hooks/deriveds/by-nodes/use-animation.d.ts.map +1 -0
- package/dist/hooks/deriveds/by-nodes/use-animation.js +61 -0
- package/dist/hooks/deriveds/by-nodes/use-animation.js.map +1 -0
- package/dist/hooks/deriveds/by-nodes/use-audio.d.ts +33 -0
- package/dist/hooks/deriveds/by-nodes/use-audio.d.ts.map +1 -0
- package/dist/hooks/deriveds/by-nodes/use-audio.js +43 -0
- package/dist/hooks/deriveds/by-nodes/use-audio.js.map +1 -0
- package/dist/hooks/deriveds/by-nodes/use-clickable.d.ts +32 -0
- package/dist/hooks/deriveds/by-nodes/use-clickable.d.ts.map +1 -0
- package/dist/hooks/deriveds/by-nodes/use-clickable.js +43 -0
- package/dist/hooks/deriveds/by-nodes/use-clickable.js.map +1 -0
- package/dist/hooks/deriveds/by-nodes/use-collider.d.ts +35 -0
- package/dist/hooks/deriveds/by-nodes/use-collider.d.ts.map +1 -0
- package/dist/hooks/deriveds/by-nodes/use-collider.js +55 -0
- package/dist/hooks/deriveds/by-nodes/use-collider.js.map +1 -0
- package/dist/hooks/deriveds/by-nodes/use-ray-cast.d.ts +35 -0
- package/dist/hooks/deriveds/by-nodes/use-ray-cast.d.ts.map +1 -0
- package/dist/hooks/deriveds/by-nodes/use-ray-cast.js +47 -0
- package/dist/hooks/deriveds/by-nodes/use-ray-cast.js.map +1 -0
- package/dist/hooks/deriveds/by-nodes/use-timer.d.ts +34 -0
- package/dist/hooks/deriveds/by-nodes/use-timer.d.ts.map +1 -0
- package/dist/hooks/deriveds/by-nodes/use-timer.js +48 -0
- package/dist/hooks/deriveds/by-nodes/use-timer.js.map +1 -0
- package/dist/hooks/deriveds/index.d.ts +5 -0
- package/dist/hooks/deriveds/index.d.ts.map +1 -0
- package/dist/hooks/deriveds/index.js +5 -0
- package/dist/hooks/deriveds/index.js.map +1 -0
- package/dist/hooks/deriveds/use-condition.d.ts +37 -0
- package/dist/hooks/deriveds/use-condition.d.ts.map +1 -0
- package/dist/hooks/deriveds/use-condition.js +47 -0
- package/dist/hooks/deriveds/use-condition.js.map +1 -0
- package/dist/hooks/deriveds/use-match.d.ts +26 -0
- package/dist/hooks/deriveds/use-match.d.ts.map +1 -0
- package/dist/hooks/deriveds/use-match.js +38 -0
- package/dist/hooks/deriveds/use-match.js.map +1 -0
- package/dist/hooks/deriveds/use-partial-node.d.ts +22 -0
- package/dist/hooks/deriveds/use-partial-node.d.ts.map +1 -0
- package/dist/hooks/deriveds/use-partial-node.js +25 -0
- package/dist/hooks/deriveds/use-partial-node.js.map +1 -0
- package/dist/hooks/deriveds/use-when.d.ts +28 -0
- package/dist/hooks/deriveds/use-when.d.ts.map +1 -0
- package/dist/hooks/deriveds/use-when.js +35 -0
- package/dist/hooks/deriveds/use-when.js.map +1 -0
- package/dist/hooks/index.d.ts +16 -0
- package/dist/hooks/index.d.ts.map +1 -0
- package/dist/hooks/index.js +16 -0
- package/dist/hooks/index.js.map +1 -0
- package/dist/hooks/use-child.d.ts +24 -0
- package/dist/hooks/use-child.d.ts.map +1 -0
- package/dist/hooks/use-child.js +37 -0
- package/dist/hooks/use-child.js.map +1 -0
- package/dist/hooks/use-computed.d.ts +28 -0
- package/dist/hooks/use-computed.d.ts.map +1 -0
- package/dist/hooks/use-computed.js +41 -0
- package/dist/hooks/use-computed.js.map +1 -0
- package/dist/hooks/use-context.d.ts +58 -0
- package/dist/hooks/use-context.d.ts.map +1 -0
- package/dist/hooks/use-context.js +77 -0
- package/dist/hooks/use-context.js.map +1 -0
- package/dist/hooks/use-effect.d.ts +24 -0
- package/dist/hooks/use-effect.d.ts.map +1 -0
- package/dist/hooks/use-effect.js +63 -0
- package/dist/hooks/use-effect.js.map +1 -0
- package/dist/hooks/use-event.d.ts +29 -0
- package/dist/hooks/use-event.d.ts.map +1 -0
- package/dist/hooks/use-event.js +30 -0
- package/dist/hooks/use-event.js.map +1 -0
- package/dist/hooks/use-game.d.ts +17 -0
- package/dist/hooks/use-game.d.ts.map +1 -0
- package/dist/hooks/use-game.js +35 -0
- package/dist/hooks/use-game.js.map +1 -0
- package/dist/hooks/use-mount.d.ts +21 -0
- package/dist/hooks/use-mount.d.ts.map +1 -0
- package/dist/hooks/use-mount.js +33 -0
- package/dist/hooks/use-mount.js.map +1 -0
- package/dist/hooks/use-node.d.ts +42 -0
- package/dist/hooks/use-node.d.ts.map +1 -0
- package/dist/hooks/use-node.js +63 -0
- package/dist/hooks/use-node.js.map +1 -0
- package/dist/hooks/use-ref.d.ts +27 -0
- package/dist/hooks/use-ref.d.ts.map +1 -0
- package/dist/hooks/use-ref.js +33 -0
- package/dist/hooks/use-ref.js.map +1 -0
- package/dist/hooks/use-script.d.ts +33 -0
- package/dist/hooks/use-script.d.ts.map +1 -0
- package/dist/hooks/use-script.js +40 -0
- package/dist/hooks/use-script.js.map +1 -0
- package/dist/hooks/use-signal.d.ts +25 -0
- package/dist/hooks/use-signal.d.ts.map +1 -0
- package/dist/hooks/use-signal.js +36 -0
- package/dist/hooks/use-signal.js.map +1 -0
- package/dist/hooks/use-spawn.d.ts +27 -0
- package/dist/hooks/use-spawn.d.ts.map +1 -0
- package/dist/hooks/use-spawn.js +39 -0
- package/dist/hooks/use-spawn.js.map +1 -0
- package/dist/hooks/use-trigger.d.ts +51 -0
- package/dist/hooks/use-trigger.d.ts.map +1 -0
- package/dist/hooks/use-trigger.js +68 -0
- package/dist/hooks/use-trigger.js.map +1 -0
- package/dist/index.d.ts +11 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +11 -0
- package/dist/index.js.map +1 -0
- package/dist/input/input.d.ts +46 -0
- package/dist/input/input.d.ts.map +1 -0
- package/dist/input/input.js +159 -0
- package/dist/input/input.js.map +1 -0
- package/dist/jsx/components/fragment.d.ts +3 -0
- package/dist/jsx/components/fragment.d.ts.map +1 -0
- package/dist/jsx/components/fragment.js +7 -0
- package/dist/jsx/components/fragment.js.map +1 -0
- package/dist/jsx/components/game.d.ts +21 -0
- package/dist/jsx/components/game.d.ts.map +1 -0
- package/dist/jsx/components/game.js +17 -0
- package/dist/jsx/components/game.js.map +1 -0
- package/dist/jsx/components/index.d.ts +5 -0
- package/dist/jsx/components/index.d.ts.map +1 -0
- package/dist/jsx/components/index.js +5 -0
- package/dist/jsx/components/index.js.map +1 -0
- package/dist/jsx/components/list.d.ts +88 -0
- package/dist/jsx/components/list.d.ts.map +1 -0
- package/dist/jsx/components/list.js +93 -0
- package/dist/jsx/components/list.js.map +1 -0
- package/dist/jsx/components/scene.d.ts +40 -0
- package/dist/jsx/components/scene.d.ts.map +1 -0
- package/dist/jsx/components/scene.js +20 -0
- package/dist/jsx/components/scene.js.map +1 -0
- package/dist/jsx/index.d.ts +5 -0
- package/dist/jsx/index.d.ts.map +1 -0
- package/dist/jsx/index.js +5 -0
- package/dist/jsx/index.js.map +1 -0
- package/dist/jsx/jsx.d.ts +3 -0
- package/dist/jsx/jsx.d.ts.map +1 -0
- package/dist/jsx/jsx.js +4 -0
- package/dist/jsx/jsx.js.map +1 -0
- package/dist/jsx/render/game.d.ts +41 -0
- package/dist/jsx/render/game.d.ts.map +1 -0
- package/dist/jsx/render/game.js +86 -0
- package/dist/jsx/render/game.js.map +1 -0
- package/dist/jsx/render/index.d.ts +3 -0
- package/dist/jsx/render/index.d.ts.map +1 -0
- package/dist/jsx/render/index.js +3 -0
- package/dist/jsx/render/index.js.map +1 -0
- package/dist/jsx/render/to-nodes.d.ts +10 -0
- package/dist/jsx/render/to-nodes.d.ts.map +1 -0
- package/dist/jsx/render/to-nodes.js +52 -0
- package/dist/jsx/render/to-nodes.js.map +1 -0
- package/dist/jsx/render/types/class-component.d.ts +4 -0
- package/dist/jsx/render/types/class-component.d.ts.map +1 -0
- package/dist/jsx/render/types/class-component.js +8 -0
- package/dist/jsx/render/types/class-component.js.map +1 -0
- package/dist/jsx/render/types/func-components.d.ts +4 -0
- package/dist/jsx/render/types/func-components.d.ts.map +1 -0
- package/dist/jsx/render/types/func-components.js +8 -0
- package/dist/jsx/render/types/func-components.js.map +1 -0
- package/dist/jsx/render/types/instrinsic-elements.d.ts +6 -0
- package/dist/jsx/render/types/instrinsic-elements.d.ts.map +1 -0
- package/dist/jsx/render/types/instrinsic-elements.js +41 -0
- package/dist/jsx/render/types/instrinsic-elements.js.map +1 -0
- package/dist/jsx/types.d.ts +41 -0
- package/dist/jsx/types.d.ts.map +1 -0
- package/dist/jsx/types.js +2 -0
- package/dist/jsx/types.js.map +1 -0
- package/dist/jsx/utils.d.ts +4 -0
- package/dist/jsx/utils.d.ts.map +1 -0
- package/dist/jsx/utils.js +15 -0
- package/dist/jsx/utils.js.map +1 -0
- package/dist/jsx-runtime.d.ts +6 -0
- package/dist/jsx-runtime.d.ts.map +1 -0
- package/dist/jsx-runtime.js +6 -0
- package/dist/jsx-runtime.js.map +1 -0
- package/dist/math/index.d.ts +3 -0
- package/dist/math/index.d.ts.map +1 -0
- package/dist/math/index.js +2 -0
- package/dist/math/index.js.map +1 -0
- package/dist/math/types.d.ts +13 -0
- package/dist/math/types.d.ts.map +1 -0
- package/dist/math/types.js +2 -0
- package/dist/math/types.js.map +1 -0
- package/dist/math/vector2.d.ts +145 -0
- package/dist/math/vector2.d.ts.map +1 -0
- package/dist/math/vector2.js +164 -0
- package/dist/math/vector2.js.map +1 -0
- package/dist/nodes/_node.d.ts +283 -0
- package/dist/nodes/_node.d.ts.map +1 -0
- package/dist/nodes/_node.js +371 -0
- package/dist/nodes/_node.js.map +1 -0
- package/dist/nodes/animation-player.d.ts +208 -0
- package/dist/nodes/animation-player.d.ts.map +1 -0
- package/dist/nodes/animation-player.js +249 -0
- package/dist/nodes/animation-player.js.map +1 -0
- package/dist/nodes/audio-player.d.ts +128 -0
- package/dist/nodes/audio-player.d.ts.map +1 -0
- package/dist/nodes/audio-player.js +173 -0
- package/dist/nodes/audio-player.js.map +1 -0
- package/dist/nodes/group.d.ts +55 -0
- package/dist/nodes/group.d.ts.map +1 -0
- package/dist/nodes/group.js +54 -0
- package/dist/nodes/group.js.map +1 -0
- package/dist/nodes/index.d.ts +8 -0
- package/dist/nodes/index.d.ts.map +1 -0
- package/dist/nodes/index.js +7 -0
- package/dist/nodes/index.js.map +1 -0
- package/dist/nodes/lib/enum.d.ts +42 -0
- package/dist/nodes/lib/enum.d.ts.map +1 -0
- package/dist/nodes/lib/enum.js +43 -0
- package/dist/nodes/lib/enum.js.map +1 -0
- package/dist/nodes/lib/index.d.ts +5 -0
- package/dist/nodes/lib/index.d.ts.map +1 -0
- package/dist/nodes/lib/index.js +5 -0
- package/dist/nodes/lib/index.js.map +1 -0
- package/dist/nodes/lib/registry.d.ts +43 -0
- package/dist/nodes/lib/registry.d.ts.map +1 -0
- package/dist/nodes/lib/registry.js +46 -0
- package/dist/nodes/lib/registry.js.map +1 -0
- package/dist/nodes/lib/types.d.ts +89 -0
- package/dist/nodes/lib/types.d.ts.map +1 -0
- package/dist/nodes/lib/types.js +2 -0
- package/dist/nodes/lib/types.js.map +1 -0
- package/dist/nodes/lib/utils.d.ts +35 -0
- package/dist/nodes/lib/utils.d.ts.map +1 -0
- package/dist/nodes/lib/utils.js +58 -0
- package/dist/nodes/lib/utils.js.map +1 -0
- package/dist/nodes/node2d/_node2d.d.ts +59 -0
- package/dist/nodes/node2d/_node2d.d.ts.map +1 -0
- package/dist/nodes/node2d/_node2d.js +57 -0
- package/dist/nodes/node2d/_node2d.js.map +1 -0
- package/dist/nodes/node2d/camera.d.ts +64 -0
- package/dist/nodes/node2d/camera.d.ts.map +1 -0
- package/dist/nodes/node2d/camera.js +72 -0
- package/dist/nodes/node2d/camera.js.map +1 -0
- package/dist/nodes/node2d/clickable.d.ts +96 -0
- package/dist/nodes/node2d/clickable.d.ts.map +1 -0
- package/dist/nodes/node2d/clickable.js +117 -0
- package/dist/nodes/node2d/clickable.js.map +1 -0
- package/dist/nodes/node2d/collider.d.ts +96 -0
- package/dist/nodes/node2d/collider.d.ts.map +1 -0
- package/dist/nodes/node2d/collider.js +116 -0
- package/dist/nodes/node2d/collider.js.map +1 -0
- package/dist/nodes/node2d/index.d.ts +12 -0
- package/dist/nodes/node2d/index.d.ts.map +1 -0
- package/dist/nodes/node2d/index.js +11 -0
- package/dist/nodes/node2d/index.js.map +1 -0
- package/dist/nodes/node2d/lib/index.d.ts +2 -0
- package/dist/nodes/node2d/lib/index.d.ts.map +1 -0
- package/dist/nodes/node2d/lib/index.js +2 -0
- package/dist/nodes/node2d/lib/index.js.map +1 -0
- package/dist/nodes/node2d/lib/utils.d.ts +4 -0
- package/dist/nodes/node2d/lib/utils.d.ts.map +1 -0
- package/dist/nodes/node2d/lib/utils.js +14 -0
- package/dist/nodes/node2d/lib/utils.js.map +1 -0
- package/dist/nodes/node2d/ray-cast.d.ts +115 -0
- package/dist/nodes/node2d/ray-cast.d.ts.map +1 -0
- package/dist/nodes/node2d/ray-cast.js +129 -0
- package/dist/nodes/node2d/ray-cast.js.map +1 -0
- package/dist/nodes/node2d/rectangle.d.ts +87 -0
- package/dist/nodes/node2d/rectangle.d.ts.map +1 -0
- package/dist/nodes/node2d/rectangle.js +60 -0
- package/dist/nodes/node2d/rectangle.js.map +1 -0
- package/dist/nodes/node2d/rigid-body.d.ts +65 -0
- package/dist/nodes/node2d/rigid-body.d.ts.map +1 -0
- package/dist/nodes/node2d/rigid-body.js +56 -0
- package/dist/nodes/node2d/rigid-body.js.map +1 -0
- package/dist/nodes/node2d/sprite.d.ts +285 -0
- package/dist/nodes/node2d/sprite.d.ts.map +1 -0
- package/dist/nodes/node2d/sprite.js +226 -0
- package/dist/nodes/node2d/sprite.js.map +1 -0
- package/dist/nodes/node2d/text.d.ts +62 -0
- package/dist/nodes/node2d/text.d.ts.map +1 -0
- package/dist/nodes/node2d/text.js +52 -0
- package/dist/nodes/node2d/text.js.map +1 -0
- package/dist/nodes/node2d/transform.d.ts +32 -0
- package/dist/nodes/node2d/transform.d.ts.map +1 -0
- package/dist/nodes/node2d/transform.js +30 -0
- package/dist/nodes/node2d/transform.js.map +1 -0
- package/dist/nodes/timer.d.ts +107 -0
- package/dist/nodes/timer.d.ts.map +1 -0
- package/dist/nodes/timer.js +108 -0
- package/dist/nodes/timer.js.map +1 -0
- package/dist/reactivity/index.d.ts +5 -0
- package/dist/reactivity/index.d.ts.map +1 -0
- package/dist/reactivity/index.js +5 -0
- package/dist/reactivity/index.js.map +1 -0
- package/dist/reactivity/reactive.d.ts +4 -0
- package/dist/reactivity/reactive.d.ts.map +1 -0
- package/dist/reactivity/reactive.js +50 -0
- package/dist/reactivity/reactive.js.map +1 -0
- package/dist/reactivity/register.d.ts +7 -0
- package/dist/reactivity/register.d.ts.map +1 -0
- package/dist/reactivity/register.js +18 -0
- package/dist/reactivity/register.js.map +1 -0
- package/dist/reactivity/signal.d.ts +126 -0
- package/dist/reactivity/signal.d.ts.map +1 -0
- package/dist/reactivity/signal.js +152 -0
- package/dist/reactivity/signal.js.map +1 -0
- package/dist/reactivity/types.d.ts +31 -0
- package/dist/reactivity/types.d.ts.map +1 -0
- package/dist/reactivity/types.js +2 -0
- package/dist/reactivity/types.js.map +1 -0
- package/dist/scripts/index.d.ts +2 -0
- package/dist/scripts/index.d.ts.map +1 -0
- package/dist/scripts/index.js +2 -0
- package/dist/scripts/index.js.map +1 -0
- package/dist/scripts/script.d.ts +80 -0
- package/dist/scripts/script.d.ts.map +1 -0
- package/dist/scripts/script.js +75 -0
- package/dist/scripts/script.js.map +1 -0
- package/dist/utils/dpr.d.ts +2 -0
- package/dist/utils/dpr.d.ts.map +1 -0
- package/dist/utils/dpr.js +14 -0
- package/dist/utils/dpr.js.map +1 -0
- package/dist/utils/ternaries.d.ts +6 -0
- package/dist/utils/ternaries.d.ts.map +1 -0
- package/dist/utils/ternaries.js +17 -0
- package/dist/utils/ternaries.js.map +1 -0
- package/package.json +56 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"use-animation.d.ts","sourceRoot":"","sources":["../../../../src/hooks/deriveds/by-nodes/use-animation.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAA;AAGrD,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAA;AAKtD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA+BG;AACH,wBAAgB,YAAY,CAAC,IAAI,CAAC,EAAE,aAAa,CAAC,WAAW,CAAC,eAAe,CAAC;;;;;;;;EA0B7E"}
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
import { PrimaryNode } from '../../../nodes/index.js';
|
|
2
|
+
import { declareDerivedHook } from '../../context.js';
|
|
3
|
+
import { useEvent } from '../../use-event.js';
|
|
4
|
+
import { useSignal } from '../../use-signal.js';
|
|
5
|
+
import { usePartialNode } from '../use-partial-node.js';
|
|
6
|
+
import { useCondition } from '../use-condition.js';
|
|
7
|
+
/**
|
|
8
|
+
* The **`useAnimation`** derived hook provides a declarative API for the `AnimationPlayer` node.
|
|
9
|
+
* Returns the node reference, reactive `animName` and `frameIndex` signals,
|
|
10
|
+
* a reactive `ended` boolean, and control methods.
|
|
11
|
+
*
|
|
12
|
+
* @param anim An optional existing `NodeReference` to the AnimationPlayer node
|
|
13
|
+
* @returns An object with `ref`, `animName`, `frameIndex`, `ended`, `play`, `stop`, `setNext`
|
|
14
|
+
*
|
|
15
|
+
* @example
|
|
16
|
+
* ```tsx
|
|
17
|
+
* import { useAnimation } from 'dinix/hooks'
|
|
18
|
+
*
|
|
19
|
+
* function Character() {
|
|
20
|
+
* const sprite = useNode(PrimaryNode.Sprite)
|
|
21
|
+
* const { ref, animName, ended, play, setNext } = useAnimation()
|
|
22
|
+
*
|
|
23
|
+
* useEffect(() => {
|
|
24
|
+
* play(isWalking() ? 'walk' : 'idle')
|
|
25
|
+
* })
|
|
26
|
+
*
|
|
27
|
+
* useEvent(ref, 'animationEnded', () => {
|
|
28
|
+
* setNext('idle')
|
|
29
|
+
* })
|
|
30
|
+
*
|
|
31
|
+
* return (
|
|
32
|
+
* <sprite ref={sprite} textureId={CHAR}>
|
|
33
|
+
* <animation-player ref={ref} animations={() => anims} currentAnim={animName} />
|
|
34
|
+
* </sprite>
|
|
35
|
+
* )
|
|
36
|
+
* }
|
|
37
|
+
* ```
|
|
38
|
+
*/
|
|
39
|
+
export function useAnimation(anim) {
|
|
40
|
+
declareDerivedHook('useAnimation');
|
|
41
|
+
const ref = usePartialNode(PrimaryNode.AnimationPlayer, anim);
|
|
42
|
+
const [animName, setAnimName] = useSignal(null);
|
|
43
|
+
useEvent(ref, 'animationChanged', (name) => setAnimName(name));
|
|
44
|
+
useEvent(ref, 'animationStopped', () => setAnimName(null));
|
|
45
|
+
const [frameIndex, setFrameIndex] = useSignal(0);
|
|
46
|
+
useEvent(ref, 'animationIndexChanged', setFrameIndex);
|
|
47
|
+
const ended = useCondition(ref, 'animationEnded', 'animationChanged');
|
|
48
|
+
const play = (...args) => ref.node.play(...args);
|
|
49
|
+
const stop = (...args) => ref.node.stop(...args);
|
|
50
|
+
const setNext = (...args) => ref.node.setNext(...args);
|
|
51
|
+
return {
|
|
52
|
+
ref,
|
|
53
|
+
animName,
|
|
54
|
+
frameIndex,
|
|
55
|
+
ended,
|
|
56
|
+
play,
|
|
57
|
+
stop,
|
|
58
|
+
setNext,
|
|
59
|
+
};
|
|
60
|
+
}
|
|
61
|
+
//# sourceMappingURL=use-animation.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"use-animation.js","sourceRoot":"","sources":["../../../../src/hooks/deriveds/by-nodes/use-animation.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAA;AACrD,OAAO,EAAE,kBAAkB,EAAE,MAAM,kBAAkB,CAAA;AACrD,OAAO,EAAE,QAAQ,EAAE,MAAM,oBAAoB,CAAA;AAE7C,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAA;AAC/C,OAAO,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAA;AACvD,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAA;AAElD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA+BG;AACH,MAAM,UAAU,YAAY,CAAC,IAAiD;IAC5E,kBAAkB,CAAC,cAAc,CAAC,CAAA;IAClC,MAAM,GAAG,GAAG,cAAc,CAAC,WAAW,CAAC,eAAe,EAAE,IAAI,CAAC,CAAA;IAE7D,MAAM,CAAC,QAAQ,EAAE,WAAW,CAAC,GAAG,SAAS,CAAgB,IAAI,CAAC,CAAA;IAC9D,QAAQ,CAAC,GAAG,EAAE,kBAAkB,EAAE,CAAC,IAAI,EAAE,EAAE,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,CAAA;IAC9D,QAAQ,CAAC,GAAG,EAAE,kBAAkB,EAAE,GAAG,EAAE,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,CAAA;IAE1D,MAAM,CAAC,UAAU,EAAE,aAAa,CAAC,GAAG,SAAS,CAAC,CAAC,CAAC,CAAA;IAChD,QAAQ,CAAC,GAAG,EAAE,uBAAuB,EAAE,aAAa,CAAC,CAAA;IAErD,MAAM,KAAK,GAAG,YAAY,CAAC,GAAG,EAAE,gBAAgB,EAAE,kBAAkB,CAAC,CAAA;IAErE,MAAM,IAAI,GAAyB,CAAC,GAAG,IAAI,EAAE,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,CAAA;IACtE,MAAM,IAAI,GAAyB,CAAC,GAAG,IAAI,EAAE,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,CAAA;IACtE,MAAM,OAAO,GAA4B,CAAC,GAAG,IAAI,EAAE,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,IAAI,CAAC,CAAA;IAE/E,OAAO;QACL,GAAG;QACH,QAAQ;QACR,UAAU;QACV,KAAK;QACL,IAAI;QACJ,IAAI;QACJ,OAAO;KACR,CAAA;AACH,CAAC"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { PrimaryNode } from '../../../nodes/index.js';
|
|
2
|
+
import type { NodeReference } from '../../use-node.js';
|
|
3
|
+
/**
|
|
4
|
+
* The **`useAudio`** derived hook provides a declarative API for the `AudioPlayer` node.
|
|
5
|
+
* Returns the node reference, a reactive `playing` boolean, and control methods.
|
|
6
|
+
*
|
|
7
|
+
* @param audio An optional existing `NodeReference` to the AudioPlayer node
|
|
8
|
+
* @returns An object with `ref`, `playing`, `play`, `pause`, `stop`
|
|
9
|
+
*
|
|
10
|
+
* @example
|
|
11
|
+
* ```tsx
|
|
12
|
+
* import { useAudio } from 'dinix/hooks'
|
|
13
|
+
*
|
|
14
|
+
* function MusicPlayer() {
|
|
15
|
+
* const { ref, playing, play, stop } = useAudio()
|
|
16
|
+
*
|
|
17
|
+
* return (
|
|
18
|
+
* <transform>
|
|
19
|
+
* <audio-player ref={ref} soundId={MUSIC} loop />
|
|
20
|
+
* <clickable onClick={() => playing() ? stop() : play()} />
|
|
21
|
+
* </transform>
|
|
22
|
+
* )
|
|
23
|
+
* }
|
|
24
|
+
* ```
|
|
25
|
+
*/
|
|
26
|
+
export declare function useAudio(audio?: NodeReference<PrimaryNode.AudioPlayer>): {
|
|
27
|
+
ref: NodeReference<PrimaryNode.AudioPlayer>;
|
|
28
|
+
playing: import("../../../index.js").SignalGetter<boolean>;
|
|
29
|
+
play: (offset?: number) => void;
|
|
30
|
+
pause: () => void;
|
|
31
|
+
stop: () => void;
|
|
32
|
+
};
|
|
33
|
+
//# sourceMappingURL=use-audio.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"use-audio.d.ts","sourceRoot":"","sources":["../../../../src/hooks/deriveds/by-nodes/use-audio.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAA;AAErD,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAA;AAItD;;;;;;;;;;;;;;;;;;;;;;GAsBG;AACH,wBAAgB,QAAQ,CAAC,KAAK,CAAC,EAAE,aAAa,CAAC,WAAW,CAAC,WAAW,CAAC;;;;;;EAiBtE"}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import { PrimaryNode } from '../../../nodes/index.js';
|
|
2
|
+
import { declareDerivedHook } from '../../context.js';
|
|
3
|
+
import { usePartialNode } from '../use-partial-node.js';
|
|
4
|
+
import { useCondition } from '../use-condition.js';
|
|
5
|
+
/**
|
|
6
|
+
* The **`useAudio`** derived hook provides a declarative API for the `AudioPlayer` node.
|
|
7
|
+
* Returns the node reference, a reactive `playing` boolean, and control methods.
|
|
8
|
+
*
|
|
9
|
+
* @param audio An optional existing `NodeReference` to the AudioPlayer node
|
|
10
|
+
* @returns An object with `ref`, `playing`, `play`, `pause`, `stop`
|
|
11
|
+
*
|
|
12
|
+
* @example
|
|
13
|
+
* ```tsx
|
|
14
|
+
* import { useAudio } from 'dinix/hooks'
|
|
15
|
+
*
|
|
16
|
+
* function MusicPlayer() {
|
|
17
|
+
* const { ref, playing, play, stop } = useAudio()
|
|
18
|
+
*
|
|
19
|
+
* return (
|
|
20
|
+
* <transform>
|
|
21
|
+
* <audio-player ref={ref} soundId={MUSIC} loop />
|
|
22
|
+
* <clickable onClick={() => playing() ? stop() : play()} />
|
|
23
|
+
* </transform>
|
|
24
|
+
* )
|
|
25
|
+
* }
|
|
26
|
+
* ```
|
|
27
|
+
*/
|
|
28
|
+
export function useAudio(audio) {
|
|
29
|
+
declareDerivedHook('useAudio');
|
|
30
|
+
const ref = usePartialNode(PrimaryNode.AudioPlayer, audio);
|
|
31
|
+
const playing = useCondition(ref, 'started', 'ended');
|
|
32
|
+
const play = (...args) => ref.node.play(...args);
|
|
33
|
+
const pause = (...args) => ref.node.pause(...args);
|
|
34
|
+
const stop = (...args) => ref.node.stop(...args);
|
|
35
|
+
return {
|
|
36
|
+
ref,
|
|
37
|
+
playing,
|
|
38
|
+
play,
|
|
39
|
+
pause,
|
|
40
|
+
stop,
|
|
41
|
+
};
|
|
42
|
+
}
|
|
43
|
+
//# sourceMappingURL=use-audio.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"use-audio.js","sourceRoot":"","sources":["../../../../src/hooks/deriveds/by-nodes/use-audio.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAA;AACrD,OAAO,EAAE,kBAAkB,EAAE,MAAM,kBAAkB,CAAA;AAErD,OAAO,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAA;AACvD,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAA;AAElD;;;;;;;;;;;;;;;;;;;;;;GAsBG;AACH,MAAM,UAAU,QAAQ,CAAC,KAA8C;IACrE,kBAAkB,CAAC,UAAU,CAAC,CAAA;IAC9B,MAAM,GAAG,GAAG,cAAc,CAAC,WAAW,CAAC,WAAW,EAAE,KAAK,CAAC,CAAA;IAE1D,MAAM,OAAO,GAAG,YAAY,CAAC,GAAG,EAAE,SAAS,EAAE,OAAO,CAAC,CAAA;IAErD,MAAM,IAAI,GAAyB,CAAC,GAAG,IAAI,EAAE,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,CAAA;IACtE,MAAM,KAAK,GAA0B,CAAC,GAAG,IAAI,EAAE,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC,CAAA;IACzE,MAAM,IAAI,GAAyB,CAAC,GAAG,IAAI,EAAE,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,CAAA;IAEtE,OAAO;QACL,GAAG;QACH,OAAO;QACP,IAAI;QACJ,KAAK;QACL,IAAI;KACL,CAAA;AACH,CAAC"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { Vector2 } from '../../../math/vector2.js';
|
|
2
|
+
import { PrimaryNode } from '../../../nodes/index.js';
|
|
3
|
+
import type { NodeReference } from '../../use-node.js';
|
|
4
|
+
/**
|
|
5
|
+
* The **`useClickable`** derived hook provides a declarative API for the `Clickable` node.
|
|
6
|
+
* Returns the node reference and a reactive `hovered` boolean that tracks pointer hover state.
|
|
7
|
+
*
|
|
8
|
+
* @param clickable An optional existing `NodeReference` to the Clickable node
|
|
9
|
+
* @returns An object with `ref` (NodeReference) and `hovered` (SignalGetter<boolean>)
|
|
10
|
+
*
|
|
11
|
+
* @example
|
|
12
|
+
* ```tsx
|
|
13
|
+
* import { useClickable } from 'dinix/hooks'
|
|
14
|
+
*
|
|
15
|
+
* function Button() {
|
|
16
|
+
* const clickable = useClickable()
|
|
17
|
+
* const brightness = useComputed(() => (clickable.hovered() ? 1.1 : 1))
|
|
18
|
+
*
|
|
19
|
+
* return (
|
|
20
|
+
* <sprite ref={clickable.ref} textureId={BTN} brightness={brightness}>
|
|
21
|
+
* <clickable size={[64, 32]} onClick={handleClick} />
|
|
22
|
+
* </sprite>
|
|
23
|
+
* )
|
|
24
|
+
* }
|
|
25
|
+
* ```
|
|
26
|
+
*/
|
|
27
|
+
export declare function useClickable(clickable?: NodeReference<PrimaryNode.Clickable>): {
|
|
28
|
+
ref: NodeReference<PrimaryNode.Clickable>;
|
|
29
|
+
hovered: import("../../../index.js").SignalGetter<boolean>;
|
|
30
|
+
position: import("../../../index.js").SignalGetter<Vector2>;
|
|
31
|
+
};
|
|
32
|
+
//# sourceMappingURL=use-clickable.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"use-clickable.d.ts","sourceRoot":"","sources":["../../../../src/hooks/deriveds/by-nodes/use-clickable.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,0BAA0B,CAAA;AAClD,OAAO,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAA;AAGrD,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAA;AAKtD;;;;;;;;;;;;;;;;;;;;;;GAsBG;AACH,wBAAgB,YAAY,CAAC,SAAS,CAAC,EAAE,aAAa,CAAC,WAAW,CAAC,SAAS,CAAC;;;;EAa5E"}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import { Vector2 } from '../../../math/vector2.js';
|
|
2
|
+
import { PrimaryNode } from '../../../nodes/index.js';
|
|
3
|
+
import { declareDerivedHook } from '../../context.js';
|
|
4
|
+
import { useEvent } from '../../use-event.js';
|
|
5
|
+
import { useSignal } from '../../use-signal.js';
|
|
6
|
+
import { useCondition } from '../use-condition.js';
|
|
7
|
+
import { usePartialNode } from '../use-partial-node.js';
|
|
8
|
+
/**
|
|
9
|
+
* The **`useClickable`** derived hook provides a declarative API for the `Clickable` node.
|
|
10
|
+
* Returns the node reference and a reactive `hovered` boolean that tracks pointer hover state.
|
|
11
|
+
*
|
|
12
|
+
* @param clickable An optional existing `NodeReference` to the Clickable node
|
|
13
|
+
* @returns An object with `ref` (NodeReference) and `hovered` (SignalGetter<boolean>)
|
|
14
|
+
*
|
|
15
|
+
* @example
|
|
16
|
+
* ```tsx
|
|
17
|
+
* import { useClickable } from 'dinix/hooks'
|
|
18
|
+
*
|
|
19
|
+
* function Button() {
|
|
20
|
+
* const clickable = useClickable()
|
|
21
|
+
* const brightness = useComputed(() => (clickable.hovered() ? 1.1 : 1))
|
|
22
|
+
*
|
|
23
|
+
* return (
|
|
24
|
+
* <sprite ref={clickable.ref} textureId={BTN} brightness={brightness}>
|
|
25
|
+
* <clickable size={[64, 32]} onClick={handleClick} />
|
|
26
|
+
* </sprite>
|
|
27
|
+
* )
|
|
28
|
+
* }
|
|
29
|
+
* ```
|
|
30
|
+
*/
|
|
31
|
+
export function useClickable(clickable) {
|
|
32
|
+
declareDerivedHook('useClickable');
|
|
33
|
+
const ref = usePartialNode(PrimaryNode.Clickable, clickable);
|
|
34
|
+
const hovered = useCondition(ref, 'mouseEntered', 'mouseExited');
|
|
35
|
+
const [position, setPos] = useSignal(Vector2.ZERO);
|
|
36
|
+
useEvent(ref, 'mouseOver', setPos);
|
|
37
|
+
return {
|
|
38
|
+
ref,
|
|
39
|
+
hovered,
|
|
40
|
+
position,
|
|
41
|
+
};
|
|
42
|
+
}
|
|
43
|
+
//# sourceMappingURL=use-clickable.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"use-clickable.js","sourceRoot":"","sources":["../../../../src/hooks/deriveds/by-nodes/use-clickable.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,0BAA0B,CAAA;AAClD,OAAO,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAA;AACrD,OAAO,EAAE,kBAAkB,EAAE,MAAM,kBAAkB,CAAA;AACrD,OAAO,EAAE,QAAQ,EAAE,MAAM,oBAAoB,CAAA;AAE7C,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAA;AAC/C,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAA;AAClD,OAAO,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAA;AAEvD;;;;;;;;;;;;;;;;;;;;;;GAsBG;AACH,MAAM,UAAU,YAAY,CAAC,SAAgD;IAC3E,kBAAkB,CAAC,cAAc,CAAC,CAAA;IAClC,MAAM,GAAG,GAAG,cAAc,CAAC,WAAW,CAAC,SAAS,EAAE,SAAS,CAAC,CAAA;IAE5D,MAAM,OAAO,GAAG,YAAY,CAAC,GAAG,EAAE,cAAc,EAAE,aAAa,CAAC,CAAA;IAChE,MAAM,CAAC,QAAQ,EAAE,MAAM,CAAC,GAAG,SAAS,CAAC,OAAO,CAAC,IAAI,CAAC,CAAA;IAClD,QAAQ,CAAC,GAAG,EAAE,WAAW,EAAE,MAAM,CAAC,CAAA;IAElC,OAAO;QACL,GAAG;QACH,OAAO;QACP,QAAQ;KACT,CAAA;AACH,CAAC"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { Collider, PrimaryNode } from '../../../nodes/index.js';
|
|
2
|
+
import type { NodeReference } from '../../use-node.js';
|
|
3
|
+
/**
|
|
4
|
+
* The **`useCollider`** derived hook provides a declarative API for the `Collider` node.
|
|
5
|
+
* Returns the node reference, a reactive `colliding` boolean, and a signal tracking
|
|
6
|
+
* the currently colliding collider.
|
|
7
|
+
*
|
|
8
|
+
* @param collider An optional existing `NodeReference` to the Collider node
|
|
9
|
+
* @returns An object with `ref`, `colliding`, and `other`
|
|
10
|
+
*
|
|
11
|
+
* @example
|
|
12
|
+
* ```tsx
|
|
13
|
+
* import { useCollider } from 'dinix/hooks'
|
|
14
|
+
*
|
|
15
|
+
* function DamageZone() {
|
|
16
|
+
* const { ref, colliding, other } = useCollider()
|
|
17
|
+
*
|
|
18
|
+
* useEffect(() => {
|
|
19
|
+
* if (colliding()) {
|
|
20
|
+
* console.log('Touching:', other())
|
|
21
|
+
* }
|
|
22
|
+
* })
|
|
23
|
+
*
|
|
24
|
+
* return (
|
|
25
|
+
* <collider ref={ref} shape={shapes.circle(16)} group={['zone']} collidesWith={['player']} />
|
|
26
|
+
* )
|
|
27
|
+
* }
|
|
28
|
+
* ```
|
|
29
|
+
*/
|
|
30
|
+
export declare function useCollider(collider?: NodeReference<PrimaryNode.Collider>): {
|
|
31
|
+
ref: NodeReference<PrimaryNode.Collider>;
|
|
32
|
+
colliding: import("../../../index.js").SignalGetter<boolean>;
|
|
33
|
+
detectedColliders: import("../../../index.js").SignalGetter<Set<Collider>>;
|
|
34
|
+
};
|
|
35
|
+
//# sourceMappingURL=use-collider.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"use-collider.d.ts","sourceRoot":"","sources":["../../../../src/hooks/deriveds/by-nodes/use-collider.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAA;AAG/D,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAA;AAKtD;;;;;;;;;;;;;;;;;;;;;;;;;;GA0BG;AACH,wBAAgB,WAAW,CAAC,QAAQ,CAAC,EAAE,aAAa,CAAC,WAAW,CAAC,QAAQ,CAAC;;;;EAuBzE"}
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
import { Collider, PrimaryNode } from '../../../nodes/index.js';
|
|
2
|
+
import { declareDerivedHook } from '../../context.js';
|
|
3
|
+
import { useEvent } from '../../use-event.js';
|
|
4
|
+
import { useSignal } from '../../use-signal.js';
|
|
5
|
+
import { usePartialNode } from '../use-partial-node.js';
|
|
6
|
+
import { useComputed } from '../../use-computed.js';
|
|
7
|
+
/**
|
|
8
|
+
* The **`useCollider`** derived hook provides a declarative API for the `Collider` node.
|
|
9
|
+
* Returns the node reference, a reactive `colliding` boolean, and a signal tracking
|
|
10
|
+
* the currently colliding collider.
|
|
11
|
+
*
|
|
12
|
+
* @param collider An optional existing `NodeReference` to the Collider node
|
|
13
|
+
* @returns An object with `ref`, `colliding`, and `other`
|
|
14
|
+
*
|
|
15
|
+
* @example
|
|
16
|
+
* ```tsx
|
|
17
|
+
* import { useCollider } from 'dinix/hooks'
|
|
18
|
+
*
|
|
19
|
+
* function DamageZone() {
|
|
20
|
+
* const { ref, colliding, other } = useCollider()
|
|
21
|
+
*
|
|
22
|
+
* useEffect(() => {
|
|
23
|
+
* if (colliding()) {
|
|
24
|
+
* console.log('Touching:', other())
|
|
25
|
+
* }
|
|
26
|
+
* })
|
|
27
|
+
*
|
|
28
|
+
* return (
|
|
29
|
+
* <collider ref={ref} shape={shapes.circle(16)} group={['zone']} collidesWith={['player']} />
|
|
30
|
+
* )
|
|
31
|
+
* }
|
|
32
|
+
* ```
|
|
33
|
+
*/
|
|
34
|
+
export function useCollider(collider) {
|
|
35
|
+
declareDerivedHook('useCollider');
|
|
36
|
+
const ref = usePartialNode(PrimaryNode.Collider, collider);
|
|
37
|
+
const [detectedColliders, setDC] = useSignal(new Set());
|
|
38
|
+
useEvent(ref, 'colliderEntered', (c) => {
|
|
39
|
+
const set = new Set(detectedColliders());
|
|
40
|
+
set.add(c);
|
|
41
|
+
setDC(set);
|
|
42
|
+
});
|
|
43
|
+
useEvent(ref, 'colliderExited', (c) => {
|
|
44
|
+
const set = new Set(detectedColliders());
|
|
45
|
+
set.delete(c);
|
|
46
|
+
setDC(set);
|
|
47
|
+
});
|
|
48
|
+
const colliding = useComputed(() => detectedColliders() != null);
|
|
49
|
+
return {
|
|
50
|
+
ref,
|
|
51
|
+
colliding,
|
|
52
|
+
detectedColliders,
|
|
53
|
+
};
|
|
54
|
+
}
|
|
55
|
+
//# sourceMappingURL=use-collider.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"use-collider.js","sourceRoot":"","sources":["../../../../src/hooks/deriveds/by-nodes/use-collider.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAA;AAC/D,OAAO,EAAE,kBAAkB,EAAE,MAAM,kBAAkB,CAAA;AACrD,OAAO,EAAE,QAAQ,EAAE,MAAM,oBAAoB,CAAA;AAE7C,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAA;AAC/C,OAAO,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAA;AACvD,OAAO,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAA;AAEnD;;;;;;;;;;;;;;;;;;;;;;;;;;GA0BG;AACH,MAAM,UAAU,WAAW,CAAC,QAA8C;IACxE,kBAAkB,CAAC,aAAa,CAAC,CAAA;IACjC,MAAM,GAAG,GAAG,cAAc,CAAC,WAAW,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAA;IAE1D,MAAM,CAAC,iBAAiB,EAAE,KAAK,CAAC,GAAG,SAAS,CAAgB,IAAI,GAAG,EAAE,CAAC,CAAA;IACtE,QAAQ,CAAC,GAAG,EAAE,iBAAiB,EAAE,CAAC,CAAC,EAAE,EAAE;QACrC,MAAM,GAAG,GAAG,IAAI,GAAG,CAAC,iBAAiB,EAAE,CAAC,CAAA;QACxC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAA;QACV,KAAK,CAAC,GAAG,CAAC,CAAA;IACZ,CAAC,CAAC,CAAA;IACF,QAAQ,CAAC,GAAG,EAAE,gBAAgB,EAAE,CAAC,CAAC,EAAE,EAAE;QACpC,MAAM,GAAG,GAAG,IAAI,GAAG,CAAC,iBAAiB,EAAE,CAAC,CAAA;QACxC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAA;QACb,KAAK,CAAC,GAAG,CAAC,CAAA;IACZ,CAAC,CAAC,CAAA;IAEF,MAAM,SAAS,GAAG,WAAW,CAAC,GAAG,EAAE,CAAC,iBAAiB,EAAE,IAAI,IAAI,CAAC,CAAA;IAEhE,OAAO;QACL,GAAG;QACH,SAAS;QACT,iBAAiB;KAClB,CAAA;AACH,CAAC"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { Collider, PrimaryNode } from '../../../nodes/index.js';
|
|
2
|
+
import type { NodeReference } from '../../use-node.js';
|
|
3
|
+
/**
|
|
4
|
+
* The **`useRayCast`** derived hook provides a declarative API for the `RayCast` node.
|
|
5
|
+
* Returns the node reference, a reactive `detected` boolean, the current collider signal,
|
|
6
|
+
* and a reactive `length` computed value.
|
|
7
|
+
*
|
|
8
|
+
* @param raycast An optional existing `NodeReference` to the RayCast node
|
|
9
|
+
* @returns An object with `ref`, `detected`, `collider`, and `length`
|
|
10
|
+
*
|
|
11
|
+
* @example
|
|
12
|
+
* ```tsx
|
|
13
|
+
* import { useRayCast } from 'dinix/hooks'
|
|
14
|
+
*
|
|
15
|
+
* function Peashooter() {
|
|
16
|
+
* const { ref, detected, collider } = useRayCast()
|
|
17
|
+
*
|
|
18
|
+
* useEffect(() => {
|
|
19
|
+
* if (detected()) {
|
|
20
|
+
* console.log('Hit:', collider())
|
|
21
|
+
* }
|
|
22
|
+
* })
|
|
23
|
+
*
|
|
24
|
+
* return (
|
|
25
|
+
* <ray-cast ref={ref} direction={[100, 0]} collidesWith={['zombie']} />
|
|
26
|
+
* )
|
|
27
|
+
* }
|
|
28
|
+
* ```
|
|
29
|
+
*/
|
|
30
|
+
export declare function useRayCast(raycast?: NodeReference<PrimaryNode.RayCast>): {
|
|
31
|
+
ref: NodeReference<PrimaryNode.RayCast>;
|
|
32
|
+
detected: import("../../../index.js").SignalGetter<boolean>;
|
|
33
|
+
collider: import("../../../index.js").SignalGetter<Collider | null>;
|
|
34
|
+
};
|
|
35
|
+
//# sourceMappingURL=use-ray-cast.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"use-ray-cast.d.ts","sourceRoot":"","sources":["../../../../src/hooks/deriveds/by-nodes/use-ray-cast.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAA;AAI/D,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAA;AAItD;;;;;;;;;;;;;;;;;;;;;;;;;;GA0BG;AACH,wBAAgB,UAAU,CAAC,OAAO,CAAC,EAAE,aAAa,CAAC,WAAW,CAAC,OAAO,CAAC;;;;EAetE"}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import { Collider, PrimaryNode } from '../../../nodes/index.js';
|
|
2
|
+
import { declareDerivedHook } from '../../context.js';
|
|
3
|
+
import { useComputed } from '../../use-computed.js';
|
|
4
|
+
import { useEvent } from '../../use-event.js';
|
|
5
|
+
import { useSignal } from '../../use-signal.js';
|
|
6
|
+
import { usePartialNode } from '../use-partial-node.js';
|
|
7
|
+
/**
|
|
8
|
+
* The **`useRayCast`** derived hook provides a declarative API for the `RayCast` node.
|
|
9
|
+
* Returns the node reference, a reactive `detected` boolean, the current collider signal,
|
|
10
|
+
* and a reactive `length` computed value.
|
|
11
|
+
*
|
|
12
|
+
* @param raycast An optional existing `NodeReference` to the RayCast node
|
|
13
|
+
* @returns An object with `ref`, `detected`, `collider`, and `length`
|
|
14
|
+
*
|
|
15
|
+
* @example
|
|
16
|
+
* ```tsx
|
|
17
|
+
* import { useRayCast } from 'dinix/hooks'
|
|
18
|
+
*
|
|
19
|
+
* function Peashooter() {
|
|
20
|
+
* const { ref, detected, collider } = useRayCast()
|
|
21
|
+
*
|
|
22
|
+
* useEffect(() => {
|
|
23
|
+
* if (detected()) {
|
|
24
|
+
* console.log('Hit:', collider())
|
|
25
|
+
* }
|
|
26
|
+
* })
|
|
27
|
+
*
|
|
28
|
+
* return (
|
|
29
|
+
* <ray-cast ref={ref} direction={[100, 0]} collidesWith={['zombie']} />
|
|
30
|
+
* )
|
|
31
|
+
* }
|
|
32
|
+
* ```
|
|
33
|
+
*/
|
|
34
|
+
export function useRayCast(raycast) {
|
|
35
|
+
declareDerivedHook('useRayCast');
|
|
36
|
+
const ref = usePartialNode(PrimaryNode.RayCast, raycast);
|
|
37
|
+
const [collider, setCollider] = useSignal(null);
|
|
38
|
+
useEvent(ref, 'colliderEntered', (c) => setCollider(c));
|
|
39
|
+
useEvent(ref, 'colliderExited', () => setCollider(null));
|
|
40
|
+
const detected = useComputed(() => collider() != null);
|
|
41
|
+
return {
|
|
42
|
+
ref,
|
|
43
|
+
detected,
|
|
44
|
+
collider,
|
|
45
|
+
};
|
|
46
|
+
}
|
|
47
|
+
//# sourceMappingURL=use-ray-cast.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"use-ray-cast.js","sourceRoot":"","sources":["../../../../src/hooks/deriveds/by-nodes/use-ray-cast.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAA;AAC/D,OAAO,EAAE,kBAAkB,EAAE,MAAM,kBAAkB,CAAA;AACrD,OAAO,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAA;AACnD,OAAO,EAAE,QAAQ,EAAE,MAAM,oBAAoB,CAAA;AAE7C,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAA;AAC/C,OAAO,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAA;AAEvD;;;;;;;;;;;;;;;;;;;;;;;;;;GA0BG;AACH,MAAM,UAAU,UAAU,CAAC,OAA4C;IACrE,kBAAkB,CAAC,YAAY,CAAC,CAAA;IAChC,MAAM,GAAG,GAAG,cAAc,CAAC,WAAW,CAAC,OAAO,EAAE,OAAO,CAAC,CAAA;IAExD,MAAM,CAAC,QAAQ,EAAE,WAAW,CAAC,GAAG,SAAS,CAAkB,IAAI,CAAC,CAAA;IAChE,QAAQ,CAAC,GAAG,EAAE,iBAAiB,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAA;IACvD,QAAQ,CAAC,GAAG,EAAE,gBAAgB,EAAE,GAAG,EAAE,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,CAAA;IAExD,MAAM,QAAQ,GAAG,WAAW,CAAC,GAAG,EAAE,CAAC,QAAQ,EAAE,IAAI,IAAI,CAAC,CAAA;IAEtD,OAAO;QACL,GAAG;QACH,QAAQ;QACR,QAAQ;KACT,CAAA;AACH,CAAC"}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { PrimaryNode } from '../../../nodes/index.js';
|
|
2
|
+
import type { NodeReference } from '../../use-node.js';
|
|
3
|
+
/**
|
|
4
|
+
* The **`useTimer`** derived hook provides a declarative API for the `Timer` node.
|
|
5
|
+
* Returns the node reference, reactive time/progress values, and control methods.
|
|
6
|
+
*
|
|
7
|
+
* @param timer An optional existing `NodeReference` to the Timer node
|
|
8
|
+
* @returns An object with `ref`, `time`, `progress`, `play`, `pause`, `stop`
|
|
9
|
+
*
|
|
10
|
+
* @example
|
|
11
|
+
* ```tsx
|
|
12
|
+
* import { useTimer } from 'dinix/hooks'
|
|
13
|
+
*
|
|
14
|
+
* function Cooldown() {
|
|
15
|
+
* const { ref, time, progress, play, pause, stop } = useTimer()
|
|
16
|
+
*
|
|
17
|
+
* return (
|
|
18
|
+
* <transform>
|
|
19
|
+
* <timer ref={ref} duration={3} autoPlay />
|
|
20
|
+
* <rectangle size={[100, 10]} fillColor={[1 - progress(), progress(), 0, 1]} />
|
|
21
|
+
* </transform>
|
|
22
|
+
* )
|
|
23
|
+
* }
|
|
24
|
+
* ```
|
|
25
|
+
*/
|
|
26
|
+
export declare function useTimer(timer?: NodeReference<PrimaryNode.Timer>): {
|
|
27
|
+
ref: NodeReference<PrimaryNode.Timer>;
|
|
28
|
+
time: import("../../../index.js").SignalGetter<number>;
|
|
29
|
+
progress: import("../../../index.js").SignalGetter<number>;
|
|
30
|
+
play: (from?: number) => void;
|
|
31
|
+
pause: () => void;
|
|
32
|
+
stop: () => void;
|
|
33
|
+
};
|
|
34
|
+
//# sourceMappingURL=use-timer.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"use-timer.d.ts","sourceRoot":"","sources":["../../../../src/hooks/deriveds/by-nodes/use-timer.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAA;AAIrD,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAA;AAItD;;;;;;;;;;;;;;;;;;;;;;GAsBG;AACH,wBAAgB,QAAQ,CAAC,KAAK,CAAC,EAAE,aAAa,CAAC,WAAW,CAAC,KAAK,CAAC;;;;;;;EAqBhE"}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import { PrimaryNode } from '../../../nodes/index.js';
|
|
2
|
+
import { declareDerivedHook } from '../../context.js';
|
|
3
|
+
import { useComputed } from '../../use-computed.js';
|
|
4
|
+
import { useEvent } from '../../use-event.js';
|
|
5
|
+
import { useSignal } from '../../use-signal.js';
|
|
6
|
+
import { usePartialNode } from '../use-partial-node.js';
|
|
7
|
+
/**
|
|
8
|
+
* The **`useTimer`** derived hook provides a declarative API for the `Timer` node.
|
|
9
|
+
* Returns the node reference, reactive time/progress values, and control methods.
|
|
10
|
+
*
|
|
11
|
+
* @param timer An optional existing `NodeReference` to the Timer node
|
|
12
|
+
* @returns An object with `ref`, `time`, `progress`, `play`, `pause`, `stop`
|
|
13
|
+
*
|
|
14
|
+
* @example
|
|
15
|
+
* ```tsx
|
|
16
|
+
* import { useTimer } from 'dinix/hooks'
|
|
17
|
+
*
|
|
18
|
+
* function Cooldown() {
|
|
19
|
+
* const { ref, time, progress, play, pause, stop } = useTimer()
|
|
20
|
+
*
|
|
21
|
+
* return (
|
|
22
|
+
* <transform>
|
|
23
|
+
* <timer ref={ref} duration={3} autoPlay />
|
|
24
|
+
* <rectangle size={[100, 10]} fillColor={[1 - progress(), progress(), 0, 1]} />
|
|
25
|
+
* </transform>
|
|
26
|
+
* )
|
|
27
|
+
* }
|
|
28
|
+
* ```
|
|
29
|
+
*/
|
|
30
|
+
export function useTimer(timer) {
|
|
31
|
+
declareDerivedHook('useTimer');
|
|
32
|
+
const ref = usePartialNode(PrimaryNode.Timer, timer);
|
|
33
|
+
const [time, setTime] = useSignal(0);
|
|
34
|
+
useEvent(ref, 'timeChanged', setTime);
|
|
35
|
+
const progress = useComputed(() => time() / (ref.signal()?.duration ?? time()));
|
|
36
|
+
const play = (...args) => ref.node.play(...args);
|
|
37
|
+
const pause = (...args) => ref.node.pause(...args);
|
|
38
|
+
const stop = (...args) => ref.node.stop(...args);
|
|
39
|
+
return {
|
|
40
|
+
ref,
|
|
41
|
+
time,
|
|
42
|
+
progress,
|
|
43
|
+
play,
|
|
44
|
+
pause,
|
|
45
|
+
stop,
|
|
46
|
+
};
|
|
47
|
+
}
|
|
48
|
+
//# sourceMappingURL=use-timer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"use-timer.js","sourceRoot":"","sources":["../../../../src/hooks/deriveds/by-nodes/use-timer.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAA;AACrD,OAAO,EAAE,kBAAkB,EAAE,MAAM,kBAAkB,CAAA;AACrD,OAAO,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAA;AACnD,OAAO,EAAE,QAAQ,EAAE,MAAM,oBAAoB,CAAA;AAE7C,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAA;AAC/C,OAAO,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAA;AAEvD;;;;;;;;;;;;;;;;;;;;;;GAsBG;AACH,MAAM,UAAU,QAAQ,CAAC,KAAwC;IAC/D,kBAAkB,CAAC,UAAU,CAAC,CAAA;IAC9B,MAAM,GAAG,GAAG,cAAc,CAAC,WAAW,CAAC,KAAK,EAAE,KAAK,CAAC,CAAA;IAEpD,MAAM,CAAC,IAAI,EAAE,OAAO,CAAC,GAAG,SAAS,CAAC,CAAC,CAAC,CAAA;IACpC,QAAQ,CAAC,GAAG,EAAE,aAAa,EAAE,OAAO,CAAC,CAAA;IAErC,MAAM,QAAQ,GAAG,WAAW,CAAC,GAAG,EAAE,CAAC,IAAI,EAAE,GAAG,CAAC,GAAG,CAAC,MAAM,EAAE,EAAE,QAAQ,IAAI,IAAI,EAAE,CAAC,CAAC,CAAA;IAE/E,MAAM,IAAI,GAAyB,CAAC,GAAG,IAAI,EAAE,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,CAAA;IACtE,MAAM,KAAK,GAA0B,CAAC,GAAG,IAAI,EAAE,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC,CAAA;IACzE,MAAM,IAAI,GAAyB,CAAC,GAAG,IAAI,EAAE,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,CAAA;IAEtE,OAAO;QACL,GAAG;QACH,IAAI;QACJ,QAAQ;QACR,IAAI;QACJ,KAAK;QACL,IAAI;KACL,CAAA;AACH,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/hooks/deriveds/index.ts"],"names":[],"mappings":"AAAA,cAAc,qBAAqB,CAAA;AAEnC,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAA;AACjD,OAAO,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAA;AACzC,OAAO,EAAE,OAAO,EAAE,MAAM,eAAe,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/hooks/deriveds/index.ts"],"names":[],"mappings":"AAAA,cAAc,qBAAqB,CAAA;AAEnC,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAA;AACjD,OAAO,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAA;AACzC,OAAO,EAAE,OAAO,EAAE,MAAM,eAAe,CAAA"}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import type { PrimaryNode } from '../../nodes/index.js';
|
|
2
|
+
import { type SignalGetter } from '../../reactivity/index.js';
|
|
3
|
+
import { type Events } from '../use-event.js';
|
|
4
|
+
import type { NodeReference } from '../use-node.js';
|
|
5
|
+
/**
|
|
6
|
+
* The **`useCondition`** derived hook creates a reactive boolean that toggles between `true` and `false`
|
|
7
|
+
* based on two opposing events on a node. Returns a `SignalGetter<boolean>` that can be used
|
|
8
|
+
* with `useComputed`, reactive props, or `useEffect`.
|
|
9
|
+
*
|
|
10
|
+
* @param node A `NodeReference` to the node that emits the events
|
|
11
|
+
* @param agreeEvent The event name that sets the condition to `true`
|
|
12
|
+
* @param disagreeEvent The event name that sets the condition to `false`
|
|
13
|
+
* @param defaultValue The initial value of the condition (defaults to `false`)
|
|
14
|
+
* @returns A `SignalGetter<boolean>` that reflects the current state
|
|
15
|
+
*
|
|
16
|
+
* @example
|
|
17
|
+
* ```tsx
|
|
18
|
+
* const clickable = useNode(PrimaryNode.Clickable)
|
|
19
|
+
* const hover = useCondition(clickable, 'mouseEntered', 'mouseExited')
|
|
20
|
+
*
|
|
21
|
+
* const brightness = useComputed(() => (hover() ? 1.1 : 1))
|
|
22
|
+
*
|
|
23
|
+
* return <sprite brightness={brightness} />
|
|
24
|
+
* ```
|
|
25
|
+
*
|
|
26
|
+
* @example
|
|
27
|
+
* ```tsx
|
|
28
|
+
* const raycast = useNode(PrimaryNode.RayCast)
|
|
29
|
+
* const isZombieDetected = useCondition(raycast, 'colliderEntered', 'colliderExited')
|
|
30
|
+
*
|
|
31
|
+
* useEffect(() => {
|
|
32
|
+
* anim.node.setNext(isZombieDetected() ? 'shoot' : 'idle')
|
|
33
|
+
* })
|
|
34
|
+
* ```
|
|
35
|
+
*/
|
|
36
|
+
export declare function useCondition<N extends PrimaryNode, A extends keyof Events<N>, D extends keyof Events<N>>(node: NodeReference<N>, agreeEvent: A, disagreeEvent: D, defaultValue?: boolean): SignalGetter<boolean>;
|
|
37
|
+
//# sourceMappingURL=use-condition.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"use-condition.d.ts","sourceRoot":"","sources":["../../../src/hooks/deriveds/use-condition.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAiB,WAAW,EAAE,MAAM,sBAAsB,CAAA;AACtE,OAAO,EAAE,KAAK,YAAY,EAAE,MAAM,2BAA2B,CAAA;AAE7D,OAAO,EAAY,KAAK,MAAM,EAAiB,MAAM,iBAAiB,CAAA;AACtE,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,gBAAgB,CAAA;AAGnD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA8BG;AACH,wBAAgB,YAAY,CAC1B,CAAC,SAAS,WAAW,EACrB,CAAC,SAAS,MAAM,MAAM,CAAC,CAAC,CAAC,EACzB,CAAC,SAAS,MAAM,MAAM,CAAC,CAAC,CAAC,EAEzB,IAAI,EAAE,aAAa,CAAC,CAAC,CAAC,EACtB,UAAU,EAAE,CAAC,EACb,aAAa,EAAE,CAAC,EAChB,YAAY,UAAQ,GACnB,YAAY,CAAC,OAAO,CAAC,CAavB"}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import {} from '../../reactivity/index.js';
|
|
2
|
+
import { declareDerivedHook } from '../context.js';
|
|
3
|
+
import { useEvent } from '../use-event.js';
|
|
4
|
+
import { useSignal } from '../use-signal.js';
|
|
5
|
+
/**
|
|
6
|
+
* The **`useCondition`** derived hook creates a reactive boolean that toggles between `true` and `false`
|
|
7
|
+
* based on two opposing events on a node. Returns a `SignalGetter<boolean>` that can be used
|
|
8
|
+
* with `useComputed`, reactive props, or `useEffect`.
|
|
9
|
+
*
|
|
10
|
+
* @param node A `NodeReference` to the node that emits the events
|
|
11
|
+
* @param agreeEvent The event name that sets the condition to `true`
|
|
12
|
+
* @param disagreeEvent The event name that sets the condition to `false`
|
|
13
|
+
* @param defaultValue The initial value of the condition (defaults to `false`)
|
|
14
|
+
* @returns A `SignalGetter<boolean>` that reflects the current state
|
|
15
|
+
*
|
|
16
|
+
* @example
|
|
17
|
+
* ```tsx
|
|
18
|
+
* const clickable = useNode(PrimaryNode.Clickable)
|
|
19
|
+
* const hover = useCondition(clickable, 'mouseEntered', 'mouseExited')
|
|
20
|
+
*
|
|
21
|
+
* const brightness = useComputed(() => (hover() ? 1.1 : 1))
|
|
22
|
+
*
|
|
23
|
+
* return <sprite brightness={brightness} />
|
|
24
|
+
* ```
|
|
25
|
+
*
|
|
26
|
+
* @example
|
|
27
|
+
* ```tsx
|
|
28
|
+
* const raycast = useNode(PrimaryNode.RayCast)
|
|
29
|
+
* const isZombieDetected = useCondition(raycast, 'colliderEntered', 'colliderExited')
|
|
30
|
+
*
|
|
31
|
+
* useEffect(() => {
|
|
32
|
+
* anim.node.setNext(isZombieDetected() ? 'shoot' : 'idle')
|
|
33
|
+
* })
|
|
34
|
+
* ```
|
|
35
|
+
*/
|
|
36
|
+
export function useCondition(node, agreeEvent, disagreeEvent, defaultValue = false) {
|
|
37
|
+
declareDerivedHook('useCondition');
|
|
38
|
+
const [condition, setCondition] = useSignal(defaultValue);
|
|
39
|
+
useEvent(node, agreeEvent, (() => {
|
|
40
|
+
setCondition(true);
|
|
41
|
+
}));
|
|
42
|
+
useEvent(node, disagreeEvent, (() => {
|
|
43
|
+
setCondition(false);
|
|
44
|
+
}));
|
|
45
|
+
return condition;
|
|
46
|
+
}
|
|
47
|
+
//# sourceMappingURL=use-condition.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"use-condition.js","sourceRoot":"","sources":["../../../src/hooks/deriveds/use-condition.ts"],"names":[],"mappings":"AACA,OAAO,EAAqB,MAAM,2BAA2B,CAAA;AAC7D,OAAO,EAAE,kBAAkB,EAAE,MAAM,eAAe,CAAA;AAClD,OAAO,EAAE,QAAQ,EAA8B,MAAM,iBAAiB,CAAA;AAEtE,OAAO,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAA;AAE5C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA8BG;AACH,MAAM,UAAU,YAAY,CAK1B,IAAsB,EACtB,UAAa,EACb,aAAgB,EAChB,YAAY,GAAG,KAAK;IAEpB,kBAAkB,CAAC,cAAc,CAAC,CAAA;IAElC,MAAM,CAAC,SAAS,EAAE,YAAY,CAAC,GAAG,SAAS,CAAC,YAAY,CAAC,CAAA;IAEzD,QAAQ,CAAC,IAAI,EAAE,UAAU,EAAE,CAAC,GAAG,EAAE;QAC/B,YAAY,CAAC,IAAI,CAAC,CAAA;IACpB,CAAC,CAAkC,CAAC,CAAA;IACpC,QAAQ,CAAC,IAAI,EAAE,aAAa,EAAE,CAAC,GAAG,EAAE;QAClC,YAAY,CAAC,KAAK,CAAC,CAAA;IACrB,CAAC,CAAkC,CAAC,CAAA;IAEpC,OAAO,SAAS,CAAA;AAClB,CAAC"}
|