@bquery/bquery 1.6.0 → 1.8.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 (402) hide show
  1. package/README.md +192 -18
  2. package/dist/a11y/announce.d.ts +43 -0
  3. package/dist/a11y/announce.d.ts.map +1 -0
  4. package/dist/a11y/audit.d.ts +42 -0
  5. package/dist/a11y/audit.d.ts.map +1 -0
  6. package/dist/a11y/index.d.ts +53 -0
  7. package/dist/a11y/index.d.ts.map +1 -0
  8. package/dist/a11y/media-preferences.d.ts +77 -0
  9. package/dist/a11y/media-preferences.d.ts.map +1 -0
  10. package/dist/a11y/roving-tab-index.d.ts +38 -0
  11. package/dist/a11y/roving-tab-index.d.ts.map +1 -0
  12. package/dist/a11y/skip-link.d.ts +37 -0
  13. package/dist/a11y/skip-link.d.ts.map +1 -0
  14. package/dist/a11y/trap-focus.d.ts +49 -0
  15. package/dist/a11y/trap-focus.d.ts.map +1 -0
  16. package/dist/a11y/types.d.ts +152 -0
  17. package/dist/a11y/types.d.ts.map +1 -0
  18. package/dist/a11y-DVBCy09c.js +421 -0
  19. package/dist/a11y-DVBCy09c.js.map +1 -0
  20. package/dist/a11y.es.mjs +14 -0
  21. package/dist/component/component.d.ts.map +1 -1
  22. package/dist/component/html.d.ts.map +1 -1
  23. package/dist/component/index.d.ts +2 -1
  24. package/dist/component/index.d.ts.map +1 -1
  25. package/dist/component/library.d.ts.map +1 -1
  26. package/dist/component/scope.d.ts +138 -0
  27. package/dist/component/scope.d.ts.map +1 -0
  28. package/dist/component/types.d.ts +53 -1
  29. package/dist/component/types.d.ts.map +1 -1
  30. package/dist/component-L3-JfOFz.js +684 -0
  31. package/dist/component-L3-JfOFz.js.map +1 -0
  32. package/dist/component.es.mjs +9 -6
  33. package/dist/{config-DRmZZno3.js → config-DhT9auRm.js} +4 -4
  34. package/dist/{config-DRmZZno3.js.map → config-DhT9auRm.js.map} +1 -1
  35. package/dist/constraints-D5RHQLmP.js +100 -0
  36. package/dist/constraints-D5RHQLmP.js.map +1 -0
  37. package/dist/core/collection.d.ts +134 -0
  38. package/dist/core/collection.d.ts.map +1 -1
  39. package/dist/core/element.d.ts +120 -0
  40. package/dist/core/element.d.ts.map +1 -1
  41. package/dist/core/env.d.ts +18 -0
  42. package/dist/core/env.d.ts.map +1 -0
  43. package/dist/core/index.d.ts +1 -0
  44. package/dist/core/index.d.ts.map +1 -1
  45. package/dist/core/shared.d.ts +14 -0
  46. package/dist/core/shared.d.ts.map +1 -1
  47. package/dist/core/utils/index.d.ts +52 -41
  48. package/dist/core/utils/index.d.ts.map +1 -1
  49. package/dist/core-DdtZHzsS.js +168 -0
  50. package/dist/core-DdtZHzsS.js.map +1 -0
  51. package/dist/{core-CCEabVHl.js → core-EMYSLzaT.js} +293 -194
  52. package/dist/core-EMYSLzaT.js.map +1 -0
  53. package/dist/core.es.mjs +48 -46
  54. package/dist/custom-directives-Dr4C5lVV.js +9 -0
  55. package/dist/custom-directives-Dr4C5lVV.js.map +1 -0
  56. package/dist/devtools/devtools.d.ts +212 -0
  57. package/dist/devtools/devtools.d.ts.map +1 -0
  58. package/dist/devtools/index.d.ts +20 -0
  59. package/dist/devtools/index.d.ts.map +1 -0
  60. package/dist/devtools/types.d.ts +69 -0
  61. package/dist/devtools/types.d.ts.map +1 -0
  62. package/dist/devtools-BhB2iDPT.js +122 -0
  63. package/dist/devtools-BhB2iDPT.js.map +1 -0
  64. package/dist/devtools.es.mjs +19 -0
  65. package/dist/dnd/draggable.d.ts +51 -0
  66. package/dist/dnd/draggable.d.ts.map +1 -0
  67. package/dist/dnd/droppable.d.ts +38 -0
  68. package/dist/dnd/droppable.d.ts.map +1 -0
  69. package/dist/dnd/index.d.ts +47 -0
  70. package/dist/dnd/index.d.ts.map +1 -0
  71. package/dist/dnd/sortable.d.ts +43 -0
  72. package/dist/dnd/sortable.d.ts.map +1 -0
  73. package/dist/dnd/types.d.ts +250 -0
  74. package/dist/dnd/types.d.ts.map +1 -0
  75. package/dist/dnd-NwZBYh4l.js +244 -0
  76. package/dist/dnd-NwZBYh4l.js.map +1 -0
  77. package/dist/dnd.es.mjs +6 -0
  78. package/dist/env-CTdvLaH2.js +19 -0
  79. package/dist/env-CTdvLaH2.js.map +1 -0
  80. package/dist/forms/create-form.d.ts +49 -0
  81. package/dist/forms/create-form.d.ts.map +1 -0
  82. package/dist/forms/index.d.ts +40 -0
  83. package/dist/forms/index.d.ts.map +1 -0
  84. package/dist/forms/types.d.ts +185 -0
  85. package/dist/forms/types.d.ts.map +1 -0
  86. package/dist/forms/use-field.d.ts +34 -0
  87. package/dist/forms/use-field.d.ts.map +1 -0
  88. package/dist/forms/validators.d.ts +204 -0
  89. package/dist/forms/validators.d.ts.map +1 -0
  90. package/dist/forms-UcRHsYxC.js +227 -0
  91. package/dist/forms-UcRHsYxC.js.map +1 -0
  92. package/dist/forms.es.mjs +16 -0
  93. package/dist/full.d.ts +30 -11
  94. package/dist/full.d.ts.map +1 -1
  95. package/dist/full.es.mjs +209 -93
  96. package/dist/full.iife.js +47 -31
  97. package/dist/full.iife.js.map +1 -1
  98. package/dist/full.umd.js +47 -31
  99. package/dist/full.umd.js.map +1 -1
  100. package/dist/function-Cybd57JV.js +33 -0
  101. package/dist/function-Cybd57JV.js.map +1 -0
  102. package/dist/i18n/formatting.d.ts +40 -0
  103. package/dist/i18n/formatting.d.ts.map +1 -0
  104. package/dist/i18n/i18n.d.ts +48 -0
  105. package/dist/i18n/i18n.d.ts.map +1 -0
  106. package/dist/i18n/index.d.ts +57 -0
  107. package/dist/i18n/index.d.ts.map +1 -0
  108. package/dist/i18n/translate.d.ts +83 -0
  109. package/dist/i18n/translate.d.ts.map +1 -0
  110. package/dist/i18n/types.d.ts +156 -0
  111. package/dist/i18n/types.d.ts.map +1 -0
  112. package/dist/i18n-kuF6Ekj6.js +89 -0
  113. package/dist/i18n-kuF6Ekj6.js.map +1 -0
  114. package/dist/i18n.es.mjs +6 -0
  115. package/dist/index.d.ts +11 -0
  116. package/dist/index.d.ts.map +1 -1
  117. package/dist/index.es.mjs +257 -143
  118. package/dist/media/battery.d.ts +35 -0
  119. package/dist/media/battery.d.ts.map +1 -0
  120. package/dist/media/breakpoints.d.ts +51 -0
  121. package/dist/media/breakpoints.d.ts.map +1 -0
  122. package/dist/media/clipboard.d.ts +30 -0
  123. package/dist/media/clipboard.d.ts.map +1 -0
  124. package/dist/media/device-sensors.d.ts +54 -0
  125. package/dist/media/device-sensors.d.ts.map +1 -0
  126. package/dist/media/geolocation.d.ts +38 -0
  127. package/dist/media/geolocation.d.ts.map +1 -0
  128. package/dist/media/index.d.ts +42 -0
  129. package/dist/media/index.d.ts.map +1 -0
  130. package/dist/media/media-query.d.ts +36 -0
  131. package/dist/media/media-query.d.ts.map +1 -0
  132. package/dist/media/network.d.ts +35 -0
  133. package/dist/media/network.d.ts.map +1 -0
  134. package/dist/media/types.d.ts +173 -0
  135. package/dist/media/types.d.ts.map +1 -0
  136. package/dist/media/viewport.d.ts +32 -0
  137. package/dist/media/viewport.d.ts.map +1 -0
  138. package/dist/media-i-fB5WxI.js +340 -0
  139. package/dist/media-i-fB5WxI.js.map +1 -0
  140. package/dist/media.es.mjs +12 -0
  141. package/dist/motion/index.d.ts +7 -3
  142. package/dist/motion/index.d.ts.map +1 -1
  143. package/dist/motion/morph.d.ts +27 -0
  144. package/dist/motion/morph.d.ts.map +1 -0
  145. package/dist/motion/parallax.d.ts +30 -0
  146. package/dist/motion/parallax.d.ts.map +1 -0
  147. package/dist/motion/reduced-motion.d.ts +36 -3
  148. package/dist/motion/reduced-motion.d.ts.map +1 -1
  149. package/dist/motion/types.d.ts +58 -0
  150. package/dist/motion/types.d.ts.map +1 -1
  151. package/dist/motion/typewriter.d.ts +31 -0
  152. package/dist/motion/typewriter.d.ts.map +1 -0
  153. package/dist/motion-BJsAuULb.js +530 -0
  154. package/dist/motion-BJsAuULb.js.map +1 -0
  155. package/dist/motion.es.mjs +27 -23
  156. package/dist/{view-C70lA3vf.js → mount-B4Y8bk8Z.js} +166 -160
  157. package/dist/mount-B4Y8bk8Z.js.map +1 -0
  158. package/dist/{object-qGpWr6-J.js → object-BCk-1c8T.js} +5 -4
  159. package/dist/{object-qGpWr6-J.js.map → object-BCk-1c8T.js.map} +1 -1
  160. package/dist/{platform-Dr9b6fsq.js → platform-Dw2gE3zI.js} +21 -22
  161. package/dist/{platform-Dr9b6fsq.js.map → platform-Dw2gE3zI.js.map} +1 -1
  162. package/dist/platform.es.mjs +2 -2
  163. package/dist/plugin/index.d.ts +22 -0
  164. package/dist/plugin/index.d.ts.map +1 -0
  165. package/dist/plugin/registry.d.ts +108 -0
  166. package/dist/plugin/registry.d.ts.map +1 -0
  167. package/dist/plugin/types.d.ts +110 -0
  168. package/dist/plugin/types.d.ts.map +1 -0
  169. package/dist/plugin-C2WuC8SF.js +66 -0
  170. package/dist/plugin-C2WuC8SF.js.map +1 -0
  171. package/dist/plugin.es.mjs +9 -0
  172. package/dist/reactive/async-data.d.ts +28 -3
  173. package/dist/reactive/async-data.d.ts.map +1 -1
  174. package/dist/reactive/computed.d.ts +10 -0
  175. package/dist/reactive/computed.d.ts.map +1 -1
  176. package/dist/reactive/effect.d.ts +3 -0
  177. package/dist/reactive/effect.d.ts.map +1 -1
  178. package/dist/reactive/http.d.ts +194 -0
  179. package/dist/reactive/http.d.ts.map +1 -0
  180. package/dist/reactive/index.d.ts +2 -2
  181. package/dist/reactive/index.d.ts.map +1 -1
  182. package/dist/reactive/pagination.d.ts +126 -0
  183. package/dist/reactive/pagination.d.ts.map +1 -0
  184. package/dist/reactive/polling.d.ts +55 -0
  185. package/dist/reactive/polling.d.ts.map +1 -0
  186. package/dist/reactive/readonly.d.ts +20 -1
  187. package/dist/reactive/readonly.d.ts.map +1 -1
  188. package/dist/reactive/rest.d.ts +293 -0
  189. package/dist/reactive/rest.d.ts.map +1 -0
  190. package/dist/reactive/scope.d.ts +140 -0
  191. package/dist/reactive/scope.d.ts.map +1 -0
  192. package/dist/reactive/signal.d.ts +16 -2
  193. package/dist/reactive/signal.d.ts.map +1 -1
  194. package/dist/reactive/to-value.d.ts +57 -0
  195. package/dist/reactive/to-value.d.ts.map +1 -0
  196. package/dist/reactive/websocket.d.ts +285 -0
  197. package/dist/reactive/websocket.d.ts.map +1 -0
  198. package/dist/reactive-DwkhUJfP.js +1148 -0
  199. package/dist/reactive-DwkhUJfP.js.map +1 -0
  200. package/dist/reactive.es.mjs +38 -20
  201. package/dist/registry-B08iilIh.js +26 -0
  202. package/dist/registry-B08iilIh.js.map +1 -0
  203. package/dist/router/bq-link.d.ts +112 -0
  204. package/dist/router/bq-link.d.ts.map +1 -0
  205. package/dist/router/constraints.d.ts +9 -0
  206. package/dist/router/constraints.d.ts.map +1 -0
  207. package/dist/router/index.d.ts +15 -7
  208. package/dist/router/index.d.ts.map +1 -1
  209. package/dist/router/match.d.ts +0 -1
  210. package/dist/router/match.d.ts.map +1 -1
  211. package/dist/router/path-pattern.d.ts +14 -0
  212. package/dist/router/path-pattern.d.ts.map +1 -0
  213. package/dist/router/query.d.ts.map +1 -1
  214. package/dist/router/router.d.ts +3 -1
  215. package/dist/router/router.d.ts.map +1 -1
  216. package/dist/router/state.d.ts +25 -2
  217. package/dist/router/state.d.ts.map +1 -1
  218. package/dist/router/types.d.ts +48 -4
  219. package/dist/router/types.d.ts.map +1 -1
  220. package/dist/router/use-route.d.ts +50 -0
  221. package/dist/router/use-route.d.ts.map +1 -0
  222. package/dist/router/utils.d.ts +3 -0
  223. package/dist/router/utils.d.ts.map +1 -1
  224. package/dist/router-CQikC9Ed.js +492 -0
  225. package/dist/router-CQikC9Ed.js.map +1 -0
  226. package/dist/router.es.mjs +14 -10
  227. package/dist/{sanitize-Bs2dkMby.js → sanitize-B1V4JswB.js} +2 -1
  228. package/dist/{sanitize-Bs2dkMby.js.map → sanitize-B1V4JswB.js.map} +1 -1
  229. package/dist/security/index.d.ts +2 -2
  230. package/dist/security/index.d.ts.map +1 -1
  231. package/dist/security.es.mjs +1 -1
  232. package/dist/ssr/hydrate.d.ts +65 -0
  233. package/dist/ssr/hydrate.d.ts.map +1 -0
  234. package/dist/ssr/index.d.ts +59 -0
  235. package/dist/ssr/index.d.ts.map +1 -0
  236. package/dist/ssr/render.d.ts +62 -0
  237. package/dist/ssr/render.d.ts.map +1 -0
  238. package/dist/ssr/serialize.d.ts +118 -0
  239. package/dist/ssr/serialize.d.ts.map +1 -0
  240. package/dist/ssr/types.d.ts +70 -0
  241. package/dist/ssr/types.d.ts.map +1 -0
  242. package/dist/ssr-_dAcGdzu.js +248 -0
  243. package/dist/ssr-_dAcGdzu.js.map +1 -0
  244. package/dist/ssr.es.mjs +9 -0
  245. package/dist/store/create-store.d.ts.map +1 -1
  246. package/dist/store/index.d.ts +1 -1
  247. package/dist/store/index.d.ts.map +1 -1
  248. package/dist/store/persisted.d.ts +38 -4
  249. package/dist/store/persisted.d.ts.map +1 -1
  250. package/dist/store/types.d.ts +138 -1
  251. package/dist/store/types.d.ts.map +1 -1
  252. package/dist/store/utils.d.ts +2 -2
  253. package/dist/store/utils.d.ts.map +1 -1
  254. package/dist/store-Cb3gPRve.js +338 -0
  255. package/dist/store-Cb3gPRve.js.map +1 -0
  256. package/dist/store.es.mjs +11 -10
  257. package/dist/storybook/index.d.ts.map +1 -1
  258. package/dist/storybook.es.mjs +1 -1
  259. package/dist/storybook.es.mjs.map +1 -1
  260. package/dist/testing/index.d.ts +23 -0
  261. package/dist/testing/index.d.ts.map +1 -0
  262. package/dist/testing/testing.d.ts +156 -0
  263. package/dist/testing/testing.d.ts.map +1 -0
  264. package/dist/testing/types.d.ts +134 -0
  265. package/dist/testing/types.d.ts.map +1 -0
  266. package/dist/testing-C5Sjfsna.js +224 -0
  267. package/dist/testing-C5Sjfsna.js.map +1 -0
  268. package/dist/testing.es.mjs +9 -0
  269. package/dist/type-guards-BMX2c0LP.js +44 -0
  270. package/dist/type-guards-BMX2c0LP.js.map +1 -0
  271. package/dist/untrack-D0fnO5k2.js +36 -0
  272. package/dist/untrack-D0fnO5k2.js.map +1 -0
  273. package/dist/view/custom-directives.d.ts +20 -0
  274. package/dist/view/custom-directives.d.ts.map +1 -0
  275. package/dist/view/evaluate.d.ts.map +1 -1
  276. package/dist/view/process.d.ts.map +1 -1
  277. package/dist/view.es.mjs +9 -9
  278. package/package.json +47 -11
  279. package/src/a11y/announce.ts +131 -0
  280. package/src/a11y/audit.ts +314 -0
  281. package/src/a11y/index.ts +68 -0
  282. package/src/a11y/media-preferences.ts +255 -0
  283. package/src/a11y/roving-tab-index.ts +164 -0
  284. package/src/a11y/skip-link.ts +255 -0
  285. package/src/a11y/trap-focus.ts +184 -0
  286. package/src/a11y/types.ts +183 -0
  287. package/src/component/component.ts +599 -524
  288. package/src/component/html.ts +153 -153
  289. package/src/component/index.ts +52 -50
  290. package/src/component/library.ts +540 -518
  291. package/src/component/scope.ts +212 -0
  292. package/src/component/types.ts +310 -256
  293. package/src/core/collection.ts +249 -1
  294. package/src/core/element.ts +252 -11
  295. package/src/core/env.ts +60 -0
  296. package/src/core/index.ts +1 -0
  297. package/src/core/shared.ts +64 -0
  298. package/src/core/utils/index.ts +66 -1
  299. package/src/devtools/devtools.ts +410 -0
  300. package/src/devtools/index.ts +48 -0
  301. package/src/devtools/types.ts +104 -0
  302. package/src/dnd/draggable.ts +296 -0
  303. package/src/dnd/droppable.ts +228 -0
  304. package/src/dnd/index.ts +62 -0
  305. package/src/dnd/sortable.ts +307 -0
  306. package/src/dnd/types.ts +293 -0
  307. package/src/forms/create-form.ts +320 -0
  308. package/src/forms/index.ts +70 -0
  309. package/src/forms/types.ts +203 -0
  310. package/src/forms/use-field.ts +231 -0
  311. package/src/forms/validators.ts +294 -0
  312. package/src/full.ts +554 -229
  313. package/src/i18n/formatting.ts +67 -0
  314. package/src/i18n/i18n.ts +200 -0
  315. package/src/i18n/index.ts +67 -0
  316. package/src/i18n/translate.ts +182 -0
  317. package/src/i18n/types.ts +171 -0
  318. package/src/index.ts +72 -0
  319. package/src/media/battery.ts +116 -0
  320. package/src/media/breakpoints.ts +129 -0
  321. package/src/media/clipboard.ts +80 -0
  322. package/src/media/device-sensors.ts +158 -0
  323. package/src/media/geolocation.ts +119 -0
  324. package/src/media/index.ts +76 -0
  325. package/src/media/media-query.ts +92 -0
  326. package/src/media/network.ts +115 -0
  327. package/src/media/types.ts +177 -0
  328. package/src/media/viewport.ts +84 -0
  329. package/src/motion/index.ts +11 -2
  330. package/src/motion/morph.ts +151 -0
  331. package/src/motion/parallax.ts +120 -0
  332. package/src/motion/reduced-motion.ts +52 -3
  333. package/src/motion/types.ts +63 -0
  334. package/src/motion/typewriter.ts +164 -0
  335. package/src/plugin/index.ts +37 -0
  336. package/src/plugin/registry.ts +284 -0
  337. package/src/plugin/types.ts +137 -0
  338. package/src/reactive/async-data.ts +250 -29
  339. package/src/reactive/computed.ts +53 -1
  340. package/src/reactive/effect.ts +29 -6
  341. package/src/reactive/http.ts +790 -0
  342. package/src/reactive/index.ts +60 -0
  343. package/src/reactive/pagination.ts +317 -0
  344. package/src/reactive/polling.ts +179 -0
  345. package/src/reactive/readonly.ts +52 -8
  346. package/src/reactive/rest.ts +859 -0
  347. package/src/reactive/scope.ts +276 -0
  348. package/src/reactive/signal.ts +61 -1
  349. package/src/reactive/to-value.ts +71 -0
  350. package/src/reactive/websocket.ts +849 -0
  351. package/src/router/bq-link.ts +279 -0
  352. package/src/router/constraints.ts +204 -0
  353. package/src/router/index.ts +15 -7
  354. package/src/router/match.ts +255 -49
  355. package/src/router/path-pattern.ts +52 -0
  356. package/src/router/query.ts +3 -0
  357. package/src/router/router.ts +258 -48
  358. package/src/router/state.ts +51 -3
  359. package/src/router/types.ts +50 -4
  360. package/src/router/use-route.ts +68 -0
  361. package/src/router/utils.ts +44 -3
  362. package/src/security/index.ts +12 -17
  363. package/src/security/sanitize.ts +70 -70
  364. package/src/security/trusted-html.ts +71 -71
  365. package/src/ssr/hydrate.ts +84 -0
  366. package/src/ssr/index.ts +70 -0
  367. package/src/ssr/render.ts +508 -0
  368. package/src/ssr/serialize.ts +296 -0
  369. package/src/ssr/types.ts +81 -0
  370. package/src/store/create-store.ts +146 -8
  371. package/src/store/define-store.ts +49 -49
  372. package/src/store/index.ts +5 -0
  373. package/src/store/mapping.ts +74 -74
  374. package/src/store/persisted.ts +245 -62
  375. package/src/store/types.ts +247 -92
  376. package/src/store/utils.ts +4 -10
  377. package/src/store/watch.ts +53 -53
  378. package/src/storybook/index.ts +480 -479
  379. package/src/testing/index.ts +42 -0
  380. package/src/testing/testing.ts +593 -0
  381. package/src/testing/types.ts +170 -0
  382. package/src/view/custom-directives.ts +28 -0
  383. package/src/view/evaluate.ts +2 -0
  384. package/src/view/process.ts +19 -3
  385. package/dist/component-BEQgt5hl.js +0 -600
  386. package/dist/component-BEQgt5hl.js.map +0 -1
  387. package/dist/core-BGQJVw0-.js +0 -35
  388. package/dist/core-BGQJVw0-.js.map +0 -1
  389. package/dist/core-CCEabVHl.js.map +0 -1
  390. package/dist/effect-AFRW_Plg.js +0 -84
  391. package/dist/effect-AFRW_Plg.js.map +0 -1
  392. package/dist/motion-D9TcHxOF.js +0 -415
  393. package/dist/motion-D9TcHxOF.js.map +0 -1
  394. package/dist/reactive-DSkct0dO.js +0 -254
  395. package/dist/reactive-DSkct0dO.js.map +0 -1
  396. package/dist/router-CbDhl8rS.js +0 -188
  397. package/dist/router-CbDhl8rS.js.map +0 -1
  398. package/dist/store-BwDvI45q.js +0 -263
  399. package/dist/store-BwDvI45q.js.map +0 -1
  400. package/dist/untrack-B0rVscTc.js +0 -7
  401. package/dist/untrack-B0rVscTc.js.map +0 -1
  402. package/dist/view-C70lA3vf.js.map +0 -1
@@ -0,0 +1,140 @@
1
+ /**
2
+ * Reactive effect scopes for grouped disposal.
3
+ *
4
+ * An `EffectScope` collects all effects, computed values, and watches created
5
+ * inside its `run()` callback so they can be disposed together with a single
6
+ * `stop()` call. Scopes nest — an inner scope is collected by its parent.
7
+ *
8
+ * @module bquery/reactive
9
+ */
10
+ import type { CleanupFn } from './internals';
11
+ /**
12
+ * A scope that collects reactive resources for grouped disposal.
13
+ *
14
+ * @example
15
+ * ```ts
16
+ * import { effectScope, signal, effect, computed } from '@bquery/bquery/reactive';
17
+ *
18
+ * const scope = effectScope();
19
+ *
20
+ * scope.run(() => {
21
+ * const count = signal(0);
22
+ * effect(() => console.log(count.value));
23
+ * const doubled = computed(() => count.value * 2);
24
+ * });
25
+ *
26
+ * scope.stop(); // All effects and computed values disposed
27
+ * ```
28
+ */
29
+ export interface EffectScope {
30
+ /** Whether the scope has not yet been stopped. */
31
+ readonly active: boolean;
32
+ /**
33
+ * Executes `fn` inside this scope, collecting any reactive resources
34
+ * (effects, computed values, watches, nested scopes) created during the call.
35
+ *
36
+ * `run()` is synchronous-only. Do not pass an async function or a function
37
+ * that returns a Promise — resources created after an `await` cannot be
38
+ * collected reliably.
39
+ *
40
+ * @template T - Return type of the provided function
41
+ * @param fn - Function to run inside the scope
42
+ * @returns The return value of `fn`
43
+ * @throws {Error} If the scope has already been stopped
44
+ */
45
+ run<T>(fn: () => T): T;
46
+ /**
47
+ * Disposes all collected resources and marks the scope as inactive.
48
+ * Calling `stop()` on an already-stopped scope is a safe no-op.
49
+ */
50
+ stop(): void;
51
+ }
52
+ /** @internal */
53
+ export declare const hasScopeDisposer: (scope: EffectScope | undefined) => scope is EffectScope & {
54
+ _addDisposer(fn: CleanupFn): void;
55
+ };
56
+ /**
57
+ * Returns the currently active scope, or `undefined` if none.
58
+ * @internal
59
+ */
60
+ export declare const getActiveScope: () => EffectScope | undefined;
61
+ /**
62
+ * Creates a new effect scope for grouped disposal of reactive resources.
63
+ *
64
+ * All `effect()`, `computed()`, `watch()`, and nested `effectScope()` calls
65
+ * made inside `scope.run(fn)` are automatically collected. Calling
66
+ * `scope.stop()` disposes them all at once.
67
+ *
68
+ * `run()` is synchronous-only. Create the scope outside async flows when
69
+ * needed, but keep the callback itself synchronous so cleanup registration
70
+ * stays deterministic.
71
+ *
72
+ * @returns A new {@link EffectScope}
73
+ *
74
+ * @example
75
+ * ```ts
76
+ * import { effectScope, signal, effect, onScopeDispose } from '@bquery/bquery/reactive';
77
+ *
78
+ * const scope = effectScope();
79
+ *
80
+ * scope.run(() => {
81
+ * const count = signal(0);
82
+ *
83
+ * effect(() => console.log(count.value));
84
+ *
85
+ * onScopeDispose(() => {
86
+ * console.log('Custom cleanup');
87
+ * });
88
+ * });
89
+ *
90
+ * scope.stop(); // logs "Custom cleanup", all effects stopped
91
+ * ```
92
+ */
93
+ export declare const effectScope: () => EffectScope;
94
+ /**
95
+ * Returns the currently active {@link EffectScope}, or `undefined` if
96
+ * code is not running inside any scope's `run()` callback.
97
+ *
98
+ * @returns The active scope, or `undefined`
99
+ *
100
+ * @example
101
+ * ```ts
102
+ * import { effectScope, getCurrentScope } from '@bquery/bquery/reactive';
103
+ *
104
+ * const scope = effectScope();
105
+ * scope.run(() => {
106
+ * console.log(getCurrentScope() !== undefined); // true
107
+ * });
108
+ *
109
+ * console.log(getCurrentScope()); // undefined
110
+ * ```
111
+ */
112
+ export declare const getCurrentScope: () => EffectScope | undefined;
113
+ /**
114
+ * Registers a cleanup callback on the currently active scope.
115
+ *
116
+ * The callback runs when the scope is stopped. This is useful for
117
+ * registering arbitrary cleanup (e.g. event listeners, timers)
118
+ * alongside effects and computed values.
119
+ *
120
+ * @param fn - Cleanup function to run when the scope stops
121
+ * @throws {Error} If called outside an active scope
122
+ *
123
+ * @example
124
+ * ```ts
125
+ * import { effectScope, onScopeDispose } from '@bquery/bquery/reactive';
126
+ *
127
+ * const scope = effectScope();
128
+ *
129
+ * scope.run(() => {
130
+ * const controller = new AbortController();
131
+ * fetch('/api/data', { signal: controller.signal });
132
+ *
133
+ * onScopeDispose(() => controller.abort());
134
+ * });
135
+ *
136
+ * scope.stop(); // abort() is called
137
+ * ```
138
+ */
139
+ export declare const onScopeDispose: (fn: CleanupFn) => void;
140
+ //# sourceMappingURL=scope.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"scope.d.ts","sourceRoot":"","sources":["../../src/reactive/scope.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAEH,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AAM7C;;;;;;;;;;;;;;;;;GAiBG;AACH,MAAM,WAAW,WAAW;IAC1B,kDAAkD;IAClD,QAAQ,CAAC,MAAM,EAAE,OAAO,CAAC;IAEzB;;;;;;;;;;;;OAYG;IACH,GAAG,CAAC,CAAC,EAAE,EAAE,EAAE,MAAM,CAAC,GAAG,CAAC,CAAC;IAEvB;;;OAGG;IACH,IAAI,IAAI,IAAI,CAAC;CACd;AAcD,gBAAgB;AAChB,eAAO,MAAM,gBAAgB,GAC3B,OAAO,WAAW,GAAG,SAAS,KAC7B,KAAK,IAAI,WAAW,GAAG;IAAE,YAAY,CAAC,EAAE,EAAE,SAAS,GAAG,IAAI,CAAA;CACW,CAAC;AA2BzE;;;GAGG;AACH,eAAO,MAAM,cAAc,QAAO,WAAW,GAAG,SAQ/C,CAAC;AA8DF;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA+BG;AACH,eAAO,MAAM,WAAW,QAAO,WAU9B,CAAC;AAEF;;;;;;;;;;;;;;;;;GAiBG;AACH,eAAO,MAAM,eAAe,QAAO,WAAW,GAAG,SAA6B,CAAC;AAE/E;;;;;;;;;;;;;;;;;;;;;;;;;GAyBG;AACH,eAAO,MAAM,cAAc,GAAI,IAAI,SAAS,KAAG,IAQ9C,CAAC"}
@@ -8,14 +8,28 @@ export { createUseFetch, useAsyncData, useFetch } from './async-data';
8
8
  export { Computed, computed } from './computed';
9
9
  export { Signal, signal } from './core';
10
10
  export { effect } from './effect';
11
+ export { createHttp, createRequestQueue, http, HttpError } from './http';
11
12
  export { linkedSignal } from './linked';
13
+ export { useInfiniteFetch, usePaginatedFetch } from './pagination';
12
14
  export { persistedSignal } from './persisted';
15
+ export { usePolling } from './polling';
13
16
  export { readonly } from './readonly';
17
+ export { createRestClient, deduplicateRequest, useResource, useResourceList, useSubmit, } from './rest';
18
+ export { effectScope, getCurrentScope, onScopeDispose } from './scope';
14
19
  export { isComputed, isSignal } from './type-guards';
20
+ export { toValue } from './to-value';
15
21
  export { untrack } from './untrack';
16
22
  export { watch } from './watch';
23
+ export { useEventSource, useWebSocket, useWebSocketChannel } from './websocket';
17
24
  export type { CleanupFn, Observer } from './internals';
18
- export type { AsyncDataState, AsyncDataStatus, AsyncWatchSource, FetchInput, UseAsyncDataOptions, UseFetchOptions, } from './async-data';
25
+ export type { AsyncDataState, AsyncDataStatus, AsyncWatchSource, FetchInput, UseAsyncDataOptions, UseFetchOptions, UseFetchRetryConfig, } from './async-data';
26
+ export type { HttpClient, HttpProgressEvent, HttpRequestConfig, HttpResponse, Interceptor, InterceptorManager, RequestQueue, RequestQueueOptions, RetryConfig, } from './http';
27
+ export type { InfiniteState, PaginatedState, UseInfiniteFetchOptions, UsePaginatedFetchOptions, } from './pagination';
28
+ export type { PollingState, UsePollingOptions } from './polling';
29
+ export type { IdExtractor, ResourceListActions, RestClient, UseResourceListOptions, UseResourceListReturn, UseResourceOptions, UseResourceReturn, UseSubmitOptions, UseSubmitReturn, } from './rest';
30
+ export type { EffectScope } from './scope';
19
31
  export type { LinkedSignal } from './linked';
20
- export type { ReadonlySignal } from './readonly';
32
+ export type { MaybeSignal } from './to-value';
33
+ export type { ReadonlySignal, ReadonlySignalHandle } from './readonly';
34
+ export type { ChannelMessage, ChannelSubscription, EventSourceStatus, UseEventSourceOptions, UseEventSourceReturn, UseWebSocketChannelOptions, UseWebSocketChannelReturn, UseWebSocketOptions, UseWebSocketReturn, WebSocketHeartbeatConfig, WebSocketReconnectConfig, WebSocketSerializer, WebSocketStatus, } from './websocket';
21
35
  //# sourceMappingURL=signal.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"signal.d.ts","sourceRoot":"","sources":["../../src/reactive/signal.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EAAE,KAAK,EAAE,MAAM,SAAS,CAAC;AAChC,OAAO,EAAE,cAAc,EAAE,YAAY,EAAE,QAAQ,EAAE,MAAM,cAAc,CAAC;AACtE,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAChD,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AACxC,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAClC,OAAO,EAAE,YAAY,EAAE,MAAM,UAAU,CAAC;AACxC,OAAO,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AAC9C,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AACtC,OAAO,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AACrD,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,KAAK,EAAE,MAAM,SAAS,CAAC;AAEhC,YAAY,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AACvD,YAAY,EACV,cAAc,EACd,eAAe,EACf,gBAAgB,EAChB,UAAU,EACV,mBAAmB,EACnB,eAAe,GAChB,MAAM,cAAc,CAAC;AACtB,YAAY,EAAE,YAAY,EAAE,MAAM,UAAU,CAAC;AAC7C,YAAY,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC"}
1
+ {"version":3,"file":"signal.d.ts","sourceRoot":"","sources":["../../src/reactive/signal.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EAAE,KAAK,EAAE,MAAM,SAAS,CAAC;AAChC,OAAO,EAAE,cAAc,EAAE,YAAY,EAAE,QAAQ,EAAE,MAAM,cAAc,CAAC;AACtE,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAChD,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AACxC,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAClC,OAAO,EAAE,UAAU,EAAE,kBAAkB,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM,QAAQ,CAAC;AACzE,OAAO,EAAE,YAAY,EAAE,MAAM,UAAU,CAAC;AACxC,OAAO,EAAE,gBAAgB,EAAE,iBAAiB,EAAE,MAAM,cAAc,CAAC;AACnE,OAAO,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AAC9C,OAAO,EAAE,UAAU,EAAE,MAAM,WAAW,CAAC;AACvC,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AACtC,OAAO,EACL,gBAAgB,EAChB,kBAAkB,EAClB,WAAW,EACX,eAAe,EACf,SAAS,GACV,MAAM,QAAQ,CAAC;AAChB,OAAO,EAAE,WAAW,EAAE,eAAe,EAAE,cAAc,EAAE,MAAM,SAAS,CAAC;AACvE,OAAO,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AACrD,OAAO,EAAE,OAAO,EAAE,MAAM,YAAY,CAAC;AACrC,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,KAAK,EAAE,MAAM,SAAS,CAAC;AAChC,OAAO,EAAE,cAAc,EAAE,YAAY,EAAE,mBAAmB,EAAE,MAAM,aAAa,CAAC;AAEhF,YAAY,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AACvD,YAAY,EACV,cAAc,EACd,eAAe,EACf,gBAAgB,EAChB,UAAU,EACV,mBAAmB,EACnB,eAAe,EACf,mBAAmB,GACpB,MAAM,cAAc,CAAC;AACtB,YAAY,EACV,UAAU,EACV,iBAAiB,EACjB,iBAAiB,EACjB,YAAY,EACZ,WAAW,EACX,kBAAkB,EAClB,YAAY,EACZ,mBAAmB,EACnB,WAAW,GACZ,MAAM,QAAQ,CAAC;AAChB,YAAY,EACV,aAAa,EACb,cAAc,EACd,uBAAuB,EACvB,wBAAwB,GACzB,MAAM,cAAc,CAAC;AACtB,YAAY,EAAE,YAAY,EAAE,iBAAiB,EAAE,MAAM,WAAW,CAAC;AACjE,YAAY,EACV,WAAW,EACX,mBAAmB,EACnB,UAAU,EACV,sBAAsB,EACtB,qBAAqB,EACrB,kBAAkB,EAClB,iBAAiB,EACjB,gBAAgB,EAChB,eAAe,GAChB,MAAM,QAAQ,CAAC;AAChB,YAAY,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAC3C,YAAY,EAAE,YAAY,EAAE,MAAM,UAAU,CAAC;AAC7C,YAAY,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AAC9C,YAAY,EAAE,cAAc,EAAE,oBAAoB,EAAE,MAAM,YAAY,CAAC;AACvE,YAAY,EACV,cAAc,EACd,mBAAmB,EACnB,iBAAiB,EACjB,qBAAqB,EACrB,oBAAoB,EACpB,0BAA0B,EAC1B,yBAAyB,EACzB,mBAAmB,EACnB,kBAAkB,EAClB,wBAAwB,EACxB,wBAAwB,EACxB,mBAAmB,EACnB,eAAe,GAChB,MAAM,aAAa,CAAC"}
@@ -0,0 +1,57 @@
1
+ /**
2
+ * Utility to unwrap reactive or plain values.
3
+ */
4
+ import { Computed } from './computed';
5
+ import { Signal } from './core';
6
+ import { readonly } from './readonly';
7
+ /**
8
+ * A value that may be a raw value, a Signal, a `readonly()` wrapper, or a Computed.
9
+ *
10
+ * Useful for APIs that accept both reactive and plain inputs.
11
+ *
12
+ * Readonly wrappers are limited to the values returned by {@link readonly}. This keeps
13
+ * the type aligned with runtime behavior, where arbitrary structural `{ value, peek }`
14
+ * objects are intentionally returned unchanged.
15
+ *
16
+ * @template T - The underlying value type
17
+ *
18
+ * @example
19
+ * ```ts
20
+ * function useTitle(title: MaybeSignal<string>) {
21
+ * document.title = toValue(title);
22
+ * }
23
+ *
24
+ * useTitle('Hello'); // plain string
25
+ * useTitle(signal('Hello')); // reactive signal
26
+ * useTitle(computed(() => 'Hi')); // computed value
27
+ * ```
28
+ */
29
+ export type MaybeSignal<T> = T | Signal<T> | ReturnType<typeof readonly<T>> | Computed<T>;
30
+ /**
31
+ * Extracts the current value from a Signal, a bQuery `readonly()` wrapper, a
32
+ * Computed, or returns the raw value as-is. This eliminates repetitive
33
+ * `isSignal(x) ? x.value : x` patterns throughout user code.
34
+ *
35
+ * Reading a Signal or Computed via `toValue()` uses `.value`, so the
36
+ * read **does** participate in reactive tracking when called inside
37
+ * an effect or computed.
38
+ *
39
+ * @template T - The underlying value type
40
+ * @param source - A plain value, Signal, bQuery readonly wrapper, or Computed
41
+ * @returns The unwrapped value
42
+ *
43
+ * @example
44
+ * ```ts
45
+ * import { signal, computed, toValue } from '@bquery/bquery/reactive';
46
+ *
47
+ * const count = signal(5);
48
+ * const doubled = computed(() => count.value * 2);
49
+ *
50
+ * toValue(42); // 42
51
+ * toValue(count); // 5
52
+ * toValue(doubled); // 10
53
+ * toValue(null); // null
54
+ * ```
55
+ */
56
+ export declare const toValue: <T>(source: MaybeSignal<T>) => T;
57
+ //# sourceMappingURL=to-value.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"to-value.d.ts","sourceRoot":"","sources":["../../src/reactive/to-value.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AACtC,OAAO,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAChC,OAAO,EAAE,QAAQ,EAAoB,MAAM,YAAY,CAAC;AAExD;;;;;;;;;;;;;;;;;;;;;GAqBG;AACH,MAAM,MAAM,WAAW,CAAC,CAAC,IAAI,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,UAAU,CAAC,OAAO,QAAQ,CAAC,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;AAE1F;;;;;;;;;;;;;;;;;;;;;;;;;GAyBG;AACH,eAAO,MAAM,OAAO,GAAI,CAAC,EAAE,QAAQ,WAAW,CAAC,CAAC,CAAC,KAAG,CAYnD,CAAC"}
@@ -0,0 +1,285 @@
1
+ /**
2
+ * Reactive WebSocket composable with auto-reconnect, heartbeat,
3
+ * message history, and signal-based connection state.
4
+ *
5
+ * @module bquery/reactive
6
+ */
7
+ import { Signal } from './core';
8
+ /** Connection status for a WebSocket. */
9
+ export type WebSocketStatus = 'CONNECTING' | 'OPEN' | 'CLOSING' | 'CLOSED';
10
+ /** Connection status for an EventSource. */
11
+ export type EventSourceStatus = 'CONNECTING' | 'OPEN' | 'CLOSED';
12
+ /** Configuration for automatic reconnection. */
13
+ export interface WebSocketReconnectConfig {
14
+ /** Maximum number of reconnection attempts. Use `0` to disable reconnection (default: Infinity / unlimited). */
15
+ maxAttempts?: number;
16
+ /** Base delay in ms between reconnects (default: 1000). */
17
+ delay?: number;
18
+ /** Maximum delay in ms between reconnects (default: 30000). */
19
+ maxDelay?: number;
20
+ /** Multiply factor for exponential backoff (default: 2). */
21
+ factor?: number;
22
+ /** Custom predicate — return `false` to prevent a reconnect attempt. */
23
+ shouldReconnect?: (event: CloseEvent, attempts: number) => boolean;
24
+ }
25
+ /** Reconnect configuration supported by `useEventSource()`. */
26
+ export type EventSourceReconnectConfig = Pick<WebSocketReconnectConfig, 'maxAttempts' | 'delay' | 'maxDelay' | 'factor'>;
27
+ /** Configuration for keep-alive heartbeats. */
28
+ export interface WebSocketHeartbeatConfig {
29
+ /** Outgoing ping message (default: `'ping'`). */
30
+ message?: string | ArrayBufferLike | Blob | ArrayBufferView;
31
+ /** Interval in ms between heartbeat pings (default: 30 000). */
32
+ interval?: number;
33
+ /** Time in ms to wait for a pong before assuming the connection is dead (default: 10 000). */
34
+ pongTimeout?: number;
35
+ /** Expected response message. If set, only messages matching this value reset the pong timer. */
36
+ responseMessage?: string;
37
+ }
38
+ /** Serializer/deserializer for typed messaging. */
39
+ export interface WebSocketSerializer<TSend = unknown, TReceive = unknown> {
40
+ /** Serialize a value before sending over the wire. Default: `JSON.stringify`. */
41
+ serialize?: (data: TSend) => string | ArrayBufferLike | Blob | ArrayBufferView;
42
+ /** Deserialize an incoming message. Default: `JSON.parse`. */
43
+ deserialize?: (event: MessageEvent) => TReceive;
44
+ }
45
+ /** Full configuration accepted by `useWebSocket()`. */
46
+ export interface UseWebSocketOptions<TSend = unknown, TReceive = unknown> extends WebSocketSerializer<TSend, TReceive> {
47
+ /** Sub-protocols to request during the WebSocket handshake. */
48
+ protocols?: string | string[];
49
+ /** Open the connection immediately (default: true). */
50
+ immediate?: boolean;
51
+ /** Automatically reconnect on unexpected close (default: true). Pass `false` or config. */
52
+ autoReconnect?: boolean | WebSocketReconnectConfig;
53
+ /** Keep-alive heartbeat configuration. Pass `true` for defaults or a config object. */
54
+ heartbeat?: boolean | WebSocketHeartbeatConfig;
55
+ /** Maximum number of messages to keep in `history` (default: 0 = disabled). */
56
+ historySize?: number;
57
+ /** Called when the connection opens. */
58
+ onOpen?: (event: Event) => void;
59
+ /** Called when a message is received (after deserialization). */
60
+ onMessage?: (data: TReceive, event: MessageEvent) => void;
61
+ /** Called when the connection closes. */
62
+ onClose?: (event: CloseEvent) => void;
63
+ /** Called when a connection error occurs. */
64
+ onError?: (event: Event) => void;
65
+ /** Called after a successful reconnection. Receives the reconnection attempt count. */
66
+ onReconnect?: (attempts: number) => void;
67
+ }
68
+ /** Return value of `useWebSocket()`. */
69
+ export interface UseWebSocketReturn<TSend = unknown, TReceive = unknown> {
70
+ /** Reactive connection status. */
71
+ status: {
72
+ readonly value: WebSocketStatus;
73
+ peek(): WebSocketStatus;
74
+ };
75
+ /** Reactive last received message (deserialized). */
76
+ data: Signal<TReceive | undefined>;
77
+ /** Last error event. */
78
+ error: Signal<Event | null>;
79
+ /** Rolling message history (newest last). */
80
+ history: Signal<TReceive[]>;
81
+ /** Computed boolean — `true` when the socket is `OPEN`. */
82
+ isConnected: {
83
+ readonly value: boolean;
84
+ peek(): boolean;
85
+ };
86
+ /** Number of reconnection attempts since last successful open. */
87
+ reconnectAttempts: Signal<number>;
88
+ /** Round-trip latency in ms measured via heartbeat pings (requires `heartbeat` option). */
89
+ latency: Signal<number>;
90
+ /** Timestamp of the last unexpected disconnection, or 0 if never disconnected. */
91
+ lastDisconnectedAt: Signal<number>;
92
+ /**
93
+ * Send a message.
94
+ *
95
+ * If the socket is not `OPEN`, the message is queued and sent once a
96
+ * connection is (re)established, subject to the configured options.
97
+ */
98
+ send: (data: TSend) => void;
99
+ /**
100
+ * Send raw data without serialization.
101
+ *
102
+ * Uses the same queuing behavior as {@link send}: data is queued when the
103
+ * socket is not `OPEN` and flushed once a connection is (re)established.
104
+ */
105
+ sendRaw: (data: string | ArrayBufferLike | Blob | ArrayBufferView) => void;
106
+ /** Manually open / reconnect the WebSocket. */
107
+ open: () => void;
108
+ /** Gracefully close the connection. */
109
+ close: (code?: number, reason?: string) => void;
110
+ /** Tear down all resources (close + remove listeners + stop reconnect/heartbeat). */
111
+ dispose: () => void;
112
+ }
113
+ /**
114
+ * Reactive WebSocket composable with auto-reconnect, heartbeat,
115
+ * typed messaging, and signal-based connection state.
116
+ *
117
+ * @template TSend - Type of outgoing messages (serialized via `serialize`)
118
+ * @template TReceive - Type of incoming messages (deserialized via `deserialize`)
119
+ * @param url - WebSocket URL (`ws://` or `wss://`) or a getter returning one
120
+ * @param options - Connection, reconnect, heartbeat, and serialization options
121
+ * @returns Reactive WebSocket state with `send()`, `open()`, `close()`, and `dispose()`
122
+ *
123
+ * @example
124
+ * ```ts
125
+ * import { useWebSocket } from '@bquery/bquery/reactive';
126
+ *
127
+ * const ws = useWebSocket<{ type: string; payload: unknown }>('wss://api.example.com/ws', {
128
+ * autoReconnect: { maxAttempts: 5, delay: 2000 },
129
+ * heartbeat: true,
130
+ * historySize: 50,
131
+ * onMessage: (data) => console.log('Received:', data),
132
+ * });
133
+ *
134
+ * ws.send({ type: 'subscribe', payload: { channel: 'updates' } });
135
+ *
136
+ * // Reactive state
137
+ * effect(() => {
138
+ * console.log('Connected:', ws.isConnected.value);
139
+ * console.log('Last message:', ws.data.value);
140
+ * });
141
+ *
142
+ * // Cleanup
143
+ * ws.dispose();
144
+ * ```
145
+ */
146
+ export declare const useWebSocket: <TSend = string, TReceive = string>(url: string | URL | (() => string | URL), options?: UseWebSocketOptions<TSend, TReceive>) => UseWebSocketReturn<TSend, TReceive>;
147
+ /** Default channel message format used by `useWebSocketChannel()`. */
148
+ export interface ChannelMessage<T = unknown> {
149
+ /** Channel / topic name. */
150
+ channel: string;
151
+ /** Message payload. */
152
+ data: T;
153
+ }
154
+ /** Configuration for `useWebSocketChannel()`. */
155
+ export interface UseWebSocketChannelOptions<TSend = unknown, TReceive = unknown> {
156
+ /**
157
+ * Extract the channel name from an incoming deserialized message.
158
+ * Default: reads `(msg as ChannelMessage).channel`.
159
+ */
160
+ getChannel?: (msg: TReceive) => string | undefined;
161
+ /**
162
+ * Wrap a payload + channel into the wire format before sending.
163
+ * Default: `{ channel, data }`.
164
+ */
165
+ wrap?: (channel: string, data: TSend) => TReceive;
166
+ }
167
+ /** A single channel subscription returned by `subscribe()`. */
168
+ export interface ChannelSubscription<TReceive = unknown> {
169
+ /** Reactive last message received on this channel. */
170
+ data: Signal<TReceive | undefined>;
171
+ /** Unsubscribe from this channel. */
172
+ unsubscribe: () => void;
173
+ }
174
+ /** Return value of `useWebSocketChannel()`. */
175
+ export interface UseWebSocketChannelReturn<TSend = unknown, TReceive = unknown> {
176
+ /** Subscribe to a topic. Multiple subscriptions to the same channel share a signal. */
177
+ subscribe: (channel: string) => ChannelSubscription<TReceive>;
178
+ /** Publish a message to a channel. */
179
+ publish: (channel: string, data: TSend) => void;
180
+ /** The underlying `useWebSocket` return for direct access. */
181
+ ws: UseWebSocketReturn<TReceive, TReceive>;
182
+ }
183
+ /**
184
+ * Topic-based channel multiplexer over a single WebSocket connection.
185
+ *
186
+ * Builds on `useWebSocket()` and routes incoming messages to per-channel
187
+ * reactive signals based on a configurable channel extractor.
188
+ *
189
+ * @template TSend - Type of outgoing message payloads
190
+ * @template TReceive - Type of incoming deserialized messages
191
+ * @param url - WebSocket URL
192
+ * @param wsOptions - All `useWebSocket` options
193
+ * @param channelOptions - Channel routing configuration
194
+ * @returns Channel multiplexer with `subscribe()`, `publish()`, and the underlying `ws`
195
+ *
196
+ * @example
197
+ * ```ts
198
+ * import { useWebSocketChannel } from '@bquery/bquery/reactive';
199
+ *
200
+ * const chat = useWebSocketChannel('wss://chat.example.com/ws');
201
+ *
202
+ * const general = chat.subscribe('general');
203
+ * const updates = chat.subscribe('updates');
204
+ *
205
+ * effect(() => console.log('General:', general.data.value));
206
+ *
207
+ * chat.publish('general', { text: 'Hello!' });
208
+ * ```
209
+ */
210
+ export declare const useWebSocketChannel: <TSend = unknown, TReceive = unknown>(url: string | URL | (() => string | URL), wsOptions?: UseWebSocketOptions<TReceive, TReceive>, channelOptions?: UseWebSocketChannelOptions<TSend, TReceive>) => UseWebSocketChannelReturn<TSend, TReceive>;
211
+ /** Configuration for `useEventSource()`. */
212
+ export interface UseEventSourceOptions<TData = unknown> {
213
+ /** Whether to open the connection immediately (default: true). */
214
+ immediate?: boolean;
215
+ /** Automatically reconnect on error (default: true). Pass a reconnect config to customize delay and attempt limits. */
216
+ autoReconnect?: boolean | EventSourceReconnectConfig;
217
+ /** Event names to listen for besides the default `message` event. */
218
+ events?: string[];
219
+ /** Deserializer for incoming event data. Default: `JSON.parse` with string fallback. */
220
+ deserialize?: (data: string) => TData;
221
+ /** EventSource init options (e.g. `withCredentials`). */
222
+ eventSourceInit?: EventSourceInit;
223
+ /** Called when the connection opens. */
224
+ onOpen?: (event: Event) => void;
225
+ /** Called when a message is received. */
226
+ onMessage?: (data: TData, event: MessageEvent) => void;
227
+ /** Called when an error occurs. */
228
+ onError?: (event: Event) => void;
229
+ }
230
+ /** Return value of `useEventSource()`. */
231
+ export interface UseEventSourceReturn<TData = unknown> {
232
+ /** Current connection status (`CONNECTING`, `OPEN`, `CLOSED`). */
233
+ status: {
234
+ readonly value: EventSourceStatus;
235
+ peek(): EventSourceStatus;
236
+ };
237
+ /** Last received data (deserialized). */
238
+ data: Signal<TData | undefined>;
239
+ /** Last event name that delivered data. */
240
+ eventName: Signal<string | undefined>;
241
+ /** Last error event. */
242
+ error: Signal<Event | null>;
243
+ /** Computed boolean — `true` when the EventSource is open. */
244
+ isConnected: {
245
+ readonly value: boolean;
246
+ peek(): boolean;
247
+ };
248
+ /** Manually open / reconnect the EventSource. */
249
+ open: () => void;
250
+ /** Close the connection. */
251
+ close: () => void;
252
+ /** Tear down all resources. */
253
+ dispose: () => void;
254
+ }
255
+ /**
256
+ * Reactive Server-Sent Events (SSE) composable.
257
+ *
258
+ * Wraps the native `EventSource` API with reactive signals, auto-reconnect,
259
+ * and typed deserialization.
260
+ *
261
+ * @template TData - Type of deserialized event data
262
+ * @param url - SSE endpoint URL or a getter returning one
263
+ * @param options - EventSource options
264
+ * @returns Reactive EventSource state with `open()`, `close()`, and `dispose()`
265
+ *
266
+ * @example
267
+ * ```ts
268
+ * import { useEventSource } from '@bquery/bquery/reactive';
269
+ *
270
+ * const sse = useEventSource<{ type: string; message: string }>('/api/events', {
271
+ * events: ['notification', 'update'],
272
+ * onMessage: (data) => console.log('Event:', data),
273
+ * });
274
+ *
275
+ * effect(() => {
276
+ * if (sse.data.value) {
277
+ * console.log(`[${sse.eventName.value}]`, sse.data.value);
278
+ * }
279
+ * });
280
+ *
281
+ * sse.dispose();
282
+ * ```
283
+ */
284
+ export declare const useEventSource: <TData = unknown>(url: string | URL | (() => string | URL), options?: UseEventSourceOptions<TData>) => UseEventSourceReturn<TData>;
285
+ //# sourceMappingURL=websocket.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"websocket.d.ts","sourceRoot":"","sources":["../../src/reactive/websocket.ts"],"names":[],"mappings":"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"}