@ersbeth/picoflow 1.1.2 → 2.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (383) hide show
  1. package/.vscode/settings.json +3 -3
  2. package/CHANGELOG.md +43 -0
  3. package/README.md +2 -18
  4. package/biome.json +45 -35
  5. package/dist/picoflow.js +856 -1530
  6. package/dist/types/api/base/flowDisposable.d.ts +41 -0
  7. package/dist/types/api/base/flowDisposable.d.ts.map +1 -0
  8. package/dist/types/api/base/flowObservable.d.ts +27 -0
  9. package/dist/types/api/base/flowObservable.d.ts.map +1 -0
  10. package/dist/types/api/base/flowSubscribable.d.ts +79 -0
  11. package/dist/types/api/base/flowSubscribable.d.ts.map +1 -0
  12. package/dist/types/api/base/flowTracker.d.ts +8 -0
  13. package/dist/types/api/base/flowTracker.d.ts.map +1 -0
  14. package/dist/types/api/base/index.d.ts +5 -0
  15. package/dist/types/api/base/index.d.ts.map +1 -0
  16. package/dist/types/api/index.d.ts +3 -0
  17. package/dist/types/api/index.d.ts.map +1 -0
  18. package/dist/types/api/nodes/async/flowConstantAsync.d.ts +31 -0
  19. package/dist/types/api/nodes/async/flowConstantAsync.d.ts.map +1 -0
  20. package/dist/types/api/nodes/async/flowDerivationAsync.d.ts +37 -0
  21. package/dist/types/api/nodes/async/flowDerivationAsync.d.ts.map +1 -0
  22. package/dist/types/api/nodes/async/flowStateAsync.d.ts +41 -0
  23. package/dist/types/api/nodes/async/flowStateAsync.d.ts.map +1 -0
  24. package/dist/types/api/nodes/async/flowWritableDerivationAsync.d.ts +30 -0
  25. package/dist/types/api/nodes/async/flowWritableDerivationAsync.d.ts.map +1 -0
  26. package/dist/types/{flow → api}/nodes/async/index.d.ts +1 -2
  27. package/dist/types/api/nodes/async/index.d.ts.map +1 -0
  28. package/dist/types/api/nodes/collections/flowArray.d.ts +134 -0
  29. package/dist/types/api/nodes/collections/flowArray.d.ts.map +1 -0
  30. package/dist/types/api/nodes/collections/flowMap.d.ts +98 -0
  31. package/dist/types/api/nodes/collections/flowMap.d.ts.map +1 -0
  32. package/dist/types/api/nodes/collections/index.d.ts.map +1 -0
  33. package/dist/types/api/nodes/flowEffect.d.ts +28 -0
  34. package/dist/types/api/nodes/flowEffect.d.ts.map +1 -0
  35. package/dist/types/api/nodes/flowSignal.d.ts +25 -0
  36. package/dist/types/api/nodes/flowSignal.d.ts.map +1 -0
  37. package/dist/types/api/nodes/flowValue.d.ts +35 -0
  38. package/dist/types/api/nodes/flowValue.d.ts.map +1 -0
  39. package/dist/types/api/nodes/index.d.ts +8 -0
  40. package/dist/types/api/nodes/index.d.ts.map +1 -0
  41. package/dist/types/api/nodes/sync/flowConstant.d.ts +29 -0
  42. package/dist/types/api/nodes/sync/flowConstant.d.ts.map +1 -0
  43. package/dist/types/api/nodes/sync/flowDerivation.d.ts +36 -0
  44. package/dist/types/api/nodes/sync/flowDerivation.d.ts.map +1 -0
  45. package/dist/types/api/nodes/sync/flowState.d.ts +39 -0
  46. package/dist/types/api/nodes/sync/flowState.d.ts.map +1 -0
  47. package/dist/types/api/nodes/sync/flowWritableDerivation.d.ts +28 -0
  48. package/dist/types/api/nodes/sync/flowWritableDerivation.d.ts.map +1 -0
  49. package/dist/types/{flow → api}/nodes/sync/index.d.ts +1 -2
  50. package/dist/types/api/nodes/sync/index.d.ts.map +1 -0
  51. package/dist/types/api/nodes/utils.d.ts +22 -0
  52. package/dist/types/api/nodes/utils.d.ts.map +1 -0
  53. package/dist/types/base/disposable.d.ts +11 -0
  54. package/dist/types/base/disposable.d.ts.map +1 -0
  55. package/dist/types/base/executionStack.d.ts +14 -0
  56. package/dist/types/base/executionStack.d.ts.map +1 -0
  57. package/dist/types/base/index.d.ts +6 -0
  58. package/dist/types/base/index.d.ts.map +1 -0
  59. package/dist/types/base/node.d.ts +27 -0
  60. package/dist/types/base/node.d.ts.map +1 -0
  61. package/dist/types/base/observable.d.ts +37 -0
  62. package/dist/types/base/observable.d.ts.map +1 -0
  63. package/dist/types/base/observer.d.ts +25 -0
  64. package/dist/types/base/observer.d.ts.map +1 -0
  65. package/dist/types/converters/index.d.ts +2 -0
  66. package/dist/types/converters/index.d.ts.map +1 -0
  67. package/dist/types/converters/solid.d.ts +46 -0
  68. package/dist/types/converters/solid.d.ts.map +1 -0
  69. package/dist/types/index.d.ts +2 -63
  70. package/dist/types/index.d.ts.map +1 -1
  71. package/dist/types/nodes/arrayNode.d.ts +2 -0
  72. package/dist/types/nodes/arrayNode.d.ts.map +1 -0
  73. package/dist/types/nodes/effectNode.d.ts +2 -0
  74. package/dist/types/nodes/effectNode.d.ts.map +1 -0
  75. package/dist/types/nodes/index.d.ts +9 -0
  76. package/dist/types/nodes/index.d.ts.map +1 -0
  77. package/dist/types/nodes/mapNode.d.ts +2 -0
  78. package/dist/types/nodes/mapNode.d.ts.map +1 -0
  79. package/dist/types/nodes/signalNode.d.ts +2 -0
  80. package/dist/types/nodes/signalNode.d.ts.map +1 -0
  81. package/dist/types/nodes/valueAsyncNode.d.ts +2 -0
  82. package/dist/types/nodes/valueAsyncNode.d.ts.map +1 -0
  83. package/dist/types/nodes/valueNode.d.ts +2 -0
  84. package/dist/types/nodes/valueNode.d.ts.map +1 -0
  85. package/dist/types/nodes/valueSyncNode.d.ts +2 -0
  86. package/dist/types/nodes/valueSyncNode.d.ts.map +1 -0
  87. package/dist/types/schedulers/asyncResolver.d.ts +2 -0
  88. package/dist/types/schedulers/asyncResolver.d.ts.map +1 -0
  89. package/dist/types/schedulers/asyncScheduler.d.ts +2 -0
  90. package/dist/types/schedulers/asyncScheduler.d.ts.map +1 -0
  91. package/dist/types/schedulers/index.d.ts +5 -0
  92. package/dist/types/schedulers/index.d.ts.map +1 -0
  93. package/dist/types/schedulers/pendingError.d.ts +2 -0
  94. package/dist/types/schedulers/pendingError.d.ts.map +1 -0
  95. package/dist/types/schedulers/scheduler.d.ts +2 -0
  96. package/dist/types/schedulers/scheduler.d.ts.map +1 -0
  97. package/dist/types/schedulers/syncResolver.d.ts +2 -0
  98. package/dist/types/schedulers/syncResolver.d.ts.map +1 -0
  99. package/dist/types/schedulers/syncScheduler.d.ts +2 -0
  100. package/dist/types/schedulers/syncScheduler.d.ts.map +1 -0
  101. package/docs/.vitepress/config.mts +128 -93
  102. package/docs/api/functions/array.md +14 -37
  103. package/docs/api/functions/constant.md +13 -25
  104. package/docs/api/functions/constantAsync.md +69 -0
  105. package/docs/api/functions/derivation.md +14 -33
  106. package/docs/api/functions/derivationAsync.md +34 -0
  107. package/docs/api/functions/from.md +62 -153
  108. package/docs/api/functions/isDisposable.md +8 -30
  109. package/docs/api/functions/map.md +15 -36
  110. package/docs/api/functions/signal.md +8 -23
  111. package/docs/api/functions/state.md +43 -23
  112. package/docs/api/functions/stateAsync.md +69 -0
  113. package/docs/api/functions/subscribe.md +40 -0
  114. package/docs/api/functions/writableDerivation.md +33 -0
  115. package/docs/api/functions/writableDerivationAsync.md +34 -0
  116. package/docs/api/index.md +45 -102
  117. package/docs/api/interfaces/FlowArray.md +439 -0
  118. package/docs/api/interfaces/FlowConstant.md +220 -0
  119. package/docs/api/interfaces/FlowConstantAsync.md +221 -0
  120. package/docs/api/interfaces/FlowDerivation.md +241 -0
  121. package/docs/api/interfaces/FlowDerivationAsync.md +242 -0
  122. package/docs/api/interfaces/FlowDisposable.md +32 -38
  123. package/docs/api/interfaces/FlowEffect.md +64 -0
  124. package/docs/api/interfaces/FlowMap.md +374 -0
  125. package/docs/api/interfaces/FlowObservable.md +155 -0
  126. package/docs/api/interfaces/FlowSignal.md +156 -0
  127. package/docs/api/interfaces/FlowState.md +269 -0
  128. package/docs/api/interfaces/FlowStateAsync.md +268 -0
  129. package/docs/api/interfaces/FlowSubscribable.md +55 -0
  130. package/docs/api/interfaces/FlowTracker.md +61 -0
  131. package/docs/api/interfaces/FlowValue.md +222 -0
  132. package/docs/api/interfaces/FlowWritableDerivation.md +292 -0
  133. package/docs/api/interfaces/FlowWritableDerivationAsync.md +293 -0
  134. package/docs/api/type-aliases/DerivationFunction.md +28 -0
  135. package/docs/api/type-aliases/DerivationFunctionAsync.md +28 -0
  136. package/docs/api/type-aliases/FlowArrayAction.md +19 -8
  137. package/docs/api/type-aliases/FlowDataTracker.md +33 -0
  138. package/docs/api/type-aliases/FlowMapAction.md +48 -0
  139. package/docs/api/type-aliases/FlowOnDataListener.md +33 -0
  140. package/docs/api/type-aliases/FlowOnErrorListener.md +27 -0
  141. package/docs/api/type-aliases/FlowOnPendingListener.md +21 -0
  142. package/docs/api/type-aliases/FlowReadonly.md +22 -0
  143. package/docs/api/type-aliases/InitFunction.md +21 -0
  144. package/docs/api/type-aliases/InitFunctionAsync.md +21 -0
  145. package/docs/api/type-aliases/NotPromise.md +6 -3
  146. package/docs/api/type-aliases/UpdateFunction.md +27 -0
  147. package/docs/api/type-aliases/UpdateFunctionAsync.md +27 -0
  148. package/docs/api/typedoc-sidebar.json +1 -81
  149. package/docs/examples/examples.md +0 -2
  150. package/docs/guide/advanced/architecture.md +1234 -0
  151. package/docs/guide/advanced/migration-v2.md +204 -0
  152. package/docs/guide/advanced/solidjs.md +2 -88
  153. package/docs/guide/introduction/concepts.md +4 -3
  154. package/docs/guide/introduction/conventions.md +2 -33
  155. package/docs/guide/introduction/getting-started.md +28 -23
  156. package/docs/guide/introduction/lifecycle.md +16 -19
  157. package/docs/guide/primitives/array.md +102 -216
  158. package/docs/guide/primitives/constant.md +39 -212
  159. package/docs/guide/primitives/derivations.md +55 -122
  160. package/docs/guide/primitives/effects.md +155 -241
  161. package/docs/guide/primitives/map.md +64 -186
  162. package/docs/guide/primitives/overview.md +45 -128
  163. package/docs/guide/primitives/signal.md +51 -88
  164. package/docs/guide/primitives/state.md +34 -130
  165. package/package.json +56 -60
  166. package/src/api/base/flowDisposable.ts +44 -0
  167. package/src/api/base/flowObservable.ts +28 -0
  168. package/src/api/base/flowSubscribable.ts +87 -0
  169. package/src/api/base/flowTracker.ts +7 -0
  170. package/src/api/base/index.ts +4 -0
  171. package/src/{flow → api}/index.ts +0 -1
  172. package/src/api/nodes/async/flowConstantAsync.ts +36 -0
  173. package/src/api/nodes/async/flowDerivationAsync.ts +42 -0
  174. package/src/api/nodes/async/flowStateAsync.ts +47 -0
  175. package/src/api/nodes/async/flowWritableDerivationAsync.ts +33 -0
  176. package/src/{flow → api}/nodes/async/index.ts +1 -2
  177. package/src/api/nodes/collections/flowArray.ts +155 -0
  178. package/src/api/nodes/collections/flowMap.ts +115 -0
  179. package/src/api/nodes/flowEffect.ts +42 -0
  180. package/src/api/nodes/flowSignal.ts +28 -0
  181. package/src/api/nodes/flowValue.ts +36 -0
  182. package/src/api/nodes/index.ts +7 -0
  183. package/src/api/nodes/sync/flowConstant.ts +33 -0
  184. package/src/api/nodes/sync/flowDerivation.ts +41 -0
  185. package/src/api/nodes/sync/flowState.ts +45 -0
  186. package/src/api/nodes/sync/flowWritableDerivation.ts +31 -0
  187. package/src/{flow → api}/nodes/sync/index.ts +1 -2
  188. package/src/api/nodes/utils.ts +22 -0
  189. package/src/base/disposable.ts +18 -0
  190. package/src/base/executionStack.ts +42 -0
  191. package/src/base/index.ts +5 -0
  192. package/src/base/node.ts +98 -0
  193. package/src/base/observable.ts +87 -0
  194. package/src/base/observer.ts +51 -0
  195. package/src/converters/index.ts +1 -0
  196. package/src/converters/solid.ts +109 -0
  197. package/src/index.ts +2 -64
  198. package/src/nodes/arrayNode.ts +172 -0
  199. package/src/nodes/effectNode.ts +59 -0
  200. package/src/nodes/index.ts +8 -0
  201. package/src/nodes/mapNode.ts +127 -0
  202. package/src/nodes/signalNode.ts +21 -0
  203. package/src/nodes/valueAsyncNode.ts +88 -0
  204. package/src/nodes/valueNode.ts +144 -0
  205. package/src/nodes/valueSyncNode.ts +128 -0
  206. package/src/schedulers/asyncResolver.ts +78 -0
  207. package/src/schedulers/asyncScheduler.ts +66 -0
  208. package/src/schedulers/index.ts +4 -0
  209. package/src/schedulers/pendingError.ts +13 -0
  210. package/src/schedulers/scheduler.ts +9 -0
  211. package/src/schedulers/syncResolver.ts +69 -0
  212. package/src/schedulers/syncScheduler.ts +55 -0
  213. package/test/base/pendingError.test.ts +67 -0
  214. package/test/converters/solid.derivation.browser.test.tsx +69 -0
  215. package/test/converters/solid.node.test.ts +654 -0
  216. package/test/converters/solid.state.browser.test.tsx +1592 -0
  217. package/test/reactivity/flowSignal.test.ts +226 -0
  218. package/test/reactivity/nodes/async/asyncScheduler/asyncResolver.test.ts +593 -0
  219. package/test/reactivity/nodes/async/asyncScheduler/asyncScheduler.test.ts +317 -0
  220. package/test/reactivity/nodes/async/flowConstantAsync.test.ts +652 -0
  221. package/test/reactivity/nodes/async/flowDerivation.test.ts +898 -0
  222. package/test/reactivity/nodes/async/flowDerivationAsync.test.ts +1716 -0
  223. package/test/reactivity/nodes/async/flowStateAsync.test.ts +708 -0
  224. package/test/reactivity/nodes/async/flowWritableDerivationAsync.test.ts +614 -0
  225. package/test/reactivity/nodes/collections/flowArray.asyncStates.test.ts +1289 -0
  226. package/test/reactivity/nodes/collections/flowArray.scalars.test.ts +961 -0
  227. package/test/reactivity/nodes/collections/flowArray.states.test.ts +1035 -0
  228. package/test/reactivity/nodes/collections/flowMap.asyncStates.test.ts +960 -0
  229. package/test/reactivity/nodes/collections/flowMap.scalars.test.ts +775 -0
  230. package/test/reactivity/nodes/collections/flowMap.states.test.ts +958 -0
  231. package/test/reactivity/nodes/sync/flowConstant.test.ts +377 -0
  232. package/test/reactivity/nodes/sync/flowDerivation.test.ts +896 -0
  233. package/test/reactivity/nodes/sync/flowState.test.ts +341 -0
  234. package/test/reactivity/nodes/sync/flowWritableDerivation.test.ts +603 -0
  235. package/test/vitest.d.ts +10 -0
  236. package/tsconfig.json +31 -20
  237. package/typedoc.json +35 -35
  238. package/vite.config.ts +25 -23
  239. package/vitest.browser.config.ts +21 -0
  240. package/vitest.config.ts +12 -12
  241. package/.cursor/plans/unifier-flowresource-avec-flowderivation-c9506e24.plan.md +0 -372
  242. package/.cursor/plans/update-js-e795d61b.plan.md +0 -567
  243. package/dist/types/flow/base/flowDisposable.d.ts +0 -67
  244. package/dist/types/flow/base/flowDisposable.d.ts.map +0 -1
  245. package/dist/types/flow/base/flowEffect.d.ts +0 -127
  246. package/dist/types/flow/base/flowEffect.d.ts.map +0 -1
  247. package/dist/types/flow/base/flowGraph.d.ts +0 -97
  248. package/dist/types/flow/base/flowGraph.d.ts.map +0 -1
  249. package/dist/types/flow/base/flowSignal.d.ts +0 -134
  250. package/dist/types/flow/base/flowSignal.d.ts.map +0 -1
  251. package/dist/types/flow/base/flowTracker.d.ts +0 -15
  252. package/dist/types/flow/base/flowTracker.d.ts.map +0 -1
  253. package/dist/types/flow/base/index.d.ts +0 -7
  254. package/dist/types/flow/base/index.d.ts.map +0 -1
  255. package/dist/types/flow/base/utils.d.ts +0 -20
  256. package/dist/types/flow/base/utils.d.ts.map +0 -1
  257. package/dist/types/flow/collections/flowArray.d.ts +0 -148
  258. package/dist/types/flow/collections/flowArray.d.ts.map +0 -1
  259. package/dist/types/flow/collections/flowMap.d.ts +0 -224
  260. package/dist/types/flow/collections/flowMap.d.ts.map +0 -1
  261. package/dist/types/flow/collections/index.d.ts.map +0 -1
  262. package/dist/types/flow/index.d.ts +0 -4
  263. package/dist/types/flow/index.d.ts.map +0 -1
  264. package/dist/types/flow/nodes/async/flowConstantAsync.d.ts +0 -137
  265. package/dist/types/flow/nodes/async/flowConstantAsync.d.ts.map +0 -1
  266. package/dist/types/flow/nodes/async/flowDerivationAsync.d.ts +0 -137
  267. package/dist/types/flow/nodes/async/flowDerivationAsync.d.ts.map +0 -1
  268. package/dist/types/flow/nodes/async/flowNodeAsync.d.ts +0 -343
  269. package/dist/types/flow/nodes/async/flowNodeAsync.d.ts.map +0 -1
  270. package/dist/types/flow/nodes/async/flowReadonlyAsync.d.ts +0 -81
  271. package/dist/types/flow/nodes/async/flowReadonlyAsync.d.ts.map +0 -1
  272. package/dist/types/flow/nodes/async/flowStateAsync.d.ts +0 -111
  273. package/dist/types/flow/nodes/async/flowStateAsync.d.ts.map +0 -1
  274. package/dist/types/flow/nodes/async/index.d.ts.map +0 -1
  275. package/dist/types/flow/nodes/index.d.ts +0 -3
  276. package/dist/types/flow/nodes/index.d.ts.map +0 -1
  277. package/dist/types/flow/nodes/sync/flowConstant.d.ts +0 -108
  278. package/dist/types/flow/nodes/sync/flowConstant.d.ts.map +0 -1
  279. package/dist/types/flow/nodes/sync/flowDerivation.d.ts +0 -100
  280. package/dist/types/flow/nodes/sync/flowDerivation.d.ts.map +0 -1
  281. package/dist/types/flow/nodes/sync/flowNode.d.ts +0 -314
  282. package/dist/types/flow/nodes/sync/flowNode.d.ts.map +0 -1
  283. package/dist/types/flow/nodes/sync/flowReadonly.d.ts +0 -57
  284. package/dist/types/flow/nodes/sync/flowReadonly.d.ts.map +0 -1
  285. package/dist/types/flow/nodes/sync/flowState.d.ts +0 -96
  286. package/dist/types/flow/nodes/sync/flowState.d.ts.map +0 -1
  287. package/dist/types/flow/nodes/sync/index.d.ts.map +0 -1
  288. package/dist/types/solid/converters.d.ts +0 -57
  289. package/dist/types/solid/converters.d.ts.map +0 -1
  290. package/dist/types/solid/index.d.ts +0 -3
  291. package/dist/types/solid/index.d.ts.map +0 -1
  292. package/dist/types/solid/primitives.d.ts +0 -181
  293. package/dist/types/solid/primitives.d.ts.map +0 -1
  294. package/docs/api/classes/FlowArray.md +0 -489
  295. package/docs/api/classes/FlowConstant.md +0 -350
  296. package/docs/api/classes/FlowDerivation.md +0 -334
  297. package/docs/api/classes/FlowEffect.md +0 -100
  298. package/docs/api/classes/FlowMap.md +0 -512
  299. package/docs/api/classes/FlowObservable.md +0 -306
  300. package/docs/api/classes/FlowResource.md +0 -380
  301. package/docs/api/classes/FlowResourceAsync.md +0 -362
  302. package/docs/api/classes/FlowSignal.md +0 -160
  303. package/docs/api/classes/FlowState.md +0 -368
  304. package/docs/api/classes/FlowStream.md +0 -367
  305. package/docs/api/classes/FlowStreamAsync.md +0 -364
  306. package/docs/api/classes/SolidDerivation.md +0 -75
  307. package/docs/api/classes/SolidResource.md +0 -91
  308. package/docs/api/classes/SolidState.md +0 -71
  309. package/docs/api/classes/TrackingContext.md +0 -33
  310. package/docs/api/functions/effect.md +0 -49
  311. package/docs/api/functions/resource.md +0 -52
  312. package/docs/api/functions/resourceAsync.md +0 -50
  313. package/docs/api/functions/stream.md +0 -53
  314. package/docs/api/functions/streamAsync.md +0 -50
  315. package/docs/api/interfaces/SolidObservable.md +0 -19
  316. package/docs/api/type-aliases/FlowStreamDisposer.md +0 -15
  317. package/docs/api/type-aliases/FlowStreamSetter.md +0 -27
  318. package/docs/api/type-aliases/FlowStreamUpdater.md +0 -32
  319. package/docs/api/type-aliases/SolidGetter.md +0 -17
  320. package/docs/guide/primitives/resources.md +0 -858
  321. package/docs/guide/primitives/streams.md +0 -931
  322. package/src/flow/base/flowDisposable.ts +0 -71
  323. package/src/flow/base/flowEffect.ts +0 -171
  324. package/src/flow/base/flowGraph.ts +0 -288
  325. package/src/flow/base/flowSignal.ts +0 -207
  326. package/src/flow/base/flowTracker.ts +0 -17
  327. package/src/flow/base/index.ts +0 -6
  328. package/src/flow/base/utils.ts +0 -19
  329. package/src/flow/collections/flowArray.ts +0 -409
  330. package/src/flow/collections/flowMap.ts +0 -398
  331. package/src/flow/nodes/async/flowConstantAsync.ts +0 -142
  332. package/src/flow/nodes/async/flowDerivationAsync.ts +0 -143
  333. package/src/flow/nodes/async/flowNodeAsync.ts +0 -474
  334. package/src/flow/nodes/async/flowReadonlyAsync.ts +0 -81
  335. package/src/flow/nodes/async/flowStateAsync.ts +0 -116
  336. package/src/flow/nodes/await/advanced/index.ts +0 -5
  337. package/src/flow/nodes/await/advanced/resource.ts +0 -134
  338. package/src/flow/nodes/await/advanced/resourceAsync.ts +0 -109
  339. package/src/flow/nodes/await/advanced/stream.ts +0 -188
  340. package/src/flow/nodes/await/advanced/streamAsync.ts +0 -176
  341. package/src/flow/nodes/await/flowConstantAwait.ts +0 -154
  342. package/src/flow/nodes/await/flowDerivationAwait.ts +0 -154
  343. package/src/flow/nodes/await/flowNodeAwait.ts +0 -508
  344. package/src/flow/nodes/await/flowReadonlyAwait.ts +0 -89
  345. package/src/flow/nodes/await/flowStateAwait.ts +0 -130
  346. package/src/flow/nodes/await/index.ts +0 -5
  347. package/src/flow/nodes/index.ts +0 -3
  348. package/src/flow/nodes/sync/flowConstant.ts +0 -111
  349. package/src/flow/nodes/sync/flowDerivation.ts +0 -105
  350. package/src/flow/nodes/sync/flowNode.ts +0 -439
  351. package/src/flow/nodes/sync/flowReadonly.ts +0 -57
  352. package/src/flow/nodes/sync/flowState.ts +0 -101
  353. package/src/solid/converters.ts +0 -148
  354. package/src/solid/index.ts +0 -2
  355. package/src/solid/primitives.ts +0 -215
  356. package/test/base/flowEffect.test.ts +0 -108
  357. package/test/base/flowGraph.test.ts +0 -485
  358. package/test/base/flowSignal.test.ts +0 -372
  359. package/test/collections/flowArray.asyncStates.test.ts +0 -1553
  360. package/test/collections/flowArray.scalars.test.ts +0 -1129
  361. package/test/collections/flowArray.states.test.ts +0 -1365
  362. package/test/collections/flowMap.asyncStates.test.ts +0 -1105
  363. package/test/collections/flowMap.scalars.test.ts +0 -877
  364. package/test/collections/flowMap.states.test.ts +0 -1097
  365. package/test/nodes/async/flowConstantAsync.test.ts +0 -860
  366. package/test/nodes/async/flowDerivationAsync.test.ts +0 -1517
  367. package/test/nodes/async/flowStateAsync.test.ts +0 -1387
  368. package/test/nodes/await/advanced/resource.test.ts +0 -129
  369. package/test/nodes/await/advanced/resourceAsync.test.ts +0 -108
  370. package/test/nodes/await/advanced/stream.test.ts +0 -198
  371. package/test/nodes/await/advanced/streamAsync.test.ts +0 -196
  372. package/test/nodes/await/flowConstantAwait.test.ts +0 -643
  373. package/test/nodes/await/flowDerivationAwait.test.ts +0 -1583
  374. package/test/nodes/await/flowStateAwait.test.ts +0 -999
  375. package/test/nodes/mixed/derivation.test.ts +0 -1527
  376. package/test/nodes/sync/flowConstant.test.ts +0 -620
  377. package/test/nodes/sync/flowDerivation.test.ts +0 -1373
  378. package/test/nodes/sync/flowState.test.ts +0 -945
  379. package/test/solid/converters.test.ts +0 -721
  380. package/test/solid/primitives.test.ts +0 -1031
  381. /package/dist/types/{flow → api/nodes}/collections/index.d.ts +0 -0
  382. /package/docs/guide/advanced/{upgrading.md → migration-v1.md} +0 -0
  383. /package/src/{flow → api/nodes}/collections/index.ts +0 -0
@@ -0,0 +1,269 @@
1
+ [@ersbeth/picoflow](/api/index.md) / FlowState
2
+
3
+ # Interface: FlowState\<T\>
4
+
5
+ Defined in: [api/nodes/sync/flowState.ts:18](https://gitlab.com/ersbeth-web/picoflow/-/blob/4e864254f0eac72524c3be40b9e41d799a16e020/src/api/nodes/sync/flowState.ts#L18)
6
+
7
+ Writable reactive value that can be updated manually and notifies dependents on changes.
8
+
9
+ State is the simplest writable reactive primitive. Unlike derivations, it has no dependencies and never
10
+ recomputes automatically - changes only occur when you explicitly call `set()`. Use state for user input,
11
+ application state, or any data that changes imperatively. Changes propagate automatically to all dependents.
12
+
13
+ ## Extends
14
+
15
+ - [`FlowValue`](/api/interfaces/FlowValue.md)\<`T`\>
16
+
17
+ ## Extended by
18
+
19
+ - [`FlowArray`](/api/interfaces/FlowArray.md)
20
+ - [`FlowMap`](/api/interfaces/FlowMap.md)
21
+ - [`FlowWritableDerivation`](/api/interfaces/FlowWritableDerivation.md)
22
+
23
+ ## Type Parameters
24
+
25
+ | Type Parameter |
26
+ | ------ |
27
+ | `T` |
28
+
29
+ ## Accessors
30
+
31
+ ### disposed
32
+
33
+ #### Get Signature
34
+
35
+ ```ts
36
+ get disposed(): boolean;
37
+ ```
38
+
39
+ Defined in: [api/base/flowDisposable.ts:17](https://gitlab.com/ersbeth-web/picoflow/-/blob/4e864254f0eac72524c3be40b9e41d799a16e020/src/api/base/flowDisposable.ts#L17)
40
+
41
+ Indicates whether this resource has been disposed.
42
+
43
+ Returns `true` if `dispose()` has been called, `false` otherwise. Once disposed,
44
+ the resource is no longer usable and any operations on it will throw errors.
45
+
46
+ ##### Returns
47
+
48
+ `boolean`
49
+
50
+ #### Inherited from
51
+
52
+ [`FlowValue`](/api/interfaces/FlowValue.md).[`disposed`](/api/interfaces/FlowValue.md#disposed)
53
+
54
+ ## Methods
55
+
56
+ ### dispose()
57
+
58
+ ```ts
59
+ dispose(): void;
60
+ ```
61
+
62
+ Defined in: [api/base/flowDisposable.ts:27](https://gitlab.com/ersbeth-web/picoflow/-/blob/4e864254f0eac72524c3be40b9e41d799a16e020/src/api/base/flowDisposable.ts#L27)
63
+
64
+ Releases all resources held by this disposable object.
65
+
66
+ Cleans up all subscriptions, dependencies, and internal state. After calling this method,
67
+ the resource enters a disposed state and cannot be reused. Any subsequent operations will
68
+ throw errors. This method should be called when you no longer need the reactive primitive
69
+ to prevent memory leaks.
70
+
71
+ #### Returns
72
+
73
+ `void`
74
+
75
+ #### Inherited from
76
+
77
+ [`FlowValue`](/api/interfaces/FlowValue.md).[`dispose`](/api/interfaces/FlowValue.md#dispose)
78
+
79
+ ***
80
+
81
+ ### get()
82
+
83
+ ```ts
84
+ get(tracker): T;
85
+ ```
86
+
87
+ Defined in: [api/nodes/flowValue.ts:24](https://gitlab.com/ersbeth-web/picoflow/-/blob/4e864254f0eac72524c3be40b9e41d799a16e020/src/api/nodes/flowValue.ts#L24)
88
+
89
+ Gets the current value and establishes a reactive dependency.
90
+
91
+ When called from within a reactive computation, this method registers the value as a dependency,
92
+ ensuring the computation re-executes when the value changes. The value is computed on first access
93
+ (if lazy) and then cached. For async values, throws PendingError while the value is resolving.
94
+
95
+ #### Parameters
96
+
97
+ | Parameter | Type | Description |
98
+ | ------ | ------ | ------ |
99
+ | `tracker` | [`FlowTracker`](/api/interfaces/FlowTracker.md) | Tracker that records this value as a dependency |
100
+
101
+ #### Returns
102
+
103
+ `T`
104
+
105
+ The current value
106
+
107
+ #### Inherited from
108
+
109
+ [`FlowValue`](/api/interfaces/FlowValue.md).[`get`](/api/interfaces/FlowValue.md#get)
110
+
111
+ ***
112
+
113
+ ### pick()
114
+
115
+ ```ts
116
+ pick(): Promise<T>;
117
+ ```
118
+
119
+ Defined in: [api/nodes/flowValue.ts:35](https://gitlab.com/ersbeth-web/picoflow/-/blob/4e864254f0eac72524c3be40b9e41d799a16e020/src/api/nodes/flowValue.ts#L35)
120
+
121
+ Asynchronously gets the current value without establishing a reactive dependency.
122
+
123
+ This method reads the value non-reactively, meaning it won't trigger re-execution of the calling
124
+ computation when the value changes. The value is computed on first access (if lazy) and then cached.
125
+ For async values, the promise resolves once the value is available.
126
+
127
+ #### Returns
128
+
129
+ `Promise`\<`T`\>
130
+
131
+ Promise that resolves with the current value
132
+
133
+ #### Inherited from
134
+
135
+ [`FlowValue`](/api/interfaces/FlowValue.md).[`pick`](/api/interfaces/FlowValue.md#pick)
136
+
137
+ ***
138
+
139
+ ### set()
140
+
141
+ #### Call Signature
142
+
143
+ ```ts
144
+ set(value): void;
145
+ ```
146
+
147
+ Defined in: [api/nodes/sync/flowState.ts:25](https://gitlab.com/ersbeth-web/picoflow/-/blob/4e864254f0eac72524c3be40b9e41d799a16e020/src/api/nodes/sync/flowState.ts#L25)
148
+
149
+ Updates the state with a new value or via an updater function.
150
+ Notifies all dependents after the update.
151
+
152
+ ##### Parameters
153
+
154
+ | Parameter | Type | Description |
155
+ | ------ | ------ | ------ |
156
+ | `value` | [`NotPromise`](/api/type-aliases/NotPromise.md)\<`T`\> | New value to set, or function that receives current value and returns new value |
157
+
158
+ ##### Returns
159
+
160
+ `void`
161
+
162
+ #### Call Signature
163
+
164
+ ```ts
165
+ set(updater): void;
166
+ ```
167
+
168
+ Defined in: [api/nodes/sync/flowState.ts:26](https://gitlab.com/ersbeth-web/picoflow/-/blob/4e864254f0eac72524c3be40b9e41d799a16e020/src/api/nodes/sync/flowState.ts#L26)
169
+
170
+ ##### Parameters
171
+
172
+ | Parameter | Type |
173
+ | ------ | ------ |
174
+ | `updater` | [`UpdateFunction`](/api/type-aliases/UpdateFunction.md)\<`T`\> |
175
+
176
+ ##### Returns
177
+
178
+ `void`
179
+
180
+ ***
181
+
182
+ ### subscribe()
183
+
184
+ ```ts
185
+ subscribe(
186
+ onData,
187
+ onError?,
188
+ onPending?): FlowEffect;
189
+ ```
190
+
191
+ Defined in: [api/base/flowSubscribable.ts:82](https://gitlab.com/ersbeth-web/picoflow/-/blob/4e864254f0eac72524c3be40b9e41d799a16e020/src/api/base/flowSubscribable.ts#L82)
192
+
193
+ Subscribes to this observable with lifecycle callbacks.
194
+
195
+ Creates an active subscription that executes immediately and then re-executes whenever
196
+ the observable's dependencies change. The subscription remains active until the returned
197
+ disposal function is called. The `onData` callback receives the computed value, while
198
+ `onError` handles errors and `onPending` signals async operations in progress.
199
+
200
+ #### Parameters
201
+
202
+ | Parameter | Type | Description |
203
+ | ------ | ------ | ------ |
204
+ | `onData` | [`FlowOnDataListener`](/api/type-aliases/FlowOnDataListener.md)\<`T`\> | Callback invoked with the computed data on each execution |
205
+ | `onError?` | [`FlowOnErrorListener`](/api/type-aliases/FlowOnErrorListener.md) | Optional callback for handling errors during execution |
206
+ | `onPending?` | [`FlowOnPendingListener`](/api/type-aliases/FlowOnPendingListener.md) | Optional callback invoked when async dependencies are pending |
207
+
208
+ #### Returns
209
+
210
+ [`FlowEffect`](/api/interfaces/FlowEffect.md)
211
+
212
+ A function to dispose the subscription and stop receiving updates
213
+
214
+ #### Inherited from
215
+
216
+ [`FlowValue`](/api/interfaces/FlowValue.md).[`subscribe`](/api/interfaces/FlowValue.md#subscribe)
217
+
218
+ ***
219
+
220
+ ### trigger()
221
+
222
+ ```ts
223
+ trigger(): void;
224
+ ```
225
+
226
+ Defined in: [api/base/flowObservable.ts:27](https://gitlab.com/ersbeth-web/picoflow/-/blob/4e864254f0eac72524c3be40b9e41d799a16e020/src/api/base/flowObservable.ts#L27)
227
+
228
+ Manually triggers notifications to all dependents.
229
+
230
+ Forces all dependents of this observable to be notified and re-executed, even if the
231
+ value hasn't actually changed. Useful for imperatively triggering updates when the
232
+ reactive system cannot detect changes automatically.
233
+
234
+ #### Returns
235
+
236
+ `void`
237
+
238
+ #### Inherited from
239
+
240
+ [`FlowValue`](/api/interfaces/FlowValue.md).[`trigger`](/api/interfaces/FlowValue.md#trigger)
241
+
242
+ ***
243
+
244
+ ### watch()
245
+
246
+ ```ts
247
+ watch(tracker): void;
248
+ ```
249
+
250
+ Defined in: [api/base/flowObservable.ts:18](https://gitlab.com/ersbeth-web/picoflow/-/blob/4e864254f0eac72524c3be40b9e41d799a16e020/src/api/base/flowObservable.ts#L18)
251
+
252
+ Establishes a reactive dependency without reading the value.
253
+
254
+ Registers this observable as a dependency of the given tracker, allowing it to be notified
255
+ when changes occur. This enables dependency tracking without accessing the actual value.
256
+
257
+ #### Parameters
258
+
259
+ | Parameter | Type | Description |
260
+ | ------ | ------ | ------ |
261
+ | `tracker` | [`FlowTracker`](/api/interfaces/FlowTracker.md) | Tracker that records this observable as a dependency |
262
+
263
+ #### Returns
264
+
265
+ `void`
266
+
267
+ #### Inherited from
268
+
269
+ [`FlowValue`](/api/interfaces/FlowValue.md).[`watch`](/api/interfaces/FlowValue.md#watch)
@@ -0,0 +1,268 @@
1
+ [@ersbeth/picoflow](/api/index.md) / FlowStateAsync
2
+
3
+ # Interface: FlowStateAsync\<T\>
4
+
5
+ Defined in: [api/nodes/async/flowStateAsync.ts:19](https://gitlab.com/ersbeth-web/picoflow/-/blob/4e864254f0eac72524c3be40b9e41d799a16e020/src/api/nodes/async/flowStateAsync.ts#L19)
6
+
7
+ Writable reactive value that resolves promises and can be updated with new promises.
8
+
9
+ Async state is the async equivalent of regular state. Unlike sync state, it accepts promises instead of
10
+ direct values. Set new promises or async updater functions to update the state. While a promise is pending,
11
+ accessing the value throws PendingError. Use for async data that changes imperatively, such as user-triggered
12
+ API calls, async form submissions, or any async operation that updates based on user actions.
13
+
14
+ ## Extends
15
+
16
+ - [`FlowValue`](/api/interfaces/FlowValue.md)\<`T`\>
17
+
18
+ ## Extended by
19
+
20
+ - [`FlowWritableDerivationAsync`](/api/interfaces/FlowWritableDerivationAsync.md)
21
+
22
+ ## Type Parameters
23
+
24
+ | Type Parameter |
25
+ | ------ |
26
+ | `T` |
27
+
28
+ ## Accessors
29
+
30
+ ### disposed
31
+
32
+ #### Get Signature
33
+
34
+ ```ts
35
+ get disposed(): boolean;
36
+ ```
37
+
38
+ Defined in: [api/base/flowDisposable.ts:17](https://gitlab.com/ersbeth-web/picoflow/-/blob/4e864254f0eac72524c3be40b9e41d799a16e020/src/api/base/flowDisposable.ts#L17)
39
+
40
+ Indicates whether this resource has been disposed.
41
+
42
+ Returns `true` if `dispose()` has been called, `false` otherwise. Once disposed,
43
+ the resource is no longer usable and any operations on it will throw errors.
44
+
45
+ ##### Returns
46
+
47
+ `boolean`
48
+
49
+ #### Inherited from
50
+
51
+ [`FlowValue`](/api/interfaces/FlowValue.md).[`disposed`](/api/interfaces/FlowValue.md#disposed)
52
+
53
+ ## Methods
54
+
55
+ ### dispose()
56
+
57
+ ```ts
58
+ dispose(): void;
59
+ ```
60
+
61
+ Defined in: [api/base/flowDisposable.ts:27](https://gitlab.com/ersbeth-web/picoflow/-/blob/4e864254f0eac72524c3be40b9e41d799a16e020/src/api/base/flowDisposable.ts#L27)
62
+
63
+ Releases all resources held by this disposable object.
64
+
65
+ Cleans up all subscriptions, dependencies, and internal state. After calling this method,
66
+ the resource enters a disposed state and cannot be reused. Any subsequent operations will
67
+ throw errors. This method should be called when you no longer need the reactive primitive
68
+ to prevent memory leaks.
69
+
70
+ #### Returns
71
+
72
+ `void`
73
+
74
+ #### Inherited from
75
+
76
+ [`FlowValue`](/api/interfaces/FlowValue.md).[`dispose`](/api/interfaces/FlowValue.md#dispose)
77
+
78
+ ***
79
+
80
+ ### get()
81
+
82
+ ```ts
83
+ get(tracker): T;
84
+ ```
85
+
86
+ Defined in: [api/nodes/flowValue.ts:24](https://gitlab.com/ersbeth-web/picoflow/-/blob/4e864254f0eac72524c3be40b9e41d799a16e020/src/api/nodes/flowValue.ts#L24)
87
+
88
+ Gets the current value and establishes a reactive dependency.
89
+
90
+ When called from within a reactive computation, this method registers the value as a dependency,
91
+ ensuring the computation re-executes when the value changes. The value is computed on first access
92
+ (if lazy) and then cached. For async values, throws PendingError while the value is resolving.
93
+
94
+ #### Parameters
95
+
96
+ | Parameter | Type | Description |
97
+ | ------ | ------ | ------ |
98
+ | `tracker` | [`FlowTracker`](/api/interfaces/FlowTracker.md) | Tracker that records this value as a dependency |
99
+
100
+ #### Returns
101
+
102
+ `T`
103
+
104
+ The current value
105
+
106
+ #### Inherited from
107
+
108
+ [`FlowValue`](/api/interfaces/FlowValue.md).[`get`](/api/interfaces/FlowValue.md#get)
109
+
110
+ ***
111
+
112
+ ### pick()
113
+
114
+ ```ts
115
+ pick(): Promise<T>;
116
+ ```
117
+
118
+ Defined in: [api/nodes/flowValue.ts:35](https://gitlab.com/ersbeth-web/picoflow/-/blob/4e864254f0eac72524c3be40b9e41d799a16e020/src/api/nodes/flowValue.ts#L35)
119
+
120
+ Asynchronously gets the current value without establishing a reactive dependency.
121
+
122
+ This method reads the value non-reactively, meaning it won't trigger re-execution of the calling
123
+ computation when the value changes. The value is computed on first access (if lazy) and then cached.
124
+ For async values, the promise resolves once the value is available.
125
+
126
+ #### Returns
127
+
128
+ `Promise`\<`T`\>
129
+
130
+ Promise that resolves with the current value
131
+
132
+ #### Inherited from
133
+
134
+ [`FlowValue`](/api/interfaces/FlowValue.md).[`pick`](/api/interfaces/FlowValue.md#pick)
135
+
136
+ ***
137
+
138
+ ### set()
139
+
140
+ #### Call Signature
141
+
142
+ ```ts
143
+ set(promise): void;
144
+ ```
145
+
146
+ Defined in: [api/nodes/async/flowStateAsync.ts:26](https://gitlab.com/ersbeth-web/picoflow/-/blob/4e864254f0eac72524c3be40b9e41d799a16e020/src/api/nodes/async/flowStateAsync.ts#L26)
147
+
148
+ Updates the state with a new promise or via an async updater function.
149
+ Notifies all dependents immediately (they will receive PendingError until resolved).
150
+
151
+ ##### Parameters
152
+
153
+ | Parameter | Type | Description |
154
+ | ------ | ------ | ------ |
155
+ | `promise` | `Promise`\<`T`\> | New promise to resolve, or async function that receives current value and returns a promise |
156
+
157
+ ##### Returns
158
+
159
+ `void`
160
+
161
+ #### Call Signature
162
+
163
+ ```ts
164
+ set(updater): void;
165
+ ```
166
+
167
+ Defined in: [api/nodes/async/flowStateAsync.ts:27](https://gitlab.com/ersbeth-web/picoflow/-/blob/4e864254f0eac72524c3be40b9e41d799a16e020/src/api/nodes/async/flowStateAsync.ts#L27)
168
+
169
+ ##### Parameters
170
+
171
+ | Parameter | Type |
172
+ | ------ | ------ |
173
+ | `updater` | [`UpdateFunctionAsync`](/api/type-aliases/UpdateFunctionAsync.md)\<`T`\> |
174
+
175
+ ##### Returns
176
+
177
+ `void`
178
+
179
+ ***
180
+
181
+ ### subscribe()
182
+
183
+ ```ts
184
+ subscribe(
185
+ onData,
186
+ onError?,
187
+ onPending?): FlowEffect;
188
+ ```
189
+
190
+ Defined in: [api/base/flowSubscribable.ts:82](https://gitlab.com/ersbeth-web/picoflow/-/blob/4e864254f0eac72524c3be40b9e41d799a16e020/src/api/base/flowSubscribable.ts#L82)
191
+
192
+ Subscribes to this observable with lifecycle callbacks.
193
+
194
+ Creates an active subscription that executes immediately and then re-executes whenever
195
+ the observable's dependencies change. The subscription remains active until the returned
196
+ disposal function is called. The `onData` callback receives the computed value, while
197
+ `onError` handles errors and `onPending` signals async operations in progress.
198
+
199
+ #### Parameters
200
+
201
+ | Parameter | Type | Description |
202
+ | ------ | ------ | ------ |
203
+ | `onData` | [`FlowOnDataListener`](/api/type-aliases/FlowOnDataListener.md)\<`T`\> | Callback invoked with the computed data on each execution |
204
+ | `onError?` | [`FlowOnErrorListener`](/api/type-aliases/FlowOnErrorListener.md) | Optional callback for handling errors during execution |
205
+ | `onPending?` | [`FlowOnPendingListener`](/api/type-aliases/FlowOnPendingListener.md) | Optional callback invoked when async dependencies are pending |
206
+
207
+ #### Returns
208
+
209
+ [`FlowEffect`](/api/interfaces/FlowEffect.md)
210
+
211
+ A function to dispose the subscription and stop receiving updates
212
+
213
+ #### Inherited from
214
+
215
+ [`FlowValue`](/api/interfaces/FlowValue.md).[`subscribe`](/api/interfaces/FlowValue.md#subscribe)
216
+
217
+ ***
218
+
219
+ ### trigger()
220
+
221
+ ```ts
222
+ trigger(): void;
223
+ ```
224
+
225
+ Defined in: [api/base/flowObservable.ts:27](https://gitlab.com/ersbeth-web/picoflow/-/blob/4e864254f0eac72524c3be40b9e41d799a16e020/src/api/base/flowObservable.ts#L27)
226
+
227
+ Manually triggers notifications to all dependents.
228
+
229
+ Forces all dependents of this observable to be notified and re-executed, even if the
230
+ value hasn't actually changed. Useful for imperatively triggering updates when the
231
+ reactive system cannot detect changes automatically.
232
+
233
+ #### Returns
234
+
235
+ `void`
236
+
237
+ #### Inherited from
238
+
239
+ [`FlowValue`](/api/interfaces/FlowValue.md).[`trigger`](/api/interfaces/FlowValue.md#trigger)
240
+
241
+ ***
242
+
243
+ ### watch()
244
+
245
+ ```ts
246
+ watch(tracker): void;
247
+ ```
248
+
249
+ Defined in: [api/base/flowObservable.ts:18](https://gitlab.com/ersbeth-web/picoflow/-/blob/4e864254f0eac72524c3be40b9e41d799a16e020/src/api/base/flowObservable.ts#L18)
250
+
251
+ Establishes a reactive dependency without reading the value.
252
+
253
+ Registers this observable as a dependency of the given tracker, allowing it to be notified
254
+ when changes occur. This enables dependency tracking without accessing the actual value.
255
+
256
+ #### Parameters
257
+
258
+ | Parameter | Type | Description |
259
+ | ------ | ------ | ------ |
260
+ | `tracker` | [`FlowTracker`](/api/interfaces/FlowTracker.md) | Tracker that records this observable as a dependency |
261
+
262
+ #### Returns
263
+
264
+ `void`
265
+
266
+ #### Inherited from
267
+
268
+ [`FlowValue`](/api/interfaces/FlowValue.md).[`watch`](/api/interfaces/FlowValue.md#watch)
@@ -0,0 +1,55 @@
1
+ [@ersbeth/picoflow](/api/index.md) / FlowSubscribable
2
+
3
+ # Interface: FlowSubscribable\<T\>
4
+
5
+ Defined in: [api/base/flowSubscribable.ts:68](https://gitlab.com/ersbeth-web/picoflow/-/blob/4e864254f0eac72524c3be40b9e41d799a16e020/src/api/base/flowSubscribable.ts#L68)
6
+
7
+ Contract for observables that can be subscribed to with lifecycle callbacks.
8
+
9
+ This interface enables imperative subscription to reactive values, allowing manual control over
10
+ when effects run. The subscribe method returns a disposal function to stop the subscription.
11
+ Useful for integrating with non-reactive code or frameworks that manage subscriptions differently.
12
+
13
+ ## Extended by
14
+
15
+ - [`FlowObservable`](/api/interfaces/FlowObservable.md)
16
+
17
+ ## Type Parameters
18
+
19
+ | Type Parameter |
20
+ | ------ |
21
+ | `T` |
22
+
23
+ ## Methods
24
+
25
+ ### subscribe()
26
+
27
+ ```ts
28
+ subscribe(
29
+ onData,
30
+ onError?,
31
+ onPending?): FlowEffect;
32
+ ```
33
+
34
+ Defined in: [api/base/flowSubscribable.ts:82](https://gitlab.com/ersbeth-web/picoflow/-/blob/4e864254f0eac72524c3be40b9e41d799a16e020/src/api/base/flowSubscribable.ts#L82)
35
+
36
+ Subscribes to this observable with lifecycle callbacks.
37
+
38
+ Creates an active subscription that executes immediately and then re-executes whenever
39
+ the observable's dependencies change. The subscription remains active until the returned
40
+ disposal function is called. The `onData` callback receives the computed value, while
41
+ `onError` handles errors and `onPending` signals async operations in progress.
42
+
43
+ #### Parameters
44
+
45
+ | Parameter | Type | Description |
46
+ | ------ | ------ | ------ |
47
+ | `onData` | [`FlowOnDataListener`](/api/type-aliases/FlowOnDataListener.md)\<`T`\> | Callback invoked with the computed data on each execution |
48
+ | `onError?` | [`FlowOnErrorListener`](/api/type-aliases/FlowOnErrorListener.md) | Optional callback for handling errors during execution |
49
+ | `onPending?` | [`FlowOnPendingListener`](/api/type-aliases/FlowOnPendingListener.md) | Optional callback invoked when async dependencies are pending |
50
+
51
+ #### Returns
52
+
53
+ [`FlowEffect`](/api/interfaces/FlowEffect.md)
54
+
55
+ A function to dispose the subscription and stop receiving updates
@@ -0,0 +1,61 @@
1
+ [@ersbeth/picoflow](/api/index.md) / FlowTracker
2
+
3
+ # Interface: FlowTracker
4
+
5
+ Defined in: [api/base/flowTracker.ts:7](https://gitlab.com/ersbeth-web/picoflow/-/blob/4e864254f0eac72524c3be40b9e41d799a16e020/src/api/base/flowTracker.ts#L7)
6
+
7
+ Contract for reactive computations that track dependencies and react to changes in the reactivity graph.
8
+
9
+ ## Extends
10
+
11
+ - [`FlowDisposable`](/api/interfaces/FlowDisposable.md)
12
+
13
+ ## Accessors
14
+
15
+ ### disposed
16
+
17
+ #### Get Signature
18
+
19
+ ```ts
20
+ get disposed(): boolean;
21
+ ```
22
+
23
+ Defined in: [api/base/flowDisposable.ts:17](https://gitlab.com/ersbeth-web/picoflow/-/blob/4e864254f0eac72524c3be40b9e41d799a16e020/src/api/base/flowDisposable.ts#L17)
24
+
25
+ Indicates whether this resource has been disposed.
26
+
27
+ Returns `true` if `dispose()` has been called, `false` otherwise. Once disposed,
28
+ the resource is no longer usable and any operations on it will throw errors.
29
+
30
+ ##### Returns
31
+
32
+ `boolean`
33
+
34
+ #### Inherited from
35
+
36
+ [`FlowDisposable`](/api/interfaces/FlowDisposable.md).[`disposed`](/api/interfaces/FlowDisposable.md#disposed)
37
+
38
+ ## Methods
39
+
40
+ ### dispose()
41
+
42
+ ```ts
43
+ dispose(): void;
44
+ ```
45
+
46
+ Defined in: [api/base/flowDisposable.ts:27](https://gitlab.com/ersbeth-web/picoflow/-/blob/4e864254f0eac72524c3be40b9e41d799a16e020/src/api/base/flowDisposable.ts#L27)
47
+
48
+ Releases all resources held by this disposable object.
49
+
50
+ Cleans up all subscriptions, dependencies, and internal state. After calling this method,
51
+ the resource enters a disposed state and cannot be reused. Any subsequent operations will
52
+ throw errors. This method should be called when you no longer need the reactive primitive
53
+ to prevent memory leaks.
54
+
55
+ #### Returns
56
+
57
+ `void`
58
+
59
+ #### Inherited from
60
+
61
+ [`FlowDisposable`](/api/interfaces/FlowDisposable.md).[`dispose`](/api/interfaces/FlowDisposable.md#dispose)