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.
Files changed (501) hide show
  1. package/dist/animation/easing.d.ts +29 -0
  2. package/dist/animation/easing.d.ts.map +1 -0
  3. package/dist/animation/easing.js +50 -0
  4. package/dist/animation/easing.js.map +1 -0
  5. package/dist/animation/index.d.ts +7 -0
  6. package/dist/animation/index.d.ts.map +1 -0
  7. package/dist/animation/index.js +7 -0
  8. package/dist/animation/index.js.map +1 -0
  9. package/dist/animation/multiple.d.ts +26 -0
  10. package/dist/animation/multiple.d.ts.map +1 -0
  11. package/dist/animation/multiple.js +27 -0
  12. package/dist/animation/multiple.js.map +1 -0
  13. package/dist/animation/properties.d.ts +30 -0
  14. package/dist/animation/properties.d.ts.map +1 -0
  15. package/dist/animation/properties.js +32 -0
  16. package/dist/animation/properties.js.map +1 -0
  17. package/dist/animation/sequences.d.ts +30 -0
  18. package/dist/animation/sequences.d.ts.map +1 -0
  19. package/dist/animation/sequences.js +50 -0
  20. package/dist/animation/sequences.js.map +1 -0
  21. package/dist/animation/sprite-sheet.d.ts +81 -0
  22. package/dist/animation/sprite-sheet.d.ts.map +1 -0
  23. package/dist/animation/sprite-sheet.js +103 -0
  24. package/dist/animation/sprite-sheet.js.map +1 -0
  25. package/dist/animation/tween.d.ts +78 -0
  26. package/dist/animation/tween.d.ts.map +1 -0
  27. package/dist/animation/tween.js +103 -0
  28. package/dist/animation/tween.js.map +1 -0
  29. package/dist/assets/index.d.ts +6 -0
  30. package/dist/assets/index.d.ts.map +1 -0
  31. package/dist/assets/index.js +5 -0
  32. package/dist/assets/index.js.map +1 -0
  33. package/dist/assets/load-sound.d.ts +17 -0
  34. package/dist/assets/load-sound.d.ts.map +1 -0
  35. package/dist/assets/load-sound.js +35 -0
  36. package/dist/assets/load-sound.js.map +1 -0
  37. package/dist/assets/load-texture.d.ts +12 -0
  38. package/dist/assets/load-texture.d.ts.map +1 -0
  39. package/dist/assets/load-texture.js +40 -0
  40. package/dist/assets/load-texture.js.map +1 -0
  41. package/dist/assets/loader.d.ts +59 -0
  42. package/dist/assets/loader.d.ts.map +1 -0
  43. package/dist/assets/loader.js +65 -0
  44. package/dist/assets/loader.js.map +1 -0
  45. package/dist/assets/texture.d.ts +36 -0
  46. package/dist/assets/texture.d.ts.map +1 -0
  47. package/dist/assets/texture.js +49 -0
  48. package/dist/assets/texture.js.map +1 -0
  49. package/dist/audio/audio-context.d.ts +14 -0
  50. package/dist/audio/audio-context.d.ts.map +1 -0
  51. package/dist/audio/audio-context.js +20 -0
  52. package/dist/audio/audio-context.js.map +1 -0
  53. package/dist/audio/index.d.ts +2 -0
  54. package/dist/audio/index.d.ts.map +1 -0
  55. package/dist/audio/index.js +2 -0
  56. package/dist/audio/index.js.map +1 -0
  57. package/dist/collision/broadphase/spatial-hash.d.ts +32 -0
  58. package/dist/collision/broadphase/spatial-hash.d.ts.map +1 -0
  59. package/dist/collision/broadphase/spatial-hash.js +87 -0
  60. package/dist/collision/broadphase/spatial-hash.js.map +1 -0
  61. package/dist/collision/collision-system.d.ts +52 -0
  62. package/dist/collision/collision-system.d.ts.map +1 -0
  63. package/dist/collision/collision-system.js +278 -0
  64. package/dist/collision/collision-system.js.map +1 -0
  65. package/dist/collision/events/collision-emitter.d.ts +38 -0
  66. package/dist/collision/events/collision-emitter.d.ts.map +1 -0
  67. package/dist/collision/events/collision-emitter.js +47 -0
  68. package/dist/collision/events/collision-emitter.js.map +1 -0
  69. package/dist/collision/index.d.ts +13 -0
  70. package/dist/collision/index.d.ts.map +1 -0
  71. package/dist/collision/index.js +11 -0
  72. package/dist/collision/index.js.map +1 -0
  73. package/dist/collision/narrowphase/detector.d.ts +26 -0
  74. package/dist/collision/narrowphase/detector.d.ts.map +1 -0
  75. package/dist/collision/narrowphase/detector.js +70 -0
  76. package/dist/collision/narrowphase/detector.js.map +1 -0
  77. package/dist/collision/narrowphase/shapes.d.ts +91 -0
  78. package/dist/collision/narrowphase/shapes.d.ts.map +1 -0
  79. package/dist/collision/narrowphase/shapes.js +52 -0
  80. package/dist/collision/narrowphase/shapes.js.map +1 -0
  81. package/dist/collision/physics/physics-body.d.ts +38 -0
  82. package/dist/collision/physics/physics-body.d.ts.map +1 -0
  83. package/dist/collision/physics/physics-body.js +53 -0
  84. package/dist/collision/physics/physics-body.js.map +1 -0
  85. package/dist/collision/physics/physics-system.d.ts +23 -0
  86. package/dist/collision/physics/physics-system.d.ts.map +1 -0
  87. package/dist/collision/physics/physics-system.js +86 -0
  88. package/dist/collision/physics/physics-system.js.map +1 -0
  89. package/dist/collision/physics/resolver.d.ts +16 -0
  90. package/dist/collision/physics/resolver.d.ts.map +1 -0
  91. package/dist/collision/physics/resolver.js +91 -0
  92. package/dist/collision/physics/resolver.js.map +1 -0
  93. package/dist/collision/types.d.ts +22 -0
  94. package/dist/collision/types.d.ts.map +1 -0
  95. package/dist/collision/types.js +2 -0
  96. package/dist/collision/types.js.map +1 -0
  97. package/dist/core/game-config.d.ts +34 -0
  98. package/dist/core/game-config.d.ts.map +1 -0
  99. package/dist/core/game-config.js +31 -0
  100. package/dist/core/game-config.js.map +1 -0
  101. package/dist/core/game.d.ts +86 -0
  102. package/dist/core/game.d.ts.map +1 -0
  103. package/dist/core/game.js +166 -0
  104. package/dist/core/game.js.map +1 -0
  105. package/dist/core/index.d.ts +6 -0
  106. package/dist/core/index.d.ts.map +1 -0
  107. package/dist/core/index.js +6 -0
  108. package/dist/core/index.js.map +1 -0
  109. package/dist/core/scene-manager.d.ts +28 -0
  110. package/dist/core/scene-manager.d.ts.map +1 -0
  111. package/dist/core/scene-manager.js +65 -0
  112. package/dist/core/scene-manager.js.map +1 -0
  113. package/dist/core/scene.d.ts +43 -0
  114. package/dist/core/scene.d.ts.map +1 -0
  115. package/dist/core/scene.js +48 -0
  116. package/dist/core/scene.js.map +1 -0
  117. package/dist/core/theme.d.ts +63 -0
  118. package/dist/core/theme.d.ts.map +1 -0
  119. package/dist/core/theme.js +59 -0
  120. package/dist/core/theme.js.map +1 -0
  121. package/dist/errors/animation.d.ts +24 -0
  122. package/dist/errors/animation.d.ts.map +1 -0
  123. package/dist/errors/animation.js +29 -0
  124. package/dist/errors/animation.js.map +1 -0
  125. package/dist/errors/assets.d.ts +34 -0
  126. package/dist/errors/assets.d.ts.map +1 -0
  127. package/dist/errors/assets.js +41 -0
  128. package/dist/errors/assets.js.map +1 -0
  129. package/dist/errors/base.d.ts +12 -0
  130. package/dist/errors/base.d.ts.map +1 -0
  131. package/dist/errors/base.js +15 -0
  132. package/dist/errors/base.js.map +1 -0
  133. package/dist/errors/env.d.ts +24 -0
  134. package/dist/errors/env.d.ts.map +1 -0
  135. package/dist/errors/env.js +29 -0
  136. package/dist/errors/env.js.map +1 -0
  137. package/dist/errors/hook.d.ts +46 -0
  138. package/dist/errors/hook.d.ts.map +1 -0
  139. package/dist/errors/hook.js +55 -0
  140. package/dist/errors/hook.js.map +1 -0
  141. package/dist/errors/index.d.ts +11 -0
  142. package/dist/errors/index.d.ts.map +1 -0
  143. package/dist/errors/index.js +11 -0
  144. package/dist/errors/index.js.map +1 -0
  145. package/dist/errors/jsx.d.ts +26 -0
  146. package/dist/errors/jsx.d.ts.map +1 -0
  147. package/dist/errors/jsx.js +45 -0
  148. package/dist/errors/jsx.js.map +1 -0
  149. package/dist/errors/lifecycle.d.ts +35 -0
  150. package/dist/errors/lifecycle.d.ts.map +1 -0
  151. package/dist/errors/lifecycle.js +42 -0
  152. package/dist/errors/lifecycle.js.map +1 -0
  153. package/dist/errors/math.d.ts +24 -0
  154. package/dist/errors/math.d.ts.map +1 -0
  155. package/dist/errors/math.js +34 -0
  156. package/dist/errors/math.js.map +1 -0
  157. package/dist/errors/node.d.ts +68 -0
  158. package/dist/errors/node.d.ts.map +1 -0
  159. package/dist/errors/node.js +87 -0
  160. package/dist/errors/node.js.map +1 -0
  161. package/dist/errors/scene.d.ts +35 -0
  162. package/dist/errors/scene.d.ts.map +1 -0
  163. package/dist/errors/scene.js +42 -0
  164. package/dist/errors/scene.js.map +1 -0
  165. package/dist/events/event.d.ts +106 -0
  166. package/dist/events/event.d.ts.map +1 -0
  167. package/dist/events/event.js +125 -0
  168. package/dist/events/event.js.map +1 -0
  169. package/dist/events/index.d.ts +2 -0
  170. package/dist/events/index.d.ts.map +1 -0
  171. package/dist/events/index.js +2 -0
  172. package/dist/events/index.js.map +1 -0
  173. package/dist/events/types.d.ts +20 -0
  174. package/dist/events/types.d.ts.map +1 -0
  175. package/dist/events/types.js +2 -0
  176. package/dist/events/types.js.map +1 -0
  177. package/dist/hooks/context.d.ts +15 -0
  178. package/dist/hooks/context.d.ts.map +1 -0
  179. package/dist/hooks/context.js +26 -0
  180. package/dist/hooks/context.js.map +1 -0
  181. package/dist/hooks/deriveds/by-nodes/index.d.ts +7 -0
  182. package/dist/hooks/deriveds/by-nodes/index.d.ts.map +1 -0
  183. package/dist/hooks/deriveds/by-nodes/index.js +7 -0
  184. package/dist/hooks/deriveds/by-nodes/index.js.map +1 -0
  185. package/dist/hooks/deriveds/by-nodes/use-animation.d.ts +44 -0
  186. package/dist/hooks/deriveds/by-nodes/use-animation.d.ts.map +1 -0
  187. package/dist/hooks/deriveds/by-nodes/use-animation.js +61 -0
  188. package/dist/hooks/deriveds/by-nodes/use-animation.js.map +1 -0
  189. package/dist/hooks/deriveds/by-nodes/use-audio.d.ts +33 -0
  190. package/dist/hooks/deriveds/by-nodes/use-audio.d.ts.map +1 -0
  191. package/dist/hooks/deriveds/by-nodes/use-audio.js +43 -0
  192. package/dist/hooks/deriveds/by-nodes/use-audio.js.map +1 -0
  193. package/dist/hooks/deriveds/by-nodes/use-clickable.d.ts +32 -0
  194. package/dist/hooks/deriveds/by-nodes/use-clickable.d.ts.map +1 -0
  195. package/dist/hooks/deriveds/by-nodes/use-clickable.js +43 -0
  196. package/dist/hooks/deriveds/by-nodes/use-clickable.js.map +1 -0
  197. package/dist/hooks/deriveds/by-nodes/use-collider.d.ts +35 -0
  198. package/dist/hooks/deriveds/by-nodes/use-collider.d.ts.map +1 -0
  199. package/dist/hooks/deriveds/by-nodes/use-collider.js +55 -0
  200. package/dist/hooks/deriveds/by-nodes/use-collider.js.map +1 -0
  201. package/dist/hooks/deriveds/by-nodes/use-ray-cast.d.ts +35 -0
  202. package/dist/hooks/deriveds/by-nodes/use-ray-cast.d.ts.map +1 -0
  203. package/dist/hooks/deriveds/by-nodes/use-ray-cast.js +47 -0
  204. package/dist/hooks/deriveds/by-nodes/use-ray-cast.js.map +1 -0
  205. package/dist/hooks/deriveds/by-nodes/use-timer.d.ts +34 -0
  206. package/dist/hooks/deriveds/by-nodes/use-timer.d.ts.map +1 -0
  207. package/dist/hooks/deriveds/by-nodes/use-timer.js +48 -0
  208. package/dist/hooks/deriveds/by-nodes/use-timer.js.map +1 -0
  209. package/dist/hooks/deriveds/index.d.ts +5 -0
  210. package/dist/hooks/deriveds/index.d.ts.map +1 -0
  211. package/dist/hooks/deriveds/index.js +5 -0
  212. package/dist/hooks/deriveds/index.js.map +1 -0
  213. package/dist/hooks/deriveds/use-condition.d.ts +37 -0
  214. package/dist/hooks/deriveds/use-condition.d.ts.map +1 -0
  215. package/dist/hooks/deriveds/use-condition.js +47 -0
  216. package/dist/hooks/deriveds/use-condition.js.map +1 -0
  217. package/dist/hooks/deriveds/use-match.d.ts +26 -0
  218. package/dist/hooks/deriveds/use-match.d.ts.map +1 -0
  219. package/dist/hooks/deriveds/use-match.js +38 -0
  220. package/dist/hooks/deriveds/use-match.js.map +1 -0
  221. package/dist/hooks/deriveds/use-partial-node.d.ts +22 -0
  222. package/dist/hooks/deriveds/use-partial-node.d.ts.map +1 -0
  223. package/dist/hooks/deriveds/use-partial-node.js +25 -0
  224. package/dist/hooks/deriveds/use-partial-node.js.map +1 -0
  225. package/dist/hooks/deriveds/use-when.d.ts +28 -0
  226. package/dist/hooks/deriveds/use-when.d.ts.map +1 -0
  227. package/dist/hooks/deriveds/use-when.js +35 -0
  228. package/dist/hooks/deriveds/use-when.js.map +1 -0
  229. package/dist/hooks/index.d.ts +16 -0
  230. package/dist/hooks/index.d.ts.map +1 -0
  231. package/dist/hooks/index.js +16 -0
  232. package/dist/hooks/index.js.map +1 -0
  233. package/dist/hooks/use-child.d.ts +24 -0
  234. package/dist/hooks/use-child.d.ts.map +1 -0
  235. package/dist/hooks/use-child.js +37 -0
  236. package/dist/hooks/use-child.js.map +1 -0
  237. package/dist/hooks/use-computed.d.ts +28 -0
  238. package/dist/hooks/use-computed.d.ts.map +1 -0
  239. package/dist/hooks/use-computed.js +41 -0
  240. package/dist/hooks/use-computed.js.map +1 -0
  241. package/dist/hooks/use-context.d.ts +58 -0
  242. package/dist/hooks/use-context.d.ts.map +1 -0
  243. package/dist/hooks/use-context.js +77 -0
  244. package/dist/hooks/use-context.js.map +1 -0
  245. package/dist/hooks/use-effect.d.ts +24 -0
  246. package/dist/hooks/use-effect.d.ts.map +1 -0
  247. package/dist/hooks/use-effect.js +63 -0
  248. package/dist/hooks/use-effect.js.map +1 -0
  249. package/dist/hooks/use-event.d.ts +29 -0
  250. package/dist/hooks/use-event.d.ts.map +1 -0
  251. package/dist/hooks/use-event.js +30 -0
  252. package/dist/hooks/use-event.js.map +1 -0
  253. package/dist/hooks/use-game.d.ts +17 -0
  254. package/dist/hooks/use-game.d.ts.map +1 -0
  255. package/dist/hooks/use-game.js +35 -0
  256. package/dist/hooks/use-game.js.map +1 -0
  257. package/dist/hooks/use-mount.d.ts +21 -0
  258. package/dist/hooks/use-mount.d.ts.map +1 -0
  259. package/dist/hooks/use-mount.js +33 -0
  260. package/dist/hooks/use-mount.js.map +1 -0
  261. package/dist/hooks/use-node.d.ts +42 -0
  262. package/dist/hooks/use-node.d.ts.map +1 -0
  263. package/dist/hooks/use-node.js +63 -0
  264. package/dist/hooks/use-node.js.map +1 -0
  265. package/dist/hooks/use-ref.d.ts +27 -0
  266. package/dist/hooks/use-ref.d.ts.map +1 -0
  267. package/dist/hooks/use-ref.js +33 -0
  268. package/dist/hooks/use-ref.js.map +1 -0
  269. package/dist/hooks/use-script.d.ts +33 -0
  270. package/dist/hooks/use-script.d.ts.map +1 -0
  271. package/dist/hooks/use-script.js +40 -0
  272. package/dist/hooks/use-script.js.map +1 -0
  273. package/dist/hooks/use-signal.d.ts +25 -0
  274. package/dist/hooks/use-signal.d.ts.map +1 -0
  275. package/dist/hooks/use-signal.js +36 -0
  276. package/dist/hooks/use-signal.js.map +1 -0
  277. package/dist/hooks/use-spawn.d.ts +27 -0
  278. package/dist/hooks/use-spawn.d.ts.map +1 -0
  279. package/dist/hooks/use-spawn.js +39 -0
  280. package/dist/hooks/use-spawn.js.map +1 -0
  281. package/dist/hooks/use-trigger.d.ts +51 -0
  282. package/dist/hooks/use-trigger.d.ts.map +1 -0
  283. package/dist/hooks/use-trigger.js +68 -0
  284. package/dist/hooks/use-trigger.js.map +1 -0
  285. package/dist/index.d.ts +11 -0
  286. package/dist/index.d.ts.map +1 -0
  287. package/dist/index.js +11 -0
  288. package/dist/index.js.map +1 -0
  289. package/dist/input/input.d.ts +46 -0
  290. package/dist/input/input.d.ts.map +1 -0
  291. package/dist/input/input.js +159 -0
  292. package/dist/input/input.js.map +1 -0
  293. package/dist/jsx/components/fragment.d.ts +3 -0
  294. package/dist/jsx/components/fragment.d.ts.map +1 -0
  295. package/dist/jsx/components/fragment.js +7 -0
  296. package/dist/jsx/components/fragment.js.map +1 -0
  297. package/dist/jsx/components/game.d.ts +21 -0
  298. package/dist/jsx/components/game.d.ts.map +1 -0
  299. package/dist/jsx/components/game.js +17 -0
  300. package/dist/jsx/components/game.js.map +1 -0
  301. package/dist/jsx/components/index.d.ts +5 -0
  302. package/dist/jsx/components/index.d.ts.map +1 -0
  303. package/dist/jsx/components/index.js +5 -0
  304. package/dist/jsx/components/index.js.map +1 -0
  305. package/dist/jsx/components/list.d.ts +88 -0
  306. package/dist/jsx/components/list.d.ts.map +1 -0
  307. package/dist/jsx/components/list.js +93 -0
  308. package/dist/jsx/components/list.js.map +1 -0
  309. package/dist/jsx/components/scene.d.ts +40 -0
  310. package/dist/jsx/components/scene.d.ts.map +1 -0
  311. package/dist/jsx/components/scene.js +20 -0
  312. package/dist/jsx/components/scene.js.map +1 -0
  313. package/dist/jsx/index.d.ts +5 -0
  314. package/dist/jsx/index.d.ts.map +1 -0
  315. package/dist/jsx/index.js +5 -0
  316. package/dist/jsx/index.js.map +1 -0
  317. package/dist/jsx/jsx.d.ts +3 -0
  318. package/dist/jsx/jsx.d.ts.map +1 -0
  319. package/dist/jsx/jsx.js +4 -0
  320. package/dist/jsx/jsx.js.map +1 -0
  321. package/dist/jsx/render/game.d.ts +41 -0
  322. package/dist/jsx/render/game.d.ts.map +1 -0
  323. package/dist/jsx/render/game.js +86 -0
  324. package/dist/jsx/render/game.js.map +1 -0
  325. package/dist/jsx/render/index.d.ts +3 -0
  326. package/dist/jsx/render/index.d.ts.map +1 -0
  327. package/dist/jsx/render/index.js +3 -0
  328. package/dist/jsx/render/index.js.map +1 -0
  329. package/dist/jsx/render/to-nodes.d.ts +10 -0
  330. package/dist/jsx/render/to-nodes.d.ts.map +1 -0
  331. package/dist/jsx/render/to-nodes.js +52 -0
  332. package/dist/jsx/render/to-nodes.js.map +1 -0
  333. package/dist/jsx/render/types/class-component.d.ts +4 -0
  334. package/dist/jsx/render/types/class-component.d.ts.map +1 -0
  335. package/dist/jsx/render/types/class-component.js +8 -0
  336. package/dist/jsx/render/types/class-component.js.map +1 -0
  337. package/dist/jsx/render/types/func-components.d.ts +4 -0
  338. package/dist/jsx/render/types/func-components.d.ts.map +1 -0
  339. package/dist/jsx/render/types/func-components.js +8 -0
  340. package/dist/jsx/render/types/func-components.js.map +1 -0
  341. package/dist/jsx/render/types/instrinsic-elements.d.ts +6 -0
  342. package/dist/jsx/render/types/instrinsic-elements.d.ts.map +1 -0
  343. package/dist/jsx/render/types/instrinsic-elements.js +41 -0
  344. package/dist/jsx/render/types/instrinsic-elements.js.map +1 -0
  345. package/dist/jsx/types.d.ts +41 -0
  346. package/dist/jsx/types.d.ts.map +1 -0
  347. package/dist/jsx/types.js +2 -0
  348. package/dist/jsx/types.js.map +1 -0
  349. package/dist/jsx/utils.d.ts +4 -0
  350. package/dist/jsx/utils.d.ts.map +1 -0
  351. package/dist/jsx/utils.js +15 -0
  352. package/dist/jsx/utils.js.map +1 -0
  353. package/dist/jsx-runtime.d.ts +6 -0
  354. package/dist/jsx-runtime.d.ts.map +1 -0
  355. package/dist/jsx-runtime.js +6 -0
  356. package/dist/jsx-runtime.js.map +1 -0
  357. package/dist/math/index.d.ts +3 -0
  358. package/dist/math/index.d.ts.map +1 -0
  359. package/dist/math/index.js +2 -0
  360. package/dist/math/index.js.map +1 -0
  361. package/dist/math/types.d.ts +13 -0
  362. package/dist/math/types.d.ts.map +1 -0
  363. package/dist/math/types.js +2 -0
  364. package/dist/math/types.js.map +1 -0
  365. package/dist/math/vector2.d.ts +145 -0
  366. package/dist/math/vector2.d.ts.map +1 -0
  367. package/dist/math/vector2.js +164 -0
  368. package/dist/math/vector2.js.map +1 -0
  369. package/dist/nodes/_node.d.ts +283 -0
  370. package/dist/nodes/_node.d.ts.map +1 -0
  371. package/dist/nodes/_node.js +371 -0
  372. package/dist/nodes/_node.js.map +1 -0
  373. package/dist/nodes/animation-player.d.ts +208 -0
  374. package/dist/nodes/animation-player.d.ts.map +1 -0
  375. package/dist/nodes/animation-player.js +249 -0
  376. package/dist/nodes/animation-player.js.map +1 -0
  377. package/dist/nodes/audio-player.d.ts +128 -0
  378. package/dist/nodes/audio-player.d.ts.map +1 -0
  379. package/dist/nodes/audio-player.js +173 -0
  380. package/dist/nodes/audio-player.js.map +1 -0
  381. package/dist/nodes/group.d.ts +55 -0
  382. package/dist/nodes/group.d.ts.map +1 -0
  383. package/dist/nodes/group.js +54 -0
  384. package/dist/nodes/group.js.map +1 -0
  385. package/dist/nodes/index.d.ts +8 -0
  386. package/dist/nodes/index.d.ts.map +1 -0
  387. package/dist/nodes/index.js +7 -0
  388. package/dist/nodes/index.js.map +1 -0
  389. package/dist/nodes/lib/enum.d.ts +42 -0
  390. package/dist/nodes/lib/enum.d.ts.map +1 -0
  391. package/dist/nodes/lib/enum.js +43 -0
  392. package/dist/nodes/lib/enum.js.map +1 -0
  393. package/dist/nodes/lib/index.d.ts +5 -0
  394. package/dist/nodes/lib/index.d.ts.map +1 -0
  395. package/dist/nodes/lib/index.js +5 -0
  396. package/dist/nodes/lib/index.js.map +1 -0
  397. package/dist/nodes/lib/registry.d.ts +43 -0
  398. package/dist/nodes/lib/registry.d.ts.map +1 -0
  399. package/dist/nodes/lib/registry.js +46 -0
  400. package/dist/nodes/lib/registry.js.map +1 -0
  401. package/dist/nodes/lib/types.d.ts +89 -0
  402. package/dist/nodes/lib/types.d.ts.map +1 -0
  403. package/dist/nodes/lib/types.js +2 -0
  404. package/dist/nodes/lib/types.js.map +1 -0
  405. package/dist/nodes/lib/utils.d.ts +35 -0
  406. package/dist/nodes/lib/utils.d.ts.map +1 -0
  407. package/dist/nodes/lib/utils.js +58 -0
  408. package/dist/nodes/lib/utils.js.map +1 -0
  409. package/dist/nodes/node2d/_node2d.d.ts +59 -0
  410. package/dist/nodes/node2d/_node2d.d.ts.map +1 -0
  411. package/dist/nodes/node2d/_node2d.js +57 -0
  412. package/dist/nodes/node2d/_node2d.js.map +1 -0
  413. package/dist/nodes/node2d/camera.d.ts +64 -0
  414. package/dist/nodes/node2d/camera.d.ts.map +1 -0
  415. package/dist/nodes/node2d/camera.js +72 -0
  416. package/dist/nodes/node2d/camera.js.map +1 -0
  417. package/dist/nodes/node2d/clickable.d.ts +96 -0
  418. package/dist/nodes/node2d/clickable.d.ts.map +1 -0
  419. package/dist/nodes/node2d/clickable.js +117 -0
  420. package/dist/nodes/node2d/clickable.js.map +1 -0
  421. package/dist/nodes/node2d/collider.d.ts +96 -0
  422. package/dist/nodes/node2d/collider.d.ts.map +1 -0
  423. package/dist/nodes/node2d/collider.js +116 -0
  424. package/dist/nodes/node2d/collider.js.map +1 -0
  425. package/dist/nodes/node2d/index.d.ts +12 -0
  426. package/dist/nodes/node2d/index.d.ts.map +1 -0
  427. package/dist/nodes/node2d/index.js +11 -0
  428. package/dist/nodes/node2d/index.js.map +1 -0
  429. package/dist/nodes/node2d/lib/index.d.ts +2 -0
  430. package/dist/nodes/node2d/lib/index.d.ts.map +1 -0
  431. package/dist/nodes/node2d/lib/index.js +2 -0
  432. package/dist/nodes/node2d/lib/index.js.map +1 -0
  433. package/dist/nodes/node2d/lib/utils.d.ts +4 -0
  434. package/dist/nodes/node2d/lib/utils.d.ts.map +1 -0
  435. package/dist/nodes/node2d/lib/utils.js +14 -0
  436. package/dist/nodes/node2d/lib/utils.js.map +1 -0
  437. package/dist/nodes/node2d/ray-cast.d.ts +115 -0
  438. package/dist/nodes/node2d/ray-cast.d.ts.map +1 -0
  439. package/dist/nodes/node2d/ray-cast.js +129 -0
  440. package/dist/nodes/node2d/ray-cast.js.map +1 -0
  441. package/dist/nodes/node2d/rectangle.d.ts +87 -0
  442. package/dist/nodes/node2d/rectangle.d.ts.map +1 -0
  443. package/dist/nodes/node2d/rectangle.js +60 -0
  444. package/dist/nodes/node2d/rectangle.js.map +1 -0
  445. package/dist/nodes/node2d/rigid-body.d.ts +65 -0
  446. package/dist/nodes/node2d/rigid-body.d.ts.map +1 -0
  447. package/dist/nodes/node2d/rigid-body.js +56 -0
  448. package/dist/nodes/node2d/rigid-body.js.map +1 -0
  449. package/dist/nodes/node2d/sprite.d.ts +285 -0
  450. package/dist/nodes/node2d/sprite.d.ts.map +1 -0
  451. package/dist/nodes/node2d/sprite.js +226 -0
  452. package/dist/nodes/node2d/sprite.js.map +1 -0
  453. package/dist/nodes/node2d/text.d.ts +62 -0
  454. package/dist/nodes/node2d/text.d.ts.map +1 -0
  455. package/dist/nodes/node2d/text.js +52 -0
  456. package/dist/nodes/node2d/text.js.map +1 -0
  457. package/dist/nodes/node2d/transform.d.ts +32 -0
  458. package/dist/nodes/node2d/transform.d.ts.map +1 -0
  459. package/dist/nodes/node2d/transform.js +30 -0
  460. package/dist/nodes/node2d/transform.js.map +1 -0
  461. package/dist/nodes/timer.d.ts +107 -0
  462. package/dist/nodes/timer.d.ts.map +1 -0
  463. package/dist/nodes/timer.js +108 -0
  464. package/dist/nodes/timer.js.map +1 -0
  465. package/dist/reactivity/index.d.ts +5 -0
  466. package/dist/reactivity/index.d.ts.map +1 -0
  467. package/dist/reactivity/index.js +5 -0
  468. package/dist/reactivity/index.js.map +1 -0
  469. package/dist/reactivity/reactive.d.ts +4 -0
  470. package/dist/reactivity/reactive.d.ts.map +1 -0
  471. package/dist/reactivity/reactive.js +50 -0
  472. package/dist/reactivity/reactive.js.map +1 -0
  473. package/dist/reactivity/register.d.ts +7 -0
  474. package/dist/reactivity/register.d.ts.map +1 -0
  475. package/dist/reactivity/register.js +18 -0
  476. package/dist/reactivity/register.js.map +1 -0
  477. package/dist/reactivity/signal.d.ts +126 -0
  478. package/dist/reactivity/signal.d.ts.map +1 -0
  479. package/dist/reactivity/signal.js +152 -0
  480. package/dist/reactivity/signal.js.map +1 -0
  481. package/dist/reactivity/types.d.ts +31 -0
  482. package/dist/reactivity/types.d.ts.map +1 -0
  483. package/dist/reactivity/types.js +2 -0
  484. package/dist/reactivity/types.js.map +1 -0
  485. package/dist/scripts/index.d.ts +2 -0
  486. package/dist/scripts/index.d.ts.map +1 -0
  487. package/dist/scripts/index.js +2 -0
  488. package/dist/scripts/index.js.map +1 -0
  489. package/dist/scripts/script.d.ts +80 -0
  490. package/dist/scripts/script.d.ts.map +1 -0
  491. package/dist/scripts/script.js +75 -0
  492. package/dist/scripts/script.js.map +1 -0
  493. package/dist/utils/dpr.d.ts +2 -0
  494. package/dist/utils/dpr.d.ts.map +1 -0
  495. package/dist/utils/dpr.js +14 -0
  496. package/dist/utils/dpr.js.map +1 -0
  497. package/dist/utils/ternaries.d.ts +6 -0
  498. package/dist/utils/ternaries.d.ts.map +1 -0
  499. package/dist/utils/ternaries.js +17 -0
  500. package/dist/utils/ternaries.js.map +1 -0
  501. 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,5 @@
1
+ export * from './by-nodes/index.js';
2
+ export { useCondition } from './use-condition.js';
3
+ export { useMatch } from './use-match.js';
4
+ export { useWhen } from './use-when.js';
5
+ //# sourceMappingURL=index.d.ts.map
@@ -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,5 @@
1
+ export * from './by-nodes/index.js';
2
+ export { useCondition } from './use-condition.js';
3
+ export { useMatch } from './use-match.js';
4
+ export { useWhen } from './use-when.js';
5
+ //# sourceMappingURL=index.js.map
@@ -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"}