@logixjs/core 0.0.1 → 1.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 (398) hide show
  1. package/LICENSE +201 -0
  2. package/dist/{Action-mqVvtEHt.d.ts → Action-DYl88bwj.d.ts} +1 -1
  3. package/dist/{Action-BkRHy2vg.d.cts → Action-DkxsI_DK.d.cts} +1 -1
  4. package/dist/Action.cjs.map +1 -1
  5. package/dist/Action.d.cts +1 -1
  6. package/dist/Action.d.ts +1 -1
  7. package/dist/Action.js +2 -2
  8. package/dist/{Actions-AsQ07yTP.d.cts → Actions-Dicm7jdc.d.cts} +2 -2
  9. package/dist/{Actions-AsQ07yTP.d.ts → Actions-Dicm7jdc.d.ts} +2 -2
  10. package/dist/Actions.cjs.map +1 -1
  11. package/dist/Actions.d.cts +1 -1
  12. package/dist/Actions.d.ts +1 -1
  13. package/dist/Actions.js +1 -1
  14. package/dist/{Bound-BN1DQ_lM.d.ts → Bound-1OJLzVIS.d.ts} +2 -2
  15. package/dist/{Bound-BPIfH9SS.d.cts → Bound-BMLrtQ1V.d.cts} +2 -2
  16. package/dist/Bound.cjs +1737 -399
  17. package/dist/Bound.cjs.map +1 -1
  18. package/dist/Bound.d.cts +5 -5
  19. package/dist/Bound.d.ts +5 -5
  20. package/dist/Bound.js +19 -17
  21. package/dist/{Debug-B5q5Bkzx.d.ts → Debug-DKrWP5H1.d.ts} +40 -22
  22. package/dist/{Debug-Bq8Sqjcr.d.cts → Debug-hIT44XsY.d.cts} +40 -22
  23. package/dist/Debug.cjs +1348 -318
  24. package/dist/Debug.cjs.map +1 -1
  25. package/dist/Debug.d.cts +12 -11
  26. package/dist/Debug.d.ts +12 -11
  27. package/dist/Debug.js +20 -11
  28. package/dist/EffectOp.cjs +15 -6
  29. package/dist/EffectOp.cjs.map +1 -1
  30. package/dist/EffectOp.js +3 -3
  31. package/dist/Env.cjs +772 -6
  32. package/dist/Env.cjs.map +1 -1
  33. package/dist/Env.js +5 -2
  34. package/dist/ExternalStore-DqJKKRJ4.d.ts +61 -0
  35. package/dist/ExternalStore-JC-gAgEI.d.cts +61 -0
  36. package/dist/ExternalStore.cjs +774 -0
  37. package/dist/ExternalStore.cjs.map +1 -0
  38. package/dist/ExternalStore.d.cts +8 -0
  39. package/dist/ExternalStore.d.ts +8 -0
  40. package/dist/ExternalStore.js +19 -0
  41. package/dist/ExternalStore.js.map +1 -0
  42. package/dist/{Flow-BhpjE22E.d.ts → Flow-CZmXRDqp.d.cts} +13 -4
  43. package/dist/{Flow-1fZT8MpX.d.cts → Flow-DIVDxz7R.d.ts} +13 -4
  44. package/dist/Flow.cjs +765 -148
  45. package/dist/Flow.cjs.map +1 -1
  46. package/dist/Flow.d.cts +6 -6
  47. package/dist/Flow.d.ts +6 -6
  48. package/dist/Flow.js +9 -8
  49. package/dist/{Handle-D_cLW1Z3.d.ts → Handle-Bo6cAFut.d.ts} +1 -1
  50. package/dist/{Handle-D8D1zPb_.d.cts → Handle-CfDvSqN7.d.cts} +1 -1
  51. package/dist/Handle.d.cts +5 -5
  52. package/dist/Handle.d.ts +5 -5
  53. package/dist/{Kernel-8kC-jOda.d.cts → Kernel-CuXBF9S_.d.cts} +16 -7
  54. package/dist/{Kernel-CnGE1Fyk.d.ts → Kernel-D9guNwRL.d.ts} +16 -7
  55. package/dist/Kernel.cjs +814 -26
  56. package/dist/Kernel.cjs.map +1 -1
  57. package/dist/Kernel.d.cts +13 -12
  58. package/dist/Kernel.d.ts +13 -12
  59. package/dist/Kernel.js +7 -4
  60. package/dist/{Link-Db7975nU.d.ts → Link-CUM0yUCH.d.ts} +10 -3
  61. package/dist/{Link-fX8x1eCK.d.cts → Link-NAfR6uGD.d.cts} +10 -3
  62. package/dist/Link.cjs +1294 -121
  63. package/dist/Link.cjs.map +1 -1
  64. package/dist/Link.d.cts +5 -5
  65. package/dist/Link.d.ts +5 -5
  66. package/dist/Link.js +37 -29
  67. package/dist/{Logic-DRh4sDZj.d.cts → Logic-09VQpIj3.d.cts} +7 -4
  68. package/dist/{Logic-BRjEMr-W.d.ts → Logic-DKg7ghGy.d.ts} +7 -4
  69. package/dist/Logic.cjs +2 -1
  70. package/dist/Logic.cjs.map +1 -1
  71. package/dist/Logic.d.cts +5 -5
  72. package/dist/Logic.d.ts +5 -5
  73. package/dist/Logic.js +1 -1
  74. package/dist/{MatchBuilder-CJk5oCkR.d.cts → MatchBuilder-CsW5jgrL.d.ts} +1 -1
  75. package/dist/{MatchBuilder-0QOc-nlU.d.ts → MatchBuilder-Dksk07F4.d.cts} +1 -1
  76. package/dist/MatchBuilder.cjs +2 -2
  77. package/dist/MatchBuilder.cjs.map +1 -1
  78. package/dist/MatchBuilder.d.cts +6 -6
  79. package/dist/MatchBuilder.d.ts +6 -6
  80. package/dist/MatchBuilder.js +2 -2
  81. package/dist/Middleware-D8tUDLv_.d.cts +100 -0
  82. package/dist/Middleware-DS7CbTTN.d.ts +100 -0
  83. package/dist/Middleware.cjs +678 -58
  84. package/dist/Middleware.cjs.map +1 -1
  85. package/dist/Middleware.d.cts +2 -86
  86. package/dist/Middleware.d.ts +2 -86
  87. package/dist/Middleware.js +15 -12
  88. package/dist/{Module-DnzluX2J.d.ts → Module-B_Cntyms.d.ts} +54 -25
  89. package/dist/{Module-B_0xRDMR.d.cts → Module-CmNOVXzf.d.cts} +54 -25
  90. package/dist/Module.cjs +9331 -3317
  91. package/dist/Module.cjs.map +1 -1
  92. package/dist/Module.d.cts +7 -6
  93. package/dist/Module.d.ts +7 -6
  94. package/dist/Module.js +39 -31
  95. package/dist/ModuleTag-CGho_InD.d.ts +113 -0
  96. package/dist/ModuleTag-CITb8L_G.d.cts +113 -0
  97. package/dist/ModuleTag.cjs +7248 -2847
  98. package/dist/ModuleTag.cjs.map +1 -1
  99. package/dist/ModuleTag.d.cts +6 -6
  100. package/dist/ModuleTag.d.ts +6 -6
  101. package/dist/ModuleTag.js +35 -29
  102. package/dist/Observability-Bdhnx2Dv.d.ts +385 -0
  103. package/dist/Observability-DXGAFBIT.d.cts +385 -0
  104. package/dist/Observability.cjs +5093 -1556
  105. package/dist/Observability.cjs.map +1 -1
  106. package/dist/Observability.d.cts +6 -7
  107. package/dist/Observability.d.ts +6 -7
  108. package/dist/Observability.js +28 -23
  109. package/dist/{Platform-CHX8o-U4.d.ts → Platform-B4s8tg6C.d.cts} +4 -5
  110. package/dist/{Platform-C49Pv956.d.cts → Platform-BV_0MW7g.d.cts} +5 -2
  111. package/dist/{Platform-C49Pv956.d.ts → Platform-BV_0MW7g.d.ts} +5 -2
  112. package/dist/{Platform-CVlv0xLQ.d.cts → Platform-W0Mefy_e.d.ts} +4 -5
  113. package/dist/Platform.cjs +2 -1
  114. package/dist/Platform.cjs.map +1 -1
  115. package/dist/Platform.d.cts +2 -3
  116. package/dist/Platform.d.ts +2 -3
  117. package/dist/Platform.js +2 -2
  118. package/dist/{Process-CM9xbMdP.d.ts → Process-CO8G7HO9.d.cts} +30 -5
  119. package/dist/{Process-mL8fHDSB.d.cts → Process-Cyf6VNDR.d.ts} +30 -5
  120. package/dist/Process.cjs +1288 -120
  121. package/dist/Process.cjs.map +1 -1
  122. package/dist/Process.d.cts +6 -6
  123. package/dist/Process.d.ts +6 -6
  124. package/dist/Process.js +34 -26
  125. package/dist/ReadQuery-C_or5nLC.d.ts +128 -0
  126. package/dist/ReadQuery-DXLzCE0E.d.cts +614 -0
  127. package/dist/ReadQuery-DXLzCE0E.d.ts +614 -0
  128. package/dist/ReadQuery-Yve1lmUo.d.cts +128 -0
  129. package/dist/ReadQuery.cjs +290 -5
  130. package/dist/ReadQuery.cjs.map +1 -1
  131. package/dist/ReadQuery.d.cts +3 -2
  132. package/dist/ReadQuery.d.ts +3 -2
  133. package/dist/ReadQuery.js +23 -5
  134. package/dist/{Reflection-CQnKwPXj.d.ts → Reflection-B2Xi1e4Q.d.ts} +89 -7
  135. package/dist/{Reflection-Kabo1mlU.d.cts → Reflection-DNB4V4_e.d.cts} +89 -7
  136. package/dist/Reflection.cjs +3227 -1617
  137. package/dist/Reflection.cjs.map +1 -1
  138. package/dist/Reflection.d.cts +17 -15
  139. package/dist/Reflection.d.ts +17 -15
  140. package/dist/Reflection.js +33 -25
  141. package/dist/{Resource-Dy1xD_DG.d.cts → Resource-pKvQQ4x5.d.cts} +3 -3
  142. package/dist/{Resource-Dy1xD_DG.d.ts → Resource-pKvQQ4x5.d.ts} +3 -3
  143. package/dist/Resource.cjs +781 -15
  144. package/dist/Resource.cjs.map +1 -1
  145. package/dist/Resource.d.cts +1 -1
  146. package/dist/Resource.d.ts +1 -1
  147. package/dist/Resource.js +6 -3
  148. package/dist/{Root-7ADUMk4t.d.cts → Root-CCVuFHB6.d.cts} +3 -3
  149. package/dist/{Root-7ADUMk4t.d.ts → Root-CCVuFHB6.d.ts} +3 -3
  150. package/dist/Root.cjs +786 -20
  151. package/dist/Root.cjs.map +1 -1
  152. package/dist/Root.d.cts +2 -2
  153. package/dist/Root.d.ts +2 -2
  154. package/dist/Root.js +7 -3
  155. package/dist/{Runtime-CtyzZG4i.d.ts → Runtime-CRmvwK4I.d.ts} +70 -14
  156. package/dist/{Runtime-B-aL-f29.d.cts → Runtime-C_wJM9mN.d.cts} +70 -14
  157. package/dist/Runtime.cjs +4942 -1601
  158. package/dist/Runtime.cjs.map +1 -1
  159. package/dist/Runtime.d.cts +17 -15
  160. package/dist/Runtime.d.ts +17 -15
  161. package/dist/Runtime.js +44 -32
  162. package/dist/{ScopeRegistry-D1owDNSm.d.cts → ScopeRegistry-BhYzqWri.d.cts} +6 -6
  163. package/dist/{ScopeRegistry-D1owDNSm.d.ts → ScopeRegistry-BhYzqWri.d.ts} +6 -6
  164. package/dist/ScopeRegistry.cjs +776 -10
  165. package/dist/ScopeRegistry.cjs.map +1 -1
  166. package/dist/ScopeRegistry.d.cts +1 -1
  167. package/dist/ScopeRegistry.d.ts +1 -1
  168. package/dist/ScopeRegistry.js +6 -3
  169. package/dist/{State-CU50R26M.d.cts → State-rNFsFPTl.d.cts} +2 -2
  170. package/dist/{State-CU50R26M.d.ts → State-rNFsFPTl.d.ts} +2 -2
  171. package/dist/State.cjs.map +1 -1
  172. package/dist/State.d.cts +1 -1
  173. package/dist/State.d.ts +1 -1
  174. package/dist/State.js +1 -1
  175. package/dist/{StateTrait-BGsZghTz.d.ts → StateTrait-CijdwNb6.d.ts} +25 -8
  176. package/dist/{StateTrait-OWhbj12c.d.cts → StateTrait-Dltto6PU.d.cts} +25 -8
  177. package/dist/StateTrait.cjs +1890 -528
  178. package/dist/StateTrait.cjs.map +1 -1
  179. package/dist/StateTrait.d.cts +9 -7
  180. package/dist/StateTrait.d.ts +9 -7
  181. package/dist/StateTrait.js +18 -14
  182. package/dist/{TraitLifecycle-CwV5WPFX.d.cts → TraitLifecycle-BKzDqzLu.d.cts} +2 -2
  183. package/dist/{TraitLifecycle-LdIWmKlg.d.ts → TraitLifecycle-Cvo94uDB.d.ts} +2 -2
  184. package/dist/TraitLifecycle.cjs +630 -67
  185. package/dist/TraitLifecycle.cjs.map +1 -1
  186. package/dist/TraitLifecycle.d.cts +6 -6
  187. package/dist/TraitLifecycle.d.ts +6 -6
  188. package/dist/TraitLifecycle.js +8 -7
  189. package/dist/Workflow-C_OWr4dV.d.ts +415 -0
  190. package/dist/Workflow-DmydkHO8.d.cts +415 -0
  191. package/dist/Workflow.cjs +3150 -0
  192. package/dist/Workflow.cjs.map +1 -0
  193. package/dist/Workflow.d.cts +7 -0
  194. package/dist/Workflow.d.ts +7 -0
  195. package/dist/Workflow.js +58 -0
  196. package/dist/Workflow.js.map +1 -0
  197. package/dist/{action-DiMDD_0v.d.cts → action-BQxjPFEw.d.cts} +5 -5
  198. package/dist/{action-DiMDD_0v.d.ts → action-BQxjPFEw.d.ts} +5 -5
  199. package/dist/chunk-2XRLXDWR.js +276 -0
  200. package/dist/chunk-2XRLXDWR.js.map +1 -0
  201. package/dist/chunk-3L6QGFMM.js +701 -0
  202. package/dist/chunk-3L6QGFMM.js.map +1 -0
  203. package/dist/{chunk-GMPEOUP2.js → chunk-4MZ7BT3R.js} +2 -2
  204. package/dist/chunk-4MZ7BT3R.js.map +1 -0
  205. package/dist/{chunk-3IYZ5IGG.js → chunk-5WKUGEBY.js} +2 -2
  206. package/dist/{chunk-3RMKLXHX.js → chunk-63ZQ5RIN.js} +2 -2
  207. package/dist/{chunk-M3WTHJHJ.js → chunk-67DIEA53.js} +385 -148
  208. package/dist/chunk-67DIEA53.js.map +1 -0
  209. package/dist/{chunk-YS3AZQ2G.js → chunk-6HFAW2MH.js} +1 -1
  210. package/dist/chunk-6HFAW2MH.js.map +1 -0
  211. package/dist/{chunk-EY4NZKDR.js → chunk-6Y2TKCNY.js} +2 -2
  212. package/dist/{chunk-76WT3HOR.js → chunk-6YZOXFPQ.js} +25 -24
  213. package/dist/chunk-6YZOXFPQ.js.map +1 -0
  214. package/dist/{chunk-G5ZBFPNU.js → chunk-A2RQOJC7.js} +2 -2
  215. package/dist/{chunk-AUIR5O6W.js → chunk-AFSB6NKM.js} +13 -19
  216. package/dist/chunk-AFSB6NKM.js.map +1 -0
  217. package/dist/{chunk-JCXGZRMU.js → chunk-AO4JEOKD.js} +22 -23
  218. package/dist/chunk-AO4JEOKD.js.map +1 -0
  219. package/dist/{chunk-TAAPQVZN.js → chunk-AYELIQXR.js} +2 -2
  220. package/dist/{chunk-QMM6O4CD.js → chunk-BLHZW7DG.js} +15 -3
  221. package/dist/{chunk-QMM6O4CD.js.map → chunk-BLHZW7DG.js.map} +1 -1
  222. package/dist/{chunk-TQOBJYDP.js → chunk-CD4N74YC.js} +1 -1
  223. package/dist/chunk-CD4N74YC.js.map +1 -0
  224. package/dist/{chunk-ANLBCBDC.js → chunk-CGE2HBTH.js} +11 -11
  225. package/dist/chunk-CGE2HBTH.js.map +1 -0
  226. package/dist/{chunk-OFADUJWJ.js → chunk-CYYSQMLO.js} +5 -5
  227. package/dist/chunk-CYYSQMLO.js.map +1 -0
  228. package/dist/{chunk-66ALHVEX.js → chunk-EB46EYI7.js} +3 -3
  229. package/dist/{chunk-NZJKFF45.js → chunk-EKCDHWRK.js} +4 -4
  230. package/dist/chunk-EKCDHWRK.js.map +1 -0
  231. package/dist/{chunk-BABLDP24.js → chunk-EPQFNJU3.js} +152 -7
  232. package/dist/chunk-EPQFNJU3.js.map +1 -0
  233. package/dist/{chunk-OGWBVHB3.js → chunk-ESR6HGOY.js} +73 -14
  234. package/dist/chunk-ESR6HGOY.js.map +1 -0
  235. package/dist/{chunk-NBD3KUOZ.js → chunk-F6RP62H3.js} +150 -98
  236. package/dist/chunk-F6RP62H3.js.map +1 -0
  237. package/dist/chunk-FBYW3QDI.js +252 -0
  238. package/dist/chunk-FBYW3QDI.js.map +1 -0
  239. package/dist/{chunk-IPF7E66P.js → chunk-FYAODKVP.js} +2 -2
  240. package/dist/chunk-GNEN7NKO.js +908 -0
  241. package/dist/chunk-GNEN7NKO.js.map +1 -0
  242. package/dist/chunk-GWSM4KLB.js +763 -0
  243. package/dist/chunk-GWSM4KLB.js.map +1 -0
  244. package/dist/{chunk-4SO6JMZL.js → chunk-HDMXCUZL.js} +1 -1
  245. package/dist/chunk-HDMXCUZL.js.map +1 -0
  246. package/dist/{chunk-ZFY7U2FR.js → chunk-HJM5Y5NU.js} +43 -3
  247. package/dist/chunk-HJM5Y5NU.js.map +1 -0
  248. package/dist/{chunk-ZGDVUPTM.js → chunk-IOZ3VKPK.js} +129 -68
  249. package/dist/chunk-IOZ3VKPK.js.map +1 -0
  250. package/dist/{chunk-PYOE4VSI.js → chunk-IVXSVHO4.js} +303 -247
  251. package/dist/chunk-IVXSVHO4.js.map +1 -0
  252. package/dist/chunk-J3CWXIPV.js +242 -0
  253. package/dist/chunk-J3CWXIPV.js.map +1 -0
  254. package/dist/chunk-K6JQW266.js +42 -0
  255. package/dist/chunk-K6JQW266.js.map +1 -0
  256. package/dist/chunk-KMZYQF6Q.js +202 -0
  257. package/dist/chunk-KMZYQF6Q.js.map +1 -0
  258. package/dist/{chunk-JWOYLO27.js → chunk-LPPZDFTD.js} +22 -12
  259. package/dist/chunk-LPPZDFTD.js.map +1 -0
  260. package/dist/{chunk-PAYXCY6A.js → chunk-MYB2B5WX.js} +997 -576
  261. package/dist/chunk-MYB2B5WX.js.map +1 -0
  262. package/dist/chunk-MYKNINNN.js +228 -0
  263. package/dist/chunk-MYKNINNN.js.map +1 -0
  264. package/dist/chunk-NSQIRMVF.js +27 -0
  265. package/dist/{chunk-QCHIQWAJ.js.map → chunk-NSQIRMVF.js.map} +1 -1
  266. package/dist/chunk-NUDBM4MM.js +30 -0
  267. package/dist/chunk-NUDBM4MM.js.map +1 -0
  268. package/dist/chunk-NZMWWDAY.js +23 -0
  269. package/dist/chunk-NZMWWDAY.js.map +1 -0
  270. package/dist/{chunk-RNFE3ML2.js → chunk-OCUV2Y25.js} +4 -3
  271. package/dist/chunk-OCUV2Y25.js.map +1 -0
  272. package/dist/chunk-P4ZJOQA7.js +271 -0
  273. package/dist/chunk-P4ZJOQA7.js.map +1 -0
  274. package/dist/chunk-P6C5EZ3D.js +342 -0
  275. package/dist/chunk-P6C5EZ3D.js.map +1 -0
  276. package/dist/{chunk-CW6T36TN.js → chunk-PBD7BJUN.js} +62 -4
  277. package/dist/chunk-PBD7BJUN.js.map +1 -0
  278. package/dist/chunk-PBIUCQY3.js +696 -0
  279. package/dist/chunk-PBIUCQY3.js.map +1 -0
  280. package/dist/chunk-PD6YECQH.js +845 -0
  281. package/dist/chunk-PD6YECQH.js.map +1 -0
  282. package/dist/{chunk-M7IYCTJV.js → chunk-R4LFQGP3.js} +2 -2
  283. package/dist/chunk-RHJIGDUE.js +21 -0
  284. package/dist/chunk-RHJIGDUE.js.map +1 -0
  285. package/dist/{chunk-KP7MUZNX.js → chunk-RLXO27MW.js} +30 -8
  286. package/dist/chunk-RLXO27MW.js.map +1 -0
  287. package/dist/{chunk-DFNM3WX2.js → chunk-S44BEV4B.js} +168 -45
  288. package/dist/chunk-S44BEV4B.js.map +1 -0
  289. package/dist/chunk-S4S5N4BJ.js +1461 -0
  290. package/dist/chunk-S4S5N4BJ.js.map +1 -0
  291. package/dist/{chunk-BZ2SHDN2.js → chunk-SGTRAXXX.js} +3 -3
  292. package/dist/chunk-SGTRAXXX.js.map +1 -0
  293. package/dist/{chunk-M2RGJPXX.js → chunk-SJAE5PB5.js} +3 -3
  294. package/dist/{chunk-JGIWG6SR.js → chunk-SNPNHU3H.js} +3937 -1776
  295. package/dist/chunk-SNPNHU3H.js.map +1 -0
  296. package/dist/{chunk-IHVBV5C2.js → chunk-SOOBFXRR.js} +94 -71
  297. package/dist/chunk-SOOBFXRR.js.map +1 -0
  298. package/dist/{chunk-ZDTRWK5F.js → chunk-TAHFWKS6.js} +2 -2
  299. package/dist/chunk-UEFFTVPY.js +9 -0
  300. package/dist/chunk-UEFFTVPY.js.map +1 -0
  301. package/dist/{chunk-24VULZ7A.js → chunk-UR5BXLBP.js} +3 -3
  302. package/dist/chunk-UR5BXLBP.js.map +1 -0
  303. package/dist/{chunk-DMBALCE2.js → chunk-V2SBGVDO.js} +471 -186
  304. package/dist/chunk-V2SBGVDO.js.map +1 -0
  305. package/dist/chunk-VJLWD47W.js +23 -0
  306. package/dist/chunk-VJLWD47W.js.map +1 -0
  307. package/dist/{chunk-4CQAV7YB.js → chunk-W647DX5Z.js} +2 -2
  308. package/dist/{chunk-THATMZXD.js → chunk-WFIIU3YZ.js} +2 -2
  309. package/dist/{chunk-THATMZXD.js.map → chunk-WFIIU3YZ.js.map} +1 -1
  310. package/dist/chunk-YZDJMAKL.js +82 -0
  311. package/dist/chunk-YZDJMAKL.js.map +1 -0
  312. package/dist/{chunk-3TMODYZV.js → chunk-Z5XH6VHY.js} +5 -5
  313. package/dist/chunk-Z5XH6VHY.js.map +1 -0
  314. package/dist/{chunk-BE3HW4FY.js → chunk-ZBBMZMA6.js} +377 -170
  315. package/dist/chunk-ZBBMZMA6.js.map +1 -0
  316. package/dist/index.cjs +21224 -11714
  317. package/dist/index.cjs.map +1 -1
  318. package/dist/index.d.cts +195 -49
  319. package/dist/index.d.ts +195 -49
  320. package/dist/index.js +150 -74
  321. package/dist/index.js.map +1 -1
  322. package/dist/{ir-BMP7yxJJ.d.cts → ir-BSosEwc8.d.cts} +1 -1
  323. package/dist/{ir-DUOz6H-5.d.ts → ir-D-uqwL_4.d.ts} +1 -1
  324. package/dist/{module-B8CBqIZ_.d.cts → module-Ds4tarcI.d.cts} +230 -140
  325. package/dist/{module-k7m3txak.d.ts → module-Zd1Gn-Nj.d.ts} +230 -140
  326. package/package.json +20 -4
  327. package/dist/ModuleTag-C8FHY_sY.d.ts +0 -93
  328. package/dist/ModuleTag-EGbgBMpZ.d.cts +0 -93
  329. package/dist/Observability-COqEvp2C.d.cts +0 -713
  330. package/dist/Observability-cY4kLn0S.d.ts +0 -713
  331. package/dist/ReadQuery-BlMwhe-F.d.ts +0 -30
  332. package/dist/ReadQuery-CL5XlXts.d.cts +0 -30
  333. package/dist/ReadQuery-SinbStGF.d.cts +0 -38
  334. package/dist/ReadQuery-SinbStGF.d.ts +0 -38
  335. package/dist/chunk-24VULZ7A.js.map +0 -1
  336. package/dist/chunk-3QMIVH35.js +0 -43
  337. package/dist/chunk-3QMIVH35.js.map +0 -1
  338. package/dist/chunk-3TMODYZV.js.map +0 -1
  339. package/dist/chunk-4SO6JMZL.js.map +0 -1
  340. package/dist/chunk-76WT3HOR.js.map +0 -1
  341. package/dist/chunk-ANLBCBDC.js.map +0 -1
  342. package/dist/chunk-AUIR5O6W.js.map +0 -1
  343. package/dist/chunk-BABLDP24.js.map +0 -1
  344. package/dist/chunk-BE3HW4FY.js.map +0 -1
  345. package/dist/chunk-BZ2SHDN2.js.map +0 -1
  346. package/dist/chunk-CW6T36TN.js.map +0 -1
  347. package/dist/chunk-DFNM3WX2.js.map +0 -1
  348. package/dist/chunk-DMBALCE2.js.map +0 -1
  349. package/dist/chunk-EGK3KN7B.js +0 -406
  350. package/dist/chunk-EGK3KN7B.js.map +0 -1
  351. package/dist/chunk-GMPEOUP2.js.map +0 -1
  352. package/dist/chunk-IHVBV5C2.js.map +0 -1
  353. package/dist/chunk-JCXGZRMU.js.map +0 -1
  354. package/dist/chunk-JGIWG6SR.js.map +0 -1
  355. package/dist/chunk-JWOYLO27.js.map +0 -1
  356. package/dist/chunk-KIXAU3GM.js +0 -137
  357. package/dist/chunk-KIXAU3GM.js.map +0 -1
  358. package/dist/chunk-KL5ACTCT.js +0 -8
  359. package/dist/chunk-KL5ACTCT.js.map +0 -1
  360. package/dist/chunk-KP7MUZNX.js.map +0 -1
  361. package/dist/chunk-M3BFQ7HK.js +0 -13
  362. package/dist/chunk-M3BFQ7HK.js.map +0 -1
  363. package/dist/chunk-M3WTHJHJ.js.map +0 -1
  364. package/dist/chunk-NBD3KUOZ.js.map +0 -1
  365. package/dist/chunk-NQZ2OSGR.js +0 -151
  366. package/dist/chunk-NQZ2OSGR.js.map +0 -1
  367. package/dist/chunk-NZJKFF45.js.map +0 -1
  368. package/dist/chunk-OFADUJWJ.js.map +0 -1
  369. package/dist/chunk-OGWBVHB3.js.map +0 -1
  370. package/dist/chunk-PAYXCY6A.js.map +0 -1
  371. package/dist/chunk-PYOE4VSI.js.map +0 -1
  372. package/dist/chunk-QCHIQWAJ.js +0 -21
  373. package/dist/chunk-RNFE3ML2.js.map +0 -1
  374. package/dist/chunk-TKZ7MEIA.js +0 -27
  375. package/dist/chunk-TKZ7MEIA.js.map +0 -1
  376. package/dist/chunk-TQOBJYDP.js.map +0 -1
  377. package/dist/chunk-VZB726PE.js +0 -93
  378. package/dist/chunk-VZB726PE.js.map +0 -1
  379. package/dist/chunk-W3TEWHLO.js +0 -568
  380. package/dist/chunk-W3TEWHLO.js.map +0 -1
  381. package/dist/chunk-YS3AZQ2G.js.map +0 -1
  382. package/dist/chunk-ZFLHVFUC.js +0 -192
  383. package/dist/chunk-ZFLHVFUC.js.map +0 -1
  384. package/dist/chunk-ZFY7U2FR.js.map +0 -1
  385. package/dist/chunk-ZGDVUPTM.js.map +0 -1
  386. package/dist/protocol-g_1897M2.d.cts +0 -127
  387. package/dist/protocol-g_1897M2.d.ts +0 -127
  388. /package/dist/{chunk-3IYZ5IGG.js.map → chunk-5WKUGEBY.js.map} +0 -0
  389. /package/dist/{chunk-3RMKLXHX.js.map → chunk-63ZQ5RIN.js.map} +0 -0
  390. /package/dist/{chunk-EY4NZKDR.js.map → chunk-6Y2TKCNY.js.map} +0 -0
  391. /package/dist/{chunk-G5ZBFPNU.js.map → chunk-A2RQOJC7.js.map} +0 -0
  392. /package/dist/{chunk-TAAPQVZN.js.map → chunk-AYELIQXR.js.map} +0 -0
  393. /package/dist/{chunk-66ALHVEX.js.map → chunk-EB46EYI7.js.map} +0 -0
  394. /package/dist/{chunk-IPF7E66P.js.map → chunk-FYAODKVP.js.map} +0 -0
  395. /package/dist/{chunk-M7IYCTJV.js.map → chunk-R4LFQGP3.js.map} +0 -0
  396. /package/dist/{chunk-M2RGJPXX.js.map → chunk-SJAE5PB5.js.map} +0 -0
  397. /package/dist/{chunk-ZDTRWK5F.js.map → chunk-TAHFWKS6.js.map} +0 -0
  398. /package/dist/{chunk-4CQAV7YB.js.map → chunk-W647DX5Z.js.map} +0 -0
package/dist/Env.cjs CHANGED
@@ -26,7 +26,750 @@ __export(Env_exports, {
26
26
  module.exports = __toCommonJS(Env_exports);
27
27
 
28
28
  // src/internal/runtime/core/env.ts
29
+ var import_effect9 = require("effect");
30
+
31
+ // src/internal/runtime/core/HostScheduler.ts
32
+ var noopCancel = () => {
33
+ };
34
+ var safeNowMs = () => {
35
+ const perf = globalThis.performance;
36
+ if (perf && typeof perf.now === "function") {
37
+ try {
38
+ const v = perf.now();
39
+ if (typeof v === "number" && Number.isFinite(v)) return v;
40
+ } catch {
41
+ }
42
+ }
43
+ return Date.now();
44
+ };
45
+ var safeQueueMicrotask = (cb) => {
46
+ const qm = globalThis.queueMicrotask;
47
+ if (typeof qm === "function") {
48
+ try {
49
+ qm(cb);
50
+ return;
51
+ } catch {
52
+ }
53
+ }
54
+ try {
55
+ Promise.resolve().then(cb);
56
+ } catch {
57
+ setTimeout(cb, 0);
58
+ }
59
+ };
60
+ var safeSetTimeout = (ms, cb) => {
61
+ const id = setTimeout(cb, ms);
62
+ return () => {
63
+ try {
64
+ clearTimeout(id);
65
+ } catch {
66
+ }
67
+ };
68
+ };
69
+ var makeMessageChannelMacrotask = () => {
70
+ const MC = globalThis.MessageChannel;
71
+ if (typeof MC !== "function") return void 0;
72
+ let channel;
73
+ try {
74
+ channel = new MC();
75
+ } catch {
76
+ return void 0;
77
+ }
78
+ const queue = [];
79
+ let scheduled = false;
80
+ const flush = () => {
81
+ scheduled = false;
82
+ const tasks = queue.splice(0, queue.length);
83
+ for (const t of tasks) {
84
+ if (t.canceled) continue;
85
+ try {
86
+ t.cb();
87
+ } catch {
88
+ }
89
+ }
90
+ };
91
+ try {
92
+ channel.port1.onmessage = flush;
93
+ } catch {
94
+ return void 0;
95
+ }
96
+ const schedule = (cb) => {
97
+ const task = { canceled: false, cb };
98
+ queue.push(task);
99
+ if (!scheduled) {
100
+ scheduled = true;
101
+ try {
102
+ channel.port2.postMessage(void 0);
103
+ } catch {
104
+ scheduled = false;
105
+ return safeSetTimeout(0, cb);
106
+ }
107
+ }
108
+ return () => {
109
+ task.canceled = true;
110
+ };
111
+ };
112
+ return schedule;
113
+ };
114
+ var makeSetImmediateMacrotask = () => {
115
+ const si = globalThis.setImmediate;
116
+ const ci = globalThis.clearImmediate;
117
+ if (typeof si !== "function") return void 0;
118
+ return (cb) => {
119
+ let id;
120
+ try {
121
+ id = si(cb);
122
+ } catch {
123
+ return safeSetTimeout(0, cb);
124
+ }
125
+ return () => {
126
+ if (typeof ci !== "function") return;
127
+ try {
128
+ ci(id);
129
+ } catch {
130
+ }
131
+ };
132
+ };
133
+ };
134
+ var makeRaf = () => {
135
+ const raf = globalThis.requestAnimationFrame;
136
+ const cancel = globalThis.cancelAnimationFrame;
137
+ if (typeof raf !== "function") return void 0;
138
+ return (cb) => {
139
+ let id;
140
+ try {
141
+ id = raf(cb);
142
+ } catch {
143
+ return noopCancel;
144
+ }
145
+ return () => {
146
+ if (typeof cancel !== "function") return;
147
+ try {
148
+ cancel(id);
149
+ } catch {
150
+ }
151
+ };
152
+ };
153
+ };
154
+ var makeDefaultHostScheduler = () => {
155
+ const macrotask = makeSetImmediateMacrotask() ?? makeMessageChannelMacrotask() ?? ((cb) => safeSetTimeout(0, cb));
156
+ const raf = makeRaf();
157
+ return {
158
+ nowMs: safeNowMs,
159
+ scheduleMicrotask: safeQueueMicrotask,
160
+ scheduleMacrotask: macrotask,
161
+ scheduleAnimationFrame: (cb) => raf?.(cb) ?? macrotask(cb),
162
+ scheduleTimeout: safeSetTimeout
163
+ };
164
+ };
165
+ var globalHostScheduler;
166
+ var getGlobalHostScheduler = () => {
167
+ globalHostScheduler ?? (globalHostScheduler = makeDefaultHostScheduler());
168
+ return globalHostScheduler;
169
+ };
170
+
171
+ // src/internal/runtime/core/RuntimeStore.ts
172
+ var parseTopicKey = (topicKey) => {
173
+ const idx = topicKey.indexOf("::");
174
+ if (idx <= 0) return void 0;
175
+ const moduleId = topicKey.slice(0, idx);
176
+ const rest = topicKey.slice(idx + 2);
177
+ if (rest.length === 0) return void 0;
178
+ const idx2 = rest.indexOf("::");
179
+ if (idx2 < 0) {
180
+ return { kind: "module", moduleInstanceKey: `${moduleId}::${rest}` };
181
+ }
182
+ const instanceId = rest.slice(0, idx2);
183
+ const suffix = rest.slice(idx2 + 2);
184
+ if (suffix.startsWith("rq:")) {
185
+ const selectorId = suffix.slice("rq:".length);
186
+ if (selectorId.length === 0) return void 0;
187
+ return {
188
+ kind: "readQuery",
189
+ moduleInstanceKey: `${moduleId}::${instanceId}`,
190
+ selectorId
191
+ };
192
+ }
193
+ return { kind: "module", moduleInstanceKey: `${moduleId}::${instanceId}` };
194
+ };
195
+ var EMPTY_LISTENER_SNAPSHOT = [];
196
+ var NO_CHANGED_TOPIC_LISTENERS = [];
197
+ var makeRuntimeStore = () => {
198
+ let tickSeq = 0;
199
+ const moduleStates = /* @__PURE__ */ new Map();
200
+ const topicVersions = /* @__PURE__ */ new Map();
201
+ const topicPriorities = /* @__PURE__ */ new Map();
202
+ const listenersByTopic = /* @__PURE__ */ new Map();
203
+ const subscriberCountByModule = /* @__PURE__ */ new Map();
204
+ const getTopicVersion = (topicKey) => topicVersions.get(topicKey) ?? 0;
205
+ const getTopicPriority = (topicKey) => topicPriorities.get(topicKey) ?? "normal";
206
+ const commitTopicBump = (topicKey, priority) => {
207
+ const prev = topicVersions.get(topicKey) ?? 0;
208
+ topicVersions.set(topicKey, prev + 1);
209
+ topicPriorities.set(topicKey, priority);
210
+ };
211
+ const refreshTopicSnapshot = (state) => {
212
+ state.snapshot = Array.from(state.listeners);
213
+ };
214
+ const subscribeTopic = (topicKey, listener) => {
215
+ const info = parseTopicKey(topicKey);
216
+ const existing = listenersByTopic.get(topicKey);
217
+ const state = existing ?? { listeners: /* @__PURE__ */ new Set(), snapshot: EMPTY_LISTENER_SNAPSHOT };
218
+ const alreadyHas = state.listeners.has(listener);
219
+ if (!alreadyHas) {
220
+ state.listeners.add(listener);
221
+ refreshTopicSnapshot(state);
222
+ }
223
+ if (!existing) {
224
+ listenersByTopic.set(topicKey, state);
225
+ }
226
+ if (!alreadyHas && info) {
227
+ const prev = subscriberCountByModule.get(info.moduleInstanceKey) ?? 0;
228
+ subscriberCountByModule.set(info.moduleInstanceKey, prev + 1);
229
+ }
230
+ return () => {
231
+ const currentState = listenersByTopic.get(topicKey);
232
+ if (!currentState) return;
233
+ const deleted = currentState.listeners.delete(listener);
234
+ if (deleted && info) {
235
+ const prev = subscriberCountByModule.get(info.moduleInstanceKey) ?? 0;
236
+ const next = prev - 1;
237
+ if (next <= 0) {
238
+ subscriberCountByModule.delete(info.moduleInstanceKey);
239
+ } else {
240
+ subscriberCountByModule.set(info.moduleInstanceKey, next);
241
+ }
242
+ }
243
+ if (currentState.listeners.size === 0) {
244
+ listenersByTopic.delete(topicKey);
245
+ } else if (deleted) {
246
+ refreshTopicSnapshot(currentState);
247
+ }
248
+ };
249
+ };
250
+ const getTopicSubscriberCount = (topicKey) => listenersByTopic.get(topicKey)?.listeners.size ?? 0;
251
+ const getModuleSubscriberCount = (moduleInstanceKey) => subscriberCountByModule.get(moduleInstanceKey) ?? 0;
252
+ const registerModuleInstance = (args) => {
253
+ moduleStates.set(args.moduleInstanceKey, args.initialState);
254
+ if (!topicVersions.has(args.moduleInstanceKey)) {
255
+ topicVersions.set(args.moduleInstanceKey, 0);
256
+ topicPriorities.set(args.moduleInstanceKey, "normal");
257
+ }
258
+ };
259
+ const unregisterModuleInstance = (moduleInstanceKey) => {
260
+ moduleStates.delete(moduleInstanceKey);
261
+ };
262
+ const commitTick = (args) => {
263
+ tickSeq = args.tickSeq;
264
+ for (const [key, commit] of args.accepted.modules) {
265
+ moduleStates.set(key, commit.state);
266
+ }
267
+ if (args.accepted.dirtyTopics.size === 0) {
268
+ return {
269
+ changedTopicListeners: NO_CHANGED_TOPIC_LISTENERS
270
+ };
271
+ }
272
+ if (args.onListener) {
273
+ let firstTopicListeners;
274
+ let secondTopicListeners;
275
+ let restTopicListeners;
276
+ for (const [topicKey, priority] of args.accepted.dirtyTopics) {
277
+ commitTopicBump(topicKey, priority);
278
+ const listeners = listenersByTopic.get(topicKey)?.snapshot ?? EMPTY_LISTENER_SNAPSHOT;
279
+ if (listeners.length === 0) {
280
+ continue;
281
+ }
282
+ if (!firstTopicListeners) {
283
+ firstTopicListeners = listeners;
284
+ continue;
285
+ }
286
+ if (!secondTopicListeners) {
287
+ secondTopicListeners = listeners;
288
+ continue;
289
+ }
290
+ if (!restTopicListeners) {
291
+ restTopicListeners = [];
292
+ }
293
+ restTopicListeners.push(listeners);
294
+ }
295
+ if (firstTopicListeners) {
296
+ for (const listener of firstTopicListeners) {
297
+ try {
298
+ args.onListener(listener);
299
+ } catch {
300
+ }
301
+ }
302
+ }
303
+ if (secondTopicListeners) {
304
+ for (const listener of secondTopicListeners) {
305
+ try {
306
+ args.onListener(listener);
307
+ } catch {
308
+ }
309
+ }
310
+ }
311
+ if (restTopicListeners) {
312
+ for (const listeners of restTopicListeners) {
313
+ for (const listener of listeners) {
314
+ try {
315
+ args.onListener(listener);
316
+ } catch {
317
+ }
318
+ }
319
+ }
320
+ }
321
+ return {
322
+ changedTopicListeners: NO_CHANGED_TOPIC_LISTENERS
323
+ };
324
+ }
325
+ let singleTopicListeners;
326
+ let flattenedTopicListeners;
327
+ for (const [topicKey, priority] of args.accepted.dirtyTopics) {
328
+ commitTopicBump(topicKey, priority);
329
+ const listeners = listenersByTopic.get(topicKey)?.snapshot ?? EMPTY_LISTENER_SNAPSHOT;
330
+ if (listeners.length === 0) {
331
+ continue;
332
+ }
333
+ if (flattenedTopicListeners) {
334
+ for (const listener of listeners) {
335
+ flattenedTopicListeners.push(listener);
336
+ }
337
+ continue;
338
+ }
339
+ if (!singleTopicListeners) {
340
+ singleTopicListeners = listeners;
341
+ continue;
342
+ }
343
+ flattenedTopicListeners = Array.from(singleTopicListeners);
344
+ for (const listener of listeners) {
345
+ flattenedTopicListeners.push(listener);
346
+ }
347
+ }
348
+ return {
349
+ changedTopicListeners: flattenedTopicListeners ?? singleTopicListeners ?? NO_CHANGED_TOPIC_LISTENERS
350
+ };
351
+ };
352
+ const getModuleState = (moduleInstanceKey) => moduleStates.get(moduleInstanceKey);
353
+ const dispose = () => {
354
+ moduleStates.clear();
355
+ topicVersions.clear();
356
+ topicPriorities.clear();
357
+ listenersByTopic.clear();
358
+ subscriberCountByModule.clear();
359
+ };
360
+ return {
361
+ getTickSeq: () => tickSeq,
362
+ getModuleState,
363
+ getTopicVersion,
364
+ getTopicPriority,
365
+ subscribeTopic,
366
+ getTopicSubscriberCount,
367
+ getModuleSubscriberCount,
368
+ registerModuleInstance,
369
+ unregisterModuleInstance,
370
+ commitTick,
371
+ dispose
372
+ };
373
+ };
374
+
375
+ // src/internal/runtime/core/TickScheduler.ts
376
+ var import_effect7 = require("effect");
377
+
378
+ // src/internal/runtime/core/DebugSink.record.ts
379
+ var import_effect3 = require("effect");
380
+
381
+ // src/internal/observability/jsonValue.ts
382
+ var defaultOptions = {
383
+ maxDepth: 6,
384
+ maxObjectKeys: 32,
385
+ maxArrayLength: 32,
386
+ maxStringLength: 256,
387
+ maxJsonBytes: 4 * 1024,
388
+ oversizedPreviewBytes: 256
389
+ };
390
+
391
+ // src/internal/runtime/core/errorSummary.ts
29
392
  var import_effect = require("effect");
393
+
394
+ // src/internal/runtime/core/EffectOpCore.ts
395
+ var import_effect2 = require("effect");
396
+ var currentLinkId = import_effect2.ServiceMap.Reference("@logixjs/core/CurrentLinkId", {
397
+ defaultValue: () => void 0
398
+ });
399
+ var EffectOpMiddlewareTag = class extends import_effect2.ServiceMap.Service()("Logix/EffectOpMiddleware") {
400
+ };
401
+
402
+ // src/internal/runtime/core/DebugSink.record.ts
403
+ var currentDebugSinks = import_effect3.ServiceMap.Reference("@logixjs/core/Debug.currentDebugSinks", {
404
+ defaultValue: () => []
405
+ });
406
+ var currentRuntimeLabel = import_effect3.ServiceMap.Reference("@logixjs/core/Debug.currentRuntimeLabel", {
407
+ defaultValue: () => void 0
408
+ });
409
+ var currentTxnId = import_effect3.ServiceMap.Reference("@logixjs/core/Debug.currentTxnId", {
410
+ defaultValue: () => void 0
411
+ });
412
+ var currentOpSeq = import_effect3.ServiceMap.Reference("@logixjs/core/Debug.currentOpSeq", {
413
+ defaultValue: () => void 0
414
+ });
415
+ var currentDiagnosticsLevel = import_effect3.ServiceMap.Reference("@logixjs/core/Debug.currentDiagnosticsLevel", {
416
+ defaultValue: () => "off"
417
+ });
418
+ var currentDiagnosticsMaterialization = import_effect3.ServiceMap.Reference(
419
+ "@logixjs/core/Debug.currentDiagnosticsMaterialization",
420
+ {
421
+ defaultValue: () => "eager"
422
+ }
423
+ );
424
+ var currentTraceMode = import_effect3.ServiceMap.Reference("@logixjs/core/Debug.currentTraceMode", {
425
+ defaultValue: () => "on"
426
+ });
427
+ var currentTraitConvergeDiagnosticsSampling = import_effect3.ServiceMap.Reference(
428
+ "@logixjs/core/Debug.currentTraitConvergeDiagnosticsSampling",
429
+ {
430
+ defaultValue: () => ({
431
+ sampleEveryN: 32,
432
+ topK: 3
433
+ })
434
+ }
435
+ );
436
+ var browserLifecycleSeen = /* @__PURE__ */ new Set();
437
+ var browserDiagnosticSeen = /* @__PURE__ */ new Set();
438
+ var lifecycleErrorLog = (event) => {
439
+ const moduleId = event.moduleId ?? "unknown";
440
+ const causePretty = (() => {
441
+ try {
442
+ return import_effect3.Cause.pretty(event.cause);
443
+ } catch {
444
+ try {
445
+ return JSON.stringify(event.cause, null, 2);
446
+ } catch {
447
+ return String(event.cause);
448
+ }
449
+ }
450
+ })();
451
+ const message = `[Logix][module=${moduleId}] lifecycle:error
452
+ ${causePretty}`;
453
+ return import_effect3.Effect.logError(message).pipe(
454
+ import_effect3.Effect.annotateLogs({
455
+ "logix.moduleId": moduleId,
456
+ "logix.event": "lifecycle:error",
457
+ "logix.cause": causePretty
458
+ })
459
+ );
460
+ };
461
+ var diagnosticLog = (event) => {
462
+ const moduleId = event.moduleId ?? "unknown";
463
+ const header = `[Logix][module=${moduleId}] diagnostic(${event.severity})`;
464
+ const detail = `code=${event.code} message=${event.message}${event.actionTag ? ` action=${event.actionTag}` : ""}${event.hint ? `
465
+ hint: ${event.hint}` : ""}`;
466
+ const msg = `${header}
467
+ ${detail}`;
468
+ const base = event.severity === "warning" ? import_effect3.Effect.logWarning(msg) : event.severity === "info" ? import_effect3.Effect.logInfo(msg) : import_effect3.Effect.logError(msg);
469
+ const annotations = {
470
+ "logix.moduleId": moduleId,
471
+ "logix.event": `diagnostic(${event.severity})`,
472
+ "logix.diagnostic.code": event.code,
473
+ "logix.diagnostic.message": event.message
474
+ };
475
+ if (event.hint) {
476
+ annotations["logix.diagnostic.hint"] = event.hint;
477
+ }
478
+ if (event.actionTag) {
479
+ annotations["logix.diagnostic.actionTag"] = event.actionTag;
480
+ }
481
+ return base.pipe(import_effect3.Effect.annotateLogs(annotations));
482
+ };
483
+ var noopLayer = import_effect3.Layer.succeed(currentDebugSinks, []);
484
+ var errorOnlySink = {
485
+ record: (event) => event.type === "lifecycle:error" ? lifecycleErrorLog(event) : event.type === "diagnostic" && event.severity !== "info" ? diagnosticLog(event) : import_effect3.Effect.void
486
+ };
487
+ var errorOnlyLayer = import_effect3.Layer.succeed(currentDebugSinks, [errorOnlySink]);
488
+ var consoleSink = {
489
+ record: (event) => event.type === "lifecycle:error" ? lifecycleErrorLog(event) : event.type === "diagnostic" ? diagnosticLog(event) : import_effect3.Effect.logDebug({ debugEvent: event })
490
+ };
491
+ var consoleLayer = import_effect3.Layer.succeed(currentDebugSinks, [consoleSink]);
492
+ var isBrowser = typeof window !== "undefined" && typeof document !== "undefined";
493
+ var renderBrowserConsoleEvent = (event) => {
494
+ if (typeof event.type === "string" && event.type.startsWith("trace:")) {
495
+ const moduleId = event.moduleId ?? "unknown";
496
+ const type = event.type;
497
+ return import_effect3.Effect.sync(() => {
498
+ console.groupCollapsed(
499
+ "%c[Logix]%c trace %c" + moduleId + "%c " + String(type),
500
+ "color:#6b7280;font-weight:bold",
501
+ // tag
502
+ "color:#3b82f6",
503
+ // label
504
+ "color:#9ca3af",
505
+ // module id
506
+ "color:#6b7280"
507
+ // type
508
+ );
509
+ console.log(event);
510
+ console.groupEnd();
511
+ });
512
+ }
513
+ if (event.type === "lifecycle:error") {
514
+ const moduleId = event.moduleId ?? "unknown";
515
+ const causePretty = (() => {
516
+ try {
517
+ return import_effect3.Cause.pretty(event.cause);
518
+ } catch {
519
+ try {
520
+ return JSON.stringify(event.cause, null, 2);
521
+ } catch {
522
+ return String(event.cause);
523
+ }
524
+ }
525
+ })();
526
+ const key = `${moduleId}|${causePretty}`;
527
+ if (browserLifecycleSeen.has(key)) {
528
+ return import_effect3.Effect.void;
529
+ }
530
+ browserLifecycleSeen.add(key);
531
+ return import_effect3.Effect.sync(() => {
532
+ console.groupCollapsed(
533
+ "%c[Logix]%c lifecycle:error %c" + moduleId,
534
+ "color:#ef4444;font-weight:bold",
535
+ // tag
536
+ "color:#ef4444",
537
+ // label
538
+ "color:#9ca3af"
539
+ // module id
540
+ );
541
+ console.error(causePretty);
542
+ console.groupEnd();
543
+ });
544
+ }
545
+ if (event.type === "diagnostic") {
546
+ const moduleId = event.moduleId ?? "unknown";
547
+ const detail = `code=${event.code} message=${event.message}${event.actionTag ? ` action=${event.actionTag}` : ""}${event.hint ? `
548
+ hint: ${event.hint}` : ""}`;
549
+ const color = event.severity === "warning" ? "color:#d97706" : event.severity === "info" ? "color:#3b82f6" : "color:#ef4444";
550
+ const label = event.severity === "warning" ? "diagnostic(warning)" : event.severity === "info" ? "diagnostic(info)" : "diagnostic(error)";
551
+ const key = `${moduleId}|${event.code}|${event.message}`;
552
+ if (browserDiagnosticSeen.has(key)) {
553
+ return import_effect3.Effect.void;
554
+ }
555
+ browserDiagnosticSeen.add(key);
556
+ return import_effect3.Effect.sync(() => {
557
+ console.groupCollapsed(
558
+ "%c[Logix]%c " + label + "%c module=" + moduleId,
559
+ "color:#6b7280;font-weight:bold",
560
+ color,
561
+ "color:#9ca3af"
562
+ );
563
+ if (event.severity === "warning") {
564
+ console.warn(detail);
565
+ } else if (event.severity === "info") {
566
+ console.info(detail);
567
+ } else {
568
+ console.error(detail);
569
+ }
570
+ console.groupEnd();
571
+ });
572
+ }
573
+ return import_effect3.Effect.void;
574
+ };
575
+ var browserConsoleSink = {
576
+ record: (event) => {
577
+ if (!isBrowser) {
578
+ return event.type === "lifecycle:error" ? lifecycleErrorLog(event) : event.type === "diagnostic" ? diagnosticLog(event) : import_effect3.Effect.logDebug({ debugEvent: event });
579
+ }
580
+ return renderBrowserConsoleEvent(event);
581
+ }
582
+ };
583
+ var browserConsoleLayer = import_effect3.Layer.succeed(currentDebugSinks, [browserConsoleSink]);
584
+ var browserDiagnosticConsoleSink = {
585
+ record: (event) => {
586
+ if (!isBrowser) {
587
+ return event.type === "lifecycle:error" ? lifecycleErrorLog(event) : event.type === "diagnostic" && event.severity !== "info" ? diagnosticLog(event) : import_effect3.Effect.void;
588
+ }
589
+ return event.type === "lifecycle:error" || event.type === "diagnostic" && event.severity !== "info" ? renderBrowserConsoleEvent(event) : import_effect3.Effect.void;
590
+ }
591
+ };
592
+ var browserDiagnosticConsoleLayer = import_effect3.Layer.succeed(currentDebugSinks, [browserDiagnosticConsoleSink]);
593
+ var browserPrettyLoggerLayer = import_effect3.Layer.effect(
594
+ import_effect3.Logger.CurrentLoggers,
595
+ import_effect3.Effect.gen(function* () {
596
+ const current = yield* import_effect3.Effect.service(import_effect3.Logger.CurrentLoggers);
597
+ return new Set(
598
+ [...current].filter((logger) => logger !== import_effect3.Logger.defaultLogger).concat(import_effect3.Logger.consolePretty({ mode: "browser", colors: true }))
599
+ );
600
+ })
601
+ );
602
+
603
+ // src/internal/runtime/core/TaskRunner.ts
604
+ var import_effect6 = require("effect");
605
+
606
+ // src/internal/runtime/core/ModeRunner.ts
607
+ var import_effect5 = require("effect");
608
+
609
+ // src/internal/runtime/core/LatestFiberSlot.ts
610
+ var import_effect4 = require("effect");
611
+
612
+ // src/internal/runtime/core/TaskRunner.ts
613
+ var inSyncTransactionFiber = import_effect6.ServiceMap.Reference("@logixjs/core/TaskRunner.inSyncTransactionFiber", {
614
+ defaultValue: () => false
615
+ });
616
+ var forceSourceRefresh = import_effect6.ServiceMap.Reference("@logixjs/core/TaskRunner.forceSourceRefresh", {
617
+ defaultValue: () => false
618
+ });
619
+
620
+ // src/internal/runtime/core/DeclarativeLinkRuntime.ts
621
+ var import_effect8 = require("effect");
622
+ var makeDeclarativeLinkRuntime = () => {
623
+ const moduleAsSourceById = /* @__PURE__ */ new Map();
624
+ const moduleAsSourceIdsBySource = /* @__PURE__ */ new Map();
625
+ const declarativeById = /* @__PURE__ */ new Map();
626
+ const declarativeReadNodesBySource = /* @__PURE__ */ new Map();
627
+ const registerModuleAsSourceLink = (link) => {
628
+ const stored = {
629
+ ...link,
630
+ hasValue: false,
631
+ lastValue: void 0
632
+ };
633
+ moduleAsSourceById.set(link.id, stored);
634
+ const set = moduleAsSourceIdsBySource.get(link.sourceModuleInstanceKey) ?? /* @__PURE__ */ new Set();
635
+ set.add(link.id);
636
+ moduleAsSourceIdsBySource.set(link.sourceModuleInstanceKey, set);
637
+ return () => {
638
+ moduleAsSourceById.delete(link.id);
639
+ const current = moduleAsSourceIdsBySource.get(link.sourceModuleInstanceKey);
640
+ if (!current) return;
641
+ current.delete(link.id);
642
+ if (current.size === 0) {
643
+ moduleAsSourceIdsBySource.delete(link.sourceModuleInstanceKey);
644
+ }
645
+ };
646
+ };
647
+ const registerDeclarativeLink = (link) => {
648
+ const readNodeById = /* @__PURE__ */ new Map();
649
+ for (const n of link.readNodes) {
650
+ readNodeById.set(n.nodeId, n);
651
+ }
652
+ const dispatchNodeById = /* @__PURE__ */ new Map();
653
+ for (const n of link.dispatchNodes) {
654
+ dispatchNodeById.set(n.nodeId, n);
655
+ }
656
+ const incomingByDispatch = /* @__PURE__ */ new Map();
657
+ for (const e of link.ir.edges) {
658
+ const to = e.to;
659
+ const isDispatch = dispatchNodeById.has(to);
660
+ if (!isDispatch) continue;
661
+ incomingByDispatch.set(to, (incomingByDispatch.get(to) ?? 0) + 1);
662
+ const count = incomingByDispatch.get(to) ?? 0;
663
+ if (count > 1) {
664
+ throw new Error(
665
+ `[DeclarativeLinkRuntime] Invalid DeclarativeLinkIR: dispatch node has multiple incoming edges (linkId=${link.linkId}, nodeId=${to}).`
666
+ );
667
+ }
668
+ }
669
+ const dispatchTargetsByReadNode = /* @__PURE__ */ new Map();
670
+ for (const e of link.ir.edges) {
671
+ const from = e.from;
672
+ const to = e.to;
673
+ if (!readNodeById.has(from)) continue;
674
+ if (!dispatchNodeById.has(to)) continue;
675
+ const list = dispatchTargetsByReadNode.get(from) ?? [];
676
+ list.push(to);
677
+ dispatchTargetsByReadNode.set(from, list);
678
+ }
679
+ const stored = {
680
+ ...link,
681
+ readNodeById,
682
+ dispatchNodeById,
683
+ dispatchTargetsByReadNode,
684
+ readNodeState: /* @__PURE__ */ new Map()
685
+ };
686
+ declarativeById.set(link.linkId, stored);
687
+ for (const n of link.readNodes) {
688
+ const list = declarativeReadNodesBySource.get(n.moduleInstanceKey) ?? [];
689
+ list.push({ linkId: link.linkId, nodeId: n.nodeId });
690
+ declarativeReadNodesBySource.set(n.moduleInstanceKey, list);
691
+ }
692
+ return () => {
693
+ declarativeById.delete(link.linkId);
694
+ for (const n of link.readNodes) {
695
+ const list = declarativeReadNodesBySource.get(n.moduleInstanceKey);
696
+ if (!list) continue;
697
+ const next = list.filter((x) => !(x.linkId === link.linkId && x.nodeId === n.nodeId));
698
+ if (next.length === 0) {
699
+ declarativeReadNodesBySource.delete(n.moduleInstanceKey);
700
+ } else {
701
+ declarativeReadNodesBySource.set(n.moduleInstanceKey, next);
702
+ }
703
+ }
704
+ };
705
+ };
706
+ const applyForSources = (args) => import_effect8.Effect.gen(function* () {
707
+ let scheduled = false;
708
+ for (const sourceKey of args.changedModuleInstanceKeys) {
709
+ const ids = moduleAsSourceIdsBySource.get(sourceKey);
710
+ if (!ids || ids.size === 0) continue;
711
+ const commit = args.acceptedModules.get(sourceKey);
712
+ if (!commit) continue;
713
+ for (const id of ids) {
714
+ const link = moduleAsSourceById.get(id);
715
+ if (!link) continue;
716
+ let selected;
717
+ try {
718
+ selected = link.readQuery.select(commit.state);
719
+ } catch {
720
+ continue;
721
+ }
722
+ const nextValue = link.computeValue(selected);
723
+ if (link.hasValue && link.equalsValue(link.lastValue, nextValue)) {
724
+ continue;
725
+ }
726
+ link.hasValue = true;
727
+ link.lastValue = nextValue;
728
+ scheduled = true;
729
+ yield* link.applyValue(nextValue);
730
+ }
731
+ }
732
+ for (const sourceKey of args.changedModuleInstanceKeys) {
733
+ const refs = declarativeReadNodesBySource.get(sourceKey);
734
+ if (!refs || refs.length === 0) continue;
735
+ const commit = args.acceptedModules.get(sourceKey);
736
+ if (!commit) continue;
737
+ for (const ref of refs) {
738
+ const link = declarativeById.get(ref.linkId);
739
+ if (!link) continue;
740
+ const readNode = link.readNodeById.get(ref.nodeId);
741
+ if (!readNode) continue;
742
+ let value;
743
+ try {
744
+ value = readNode.readQuery.select(commit.state);
745
+ } catch {
746
+ continue;
747
+ }
748
+ const state = link.readNodeState.get(ref.nodeId) ?? { hasValue: false, lastValue: void 0 };
749
+ const changed = !state.hasValue || !Object.is(state.lastValue, value);
750
+ if (!changed) continue;
751
+ state.hasValue = true;
752
+ state.lastValue = value;
753
+ link.readNodeState.set(ref.nodeId, state);
754
+ const targets = link.dispatchTargetsByReadNode.get(ref.nodeId) ?? [];
755
+ for (const dispatchNodeId of targets) {
756
+ const node = link.dispatchNodeById.get(dispatchNodeId);
757
+ if (!node) continue;
758
+ scheduled = true;
759
+ yield* node.dispatch(value);
760
+ }
761
+ }
762
+ }
763
+ return { scheduled };
764
+ });
765
+ return {
766
+ registerModuleAsSourceLink,
767
+ registerDeclarativeLink,
768
+ applyForSources
769
+ };
770
+ };
771
+
772
+ // src/internal/runtime/core/env.ts
30
773
  var getNodeEnv = () => {
31
774
  try {
32
775
  const env = globalThis?.process?.env;
@@ -36,17 +779,40 @@ var getNodeEnv = () => {
36
779
  }
37
780
  };
38
781
  var isDevEnv = () => getNodeEnv() !== "production";
39
- var StateTransactionConfigTagImpl = class extends import_effect.Context.Tag("@logixjs/core/StateTransactionRuntimeConfig")() {
782
+ var StateTransactionConfigTagImpl = class extends import_effect9.ServiceMap.Service()("@logixjs/core/StateTransactionRuntimeConfig") {
783
+ };
784
+ var ReadQueryStrictGateConfigTagImpl = class extends import_effect9.ServiceMap.Service()("@logixjs/core/ReadQueryStrictGateRuntimeConfig") {
785
+ };
786
+ var ReplayModeConfigTagImpl = class extends import_effect9.ServiceMap.Service()("@logixjs/core/ReplayModeConfig") {
787
+ };
788
+ var StateTransactionOverridesTagImpl = class extends import_effect9.ServiceMap.Service()("@logixjs/core/StateTransactionOverrides") {
789
+ };
790
+ var SchedulingPolicySurfaceTagImpl = class extends import_effect9.ServiceMap.Service()("@logixjs/core/SchedulingPolicySurface") {
40
791
  };
41
- var ReadQueryStrictGateConfigTagImpl = class extends import_effect.Context.Tag("@logixjs/core/ReadQueryStrictGateRuntimeConfig")() {
792
+ var SchedulingPolicySurfaceOverridesTagImpl = class extends import_effect9.ServiceMap.Service()("@logixjs/core/SchedulingPolicySurfaceOverrides") {
42
793
  };
43
- var ReplayModeConfigTagImpl = class extends import_effect.Context.Tag("@logixjs/core/ReplayModeConfig")() {
794
+ var RuntimeStoreTag = class extends import_effect9.ServiceMap.Service()("@logixjs/core/RuntimeStore") {
44
795
  };
45
- var StateTransactionOverridesTagImpl = class extends import_effect.Context.Tag("@logixjs/core/StateTransactionOverrides")() {
796
+ var runtimeStoreLayer = import_effect9.Layer.effect(
797
+ RuntimeStoreTag,
798
+ import_effect9.Effect.acquireRelease(
799
+ import_effect9.Effect.sync(() => makeRuntimeStore()),
800
+ (store) => import_effect9.Effect.sync(() => store.dispose())
801
+ )
802
+ );
803
+ var HostSchedulerTag = class extends import_effect9.ServiceMap.Service()("@logixjs/core/HostScheduler") {
46
804
  };
47
- var ConcurrencyPolicyTagImpl = class extends import_effect.Context.Tag("@logixjs/core/ConcurrencyPolicy")() {
805
+ var hostSchedulerLayer = import_effect9.Layer.succeed(
806
+ HostSchedulerTag,
807
+ getGlobalHostScheduler()
808
+ );
809
+ var DeclarativeLinkRuntimeTag = class extends import_effect9.ServiceMap.Service()("@logixjs/core/DeclarativeLinkRuntime") {
48
810
  };
49
- var ConcurrencyPolicyOverridesTagImpl = class extends import_effect.Context.Tag("@logixjs/core/ConcurrencyPolicyOverrides")() {
811
+ var declarativeLinkRuntimeLayer = import_effect9.Layer.succeed(
812
+ DeclarativeLinkRuntimeTag,
813
+ makeDeclarativeLinkRuntime()
814
+ );
815
+ var TickSchedulerTag = class extends import_effect9.ServiceMap.Service()("@logixjs/core/TickScheduler") {
50
816
  };
51
817
 
52
818
  // src/Env.ts