@graphrefly/graphrefly 0.42.0 → 0.44.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 (284) hide show
  1. package/dist/{cascading-CH-_VwG9.d.cts → cascading-BglDkMdX.d.cts} +2 -2
  2. package/dist/{cascading-OgKQZjsa.d.ts → cascading-MFgxu7Yo.d.ts} +2 -2
  3. package/dist/chunk-2T7U5EU6.js +1 -0
  4. package/dist/chunk-5M4CCMMD.js +45 -0
  5. package/dist/{chunk-YGL7FPVQ.js → chunk-5XJ6B66J.js} +1 -1
  6. package/dist/{chunk-NWXQIOIB.js → chunk-6X7AFUJV.js} +1 -1
  7. package/dist/chunk-7K6PWTDQ.js +1 -0
  8. package/dist/{chunk-D27JNOLZ.js → chunk-7LIAPXJB.js} +1 -1
  9. package/dist/{chunk-CLD3F4R5.js → chunk-7WPU3UHQ.js} +1 -1
  10. package/dist/{chunk-NNKJUORL.js → chunk-A5WCQ5NO.js} +1 -1
  11. package/dist/chunk-APPIWSGD.js +84 -0
  12. package/dist/{chunk-TZQPPQEQ.js → chunk-BEZWM2SY.js} +1 -1
  13. package/dist/{chunk-5QRRKBUT.js → chunk-CB676TKJ.js} +1 -1
  14. package/dist/{chunk-KT5DTRBP.js → chunk-CE6TI2TL.js} +1 -1
  15. package/dist/{chunk-6YFZMUMR.js → chunk-CLVB32RD.js} +1 -1
  16. package/dist/{chunk-2K5RXLAH.js → chunk-CRVT7D2P.js} +1 -1
  17. package/dist/chunk-D7GPHKFH.js +1 -0
  18. package/dist/{chunk-FUZ6S2DY.js → chunk-DHRX7JX4.js} +1 -1
  19. package/dist/chunk-FZMYDOWV.js +1 -0
  20. package/dist/{chunk-35JTVPOX.js → chunk-GHBWHMRZ.js} +1 -1
  21. package/dist/{chunk-KGKJCHEK.js → chunk-GLERH466.js} +1 -1
  22. package/dist/{chunk-CISGGAIF.js → chunk-HIDYF36O.js} +1 -1
  23. package/dist/chunk-HITNVN6B.js +3 -0
  24. package/dist/{chunk-7ARY3Y3T.js → chunk-HY4DJBA7.js} +1 -1
  25. package/dist/chunk-KZIEYVXN.js +1 -0
  26. package/dist/{chunk-IZM3UEH3.js → chunk-N4MQX6JU.js} +1 -1
  27. package/dist/{chunk-FDZAZNRO.js → chunk-N7FHEL4D.js} +1 -1
  28. package/dist/chunk-NTEURFZH.js +1 -0
  29. package/dist/{chunk-4QH6VJF4.js → chunk-OIVP6KFV.js} +1 -1
  30. package/dist/{chunk-KCACBSJH.js → chunk-OPHBU3LG.js} +1 -1
  31. package/dist/{chunk-Q7QQQA3I.js → chunk-OYQOZP2F.js} +1 -1
  32. package/dist/{chunk-7B7ELAT2.js → chunk-PTZK576G.js} +1 -1
  33. package/dist/{chunk-DEJTNNQC.js → chunk-ST7UXLWR.js} +1 -1
  34. package/dist/chunk-SVY7VUYU.js +1 -0
  35. package/dist/{chunk-WHMUB5QB.js → chunk-TK3NWWD4.js} +1 -1
  36. package/dist/chunk-UNGSTR4X.js +61 -0
  37. package/dist/{chunk-VRALOYRD.js → chunk-VV4N5P64.js} +1 -1
  38. package/dist/chunk-W3I423PS.js +1 -0
  39. package/dist/{chunk-HZKW2AAB.js → chunk-WJR24TAG.js} +1 -1
  40. package/dist/{chunk-F3IGTWCQ.js → chunk-XTGKMHSW.js} +1 -1
  41. package/dist/{chunk-LDQ3IUIP.js → chunk-YBB7ZGTY.js} +1 -1
  42. package/dist/{chunk-G5VBJ5K6.js → chunk-Z4NPUARF.js} +1 -1
  43. package/dist/{chunk-KRH66M4O.js → chunk-ZGNQRPDT.js} +1 -1
  44. package/dist/{chunk-AGNM6RS6.js → chunk-ZKPSFFKU.js} +1 -1
  45. package/dist/{chunk-KY2LMAXU.js → chunk-ZLV5SQSX.js} +1 -1
  46. package/dist/compat/index.cjs +5 -5
  47. package/dist/compat/index.d.cts +16 -16
  48. package/dist/compat/index.d.ts +16 -16
  49. package/dist/compat/index.js +1 -1
  50. package/dist/compat/jotai/index.cjs +1 -1
  51. package/dist/compat/jotai/index.d.cts +2 -2
  52. package/dist/compat/jotai/index.d.ts +2 -2
  53. package/dist/compat/jotai/index.js +1 -1
  54. package/dist/compat/nanostores/index.cjs +1 -1
  55. package/dist/compat/nanostores/index.d.cts +2 -2
  56. package/dist/compat/nanostores/index.d.ts +2 -2
  57. package/dist/compat/nanostores/index.js +1 -1
  58. package/dist/compat/nestjs/index.cjs +5 -5
  59. package/dist/compat/nestjs/index.d.cts +8 -8
  60. package/dist/compat/nestjs/index.d.ts +8 -8
  61. package/dist/compat/nestjs/index.js +1 -1
  62. package/dist/compat/react/index.d.cts +2 -2
  63. package/dist/compat/react/index.d.ts +2 -2
  64. package/dist/compat/solid/index.d.cts +2 -2
  65. package/dist/compat/solid/index.d.ts +2 -2
  66. package/dist/compat/svelte/index.d.cts +2 -2
  67. package/dist/compat/svelte/index.d.ts +2 -2
  68. package/dist/compat/vue/index.d.cts +2 -2
  69. package/dist/compat/vue/index.d.ts +2 -2
  70. package/dist/compat/zustand/index.cjs +3 -3
  71. package/dist/compat/zustand/index.d.cts +4 -4
  72. package/dist/compat/zustand/index.d.ts +4 -4
  73. package/dist/compat/zustand/index.js +1 -1
  74. package/dist/core/index.cjs +1 -1
  75. package/dist/core/index.d.cts +3 -4
  76. package/dist/core/index.d.ts +3 -4
  77. package/dist/core/index.js +1 -1
  78. package/dist/{decay-CdEBmDIs.d.ts → decay-BvOWTZ00.d.ts} +2 -2
  79. package/dist/{decay-2ZukgQ4o.d.cts → decay-CFlLvXUT.d.cts} +2 -2
  80. package/dist/extra/browser.cjs +1 -1
  81. package/dist/extra/browser.d.cts +1 -1
  82. package/dist/extra/browser.d.ts +1 -1
  83. package/dist/extra/browser.js +1 -1
  84. package/dist/extra/index.cjs +15 -15
  85. package/dist/extra/index.d.cts +10 -10
  86. package/dist/extra/index.d.ts +10 -10
  87. package/dist/extra/index.js +1 -1
  88. package/dist/extra/node.cjs +2 -2
  89. package/dist/extra/node.d.cts +1 -1
  90. package/dist/extra/node.d.ts +1 -1
  91. package/dist/extra/node.js +1 -1
  92. package/dist/extra/operators.cjs +1 -1
  93. package/dist/extra/operators.d.cts +9 -1
  94. package/dist/extra/operators.d.ts +9 -1
  95. package/dist/extra/operators.js +1 -1
  96. package/dist/extra/reactive.cjs +1 -1
  97. package/dist/extra/reactive.d.cts +3 -3
  98. package/dist/extra/reactive.d.ts +3 -3
  99. package/dist/extra/reactive.js +1 -1
  100. package/dist/extra/render/index.d.cts +3 -3
  101. package/dist/extra/render/index.d.ts +3 -3
  102. package/dist/extra/sources.cjs +3 -3
  103. package/dist/extra/sources.d.cts +1 -1
  104. package/dist/extra/sources.d.ts +1 -1
  105. package/dist/extra/sources.js +1 -1
  106. package/dist/extra/storage-browser.cjs +1 -1
  107. package/dist/extra/storage-browser.d.cts +1 -1
  108. package/dist/extra/storage-browser.d.ts +1 -1
  109. package/dist/extra/storage-browser.js +1 -1
  110. package/dist/{fallback-Ctlj2tMY.d.cts → fallback-74oxi34l.d.cts} +1 -1
  111. package/dist/{fallback-CqYVLL6X.d.ts → fallback-DUyyBTBK.d.ts} +1 -1
  112. package/dist/graph/index.cjs +7 -7
  113. package/dist/graph/index.d.cts +5 -5
  114. package/dist/graph/index.d.ts +5 -5
  115. package/dist/graph/index.js +1 -1
  116. package/dist/{graph-C4SHb3Ly.d.cts → graph-CWvEUQAq.d.cts} +196 -3
  117. package/dist/{graph-7VguS7a4.d.ts → graph-D9LFnda9.d.ts} +196 -3
  118. package/dist/{index-LIpQQE9f.d.cts → index-5k1T6jl0.d.cts} +9 -9
  119. package/dist/{index-CPNSy-U0.d.cts → index-9770hRuQ.d.cts} +23 -4
  120. package/dist/{index-CEMx8n40.d.cts → index-B-_tFaqV.d.cts} +4 -4
  121. package/dist/{index-2B7u2pVn.d.cts → index-B17QddL1.d.cts} +4 -4
  122. package/dist/{index-B-i4_g3k.d.ts → index-B1F8Enjf.d.ts} +61 -8
  123. package/dist/{index-DBevwHj_.d.ts → index-B5S8ULbU.d.ts} +3 -3
  124. package/dist/{index-Dgs8zcj7.d.ts → index-B8YnZpIR.d.ts} +2 -2
  125. package/dist/{index-B3OTH1dV.d.ts → index-BHskSB8v.d.ts} +28 -17
  126. package/dist/{index-sl4NyzQx.d.cts → index-BIYAkbAi.d.cts} +1 -1
  127. package/dist/{index-C9kSENB4.d.cts → index-BQSKmbuG.d.cts} +1 -1
  128. package/dist/{index-tJoTcnHh.d.cts → index-BaQaY_IQ.d.cts} +2 -2
  129. package/dist/{index-CJK1JkYy.d.ts → index-BmZXHqkE.d.ts} +1 -1
  130. package/dist/{index-pT8sCpOJ.d.ts → index-BoJ5JHxI.d.ts} +12 -3
  131. package/dist/{index-BeT2r7sk.d.ts → index-BocU7pqs.d.ts} +23 -4
  132. package/dist/{index-ChOyVLKm.d.cts → index-BrPrLl4e.d.cts} +1 -1
  133. package/dist/{index-D-Xs74HZ.d.cts → index-BxNs2HB9.d.cts} +33 -9
  134. package/dist/{index-Bf7eqeSF.d.ts → index-Byu-OpX_.d.ts} +2 -2
  135. package/dist/{index-BoLv_OfD.d.cts → index-C1T3d7V-.d.cts} +61 -8
  136. package/dist/{index-BTQtTb_H.d.cts → index-C5ri2Axc.d.cts} +3 -3
  137. package/dist/{index-z96luz5O.d.cts → index-C5stwKcw.d.cts} +1 -1
  138. package/dist/{index-CZmcDtFn.d.ts → index-C9l6OEBL.d.ts} +1 -1
  139. package/dist/{index-CCq87F7t.d.ts → index-CBBLl_rc.d.ts} +1 -1
  140. package/dist/{index-D6egPFAL.d.ts → index-CBGUK09R.d.ts} +4 -4
  141. package/dist/{index-C0-Jv1kP.d.cts → index-CC-AvFTy.d.cts} +12 -3
  142. package/dist/{index-DQo8xBgd.d.ts → index-CJF1URuX.d.ts} +9 -9
  143. package/dist/{index-BJX94aud.d.cts → index-CK29LV56.d.cts} +1 -1
  144. package/dist/{index-BP8a88zx.d.ts → index-CMh5Rz1y.d.ts} +4 -4
  145. package/dist/{index-CvrqGfNS.d.ts → index-CPQlGA29.d.ts} +1 -1
  146. package/dist/{index-Bbkgpt5t.d.ts → index-CR8QpwX8.d.ts} +49 -24
  147. package/dist/{index-Du7u1lSf.d.cts → index-CS0LTlB8.d.cts} +4 -4
  148. package/dist/{index-Bc41FuHp.d.cts → index-CSOmP7xT.d.cts} +2 -2
  149. package/dist/{index-BsT7F2et.d.ts → index-CYq8vAyV.d.ts} +2 -2
  150. package/dist/{index-Bn4zHYLj.d.ts → index-CZ3r5Rxp.d.ts} +4 -4
  151. package/dist/{index-HoU88d5U.d.cts → index-CasX6Pfq.d.cts} +68 -9
  152. package/dist/{index-BG0BN3PB.d.ts → index-CdAlHFEt.d.ts} +1 -1
  153. package/dist/{index-CpyNFqkB.d.ts → index-CdTelp1M.d.ts} +8 -4
  154. package/dist/{index-D8l8hNXn.d.ts → index-CeFiHtAg.d.ts} +4 -4
  155. package/dist/{index-DmAgG5CI.d.cts → index-Cj3WohTd.d.cts} +8 -4
  156. package/dist/{index-BtAsBp8K.d.cts → index-Climxqsu.d.cts} +4 -4
  157. package/dist/{index-CJIuLu2f.d.cts → index-Co7uli2l.d.cts} +28 -17
  158. package/dist/{index-DIOoAZUX.d.ts → index-CviRnE4K.d.ts} +1 -1
  159. package/dist/{index-Dhc7a7Xo.d.cts → index-Cwv0KWcU.d.cts} +2 -2
  160. package/dist/{index-Dn-wI9g4.d.ts → index-CzLVrjxn.d.ts} +2 -2
  161. package/dist/{index-DO9XxMzS.d.ts → index-D0aciIex.d.cts} +3 -18
  162. package/dist/{index-4Uz-e_fL.d.ts → index-DHen9Klo.d.ts} +33 -9
  163. package/dist/{index-3NmAfcH0.d.cts → index-DV_1YuVk.d.cts} +40 -8
  164. package/dist/{index-BdGtBX-X.d.cts → index-Dc4AYqrJ.d.cts} +3 -3
  165. package/dist/{index-Dmqp7KjD.d.ts → index-Dgl1HpPn.d.ts} +1 -1
  166. package/dist/{index-CJQm0g38.d.ts → index-DisjX8a-.d.ts} +40 -8
  167. package/dist/{index-B11anra4.d.cts → index-UPSiS-X7.d.cts} +49 -24
  168. package/dist/{index-DBIqYS43.d.cts → index-Yq60JP3s.d.ts} +3 -18
  169. package/dist/{index-f5IivDUX.d.cts → index-ZVQhLa2i.d.cts} +1 -1
  170. package/dist/{index-hHcaFlJX.d.cts → index-_6ODbuOu.d.cts} +1 -1
  171. package/dist/{index-BVpm6noz.d.cts → index-hcDJ8PSI.d.cts} +1 -1
  172. package/dist/{index-DBHK8O6H.d.ts → index-nozs3fFC.d.ts} +3 -3
  173. package/dist/{index-BUYXac2c.d.ts → index-p09KSrTN.d.ts} +68 -9
  174. package/dist/{index-C7O6r5fV.d.ts → index-sqkqlb1p.d.ts} +1 -1
  175. package/dist/{index-CZjOhcBy.d.cts → index-tRCxuAXF.d.cts} +2 -2
  176. package/dist/index.cjs +48 -48
  177. package/dist/index.d.cts +42 -43
  178. package/dist/index.d.ts +42 -43
  179. package/dist/index.js +1 -1
  180. package/dist/{node-ClS5yC-B.d.cts → node-kK3CvTrR.d.cts} +1 -1
  181. package/dist/{node-ClS5yC-B.d.ts → node-kK3CvTrR.d.ts} +1 -1
  182. package/dist/{observable-BsBzUrcI.d.ts → observable-DWjNfLvC.d.ts} +1 -1
  183. package/dist/{observable-DLGPPtb8.d.cts → observable-e3eiPPFy.d.cts} +1 -1
  184. package/dist/patterns/ai/browser.cjs +5 -5
  185. package/dist/patterns/ai/browser.d.cts +4 -4
  186. package/dist/patterns/ai/browser.d.ts +4 -4
  187. package/dist/patterns/ai/browser.js +1 -1
  188. package/dist/patterns/ai/index.cjs +16 -16
  189. package/dist/patterns/ai/index.d.cts +16 -17
  190. package/dist/patterns/ai/index.d.ts +16 -17
  191. package/dist/patterns/ai/index.js +1 -1
  192. package/dist/patterns/ai/node.cjs +1 -1
  193. package/dist/patterns/ai/node.d.cts +4 -4
  194. package/dist/patterns/ai/node.d.ts +4 -4
  195. package/dist/patterns/ai/node.js +1 -1
  196. package/dist/patterns/cqrs/index.cjs +3 -3
  197. package/dist/patterns/cqrs/index.d.cts +6 -6
  198. package/dist/patterns/cqrs/index.d.ts +6 -6
  199. package/dist/patterns/cqrs/index.js +1 -1
  200. package/dist/patterns/demo-shell/index.cjs +5 -5
  201. package/dist/patterns/demo-shell/index.d.cts +5 -5
  202. package/dist/patterns/demo-shell/index.d.ts +5 -5
  203. package/dist/patterns/demo-shell/index.js +1 -1
  204. package/dist/patterns/domain-templates/index.cjs +3 -3
  205. package/dist/patterns/domain-templates/index.d.cts +4 -4
  206. package/dist/patterns/domain-templates/index.d.ts +4 -4
  207. package/dist/patterns/domain-templates/index.js +1 -1
  208. package/dist/patterns/graphspec/index.cjs +16 -16
  209. package/dist/patterns/graphspec/index.d.cts +5 -5
  210. package/dist/patterns/graphspec/index.d.ts +5 -5
  211. package/dist/patterns/graphspec/index.js +1 -1
  212. package/dist/patterns/harness/index.cjs +9 -9
  213. package/dist/patterns/harness/index.d.cts +10 -11
  214. package/dist/patterns/harness/index.d.ts +10 -11
  215. package/dist/patterns/harness/index.js +1 -1
  216. package/dist/patterns/inspect/index.cjs +3 -3
  217. package/dist/patterns/inspect/index.d.cts +7 -7
  218. package/dist/patterns/inspect/index.d.ts +7 -7
  219. package/dist/patterns/inspect/index.js +1 -1
  220. package/dist/patterns/job-queue/index.cjs +3 -3
  221. package/dist/patterns/job-queue/index.d.cts +6 -6
  222. package/dist/patterns/job-queue/index.d.ts +6 -6
  223. package/dist/patterns/job-queue/index.js +1 -1
  224. package/dist/patterns/memory/index.cjs +3 -3
  225. package/dist/patterns/memory/index.d.cts +6 -6
  226. package/dist/patterns/memory/index.d.ts +6 -6
  227. package/dist/patterns/memory/index.js +1 -1
  228. package/dist/patterns/messaging/index.cjs +3 -3
  229. package/dist/patterns/messaging/index.d.cts +5 -5
  230. package/dist/patterns/messaging/index.d.ts +5 -5
  231. package/dist/patterns/messaging/index.js +1 -1
  232. package/dist/patterns/orchestration/index.cjs +3 -3
  233. package/dist/patterns/orchestration/index.d.cts +6 -7
  234. package/dist/patterns/orchestration/index.d.ts +6 -7
  235. package/dist/patterns/orchestration/index.js +1 -1
  236. package/dist/patterns/process/index.cjs +3 -1
  237. package/dist/patterns/process/index.d.cts +7 -7
  238. package/dist/patterns/process/index.d.ts +7 -7
  239. package/dist/patterns/process/index.js +1 -1
  240. package/dist/patterns/reactive-layout/index.cjs +4 -4
  241. package/dist/patterns/reactive-layout/index.d.cts +5 -5
  242. package/dist/patterns/reactive-layout/index.d.ts +5 -5
  243. package/dist/patterns/reactive-layout/index.js +1 -1
  244. package/dist/patterns/reduction/index.cjs +3 -3
  245. package/dist/patterns/reduction/index.d.cts +4 -4
  246. package/dist/patterns/reduction/index.d.ts +4 -4
  247. package/dist/patterns/reduction/index.js +1 -1
  248. package/dist/patterns/surface/index.cjs +10 -10
  249. package/dist/patterns/surface/index.d.cts +6 -6
  250. package/dist/patterns/surface/index.d.ts +6 -6
  251. package/dist/patterns/surface/index.js +1 -1
  252. package/dist/{pipeline-graph-WBlobVhU.d.cts → pipeline-graph-CIKhynsF.d.cts} +11 -6
  253. package/dist/{pipeline-graph-v8fMvqNk.d.ts → pipeline-graph-Sgj0gCwn.d.ts} +11 -6
  254. package/dist/{reactive-layout-v7KPvxoc.d.ts → reactive-layout-DOTs9P3X.d.ts} +2 -2
  255. package/dist/{reactive-layout-Dsvob4zD.d.cts → reactive-layout-DgctbqZo.d.cts} +2 -2
  256. package/dist/{reactive-log-BezYsbA_.d.ts → reactive-log-BKALbfal.d.ts} +1 -1
  257. package/dist/{reactive-log-B00laMSQ.d.cts → reactive-log-DIGdYqQ6.d.cts} +1 -1
  258. package/dist/{reactive-map-48mnZ-nu.d.cts → reactive-map-CEFGp8TK.d.cts} +1 -1
  259. package/dist/{reactive-map-BVVPdvmi.d.ts → reactive-map-DS_SIAxv.d.ts} +1 -1
  260. package/dist/resilience-6LYQJAC5.js +1 -0
  261. package/dist/sugar-DQjFmVqb.d.cts +399 -0
  262. package/dist/sugar-fhLIE7TT.d.ts +399 -0
  263. package/dist/{topology-tree-BSdfSwMi.d.cts → topology-tree-Bcz27hpF.d.cts} +1 -1
  264. package/dist/{topology-tree-BNGvuG82.d.ts → topology-tree-xvaD0fOX.d.ts} +1 -1
  265. package/dist/{types-B1jDWVsM.d.cts → types-C0_yquda.d.cts} +1 -1
  266. package/dist/{types-DkzUUs0H.d.ts → types-CWFysE9E.d.ts} +1 -1
  267. package/package.json +1 -1
  268. package/dist/chunk-3ERTUW2J.js +0 -45
  269. package/dist/chunk-3K7HA4Y6.js +0 -1
  270. package/dist/chunk-3ZZX7M25.js +0 -1
  271. package/dist/chunk-4I45FVQS.js +0 -1
  272. package/dist/chunk-5ST42ESJ.js +0 -1
  273. package/dist/chunk-7VKFXLZQ.js +0 -84
  274. package/dist/chunk-ACMJ2ZPS.js +0 -3
  275. package/dist/chunk-AS3TV2TV.js +0 -1
  276. package/dist/chunk-LPRWATHB.js +0 -61
  277. package/dist/chunk-LYCLF26R.js +0 -1
  278. package/dist/chunk-VE5SIZEM.js +0 -1
  279. package/dist/chunk-XLQPNNIC.js +0 -1
  280. package/dist/meta-BgVAsg9j.d.ts +0 -102
  281. package/dist/meta-vE8bxW1E.d.cts +0 -102
  282. package/dist/resilience-445VFFXQ.js +0 -1
  283. package/dist/sugar-CH-2ZY90.d.ts +0 -203
  284. package/dist/sugar-DStZfUEK.d.cts +0 -203
@@ -1,5 +1,5 @@
1
- "use strict";var Qe=Object.defineProperty;var mn=Object.getOwnPropertyDescriptor;var bn=Object.getOwnPropertyNames;var yn=Object.prototype.hasOwnProperty;var F=(r,e)=>()=>(r&&(e=r(r=0)),e);var vn=(r,e)=>{for(var t in e)Qe(r,t,{get:e[t],enumerable:!0})},_n=(r,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of bn(e))!yn.call(r,s)&&s!==t&&Qe(r,s,{get:()=>e[s],enumerable:!(n=mn(e,s))||n.enumerable});return r};var wn=r=>_n(Qe({},"__esModule",{value:!0}),r);function Me(){return ge>0||ke}function xt(){return ge>0}function be(r){ge>0?Te.push(r):r()}function Ge(r){ge+=1;let e=!1;try{r()}catch(t){throw e=!0,t}finally{if(ge-=1,ge===0)if(e){if(!ke){let t=Te.splice(0);for(let n of t)try{n()}catch{}fe.length=0,pe.length=0,me.length=0}}else xn()}}function xn(){let r=!ke;r&&(ke=!0);let e=[],t=0;try{for(;fe.length>0||pe.length>0||me.length>0||r&&Te.length>0;){if(r&&Te.length>0){let o=Te.splice(0);for(let i of o)try{i()}catch(u){e.push(u)}continue}if(t+=1,t>1e3)throw fe.length=0,pe.length=0,me.length=0,new Error("batch drain exceeded 1000 iterations \u2014 likely a reactive cycle");let s=(fe.length>0?fe:pe.length>0?pe:me).splice(0);for(let o of s)try{o()}catch(i){e.push(i)}}}finally{r&&(ke=!1)}if(e.length===1)throw e[0];if(e.length>1)throw new AggregateError(e,"batch drain: multiple callbacks threw")}function Pe(r,e,t){if(e.length===0)return;if(e.length===1){let d=t(e[0][0]);if(d<3||!Me()){r(e);return}(d>=5?me:d===4?pe:fe).push(()=>r(e));return}let n=e.length,s=n,o=n,i=n,u=0;for(;u<n&&t(e[u][0])<3;)u++;for(s=u;u<n&&t(e[u][0])===3;)u++;for(o=u;u<n&&t(e[u][0])===4;)u++;i=u;let a=Me();if(s>0){let d=e.slice(0,s);r(d)}if(o>s){let d=e.slice(s,o);a?fe.push(()=>r(d)):r(d)}if(i>o){let d=e.slice(o,i);a?pe.push(()=>r(d)):r(d)}if(n>i){let d=e.slice(i,n);a?me.push(()=>r(d)):r(d)}}var ge,ke,fe,pe,me,Te,Ie=F(()=>{"use strict";ge=0,ke=!1,fe=[],pe=[],me=[],Te=[]});function et(r){let e=kn.filter(t=>r({type:t,id:""},"write"));return e.length===0?"restricted":e.includes("human")&&e.includes("llm")&&e.every(t=>t==="human"||t==="llm"||t==="system")?"both":e.length===1?e[0]:e.join("+")}var te,kn,Le=F(()=>{"use strict";te=class extends Error{actor;action;nodeName;constructor(e,t){super(t??`GuardDenied: action "${String(e.action)}" denied for actor type "${String(e.actor.type)}"`),this.name="GuardDenied",this.actor=e.actor,this.action=e.action,this.nodeName=e.nodeName}get node(){return this.nodeName}},kn=["human","llm","wallet","system"]});function Tt(r,e){let t=new TextEncoder().encode(r.name);if(t.length===0||t.length>255)throw new Error(`encodeEnvelope: codec name "${r.name}" encodes to ${t.length} bytes (must be 1\u2013255)`);let n=r.version;if(!Number.isInteger(n)||n<0||n>65535)throw new Error(`encodeEnvelope: codec.version ${n} out of u16 range (expected integer 0\u201365535)`);let s=2+t.length+2+e.length;if(s>4294967295)throw new Error(`encodeEnvelope: total envelope size ${s} exceeds 2^32-1 bytes (payload ${e.length} bytes)`);let o=new Uint8Array(s),i=0;return o[i++]=tt,o[i++]=t.length,o.set(t,i),i+=t.length,o[i++]=n>>>8&255,o[i++]=n&255,o.set(e,i),o}function Ot(r,e){if(r.length<kt)throw new Error(`decodeEnvelope: bytes too short (${r.length} < ${kt})`);let t=0,n=r[t++];if(n!==tt)throw new Error(`decodeEnvelope: unsupported envelope version ${n} (expected ${tt})`);let s=r[t++];if(s===0)throw new Error("decodeEnvelope: name_len must be >= 1");if(t+s+2>r.length)throw new Error(`decodeEnvelope: envelope truncated (need ${t+s+2} bytes, have ${r.length})`);let o=new TextDecoder().decode(r.subarray(t,t+s));t+=s;let i=(r[t]<<8|r[t+1])>>>0;t+=2;let u=r.subarray(t),a=e.lookupCodec(o);if(a==null)throw new Error(`decodeEnvelope: codec "${o}" not registered (envelope codec_v=${i})`);return{codec:a,codecVersion:i,payload:u}}function Nt(r){r.registerCodec(Tn)}var Tn,tt,kt,nt=F(()=>{"use strict";Tn={name:"json",version:1,contentType:"application/json",encode(r){let e=JSON.stringify(r);return new TextEncoder().encode(e)},decode(r,e){let t=new TextDecoder().decode(r);return JSON.parse(t)}},tt=1,kt=4});function $e(r){if(r==null)return ye;let{type:e,id:t,...n}=r;return{type:e??"system",id:t??"",...n}}var ye,rt=F(()=>{"use strict";ye={type:"system",id:""}});function ue(){return Math.trunc(performance.now()*1e6)}function Fe(){return Date.now()*1e6}var je=F(()=>{"use strict"});var Oe,K,se,oe,ne,ie,de,q,ee,B,ve,st,On,ot,Nn,Sn,it,St,Et,Rt,at,Be=F(()=>{"use strict";Oe=Symbol.for("graphrefly/START"),K=Symbol.for("graphrefly/DATA"),se=Symbol.for("graphrefly/DIRTY"),oe=Symbol.for("graphrefly/RESOLVED"),ne=Symbol.for("graphrefly/INVALIDATE"),ie=Symbol.for("graphrefly/PAUSE"),de=Symbol.for("graphrefly/RESUME"),q=Symbol.for("graphrefly/TEARDOWN"),ee=Symbol.for("graphrefly/COMPLETE"),B=Symbol.for("graphrefly/ERROR"),ve=Object.freeze([se]),st=Object.freeze([oe]),On=Object.freeze([ne]),ot=Object.freeze([Oe]),Nn=Object.freeze([ee]),Sn=Object.freeze([q]),it=Object.freeze([ve]),St=Object.freeze([st]),Et=Object.freeze([On]),Rt=Object.freeze([Nn]),at=Object.freeze([Sn])});function At(r){r.registerMessageType(Oe,{tier:0,wireCrossing:!1}),r.registerMessageType(se,{tier:1,wireCrossing:!1}),r.registerMessageType(ne,{tier:1,wireCrossing:!1,metaPassthrough:!1}),r.registerMessageType(ie,{tier:2,wireCrossing:!1}),r.registerMessageType(de,{tier:2,wireCrossing:!1}),r.registerMessageType(K,{tier:3,wireCrossing:!0}),r.registerMessageType(oe,{tier:3,wireCrossing:!0}),r.registerMessageType(ee,{tier:4,wireCrossing:!0,metaPassthrough:!1}),r.registerMessageType(B,{tier:4,wireCrossing:!0,metaPassthrough:!1}),r.registerMessageType(q,{tier:5,wireCrossing:!0,metaPassthrough:!1})}var He,Dt=F(()=>{"use strict";Be();He=class{_messageTypes=new Map;_codecs=new Map;_onMessage;_onSubscribe;_defaultVersioning;_defaultHashFn;_inspectorEnabled=!(typeof process<"u"&&process.env?.NODE_ENV==="production");_globalInspector;_rigorRecorder;_frozen=!1;tierOf;constructor(e){this._onMessage=e.onMessage,this._onSubscribe=e.onSubscribe,this._defaultVersioning=e.defaultVersioning,this._defaultHashFn=e.defaultHashFn,this.tierOf=t=>{let n=this._messageTypes.get(t);return n!=null?n.tier:1}}get onMessage(){return this._frozen=!0,this._onMessage}get onSubscribe(){return this._frozen=!0,this._onSubscribe}set onMessage(e){this._assertUnfrozen(),this._onMessage=e}set onSubscribe(e){this._assertUnfrozen(),this._onSubscribe=e}get defaultVersioning(){return this._defaultVersioning}set defaultVersioning(e){this._assertUnfrozen(),this._defaultVersioning=e}get defaultHashFn(){return this._defaultHashFn}set defaultHashFn(e){this._assertUnfrozen(),this._defaultHashFn=e}get inspectorEnabled(){return this._inspectorEnabled}set inspectorEnabled(e){this._inspectorEnabled=e}get globalInspector(){return this._globalInspector}set globalInspector(e){this._globalInspector=e}get rigorRecorder(){return this._rigorRecorder}set rigorRecorder(e){this._rigorRecorder=e}registerMessageType(e,t){return this._assertUnfrozen(),this._messageTypes.set(e,{tier:t.tier,wireCrossing:t.wireCrossing??t.tier>=3,metaPassthrough:t.metaPassthrough??!0}),this}messageTier(e){let t=this._messageTypes.get(e);return t!=null?t.tier:1}isWireCrossing(e){let t=this._messageTypes.get(e);return t!=null?t.wireCrossing:!0}isLocalOnly(e){return!this.isWireCrossing(e)}isMetaPassthrough(e){let t=this._messageTypes.get(e);return t!=null?t.metaPassthrough:!0}isKnownMessageType(e){return this._messageTypes.has(e)}registerCodec(e){return this._assertUnfrozen(),this._codecs.set(e.name,e),this}lookupCodec(e){return this._codecs.get(e)}_isFrozen(){return this._frozen}_assertUnfrozen(){if(this._frozen)throw new Error("GraphReFlyConfig is frozen: a node has already captured this config. Register custom types and set hooks before creating any node.")}}});function ut(r){if(r===void 0)return null;if(typeof r=="number"){if(!Number.isFinite(r))throw new TypeError(`Cannot hash non-finite number: ${r}`);if(Number.isInteger(r)&&!Number.isSafeInteger(r))throw new TypeError(`Cannot hash integer outside safe range (|n| > 2^53-1): ${r}. Cross-language cid parity is not guaranteed for unsafe integers.`);return r}if(typeof r=="string"||typeof r=="boolean"||r===null)return r;if(Array.isArray(r))return r.map(ut);if(typeof r=="object"&&r!==null){let e={};for(let t of Object.keys(r).sort())e[t]=ut(r[t]);return e}return null}function An(r){let e=Rn.encode(r),t=e.length,n=t*8,s=t+9+63&-64,o=new Uint8Array(s);o.set(e),o[t]=128;let i=new DataView(o.buffer);i.setUint32(s-4,n>>>0,!1),i.setUint32(s-8,Math.floor(n/4294967296)>>>0,!1);let u=1779033703,a=3144134277,d=1013904242,l=2773480762,f=1359893119,p=2600822924,h=528734635,c=1541459225,v=new Uint32Array(64),g=(m,y)=>m>>>y|m<<32-y;for(let m=0;m<s;m+=64){for(let S=0;S<16;S++)v[S]=i.getUint32(m+S*4,!1);for(let S=16;S<64;S++){let $=v[S-15],G=v[S-2],P=g($,7)^g($,18)^$>>>3,ae=g(G,17)^g(G,19)^G>>>10;v[S]=v[S-16]+P+v[S-7]+ae>>>0}let y=u,_=a,b=d,x=l,k=f,T=p,E=h,A=c;for(let S=0;S<64;S++){let $=g(k,6)^g(k,11)^g(k,25),G=k&T^~k&E,P=A+$+G+En[S]+v[S]>>>0,ae=g(y,2)^g(y,13)^g(y,22),xe=y&_^y&b^_&b,O=ae+xe>>>0;A=E,E=T,T=k,k=x+P>>>0,x=b,b=_,_=y,y=P+O>>>0}u=u+y>>>0,a=a+_>>>0,d=d+b>>>0,l=l+x>>>0,f=f+k>>>0,p=p+T>>>0,h=h+E>>>0,c=c+A>>>0}let w=m=>m.toString(16).padStart(8,"0");return w(u)+w(a)+w(d)+w(l)+w(f)+w(p)+w(h)+w(c)}function dt(r){let e=ut(r??null),t=JSON.stringify(e);return An(t).slice(0,16)}function Dn(){let r=globalThis.crypto;if(r?.randomUUID)return r.randomUUID();let e=()=>Math.floor(Math.random()*4294967296).toString(16).padStart(8,"0"),t=e()+e()+e()+e();return`${t.slice(0,8)}-${t.slice(8,12)}-4${t.slice(13,16)}-${(parseInt(t.slice(16,17),16)&3|8).toString(16)}${t.slice(17,20)}-${t.slice(20,32)}`}function ct(r,e,t){let n=t?.id??Dn();if(r===0)return{id:n,version:0};let o=(t?.hash??dt)(e);return{id:n,version:0,cid:o,prev:null}}function Ct(r,e,t){r.version+=1,"cid"in r&&(r.prev=r.cid,r.cid=t(e))}var En,Rn,Mt=F(()=>{"use strict";En=new Uint32Array([1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278,1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815,2227730452,2361852424,2428436474,2756734187,3204031479,3329325298]),Rn=new TextEncoder});function It(r){return{node:r,unsub:null,prevData:void 0,dirty:!1,involvedThisWave:!1,dataBatch:[],terminal:void 0}}function lt(r){r.prevData=void 0,r.dirty=!1,r.involvedThisWave=!1,r.dataBatch.length=0,r.terminal=void 0}function We(r){return r.length===0?r:typeof r[0]=="symbol"?[r]:r}function Ne(r,e,t){let n=Lt(r)?r:[],s=typeof r=="function"?r:typeof e=="function"?e:void 0,o={};return Lt(r)?o=(ft(e)?e:t)??{}:ft(r)?o=r:o=(ft(e)?e:t)??{},new H(n,s,o)}var Gt,Pt,Cn,Mn,_e,H,Lt,ft,Se=F(()=>{"use strict";nt();rt();Ie();je();Dt();Le();Be();Mt();Gt=()=>{},Pt=100;Cn=(r,e,t,n)=>{t.direction==="down-in"&&r._onDepMessage(t.depIndex,e)},Mn=(r,e,t,n)=>{let s=r;if(s._status==="completed"||s._status==="errored")return;let o=s._cached,i=o===void 0?[ot]:[ot,[K,o]];s._status==="dirty"&&i.push(ve),Pe(e,i,s._config.tierOf)},_e=new He({onMessage:Cn,onSubscribe:Mn});At(_e);Nt(_e);H=class r{_optsName;_describeKind;meta;_hasMeta;_config;_deps;_sinks=null;_sinkCount=0;_cached;_status;_cleanup;_store={};_waveHasNewData=!1;_hasNewTerminal=!1;_hasCalledFnOnce=!1;_paused=!1;_pendingWave=!1;_isExecutingFn=!1;_pendingRerun=!1;_rerunDepth=0;_dirtyDepCount=0;_batchPendingMessages=null;_pauseLocks=null;_pauseBuffer=null;_fn;_equals;_resubscribable;_resetOnTeardown;_autoComplete;_autoError;_pausable;_partial;_guard;_extraGuards;_hashFn;_versioning;_versioningLevel;_lastMutation;_inspectorHooks;_actions;constructor(e,t,n){this._config=n.config??_e,this._config.onMessage,this._optsName=n.name,this._describeKind=n.describeKind,this._equals=n.equals??Object.is,this._resubscribable=n.resubscribable??!1,this._resetOnTeardown=n.resetOnTeardown??!1,this._autoComplete=n.completeWhenDepsComplete??!0,this._autoError=n.errorWhenDepsError??!0,this._pausable=n.pausable??!0,this._guard=n.guard,this._fn=t,this._partial=n.partial??!1,this._cached=n.initial!==void 0?n.initial:void 0,this._status=e.length===0&&t==null&&this._cached!==void 0?"settled":"sentinel",this._hashFn=n.versioningHash??this._config.defaultHashFn??dt;let s=n.versioning??this._config.defaultVersioning;this._versioningLevel=s,this._versioning=s!=null?ct(s,this._cached===void 0?void 0:this._cached,{id:n.versioningId,hash:this._hashFn}):void 0,this._deps=e.map(It);let o={};for(let[u,a]of Object.entries(n.meta??{})){let d={initial:a,name:`${n.name??"node"}:meta:${u}`,describeKind:"state",config:this._config};n.guard!=null&&(d.guard=n.guard),o[u]=new r([],void 0,d)}Object.freeze(o),this.meta=o,this._hasMeta=Object.keys(o).length>0;let i=this;this._actions={emit(u){i._emit([[K,u]])},down(u){i._emit(We(u))},up(u){i._emitUp(We(u))}},this.down=this.down.bind(this),this.up=this.up.bind(this)}get _isTerminal(){return this._status==="completed"||this._status==="errored"}get name(){return this._optsName}get status(){return this._status}get cache(){return this._cached===void 0?void 0:this._cached}get lastMutation(){return this._lastMutation}get v(){return this._versioning}hasGuard(){return this._guard!=null}_applyVersioning(e,t){if(this._isExecutingFn)throw new Error(`Node "${this.name}": _applyVersioning cannot run mid-fn \u2014 call it outside of \`_execFn\` (typically at graph setup time before the first subscribe).`);let n=this._versioningLevel;if(n!=null&&e<=n)return;let s=t?.hash??this._hashFn;s!==this._hashFn&&(this._hashFn=s);let o=this._cached===void 0?void 0:this._cached,i=this._versioning,u=i?.id??t?.id,a=i?.version??0,d=ct(e,o,{id:u,hash:s});d.version=a,this._versioning=d,this._versioningLevel=e}_setInspectorHook(e){return e==null?()=>{}:(this._inspectorHooks==null&&(this._inspectorHooks=new Set),this._inspectorHooks.add(e),()=>{this._inspectorHooks?.delete(e),this._inspectorHooks?.size===0&&(this._inspectorHooks=void 0)})}_pushGuard(e){return this._extraGuards==null&&(this._extraGuards=new Set),this._extraGuards.add(e),()=>{this._extraGuards?.delete(e),this._extraGuards?.size===0&&(this._extraGuards=void 0)}}allowsObserve(e){if(this._guard==null&&this._extraGuards==null)return!0;let t=$e(e);if(this._guard!=null&&!this._guard(t,"observe"))return!1;if(this._extraGuards!=null){for(let n of this._extraGuards)if(!n(t,"observe"))return!1}return!0}_checkGuard(e){if(e?.internal)return;let t=this._guard!=null||this._extraGuards!=null,n=e?.actor!=null;if(!t&&!n)return;let s=$e(e?.actor),o=e?.delivery==="signal"?"signal":"write";if(this._guard!=null&&!this._guard(s,o))throw new te({actor:s,action:o,nodeName:this.name});if(this._extraGuards!=null){for(let i of this._extraGuards)if(!i(s,o))throw new te({actor:s,action:o,nodeName:this.name})}this._lastMutation={actor:s,timestamp_ns:Fe()}}down(e,t){let n=We(e);n.length!==0&&(this._checkGuard(t),this._emit(n))}emit(e,t){this._checkGuard(t),this._emit([[K,e]])}up(e,t){if(this._deps.length===0)return;let n=We(e);if(n.length===0)return;this._checkGuard(t);let s=t??{internal:!0};this._validateUpTiers(n);for(let o of this._deps)o.node.up?.(n,s)}_emitUp(e){if(this._deps.length!==0&&e.length!==0){this._validateUpTiers(e);for(let t of this._deps)t.node.up?.(e,{internal:!0})}}_validateUpTiers(e){let t=this._config.tierOf;for(let n of e){let s=t(n[0]);if(s===3||s===4)throw new Error(`Node "${this.name}": tier-${s} messages cannot flow up \u2014 DATA/RESOLVED/COMPLETE/ERROR are downstream-only. Use \`down(...)\` for value delivery; \`up(...)\` is for control signals (DIRTY, INVALIDATE, PAUSE, RESUME, TEARDOWN).`)}}subscribe(e,t){if(t!=null&&this._guard!=null){let a=$e(t);if(!this._guard(a,"observe"))throw new te({actor:a,action:"observe",nodeName:this.name})}let s=this._isTerminal&&this._resubscribable;if(s){this._cached=void 0,this._status="sentinel",this._store={},this._hasCalledFnOnce=!1,this._waveHasNewData=!1,this._hasNewTerminal=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._isExecutingFn=!1,this._rerunDepth=0,this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null;for(let a of this._deps)lt(a);if(this._partial===!1){for(let a of this._deps)if(a.prevData!==void 0||a.dataBatch.length!==0||a.terminal!==void 0||a.dirty)throw new Error(`resubscribable-reset invariant: DepRecord not fully reset for node ${this._optsName??"(anonymous)"}`)}}this._sinkCount+=1;let o;try{o=this._config.onSubscribe(this,e,{sinkCount:this._sinkCount,afterTerminalReset:s},this._actions)}catch(a){throw this._sinkCount-=1,a}this._sinks==null?this._sinks=e:typeof this._sinks=="function"?this._sinks=new Set([this._sinks,e]):this._sinks.add(e);let i=this._isTerminal;if(this._sinkCount===1&&!i)try{this._activate()}catch(a){if(this._sinkCount-=1,this._removeSink(e),this._sinkCount===0&&(this._status="sentinel"),typeof o=="function")try{o()}catch{}throw a}this._status==="sentinel"&&this._cached===void 0&&(this._status="pending");let u=!1;return()=>{u||(u=!0,this._sinkCount-=1,this._removeSink(e),typeof o=="function"&&o(),this._sinks==null&&this._deactivate())}}_removeSink(e){if(this._sinks===e)this._sinks=null;else if(this._sinks!=null&&typeof this._sinks!="function")if(this._sinks.delete(e),this._sinks.size===1){let[t]=this._sinks;this._sinks=t}else this._sinks.size===0&&(this._sinks=null)}_activate(){if(this._deps.length===0){this._fn&&this._execFn();return}this._dirtyDepCount=0;let e=this._deps.length,t=0;try{for(let n=0;n<e;n++){let s=n,o=this._deps[n];o.unsub=Gt,o.unsub=o.node.subscribe(i=>{if(o.unsub===null)return;let u=this._config.tierOf,a=!1;for(let d of i)u(d[0])>=3&&(a=!0),this._config.onMessage(this,d,{direction:"down-in",depIndex:s},this._actions);a&&this._maybeRunFnOnSettlement()}),t++}}catch(n){this._deps[t].unsub=null;for(let s=0;s<t;s++){let o=this._deps[s];if(o.unsub!=null){let i=o.unsub;o.unsub=null;try{i()}catch{}lt(o)}}throw this._dirtyDepCount=0,n}}_addDep(e){for(let s=0;s<this._deps.length;s++)if(this._deps[s].node===e)return s;let t=this._deps.length,n=It(e);if(this._deps.push(n),this._sinks==null)return t;n.dirty=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(it),n.unsub=Gt;try{n.unsub=e.subscribe(s=>{if(n.unsub===null)return;let o=this._config.tierOf,i=!1;for(let u of s)o(u[0])>=3&&(i=!0),this._config.onMessage(this,u,{direction:"down-in",depIndex:t},this._actions);i&&this._maybeRunFnOnSettlement()})}catch(s){throw n.unsub=null,this._deps.pop(),this._dirtyDepCount--,s}return t}_deactivate(e=!1){let t=this._cleanup;if(this._cleanup=void 0,typeof t=="function")try{t()}catch(n){this._emit([[B,this._wrapFnError("cleanup threw",n)]])}else if(t!=null&&typeof t=="object"){let n=t.deactivate;if(typeof n=="function")try{n()}catch(s){this._emit([[B,this._wrapFnError("cleanup.deactivate threw",s)]])}}for(let n of this._deps){if(n.unsub!=null){let s=n.unsub;n.unsub=null;try{s()}catch{}}lt(n)}this._waveHasNewData=!1,this._hasNewTerminal=!1,this._hasCalledFnOnce=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._rerunDepth=0,this._store={},this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null,this._fn!=null&&(this._cached=void 0),e||(this._fn!=null||this._deps.length>0)&&(!this._isTerminal||this._resubscribable)&&(this._status="sentinel")}_onDepMessage(e,t){let n=this._deps[e],s=t[0];if(this._inspectorHooks!=null){let o={kind:"dep_message",depIndex:e,message:t};for(let i of this._inspectorHooks)i(o)}if(s!==Oe){if(s===se){this._depDirtied(n);return}if(s===ne){if(this._depInvalidated(n),this._cached===void 0)return;this._emit(Et);return}if(s===ie||s===de){this._emit([t]);return}if(s===q){this._emit(at);return}if(s===K)this._depSettledAsData(n,t[1]);else if(s===oe)this._depSettledAsResolved(n);else if(s===ee)this._depSettledAsTerminal(n,!0);else if(s===B)this._depSettledAsTerminal(n,t[1]);else{this._emit([t]);return}if(!this._fn){(s===K||s===oe)&&this._emit([t]),(s===ee||s===B)&&this._maybeAutoTerminalAfterWave();return}}}_depDirtied(e){e.dirty||(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(it))}_depSettledAsData(e,t){e.dirty&&(e.dirty=!1,this._dirtyDepCount--),e.involvedThisWave=!0,e.dataBatch.push(t),this._waveHasNewData=!0}_depSettledAsResolved(e){e.dirty&&(e.dirty=!1,this._dirtyDepCount--)}_depSettledAsTerminal(e,t){e.dirty&&(e.dirty=!1,this._dirtyDepCount--),e.terminal=t,e.involvedThisWave=!0,this._hasNewTerminal=!0}_depInvalidated(e){e.prevData=void 0,e.terminal=void 0,e.dataBatch.length=0,e.dirty?e.involvedThisWave=!1:(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++)}_maybeRunFnOnSettlement(){if(!(this._isTerminal&&!this._resubscribable)&&!(this._dirtyDepCount>0)){if(!this._partial&&!this._hasCalledFnOnce)for(let e=0;e<this._deps.length;e++){let t=this._deps[e];if(t.dataBatch.length===0&&t.prevData===void 0&&t.terminal===void 0){this._maybeAutoTerminalAfterWave();return}}if(this._paused){this._pendingWave=!0;return}if(!this._waveHasNewData&&!this._hasNewTerminal&&this._hasCalledFnOnce){this._clearWaveFlags(),this._emit(St),this._maybeAutoTerminalAfterWave();return}this._fn&&this._execFn(),this._maybeAutoTerminalAfterWave()}}_maybeAutoTerminalAfterWave(){if(this._deps.length===0||this._isTerminal)return;let e=this._deps.find(t=>t.terminal!==void 0&&t.terminal!==!0);if(e!=null){this._autoError&&this._emit([[B,e.terminal]]);return}this._autoComplete&&this._deps.every(t=>t.terminal!==void 0)&&this._emit(Rt)}_execFn(){if(!this._fn||this._isTerminal&&!this._resubscribable)return;if(this._isExecutingFn){this._pendingRerun=!0;return}let e=this._cleanup;if(typeof e=="function"){this._cleanup=void 0;try{e()}catch(i){this._emit([[B,this._wrapFnError("cleanup threw",i)]]);return}}else if(e!=null&&typeof e=="object"){let i=e.beforeRun;if(typeof i=="function"){e.beforeRun=void 0;try{i()}catch(u){this._emit([[B,this._wrapFnError("cleanup.beforeRun threw",u)]]);return}}}let t=this._deps.map(i=>i.involvedThisWave?i.dataBatch.length>0?[...i.dataBatch]:[]:void 0),n=this._deps.map(i=>i.prevData);for(let i=0;i<this._deps.length;i++){let u=t[i];u!=null&&u.length>0&&(this._deps[i].prevData=u[u.length-1])}let s=this._deps.map(i=>i.terminal),o={prevData:n,terminalDeps:s,store:this._store};if(this._hasCalledFnOnce=!0,this._clearWaveFlags(),this._inspectorHooks!=null){let i={kind:"run",batchData:t,prevData:n};for(let u of this._inspectorHooks)u(i)}this._isExecutingFn=!0;try{let i=this._fn(t,this._actions,o);if(typeof i=="function")this._cleanup=i;else if(i!=null&&typeof i=="object"){let u=i;(typeof u.beforeRun=="function"||typeof u.deactivate=="function"||typeof u.invalidate=="function")&&(this._cleanup=i)}}catch(i){this._emit([[B,this._wrapFnError("fn threw",i)]])}finally{this._isExecutingFn=!1,this._pendingRerun?(this._pendingRerun=!1,this._rerunDepth+=1,this._rerunDepth>Pt?(this._rerunDepth=0,this._emit([[B,new Error(`Node "${this.name}": _pendingRerun depth exceeded ${Pt} \u2014 likely a reactive cycle`)]])):this._maybeRunFnOnSettlement()):this._rerunDepth=0,this._clearWaveFlags()}}_clearWaveFlags(){this._waveHasNewData=!1,this._hasNewTerminal=!1;for(let e of this._deps)e.involvedThisWave=!1,e.dataBatch.length=0}_wrapFnError(e,t){let n=t instanceof Error?t.message:String(t);return new Error(`Node "${this.name}": ${e}: ${n}`,{cause:t})}_frameBatch(e){let t=this._config.tierOf;if(e.length===1)return t(e[0][0])===3&&this._status!=="dirty"?[ve,e[0]]:e;let n=!0,s=!1,o=!1,i=-1;for(let a of e){let d=t(a[0]);d<i&&(n=!1),d===3&&(s=!0),a[0]===se&&(o=!0),i=d}let u=e;if(!n){let a=e.map((d,l)=>({m:d,i:l,tier:t(d[0])}));a.sort((d,l)=>d.tier-l.tier||d.i-l.i),u=a.map(d=>d.m)}if(s&&!o&&this._status!=="dirty"){let a=0;for(;a<u.length&&t(u[a][0])===0;)a++;return a===0?[ve,...u]:[...u.slice(0,a),ve,...u.slice(a)]}return u}_emit(e){if(e.length===0)return;for(let u=0;u<e.length;u++){let a=e[u];if(a[0]===B&&a[1]===void 0)throw new TypeError('[ERROR, payload] requires a non-undefined payload (spec \xA71.2). Pass an Error object or domain tag instead \u2014 e.g. node.down([[ERROR, new Error("reason")]])')}let t=e;if(this._isTerminal&&!this._resubscribable){let u=e.filter(a=>a[0]===q||a[0]===ne);if(u.length===0)return;t=u}t=this._frameBatch(t);let s=null;for(let u=0;u<t.length;u++){let a=t[u],d=a[0];if(d!==ie&&d!==de){s?.push(a);continue}if(a.length<2)throw new Error(`Node "${this.name}": [[${d===ie?"PAUSE":"RESUME"}]] must carry a lockId payload \u2014 bare PAUSE/RESUME is a protocol violation (C0 rule). Use \`[[PAUSE, lockId]]\` / \`[[RESUME, lockId]]\`.`);let l=!0;if(this._pausable!==!1){let f=a[1];if(d===ie)this._pauseLocks==null&&(this._pauseLocks=new Set),this._pauseLocks.add(f),this._paused=!0,this._pausable==="resumeAll"&&this._pauseBuffer==null&&(this._pauseBuffer=[]);else if(this._pauseLocks==null||!this._pauseLocks.has(f))l=!1;else if(this._pauseLocks.delete(f),this._pauseLocks.size===0){if(this._paused=!1,this._pauseBuffer!=null&&this._pauseBuffer.length>0){let p=this._pauseBuffer;this._pauseBuffer=[],this._emit(p)}this._pendingWave&&(this._pendingWave=!1,this._maybeRunFnOnSettlement())}}l?s?.push(a):s==null&&(s=t.slice(0,u))}if(s!=null){if(s.length===0)return;t=s}if(this._hasMeta&&t.some(u=>u[0]===q))for(let u of Object.keys(this.meta))try{this.meta[u]._emit(at)}catch{}let{finalMessages:o,equalsError:i}=this._updateState(t);if(o.length>0&&this._config.inspectorEnabled){let u=this._config.globalInspector;if(u!=null)try{u({kind:"emit",node:this,messages:o})}catch{}}if(o.length>0)if(this._paused&&this._pausable==="resumeAll"&&this._pauseBuffer!=null){let u=this._config.tierOf,a=[];for(let d of o)u(d[0])===3?this._pauseBuffer.push(d):a.push(d);a.length>0&&this._dispatchOrAccumulate(a)}else this._dispatchOrAccumulate(o);i!=null&&this._emit([[B,i]])}_updateState(e){let t=this._config.tierOf,n,s,o=-1,i=0;for(let l of e)t(l[0])===3&&i++;let u=i<=1,a=-1;if(this._versioning!=null&&i>1){for(let l=e.length-1;l>=0;l--)if(e[l][0]===K){a=l;break}}for(let l=0;l<e.length;l++){let f=e[l],p=f[0];if(p===K){if(f.length>=2){let h=!1;if(u&&this._cached!==void 0)try{h=this._equals(this._cached,f[1])}catch(c){s=this._wrapFnError("equals threw",c),o=l;break}if(h){n==null&&(n=e.slice(0,l)),n.push(st),this._status="resolved";continue}this._cached=f[1],this._versioning!=null&&(a<0||l===a)&&Ct(this._versioning,f[1],this._hashFn)}this._status="settled",n?.push(f)}else if(n?.push(f),p===se)this._status="dirty";else if(p===oe)this._status="resolved";else if(p===ee){this._status="completed";{let h=this._config.rigorRecorder;if(h!=null)try{h.onTerminalTransition(this,"completed",this._autoComplete,this._autoError,this._deps.length>0)}catch{}}}else if(p===B){this._status="errored";{let h=this._config.rigorRecorder;if(h!=null)try{h.onTerminalTransition(this,"errored",this._autoComplete,this._autoError,this._deps.length>0)}catch{}}}else if(p===ne){if(this._cached!==void 0){let c=this._config.rigorRecorder;if(c!=null)try{c.onNonVacuousInvalidate(this,this._cached)}catch{}}this._cached=void 0,this._status="dirty";let h=this._cleanup;if(typeof h=="function"){this._cleanup=void 0;try{h()}catch{}}else if(h!=null&&typeof h=="object"){let c=h.invalidate;if(typeof c=="function")try{c()}catch{}}}else p===q&&(this._resetOnTeardown&&(this._cached=void 0),this._deactivate(!0),this._status="sentinel")}let d=o>=0?n??e.slice(0,o):n??e;return s!=null?{finalMessages:d,equalsError:s}:{finalMessages:d}}_deliverToSinks=e=>{if(this._sinks==null)return;if(typeof this._sinks=="function"){this._sinks(e);return}let t=[...this._sinks];for(let n of t)n(e)};_dispatchOrAccumulate(e){if(xt()){this._batchPendingMessages===null&&(this._batchPendingMessages=[],be(()=>this._flushBatchPending()));for(let t of e)this._batchPendingMessages.push(t);return}Pe(this._deliverToSinks,e,this._config.tierOf)}_flushBatchPending(){let e=this._batchPendingMessages;if(e===null||(this._batchPendingMessages=null,e.length===0))return;let t=this._frameBatch(e);Pe(this._deliverToSinks,t,this._config.tierOf)}},Lt=r=>Array.isArray(r),ft=r=>typeof r=="object"&&r!=null&&!Array.isArray(r)});function Ee(r,e){if(e!=null&&e.length>0)return new Set(e);switch(r){case"standard":return new Set(["type","status","value","deps","meta","v"]);case"full":return null;case"spec":return new Set(["type","deps","meta","value"]);default:return new Set(["type","deps"])}}function Gn(r){return r._describeKind!=null?r._describeKind:r._deps.length>0?"derived":r._fn!=null?"producer":"state"}function Pn(r){let e={};for(let[t,n]of Object.entries(r.meta))try{e[t]=n.cache}catch{}return e}function Re(r,e,t){let n=e==null,s=!n&&e!=null?[...e].filter(l=>l.startsWith("meta.")).map(l=>l.slice(5)):null,o=n||e.has("meta")||s!=null&&s.length>0,i="state",u=[];r instanceof H&&(i=Gn(r),u=r._deps.map(l=>l.node.name??""));let a={type:i,deps:u};(n||e.has("status"))&&(a.status=r.status);let d=r instanceof H?r._guard:void 0;if(o){let l={...Pn(r)};if(d!=null&&l.access===void 0&&(l.access=et(d)),s!=null&&s.length>0&&!e.has("meta")){let f={};for(let p of s)p in l&&(f[p]=l[p]);a.meta=f}else a.meta=l}if(r.name!=null&&(a.name=r.name),(n||e.has("value"))&&(!t||i==="state")){r.status==="sentinel"&&(a.sentinel=!0);try{a.value=r.cache}catch{}}if((n||e.has("v"))&&r.v!=null){let l={id:r.v.id,version:r.v.version};"cid"in r.v&&(l.cid=r.v.cid,l.prev=r.v.prev),a.v=l}return(n||e.has("guard"))&&d!=null&&(a.guard=et(d)),(n||e.has("lastMutation"))&&r.lastMutation!=null&&(a.lastMutation=r.lastMutation),a}var pt=F(()=>{"use strict";Le();Se()});function J(r,e){return Ne([],{...e,initial:r})}function ht(r,e){return Ne((n,s,o)=>r(s,o)??void 0,{describeKind:"producer",...e})}function z(r,e,t){return Ne(r,(s,o,i)=>{let u=s.map((a,d)=>a!=null&&a.length>0?a.at(-1):i.prevData[d]);o.emit(e(u,i))},{describeKind:"derived",...t})}function Ve(r,e,t){return Ne(r,(s,o,i)=>{let u=s.map((a,d)=>a!=null&&a.length>0?a.at(-1):i.prevData[d]);return e(u,o,i)??void 0},{describeKind:"effect",...t})}var gt=F(()=>{"use strict";Se()});function $t(r){return r.replaceAll("\\","\\\\").replaceAll('"','\\"')}function Ft(r){let e=new Set,t=[];function n(s,o){let i=`${s}\0${o}`;e.has(i)||(e.add(i),t.push([s,o]))}for(let[s,o]of Object.entries(r.nodes)){let i=o.deps;if(i)for(let u of i)n(u,s)}for(let s of r.edges)n(s.from,s.to);return t}function jt(r){if(r===void 0)return"LR";if(r==="TD"||r==="LR"||r==="BT"||r==="RL")return r;throw new Error(`invalid diagram direction ${String(r)}; expected one of: TD, LR, BT, RL`)}var Bt=F(()=>{"use strict"});function ze(r,e){let t=jt(e?.direction),n=Object.keys(r.nodes).sort(),s=new Map;for(let i=0;i<n.length;i+=1)s.set(n[i],`n${i}`);let o=[`flowchart ${t}`];for(let i of n){let u=s.get(i);o.push(` ${u}["${$t(i)}"]`)}for(let[i,u]of Ft(r)){let a=s.get(i),d=s.get(u);!a||!d||o.push(` ${a} --> ${d}`)}return o.join(`
2
- `)}var Ht=F(()=>{"use strict";Bt()});var Wt=F(()=>{"use strict";Ht()});function mt(r,e){if(Object.is(r,e))return!0;if(r==null||e==null||typeof r!="object"||typeof e!="object")return!1;if(Array.isArray(r)){if(!Array.isArray(e)||r.length!==e.length)return!1;for(let o=0;o<r.length;o++)if(!mt(r[o],e[o]))return!1;return!0}if(Array.isArray(e))return!1;let t=Object.keys(r),n=Object.keys(e);if(t.length!==n.length)return!1;let s=new Set(n);for(let o of t)if(!s.has(o)||!mt(r[o],e[o]))return!1;return!0}function Vt(r,e){return`${r}\0${e}`}function bt(r,e){let t=[],n=new Set(r.subgraphs),s=new Set(e.subgraphs),o=[];for(let g of s)n.has(g)||o.push(g);o.sort();for(let g of o)t.push({type:"subgraph-mounted",path:g});let i=new Set(Object.keys(r.nodes)),u=new Set(Object.keys(e.nodes)),a=[];for(let g of u)i.has(g)||a.push(g);a.sort();for(let g of a)t.push({type:"node-added",path:g,node:{...e.nodes[g]}});let d=[];for(let g of u){if(!i.has(g))continue;let w=r.nodes[g]?.meta,m=e.nodes[g]?.meta;w==null&&m==null||mt(w??{},m??{})||d.push(g)}d.sort();for(let g of d)t.push({type:"node-meta-changed",path:g,prevMeta:r.nodes[g]?.meta??{},nextMeta:e.nodes[g]?.meta??{}});let l=new Map;for(let g of r.edges)l.set(Vt(g.from,g.to),g);let f=new Map;for(let g of e.edges)f.set(Vt(g.from,g.to),g);let p=[];for(let[g,w]of f)l.has(g)||p.push(w);p.sort((g,w)=>g.from<w.from?-1:g.from>w.from?1:g.to<w.to?-1:g.to>w.to?1:0);for(let g of p)t.push({type:"edge-added",from:g.from,to:g.to});let h=[];for(let[g,w]of l)f.has(g)||h.push(w);h.sort((g,w)=>g.from<w.from?-1:g.from>w.from?1:g.to<w.to?-1:g.to>w.to?1:0);for(let g of h)t.push({type:"edge-removed",from:g.from,to:g.to});let c=[];for(let g of i)u.has(g)||c.push(g);c.sort();for(let g of c)t.push({type:"node-removed",path:g});let v=[];for(let g of n)s.has(g)||v.push(g);v.sort();for(let g of v)t.push({type:"subgraph-unmounted",path:g});return{events:t,flushedAt_ns:ue()}}var zt=F(()=>{"use strict";je()});function Ue(r){return r.subscribe(()=>{})}var Ut=F(()=>{"use strict"});var Kt=F(()=>{"use strict";Ut()});var Ke,qt=F(()=>{"use strict";Ke=class{_timer;_gen=0;start(e,t){this.cancel(),this._gen+=1;let n=this._gen;this._timer=setTimeout(()=>{this._timer=void 0,n===this._gen&&t()},e)}cancel(){this._timer!==void 0&&(clearTimeout(this._timer),this._timer=void 0)}get pending(){return this._timer!==void 0}}});var Ae,Jt=F(()=>{"use strict";Ae=class{constructor(e){this.capacity=e;if(!Number.isInteger(e)||e<=0)throw new Error(`RingBuffer capacity must be a positive integer (got ${e})`);this.buf=new Array(e)}buf;head=0;_size=0;get size(){return this._size}get maxSize(){return this.capacity}push(e){let t=(this.head+this._size)%this.capacity;this.buf[t]=e,this._size<this.capacity?this._size++:this.head=(this.head+1)%this.capacity}shift(){if(this._size===0)return;let e=this.buf[this.head];return this.buf[this.head]=void 0,this.head=(this.head+1)%this.capacity,this._size--,e}at(e){if(this._size===0)return;let t=e<0?this._size+e:e;if(!(t<0||t>=this._size))return this.buf[(this.head+t)%this.capacity]}toArray(){let e=new Array(this._size);for(let t=0;t<this._size;t++)e[t]=this.buf[(this.head+t)%this.capacity];return e}clear(){for(let e=0;e<this._size;e++)this.buf[(this.head+e)%this.capacity]=void 0;this.head=0,this._size=0}}});function Yt(r,e,t,n={}){let s=e in r.nodes,o=t in r.nodes;if(!s)return qe(e,t,"no-such-from");if(!o)return qe(e,t,"no-such-to");let i=n.maxDepth;if(i!=null&&(!Number.isInteger(i)||i<0))throw new Error("explainPath: maxDepth must be an integer >= 0");if(e===t){if(n.findCycle===!0){let d=In(r,e,n);if(d!=null)return d}let a=Je(e,r.nodes[e],0,n);return Ye(e,t,[a])}if(i===0)return qe(e,t,"no-path");let u=Xt(r,e,t,i);return u.found?Ye(e,t,Zt(r,u.pathOrder,n)):qe(e,t,u.truncated?"max-depth-exceeded":"no-path")}function Xt(r,e,t,n){let s=new Map,o=[{path:t,depth:0}],i=new Set([t]),u=0,a=!1;for(;u<o.length;){let f=o[u++];if(f.path===e)break;if(n!=null&&f.depth>=n){let v=r.nodes[f.path];v?.deps&&v.deps.length>0&&(a=!0);continue}let p=r.nodes[f.path];if(p==null)continue;let h=p.deps??[],c=new Map;for(let v=0;v<h.length;v++){let g=h[v];if(!g)continue;let w=c.get(g);w==null&&(w=[],c.set(g,w)),w.push(v)}for(let[v,g]of c)i.has(v)||(i.add(v),s.set(v,{from:f.path,depIndices:g}),o.push({path:v,depth:f.depth+1}))}if(!s.has(e))return{found:!1,pathOrder:[],truncated:a};let d=[{path:e}],l=e;for(;l!==t;){let f=s.get(l);if(f==null)return{found:!1,pathOrder:[],truncated:!1};d[d.length-1].depIndices=f.depIndices,d.push({path:f.from}),l=f.from}return{found:!0,pathOrder:d,truncated:!1}}function In(r,e,t){let n=r.nodes[e];if(n==null)return null;let s=n.deps??[],o=[];for(let u=0;u<s.length;u++)s[u]===e&&o.push(u);if(o.length>0){let u=Je(e,n,0,t);u.dep_index=o[0];let a=Je(e,n,1,t);return Ye(e,e,[u,a])}let i=null;for(let u=0;u<s.length;u++){let a=s[u];if(!a||a===e)continue;let d=Xt(r,a,e,t.maxDepth);d.found&&(i==null||d.pathOrder.length<i.pathOrder.length)&&(i=d,i={found:!0,pathOrder:[{path:e,depIndices:[u]},...d.pathOrder],truncated:!1})}return i==null?null:Ye(e,e,Zt(r,i.pathOrder,t))}function Zt(r,e,t){return e.map((n,s)=>{let o=r.nodes[n.path],i=Je(n.path,o,s,t);return n.depIndices!=null&&n.depIndices.length>0&&(i.dep_index=n.depIndices[0],n.depIndices.length>1&&(i.dep_indices=[...n.depIndices])),i})}function Je(r,e,t,n){let s={path:r,type:e.type,hop:t};e.status!==void 0&&(s.status=e.status),"value"in e&&(s.value=e.value),e.v!=null&&(s.v=e.v);let o=n.annotations?.get(r)??e.annotation;o!=null&&(s.annotation=o);let i=n.lastMutations?.get(r)??e.lastMutation;return i!=null&&(s.lastMutation=i),s}function Ye(r,e,t){return Qt(r,e,!0,"ok",t)}function qe(r,e,t){return Qt(r,e,!1,t,[])}function Qt(r,e,t,n,s){let o=Ln(r,e,t,n,s);return{from:r,to:e,found:t,reason:n,steps:s,text:o,toJSON(){return{from:r,to:e,found:t,reason:n,steps:s}}}}function Ln(r,e,t,n,s){if(!t)switch(n){case"no-such-from":return`explainPath: no node named "${r}"`;case"no-such-to":return`explainPath: no node named "${e}"`;case"max-depth-exceeded":return`explainPath: no path from "${r}" to "${e}" within maxDepth`;default:return`explainPath: no path from "${r}" to "${e}"`}let o=[`Causal path: ${r} \u2192 ${e} (${s.length} step(s))`];for(let i of s){let a=` ${i.hop===0?"\xB7":"\u2193"} ${i.path} (${i.type}${i.status?`/${i.status}`:""})`;if(o.push(a),"value"in i&&o.push(` value: ${$n(i.value)}`),i.annotation!=null&&o.push(` annotation: ${i.annotation}`),i.lastMutation!=null){let d=i.lastMutation.actor;o.push(` actor: ${d.type}${d.id?`:${d.id}`:""}`)}}return o.join(`
3
- `)}function $n(r){if(r===void 0)return"<sentinel>";if(r===null)return"null";if(typeof r=="string")return JSON.stringify(r);if(typeof r=="number"||typeof r=="boolean"||typeof r=="bigint")return String(r);try{let e=JSON.stringify(r);return e.length>80?`${e.slice(0,77)}...`:e}catch{return String(r)}}var en=F(()=>{"use strict"});function tn(r){let e=new WeakSet,t=new WeakSet,n=[r],s=0;for(;n.length>0;){let o=n.pop();s+=jn(o,e,t,n)}return s}function jn(r,e,t,n){if(r==null)return 0;switch(typeof r){case"number":return W.number;case"boolean":return W.boolean;case"string":return W.string+r.length*2;case"bigint":return W.bigint+Bn(r);case"symbol":return W.symbol;case"function":return e.has(r)?0:(e.add(r),W.function);case"undefined":return 0}let o=r;if(e.has(o))return 0;e.add(o);let i=o[Fn];if(typeof i=="function")try{let d=i.call(o);if(typeof d=="number"&&Number.isFinite(d))return d}catch{}if(o instanceof Date)return W.date;if(o instanceof RegExp)return W.regexp+o.source.length*2;if(o instanceof Error){let d=o.message?o.message.length*2:0,l=o.stack?o.stack.length*2:0;return W.error+d+l}if(typeof URL<"u"&&o instanceof URL)return W.url+o.href.length*2;if(typeof Promise<"u"&&o instanceof Promise)return W.promise;if(o instanceof WeakMap)return W.weakmap;if(o instanceof WeakSet)return W.weakset;if(o instanceof Map){let d=W.map;for(let[l,f]of o)d+=W.mapEntry,n.push(l),n.push(f);return d}if(o instanceof Set){let d=W.set;for(let l of o)d+=W.setEntry,n.push(l);return d}if(Array.isArray(o)){let d=W.array+o.length*8;for(let l of o)n.push(l);return d}if(o instanceof ArrayBuffer)return t.has(o)?0:(t.add(o),o.byteLength);if(ArrayBuffer.isView(o)){let d=o;return t.has(d.buffer)?48:(t.add(d.buffer),d.buffer.byteLength+48)}let u=W.object,a=Object.keys(o);for(let d of a){u+=W.string+d.length*2;try{n.push(o[d])}catch{}}return u}function Bn(r){let e=r<0n?-r:r;if(e===0n)return 0;let t=e.toString(2).length;return Math.ceil(t/32)*8}var W,Fn,nn=F(()=>{"use strict";W={object:56,array:64,string:40,number:8,boolean:4,null:0,undefined:0,symbol:40,bigint:16,function:120,map:72,set:72,mapEntry:40,setEntry:24,date:24,regexp:48,error:64,url:80,promise:48,weakmap:40,weakset:40},Fn=Symbol.for("sizeof")});function rn(r,e){let t=e?.topN??10,n=r.describe({detail:"standard"}),s=[],o=r._collectObserveTargets;typeof o=="function"&&o.call(r,"",s);let i=new Map;for(let[p,h]of s)i.set(p,h);let u=[];for(let[p,h]of Object.entries(n.nodes)){let c=i.get(p),v=c instanceof H?c:null,g=v?tn(v.cache):0,w=v?v._sinkCount:0,m=h.deps?.length??0,y=h.type==="effect"&&w===0,_=w===0?h.type==="effect"?"orphan-effect":h.type==="derived"?"idle-derived":h.type==="producer"?"idle-producer":null:null;u.push({path:p,type:h.type,status:h.status??"unknown",valueSizeBytes:g,subscriberCount:w,depCount:m,isOrphanEffect:y,orphanKind:_})}let a=u.reduce((p,h)=>p+h.valueSizeBytes,0),d=(p,h)=>[...u].sort(h??((c,v)=>v[p]-c[p])).slice(0,t),l=u.filter(p=>p.orphanKind!=null),f=u.filter(p=>p.isOrphanEffect);return{nodeCount:u.length,edgeCount:n.edges.length,subgraphCount:n.subgraphs.length,nodes:u,totalValueSizeBytes:a,hotspots:{byValueSize:d("valueSizeBytes"),bySubscriberCount:d("subscriberCount"),byDepCount:d("depCount")},orphans:l,orphanEffects:f}}var sn=F(()=>{"use strict";Se();nn()});function on(r,e){let t=Math.max(16,r.size*4),n=0;for(;r.size>0;){if(n++>=t){console.error(`[Graph "${e}".destroy] disposer drain exceeded cap (${t}); ${r.size} disposer(s) discarded`),r.clear();return}let s=r.values().next();if(s.done)return;let o=s.value;r.delete(o);try{o()}catch(i){console.error(`[Graph "${e}".destroy] disposer threw:`,i)}}}function fn(r){return r!=null&&typeof r=="object"&&"cache"in r&&typeof r.subscribe=="function"&&typeof r.down=="function"}function Hn(r){if(r!=null)return fn(r)?r.cache:r}function he(r){return r!=null&&typeof r=="object"&&"cache"in r&&typeof r.subscribe=="function"&&typeof r.down=="function"}function ce(r){return he(r)?r.cache??"":r}function an(r){return he(r)?r.cache??0:r}function un(r){return he(r)?r.cache??!1:r}function Wn(r){let e=[];for(let t of Object.keys(r).sort()){let n=r[t].v;n!=null&&e.push(`${t} ${n.id} ${n.version}`)}return e.join(`
4
- `)}function dn(r){if(r.version!==we)throw new Error(`unsupported snapshot version ${String(r.version)} (expected ${we})`);for(let e of["name","nodes","edges","subgraphs"])if(!(e in r))throw new Error(`snapshot missing required key "${e}"`);if(typeof r.name!="string")throw new TypeError("snapshot 'name' must be a string");if(typeof r.nodes!="object"||r.nodes===null||Array.isArray(r.nodes))throw new TypeError("snapshot 'nodes' must be an object");if(!Array.isArray(r.edges))throw new TypeError("snapshot 'edges' must be an array");if(!Array.isArray(r.subgraphs))throw new TypeError("snapshot 'subgraphs' must be an array")}function Vn(r,e){let t=new WeakMap,n=(s,o)=>{if(Object.is(s,o))return!0;if(s==null||o==null||typeof s!="object"||typeof o!="object")return!1;let i=t.get(s);if(i==null&&(i=new WeakSet,t.set(s,i)),i.has(o))return!0;i.add(o);let u=s.constructor,a=o.constructor;if(u!==a)return!1;if(s instanceof Date)return s.getTime()===o.getTime();if(s instanceof RegExp)return s.source===o.source&&s.flags===o.flags;if(Array.isArray(s)){let p=o;if(s.length!==p.length)return!1;for(let h=0;h<s.length;h++)if(!n(s[h],p[h]))return!1;return!0}if(s instanceof Map){let p=o;if(s.size!==p.size)return!1;for(let[h,c]of s)if(!p.has(h)||!n(c,p.get(h)))return!1;return!0}if(s instanceof Set){let p=o;if(s.size!==p.size)return!1;for(let h of s){let c=!1;for(let v of p)if(n(h,v)){c=!0;break}if(!c)return!1}return!0}if(ArrayBuffer.isView(s)){let p=s,h=o;if(p.length!==h.length)return!1;for(let c=0;c<p.length;c++)if(p[c]!==h[c])return!1;return!0}let d=Object.keys(s),l=Object.keys(o);if(d.length!==l.length)return!1;let f=new Set(l);for(let p of d)if(!f.has(p)||!n(s[p],o[p]))return!1;return!0};return n(r,e)}function zn(r){return r.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function Xe(r){let e="^";for(let t=0;t<r.length;t+=1){let n=r[t];if(n==="*"){e+=".*";continue}if(n==="?"){e+=".";continue}if(n==="["){let s=r.indexOf("]",t+1);if(s<=t+1){e+="\\[";continue}let o=r.slice(t+1,s);o.startsWith("!")&&(o=`^${o.slice(1)}`),o=o.replace(/\\/g,"\\\\"),e+=`[${o}]`,t=s;continue}e+=zn(n)}return e+="$",new RegExp(e)}function yt(r){if(typeof r=="string")return JSON.stringify(r);if(typeof r=="number"||typeof r=="boolean"||r==null)return String(r);try{return JSON.stringify(r)}catch{return"[unserializable]"}}function qn(r){return r==="none"?Kn:r==="ansi"||r==null?Un:{data:r.data??"",dirty:r.dirty??"",resolved:r.resolved??"",invalidate:r.invalidate??"",pause:r.pause??"",resume:r.resume??"",complete:r.complete??"",error:r.error??"",teardown:r.teardown??"",derived:r.derived??"",path:r.path??"",reset:r.reset??""}}function cn(r){if(r==null)return{};let e=r.detail;return e==="full"?{...r,structured:r.structured??!0,timeline:r.timeline??!0,causal:r.causal??!0,derived:r.derived??!0}:e==="minimal"?{...r,structured:r.structured??!0}:r.format==="stage-log"?{...r,structured:r.structured??!0,timeline:r.timeline??!0}:r}function Jn(r,e,t){for(let n=0;n<r.length;n++){let s=r.charCodeAt(n);if(s<32||s===127)throw new Error(`Graph "${e}": ${t} "${r}" must not contain control character (U+${s.toString(16).padStart(4,"0").toUpperCase()} at index ${n})`)}}function vt(r,e,t){if(r==="")throw new Error(`Graph "${e}": ${t} name must be non-empty`);if(r.includes(L))throw new Error(`Graph "${e}": ${t} "${r}" must not contain '${L}' (path separator)`);if(r===re)throw new Error(`Graph "${e}": ${t} name "${re}" is reserved for meta companion paths`);Jn(r,e,t)}function Yn(r,e){if(r==="")throw new Error(`Graph "${e}": resolve path must be non-empty`);let t=r.split(L);for(let n of t)if(n==="")throw new Error(`Graph "${e}": resolve path has empty segment`);return t}function Xn(r,e){let t=!1;for(let s of r)if(!e.isMetaPassthrough(s[0])){t=!0;break}return t?r.filter(s=>e.isMetaPassthrough(s[0])):r}function pn(r){for(let e of r._mounts.values())pn(e);for(let e of r._nodes.values())try{e.down([[q]],{internal:!0})}catch{}}function Zn(r,e){let t=De.diff(r,e),n={};for(let s of t.nodesAdded){let o=e.nodes[s];o!=null&&(n[s]=o)}return{...t,nodesAddedFull:n}}function ln(r,e,t,n={}){let s={paths:[],depths:new Map,truncated:!1};if(!e)return n.withDetail?s:[];if(!n.both&&t!=="upstream"&&t!=="downstream")throw new Error('reachable: direction must be "upstream" or "downstream"');let o=n.maxDepth;if(o!=null&&(!Number.isInteger(o)||o<0))throw new Error("reachable: maxDepth must be an integer >= 0");if(o===0)return n.withDetail?s:[];let i=new Map,u=new Map,a=new Map,d=new Map,l=new Set;for(let[y,_]of Object.entries(r.nodes)){if(!y)continue;l.add(y);let b=_.deps??[];i.set(y,b);for(let x of b)x&&(l.add(x),u.has(x)||u.set(x,new Set),u.get(x).add(y))}for(let y of r.edges){if(y==null||typeof y!="object")continue;let _=typeof y.from=="string"?y.from:"",b=typeof y.to=="string"?y.to:"";!_||!b||(l.add(_),l.add(b),d.has(_)||d.set(_,new Set),d.get(_).add(b),a.has(b)||a.set(b,new Set),a.get(b).add(_))}if(!l.has(e))return n.withDetail?s:[];let f=n.both===!0,p=y=>{if(f){let k=i.get(y)??[],T=a.get(y),E=u.get(y),A=d.get(y),S=[...k];return T&&S.push(...T),E&&S.push(...E),A&&S.push(...A),S}if(t==="upstream"){let k=i.get(y)??[],T=a.get(y);return T?[...k,...T]:k}let _=u.get(y),b=d.get(y),x=_?[..._]:[];return b&&x.push(...b),x},h=new Set([e]),c=new Map,v=[{path:e,depth:0}],g=0,w=!1;for(;g<v.length;){let y=v[g++];if(o!=null&&y.depth>=o){p(y.path).length>0&&(w=!0);continue}for(let _ of p(y.path))!_||h.has(_)||(h.add(_),c.set(_,y.depth+1),v.push({path:_,depth:y.depth+1}))}let m=[...c.keys()].sort((y,_)=>y<_?-1:y>_?1:0);return n.withDetail?{paths:m,depths:c,truncated:w}:m}function Qn(r,e){if(r.length!==e.length)return!1;for(let t=0;t<r.length;t++){let n=r[t],s=e[t];if(n.path!==s.path||n.type!==s.type||n.status!==s.status||n.hop!==s.hop||n.dep_index!==s.dep_index||n.annotation!==s.annotation||n.value!==s.value||n.lastMutation!==s.lastMutation)return!1;let o=n.v,i=s.v;if(o!==i&&(o==null||i==null||o.id!==i.id||o.version!==i.version))return!1}return!0}var L,re,we,Un,Kn,De,hn=F(()=>{"use strict";rt();Ie();je();Le();Be();pt();Se();gt();zt();Kt();qt();Jt();nt();en();sn();L="::",re="__meta__",we=1;Un={data:"\x1B[32m",dirty:"\x1B[33m",resolved:"\x1B[36m",invalidate:"\x1B[93m",pause:"\x1B[90m",resume:"\x1B[96m",complete:"\x1B[34m",error:"\x1B[31m",teardown:"\x1B[91m",derived:"\x1B[35m",path:"\x1B[90m",reset:"\x1B[0m"},Kn={data:"",dirty:"",resolved:"",invalidate:"",pause:"",resume:"",complete:"",error:"",teardown:"",derived:"",path:"",reset:""};De=class r{name;opts;config;_nodes=new Map;_nodeToName=new WeakMap;_mounts=new Map;_parent=void 0;_storageDisposers=new Set;_disposers=new Set;_destroyed=!1;_topology;_topologyEmitters=new Set;_factory;_factoryArgs;constructor(e,t){if(e==="")throw new Error("Graph name must be non-empty");if(e.includes(L))throw new Error(`Graph name must not contain '${L}' (got "${e}")`);if(e===re)throw new Error(`Graph name "${re}" is reserved for meta companion paths`);this.name=e,this.opts=Object.freeze({...t??{}}),this.config=t?.config??_e,this._traceRing=new Ae(t?.traceCapacity??1e3),t?.versioning!=null&&this.setVersioning(t.versioning),typeof t?.factory=="string"&&(this._factory=t.factory,t.factoryArgs!==void 0&&(this._factoryArgs=t.factoryArgs))}tagFactory(e,t){return this._factory=e,this._factoryArgs=t,this}ancestors(e=!0){let t=[],n=e?this:this._parent;for(;n!=null;)t.push(n),n=n._parent;return t}get topology(){return this._topology==null&&(this._topology=ht(e=>{let t=n=>{e.emit(n)};return this._topologyEmitters.add(t),()=>{this._topologyEmitters.delete(t)}},{name:`${this.name}_topology`})),this._topology}_emitTopology(e){if(!(this._topology==null||this._topologyEmitters.size===0))for(let t of this._topologyEmitters)t(e)}nameOf(e){return this._nodeToName.get(e)}add(e,t){let n=e.name,s=t?.name??n;if(s==null||s==="")throw new Error(`Graph "${this.name}": graph.add requires a non-empty name \u2014 pass via opts.name or set it on the node (e.g. state(0, { name: "x" }))`);let o=s,i=t?.annotation;if(vt(o,this.name,"add"),this._mounts.has(o))throw new Error(`Graph "${this.name}": name "${o}" is already a mount point`);if(this._nodes.has(o))throw new Error(`Graph "${this.name}": node "${o}" already exists`);let u=this._nodeToName.get(e);if(u!==void 0)throw new Error(`Graph "${this.name}": node instance already registered as "${u}"`);return this._nodes.set(o,e),this._nodeToName.set(e,o),this._emitTopology({kind:"added",name:o,nodeKind:"node"}),i!=null&&(this._annotations.set(o,i),this.config.inspectorEnabled&&this._traceRing.push({path:o,annotation:i,timestamp_ns:ue()})),e}setVersioning(e){if(e!=null)for(let t of this._nodes.values())t instanceof H&&t._applyVersioning(e)}remove(e){vt(e,this.name,"remove");let t=this._mounts.get(e);if(t){let o={kind:"mount",nodes:[],mounts:[]},i=[];t._collectObserveTargets("",i);for(let[u,a]of i)u.includes(`${L}${re}${L}`)||o.nodes.push(u);return o.nodes.sort(),o.mounts.push(e),o.mounts.push(...t._collectSubgraphs(`${e}${L}`)),this._mounts.delete(e),t._parent=void 0,pn(t),this._emitTopology({kind:"removed",name:e,nodeKind:"mount",audit:o}),o}let n=this._nodes.get(e);if(!n)throw new Error(`Graph "${this.name}": unknown node or mount "${e}"`);this._nodes.delete(e),this._nodeToName.delete(n),n.down([[q]],{internal:!0});let s={kind:"node",nodes:[e],mounts:[]};return this._emitTopology({kind:"removed",name:e,nodeKind:"node",audit:s}),s}removeAll(e){let t=typeof e=="function"?e:(()=>{let o=Xe(e);return i=>o.test(i)})(),n={kind:"mount",nodes:[],mounts:[]},s=[...this._nodes.keys(),...this._mounts.keys()].filter(o=>t(o));for(let o of s){let i=this.remove(o);n.nodes.push(...i.nodes),n.mounts.push(...i.mounts)}return n.nodes.sort(),n.mounts.sort(),n}[Symbol.iterator](){let e=[...this._nodes.keys()].sort(),t=this._nodes,n=0;return{[Symbol.iterator](){return this},next(){if(n>=e.length)return{value:void 0,done:!0};let s=e[n++];return{value:[s,t.get(s)],done:!1}}}}node(e){if(e==="")throw new Error(`Graph "${this.name}": node name must be non-empty`);if(e.includes(L))return this.resolve(e);let t=this._nodes.get(e);if(!t)throw new Error(`Graph "${this.name}": unknown node "${e}"`);return t}get(e){return this.node(e).cache}set(e,t,n){let s=n?.internal===!0;this.node(e).down([[K,t]],{actor:n?.actor,internal:s,delivery:"write"})}setAll(e,t){let n=Symbol.iterator in e?e:Object.entries(e);Ge(()=>{for(let[s,o]of n)this.set(s,o,t)})}invalidate(e,t){let n=t?.internal===!0;this.node(e).down([[ne]],{actor:t?.actor,internal:n,delivery:"write"})}error(e,t,n){let s=n?.internal===!0;this.node(e).down([[B,t]],{actor:n?.actor,internal:s,delivery:"write"})}complete(e,t){let n=t?.internal===!0;this.node(e).down([[ee]],{actor:t?.actor,internal:n,delivery:"write"})}edges(e){let t=e?.recursive===!0,n=new Map;if(!t){for(let[a,d]of this._nodes)n.set(d,a);let u=[];for(let[a,d]of this._nodes)if(d instanceof H)for(let l of d._deps){let f=n.get(l.node);f!=null&&u.push([f,a])}return u.sort((a,d)=>a[0]<d[0]?-1:a[0]>d[0]?1:a[1]<d[1]?-1:a[1]>d[1]?1:0),u}let s=[];this._collectObserveTargets("",s);let o=new Map;for(let[u,a]of s)o.set(a,u);let i=[];for(let[u,a]of s)if(a instanceof H)for(let d of a._deps){let l=o.get(d.node);l!=null&&i.push([l,u])}return i.sort((u,a)=>u[0]<a[0]?-1:u[0]>a[0]?1:u[1]<a[1]?-1:u[1]>a[1]?1:0),i}mount(e,t){if(t===void 0){let s=new r(e);return this.mount(e,s)}if(typeof t=="function"){let s=new r(e);return t(s),this.mount(e,s)}let n=t;if(vt(e,this.name,"mount"),this._nodes.has(e))throw new Error(`Graph "${this.name}": cannot mount at "${e}" \u2014 node with that name exists`);if(this._mounts.has(e))throw new Error(`Graph "${this.name}": mount "${e}" already exists`);if(n===this)throw new Error(`Graph "${this.name}": cannot mount a graph into itself`);if(n._parent!=null)throw new Error(`Graph "${this.name}": this child graph is already mounted on "${n._parent.name}"`);for(let s=this;s!=null;s=s._parent)if(s===n)throw new Error(`Graph "${this.name}": mount("${e}", \u2026) would create a mount cycle`);return this._mounts.set(e,n),n._parent=this,this._emitTopology({kind:"added",name:e,nodeKind:"mount"}),n}resolve(e){let t=Yn(e,this.name);return this._resolveFromSegments(t)}tryResolve(e){try{return this.resolve(e)}catch{return}}_resolveFromSegments(e){let t=e;if(t[0]===this.name&&(t=t.slice(1),t.length===0))throw new Error(`Graph "${this.name}": resolve path ends at graph name only`);let n=t[0],s=t.slice(1);if(s.length===0){let u=this._nodes.get(n);if(u)return u;throw this._mounts.has(n)?new Error(`Graph "${this.name}": path ends at subgraph "${n}" \u2014 not a node (GRAPHREFLY-SPEC \xA73.5)`):new Error(`Graph "${this.name}": unknown name "${n}"`)}let o=this._nodes.get(n);if(o&&s.length>0&&s[0]===re)return this._resolveMetaChainFromNode(o,s,t.join(L));let i=this._mounts.get(n);if(!i)throw this._nodes.has(n)?new Error(`Graph "${this.name}": "${n}" is a node; trailing path "${s.join(L)}" is invalid`):new Error(`Graph "${this.name}": unknown mount or node "${n}"`);return i.resolve(s.join(L))}_resolveMetaChainFromNode(e,t,n){let s=e,o=0,i=[...t];for(;o<i.length;){if(i[o]!==re)throw new Error(`Graph "${this.name}": expected ${re} segment in meta path "${n}"`);if(o+1>=i.length)throw new Error(`Graph "${this.name}": meta path requires a key after ${re} in "${n}"`);let u=i[o+1],a=s.meta[u];if(!a)throw new Error(`Graph "${this.name}": unknown meta "${u}" in path "${n}"`);s=a,o+=2}return s}signal(e,t){if(t?.internal!==!0){for(let s of e)if(this.config.messageTier(s[0])===3)throw new Error(`Graph "${this.name}": Graph.signal() rejects tier-3 messages (DATA / RESOLVED). Broadcast is for control-plane tiers (START / DIRTY / INVALIDATE / PAUSE / RESUME / COMPLETE / ERROR / TEARDOWN). For per-node value writes, use Graph.set or graph.node(name).down(...).`)}let n=[];if(this._signalDeliver(e,t??{},new Set,n),n.length>0)throw n[0]}_signalDeliver(e,t,n,s){for(let a of this._mounts.values())a._signalDeliver(e,t,n,s);let i=t.internal===!0?{internal:!0}:{actor:t.actor,delivery:"signal"},u=Xn(e,this.config);for(let a of[...this._nodes.keys()].sort()){let d=this._nodes.get(a);if(!n.has(d)){n.add(d);try{d.down(e,i)}catch(l){if(l instanceof te)throw l;s.push(l)}u.length!==0&&this._signalMetaSubtree(d,u,n,i,s)}}}_signalMetaSubtree(e,t,n,s,o){for(let i of Object.keys(e.meta).sort()){let u=e.meta[i];if(!n.has(u)){n.add(u);try{u.down(t,s)}catch(a){if(a instanceof te)throw a;o.push(a)}this._signalMetaSubtree(u,t,n,s,o)}}}describe(e){if(e?.reactive==="diff")return this._describeReactiveDiff(e);if(e?.reactive===!0)return this._describeReactive(e);let t=Hn(e?.actor),n=e?.filter;if(e?.detail!=null&&e?.fields!=null)throw new TypeError("Graph.describe(): pass either `detail` or `fields`, not both. `detail: 'spec'` is the canonical spec projection; use `fields` only when you need a custom subset.");let s=Ee(e?.detail,e?.fields),o=e?.detail==="spec",i=s,u=[];this._collectObserveTargets("",u);let a=new Map;for(let[_,b]of u)a.set(b,_);let d=[];{let _=u.map(([,k])=>k),b=new Set(a.values()),x=0;for(;_.length>0;){let k=_.shift();if(k instanceof H)for(let T of k._deps){let E=T.node;if(a.has(E))continue;let A=E.name??"",S=A;if(!S||b.has(S))if(A){let $=2;for(;b.has(`${A}#${$}`);)$++;S=`${A}#${$}`}else for(S=`__internal__/${x++}`;b.has(S);)S=`__internal__/${x++}`;a.set(E,S),b.add(S),d.push([S,E]),_.push(E)}}}let l=[...u,...d],f={};for(let[_,b]of l){if(t!=null&&!b.allowsObserve(t))continue;let x=Re(b,i,o),k=b instanceof H?b._deps.map(S=>a.get(S.node)??S.node.name??""):[],{name:T,...E}=x,A={...E,deps:k};if(!o){let S=this._annotations.get(_);S!=null&&(A.annotation=S)}if(n!=null)if(typeof n=="function"){let S=n;if(!(S.length>=2?S(_,A):S(A)))continue}else{let S=!0;for(let[$,G]of Object.entries(n)){let P=$==="deps_includes"?"depsIncludes":$==="meta_has"?"metaHas":$;if(P==="depsIncludes"){if(!A.deps.includes(String(G))){S=!1;break}continue}if(P==="metaHas"){if(!Object.hasOwn(A.meta??{},String(G))){S=!1;break}continue}if(A[P]!==G){S=!1;break}}if(!S)continue}f[_]=A}let p=new Set(Object.keys(f)),h=[];for(let[_,b]of l)if(b instanceof H)for(let x of b._deps){let k=a.get(x.node);k!=null&&h.push([k,_])}h.sort((_,b)=>_[0]<b[0]?-1:_[0]>b[0]?1:_[1]<b[1]?-1:_[1]>b[1]?1:0);let c=h.map(([_,b])=>({from:_,to:b}));(t!=null||n!=null)&&(c=c.filter(_=>p.has(_.from)&&p.has(_.to)));let v=this._collectSubgraphs(""),g=t!=null||n!=null?v.filter(_=>{let b=`${_}${L}`;return[...p].some(x=>x===_||x.startsWith(b))}):v,w=this,m=e;return{name:this.name,nodes:f,edges:c,subgraphs:g,...this._factory!==void 0?{factory:this._factory}:{},...this._factoryArgs!==void 0?{factoryArgs:this._factoryArgs}:{},expand(_){let b={...m};return Array.isArray(_)?(b.fields=_,b.detail=void 0):(b.detail=_,b.fields=void 0),w.describe(b)}}}_collectSubgraphs(e){let t=[];for(let n of[...this._mounts.keys()].sort()){let s=e===""?n:`${e}${n}`;t.push(s),t.push(...this._mounts.get(n)._collectSubgraphs(`${s}${L}`))}return t}resourceProfile(e){return rn(this,e)}reachable(e,t,n={}){return n.withDetail===!0?ln(this.describe(),e,t,{...n,withDetail:!0}):ln(this.describe(),e,t,n)}explain(e,t,n){return n?.reactive===!0?this._explainReactive(e,t,n):this._explainStatic(ce(e),ce(t),{...n?.maxDepth!==void 0?{maxDepth:an(n.maxDepth)}:{},...n?.findCycle!==void 0?{findCycle:un(n.findCycle)}:{}})}_explainStatic(e,t,n){let s=this.describe({detail:"full"}),o=new Map(this._annotations),i=new Map;for(let[u,a]of Object.entries(s.nodes))a.lastMutation!=null&&i.set(u,a.lastMutation);return Yt(s,e,t,{...n?.maxDepth!=null?{maxDepth:n.maxDepth}:{},...n?.findCycle===!0?{findCycle:!0}:{},annotations:o,lastMutations:i})}_describeReactive(e){let t={...e,reactive:!1},n=e.reactiveName??"describe",s=0,o=J(s,{name:`${n}_version`}),i=this.observe({timeline:!0,structured:!0}),u=!1,a=!1,d=()=>{u||a||(u=!0,be(()=>{u=!1,!a&&(s+=1,o.emit(s))}))},l=i.onEvent(m=>{let y=m.type;y!=="data"&&y!=="error"&&y!=="complete"&&y!=="teardown"||d()}),f=[],p=new WeakSet,h=m=>{if(p.has(m)||a)return;p.add(m);let y=m.topology.subscribe(_=>{for(let b of _){if(b[0]!==K)continue;let x=b[1];if(d(),x.kind==="added"&&x.nodeKind==="mount"){let k=m._mounts.get(x.name);k!=null&&h(k)}}});f.push(y);for(let _ of m._mounts.keys()){let b=m._mounts.get(_);b!=null&&h(b)}};h(this);let c,v=e.actor;fn(v)&&(c=v.subscribe(m=>{let y=!1,_=!1;for(let b of m){let x=b[0];x===K?y=!0:(x===ee||x===B||x===q)&&(_=!0)}y&&d(),_&&(c?.(),c=void 0,d())}));let g;try{g=z([o],()=>this.describe(t),{name:n,describeKind:"derived",meta:{domain:"audit",kind:"describe"},equals:(m,y)=>m===y})}catch(m){l(),c?.();for(let y of f)y();throw i.dispose(),m}let w=Ue(g);return{node:g,dispose(){a=!0,l(),c?.();for(let m of f)m();f.length=0,i.dispose(),w()}}}_describeReactiveDiff(e){let t={...e,reactive:!1},n=e.reactiveName??"describe-diff",s={name:this.name,nodes:{},edges:[],subgraphs:[]},o=this.describe(t),i=bt(s,o),u=J(i,{name:n,meta:{domain:"audit",kind:"describe-diff"},equals:(p,h)=>p===h}),a=this._describeReactive({...e,reactiveName:void 0}),d=!1,l=a.node.subscribe(p=>{if(!d)for(let h of p){if(h[0]!==K)continue;let c=h[1],v=bt(o,c);o=c,v.events.length!==0&&u.emit(v)}}),f=Ue(u);return{node:u,dispose(){d=!0,l(),a.dispose(),u.down([[q,"describe-diff disposed"]]),f()}}}_explainReactive(e,t,n){let s=0,o=J(s,{name:"explain_version"}),i=this.observe({timeline:!0,structured:!0}),u=!1,a=!1,d=()=>{u||a||(u=!0,be(()=>{u=!1,!a&&(s+=1,o.emit(s))}))},l=i.onEvent(m=>{let y=m.type;y!=="data"&&y!=="error"&&y!=="complete"&&y!=="teardown"||d()}),f=[];e!=null&&he(e)&&f.push(e),t!=null&&he(t)&&f.push(t),n?.maxDepth!=null&&he(n.maxDepth)&&f.push(n.maxDepth),n?.findCycle!=null&&he(n.findCycle)&&f.push(n.findCycle);let p=()=>{for(let m of f)if(m.cache===void 0)return!1;return!0},h=()=>{let m=ce(e),y=ce(t);return{from:m,to:y,found:!1,reason:"pending",steps:[],text:"(awaiting reactive args)",toJSON:()=>({from:m,to:y,found:!1,reason:"pending",steps:[]})}},c;try{c=z([o],()=>{if(!p())return h();let m=ce(e),y=ce(t),_={...n?.maxDepth!==void 0?{maxDepth:an(n.maxDepth)}:{},...n?.findCycle!==void 0?{findCycle:un(n.findCycle)}:{}};return this._explainStatic(m,y,_)},{name:n?.name??"explain",describeKind:"derived",meta:{domain:"audit",kind:"explain_path",from:ce(e),to:ce(t)},equals:(m,y)=>m.found===y.found&&m.reason===y.reason&&m.steps.length===y.steps.length&&Qn(m.steps,y.steps)})}catch(m){throw l(),i.dispose(),m}let v=Ue(c),g=[],w=m=>{let y;return y=m.subscribe(_=>{let b=!1,x=!1;for(let k of _){let T=k[0];T===K?b=!0:(T===ee||T===B||T===q)&&(x=!0)}(b||x)&&d(),x&&y&&(y(),y=void 0)}),()=>{y&&(y(),y=void 0)}};for(let m of f)g.push(w(m));return{node:c,dispose(){a=!0,l();for(let m of g)m?.();g.length=0,i.dispose(),v()}}}_pathsMatching(e){let t=Xe(e),n=[];return this._collectObserveTargets("",n),n.map(([s])=>s).filter(s=>t.test(s))}_collectObserveTargets(e,t){for(let n of[...this._mounts.keys()].sort()){let s=e===""?n:`${e}${L}${n}`;this._mounts.get(n)._collectObserveTargets(s,t)}for(let n of[...this._nodes.keys()].sort()){let s=this._nodes.get(n),o=e===""?n:`${e}${L}${n}`;t.push([o,s]),this._appendMetaObserveTargets(o,s,t)}}_appendMetaObserveTargets(e,t,n){for(let s of Object.keys(t.meta).sort()){let o=t.meta[s],i=`${e}${L}${re}${L}${s}`;n.push([i,o]),this._appendMetaObserveTargets(i,o,n)}}observe(e,t){let n=typeof e=="string",o=cn(n?t:e);if(o.reactive===!0)return this._observeReactive(n?e:void 0,o);let i=o.structured===!0||o.timeline===!0||o.causal===!0||o.derived===!0||o.detail==="minimal"||o.detail==="full"||o.format!=null,u=o.actor;if(n){let l=e,f=this.resolve(l);if(u!=null&&!f.allowsObserve(u))throw new te({actor:u,action:"observe",nodeName:l});return i?this._buildStructuredObserver([[l,f]],o,"one"):{subscribe(p){return f.subscribe(p)},up(p){try{f.up?.(p)}catch(h){if(h instanceof te)return;throw h}}}}let a=[];this._collectObserveTargets("",a),a.sort((l,f)=>l[0]<f[0]?-1:l[0]>f[0]?1:0);let d=u==null?a:a.filter(([,l])=>l.allowsObserve(u));return i?this._buildStructuredObserver(d,o,"all"):{subscribe:l=>{let f=d.map(([p,h])=>h.subscribe(c=>{l(p,c)}));return()=>{for(let p of f)p()}},up:(l,f)=>{try{this.resolve(l).up?.(f)}catch(p){if(p instanceof te)return;throw p}}}}_observeReactive(e,t){let n=t.tiers,s=n!=null?new Set(n):null,o=t.reactiveName??"observe";return ht(i=>{let u=[],a=!1,d=!1,l=()=>{if(u.length===0||d)return;let v={events:u.slice(),flushedAt_ns:ue()};u.length=0,i.emit(v)},f={...t,reactive:!1,structured:!0,timeline:!0},p=e!=null?this.observe(e,f):this.observe(f),h=v=>{d||(u.push(v),!a&&(a=!0,be(()=>{a=!1,l()})))};for(let v of p.events)h(v);let c=p.onEvent(h);return()=>{d=!0,c(),p.dispose()}},{name:o,meta:{domain:"audit",kind:"observe-reactive"}})}_buildStructuredObserver(e,t,n){let s=n==="one"?e[0]?.[0]:void 0,o=i=>{if(n==="one"&&s!=null){let l=this.resolve(s);return this._buildStructuredObserver([[s,l]],i,"one")}let u=[];this._collectObserveTargets("",u),u.sort((l,f)=>l[0]<f[0]?-1:l[0]>f[0]?1:0);let a=i.actor,d=a==null?u:u.filter(([,l])=>l.allowsObserve(a));return this._buildStructuredObserver(d,i,"all")};return this._createObserveResult(e,t,o)}_createObserveResult(e,t,n){let s=t.timeline===!0,o=t.causal===!0,i=t.derived===!0,u=t.detail==="minimal",a=this.config.inspectorEnabled,d=(o||i)&&a,l=t.maxEvents,f=l!=null&&l>0?new Ae(l):null,p=[],h=new Set,c=t.tiers!=null?new Set(t.tiers):null,v={},g=new Set,w=0,m=0,y=0,_=0,b=0,x=0,k=!1,T=!1,E=0,A=new Map,S=new Map,$=new Map,G=N=>{if(!(c!=null&&!c.has(N.type))){f?f.push(N):p.push(N);for(let C of h)C(N)}},P=N=>c==null||c.has(N),ae=()=>s?{timestamp_ns:ue(),in_batch:Me(),batch_id:E}:{},xe=(N,C)=>{if(!(!d||!(N instanceof H)))return N._setInspectorHook(U=>{if(U.kind==="dep_message")A.set(N,U.depIndex);else if(U.kind==="run"){let le=U.batchData.map((M,Z)=>M!=null&&M.length>0?M.at(-1):U.prevData[Z]);S.set(N,le);let X=U.batchData.map(M=>M!=null?[...M]:void 0);$.set(N,X),i&&G({type:"derived",path:C,dep_values:le,dep_batches:X,...ae()})}})},O=N=>{let C=A.get(N),U=S.get(N);if(!o||U==null)return{};let X=(C!=null&&C>=0&&N instanceof H?N._deps[C]:void 0)?.node,M=X?.v,Z=$.get(N);return{trigger_dep_index:C,trigger_dep_name:X?.name,...M!=null?{trigger_version:{id:M.id,version:M.version}}:{},dep_values:[...U],...Z!=null?{dep_batches:Z}:{}}},D=[],R=[];for(let[N,C]of e){let U=xe(C,N);U&&D.push(U),R.push(C.subscribe(le=>{E++;for(let X of le){let M=X[0],Z=ae();if(M===K){v[N]=X[1];let Ze=C instanceof H?C.lastMutation?.actor??ye:ye;G({type:"data",path:N,data:X[1],actor:Ze,...Z,...O(C)})}else if(u)M===se?P("dirty")&&w++:M===oe?P("resolved")&&m++:M===ne?P("invalidate")&&y++:M===ie?P("pause")&&_++:M===de?P("resume")&&b++:M===q?P("teardown")&&x++:M===ee&&!g.has(N)?P("complete")&&(k=!0):M===B&&P("error")&&(T=!0,g.add(N));else if(M===se)P("dirty")&&w++,G({type:"dirty",path:N,...Z});else if(M===oe)P("resolved")&&m++,G({type:"resolved",path:N,...Z,...O(C)});else if(M===ne)P("invalidate")&&y++,G({type:"invalidate",path:N,...Z});else if(M===ie)P("pause")&&_++,G({type:"pause",path:N,lockId:X[1],...Z});else if(M===de)P("resume")&&b++,G({type:"resume",path:N,lockId:X[1],...Z});else if(M===ee)P("complete")&&!g.has(N)&&(k=!0),G({type:"complete",path:N,...Z});else if(M===B){P("error")&&(T=!0,g.add(N));let Ze=C instanceof H?C.lastMutation?.actor??ye:ye;G({type:"error",path:N,data:X[1],actor:Ze,...Z})}else M===q&&(P("teardown")&&x++,G({type:"teardown",path:N,...Z}))}}))}let Y=!1,I=()=>{if(!Y){Y=!0;for(let N of R)N();for(let N of D)N();for(let N of V)N({value:void 0,done:!0});V.length=0}},j=[],V=[];h.add(N=>{let C=V.shift();C?C({value:N,done:!1}):j.push(N)});let Q={get values(){return v},get dirtyCount(){return w},get resolvedCount(){return m},get invalidateCount(){return y},get pauseCount(){return _},get resumeCount(){return b},get teardownCount(){return x},get events(){return f?f.toArray():[...p]},get anyCompletedCleanly(){return k},get anyErrored(){return T},get completedWithoutErrors(){return k&&!T},onEvent(N){return h.add(N),()=>h.delete(N)},dispose:I,expand(N){I();let C={...t};return typeof N=="string"?C.detail=N:Object.assign(C,N),n(cn(C))},[Symbol.asyncIterator](){return{next(){return j.length>0?Promise.resolve({value:j.shift(),done:!1}):Y?Promise.resolve({value:void 0,done:!0}):new Promise(N=>V.push(N))},return(){return I(),Promise.resolve({value:void 0,done:!0})}}}};return t.format!=null&&this._attachFormatLogger(Q,t),Q}_attachFormatLogger(e,t){let n=t.format;if(n==null)return;let s=t.logger??(c=>console.log(c)),o=t.includeTypes?new Set(t.includeTypes):null,i=t.excludeTypes?new Set(t.excludeTypes):null,u=o==null&&i==null?()=>!0:c=>(o==null||o.has(c))&&(i==null||!i.has(c)),a=qn(t.theme),d=n==="stage-log"?ue():0,l=c=>c==null?"":t.stageLabels?.[c]??c,f=(c,v)=>c.length>v?`${c.slice(0,v-1)}\u2026`:c,p=c=>c.type==="data"||c.type==="error"?f(yt(c.data),120):"",h=c=>{if(n==="stage-log"){let k=(ue()-d)/1e9,T=l(c.path).padEnd(9);if(c.type==="data"){let E=p(c);return`[${k.toFixed(3)}s] ${T} \u2190${E?` ${E}`:""}`}if(c.type==="error"){let E=p(c);return`[${k.toFixed(3)}s] ${T} \u2717${E?` ${E}`:""}`}return c.type==="complete"?`[${k.toFixed(3)}s] ${T} \u25A0 complete`:`[${k.toFixed(3)}s] ${T} ${c.type}`}if(n==="json")try{return JSON.stringify(c)}catch{return JSON.stringify({type:c.type,path:c.path,data:"[unserializable]"})}let v=a[c.type]??"",g=c.path?`${a.path}${c.path}${a.reset} `:"",w=c.type==="data"||c.type==="error",m=c.type==="pause"||c.type==="resume",y=w?` ${yt(c.data)}`:m?` ${yt(c.lockId)}`:"",_=c.type==="data"||c.type==="resolved"||c.type==="derived"?c:void 0,b=_?.trigger_dep_name!=null?` <- ${_.trigger_dep_name}`:_?.trigger_dep_index!=null?` <- #${_.trigger_dep_index}`:"",x=c.in_batch?" [batch]":"";return`${g}${v}${c.type.toUpperCase()}${a.reset}${y}${b}${x}`};e.onEvent(c=>{u(c.type)&&s(h(c),c)})}addDisposer(e){return this._disposers.add(e),()=>{this._disposers.delete(e)}}destroy(){on(this._disposers,this.name),this.signal([[q]],{internal:!0}),on(this._storageDisposers,this.name);for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0,this._destroyed=!0}get destroyed(){return this._destroyed}_destroyClearOnly(){for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0,this._destroyed=!0}snapshot(e){let{expand:t,...n}=this.describe({detail:"full"}),s={};for(let u of Object.keys(n.nodes).sort()){let{lastMutation:a,guard:d,...l}=n.nodes[u];s[u]=l}let o=[...n.subgraphs].sort(),i={...n,version:1,nodes:s,subgraphs:o};if(e?.format==null)return i;if(e.format==="json-string")return JSON.stringify(i);if(e.format==="bytes"){if(e.codec==null)throw new Error("snapshot({format: 'bytes'}) requires a `codec` name");let u=this.config.lookupCodec(e.codec);if(u==null)throw new Error(`snapshot: codec "${e.codec}" is not registered on this graph's config. Call config.registerCodec(...) before creating nodes.`);return Tt(u,u.encode(i))}throw new Error(`snapshot: unknown format "${String(e.format)}"`)}static decode(e,t){let n=t?.config??_e,{codec:s,codecVersion:o,payload:i}=Ot(e,n);return s.decode(i,o)}restore(e,t){if(dn(e),e.name!==this.name)throw new Error(`Graph "${this.name}": restore snapshot name "${e.name}" does not match this graph`);let n=t?.only==null?null:(Array.isArray(t.only)?t.only:[t.only]).map(o=>Xe(o)),s=t?.includeProducers===!0;for(let o of Object.keys(e.nodes).sort()){if(n!==null&&!n.some(u=>u.test(o)))continue;let i=e.nodes[o];if(i!==void 0){if(!("value"in i)||i.value===void 0){"value"in i&&i.value===void 0&&t?.onError?.(o,new Error(`restore: slice.value is undefined for "${o}" (undefined is the global SENTINEL; not valid DATA)`));continue}if(!(i.type==="derived"||i.type==="effect")&&!(i.type==="producer"&&!s)){if(i.v!=null){let a=this.tryResolve(o)?.v;if(a!=null&&a.id===i.v.id&&a.version===i.v.version)continue}try{this.set(o,i.value)}catch(u){t?.onError?.(o,u)}}}}}static fromSnapshot(e,t){dn(e);let n=typeof t=="function"?t:t?.build,s=typeof t=="function"?void 0:t?.factories,o=new r(e.name);if(n)return n(o),o.restore(e),o;for(let h of[...e.subgraphs].sort((c,v)=>{let g=c.split(L).length,w=v.split(L).length;return g!==w?g-w:c<v?-1:c>v?1:0})){let c=h.split(L),v=o;for(let g of c)v._mounts.has(g)||v.mount(g,new r(g)),v=v._mounts.get(g)}let i=s?Object.entries(s).map(([h,c])=>({re:Xe(h),factory:c})):[],u=h=>{for(let c of i)if(c.re.test(h))return c.factory},a=h=>{let c=h.split(L),v=c.pop();if(v==null||v.length===0)throw new Error(`invalid snapshot path "${h}"`);let g=o;for(let w of c){let m=g._mounts.get(w);if(!m)throw new Error(`unknown mount "${w}" in path "${h}"`);g=m}return[g,v]},d=Object.entries(e.nodes).filter(([h])=>!h.includes(`${L}${re}${L}`)).sort((h,c)=>h[0]<c[0]?-1:h[0]>c[0]?1:0),l=new Map(d),f=new Map,p=!0;for(;l.size>0&&p;){p=!1;for(let[h,c]of[...l.entries()]){let v=c?.deps??[];if(!v.every(b=>f.has(b)))continue;let[g,w]=a(h),m={...c?.meta??{}},y=u(h),_;if(c?.type==="state")_=J(c.value,{meta:m});else{if(y==null)continue;_=y(w,{path:h,type:c.type,value:c.value,meta:m,deps:v,resolvedDeps:v.map(b=>f.get(b))})}g.add(_,{name:w}),f.set(h,_),l.delete(h),p=!0}}if(l.size>0){let h=[...l.keys()].sort().join(", ");throw new Error(`Graph.fromSnapshot could not reconstruct nodes without build callback: ${h}. Pass matching factories via fromSnapshot(data, { factories: { pattern: factoryFn } }).`)}return o.restore(e),o}toJSON(){return this.snapshot()}attachSnapshotStorage(e,t={}){let n=e.map(d=>({tier:d,debounceMs:Math.max(0,d.debounceMs??0),compactEvery:Math.max(1,d.compactEvery??10),timer:void 0,seq:0,lastSnapshot:void 0,lastFingerprint:"",disposed:!1,savePending:void 0}));t.autoRestore===!0&&this._cascadeRestore(e,t.onError);let s=(d,l)=>{if(d.disposed)return;let f=Wn(l.nodes);if(d.lastSnapshot!=null&&f!==""&&f===d.lastFingerprint)return;let p=d.seq+1,h=Fe(),g=d.lastSnapshot==null||p%d.compactEvery===0?{name:this.name,mode:"full",snapshot:l,seq:p,timestamp_ns:h,format_version:we}:{name:this.name,mode:"diff",diff:Zn(d.lastSnapshot,l),seq:p,timestamp_ns:h,format_version:we};if(d.tier.filter&&!d.tier.filter(g))return;let w;try{w=d.tier.save(g)}catch(m){t.onError?.(m,d.tier);return}if(w&&typeof w.then=="function"){let _=(d.savePending??Promise.resolve()).then(()=>w,()=>w).then(()=>{d.disposed||(d.seq=p,d.lastSnapshot=l,d.lastFingerprint=f)},b=>{t.onError?.(b,d.tier)});d.savePending=_.finally(()=>{d.savePending===_&&(d.savePending=void 0)})}else d.seq=p,d.lastSnapshot=l,d.lastFingerprint=f},o=(d,l)=>{try{s(d,l)}catch(f){t.onError?.(f,d.tier)}},i=(d,l)=>{if(!l.some(c=>{let v=this.config.messageTier(c[0]);return v>=3&&v<5}))return;if(t.filter){let c=this.tryResolve(d);if(c==null)return;let v=Re(c,Ee("standard"));if(!t.filter(d,v))return}let p,h=()=>(p==null&&(p=this.snapshot()),p);for(let c of n)c.disposed||(c.debounceMs===0?o(c,h()):(c.timer==null&&(c.timer=new Ke),c.timer.start(c.debounceMs,()=>{c.disposed||o(c,this.snapshot())})))},u;if(t.paths!=null){let l=(typeof t.paths=="string"?this._pathsMatching(t.paths):t.paths).map(f=>{let p=this.tryResolve(f);return p==null?()=>{}:p.subscribe(h=>i(f,h))});u=()=>{for(let f of l)f()}}else u=this.observe().subscribe((d,l)=>i(d,l));let a=()=>{u();for(let d of n)d.disposed=!0,d.timer?.cancel();this._storageDisposers.delete(a)};return this._storageDisposers.add(a),{dispose:a}}async _cascadeRestore(e,t){for(let n of e){let s;try{s=await n.load?.()}catch(i){t?.(i,n);continue}if(s==null||typeof s!="object"||Array.isArray(s))continue;let o=s;try{if(o.mode==="full"&&o.snapshot!=null)return this.restore(o.snapshot),!0;if(o.version===we&&o.nodes!=null)return this.restore(o),!0}catch(i){t?.(i,n)}}return!1}static async fromStorage(e,t,n){for(let s of t){let o;try{o=await s.load?.()}catch(a){n?.onError?.(a,s);continue}if(o==null||typeof o!="object"||Array.isArray(o))continue;let i=o,u=i.mode==="full"&&i.snapshot!=null?i.snapshot:i.version===we&&i.nodes!=null?i:void 0;if(u!=null)try{return r.fromSnapshot(u,n)}catch(a){n?.onError?.(a,s)}}throw new Error(`Graph.fromStorage: no tier held a restorable record for "${e}" across ${t.length} tier(s)`)}_annotations=new Map;_traceRing;trace(e,t,n){if(e!=null&&t!=null){if(this.tryResolve(e)==null)return;if(this._annotations.set(e,t),this.config.inspectorEnabled){let s={path:e,annotation:t,timestamp_ns:ue(),...n?.actor!=null?{actor:n.actor}:{}};this._traceRing.push(s)}return}return e!=null?this.config.inspectorEnabled?this._annotations.get(e):void 0:this.config.inspectorEnabled?this._traceRing.toArray():[]}annotation(e){return this._annotations.get(e)}clearTrace(){this._annotations.clear(),this._traceRing.clear()}pruneTrace(e){let t=this._traceRing.toArray().filter(s=>!e(s)),n=this._traceRing.size-t.length;this._traceRing.clear();for(let s of t)this._traceRing.push(s);return n}static diff(e,t){let n=new Set(Object.keys(e.nodes)),s=new Set(Object.keys(t.nodes)),o=[...s].filter(m=>!n.has(m)).sort(),i=[...n].filter(m=>!s.has(m)).sort(),u=[],a=[];for(let m of n){if(!s.has(m))continue;let y=e.nodes[m],_=t.nodes[m],b=y.v,x=_.v;b!=null&&x!=null&&b.id===x.id&&b.version!==x.version&&a.push({path:m,id:b.id,from:b.version,to:x.version});let k=b!=null&&x!=null&&b.id===x.id&&b.version===x.version;for(let T of["type","status","sentinel"]){let E=y[T],A=_[T];E!==A&&u.push({path:m,field:T,from:E,to:A})}if(!k)for(let T of["value","meta"]){let E=y[T],A=_[T];Vn(E,A)||u.push({path:m,field:T,from:E,to:A})}}let d=m=>`${m.from} ${m.to}`,l=new Set(e.edges.map(d)),f=new Set(t.edges.map(d)),p=t.edges.filter(m=>!l.has(d(m))),h=e.edges.filter(m=>!f.has(d(m))),c=new Set(e.subgraphs),v=new Set(t.subgraphs),g=[...v].filter(m=>!c.has(m)).sort(),w=[...c].filter(m=>!v.has(m)).sort();return{nodesAdded:o,nodesRemoved:i,nodesChanged:u,versionChanges:a,edgesAdded:p,edgesRemoved:h,subgraphsAdded:g,subgraphsRemoved:w}}}});var or={};vn(or,{demoShell:()=>sr});module.exports=wn(or);Ie();pt();gt();Wt();hn();function er(r){for(let e of r){let t=e.codePointAt(0);if(t>=19968&&t<=40959||t>=13312&&t<=19903||t>=12288&&t<=12351||t>=12352&&t<=12447||t>=12448&&t<=12543||t>=44032&&t<=55215||t>=65280&&t<=65519)return!0}return!1}var gn=new Set(["\uFF0C","\uFF0E","\uFF01","\uFF1A","\uFF1B","\uFF1F","\u3001","\u3002","\u30FB","\uFF09","\u3015","\u3009","\u300B","\u300D","\u300F","\u3011"]),tr=new Set([".",",","!","?",":",";",")","]","}","%",'"',"\u201D","\u2019","\xBB","\u203A","\u2026"]);function nr(r){return r.replace(/[\t\n\r\f ]+/g," ").replace(/^ | $/g,"")}function rr(r){let e=new Intl.Segmenter(void 0,{granularity:"word"}),t=[];for(let n of e.segment(r)){let s=n.segment,o=n.isWordLike??!1,i=[],u=[],a=[],d="",l=null;for(let f of s){let p;f===" "?p="space":f==="\u200B"?p="zero-width-break":f==="\xAD"?p="soft-hyphen":f===`
5
- `?p="hard-break":p="text",l!==null&&p===l?d+=f:(l!==null&&(i.push(d),u.push(l==="text"&&o),a.push(l)),d=f,l=p)}l!==null&&(i.push(d),u.push(l==="text"&&o),a.push(l)),t.push({texts:i,isWordLike:u,kinds:a})}return t}function _t(r,e,t,n,s){let o=nr(r);if(o.length===0)return[];let i=rr(o),u=new Intl.Segmenter(void 0,{granularity:"grapheme"}),a=[],d=[],l=[];for(let w of i)for(let m=0;m<w.texts.length;m++)a.push(w.texts[m]),d.push(w.kinds[m]),l.push(w.isWordLike[m]);let f=[],p=[],h=[];for(let w=0;w<a.length;w++){let m=a[w],y=d[w],_=l[w];if(y==="text"&&!_&&f.length>0&&p[p.length-1]==="text"&&m.length===1&&(tr.has(m)||gn.has(m))){f[f.length-1]+=m;continue}if(m==="-"&&f.length>0&&p[p.length-1]==="text"&&h[h.length-1]){f[f.length-1]+=m;continue}f.push(m),p.push(y),h.push(_)}let c=n.get(e);c||(c=new Map,n.set(e,c));function v(w){let m=c.get(w);if(m===void 0){s&&(s.misses+=1);let y=t.measureSegment(w,e).width;m=Number.isFinite(y)&&y>=0?y:0,c.set(w,m)}else s&&(s.hits+=1);return m}let g=[];for(let w=0;w<f.length;w++){let m=f[w],y=p[w];if(y!=="text"){g.push({text:m,width:y==="space"?v(" ")*m.length:0,kind:y,graphemeWidths:null});continue}if(er(m)){let x="";for(let k of u.segment(m)){let T=k.segment;if(x.length>0&&gn.has(T)){x+=T;continue}if(x.length>0){let E=v(x);g.push({text:x,width:E,kind:"text",graphemeWidths:null})}x=T}if(x.length>0){let k=v(x);g.push({text:x,width:k,kind:"text",graphemeWidths:null})}continue}let _=v(m),b=null;if(h[w]&&m.length>1){let x=[];for(let k of u.segment(m))x.push(v(k.segment));x.length>1&&(b=x)}g.push({text:m,width:_,kind:"text",graphemeWidths:b})}return g}function wt(r,e,t,n,s){if(r.length===0)return{lines:[],lineCount:0};let o=[],i=0,u=!1,a=0,d=0,l=0,f=0,p=-1,h=0,c=s.get(n);c||(c=new Map,s.set(n,c));let v=c.get("-");v===void 0&&(v=t.measureSegment("-",n).width,c.set("-",v));function g(b=l,x=f,k=i){let T="";for(let E=a;E<b;E++){let A=r[E];if(!(A.kind==="soft-hyphen"||A.kind==="hard-break"))if(E===a&&d>0&&A.graphemeWidths){let $=[...new Intl.Segmenter(void 0,{granularity:"grapheme"}).segment(A.text)].map(G=>G.segment);T+=$.slice(d).join("")}else T+=A.text}if(x>0&&b<r.length){let E=r[b],S=[...new Intl.Segmenter(void 0,{granularity:"grapheme"}).segment(E.text)].map(G=>G.segment),$=a===b?d:0;T+=S.slice($,x).join("")}b>0&&r[b-1]?.kind==="soft-hyphen"&&!(a===b&&d>0)&&(T+="-"),o.push({text:T,width:k,startSegment:a,startGrapheme:d,endSegment:b,endGrapheme:x}),i=0,u=!1,p=-1,h=0}function w(b){return b==="space"||b==="zero-width-break"||b==="soft-hyphen"}function m(b,x,k){u=!0,a=b,d=x,l=b+1,f=0,i=k}function y(b,x,k){u=!0,a=b,d=x,l=b,f=x+1,i=k}for(let b=0;b<r.length;b++){let x=r[b];if(x.kind==="hard-break"){u?g():o.push({text:"",width:0,startSegment:b,startGrapheme:0,endSegment:b,endGrapheme:0}),a=b+1,d=0;continue}let k=x.width;if(!u){k>e&&x.graphemeWidths?_(b,0,x.graphemeWidths):m(b,0,k),w(x.kind)&&(p=b+1,h=x.kind==="space"?i-k:i);continue}let T=i+k;if(T>e+.005){if(w(x.kind)){i+=k,l=b+1,f=0,g(b+1,0,x.kind==="space"?i-k:i);continue}if(p>=0){g(p,0,h),b--;continue}if(k>e&&x.graphemeWidths){g(),_(b,0,x.graphemeWidths);continue}g(),b--;continue}i=T,l=b+1,f=0,w(x.kind)&&(p=b+1,h=x.kind==="space"?i-k:i)}return u&&g(),{lines:o,lineCount:o.length};function _(b,x,k){for(let T=x;T<k.length;T++){let E=k[T];if(!u){y(b,T,E);continue}i+E>e+.005?(g(),y(b,T,E)):(i+=E,l=b,f=T+1)}u&&l===b&&f===k.length&&(l=b+1,f=0)}}function Ce(r){return Math.max(0,Math.min(1,r))}function sr(r){let e=Ce(r?.mainRatio??.65),t=Ce(r?.sideSplit??.5),n=Math.max(0,r?.viewportWidth??1280),s=r?.nodeRegistry??new Map,o=r?.adapter??null,i=r?.layoutFont??"14px monospace",u=r?.onHighlight,a=new De("demo-shell"),d=J(e,{name:"pane/main-ratio"}),l=J(t,{name:"pane/side-split"}),f=J(null,{name:"pane/fullscreen"}),p=J(n,{name:"viewport/width"});a.add(d,{name:"pane/main-ratio"}),a.add(l,{name:"pane/side-split"}),a.add(f,{name:"pane/fullscreen"}),a.add(p,{name:"viewport/width"});let h=z([d,p,f],([O,D,R])=>{let Y=O,I=D,j=R;return j==="main"?I:j==="graph"||j==="code"?0:Math.round(I*Y)},{name:"pane/main-width"}),c=z([h,p,f],([O,D,R])=>{let Y=R,I=D;return Y==="main"?0:Y==="graph"||Y==="code"?I:I-O},{name:"pane/side-width"}),v=z([l,f],([O,D])=>{let R=D;return R==="graph"?1:R==="code"||R==="main"?0:Ce(O)},{name:"pane/graph-height-ratio"}),g=z([v,f],([O,D])=>{let R=D;return R==="code"?1:R==="graph"||R==="main"?0:1-O},{name:"pane/code-height-ratio"});a.add(h,{name:"pane/main-width"}),a.add(c,{name:"pane/side-width"}),a.add(v,{name:"pane/graph-height-ratio"}),a.add(g,{name:"pane/code-height-ratio"});let w=J(null,{name:"demo/graph-ref"}),m=J(0,{name:"demo/graph-tick"});a.add(w,{name:"demo/graph-ref"}),a.add(m,{name:"demo/graph-tick"});let y=z([w,m],([O,D])=>{let R=O;return R?ze(R.describe()):""},{name:"graph/mermaid"}),_=z([w,m],([O,D])=>{let R=O;if(!R)return null;let{expand:Y,...I}=R.describe({detail:"standard"});return I},{name:"graph/describe"});a.add(y,{name:"graph/mermaid"}),a.add(_,{name:"graph/describe"});let b=J(null,{name:"hover/target"});a.add(b,{name:"hover/target"});let x=z([b],([O])=>{let D=O;if(!D)return null;let R=s.get(D.id);return R?R.codeLine:null},{name:"highlight/code-scroll"}),k=z([b],([O])=>{let D=O;if(!D)return null;let R=s.get(D.id);return R?R.visualSelector:null},{name:"highlight/visual"}),T=z([b],([O])=>{let D=O;return D?D.id:null},{name:"highlight/graph"});if(a.add(x,{name:"highlight/code-scroll"}),a.add(k,{name:"highlight/visual"}),a.add(T,{name:"highlight/graph"}),u?.codeScroll){let O=u.codeScroll,D=Ve([x],([R])=>{O(R)});a.add(D,{name:"highlight/apply-code-scroll"})}if(u?.visual){let O=u.visual,D=Ve([k],([R])=>{O(R)});a.add(D,{name:"highlight/apply-visual"})}if(u?.graph){let O=u.graph,D=Ve([T],([R])=>{O(R)});a.add(D,{name:"highlight/apply-graph"})}let E=J(null,{name:"inspect/selected-node"});a.add(E,{name:"inspect/selected-node"});let A=Ee("standard"),S=z([E,w,m],([O,D,R])=>{let Y=D,I=O;if(!Y||!I)return null;try{let j=Y.resolve(I),V=Re(j,A);return{path:I,...V,value:j.cache}}catch{return null}},{name:"inspect/node-detail"}),$=z([w,m],([O,D])=>{let R=O;return R?R.trace():[]},{name:"inspect/trace-log"});a.add(S,{name:"inspect/node-detail"}),a.add($,{name:"inspect/trace-log"});let G=J(!1,{name:"meta/debug"});a.add(G,{name:"meta/debug"});let P=z([G,m],([O,D])=>O?ze(a.describe()):"",{name:"meta/shell-mermaid"});a.add(P,{name:"meta/shell-mermaid"});let ae=J("",{name:"layout/code-text"});if(a.add(ae,{name:"layout/code-text"}),o){let O=new Map,D=z([_],([I])=>{let j=I;if(!j)return new Map;let V=new Map;for(let[Q]of Object.entries(j.nodes)){let N=_t(Q,i,o,O),C=wt(N,1/0,o,i,O),U=C.lines.reduce((X,M)=>Math.max(X,M.width),0),le=C.lineCount*20;V.set(Q,{width:U,height:le})}return V},{name:"layout/graph-labels",equals:(I,j)=>{if(I===j)return!0;let V=I,Q=j;if(V.size!==Q.size)return!1;for(let[N,C]of V){let U=Q.get(N);if(!U||U.width!==C.width||U.height!==C.height)return!1}return!0}}),R=z([ae,c],([I,j])=>{let V=I;if(!V)return{lineCount:0,lines:[]};let Q=_t(V,i,o,O),N=j-40;return wt(Q,Math.max(100,N),o,i,O)},{name:"layout/code-lines"}),Y=z([D],([I])=>{let j=I;if(j.size===0)return 200;let V=0;for(let{width:Q}of j.values())Q>V&&(V=Q);return Math.max(200,Math.round(V+80))},{name:"layout/side-width-hint"});a.add(D,{name:"layout/graph-labels"}),a.add(R,{name:"layout/code-lines"}),a.add(Y,{name:"layout/side-width-hint"})}let xe=0;return{graph:a,setMainRatio(O){a.set("pane/main-ratio",Ce(O))},setSideSplit(O){a.set("pane/side-split",Ce(O))},setFullscreen(O){a.set("pane/fullscreen",O)},setViewportWidth(O){a.set("viewport/width",Math.max(0,O))},setHoverTarget(O){a.set("hover/target",O)},setDemoGraph(O){a.set("demo/graph-ref",O)},bumpGraphTick(){a.set("demo/graph-tick",++xe)},selectNode(O){a.set("inspect/selected-node",O)},setMetaDebug(O){a.set("meta/debug",O)},setCodeText(O){a.set("layout/code-text",O)},batch(O){Ge(O)},destroy(){a.destroy()}}}0&&(module.exports={demoShell});
1
+ "use strict";var nt=Object.defineProperty;var vn=Object.getOwnPropertyDescriptor;var wn=Object.getOwnPropertyNames;var _n=Object.prototype.hasOwnProperty;var j=(r,e)=>()=>(r&&(e=r(r=0)),e);var xn=(r,e)=>{for(var t in e)nt(r,t,{get:e[t],enumerable:!0})},kn=(r,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of wn(e))!_n.call(r,s)&&s!==t&&nt(r,s,{get:()=>e[s],enumerable:!(n=vn(e,s))||n.enumerable});return r};var Tn=r=>kn(nt({},"__esModule",{value:!0}),r);function Le(){return me>0||Oe}function Tt(){return me>0}function ye(r){me>0?Se.push(r):r()}function Ee(r){me+=1;let e=!1;try{r()}catch(t){throw e=!0,t}finally{if(me-=1,me===0)if(e){if(!Oe){let t=Se.splice(0);for(let n of t)try{n()}catch{}fe.length=0,pe.length=0,be.length=0}}else Nn()}}function Nn(){let r=!Oe;r&&(Oe=!0);let e=[],t=0;try{for(;fe.length>0||pe.length>0||be.length>0||r&&Se.length>0;){if(r&&Se.length>0){let o=Se.splice(0);for(let i of o)try{i()}catch(a){e.push(a)}continue}if(t+=1,t>1e3)throw fe.length=0,pe.length=0,be.length=0,new Error("batch drain exceeded 1000 iterations \u2014 likely a reactive cycle");let s=(fe.length>0?fe:pe.length>0?pe:be).splice(0);for(let o of s)try{o()}catch(i){e.push(i)}}}finally{r&&(Oe=!1)}if(e.length===1)throw e[0];if(e.length>1)throw new AggregateError(e,"batch drain: multiple callbacks threw")}function $e(r,e,t){if(e.length===0)return;if(e.length===1){let d=t(e[0][0]);if(d<3||!Le()){r(e);return}(d>=5?be:d===4?pe:fe).push(()=>r(e));return}let n=e.length,s=n,o=n,i=n,a=0;for(;a<n&&t(e[a][0])<3;)a++;for(s=a;a<n&&t(e[a][0])===3;)a++;for(o=a;a<n&&t(e[a][0])===4;)a++;i=a;let u=Le();if(s>0){let d=e.slice(0,s);r(d)}if(o>s){let d=e.slice(s,o);u?fe.push(()=>r(d)):r(d)}if(i>o){let d=e.slice(o,i);u?pe.push(()=>r(d)):r(d)}if(n>i){let d=e.slice(i,n);u?be.push(()=>r(d)):r(d)}}var me,Oe,fe,pe,be,Se,Fe=j(()=>{"use strict";me=0,Oe=!1,fe=[],pe=[],be=[],Se=[]});function rt(r){let e=On.filter(t=>r({type:t,id:""},"write"));return e.length===0?"restricted":e.includes("human")&&e.includes("llm")&&e.every(t=>t==="human"||t==="llm"||t==="system")?"both":e.length===1?e[0]:e.join("+")}var te,On,je=j(()=>{"use strict";te=class extends Error{actor;action;nodeName;constructor(e,t){super(t??`GuardDenied: action "${String(e.action)}" denied for actor type "${String(e.actor.type)}"`),this.name="GuardDenied",this.actor=e.actor,this.action=e.action,this.nodeName=e.nodeName}get node(){return this.nodeName}},On=["human","llm","wallet","system"]});function Ot(r,e){let t=new TextEncoder().encode(r.name);if(t.length===0||t.length>255)throw new Error(`encodeEnvelope: codec name "${r.name}" encodes to ${t.length} bytes (must be 1\u2013255)`);let n=r.version;if(!Number.isInteger(n)||n<0||n>65535)throw new Error(`encodeEnvelope: codec.version ${n} out of u16 range (expected integer 0\u201365535)`);let s=2+t.length+2+e.length;if(s>4294967295)throw new Error(`encodeEnvelope: total envelope size ${s} exceeds 2^32-1 bytes (payload ${e.length} bytes)`);let o=new Uint8Array(s),i=0;return o[i++]=st,o[i++]=t.length,o.set(t,i),i+=t.length,o[i++]=n>>>8&255,o[i++]=n&255,o.set(e,i),o}function St(r,e){if(r.length<Nt)throw new Error(`decodeEnvelope: bytes too short (${r.length} < ${Nt})`);let t=0,n=r[t++];if(n!==st)throw new Error(`decodeEnvelope: unsupported envelope version ${n} (expected ${st})`);let s=r[t++];if(s===0)throw new Error("decodeEnvelope: name_len must be >= 1");if(t+s+2>r.length)throw new Error(`decodeEnvelope: envelope truncated (need ${t+s+2} bytes, have ${r.length})`);let o=new TextDecoder().decode(r.subarray(t,t+s));t+=s;let i=(r[t]<<8|r[t+1])>>>0;t+=2;let a=r.subarray(t),u=e.lookupCodec(o);if(u==null)throw new Error(`decodeEnvelope: codec "${o}" not registered (envelope codec_v=${i})`);return{codec:u,codecVersion:i,payload:a}}function Et(r){r.registerCodec(Sn)}var Sn,st,Nt,ot=j(()=>{"use strict";Sn={name:"json",version:1,contentType:"application/json",encode(r){let e=JSON.stringify(r);return new TextEncoder().encode(e)},decode(r,e){let t=new TextDecoder().decode(r);return JSON.parse(t)}},st=1,Nt=4});function Be(r){if(r==null)return ve;let{type:e,id:t,...n}=r;return{type:e??"system",id:t??"",...n}}var ve,it=j(()=>{"use strict";ve={type:"system",id:""}});function ue(){return Math.trunc(performance.now()*1e6)}function He(){return Date.now()*1e6}var Ve=j(()=>{"use strict"});var we,K,ne,re,se,ie,de,q,J,I,_e,at,En,ut,Rn,An,dt,Rt,At,Dt,ct,Re=j(()=>{"use strict";we=Symbol.for("graphrefly/START"),K=Symbol.for("graphrefly/DATA"),ne=Symbol.for("graphrefly/DIRTY"),re=Symbol.for("graphrefly/RESOLVED"),se=Symbol.for("graphrefly/INVALIDATE"),ie=Symbol.for("graphrefly/PAUSE"),de=Symbol.for("graphrefly/RESUME"),q=Symbol.for("graphrefly/TEARDOWN"),J=Symbol.for("graphrefly/COMPLETE"),I=Symbol.for("graphrefly/ERROR"),_e=Object.freeze([ne]),at=Object.freeze([re]),En=Object.freeze([se]),ut=Object.freeze([we]),Rn=Object.freeze([J]),An=Object.freeze([q]),dt=Object.freeze([_e]),Rt=Object.freeze([at]),At=Object.freeze([En]),Dt=Object.freeze([Rn]),ct=Object.freeze([An])});function Ct(r){r.registerMessageType(we,{tier:0,wireCrossing:!1}),r.registerMessageType(ne,{tier:1,wireCrossing:!1}),r.registerMessageType(se,{tier:1,wireCrossing:!1,metaPassthrough:!1}),r.registerMessageType(ie,{tier:2,wireCrossing:!1}),r.registerMessageType(de,{tier:2,wireCrossing:!1}),r.registerMessageType(K,{tier:3,wireCrossing:!0}),r.registerMessageType(re,{tier:3,wireCrossing:!0}),r.registerMessageType(J,{tier:4,wireCrossing:!0,metaPassthrough:!1}),r.registerMessageType(I,{tier:4,wireCrossing:!0,metaPassthrough:!1}),r.registerMessageType(q,{tier:5,wireCrossing:!0,metaPassthrough:!1})}var We,Mt=j(()=>{"use strict";Re();We=class{_messageTypes=new Map;_codecs=new Map;_onMessage;_onSubscribe;_defaultVersioning;_defaultHashFn;_inspectorEnabled=!(typeof process<"u"&&process.env?.NODE_ENV==="production");_globalInspector;_rigorRecorder;_frozen=!1;tierOf;constructor(e){this._onMessage=e.onMessage,this._onSubscribe=e.onSubscribe,this._defaultVersioning=e.defaultVersioning,this._defaultHashFn=e.defaultHashFn,this.tierOf=t=>{let n=this._messageTypes.get(t);return n!=null?n.tier:1}}get onMessage(){return this._frozen=!0,this._onMessage}get onSubscribe(){return this._frozen=!0,this._onSubscribe}set onMessage(e){this._assertUnfrozen(),this._onMessage=e}set onSubscribe(e){this._assertUnfrozen(),this._onSubscribe=e}get defaultVersioning(){return this._defaultVersioning}set defaultVersioning(e){this._assertUnfrozen(),this._defaultVersioning=e}get defaultHashFn(){return this._defaultHashFn}set defaultHashFn(e){this._assertUnfrozen(),this._defaultHashFn=e}get inspectorEnabled(){return this._inspectorEnabled}set inspectorEnabled(e){this._inspectorEnabled=e}get globalInspector(){return this._globalInspector}set globalInspector(e){this._globalInspector=e}get rigorRecorder(){return this._rigorRecorder}set rigorRecorder(e){this._rigorRecorder=e}registerMessageType(e,t){return this._assertUnfrozen(),this._messageTypes.set(e,{tier:t.tier,wireCrossing:t.wireCrossing??t.tier>=3,metaPassthrough:t.metaPassthrough??!0}),this}messageTier(e){let t=this._messageTypes.get(e);return t!=null?t.tier:1}isWireCrossing(e){let t=this._messageTypes.get(e);return t!=null?t.wireCrossing:!0}isLocalOnly(e){return!this.isWireCrossing(e)}isMetaPassthrough(e){let t=this._messageTypes.get(e);return t!=null?t.metaPassthrough:!0}isKnownMessageType(e){return this._messageTypes.has(e)}registerCodec(e){return this._assertUnfrozen(),this._codecs.set(e.name,e),this}lookupCodec(e){return this._codecs.get(e)}_isFrozen(){return this._frozen}_assertUnfrozen(){if(this._frozen)throw new Error("GraphReFlyConfig is frozen: a node has already captured this config. Register custom types and set hooks before creating any node.")}}});function lt(r){if(r===void 0)return null;if(typeof r=="number"){if(!Number.isFinite(r))throw new TypeError(`Cannot hash non-finite number: ${r}`);if(Number.isInteger(r)&&!Number.isSafeInteger(r))throw new TypeError(`Cannot hash integer outside safe range (|n| > 2^53-1): ${r}. Cross-language cid parity is not guaranteed for unsafe integers.`);return r}if(typeof r=="string"||typeof r=="boolean"||r===null)return r;if(Array.isArray(r))return r.map(lt);if(typeof r=="object"&&r!==null){let e={};for(let t of Object.keys(r).sort())e[t]=lt(r[t]);return e}return null}function Mn(r){let e=Cn.encode(r),t=e.length,n=t*8,s=t+9+63&-64,o=new Uint8Array(s);o.set(e),o[t]=128;let i=new DataView(o.buffer);i.setUint32(s-4,n>>>0,!1),i.setUint32(s-8,Math.floor(n/4294967296)>>>0,!1);let a=1779033703,u=3144134277,d=1013904242,c=2773480762,f=1359893119,p=2600822924,h=528734635,l=1541459225,v=new Uint32Array(64),g=(m,y)=>m>>>y|m<<32-y;for(let m=0;m<s;m+=64){for(let S=0;S<16;S++)v[S]=i.getUint32(m+S*4,!1);for(let S=16;S<64;S++){let F=v[S-15],G=v[S-2],P=g(F,7)^g(F,18)^F>>>3,ae=g(G,17)^g(G,19)^G>>>10;v[S]=v[S-16]+P+v[S-7]+ae>>>0}let y=a,w=u,b=d,x=c,k=f,T=p,E=h,A=l;for(let S=0;S<64;S++){let F=g(k,6)^g(k,11)^g(k,25),G=k&T^~k&E,P=A+F+G+Dn[S]+v[S]>>>0,ae=g(y,2)^g(y,13)^g(y,22),Ne=y&w^y&b^w&b,N=ae+Ne>>>0;A=E,E=T,T=k,k=x+P>>>0,x=b,b=w,w=y,y=P+N>>>0}a=a+y>>>0,u=u+w>>>0,d=d+b>>>0,c=c+x>>>0,f=f+k>>>0,p=p+T>>>0,h=h+E>>>0,l=l+A>>>0}let _=m=>m.toString(16).padStart(8,"0");return _(a)+_(u)+_(d)+_(c)+_(f)+_(p)+_(h)+_(l)}function ft(r){let e=lt(r??null),t=JSON.stringify(e);return Mn(t).slice(0,16)}function Gn(){let r=globalThis.crypto;if(r?.randomUUID)return r.randomUUID();let e=()=>Math.floor(Math.random()*4294967296).toString(16).padStart(8,"0"),t=e()+e()+e()+e();return`${t.slice(0,8)}-${t.slice(8,12)}-4${t.slice(13,16)}-${(parseInt(t.slice(16,17),16)&3|8).toString(16)}${t.slice(17,20)}-${t.slice(20,32)}`}function pt(r,e,t){let n=t?.id??Gn();if(r===0)return{id:n,version:0};let o=(t?.hash??ft)(e);return{id:n,version:0,cid:o,prev:null}}function Gt(r,e,t){r.version+=1,"cid"in r&&(r.prev=r.cid,r.cid=t(e))}var Dn,Cn,Pt=j(()=>{"use strict";Dn=new Uint32Array([1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278,1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815,2227730452,2361852424,2428436474,2756734187,3204031479,3329325298]),Cn=new TextEncoder});function $t(r){return{node:r,unsub:null,prevData:void 0,dirty:!1,involvedThisWave:!1,dataBatch:[],terminal:void 0}}function ht(r){r.prevData=void 0,r.dirty=!1,r.involvedThisWave=!1,r.dataBatch.length=0,r.terminal=void 0}function ze(r){return r.length===0?r:typeof r[0]=="symbol"?[r]:r}function Ae(r,e,t){let n=Ft(r)?r:[],s=typeof r=="function"?r:typeof e=="function"?e:void 0,o={};return Ft(r)?o=(gt(e)?e:t)??{}:gt(r)?o=r:o=(gt(e)?e:t)??{},new H(n,s,o)}var It,Lt,Pn,In,xe,H,Ft,gt,De=j(()=>{"use strict";ot();it();Fe();Ve();Mt();je();Re();Pt();It=()=>{},Lt=100;Pn=(r,e,t,n)=>{t.direction==="down-in"&&r._onDepMessage(t.depIndex,e)},In=(r,e,t,n)=>{let s=r;if(s._status==="completed"||s._status==="errored")return;let o=s._cached,i=o===void 0?[ut]:[ut,[K,o]];s._status==="dirty"&&i.push(_e),$e(e,i,s._config.tierOf)},xe=new We({onMessage:Pn,onSubscribe:In});Ct(xe);Et(xe);H=class r{_optsName;_describeKind;meta;_hasMeta;_config;_deps;_sinks=null;_sinkCount=0;_cached;_status;_cleanup;_store={};_waveHasNewData=!1;_hasNewTerminal=!1;_hasCalledFnOnce=!1;_paused=!1;_pendingWave=!1;_isExecutingFn=!1;_pendingRerun=!1;_rerunDepth=0;_dirtyDepCount=0;_batchPendingMessages=null;_pauseLocks=null;_pauseBuffer=null;_fn;_equals;_resubscribable;_resetOnTeardown;_autoComplete;_autoError;_pausable;_partial;_guard;_extraGuards;_hashFn;_versioning;_versioningLevel;_lastMutation;_inspectorHooks;_actions;constructor(e,t,n){this._config=n.config??xe,this._config.onMessage,this._optsName=n.name,this._describeKind=n.describeKind,this._equals=n.equals??Object.is,this._resubscribable=n.resubscribable??!1,this._resetOnTeardown=n.resetOnTeardown??!1,this._autoComplete=n.completeWhenDepsComplete??!0,this._autoError=n.errorWhenDepsError??!0,this._pausable=n.pausable??!0,this._guard=n.guard,this._fn=t,this._partial=n.partial??!1,this._cached=n.initial!==void 0?n.initial:void 0,this._status=e.length===0&&t==null&&this._cached!==void 0?"settled":"sentinel",this._hashFn=n.versioningHash??this._config.defaultHashFn??ft;let s=n.versioning??this._config.defaultVersioning;this._versioningLevel=s,this._versioning=s!=null?pt(s,this._cached===void 0?void 0:this._cached,{id:n.versioningId,hash:this._hashFn}):void 0,this._deps=e.map($t);let o={};for(let[a,u]of Object.entries(n.meta??{})){let d={initial:u,name:`${n.name??"node"}:meta:${a}`,describeKind:"state",config:this._config};n.guard!=null&&(d.guard=n.guard),n.resubscribable===!0&&(d.resubscribable=!0),o[a]=new r([],void 0,d)}Object.freeze(o),this.meta=o,this._hasMeta=Object.keys(o).length>0;let i=this;this._actions={emit(a){i._emit([[K,a]])},down(a){i._emit(ze(a))},up(a){i._emitUp(ze(a))}},this.down=this.down.bind(this),this.up=this.up.bind(this)}get _isTerminal(){return this._status==="completed"||this._status==="errored"}get name(){return this._optsName}get status(){return this._status}get cache(){return this._cached===void 0?void 0:this._cached}get lastMutation(){return this._lastMutation}get v(){return this._versioning}hasGuard(){return this._guard!=null}_applyVersioning(e,t){if(this._isExecutingFn)throw new Error(`Node "${this.name}": _applyVersioning cannot run mid-fn \u2014 call it outside of \`_execFn\` (typically at graph setup time before the first subscribe).`);let n=this._versioningLevel;if(n!=null&&e<=n)return;let s=t?.hash??this._hashFn;s!==this._hashFn&&(this._hashFn=s);let o=this._cached===void 0?void 0:this._cached,i=this._versioning,a=i?.id??t?.id,u=i?.version??0,d=pt(e,o,{id:a,hash:s});d.version=u,this._versioning=d,this._versioningLevel=e}_setInspectorHook(e){return e==null?()=>{}:(this._inspectorHooks==null&&(this._inspectorHooks=new Set),this._inspectorHooks.add(e),()=>{this._inspectorHooks?.delete(e),this._inspectorHooks?.size===0&&(this._inspectorHooks=void 0)})}_pushGuard(e){return this._extraGuards==null&&(this._extraGuards=new Set),this._extraGuards.add(e),()=>{this._extraGuards?.delete(e),this._extraGuards?.size===0&&(this._extraGuards=void 0)}}allowsObserve(e){if(this._guard==null&&this._extraGuards==null)return!0;let t=Be(e);if(this._guard!=null&&!this._guard(t,"observe"))return!1;if(this._extraGuards!=null){for(let n of this._extraGuards)if(!n(t,"observe"))return!1}return!0}_checkGuard(e){if(e?.internal)return;let t=this._guard!=null||this._extraGuards!=null,n=e?.actor!=null;if(!t&&!n)return;let s=Be(e?.actor),o=e?.delivery==="signal"?"signal":"write";if(this._guard!=null&&!this._guard(s,o))throw new te({actor:s,action:o,nodeName:this.name});if(this._extraGuards!=null){for(let i of this._extraGuards)if(!i(s,o))throw new te({actor:s,action:o,nodeName:this.name})}this._lastMutation={actor:s,timestamp_ns:He()}}down(e,t){let n=ze(e);n.length!==0&&(this._checkGuard(t),this._emit(n))}emit(e,t){this._checkGuard(t),this._emit([[K,e]])}up(e,t){if(this._deps.length===0)return;let n=ze(e);if(n.length===0)return;this._checkGuard(t);let s=t??{internal:!0};this._validateUpTiers(n);for(let o of this._deps)o.node.up?.(n,s)}_emitUp(e){if(this._deps.length!==0&&e.length!==0){this._validateUpTiers(e);for(let t of this._deps)t.node.up?.(e,{internal:!0})}}_validateUpTiers(e){let t=this._config.tierOf;for(let n of e){let s=t(n[0]);if(s===3||s===4)throw new Error(`Node "${this.name}": tier-${s} messages cannot flow up \u2014 DATA/RESOLVED/COMPLETE/ERROR are downstream-only. Use \`down(...)\` for value delivery; \`up(...)\` is for control signals (DIRTY, INVALIDATE, PAUSE, RESUME, TEARDOWN).`)}}subscribe(e,t){if(t!=null&&this._guard!=null){let u=Be(t);if(!this._guard(u,"observe"))throw new te({actor:u,action:"observe",nodeName:this.name})}let s=this._isTerminal&&this._resubscribable;if(s){this._cached=void 0,this._status="sentinel",this._store={},this._hasCalledFnOnce=!1,this._waveHasNewData=!1,this._hasNewTerminal=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._isExecutingFn=!1,this._rerunDepth=0,this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null;for(let u of this._deps)ht(u);if(this._partial===!1){for(let u of this._deps)if(u.prevData!==void 0||u.dataBatch.length!==0||u.terminal!==void 0||u.dirty)throw new Error(`resubscribable-reset invariant: DepRecord not fully reset for node ${this._optsName??"(anonymous)"}`)}}this._sinkCount+=1;let o;try{o=this._config.onSubscribe(this,e,{sinkCount:this._sinkCount,afterTerminalReset:s},this._actions)}catch(u){throw this._sinkCount-=1,u}this._sinks==null?this._sinks=e:typeof this._sinks=="function"?this._sinks=new Set([this._sinks,e]):this._sinks.add(e);let i=this._isTerminal;if(this._sinkCount===1&&!i)try{this._activate()}catch(u){if(this._sinkCount-=1,this._removeSink(e),this._sinkCount===0&&(this._status="sentinel"),typeof o=="function")try{o()}catch{}throw u}this._status==="sentinel"&&this._cached===void 0&&(this._status="pending");let a=!1;return()=>{a||(a=!0,this._sinkCount-=1,this._removeSink(e),typeof o=="function"&&o(),this._sinks==null&&this._deactivate())}}_removeSink(e){if(this._sinks===e)this._sinks=null;else if(this._sinks!=null&&typeof this._sinks!="function")if(this._sinks.delete(e),this._sinks.size===1){let[t]=this._sinks;this._sinks=t}else this._sinks.size===0&&(this._sinks=null)}_activate(){if(this._deps.length===0){this._fn&&this._execFn();return}this._dirtyDepCount=0;let e=this._deps.length,t=0;try{for(let n=0;n<e;n++){let s=n,o=this._deps[n];o.unsub=It,o.unsub=o.node.subscribe(i=>{if(o.unsub===null)return;let a=this._config.tierOf,u=!1;for(let d of i)a(d[0])>=3&&(u=!0),this._config.onMessage(this,d,{direction:"down-in",depIndex:s},this._actions);u&&this._maybeRunFnOnSettlement()}),t++}}catch(n){this._deps[t].unsub=null;for(let s=0;s<t;s++){let o=this._deps[s];if(o.unsub!=null){let i=o.unsub;o.unsub=null;try{i()}catch{}ht(o)}}throw this._dirtyDepCount=0,n}}_addDep(e){for(let s=0;s<this._deps.length;s++)if(this._deps[s].node===e)return s;let t=this._deps.length,n=$t(e);if(this._deps.push(n),this._sinks==null)return t;n.dirty=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(dt),n.unsub=It;try{n.unsub=e.subscribe(s=>{if(n.unsub===null)return;let o=this._config.tierOf,i=!1;for(let a of s)o(a[0])>=3&&(i=!0),this._config.onMessage(this,a,{direction:"down-in",depIndex:t},this._actions);i&&this._maybeRunFnOnSettlement()})}catch(s){throw n.unsub=null,this._deps.pop(),this._dirtyDepCount--,s}return t}_deactivate(e=!1){let t=this._cleanup;if(this._cleanup=void 0,typeof t=="function")try{t()}catch(n){this._emit([[I,this._wrapFnError("cleanup threw",n)]])}else if(t!=null&&typeof t=="object"){let n=t.deactivate;if(typeof n=="function")try{n()}catch(s){this._emit([[I,this._wrapFnError("cleanup.deactivate threw",s)]])}}for(let n of this._deps){if(n.unsub!=null){let s=n.unsub;n.unsub=null;try{s()}catch{}}ht(n)}this._waveHasNewData=!1,this._hasNewTerminal=!1,this._hasCalledFnOnce=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._rerunDepth=0,this._store={},this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null,this._fn!=null&&(this._cached=void 0),e||(this._fn!=null||this._deps.length>0)&&(!this._isTerminal||this._resubscribable)&&(this._status="sentinel")}_onDepMessage(e,t){let n=this._deps[e],s=t[0];if(this._inspectorHooks!=null){let o={kind:"dep_message",depIndex:e,message:t};for(let i of this._inspectorHooks)i(o)}if(s!==we){if(s===ne){this._depDirtied(n);return}if(s===se){if(this._depInvalidated(n),this._cached===void 0)return;this._emit(At);return}if(s===ie||s===de){this._emit([t]);return}if(s===q){this._emit(ct);return}if(s===K)this._depSettledAsData(n,t[1]);else if(s===re)this._depSettledAsResolved(n);else if(s===J)this._depSettledAsTerminal(n,!0);else if(s===I)this._depSettledAsTerminal(n,t[1]);else{this._emit([t]);return}if(!this._fn){(s===K||s===re)&&this._emit([t]),(s===J||s===I)&&this._maybeAutoTerminalAfterWave();return}}}_depDirtied(e){e.dirty||(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(dt))}_depSettledAsData(e,t){e.dirty&&(e.dirty=!1,this._dirtyDepCount--),e.involvedThisWave=!0,e.dataBatch.push(t),this._waveHasNewData=!0}_depSettledAsResolved(e){e.dirty&&(e.dirty=!1,this._dirtyDepCount--)}_depSettledAsTerminal(e,t){e.dirty&&(e.dirty=!1,this._dirtyDepCount--),e.terminal=t,e.involvedThisWave=!0,this._hasNewTerminal=!0}_depInvalidated(e){e.prevData=void 0,e.terminal=void 0,e.dataBatch.length=0,e.dirty?e.involvedThisWave=!1:(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++)}_maybeRunFnOnSettlement(){if(!(this._isTerminal&&!this._resubscribable)&&!(this._dirtyDepCount>0)){if(!this._partial&&!this._hasCalledFnOnce)for(let e=0;e<this._deps.length;e++){let t=this._deps[e];if(t.dataBatch.length===0&&t.prevData===void 0&&t.terminal===void 0){this._maybeAutoTerminalAfterWave();return}}if(this._paused){this._pendingWave=!0;return}if(!this._waveHasNewData&&!this._hasNewTerminal&&this._hasCalledFnOnce){this._clearWaveFlags(),this._emit(Rt),this._maybeAutoTerminalAfterWave();return}this._fn&&this._execFn(),this._maybeAutoTerminalAfterWave()}}_maybeAutoTerminalAfterWave(){if(this._deps.length===0||this._isTerminal)return;let e=this._deps.find(t=>t.terminal!==void 0&&t.terminal!==!0);if(e!=null){this._autoError&&this._emit([[I,e.terminal]]);return}this._autoComplete&&this._deps.every(t=>t.terminal!==void 0)&&this._emit(Dt)}_execFn(){if(!this._fn||this._isTerminal&&!this._resubscribable)return;if(this._isExecutingFn){this._pendingRerun=!0;return}let e=this._cleanup;if(typeof e=="function"){this._cleanup=void 0;try{e()}catch(i){this._emit([[I,this._wrapFnError("cleanup threw",i)]]);return}}else if(e!=null&&typeof e=="object"){let i=e.beforeRun;if(typeof i=="function"){e.beforeRun=void 0;try{i()}catch(a){this._emit([[I,this._wrapFnError("cleanup.beforeRun threw",a)]]);return}}}let t=this._deps.map(i=>i.involvedThisWave?i.dataBatch.length>0?[...i.dataBatch]:[]:void 0),n=this._deps.map(i=>i.prevData);for(let i=0;i<this._deps.length;i++){let a=t[i];a!=null&&a.length>0&&(this._deps[i].prevData=a[a.length-1])}let s=this._deps.map(i=>i.terminal),o={prevData:n,terminalDeps:s,store:this._store};if(this._hasCalledFnOnce=!0,this._clearWaveFlags(),this._inspectorHooks!=null){let i={kind:"run",batchData:t,prevData:n};for(let a of this._inspectorHooks)a(i)}this._isExecutingFn=!0;try{let i=this._fn(t,this._actions,o);if(typeof i=="function")this._cleanup=i;else if(i!=null&&typeof i=="object"){let a=i;(typeof a.beforeRun=="function"||typeof a.deactivate=="function"||typeof a.invalidate=="function")&&(this._cleanup=i)}}catch(i){this._emit([[I,this._wrapFnError("fn threw",i)]])}finally{this._isExecutingFn=!1,this._pendingRerun?(this._pendingRerun=!1,this._rerunDepth+=1,this._rerunDepth>Lt?(this._rerunDepth=0,this._emit([[I,new Error(`Node "${this.name}": _pendingRerun depth exceeded ${Lt} \u2014 likely a reactive cycle`)]])):this._maybeRunFnOnSettlement()):this._rerunDepth=0,this._clearWaveFlags()}}_clearWaveFlags(){this._waveHasNewData=!1,this._hasNewTerminal=!1;for(let e of this._deps)e.involvedThisWave=!1,e.dataBatch.length=0}_wrapFnError(e,t){let n=t instanceof Error?t.message:String(t);return new Error(`Node "${this.name}": ${e}: ${n}`,{cause:t})}_frameBatch(e){let t=this._config.tierOf;if(e.length===1)return t(e[0][0])===3&&this._status!=="dirty"?[_e,e[0]]:e;let n=!0,s=!1,o=!1,i=-1;for(let u of e){let d=t(u[0]);d<i&&(n=!1),d===3&&(s=!0),u[0]===ne&&(o=!0),i=d}let a=e;if(!n){let u=e.map((d,c)=>({m:d,i:c,tier:t(d[0])}));u.sort((d,c)=>d.tier-c.tier||d.i-c.i),a=u.map(d=>d.m)}if(s&&!o&&this._status!=="dirty"){let u=0;for(;u<a.length&&t(a[u][0])===0;)u++;return u===0?[_e,...a]:[...a.slice(0,u),_e,...a.slice(u)]}return a}_emit(e){if(e.length===0)return;for(let a=0;a<e.length;a++){let u=e[a];if(u[0]===I&&u[1]===void 0)throw new TypeError('[ERROR, payload] requires a non-undefined payload (spec \xA71.2). Pass an Error object or domain tag instead \u2014 e.g. node.down([[ERROR, new Error("reason")]])')}let t=e;if(this._isTerminal&&!this._resubscribable){let a=e.filter(u=>u[0]===q||u[0]===se);if(a.length===0)return;t=a}t=this._frameBatch(t);let s=null;for(let a=0;a<t.length;a++){let u=t[a],d=u[0];if(d!==ie&&d!==de){s?.push(u);continue}if(u.length<2)throw new Error(`Node "${this.name}": [[${d===ie?"PAUSE":"RESUME"}]] must carry a lockId payload \u2014 bare PAUSE/RESUME is a protocol violation (C0 rule). Use \`[[PAUSE, lockId]]\` / \`[[RESUME, lockId]]\`.`);let c=!0;if(this._pausable!==!1){let f=u[1];if(d===ie)this._pauseLocks==null&&(this._pauseLocks=new Set),this._pauseLocks.add(f),this._paused=!0,this._pausable==="resumeAll"&&this._pauseBuffer==null&&(this._pauseBuffer=[]);else if(this._pauseLocks==null||!this._pauseLocks.has(f))c=!1;else if(this._pauseLocks.delete(f),this._pauseLocks.size===0){if(this._paused=!1,this._pauseBuffer!=null&&this._pauseBuffer.length>0){let p=this._pauseBuffer;this._pauseBuffer=[],this._emit(p)}this._pendingWave&&(this._pendingWave=!1,this._maybeRunFnOnSettlement())}}c?s?.push(u):s==null&&(s=t.slice(0,a))}if(s!=null){if(s.length===0)return;t=s}if(this._hasMeta&&t.some(a=>a[0]===q))for(let a of Object.keys(this.meta))try{this.meta[a]._emit(ct)}catch{}let{finalMessages:o,equalsError:i}=this._updateState(t);if(o.length>0&&this._config.inspectorEnabled){let a=this._config.globalInspector;if(a!=null)try{a({kind:"emit",node:this,messages:o})}catch{}}if(o.length>0)if(this._paused&&this._pausable==="resumeAll"&&this._pauseBuffer!=null){let a=this._config.tierOf,u=[];for(let d of o)a(d[0])===3?this._pauseBuffer.push(d):u.push(d);u.length>0&&this._dispatchOrAccumulate(u)}else this._dispatchOrAccumulate(o);i!=null&&this._emit([[I,i]])}_updateState(e){let t=this._config.tierOf,n,s,o=-1,i=0;for(let c of e)t(c[0])===3&&i++;let a=i<=1,u=-1;if(this._versioning!=null&&i>1){for(let c=e.length-1;c>=0;c--)if(e[c][0]===K){u=c;break}}for(let c=0;c<e.length;c++){let f=e[c],p=f[0];if(p===K){if(f.length>=2){let h=!1;if(a&&this._cached!==void 0)try{h=this._equals(this._cached,f[1])}catch(l){s=this._wrapFnError("equals threw",l),o=c;break}if(h){n==null&&(n=e.slice(0,c)),n.push(at),this._status="resolved";continue}this._cached=f[1],this._versioning!=null&&(u<0||c===u)&&Gt(this._versioning,f[1],this._hashFn)}this._status="settled",n?.push(f)}else if(n?.push(f),p===ne)this._status="dirty";else if(p===re)this._status="resolved";else if(p===J){this._status="completed";{let h=this._config.rigorRecorder;if(h!=null)try{h.onTerminalTransition(this,"completed",this._autoComplete,this._autoError,this._deps.length>0)}catch{}}}else if(p===I){this._status="errored";{let h=this._config.rigorRecorder;if(h!=null)try{h.onTerminalTransition(this,"errored",this._autoComplete,this._autoError,this._deps.length>0)}catch{}}}else if(p===se){if(this._cached!==void 0){let l=this._config.rigorRecorder;if(l!=null)try{l.onNonVacuousInvalidate(this,this._cached)}catch{}}this._cached=void 0,this._status="dirty";let h=this._cleanup;if(typeof h=="function"){this._cleanup=void 0;try{h()}catch{}}else if(h!=null&&typeof h=="object"){let l=h.invalidate;if(typeof l=="function")try{l()}catch{}}}else p===q&&(this._resetOnTeardown&&(this._cached=void 0),this._deactivate(!0),this._status="sentinel")}let d=o>=0?n??e.slice(0,o):n??e;return s!=null?{finalMessages:d,equalsError:s}:{finalMessages:d}}_deliverToSinks=e=>{if(this._sinks==null)return;if(typeof this._sinks=="function"){this._sinks(e);return}let t=[...this._sinks];for(let n of t)n(e)};_dispatchOrAccumulate(e){if(Tt()){this._batchPendingMessages===null&&(this._batchPendingMessages=[],ye(()=>this._flushBatchPending()));for(let t of e)this._batchPendingMessages.push(t);return}$e(this._deliverToSinks,e,this._config.tierOf)}_flushBatchPending(){let e=this._batchPendingMessages;if(e===null||(this._batchPendingMessages=null,e.length===0))return;let t=this._frameBatch(e);$e(this._deliverToSinks,t,this._config.tierOf)}},Ft=r=>Array.isArray(r),gt=r=>typeof r=="object"&&r!=null&&!Array.isArray(r)});function Ce(r,e){if(e!=null&&e.length>0)return new Set(e);switch(r){case"standard":return new Set(["type","status","value","deps","meta","v"]);case"full":return null;case"spec":return new Set(["type","deps","meta","value"]);default:return new Set(["type","deps"])}}function Ln(r){return r._describeKind!=null?r._describeKind:r._deps.length>0?"derived":r._fn!=null?"producer":"state"}function $n(r){let e={};for(let[t,n]of Object.entries(r.meta))try{e[t]=n.cache}catch{}return e}function Me(r,e,t){let n=e==null,s=!n&&e!=null?[...e].filter(c=>c.startsWith("meta.")).map(c=>c.slice(5)):null,o=n||e.has("meta")||s!=null&&s.length>0,i="state",a=[];r instanceof H&&(i=Ln(r),a=r._deps.map(c=>c.node.name??""));let u={type:i,deps:a};(n||e.has("status"))&&(u.status=r.status);let d=r instanceof H?r._guard:void 0;if(o){let c={...$n(r)};if(d!=null&&c.access===void 0&&(c.access=rt(d)),s!=null&&s.length>0&&!e.has("meta")){let f={};for(let p of s)p in c&&(f[p]=c[p]);u.meta=f}else u.meta=c}if(r.name!=null&&(u.name=r.name),(n||e.has("value"))&&(!t||i==="state")){r.status==="sentinel"&&(u.sentinel=!0);try{u.value=r.cache}catch{}}if((n||e.has("v"))&&r.v!=null){let c={id:r.v.id,version:r.v.version};"cid"in r.v&&(c.cid=r.v.cid,c.prev=r.v.prev),u.v=c}return(n||e.has("guard"))&&d!=null&&(u.guard=rt(d)),(n||e.has("lastMutation"))&&r.lastMutation!=null&&(u.lastMutation=r.lastMutation),u}var mt=j(()=>{"use strict";je();De()});function Y(r,e){return Ae([],{...e,initial:r})}function he(r,e){return Ae((n,s,o)=>r(s,o)??void 0,{describeKind:"producer",...e})}function V(r,e,t){return Ae(r,(s,o,i)=>{let a=s.map((u,d)=>u!=null&&u.length>0?u.at(-1):i.prevData[d]);o.emit(e(a,i))},{describeKind:"derived",...t})}function ke(r,e,t){return Ae(r,(s,o,i)=>{let a=s.map((u,d)=>u!=null&&u.length>0?u.at(-1):i.prevData[d]);return e(a,o,i)??void 0},{describeKind:"effect",...t})}var Ue=j(()=>{"use strict";De()});function jt(r){return r.replaceAll("\\","\\\\").replaceAll('"','\\"')}function Bt(r){let e=new Set,t=[];function n(s,o){let i=`${s}\0${o}`;e.has(i)||(e.add(i),t.push([s,o]))}for(let[s,o]of Object.entries(r.nodes)){let i=o.deps;if(i)for(let a of i)n(a,s)}for(let s of r.edges)n(s.from,s.to);return t}function Ht(r){if(r===void 0)return"LR";if(r==="TD"||r==="LR"||r==="BT"||r==="RL")return r;throw new Error(`invalid diagram direction ${String(r)}; expected one of: TD, LR, BT, RL`)}var Vt=j(()=>{"use strict"});function Ke(r,e){let t=Ht(e?.direction),n=Object.keys(r.nodes).sort(),s=new Map;for(let i=0;i<n.length;i+=1)s.set(n[i],`n${i}`);let o=[`flowchart ${t}`];for(let i of n){let a=s.get(i);o.push(` ${a}["${jt(i)}"]`)}for(let[i,a]of Bt(r)){let u=s.get(i),d=s.get(a);!u||!d||o.push(` ${u} --> ${d}`)}return o.join(`
2
+ `)}var Wt=j(()=>{"use strict";Vt()});var zt=j(()=>{"use strict";Wt()});function bt(r,e){if(Object.is(r,e))return!0;if(r==null||e==null||typeof r!="object"||typeof e!="object")return!1;if(Array.isArray(r)){if(!Array.isArray(e)||r.length!==e.length)return!1;for(let o=0;o<r.length;o++)if(!bt(r[o],e[o]))return!1;return!0}if(Array.isArray(e))return!1;let t=Object.keys(r),n=Object.keys(e);if(t.length!==n.length)return!1;let s=new Set(n);for(let o of t)if(!s.has(o)||!bt(r[o],e[o]))return!1;return!0}function Ut(r,e){return`${r}\0${e}`}function yt(r,e){let t=[],n=new Set(r.subgraphs),s=new Set(e.subgraphs),o=[];for(let g of s)n.has(g)||o.push(g);o.sort();for(let g of o)t.push({type:"subgraph-mounted",path:g});let i=new Set(Object.keys(r.nodes)),a=new Set(Object.keys(e.nodes)),u=[];for(let g of a)i.has(g)||u.push(g);u.sort();for(let g of u)t.push({type:"node-added",path:g,node:{...e.nodes[g]}});let d=[];for(let g of a){if(!i.has(g))continue;let _=r.nodes[g]?.meta,m=e.nodes[g]?.meta;_==null&&m==null||bt(_??{},m??{})||d.push(g)}d.sort();for(let g of d)t.push({type:"node-meta-changed",path:g,prevMeta:r.nodes[g]?.meta??{},nextMeta:e.nodes[g]?.meta??{}});let c=new Map;for(let g of r.edges)c.set(Ut(g.from,g.to),g);let f=new Map;for(let g of e.edges)f.set(Ut(g.from,g.to),g);let p=[];for(let[g,_]of f)c.has(g)||p.push(_);p.sort((g,_)=>g.from<_.from?-1:g.from>_.from?1:g.to<_.to?-1:g.to>_.to?1:0);for(let g of p)t.push({type:"edge-added",from:g.from,to:g.to});let h=[];for(let[g,_]of c)f.has(g)||h.push(_);h.sort((g,_)=>g.from<_.from?-1:g.from>_.from?1:g.to<_.to?-1:g.to>_.to?1:0);for(let g of h)t.push({type:"edge-removed",from:g.from,to:g.to});let l=[];for(let g of i)a.has(g)||l.push(g);l.sort();for(let g of l)t.push({type:"node-removed",path:g});let v=[];for(let g of n)s.has(g)||v.push(g);v.sort();for(let g of v)t.push({type:"subgraph-unmounted",path:g});return{events:t,flushedAt_ns:ue()}}var Kt=j(()=>{"use strict";Ve()});function vt(r){return{describeKind:"producer",...r}}function qt(r,e){return he(t=>{let n=!1;try{for(let s of r){if(n)return;t.emit(s)}n||t.down([[J]])}catch(s){n||t.down([[I,s]])}return()=>{n=!0}},vt(e))}function Fn(r){return r!=null&&typeof r.then=="function"}function jn(r,e){let{signal:t,...n}=e??{};return he(s=>{let o=!1,i=()=>{o||(o=!0,s.down([[I,t.reason]]))};if(t?.aborted){i();return}return t?.addEventListener("abort",i,{once:!0}),Promise.resolve(r).then(a=>{o||(o=!0,t?.removeEventListener("abort",i),s.emit(a),s.down([[J]]))},a=>{o||(o=!0,t?.removeEventListener("abort",i),s.down([[I,a]]))}),()=>{o=!0,t?.removeEventListener("abort",i)}},vt(n))}function Bn(r,e){let{signal:t,...n}=e??{};return he(s=>{let o=new AbortController,i=()=>o.abort(t?.reason);t?.aborted?o.abort(t.reason):t?.addEventListener("abort",i,{once:!0});let a=t??o.signal,u=!1,d=r[Symbol.asyncIterator](),c=()=>{u||a.aborted||Promise.resolve(d.next()).then(f=>{if(!(u||a.aborted)){if(f.done){s.down([[J]]);return}s.emit(f.value),c()}},f=>{!u&&!a.aborted&&s.down([[I,f]])})};return c(),()=>{u=!0,t?.removeEventListener("abort",i),o.abort(),Promise.resolve(d.return?.()).catch(()=>{})}},vt(n))}function Hn(r){return r!=null&&typeof r=="object"&&"cache"in r&&typeof r.subscribe=="function"}function Jt(r,e){if(Hn(r))return r;if(Fn(r))return jn(r,e);if(r!=null){let t=r;if(typeof t[Symbol.asyncIterator]=="function")return Bn(r,e);if(typeof t[Symbol.iterator]=="function")return qt(r,e)}return Vn(r)}function Vn(...r){return qt(r,void 0)}function qe(r){return r.subscribe(()=>{})}var Yt=j(()=>{"use strict";Re();Ue()});var Xt=j(()=>{"use strict";Yt()});var Je,Zt=j(()=>{"use strict";Je=class{_timer;_gen=0;start(e,t){this.cancel(),this._gen+=1;let n=this._gen;this._timer=setTimeout(()=>{this._timer=void 0,n===this._gen&&t()},e)}cancel(){this._timer!==void 0&&(clearTimeout(this._timer),this._timer=void 0)}get pending(){return this._timer!==void 0}}});var Ge,Qt=j(()=>{"use strict";Ge=class{constructor(e){this.capacity=e;if(!Number.isInteger(e)||e<=0)throw new Error(`RingBuffer capacity must be a positive integer (got ${e})`);this.buf=new Array(e)}buf;head=0;_size=0;get size(){return this._size}get maxSize(){return this.capacity}push(e){let t=(this.head+this._size)%this.capacity;this.buf[t]=e,this._size<this.capacity?this._size++:this.head=(this.head+1)%this.capacity}shift(){if(this._size===0)return;let e=this.buf[this.head];return this.buf[this.head]=void 0,this.head=(this.head+1)%this.capacity,this._size--,e}at(e){if(this._size===0)return;let t=e<0?this._size+e:e;if(!(t<0||t>=this._size))return this.buf[(this.head+t)%this.capacity]}toArray(){let e=new Array(this._size);for(let t=0;t<this._size;t++)e[t]=this.buf[(this.head+t)%this.capacity];return e}clear(){for(let e=0;e<this._size;e++)this.buf[(this.head+e)%this.capacity]=void 0;this.head=0,this._size=0}}});function en(r,e,t,n={}){let s=e in r.nodes,o=t in r.nodes;if(!s)return Ye(e,t,"no-such-from");if(!o)return Ye(e,t,"no-such-to");let i=n.maxDepth;if(i!=null&&(!Number.isInteger(i)||i<0))throw new Error("explainPath: maxDepth must be an integer >= 0");if(e===t){if(n.findCycle===!0){let d=Wn(r,e,n);if(d!=null)return d}let u=Xe(e,r.nodes[e],0,n);return Ze(e,t,[u])}if(i===0)return Ye(e,t,"no-path");let a=tn(r,e,t,i);return a.found?Ze(e,t,nn(r,a.pathOrder,n)):Ye(e,t,a.truncated?"max-depth-exceeded":"no-path")}function tn(r,e,t,n){let s=new Map,o=[{path:t,depth:0}],i=new Set([t]),a=0,u=!1;for(;a<o.length;){let f=o[a++];if(f.path===e)break;if(n!=null&&f.depth>=n){let v=r.nodes[f.path];v?.deps&&v.deps.length>0&&(u=!0);continue}let p=r.nodes[f.path];if(p==null)continue;let h=p.deps??[],l=new Map;for(let v=0;v<h.length;v++){let g=h[v];if(!g)continue;let _=l.get(g);_==null&&(_=[],l.set(g,_)),_.push(v)}for(let[v,g]of l)i.has(v)||(i.add(v),s.set(v,{from:f.path,depIndices:g}),o.push({path:v,depth:f.depth+1}))}if(!s.has(e))return{found:!1,pathOrder:[],truncated:u};let d=[{path:e}],c=e;for(;c!==t;){let f=s.get(c);if(f==null)return{found:!1,pathOrder:[],truncated:!1};d[d.length-1].depIndices=f.depIndices,d.push({path:f.from}),c=f.from}return{found:!0,pathOrder:d,truncated:!1}}function Wn(r,e,t){let n=r.nodes[e];if(n==null)return null;let s=n.deps??[],o=[];for(let a=0;a<s.length;a++)s[a]===e&&o.push(a);if(o.length>0){let a=Xe(e,n,0,t);a.dep_index=o[0];let u=Xe(e,n,1,t);return Ze(e,e,[a,u])}let i=null;for(let a=0;a<s.length;a++){let u=s[a];if(!u||u===e)continue;let d=tn(r,u,e,t.maxDepth);d.found&&(i==null||d.pathOrder.length<i.pathOrder.length)&&(i=d,i={found:!0,pathOrder:[{path:e,depIndices:[a]},...d.pathOrder],truncated:!1})}return i==null?null:Ze(e,e,nn(r,i.pathOrder,t))}function nn(r,e,t){return e.map((n,s)=>{let o=r.nodes[n.path],i=Xe(n.path,o,s,t);return n.depIndices!=null&&n.depIndices.length>0&&(i.dep_index=n.depIndices[0],n.depIndices.length>1&&(i.dep_indices=[...n.depIndices])),i})}function Xe(r,e,t,n){let s={path:r,type:e.type,hop:t};e.status!==void 0&&(s.status=e.status),"value"in e&&(s.value=e.value),e.v!=null&&(s.v=e.v);let o=n.annotations?.get(r)??e.annotation;o!=null&&(s.annotation=o);let i=n.lastMutations?.get(r)??e.lastMutation;return i!=null&&(s.lastMutation=i),s}function Ze(r,e,t){return rn(r,e,!0,"ok",t)}function Ye(r,e,t){return rn(r,e,!1,t,[])}function rn(r,e,t,n,s){let o=zn(r,e,t,n,s);return{from:r,to:e,found:t,reason:n,steps:s,text:o,toJSON(){return{from:r,to:e,found:t,reason:n,steps:s}}}}function zn(r,e,t,n,s){if(!t)switch(n){case"no-such-from":return`explainPath: no node named "${r}"`;case"no-such-to":return`explainPath: no node named "${e}"`;case"max-depth-exceeded":return`explainPath: no path from "${r}" to "${e}" within maxDepth`;default:return`explainPath: no path from "${r}" to "${e}"`}let o=[`Causal path: ${r} \u2192 ${e} (${s.length} step(s))`];for(let i of s){let u=` ${i.hop===0?"\xB7":"\u2193"} ${i.path} (${i.type}${i.status?`/${i.status}`:""})`;if(o.push(u),"value"in i&&o.push(` value: ${Un(i.value)}`),i.annotation!=null&&o.push(` annotation: ${i.annotation}`),i.lastMutation!=null){let d=i.lastMutation.actor;o.push(` actor: ${d.type}${d.id?`:${d.id}`:""}`)}}return o.join(`
3
+ `)}function Un(r){if(r===void 0)return"<sentinel>";if(r===null)return"null";if(typeof r=="string")return JSON.stringify(r);if(typeof r=="number"||typeof r=="boolean"||typeof r=="bigint")return String(r);try{let e=JSON.stringify(r);return e.length>80?`${e.slice(0,77)}...`:e}catch{return String(r)}}var sn=j(()=>{"use strict"});function on(r){let e=new WeakSet,t=new WeakSet,n=[r],s=0;for(;n.length>0;){let o=n.pop();s+=qn(o,e,t,n)}return s}function qn(r,e,t,n){if(r==null)return 0;switch(typeof r){case"number":return W.number;case"boolean":return W.boolean;case"string":return W.string+r.length*2;case"bigint":return W.bigint+Jn(r);case"symbol":return W.symbol;case"function":return e.has(r)?0:(e.add(r),W.function);case"undefined":return 0}let o=r;if(e.has(o))return 0;e.add(o);let i=o[Kn];if(typeof i=="function")try{let d=i.call(o);if(typeof d=="number"&&Number.isFinite(d))return d}catch{}if(o instanceof Date)return W.date;if(o instanceof RegExp)return W.regexp+o.source.length*2;if(o instanceof Error){let d=o.message?o.message.length*2:0,c=o.stack?o.stack.length*2:0;return W.error+d+c}if(typeof URL<"u"&&o instanceof URL)return W.url+o.href.length*2;if(typeof Promise<"u"&&o instanceof Promise)return W.promise;if(o instanceof WeakMap)return W.weakmap;if(o instanceof WeakSet)return W.weakset;if(o instanceof Map){let d=W.map;for(let[c,f]of o)d+=W.mapEntry,n.push(c),n.push(f);return d}if(o instanceof Set){let d=W.set;for(let c of o)d+=W.setEntry,n.push(c);return d}if(Array.isArray(o)){let d=W.array+o.length*8;for(let c of o)n.push(c);return d}if(o instanceof ArrayBuffer)return t.has(o)?0:(t.add(o),o.byteLength);if(ArrayBuffer.isView(o)){let d=o;return t.has(d.buffer)?48:(t.add(d.buffer),d.buffer.byteLength+48)}let a=W.object,u=Object.keys(o);for(let d of u){a+=W.string+d.length*2;try{n.push(o[d])}catch{}}return a}function Jn(r){let e=r<0n?-r:r;if(e===0n)return 0;let t=e.toString(2).length;return Math.ceil(t/32)*8}var W,Kn,an=j(()=>{"use strict";W={object:56,array:64,string:40,number:8,boolean:4,null:0,undefined:0,symbol:40,bigint:16,function:120,map:72,set:72,mapEntry:40,setEntry:24,date:24,regexp:48,error:64,url:80,promise:48,weakmap:40,weakset:40},Kn=Symbol.for("sizeof")});function un(r,e){let t=e?.topN??10,n=r.describe({detail:"standard"}),s=[],o=r._collectObserveTargets;typeof o=="function"&&o.call(r,"",s);let i=new Map;for(let[p,h]of s)i.set(p,h);let a=[];for(let[p,h]of Object.entries(n.nodes)){let l=i.get(p),v=l instanceof H?l:null,g=v?on(v.cache):0,_=v?v._sinkCount:0,m=h.deps?.length??0,y=h.type==="effect"&&_===0,w=_===0?h.type==="effect"?"orphan-effect":h.type==="derived"?"idle-derived":h.type==="producer"?"idle-producer":null:null;a.push({path:p,type:h.type,status:h.status??"unknown",valueSizeBytes:g,subscriberCount:_,depCount:m,isOrphanEffect:y,orphanKind:w})}let u=a.reduce((p,h)=>p+h.valueSizeBytes,0),d=(p,h)=>[...a].sort(h??((l,v)=>v[p]-l[p])).slice(0,t),c=a.filter(p=>p.orphanKind!=null),f=a.filter(p=>p.isOrphanEffect);return{nodeCount:a.length,edgeCount:n.edges.length,subgraphCount:n.subgraphs.length,nodes:a,totalValueSizeBytes:u,hotspots:{byValueSize:d("valueSizeBytes"),bySubscriberCount:d("subscriberCount"),byDepCount:d("depCount")},orphans:c,orphanEffects:f}}var dn=j(()=>{"use strict";De();an()});function Qe(r,e){let t=Math.max(16,r.size*4),n=0;for(;r.size>0;){if(n++>=t){console.error(`[Graph "${e}".destroy] disposer drain exceeded cap (${t}); ${r.size} disposer(s) discarded`),r.clear();return}let s=r.values().next();if(s.done)return;let o=s.value;r.delete(o);try{o()}catch(i){console.error(`[Graph "${e}".destroy] disposer threw:`,i)}}}function gn(r){return r!=null&&typeof r=="object"&&"cache"in r&&typeof r.subscribe=="function"&&typeof r.down=="function"}function Yn(r){if(r!=null)return gn(r)?r.cache:r}function ge(r){return r!=null&&typeof r=="object"&&"cache"in r&&typeof r.subscribe=="function"&&typeof r.down=="function"}function ce(r){return ge(r)?r.cache??"":r}function cn(r){return ge(r)?r.cache??0:r}function ln(r){return ge(r)?r.cache??!1:r}function Xn(r){let e=[];for(let t of Object.keys(r).sort()){let n=r[t].v;n!=null&&e.push(`${t} ${n.id} ${n.version}`)}return e.join(`
4
+ `)}function fn(r){if(r.version!==Te)throw new Error(`unsupported snapshot version ${String(r.version)} (expected ${Te})`);for(let e of["name","nodes","edges","subgraphs"])if(!(e in r))throw new Error(`snapshot missing required key "${e}"`);if(typeof r.name!="string")throw new TypeError("snapshot 'name' must be a string");if(typeof r.nodes!="object"||r.nodes===null||Array.isArray(r.nodes))throw new TypeError("snapshot 'nodes' must be an object");if(!Array.isArray(r.edges))throw new TypeError("snapshot 'edges' must be an array");if(!Array.isArray(r.subgraphs))throw new TypeError("snapshot 'subgraphs' must be an array")}function Zn(r,e){let t=new WeakMap,n=(s,o)=>{if(Object.is(s,o))return!0;if(s==null||o==null||typeof s!="object"||typeof o!="object")return!1;let i=t.get(s);if(i==null&&(i=new WeakSet,t.set(s,i)),i.has(o))return!0;i.add(o);let a=s.constructor,u=o.constructor;if(a!==u)return!1;if(s instanceof Date)return s.getTime()===o.getTime();if(s instanceof RegExp)return s.source===o.source&&s.flags===o.flags;if(Array.isArray(s)){let p=o;if(s.length!==p.length)return!1;for(let h=0;h<s.length;h++)if(!n(s[h],p[h]))return!1;return!0}if(s instanceof Map){let p=o;if(s.size!==p.size)return!1;for(let[h,l]of s)if(!p.has(h)||!n(l,p.get(h)))return!1;return!0}if(s instanceof Set){let p=o;if(s.size!==p.size)return!1;for(let h of s){let l=!1;for(let v of p)if(n(h,v)){l=!0;break}if(!l)return!1}return!0}if(ArrayBuffer.isView(s)){let p=s,h=o;if(p.length!==h.length)return!1;for(let l=0;l<p.length;l++)if(p[l]!==h[l])return!1;return!0}let d=Object.keys(s),c=Object.keys(o);if(d.length!==c.length)return!1;let f=new Set(c);for(let p of d)if(!f.has(p)||!n(s[p],o[p]))return!1;return!0};return n(r,e)}function Qn(r){return r.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function et(r){let e="^";for(let t=0;t<r.length;t+=1){let n=r[t];if(n==="*"){e+=".*";continue}if(n==="?"){e+=".";continue}if(n==="["){let s=r.indexOf("]",t+1);if(s<=t+1){e+="\\[";continue}let o=r.slice(t+1,s);o.startsWith("!")&&(o=`^${o.slice(1)}`),o=o.replace(/\\/g,"\\\\"),e+=`[${o}]`,t=s;continue}e+=Qn(n)}return e+="$",new RegExp(e)}function wt(r){if(typeof r=="string")return JSON.stringify(r);if(typeof r=="number"||typeof r=="boolean"||r==null)return String(r);try{return JSON.stringify(r)}catch{return"[unserializable]"}}function nr(r){return r==="none"?tr:r==="ansi"||r==null?er:{data:r.data??"",dirty:r.dirty??"",resolved:r.resolved??"",invalidate:r.invalidate??"",pause:r.pause??"",resume:r.resume??"",complete:r.complete??"",error:r.error??"",teardown:r.teardown??"",derived:r.derived??"",path:r.path??"",reset:r.reset??""}}function pn(r){if(r==null)return{};let e=r.detail;return e==="full"?{...r,structured:r.structured??!0,timeline:r.timeline??!0,causal:r.causal??!0,derived:r.derived??!0}:e==="minimal"?{...r,structured:r.structured??!0}:r.format==="stage-log"?{...r,structured:r.structured??!0,timeline:r.timeline??!0}:r}function rr(r,e,t){for(let n=0;n<r.length;n++){let s=r.charCodeAt(n);if(s<32||s===127)throw new Error(`Graph "${e}": ${t} "${r}" must not contain control character (U+${s.toString(16).padStart(4,"0").toUpperCase()} at index ${n})`)}}function _t(r,e,t){if(r==="")throw new Error(`Graph "${e}": ${t} name must be non-empty`);if(r.includes($))throw new Error(`Graph "${e}": ${t} "${r}" must not contain '${$}' (path separator)`);if(r===oe)throw new Error(`Graph "${e}": ${t} name "${oe}" is reserved for meta companion paths`);rr(r,e,t)}function sr(r,e){if(r==="")throw new Error(`Graph "${e}": resolve path must be non-empty`);let t=r.split($);for(let n of t)if(n==="")throw new Error(`Graph "${e}": resolve path has empty segment`);return t}function or(r,e){let t=!1;for(let s of r)if(!e.isMetaPassthrough(s[0])){t=!0;break}return t?r.filter(s=>e.isMetaPassthrough(s[0])):r}function mn(r){for(let e of r._mounts.values())mn(e);for(let e of r._nodes.values())try{e.down([[q]],{internal:!0})}catch{}}function ir(r,e){let t=Pe.diff(r,e),n={};for(let s of t.nodesAdded){let o=e.nodes[s];o!=null&&(n[s]=o)}return{...t,nodesAddedFull:n}}function hn(r,e,t,n={}){let s={paths:[],depths:new Map,truncated:!1};if(!e)return n.withDetail?s:[];if(!n.both&&t!=="upstream"&&t!=="downstream")throw new Error('reachable: direction must be "upstream" or "downstream"');let o=n.maxDepth;if(o!=null&&(!Number.isInteger(o)||o<0))throw new Error("reachable: maxDepth must be an integer >= 0");if(o===0)return n.withDetail?s:[];let i=new Map,a=new Map,u=new Map,d=new Map,c=new Set;for(let[y,w]of Object.entries(r.nodes)){if(!y)continue;c.add(y);let b=w.deps??[];i.set(y,b);for(let x of b)x&&(c.add(x),a.has(x)||a.set(x,new Set),a.get(x).add(y))}for(let y of r.edges){if(y==null||typeof y!="object")continue;let w=typeof y.from=="string"?y.from:"",b=typeof y.to=="string"?y.to:"";!w||!b||(c.add(w),c.add(b),d.has(w)||d.set(w,new Set),d.get(w).add(b),u.has(b)||u.set(b,new Set),u.get(b).add(w))}if(!c.has(e))return n.withDetail?s:[];let f=n.both===!0,p=y=>{if(f){let k=i.get(y)??[],T=u.get(y),E=a.get(y),A=d.get(y),S=[...k];return T&&S.push(...T),E&&S.push(...E),A&&S.push(...A),S}if(t==="upstream"){let k=i.get(y)??[],T=u.get(y);return T?[...k,...T]:k}let w=a.get(y),b=d.get(y),x=w?[...w]:[];return b&&x.push(...b),x},h=new Set([e]),l=new Map,v=[{path:e,depth:0}],g=0,_=!1;for(;g<v.length;){let y=v[g++];if(o!=null&&y.depth>=o){p(y.path).length>0&&(_=!0);continue}for(let w of p(y.path))!w||h.has(w)||(h.add(w),l.set(w,y.depth+1),v.push({path:w,depth:y.depth+1}))}let m=[...l.keys()].sort((y,w)=>y<w?-1:y>w?1:0);return n.withDetail?{paths:m,depths:l,truncated:_}:m}function ar(r,e){if(r.length!==e.length)return!1;for(let t=0;t<r.length;t++){let n=r[t],s=e[t];if(n.path!==s.path||n.type!==s.type||n.status!==s.status||n.hop!==s.hop||n.dep_index!==s.dep_index||n.annotation!==s.annotation||n.value!==s.value||n.lastMutation!==s.lastMutation)return!1;let o=n.v,i=s.v;if(o!==i&&(o==null||i==null||o.id!==i.id||o.version!==i.version))return!1}return!0}var $,oe,Te,er,tr,Pe,bn=j(()=>{"use strict";it();Fe();Ve();je();Re();mt();De();Ue();Kt();Xt();Zt();Qt();ot();sn();dn();$="::",oe="__meta__",Te=1;er={data:"\x1B[32m",dirty:"\x1B[33m",resolved:"\x1B[36m",invalidate:"\x1B[93m",pause:"\x1B[90m",resume:"\x1B[96m",complete:"\x1B[34m",error:"\x1B[31m",teardown:"\x1B[91m",derived:"\x1B[35m",path:"\x1B[90m",reset:"\x1B[0m"},tr={data:"",dirty:"",resolved:"",invalidate:"",pause:"",resume:"",complete:"",error:"",teardown:"",derived:"",path:"",reset:""};Pe=class r{name;opts;config;_nodes=new Map;_nodeToName=new WeakMap;_mounts=new Map;_parent=void 0;_storageDisposers=new Set;_disposers=new Set;_destroyed=!1;_topology;_topologyEmitters=new Set;_factory;_factoryArgs;constructor(e,t){if(e==="")throw new Error("Graph name must be non-empty");if(e.includes($))throw new Error(`Graph name must not contain '${$}' (got "${e}")`);if(e===oe)throw new Error(`Graph name "${oe}" is reserved for meta companion paths`);this.name=e,this.opts=Object.freeze({...t??{}}),this.config=t?.config??xe,this._traceRing=new Ge(t?.traceCapacity??1e3),t?.versioning!=null&&this.setVersioning(t.versioning),typeof t?.factory=="string"&&(this._factory=t.factory,t.factoryArgs!==void 0&&(this._factoryArgs=t.factoryArgs))}tagFactory(e,t){return this._factory=e,this._factoryArgs=t,this}ancestors(e=!0){let t=[],n=e?this:this._parent;for(;n!=null;)t.push(n),n=n._parent;return t}get topology(){return this._topology==null&&(this._topology=he(e=>{let t=n=>{e.emit(n)};return this._topologyEmitters.add(t),()=>{this._topologyEmitters.delete(t)}},{name:`${this.name}_topology`})),this._topology}_emitTopology(e){if(!(this._topology==null||this._topologyEmitters.size===0))for(let t of this._topologyEmitters)t(e)}nameOf(e){return this._nodeToName.get(e)}add(e,t){let n=e.name,s=t?.name??n;if(s==null||s==="")throw new Error(`Graph "${this.name}": graph.add requires a non-empty name \u2014 pass via opts.name or set it on the node (e.g. state(0, { name: "x" }))`);let o=s,i=t?.annotation;if(_t(o,this.name,"add"),this._mounts.has(o))throw new Error(`Graph "${this.name}": name "${o}" is already a mount point`);if(this._nodes.has(o))throw new Error(`Graph "${this.name}": node "${o}" already exists`);let a=this._nodeToName.get(e);if(a!==void 0)throw new Error(`Graph "${this.name}": node instance already registered as "${a}"`);return this._nodes.set(o,e),this._nodeToName.set(e,o),this._emitTopology({kind:"added",name:o,nodeKind:"node"}),i!=null&&(this._annotations.set(o,i),this.config.inspectorEnabled&&this._traceRing.push({path:o,annotation:i,timestamp_ns:ue()})),e}setVersioning(e){if(e!=null)for(let t of this._nodes.values())t instanceof H&&t._applyVersioning(e)}remove(e){_t(e,this.name,"remove");let t=this._mounts.get(e);if(t){let o={kind:"mount",nodes:[],mounts:[]},i=[];t._collectObserveTargets("",i);for(let[a,u]of i)a.includes(`${$}${oe}${$}`)||o.nodes.push(a);return o.nodes.sort(),o.mounts.push(e),o.mounts.push(...t._collectSubgraphs(`${e}${$}`)),this._mounts.delete(e),t._parent=void 0,mn(t),this._emitTopology({kind:"removed",name:e,nodeKind:"mount",audit:o}),o}let n=this._nodes.get(e);if(!n)throw new Error(`Graph "${this.name}": unknown node or mount "${e}"`);this._nodes.delete(e),this._nodeToName.delete(n),n.down([[q]],{internal:!0});let s={kind:"node",nodes:[e],mounts:[]};return this._emitTopology({kind:"removed",name:e,nodeKind:"node",audit:s}),s}removeAll(e){let t=typeof e=="function"?e:(()=>{let o=et(e);return i=>o.test(i)})(),n={kind:"mount",nodes:[],mounts:[]},s=[...this._nodes.keys(),...this._mounts.keys()].filter(o=>t(o));for(let o of s){let i=this.remove(o);n.nodes.push(...i.nodes),n.mounts.push(...i.mounts)}return n.nodes.sort(),n.mounts.sort(),n}[Symbol.iterator](){let e=[...this._nodes.keys()].sort(),t=this._nodes,n=0;return{[Symbol.iterator](){return this},next(){if(n>=e.length)return{value:void 0,done:!0};let s=e[n++];return{value:[s,t.get(s)],done:!1}}}}node(e){if(e==="")throw new Error(`Graph "${this.name}": node name must be non-empty`);if(e.includes($))return this.resolve(e);let t=this._nodes.get(e);if(!t)throw new Error(`Graph "${this.name}": unknown node "${e}"`);return t}get(e){return this.node(e).cache}set(e,t,n){let s=n?.internal===!0;this.node(e).down([[K,t]],{actor:n?.actor,internal:s,delivery:"write"})}setAll(e,t){let n=Symbol.iterator in e?e:Object.entries(e);Ee(()=>{for(let[s,o]of n)this.set(s,o,t)})}invalidate(e,t){let n=t?.internal===!0;this.node(e).down([[se]],{actor:t?.actor,internal:n,delivery:"write"})}error(e,t,n){let s=n?.internal===!0;this.node(e).down([[I,t]],{actor:n?.actor,internal:s,delivery:"write"})}complete(e,t){let n=t?.internal===!0;this.node(e).down([[J]],{actor:t?.actor,internal:n,delivery:"write"})}_registerSelfPruningKeepalive(e){let t,n,s=()=>{t?.(),t=void 0,n?.(),n=void 0};t=e.subscribe(o=>{for(let i of o){let a=i[0];if(a===q||a===J||a===I){s();return}}}),n=this.addDisposer(s)}_wireSignalToRemove(e,t){if(t==null)return;let n=()=>{try{this.remove(e)}catch{}};if(t.aborted){n();return}t.addEventListener("abort",n,{once:!0}),this.addDisposer(()=>t.removeEventListener("abort",n))}derived(e,t,n,s){let o=t.map(h=>this.resolve(h)),{keepAlive:i,annotation:a,equals:u,initial:d,meta:c,signal:f}=s??{},p=V(o,n,{name:e,...u!=null?{equals:u}:{},...d!==void 0?{initial:d}:{},...c!=null?{meta:c}:{}});return this.add(p,{name:e,...a!=null?{annotation:a}:{}}),i===!0&&this._registerSelfPruningKeepalive(p),this._wireSignalToRemove(e,f),p}effect(e,t,n,s){let o=t.map(c=>this.resolve(c)),{annotation:i,meta:a,signal:u}=s??{},d=ke(o,n,{name:e,...a!=null?{meta:a}:{}});return this.add(d,{name:e,...i!=null?{annotation:i}:{}}),this._wireSignalToRemove(e,u),d}produce(e,t,n){if(t===void 0)throw new Error(`Graph "${this.name}".produce("${e}", \u2026): source must not be \`undefined\` \u2014 undefined is the global SENTINEL (spec \xA71.1). Pass \`null\` for nullary DATA, or a Promise/AsyncIterable/Iterable for async sources.`);if(t!==null&&typeof t=="object"&&"cache"in t&&typeof t.subscribe=="function")throw new Error(`Graph "${this.name}".produce("${e}", \u2026): Node sources are rejected. For Node\u2192Node, use graph.derived(name, [path], ([v]) => v, { keepAlive: true }) \u2014 fromAny passes Nodes through verbatim and silently drops opts.`);let{annotation:s,meta:o,equals:i,signal:a}=n??{},u=Jt(t,{name:e,...o!=null?{meta:o}:{},...i!=null?{equals:i}:{},...a!=null?{signal:a}:{}});return this.add(u,{name:e,...s!=null?{annotation:s}:{}}),this._wireSignalToRemove(e,a),u}batch(e){Ee(e)}edges(e){let t=e?.recursive===!0,n=new Map;if(!t){for(let[u,d]of this._nodes)n.set(d,u);let a=[];for(let[u,d]of this._nodes)if(d instanceof H)for(let c of d._deps){let f=n.get(c.node);f!=null&&a.push([f,u])}return a.sort((u,d)=>u[0]<d[0]?-1:u[0]>d[0]?1:u[1]<d[1]?-1:u[1]>d[1]?1:0),a}let s=[];this._collectObserveTargets("",s);let o=new Map;for(let[a,u]of s)o.set(u,a);let i=[];for(let[a,u]of s)if(u instanceof H)for(let d of u._deps){let c=o.get(d.node);c!=null&&i.push([c,a])}return i.sort((a,u)=>a[0]<u[0]?-1:a[0]>u[0]?1:a[1]<u[1]?-1:a[1]>u[1]?1:0),i}mount(e,t){if(t===void 0){let s=new r(e);return this.mount(e,s)}if(typeof t=="function"){let s=new r(e);return t(s),this.mount(e,s)}let n=t;if(_t(e,this.name,"mount"),this._nodes.has(e))throw new Error(`Graph "${this.name}": cannot mount at "${e}" \u2014 node with that name exists`);if(this._mounts.has(e))throw new Error(`Graph "${this.name}": mount "${e}" already exists`);if(n===this)throw new Error(`Graph "${this.name}": cannot mount a graph into itself`);if(n._parent!=null)throw new Error(`Graph "${this.name}": this child graph is already mounted on "${n._parent.name}"`);for(let s=this;s!=null;s=s._parent)if(s===n)throw new Error(`Graph "${this.name}": mount("${e}", \u2026) would create a mount cycle`);return this._mounts.set(e,n),n._parent=this,this._emitTopology({kind:"added",name:e,nodeKind:"mount"}),n}resolve(e){let t=sr(e,this.name);return this._resolveFromSegments(t)}tryResolve(e){try{return this.resolve(e)}catch{return}}_resolveFromSegments(e){let t=e;if(t[0]===this.name&&(t=t.slice(1),t.length===0))throw new Error(`Graph "${this.name}": resolve path ends at graph name only`);let n=t[0],s=t.slice(1);if(s.length===0){let a=this._nodes.get(n);if(a)return a;throw this._mounts.has(n)?new Error(`Graph "${this.name}": path ends at subgraph "${n}" \u2014 not a node (GRAPHREFLY-SPEC \xA73.5)`):new Error(`Graph "${this.name}": unknown name "${n}"`)}let o=this._nodes.get(n);if(o&&s.length>0&&s[0]===oe)return this._resolveMetaChainFromNode(o,s,t.join($));let i=this._mounts.get(n);if(!i)throw this._nodes.has(n)?new Error(`Graph "${this.name}": "${n}" is a node; trailing path "${s.join($)}" is invalid`):new Error(`Graph "${this.name}": unknown mount or node "${n}"`);return i.resolve(s.join($))}_resolveMetaChainFromNode(e,t,n){let s=e,o=0,i=[...t];for(;o<i.length;){if(i[o]!==oe)throw new Error(`Graph "${this.name}": expected ${oe} segment in meta path "${n}"`);if(o+1>=i.length)throw new Error(`Graph "${this.name}": meta path requires a key after ${oe} in "${n}"`);let a=i[o+1],u=s.meta[a];if(!u)throw new Error(`Graph "${this.name}": unknown meta "${a}" in path "${n}"`);s=u,o+=2}return s}signal(e,t){if(t?.internal!==!0){for(let s of e)if(this.config.messageTier(s[0])===3)throw new Error(`Graph "${this.name}": Graph.signal() rejects tier-3 messages (DATA / RESOLVED). Broadcast is for control-plane tiers (START / DIRTY / INVALIDATE / PAUSE / RESUME / COMPLETE / ERROR / TEARDOWN). For per-node value writes, use Graph.set or graph.node(name).down(...).`)}let n=[];if(this._signalDeliver(e,t??{},new Set,n),n.length>0)throw n[0]}_signalDeliver(e,t,n,s){for(let u of this._mounts.values())u._signalDeliver(e,t,n,s);let i=t.internal===!0?{internal:!0}:{actor:t.actor,delivery:"signal"},a=or(e,this.config);for(let u of[...this._nodes.keys()].sort()){let d=this._nodes.get(u);if(!n.has(d)){n.add(d);try{d.down(e,i)}catch(c){if(c instanceof te)throw c;s.push(c)}a.length!==0&&this._signalMetaSubtree(d,a,n,i,s)}}}_signalMetaSubtree(e,t,n,s,o){for(let i of Object.keys(e.meta).sort()){let a=e.meta[i];if(!n.has(a)){n.add(a);try{a.down(t,s)}catch(u){if(u instanceof te)throw u;o.push(u)}this._signalMetaSubtree(a,t,n,s,o)}}}describe(e){if(e?.reactive==="diff")return this._describeReactiveDiff(e);if(e?.reactive===!0)return this._describeReactive(e);let t=Yn(e?.actor),n=e?.filter;if(e?.detail!=null&&e?.fields!=null)throw new TypeError("Graph.describe(): pass either `detail` or `fields`, not both. `detail: 'spec'` is the canonical spec projection; use `fields` only when you need a custom subset.");let s=Ce(e?.detail,e?.fields),o=e?.detail==="spec",i=s,a=[];this._collectObserveTargets("",a);let u=new Map;for(let[w,b]of a)u.set(b,w);let d=[];{let w=a.map(([,k])=>k),b=new Set(u.values()),x=0;for(;w.length>0;){let k=w.shift();if(k instanceof H)for(let T of k._deps){let E=T.node;if(u.has(E))continue;let A=E.name??"",S=A;if(!S||b.has(S))if(A){let F=2;for(;b.has(`${A}#${F}`);)F++;S=`${A}#${F}`}else for(S=`__internal__/${x++}`;b.has(S);)S=`__internal__/${x++}`;u.set(E,S),b.add(S),d.push([S,E]),w.push(E)}}}let c=[...a,...d],f={};for(let[w,b]of c){if(t!=null&&!b.allowsObserve(t))continue;let x=Me(b,i,o),k=b instanceof H?b._deps.map(S=>u.get(S.node)??S.node.name??""):[],{name:T,...E}=x,A={...E,deps:k};if(!o){let S=this._annotations.get(w);S!=null&&(A.annotation=S)}if(n!=null)if(typeof n=="function"){let S=n;if(!(S.length>=2?S(w,A):S(A)))continue}else{let S=!0;for(let[F,G]of Object.entries(n)){let P=F==="deps_includes"?"depsIncludes":F==="meta_has"?"metaHas":F;if(P==="depsIncludes"){if(!A.deps.includes(String(G))){S=!1;break}continue}if(P==="metaHas"){if(!Object.hasOwn(A.meta??{},String(G))){S=!1;break}continue}if(A[P]!==G){S=!1;break}}if(!S)continue}f[w]=A}let p=new Set(Object.keys(f)),h=[];for(let[w,b]of c)if(b instanceof H)for(let x of b._deps){let k=u.get(x.node);k!=null&&h.push([k,w])}h.sort((w,b)=>w[0]<b[0]?-1:w[0]>b[0]?1:w[1]<b[1]?-1:w[1]>b[1]?1:0);let l=h.map(([w,b])=>({from:w,to:b}));(t!=null||n!=null)&&(l=l.filter(w=>p.has(w.from)&&p.has(w.to)));let v=this._collectSubgraphs(""),g=t!=null||n!=null?v.filter(w=>{let b=`${w}${$}`;return[...p].some(x=>x===w||x.startsWith(b))}):v,_=this,m=e;return{name:this.name,nodes:f,edges:l,subgraphs:g,...this._factory!==void 0?{factory:this._factory}:{},...this._factoryArgs!==void 0?{factoryArgs:this._factoryArgs}:{},expand(w){let b={...m};return Array.isArray(w)?(b.fields=w,b.detail=void 0):(b.detail=w,b.fields=void 0),_.describe(b)}}}_collectSubgraphs(e){let t=[];for(let n of[...this._mounts.keys()].sort()){let s=e===""?n:`${e}${n}`;t.push(s),t.push(...this._mounts.get(n)._collectSubgraphs(`${s}${$}`))}return t}resourceProfile(e){return un(this,e)}reachable(e,t,n={}){return n.withDetail===!0?hn(this.describe(),e,t,{...n,withDetail:!0}):hn(this.describe(),e,t,n)}explain(e,t,n){return n?.reactive===!0?this._explainReactive(e,t,n):this._explainStatic(ce(e),ce(t),{...n?.maxDepth!==void 0?{maxDepth:cn(n.maxDepth)}:{},...n?.findCycle!==void 0?{findCycle:ln(n.findCycle)}:{}})}_explainStatic(e,t,n){let s=this.describe({detail:"full"}),o=new Map(this._annotations),i=new Map;for(let[a,u]of Object.entries(s.nodes))u.lastMutation!=null&&i.set(a,u.lastMutation);return en(s,e,t,{...n?.maxDepth!=null?{maxDepth:n.maxDepth}:{},...n?.findCycle===!0?{findCycle:!0}:{},annotations:o,lastMutations:i})}_describeReactive(e){let t={...e,reactive:!1},n=e.reactiveName??"describe",s=0,o=Y(s,{name:`${n}_version`}),i=this.observe({timeline:!0,structured:!0}),a=!1,u=!1,d=()=>{a||u||(a=!0,ye(()=>{a=!1,!u&&(s+=1,o.emit(s))}))},c=i.onEvent(m=>{let y=m.type;y!=="data"&&y!=="error"&&y!=="complete"&&y!=="teardown"||d()}),f=[],p=new WeakSet,h=m=>{if(p.has(m)||u)return;p.add(m);let y=m.topology.subscribe(w=>{for(let b of w){if(b[0]!==K)continue;let x=b[1];if(d(),x.kind==="added"&&x.nodeKind==="mount"){let k=m._mounts.get(x.name);k!=null&&h(k)}}});f.push(y);for(let w of m._mounts.keys()){let b=m._mounts.get(w);b!=null&&h(b)}};h(this);let l,v=e.actor;gn(v)&&(l=v.subscribe(m=>{let y=!1,w=!1;for(let b of m){let x=b[0];x===K?y=!0:(x===J||x===I||x===q)&&(w=!0)}y&&d(),w&&(l?.(),l=void 0,d())}));let g;try{g=V([o],()=>this.describe(t),{name:n,describeKind:"derived",meta:{domain:"audit",kind:"describe"},equals:(m,y)=>m===y})}catch(m){c(),l?.();for(let y of f)y();throw i.dispose(),m}let _=qe(g);return{node:g,dispose(){u=!0,c(),l?.();for(let m of f)m();f.length=0,i.dispose(),_()}}}_describeReactiveDiff(e){let t={...e,reactive:!1},n=e.reactiveName??"describe-diff",s={name:this.name,nodes:{},edges:[],subgraphs:[]},o=this.describe(t),i=yt(s,o),a=Y(i,{name:n,meta:{domain:"audit",kind:"describe-diff"},equals:(p,h)=>p===h}),u=this._describeReactive({...e,reactiveName:void 0}),d=!1,c=u.node.subscribe(p=>{if(!d)for(let h of p){if(h[0]!==K)continue;let l=h[1],v=yt(o,l);o=l,v.events.length!==0&&a.emit(v)}}),f=qe(a);return{node:a,dispose(){d=!0,c(),u.dispose(),a.down([[q,"describe-diff disposed"]]),f()}}}_explainReactive(e,t,n){let s=0,o=Y(s,{name:"explain_version"}),i=this.observe({timeline:!0,structured:!0}),a=!1,u=!1,d=()=>{a||u||(a=!0,ye(()=>{a=!1,!u&&(s+=1,o.emit(s))}))},c=i.onEvent(m=>{let y=m.type;y!=="data"&&y!=="error"&&y!=="complete"&&y!=="teardown"||d()}),f=[];e!=null&&ge(e)&&f.push(e),t!=null&&ge(t)&&f.push(t),n?.maxDepth!=null&&ge(n.maxDepth)&&f.push(n.maxDepth),n?.findCycle!=null&&ge(n.findCycle)&&f.push(n.findCycle);let p=()=>{for(let m of f)if(m.cache===void 0)return!1;return!0},h=()=>{let m=ce(e),y=ce(t);return{from:m,to:y,found:!1,reason:"pending",steps:[],text:"(awaiting reactive args)",toJSON:()=>({from:m,to:y,found:!1,reason:"pending",steps:[]})}},l;try{l=V([o],()=>{if(!p())return h();let m=ce(e),y=ce(t),w={...n?.maxDepth!==void 0?{maxDepth:cn(n.maxDepth)}:{},...n?.findCycle!==void 0?{findCycle:ln(n.findCycle)}:{}};return this._explainStatic(m,y,w)},{name:n?.name??"explain",describeKind:"derived",meta:{domain:"audit",kind:"explain_path",from:ce(e),to:ce(t)},equals:(m,y)=>m.found===y.found&&m.reason===y.reason&&m.steps.length===y.steps.length&&ar(m.steps,y.steps)})}catch(m){throw c(),i.dispose(),m}let v=qe(l),g=[],_=m=>{let y;return y=m.subscribe(w=>{let b=!1,x=!1;for(let k of w){let T=k[0];T===K?b=!0:(T===J||T===I||T===q)&&(x=!0)}(b||x)&&d(),x&&y&&(y(),y=void 0)}),()=>{y&&(y(),y=void 0)}};for(let m of f)g.push(_(m));return{node:l,dispose(){u=!0,c();for(let m of g)m?.();g.length=0,i.dispose(),v()}}}_pathsMatching(e){let t=et(e),n=[];return this._collectObserveTargets("",n),n.map(([s])=>s).filter(s=>t.test(s))}_collectObserveTargets(e,t){for(let n of[...this._mounts.keys()].sort()){let s=e===""?n:`${e}${$}${n}`;this._mounts.get(n)._collectObserveTargets(s,t)}for(let n of[...this._nodes.keys()].sort()){let s=this._nodes.get(n),o=e===""?n:`${e}${$}${n}`;t.push([o,s]),this._appendMetaObserveTargets(o,s,t)}}_appendMetaObserveTargets(e,t,n){for(let s of Object.keys(t.meta).sort()){let o=t.meta[s],i=`${e}${$}${oe}${$}${s}`;n.push([i,o]),this._appendMetaObserveTargets(i,o,n)}}observe(e,t){let n=typeof e=="string",o=pn(n?t:e);if(o.reactive===!0)return this._observeReactive(n?e:void 0,o);let i=o.structured===!0||o.timeline===!0||o.causal===!0||o.derived===!0||o.detail==="minimal"||o.detail==="full"||o.format!=null,a=o.actor;if(n){let c=e,f=this.resolve(c);if(a!=null&&!f.allowsObserve(a))throw new te({actor:a,action:"observe",nodeName:c});return i?this._buildStructuredObserver([[c,f]],o,"one"):{subscribe(p){return f.subscribe(p)},up(p){try{f.up?.(p)}catch(h){if(h instanceof te)return;throw h}}}}let u=[];this._collectObserveTargets("",u),u.sort((c,f)=>c[0]<f[0]?-1:c[0]>f[0]?1:0);let d=a==null?u:u.filter(([,c])=>c.allowsObserve(a));return i?this._buildStructuredObserver(d,o,"all"):{subscribe:c=>{let f=d.map(([p,h])=>h.subscribe(l=>{c(p,l)}));return()=>{for(let p of f)p()}},up:(c,f)=>{try{this.resolve(c).up?.(f)}catch(p){if(p instanceof te)return;throw p}}}}_observeReactive(e,t){let n=t.tiers,s=n!=null?new Set(n):null,o=t.reactiveName??"observe";return he(i=>{let a=[],u=!1,d=!1,c=()=>{if(a.length===0||d)return;let v={events:a.slice(),flushedAt_ns:ue()};a.length=0,i.emit(v)},f={...t,reactive:!1,structured:!0,timeline:!0},p=e!=null?this.observe(e,f):this.observe(f),h=v=>{d||(a.push(v),!u&&(u=!0,ye(()=>{u=!1,c()})))};for(let v of p.events)h(v);let l=p.onEvent(h);return()=>{d=!0,l(),p.dispose()}},{name:o,meta:{domain:"audit",kind:"observe-reactive"}})}_buildStructuredObserver(e,t,n){let s=n==="one"?e[0]?.[0]:void 0,o=i=>{if(n==="one"&&s!=null){let c=this.resolve(s);return this._buildStructuredObserver([[s,c]],i,"one")}let a=[];this._collectObserveTargets("",a),a.sort((c,f)=>c[0]<f[0]?-1:c[0]>f[0]?1:0);let u=i.actor,d=u==null?a:a.filter(([,c])=>c.allowsObserve(u));return this._buildStructuredObserver(d,i,"all")};return this._createObserveResult(e,t,o)}_createObserveResult(e,t,n){let s=t.timeline===!0,o=t.causal===!0,i=t.derived===!0,a=t.detail==="minimal",u=this.config.inspectorEnabled,d=(o||i)&&u,c=t.maxEvents,f=c!=null&&c>0?new Ge(c):null,p=[],h=new Set,l=t.tiers!=null?new Set(t.tiers):null,v={},g=new Set,_=0,m=0,y=0,w=0,b=0,x=0,k=!1,T=!1,E=0,A=new Map,S=new Map,F=new Map,G=O=>{if(!(l!=null&&!l.has(O.type))){f?f.push(O):p.push(O);for(let C of h)C(O)}},P=O=>l==null||l.has(O),ae=()=>s?{timestamp_ns:ue(),in_batch:Le(),batch_id:E}:{},Ne=(O,C)=>{if(!(!d||!(O instanceof H)))return O._setInspectorHook(U=>{if(U.kind==="dep_message")A.set(O,U.depIndex);else if(U.kind==="run"){let le=U.batchData.map((M,Q)=>M!=null&&M.length>0?M.at(-1):U.prevData[Q]);S.set(O,le);let Z=U.batchData.map(M=>M!=null?[...M]:void 0);F.set(O,Z),i&&G({type:"derived",path:C,dep_values:le,dep_batches:Z,...ae()})}})},N=O=>{let C=A.get(O),U=S.get(O);if(!o||U==null)return{};let Z=(C!=null&&C>=0&&O instanceof H?O._deps[C]:void 0)?.node,M=Z?.v,Q=F.get(O);return{trigger_dep_index:C,trigger_dep_name:Z?.name,...M!=null?{trigger_version:{id:M.id,version:M.version}}:{},dep_values:[...U],...Q!=null?{dep_batches:Q}:{}}},D=[],R=[];for(let[O,C]of e){let U=Ne(C,O);U&&D.push(U),R.push(C.subscribe(le=>{E++;for(let Z of le){let M=Z[0],Q=ae();if(M===K){v[O]=Z[1];let tt=C instanceof H?C.lastMutation?.actor??ve:ve;G({type:"data",path:O,data:Z[1],actor:tt,...Q,...N(C)})}else if(a)M===ne?P("dirty")&&_++:M===re?P("resolved")&&m++:M===se?P("invalidate")&&y++:M===ie?P("pause")&&w++:M===de?P("resume")&&b++:M===q?P("teardown")&&x++:M===J&&!g.has(O)?P("complete")&&(k=!0):M===I&&P("error")&&(T=!0,g.add(O));else if(M===ne)P("dirty")&&_++,G({type:"dirty",path:O,...Q});else if(M===re)P("resolved")&&m++,G({type:"resolved",path:O,...Q,...N(C)});else if(M===se)P("invalidate")&&y++,G({type:"invalidate",path:O,...Q});else if(M===ie)P("pause")&&w++,G({type:"pause",path:O,lockId:Z[1],...Q});else if(M===de)P("resume")&&b++,G({type:"resume",path:O,lockId:Z[1],...Q});else if(M===J)P("complete")&&!g.has(O)&&(k=!0),G({type:"complete",path:O,...Q});else if(M===I){P("error")&&(T=!0,g.add(O));let tt=C instanceof H?C.lastMutation?.actor??ve:ve;G({type:"error",path:O,data:Z[1],actor:tt,...Q})}else M===q&&(P("teardown")&&x++,G({type:"teardown",path:O,...Q}))}}))}let X=!1,L=()=>{if(!X){X=!0;for(let O of R)O();for(let O of D)O();for(let O of z)O({value:void 0,done:!0});z.length=0}},B=[],z=[];h.add(O=>{let C=z.shift();C?C({value:O,done:!1}):B.push(O)});let ee={get values(){return v},get dirtyCount(){return _},get resolvedCount(){return m},get invalidateCount(){return y},get pauseCount(){return w},get resumeCount(){return b},get teardownCount(){return x},get events(){return f?f.toArray():[...p]},get anyCompletedCleanly(){return k},get anyErrored(){return T},get completedWithoutErrors(){return k&&!T},onEvent(O){return h.add(O),()=>h.delete(O)},dispose:L,expand(O){L();let C={...t};return typeof O=="string"?C.detail=O:Object.assign(C,O),n(pn(C))},[Symbol.asyncIterator](){return{next(){return B.length>0?Promise.resolve({value:B.shift(),done:!1}):X?Promise.resolve({value:void 0,done:!0}):new Promise(O=>z.push(O))},return(){return L(),Promise.resolve({value:void 0,done:!0})}}}};return t.format!=null&&this._attachFormatLogger(ee,t),ee}_attachFormatLogger(e,t){let n=t.format;if(n==null)return;let s=t.logger??(l=>console.log(l)),o=t.includeTypes?new Set(t.includeTypes):null,i=t.excludeTypes?new Set(t.excludeTypes):null,a=o==null&&i==null?()=>!0:l=>(o==null||o.has(l))&&(i==null||!i.has(l)),u=nr(t.theme),d=n==="stage-log"?ue():0,c=l=>l==null?"":t.stageLabels?.[l]??l,f=(l,v)=>l.length>v?`${l.slice(0,v-1)}\u2026`:l,p=l=>l.type==="data"||l.type==="error"?f(wt(l.data),120):"",h=l=>{if(n==="stage-log"){let k=(ue()-d)/1e9,T=c(l.path).padEnd(9);if(l.type==="data"){let E=p(l);return`[${k.toFixed(3)}s] ${T} \u2190${E?` ${E}`:""}`}if(l.type==="error"){let E=p(l);return`[${k.toFixed(3)}s] ${T} \u2717${E?` ${E}`:""}`}return l.type==="complete"?`[${k.toFixed(3)}s] ${T} \u25A0 complete`:`[${k.toFixed(3)}s] ${T} ${l.type}`}if(n==="json")try{return JSON.stringify(l)}catch{return JSON.stringify({type:l.type,path:l.path,data:"[unserializable]"})}let v=u[l.type]??"",g=l.path?`${u.path}${l.path}${u.reset} `:"",_=l.type==="data"||l.type==="error",m=l.type==="pause"||l.type==="resume",y=_?` ${wt(l.data)}`:m?` ${wt(l.lockId)}`:"",w=l.type==="data"||l.type==="resolved"||l.type==="derived"?l:void 0,b=w?.trigger_dep_name!=null?` <- ${w.trigger_dep_name}`:w?.trigger_dep_index!=null?` <- #${w.trigger_dep_index}`:"",x=l.in_batch?" [batch]":"";return`${g}${v}${l.type.toUpperCase()}${u.reset}${y}${b}${x}`};e.onEvent(l=>{a(l.type)&&s(h(l),l)})}addDisposer(e){return this._disposers.add(e),()=>{this._disposers.delete(e)}}destroy(){Qe(this._disposers,this.name),this.signal([[q]],{internal:!0}),Qe(this._storageDisposers,this.name);for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0,this._destroyed=!0}get destroyed(){return this._destroyed}_destroyClearOnly(){Qe(this._disposers,this.name),Qe(this._storageDisposers,this.name);for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0,this._destroyed=!0}snapshot(e){let{expand:t,...n}=this.describe({detail:"full"}),s={};for(let a of Object.keys(n.nodes).sort()){let{lastMutation:u,guard:d,...c}=n.nodes[a];s[a]=c}let o=[...n.subgraphs].sort(),i={...n,version:1,nodes:s,subgraphs:o};if(e?.format==null)return i;if(e.format==="json-string")return JSON.stringify(i);if(e.format==="bytes"){if(e.codec==null)throw new Error("snapshot({format: 'bytes'}) requires a `codec` name");let a=this.config.lookupCodec(e.codec);if(a==null)throw new Error(`snapshot: codec "${e.codec}" is not registered on this graph's config. Call config.registerCodec(...) before creating nodes.`);return Ot(a,a.encode(i))}throw new Error(`snapshot: unknown format "${String(e.format)}"`)}static decode(e,t){let n=t?.config??xe,{codec:s,codecVersion:o,payload:i}=St(e,n);return s.decode(i,o)}restore(e,t){if(fn(e),e.name!==this.name)throw new Error(`Graph "${this.name}": restore snapshot name "${e.name}" does not match this graph`);let n=t?.only==null?null:(Array.isArray(t.only)?t.only:[t.only]).map(o=>et(o)),s=t?.includeProducers===!0;for(let o of Object.keys(e.nodes).sort()){if(n!==null&&!n.some(a=>a.test(o)))continue;let i=e.nodes[o];if(i!==void 0){if(!("value"in i)||i.value===void 0){"value"in i&&i.value===void 0&&t?.onError?.(o,new Error(`restore: slice.value is undefined for "${o}" (undefined is the global SENTINEL; not valid DATA)`));continue}if(!(i.type==="derived"||i.type==="effect")&&!(i.type==="producer"&&!s)){if(i.v!=null){let u=this.tryResolve(o)?.v;if(u!=null&&u.id===i.v.id&&u.version===i.v.version)continue}try{this.set(o,i.value)}catch(a){t?.onError?.(o,a)}}}}}static fromSnapshot(e,t){fn(e);let n=typeof t=="function"?t:t?.build,s=typeof t=="function"?void 0:t?.factories,o=new r(e.name);if(n)return n(o),o.restore(e),o;for(let h of[...e.subgraphs].sort((l,v)=>{let g=l.split($).length,_=v.split($).length;return g!==_?g-_:l<v?-1:l>v?1:0})){let l=h.split($),v=o;for(let g of l)v._mounts.has(g)||v.mount(g,new r(g)),v=v._mounts.get(g)}let i=s?Object.entries(s).map(([h,l])=>({re:et(h),factory:l})):[],a=h=>{for(let l of i)if(l.re.test(h))return l.factory},u=h=>{let l=h.split($),v=l.pop();if(v==null||v.length===0)throw new Error(`invalid snapshot path "${h}"`);let g=o;for(let _ of l){let m=g._mounts.get(_);if(!m)throw new Error(`unknown mount "${_}" in path "${h}"`);g=m}return[g,v]},d=Object.entries(e.nodes).filter(([h])=>!h.includes(`${$}${oe}${$}`)).sort((h,l)=>h[0]<l[0]?-1:h[0]>l[0]?1:0),c=new Map(d),f=new Map,p=!0;for(;c.size>0&&p;){p=!1;for(let[h,l]of[...c.entries()]){let v=l?.deps??[];if(!v.every(b=>f.has(b)))continue;let[g,_]=u(h),m={...l?.meta??{}},y=a(h),w;if(l?.type==="state")w=Y(l.value,{meta:m});else{if(y==null)continue;w=y(_,{path:h,type:l.type,value:l.value,meta:m,deps:v,resolvedDeps:v.map(b=>f.get(b))})}g.add(w,{name:_}),f.set(h,w),c.delete(h),p=!0}}if(c.size>0){let h=[...c.keys()].sort().join(", ");throw new Error(`Graph.fromSnapshot could not reconstruct nodes without build callback: ${h}. Pass matching factories via fromSnapshot(data, { factories: { pattern: factoryFn } }).`)}return o.restore(e),o}toJSON(){return this.snapshot()}attachSnapshotStorage(e,t={}){let n=e.map(d=>({tier:d,debounceMs:Math.max(0,d.debounceMs??0),compactEvery:Math.max(1,d.compactEvery??10),timer:void 0,seq:0,lastSnapshot:void 0,lastFingerprint:"",disposed:!1,savePending:void 0}));t.autoRestore===!0&&this._cascadeRestore(e,t.onError);let s=(d,c)=>{if(d.disposed)return;let f=Xn(c.nodes);if(d.lastSnapshot!=null&&f!==""&&f===d.lastFingerprint)return;let p=d.seq+1,h=He(),g=d.lastSnapshot==null||p%d.compactEvery===0?{name:this.name,mode:"full",snapshot:c,seq:p,timestamp_ns:h,format_version:Te}:{name:this.name,mode:"diff",diff:ir(d.lastSnapshot,c),seq:p,timestamp_ns:h,format_version:Te};if(d.tier.filter&&!d.tier.filter(g))return;let _;try{_=d.tier.save(g)}catch(m){t.onError?.(m,d.tier);return}if(_&&typeof _.then=="function"){let w=(d.savePending??Promise.resolve()).then(()=>_,()=>_).then(()=>{d.disposed||(d.seq=p,d.lastSnapshot=c,d.lastFingerprint=f)},b=>{t.onError?.(b,d.tier)});d.savePending=w.finally(()=>{d.savePending===w&&(d.savePending=void 0)})}else d.seq=p,d.lastSnapshot=c,d.lastFingerprint=f},o=(d,c)=>{try{s(d,c)}catch(f){t.onError?.(f,d.tier)}},i=(d,c)=>{if(!c.some(l=>{let v=this.config.messageTier(l[0]);return v>=3&&v<5}))return;if(t.filter){let l=this.tryResolve(d);if(l==null)return;let v=Me(l,Ce("standard"));if(!t.filter(d,v))return}let p,h=()=>(p==null&&(p=this.snapshot()),p);for(let l of n)l.disposed||(l.debounceMs===0?o(l,h()):(l.timer==null&&(l.timer=new Je),l.timer.start(l.debounceMs,()=>{l.disposed||o(l,this.snapshot())})))},a;if(t.paths!=null){let c=(typeof t.paths=="string"?this._pathsMatching(t.paths):t.paths).map(f=>{let p=this.tryResolve(f);return p==null?()=>{}:p.subscribe(h=>i(f,h))});a=()=>{for(let f of c)f()}}else a=this.observe().subscribe((d,c)=>i(d,c));let u=()=>{a();for(let d of n)d.disposed=!0,d.timer?.cancel();this._storageDisposers.delete(u)};return this._storageDisposers.add(u),{dispose:u}}async _cascadeRestore(e,t){for(let n of e){let s;try{s=await n.load?.()}catch(i){t?.(i,n);continue}if(s==null||typeof s!="object"||Array.isArray(s))continue;let o=s;try{if(o.mode==="full"&&o.snapshot!=null)return this.restore(o.snapshot),!0;if(o.version===Te&&o.nodes!=null)return this.restore(o),!0}catch(i){t?.(i,n)}}return!1}static async fromStorage(e,t,n){for(let s of t){let o;try{o=await s.load?.()}catch(u){n?.onError?.(u,s);continue}if(o==null||typeof o!="object"||Array.isArray(o))continue;let i=o,a=i.mode==="full"&&i.snapshot!=null?i.snapshot:i.version===Te&&i.nodes!=null?i:void 0;if(a!=null)try{return r.fromSnapshot(a,n)}catch(u){n?.onError?.(u,s)}}throw new Error(`Graph.fromStorage: no tier held a restorable record for "${e}" across ${t.length} tier(s)`)}_annotations=new Map;_traceRing;trace(e,t,n){if(e!=null&&t!=null){if(this.tryResolve(e)==null)return;if(this._annotations.set(e,t),this.config.inspectorEnabled){let s={path:e,annotation:t,timestamp_ns:ue(),...n?.actor!=null?{actor:n.actor}:{}};this._traceRing.push(s)}return}return e!=null?this.config.inspectorEnabled?this._annotations.get(e):void 0:this.config.inspectorEnabled?this._traceRing.toArray():[]}annotation(e){return this._annotations.get(e)}clearTrace(){this._annotations.clear(),this._traceRing.clear()}pruneTrace(e){let t=this._traceRing.toArray().filter(s=>!e(s)),n=this._traceRing.size-t.length;this._traceRing.clear();for(let s of t)this._traceRing.push(s);return n}static diff(e,t){let n=new Set(Object.keys(e.nodes)),s=new Set(Object.keys(t.nodes)),o=[...s].filter(m=>!n.has(m)).sort(),i=[...n].filter(m=>!s.has(m)).sort(),a=[],u=[];for(let m of n){if(!s.has(m))continue;let y=e.nodes[m],w=t.nodes[m],b=y.v,x=w.v;b!=null&&x!=null&&b.id===x.id&&b.version!==x.version&&u.push({path:m,id:b.id,from:b.version,to:x.version});let k=b!=null&&x!=null&&b.id===x.id&&b.version===x.version;for(let T of["type","status","sentinel"]){let E=y[T],A=w[T];E!==A&&a.push({path:m,field:T,from:E,to:A})}if(!k)for(let T of["value","meta"]){let E=y[T],A=w[T];Zn(E,A)||a.push({path:m,field:T,from:E,to:A})}}let d=m=>`${m.from} ${m.to}`,c=new Set(e.edges.map(d)),f=new Set(t.edges.map(d)),p=t.edges.filter(m=>!c.has(d(m))),h=e.edges.filter(m=>!f.has(d(m))),l=new Set(e.subgraphs),v=new Set(t.subgraphs),g=[...v].filter(m=>!l.has(m)).sort(),_=[...l].filter(m=>!v.has(m)).sort();return{nodesAdded:o,nodesRemoved:i,nodesChanged:a,versionChanges:u,edgesAdded:p,edgesRemoved:h,subgraphsAdded:g,subgraphsRemoved:_}}}});var pr={};xn(pr,{demoShell:()=>fr});module.exports=Tn(pr);Fe();mt();Ue();zt();bn();function ur(r){for(let e of r){let t=e.codePointAt(0);if(t>=19968&&t<=40959||t>=13312&&t<=19903||t>=12288&&t<=12351||t>=12352&&t<=12447||t>=12448&&t<=12543||t>=44032&&t<=55215||t>=65280&&t<=65519)return!0}return!1}var yn=new Set(["\uFF0C","\uFF0E","\uFF01","\uFF1A","\uFF1B","\uFF1F","\u3001","\u3002","\u30FB","\uFF09","\u3015","\u3009","\u300B","\u300D","\u300F","\u3011"]),dr=new Set([".",",","!","?",":",";",")","]","}","%",'"',"\u201D","\u2019","\xBB","\u203A","\u2026"]);function cr(r){return r.replace(/[\t\n\r\f ]+/g," ").replace(/^ | $/g,"")}function lr(r){let e=new Intl.Segmenter(void 0,{granularity:"word"}),t=[];for(let n of e.segment(r)){let s=n.segment,o=n.isWordLike??!1,i=[],a=[],u=[],d="",c=null;for(let f of s){let p;f===" "?p="space":f==="\u200B"?p="zero-width-break":f==="\xAD"?p="soft-hyphen":f===`
5
+ `?p="hard-break":p="text",c!==null&&p===c?d+=f:(c!==null&&(i.push(d),a.push(c==="text"&&o),u.push(c)),d=f,c=p)}c!==null&&(i.push(d),a.push(c==="text"&&o),u.push(c)),t.push({texts:i,isWordLike:a,kinds:u})}return t}function xt(r,e,t,n,s){let o=cr(r);if(o.length===0)return[];let i=lr(o),a=new Intl.Segmenter(void 0,{granularity:"grapheme"}),u=[],d=[],c=[];for(let _ of i)for(let m=0;m<_.texts.length;m++)u.push(_.texts[m]),d.push(_.kinds[m]),c.push(_.isWordLike[m]);let f=[],p=[],h=[];for(let _=0;_<u.length;_++){let m=u[_],y=d[_],w=c[_];if(y==="text"&&!w&&f.length>0&&p[p.length-1]==="text"&&m.length===1&&(dr.has(m)||yn.has(m))){f[f.length-1]+=m;continue}if(m==="-"&&f.length>0&&p[p.length-1]==="text"&&h[h.length-1]){f[f.length-1]+=m;continue}f.push(m),p.push(y),h.push(w)}let l=n.get(e);l||(l=new Map,n.set(e,l));function v(_){let m=l.get(_);if(m===void 0){s&&(s.misses+=1);let y=t.measureSegment(_,e).width;m=Number.isFinite(y)&&y>=0?y:0,l.set(_,m)}else s&&(s.hits+=1);return m}let g=[];for(let _=0;_<f.length;_++){let m=f[_],y=p[_];if(y!=="text"){g.push({text:m,width:y==="space"?v(" ")*m.length:0,kind:y,graphemeWidths:null});continue}if(ur(m)){let x="";for(let k of a.segment(m)){let T=k.segment;if(x.length>0&&yn.has(T)){x+=T;continue}if(x.length>0){let E=v(x);g.push({text:x,width:E,kind:"text",graphemeWidths:null})}x=T}if(x.length>0){let k=v(x);g.push({text:x,width:k,kind:"text",graphemeWidths:null})}continue}let w=v(m),b=null;if(h[_]&&m.length>1){let x=[];for(let k of a.segment(m))x.push(v(k.segment));x.length>1&&(b=x)}g.push({text:m,width:w,kind:"text",graphemeWidths:b})}return g}function kt(r,e,t,n,s){if(r.length===0)return{lines:[],lineCount:0};let o=[],i=0,a=!1,u=0,d=0,c=0,f=0,p=-1,h=0,l=s.get(n);l||(l=new Map,s.set(n,l));let v=l.get("-");v===void 0&&(v=t.measureSegment("-",n).width,l.set("-",v));function g(b=c,x=f,k=i){let T="";for(let E=u;E<b;E++){let A=r[E];if(!(A.kind==="soft-hyphen"||A.kind==="hard-break"))if(E===u&&d>0&&A.graphemeWidths){let F=[...new Intl.Segmenter(void 0,{granularity:"grapheme"}).segment(A.text)].map(G=>G.segment);T+=F.slice(d).join("")}else T+=A.text}if(x>0&&b<r.length){let E=r[b],S=[...new Intl.Segmenter(void 0,{granularity:"grapheme"}).segment(E.text)].map(G=>G.segment),F=u===b?d:0;T+=S.slice(F,x).join("")}b>0&&r[b-1]?.kind==="soft-hyphen"&&!(u===b&&d>0)&&(T+="-"),o.push({text:T,width:k,startSegment:u,startGrapheme:d,endSegment:b,endGrapheme:x}),i=0,a=!1,p=-1,h=0}function _(b){return b==="space"||b==="zero-width-break"||b==="soft-hyphen"}function m(b,x,k){a=!0,u=b,d=x,c=b+1,f=0,i=k}function y(b,x,k){a=!0,u=b,d=x,c=b,f=x+1,i=k}for(let b=0;b<r.length;b++){let x=r[b];if(x.kind==="hard-break"){a?g():o.push({text:"",width:0,startSegment:b,startGrapheme:0,endSegment:b,endGrapheme:0}),u=b+1,d=0;continue}let k=x.width;if(!a){k>e&&x.graphemeWidths?w(b,0,x.graphemeWidths):m(b,0,k),_(x.kind)&&(p=b+1,h=x.kind==="space"?i-k:i);continue}let T=i+k;if(T>e+.005){if(_(x.kind)){i+=k,c=b+1,f=0,g(b+1,0,x.kind==="space"?i-k:i);continue}if(p>=0){g(p,0,h),b--;continue}if(k>e&&x.graphemeWidths){g(),w(b,0,x.graphemeWidths);continue}g(),b--;continue}i=T,c=b+1,f=0,_(x.kind)&&(p=b+1,h=x.kind==="space"?i-k:i)}return a&&g(),{lines:o,lineCount:o.length};function w(b,x,k){for(let T=x;T<k.length;T++){let E=k[T];if(!a){y(b,T,E);continue}i+E>e+.005?(g(),y(b,T,E)):(i+=E,c=b,f=T+1)}a&&c===b&&f===k.length&&(c=b+1,f=0)}}function Ie(r){return Math.max(0,Math.min(1,r))}function fr(r){let e=Ie(r?.mainRatio??.65),t=Ie(r?.sideSplit??.5),n=Math.max(0,r?.viewportWidth??1280),s=r?.nodeRegistry??new Map,o=r?.adapter??null,i=r?.layoutFont??"14px monospace",a=r?.onHighlight,u=new Pe("demo-shell"),d=Y(e,{name:"pane/main-ratio"}),c=Y(t,{name:"pane/side-split"}),f=Y(null,{name:"pane/fullscreen"}),p=Y(n,{name:"viewport/width"});u.add(d,{name:"pane/main-ratio"}),u.add(c,{name:"pane/side-split"}),u.add(f,{name:"pane/fullscreen"}),u.add(p,{name:"viewport/width"});let h=V([d,p,f],([N,D,R])=>{let X=N,L=D,B=R;return B==="main"?L:B==="graph"||B==="code"?0:Math.round(L*X)},{name:"pane/main-width"}),l=V([h,p,f],([N,D,R])=>{let X=R,L=D;return X==="main"?0:X==="graph"||X==="code"?L:L-N},{name:"pane/side-width"}),v=V([c,f],([N,D])=>{let R=D;return R==="graph"?1:R==="code"||R==="main"?0:Ie(N)},{name:"pane/graph-height-ratio"}),g=V([v,f],([N,D])=>{let R=D;return R==="code"?1:R==="graph"||R==="main"?0:1-N},{name:"pane/code-height-ratio"});u.add(h,{name:"pane/main-width"}),u.add(l,{name:"pane/side-width"}),u.add(v,{name:"pane/graph-height-ratio"}),u.add(g,{name:"pane/code-height-ratio"});let _=Y(null,{name:"demo/graph-ref"}),m=Y(0,{name:"demo/graph-tick"});u.add(_,{name:"demo/graph-ref"}),u.add(m,{name:"demo/graph-tick"});let y=V([_,m],([N,D])=>{let R=N;return R?Ke(R.describe()):""},{name:"graph/mermaid"}),w=V([_,m],([N,D])=>{let R=N;if(!R)return null;let{expand:X,...L}=R.describe({detail:"standard"});return L},{name:"graph/describe"});u.add(y,{name:"graph/mermaid"}),u.add(w,{name:"graph/describe"});let b=Y(null,{name:"hover/target"});u.add(b,{name:"hover/target"});let x=V([b],([N])=>{let D=N;if(!D)return null;let R=s.get(D.id);return R?R.codeLine:null},{name:"highlight/code-scroll"}),k=V([b],([N])=>{let D=N;if(!D)return null;let R=s.get(D.id);return R?R.visualSelector:null},{name:"highlight/visual"}),T=V([b],([N])=>{let D=N;return D?D.id:null},{name:"highlight/graph"});if(u.add(x,{name:"highlight/code-scroll"}),u.add(k,{name:"highlight/visual"}),u.add(T,{name:"highlight/graph"}),a?.codeScroll){let N=a.codeScroll,D=ke([x],([R])=>{N(R)});u.add(D,{name:"highlight/apply-code-scroll"})}if(a?.visual){let N=a.visual,D=ke([k],([R])=>{N(R)});u.add(D,{name:"highlight/apply-visual"})}if(a?.graph){let N=a.graph,D=ke([T],([R])=>{N(R)});u.add(D,{name:"highlight/apply-graph"})}let E=Y(null,{name:"inspect/selected-node"});u.add(E,{name:"inspect/selected-node"});let A=Ce("standard"),S=V([E,_,m],([N,D,R])=>{let X=D,L=N;if(!X||!L)return null;try{let B=X.resolve(L),z=Me(B,A);return{path:L,...z,value:B.cache}}catch{return null}},{name:"inspect/node-detail"}),F=V([_,m],([N,D])=>{let R=N;return R?R.trace():[]},{name:"inspect/trace-log"});u.add(S,{name:"inspect/node-detail"}),u.add(F,{name:"inspect/trace-log"});let G=Y(!1,{name:"meta/debug"});u.add(G,{name:"meta/debug"});let P=V([G,m],([N,D])=>N?Ke(u.describe()):"",{name:"meta/shell-mermaid"});u.add(P,{name:"meta/shell-mermaid"});let ae=Y("",{name:"layout/code-text"});if(u.add(ae,{name:"layout/code-text"}),o){let N=new Map,D=V([w],([L])=>{let B=L;if(!B)return new Map;let z=new Map;for(let[ee]of Object.entries(B.nodes)){let O=xt(ee,i,o,N),C=kt(O,1/0,o,i,N),U=C.lines.reduce((Z,M)=>Math.max(Z,M.width),0),le=C.lineCount*20;z.set(ee,{width:U,height:le})}return z},{name:"layout/graph-labels",equals:(L,B)=>{if(L===B)return!0;let z=L,ee=B;if(z.size!==ee.size)return!1;for(let[O,C]of z){let U=ee.get(O);if(!U||U.width!==C.width||U.height!==C.height)return!1}return!0}}),R=V([ae,l],([L,B])=>{let z=L;if(!z)return{lineCount:0,lines:[]};let ee=xt(z,i,o,N),O=B-40;return kt(ee,Math.max(100,O),o,i,N)},{name:"layout/code-lines"}),X=V([D],([L])=>{let B=L;if(B.size===0)return 200;let z=0;for(let{width:ee}of B.values())ee>z&&(z=ee);return Math.max(200,Math.round(z+80))},{name:"layout/side-width-hint"});u.add(D,{name:"layout/graph-labels"}),u.add(R,{name:"layout/code-lines"}),u.add(X,{name:"layout/side-width-hint"})}let Ne=0;return{graph:u,setMainRatio(N){u.set("pane/main-ratio",Ie(N))},setSideSplit(N){u.set("pane/side-split",Ie(N))},setFullscreen(N){u.set("pane/fullscreen",N)},setViewportWidth(N){u.set("viewport/width",Math.max(0,N))},setHoverTarget(N){u.set("hover/target",N)},setDemoGraph(N){u.set("demo/graph-ref",N)},bumpGraphTick(){u.set("demo/graph-tick",++Ne)},selectNode(N){u.set("inspect/selected-node",N)},setMetaDebug(N){u.set("meta/debug",N)},setCodeText(N){u.set("layout/code-text",N)},batch(N){Ee(N)},destroy(){u.destroy()}}}0&&(module.exports={demoShell});
@@ -1,7 +1,7 @@
1
- import '../../graph-C4SHb3Ly.cjs';
2
- import '../../reactive-layout-Dsvob4zD.cjs';
3
- export { D as DemoShellHandle, a as DemoShellOptions, F as FullscreenPane, G as GraphLabelSize, H as HighlightCallbacks, b as HoverPaneType, c as HoverTarget, N as NodeRegistry, d as demoShell } from '../../index-Dhc7a7Xo.cjs';
4
- import '../../node-ClS5yC-B.cjs';
5
- import '../../meta-vE8bxW1E.cjs';
1
+ import '../../graph-CWvEUQAq.cjs';
2
+ import '../../reactive-layout-DgctbqZo.cjs';
3
+ export { D as DemoShellHandle, a as DemoShellOptions, F as FullscreenPane, G as GraphLabelSize, H as HighlightCallbacks, b as HoverPaneType, c as HoverTarget, N as NodeRegistry, d as demoShell } from '../../index-Cwv0KWcU.cjs';
4
+ import '../../node-kK3CvTrR.cjs';
5
+ import '../../sugar-DQjFmVqb.cjs';
6
6
  import '../../extra/storage-core.cjs';
7
7
  import '../../extra/storage-tiers.cjs';
@@ -1,7 +1,7 @@
1
- import '../../graph-7VguS7a4.js';
2
- import '../../reactive-layout-v7KPvxoc.js';
3
- export { D as DemoShellHandle, a as DemoShellOptions, F as FullscreenPane, G as GraphLabelSize, H as HighlightCallbacks, b as HoverPaneType, c as HoverTarget, N as NodeRegistry, d as demoShell } from '../../index-Dgs8zcj7.js';
4
- import '../../node-ClS5yC-B.js';
5
- import '../../meta-BgVAsg9j.js';
1
+ import '../../graph-D9LFnda9.js';
2
+ import '../../reactive-layout-DOTs9P3X.js';
3
+ export { D as DemoShellHandle, a as DemoShellOptions, F as FullscreenPane, G as GraphLabelSize, H as HighlightCallbacks, b as HoverPaneType, c as HoverTarget, N as NodeRegistry, d as demoShell } from '../../index-B8YnZpIR.js';
4
+ import '../../node-kK3CvTrR.js';
5
+ import '../../sugar-fhLIE7TT.js';
6
6
  import '../../extra/storage-core.js';
7
7
  import '../../extra/storage-tiers.js';
@@ -1 +1 @@
1
- import{a}from"../../chunk-KY2LMAXU.js";import"../../chunk-FUZ6S2DY.js";import"../../chunk-D27JNOLZ.js";import"../../chunk-3G5U5QNE.js";import"../../chunk-C72GO4IZ.js";import"../../chunk-ACMJ2ZPS.js";import"../../chunk-ESMPEKEV.js";import"../../chunk-2K5RXLAH.js";import"../../chunk-35JTVPOX.js";import"../../chunk-LYCLF26R.js";import"../../chunk-CK2E7BTU.js";import"../../chunk-QYADASLV.js";export{a as demoShell};
1
+ import{a}from"../../chunk-ZLV5SQSX.js";import"../../chunk-DHRX7JX4.js";import"../../chunk-7LIAPXJB.js";import"../../chunk-3G5U5QNE.js";import"../../chunk-C72GO4IZ.js";import"../../chunk-HITNVN6B.js";import"../../chunk-ESMPEKEV.js";import"../../chunk-GHBWHMRZ.js";import"../../chunk-CRVT7D2P.js";import"../../chunk-NTEURFZH.js";import"../../chunk-CK2E7BTU.js";import"../../chunk-QYADASLV.js";export{a as demoShell};