@graphrefly/graphrefly 0.30.0 → 0.31.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 (178) hide show
  1. package/dist/{cascading-dNCtjW8j.d.cts → cascading-BfQmSmjU.d.cts} +21 -2
  2. package/dist/{cascading-BszPheHD.d.ts → cascading-D3sapjue.d.ts} +21 -2
  3. package/dist/{chunk-T5SHIKJD.js → chunk-3JRKP4BH.js} +1 -1
  4. package/dist/{chunk-GJR3P6JG.js → chunk-3Q2WXM6X.js} +1 -1
  5. package/dist/chunk-4KAUNEKV.js +3 -0
  6. package/dist/{chunk-SLMYTGTU.js → chunk-4UUDNFYG.js} +1 -1
  7. package/dist/chunk-4VXL3UZK.js +1 -0
  8. package/dist/{chunk-AV3PIDFQ.js → chunk-4ZPO2EL5.js} +1 -1
  9. package/dist/{chunk-VWPRPPKR.js → chunk-5LJAQTSS.js} +1 -1
  10. package/dist/{chunk-W4TSQ6RJ.js → chunk-7AJKUA36.js} +1 -1
  11. package/dist/{chunk-RD52SNH2.js → chunk-7EJTWGKW.js} +1 -1
  12. package/dist/{chunk-GNCBXARM.js → chunk-7EQPXQ7H.js} +1 -1
  13. package/dist/chunk-7QMVU3IX.js +1 -0
  14. package/dist/{chunk-BA5URFYW.js → chunk-A4JT4SAD.js} +1 -1
  15. package/dist/chunk-ASDKRNOJ.js +60 -0
  16. package/dist/{chunk-Y32RJO24.js → chunk-CZVYLXFK.js} +1 -1
  17. package/dist/{chunk-567NWZ3T.js → chunk-DWIAG62L.js} +1 -1
  18. package/dist/{chunk-33FA6V4B.js → chunk-EBQ6FXKW.js} +1 -1
  19. package/dist/chunk-FTA5TB2A.js +1 -0
  20. package/dist/{chunk-P7JXGKDO.js → chunk-GF5T7PGC.js} +1 -1
  21. package/dist/{chunk-WANIEEKV.js → chunk-I4U3TPK2.js} +1 -1
  22. package/dist/{chunk-KA6MMXIY.js → chunk-JMGGCSIC.js} +1 -1
  23. package/dist/chunk-JXRZXP3N.js +1 -0
  24. package/dist/{chunk-5Z4HDCO6.js → chunk-K54OKWNY.js} +1 -1
  25. package/dist/{chunk-DDPYNMGG.js → chunk-KN4Q5MQO.js} +1 -1
  26. package/dist/chunk-LWGLBCMU.js +1 -0
  27. package/dist/{chunk-TWMEGG45.js → chunk-N2KKISCE.js} +1 -1
  28. package/dist/{chunk-4OFIQ66T.js → chunk-OKQUPJRY.js} +1 -1
  29. package/dist/chunk-PNTBXOQ6.js +5 -0
  30. package/dist/chunk-PSQNYY72.js +7 -0
  31. package/dist/{chunk-XHVB6G6M.js → chunk-PZP4MEXK.js} +1 -1
  32. package/dist/{chunk-7TDOES3L.js → chunk-Q2SY7M7K.js} +1 -1
  33. package/dist/{chunk-OL33ZI6R.js → chunk-RWGJQQLT.js} +1 -1
  34. package/dist/chunk-SGS4OJGS.js +1 -0
  35. package/dist/chunk-UMH3HSP7.js +1 -0
  36. package/dist/{chunk-BZP5T4X6.js → chunk-W6FQIFVE.js} +1 -1
  37. package/dist/{chunk-SHYH5SXV.js → chunk-WLPVGXQ6.js} +1 -1
  38. package/dist/chunk-WQ7I7JVU.js +1 -0
  39. package/dist/{chunk-XQAXYVXX.js → chunk-WYJTXYWX.js} +1 -1
  40. package/dist/{chunk-3NEPQO2E.js → chunk-X2VHDT26.js} +1 -1
  41. package/dist/{chunk-GLSM33ZM.js → chunk-XEFAMCEA.js} +1 -1
  42. package/dist/{chunk-AUY2YKCO.js → chunk-XRSHMHEG.js} +1 -1
  43. package/dist/chunk-Y26UN6J5.js +18 -0
  44. package/dist/{chunk-BKPLTBL5.js → chunk-YQJPYEAL.js} +1 -1
  45. package/dist/{chunk-73Z3W2RN.js → chunk-YZ6VYLFD.js} +1 -1
  46. package/dist/{chunk-4JJCCD5S.js → chunk-YZKGGMPT.js} +1 -1
  47. package/dist/chunk-Z3UWIJ3A.js +1 -0
  48. package/dist/{chunk-Y36UZ5VS.js → chunk-ZM7C2FUM.js} +1 -1
  49. package/dist/compat/index.cjs +1 -1
  50. package/dist/compat/index.js +1 -1
  51. package/dist/compat/jotai/index.cjs +1 -1
  52. package/dist/compat/jotai/index.js +1 -1
  53. package/dist/compat/nanostores/index.cjs +1 -1
  54. package/dist/compat/nanostores/index.js +1 -1
  55. package/dist/compat/nestjs/index.cjs +5 -5
  56. package/dist/compat/nestjs/index.js +1 -1
  57. package/dist/compat/zustand/index.cjs +1 -1
  58. package/dist/compat/zustand/index.js +1 -1
  59. package/dist/{composite-DGspwCqk.d.ts → composite-BY9hMxN7.d.ts} +1 -1
  60. package/dist/{composite-nrRumJ7l.d.cts → composite-CH0S8DFn.d.cts} +1 -1
  61. package/dist/content-addressed-storage-BUiREIuj.d.ts +124 -0
  62. package/dist/content-addressed-storage-DqIWCmZG.d.cts +124 -0
  63. package/dist/core/index.cjs +1 -1
  64. package/dist/core/index.js +1 -1
  65. package/dist/extra/browser.cjs +1 -1
  66. package/dist/extra/browser.js +1 -1
  67. package/dist/extra/index.cjs +18 -18
  68. package/dist/extra/index.d.cts +6 -5
  69. package/dist/extra/index.d.ts +6 -5
  70. package/dist/extra/index.js +1 -1
  71. package/dist/extra/node.cjs +2 -2
  72. package/dist/extra/node.js +1 -1
  73. package/dist/extra/operators.cjs +1 -1
  74. package/dist/extra/operators.d.cts +41 -1
  75. package/dist/extra/operators.d.ts +41 -1
  76. package/dist/extra/operators.js +1 -1
  77. package/dist/extra/reactive.cjs +1 -1
  78. package/dist/extra/reactive.d.cts +1 -1
  79. package/dist/extra/reactive.d.ts +1 -1
  80. package/dist/extra/reactive.js +1 -1
  81. package/dist/extra/sources.cjs +1 -1
  82. package/dist/extra/sources.d.cts +62 -2
  83. package/dist/extra/sources.d.ts +62 -2
  84. package/dist/extra/sources.js +1 -1
  85. package/dist/extra/storage-browser.cjs +1 -1
  86. package/dist/extra/storage-browser.js +1 -1
  87. package/dist/{fallback-BaTS7vVY.d.cts → fallback-Cb3GH1O7.d.cts} +6 -14
  88. package/dist/{fallback-eOm3LNxP.d.ts → fallback-DRjJ_ZM8.d.ts} +6 -14
  89. package/dist/graph/index.cjs +4 -4
  90. package/dist/graph/index.js +1 -1
  91. package/dist/{index-ClB7TCfL.d.cts → index-BMe3pCom.d.cts} +1 -1
  92. package/dist/{index-Dljd76bC.d.ts → index-BXzl1NDD.d.ts} +1 -1
  93. package/dist/{index-ClgKmOHe.d.ts → index-Bd6oFZqO.d.ts} +223 -115
  94. package/dist/{index-BJHQUCZx.d.ts → index-CJymKyzT.d.ts} +81 -6
  95. package/dist/{index-D6ajK8Mh.d.cts → index-CZChc85Q.d.cts} +223 -115
  96. package/dist/{index-BXbQUn4n.d.ts → index-CcS0t-l2.d.ts} +1 -1
  97. package/dist/{index-B2HBxvMb.d.ts → index-CwhcFzTA.d.ts} +1 -1
  98. package/dist/{index-B8Aj_z8S.d.cts → index-D-kHVedZ.d.cts} +1 -1
  99. package/dist/{index-ybtSyjWB.d.cts → index-DD7RhHNJ.d.cts} +1 -1
  100. package/dist/{index-BHu_Wba0.d.cts → index-Dm3_D5Ta.d.cts} +1 -1
  101. package/dist/{index-Cc8VQIgL.d.ts → index-DxMS0cHM.d.ts} +1 -1
  102. package/dist/{index-BS220yqj.d.cts → index-gJQqJTKx.d.cts} +81 -6
  103. package/dist/index.cjs +99 -121
  104. package/dist/index.d.cts +14 -13
  105. package/dist/index.d.ts +14 -13
  106. package/dist/index.js +1 -1
  107. package/dist/patterns/ai/browser.cjs +5 -22
  108. package/dist/patterns/ai/browser.d.cts +3 -3
  109. package/dist/patterns/ai/browser.d.ts +3 -3
  110. package/dist/patterns/ai/browser.js +1 -1
  111. package/dist/patterns/ai/index.cjs +27 -44
  112. package/dist/patterns/ai/index.d.cts +9 -7
  113. package/dist/patterns/ai/index.d.ts +9 -7
  114. package/dist/patterns/ai/index.js +1 -1
  115. package/dist/patterns/ai/node.cjs +2 -2
  116. package/dist/patterns/ai/node.d.cts +5 -4
  117. package/dist/patterns/ai/node.d.ts +5 -4
  118. package/dist/patterns/ai/node.js +1 -1
  119. package/dist/patterns/audit/index.cjs +3 -3
  120. package/dist/patterns/audit/index.js +1 -1
  121. package/dist/patterns/cqrs/index.cjs +6 -6
  122. package/dist/patterns/cqrs/index.js +1 -1
  123. package/dist/patterns/demo-shell/index.cjs +1 -1
  124. package/dist/patterns/demo-shell/index.js +1 -1
  125. package/dist/patterns/domain-templates/index.cjs +4 -4
  126. package/dist/patterns/domain-templates/index.js +1 -1
  127. package/dist/patterns/graphspec/index.cjs +6 -6
  128. package/dist/patterns/graphspec/index.d.cts +2 -2
  129. package/dist/patterns/graphspec/index.d.ts +2 -2
  130. package/dist/patterns/graphspec/index.js +1 -1
  131. package/dist/patterns/guarded-execution/index.cjs +7 -7
  132. package/dist/patterns/guarded-execution/index.js +1 -1
  133. package/dist/patterns/harness/index.cjs +11 -11
  134. package/dist/patterns/harness/index.d.cts +2 -2
  135. package/dist/patterns/harness/index.d.ts +2 -2
  136. package/dist/patterns/harness/index.js +1 -1
  137. package/dist/patterns/job-queue/index.cjs +5 -5
  138. package/dist/patterns/job-queue/index.js +1 -1
  139. package/dist/patterns/lens/index.cjs +5 -5
  140. package/dist/patterns/lens/index.d.cts +2 -2
  141. package/dist/patterns/lens/index.d.ts +2 -2
  142. package/dist/patterns/lens/index.js +1 -1
  143. package/dist/patterns/memory/index.cjs +4 -4
  144. package/dist/patterns/memory/index.js +1 -1
  145. package/dist/patterns/messaging/index.cjs +5 -5
  146. package/dist/patterns/messaging/index.js +1 -1
  147. package/dist/patterns/orchestration/index.cjs +1 -1
  148. package/dist/patterns/orchestration/index.js +1 -1
  149. package/dist/patterns/reactive-layout/index.cjs +1 -1
  150. package/dist/patterns/reactive-layout/index.js +1 -1
  151. package/dist/patterns/reduction/index.cjs +5 -5
  152. package/dist/patterns/reduction/index.js +1 -1
  153. package/dist/patterns/refine-loop/index.cjs +8 -8
  154. package/dist/patterns/refine-loop/index.js +1 -1
  155. package/dist/patterns/resilient-pipeline/index.cjs +1 -1
  156. package/dist/patterns/resilient-pipeline/index.js +1 -1
  157. package/dist/patterns/surface/index.cjs +7 -7
  158. package/dist/patterns/surface/index.d.cts +3 -3
  159. package/dist/patterns/surface/index.d.ts +3 -3
  160. package/dist/patterns/surface/index.js +1 -1
  161. package/dist/{reactive-map-BvDrRuwt.d.ts → reactive-map-CtRaCddO.d.ts} +59 -1
  162. package/dist/{reactive-map-CmlPPKHN.d.cts → reactive-map-IJIfZxoh.d.cts} +59 -1
  163. package/dist/{resilience-XRUF267O.js → resilience-IVNDYORD.js} +1 -1
  164. package/dist/{types-O3GzJY2U.d.cts → types-BgMqbc7N.d.cts} +41 -14
  165. package/dist/{types-u64Ose53.d.ts → types-CdfO2QTt.d.ts} +41 -14
  166. package/package.json +1 -1
  167. package/dist/chunk-2GQREQ6C.js +0 -1
  168. package/dist/chunk-4C2OR2GH.js +0 -18
  169. package/dist/chunk-5JDE5JHE.js +0 -1
  170. package/dist/chunk-7JDLFI6N.js +0 -1
  171. package/dist/chunk-AMBYCIOH.js +0 -3
  172. package/dist/chunk-ISCENNXS.js +0 -1
  173. package/dist/chunk-IUK4EFCE.js +0 -1
  174. package/dist/chunk-KASHOCF5.js +0 -1
  175. package/dist/chunk-LI3E75VE.js +0 -64
  176. package/dist/chunk-MGKAO4EK.js +0 -7
  177. package/dist/chunk-NSG4C6BF.js +0 -23
  178. package/dist/chunk-VIEUJSTT.js +0 -1
@@ -1,15 +1,15 @@
1
- "use strict";var kr=Object.create;var we=Object.defineProperty;var nn=Object.getOwnPropertyDescriptor;var Rr=Object.getOwnPropertyNames;var Cr=Object.prototype.hasOwnProperty;var rn=(t,e)=>(e=Symbol[t])?e:Symbol.for("Symbol."+t),He=t=>{throw TypeError(t)};var Mr=(t,e,n)=>e in t?we(t,e,{enumerable:!0,configurable:!0,writable:!0,value:n}):t[e]=n;var Zt=(t,e)=>we(t,"name",{value:e,configurable:!0});var V=(t,e)=>()=>(t&&(e=t(t=0)),e);var Dr=(t,e)=>{for(var n in e)we(t,n,{get:e[n],enumerable:!0})},Ar=(t,e,n,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let o of Rr(e))!Cr.call(t,o)&&o!==n&&we(t,o,{get:()=>e[o],enumerable:!(r=nn(e,o))||r.enumerable});return t};var Gr=t=>Ar(we({},"__esModule",{value:!0}),t);var on=t=>[,,,kr(t?.[rn("metadata")]??null)],sn=["class","method","getter","setter","accessor","field","value","get","set"],$e=t=>t!==void 0&&typeof t!="function"?He("Function expected"):t,Ir=(t,e,n,r,o)=>({kind:sn[t],name:e,metadata:r,addInitializer:s=>n._?He("Already initialized"):o.push($e(s||null))}),Lr=(t,e)=>Mr(e,rn("metadata"),t[3]),an=(t,e,n,r)=>{for(var o=0,s=t[e>>1],i=s&&s.length;o<i;o++)e&1?s[o].call(n):r=s[o].call(n,r);return r},un=(t,e,n,r,o,s)=>{var i,a,d,u,l,f=e&7,p=!!(e&8),h=!!(e&16),c=f>3?t.length+1:f?p?1:2:0,g=sn[f+5],m=f>3&&(t[c-1]=[]),v=t[c]||(t[c]=[]),_=f&&(!h&&!p&&(o=o.prototype),f<5&&(f>3||!h)&&nn(f<4?o:{get[n](){return en(this,s)},set[n](b){return tn(this,s,b)}},n));f?h&&f<4&&Zt(s,(f>2?"set ":f>1?"get ":"")+n):Zt(o,n);for(var y=r.length-1;y>=0;y--)u=Ir(f,n,d={},t[3],v),f&&(u.static=p,u.private=h,l=u.access={has:h?b=>Pr(o,b):b=>n in b},f^3&&(l.get=h?b=>(f^1?en:$r)(b,o,f^4?s:_.get):b=>b[n]),f>2&&(l.set=h?(b,x)=>tn(b,o,x,f^4?s:_.set):(b,x)=>b[n]=x)),a=(0,r[y])(f?f<4?h?s:_[g]:f>4?void 0:{get:_.get,set:_.set}:o,u),d._=1,f^4||a===void 0?$e(a)&&(f>4?m.unshift(a):f?h?s=a:_[g]=a:o=a):typeof a!="object"||a===null?He("Object expected"):($e(i=a.get)&&(_.get=i),$e(i=a.set)&&(_.set=i),$e(i=a.init)&&m.unshift(i));return f||Lr(t,o),_&&we(o,n,_),h?f^4?s:_:o};var Ot=(t,e,n)=>e.has(t)||He("Cannot "+n),Pr=(t,e)=>Object(e)!==e?He('Cannot use the "in" operator on this value'):t.has(e),en=(t,e,n)=>(Ot(t,e,"read from private field"),n?n.call(t):e.get(t));var tn=(t,e,n,r)=>(Ot(t,e,"write to private field"),r?r.call(t,n):e.set(t,n),n),$r=(t,e,n)=>(Ot(t,e,"access private method"),n);var Fe,C,W,Z,ee,K,te,F,L,A,xe,Nt,Hr,St,Fr,qr,kt,dn,cn,ln,Rt,re=V(()=>{"use strict";Fe=Symbol.for("graphrefly/START"),C=Symbol.for("graphrefly/DATA"),W=Symbol.for("graphrefly/DIRTY"),Z=Symbol.for("graphrefly/RESOLVED"),ee=Symbol.for("graphrefly/INVALIDATE"),K=Symbol.for("graphrefly/PAUSE"),te=Symbol.for("graphrefly/RESUME"),F=Symbol.for("graphrefly/TEARDOWN"),L=Symbol.for("graphrefly/COMPLETE"),A=Symbol.for("graphrefly/ERROR"),xe=Object.freeze([W]),Nt=Object.freeze([Z]),Hr=Object.freeze([ee]),St=Object.freeze([Fe]),Fr=Object.freeze([L]),qr=Object.freeze([F]),kt=Object.freeze([xe]),dn=Object.freeze([Nt]),cn=Object.freeze([Hr]),ln=Object.freeze([Fr]),Rt=Object.freeze([qr])});function Ce(){return Math.trunc(performance.now()*1e6)}function ae(){return Date.now()*1e6}var je=V(()=>{"use strict"});function En(t,e){let n=new TextEncoder().encode(t.name);if(n.length===0||n.length>255)throw new Error(`encodeEnvelope: codec name "${t.name}" encodes to ${n.length} bytes (must be 1\u2013255)`);let r=t.version;if(!Number.isInteger(r)||r<0||r>65535)throw new Error(`encodeEnvelope: codec.version ${r} out of u16 range (expected integer 0\u201365535)`);let o=2+n.length+2+e.length;if(o>4294967295)throw new Error(`encodeEnvelope: total envelope size ${o} exceeds 2^32-1 bytes (payload ${e.length} bytes)`);let s=new Uint8Array(o),i=0;return s[i++]=Mt,s[i++]=n.length,s.set(n,i),i+=n.length,s[i++]=r>>>8&255,s[i++]=r&255,s.set(e,i),s}function On(t,e){if(t.length<Tn)throw new Error(`decodeEnvelope: bytes too short (${t.length} < ${Tn})`);let n=0,r=t[n++];if(r!==Mt)throw new Error(`decodeEnvelope: unsupported envelope version ${r} (expected ${Mt})`);let o=t[n++];if(o===0)throw new Error("decodeEnvelope: name_len must be >= 1");if(n+o+2>t.length)throw new Error(`decodeEnvelope: envelope truncated (need ${n+o+2} bytes, have ${t.length})`);let s=new TextDecoder().decode(t.subarray(n,n+o));n+=o;let i=(t[n]<<8|t[n+1])>>>0;n+=2;let a=t.subarray(n),d=e.lookupCodec(s);if(d==null)throw new Error(`decodeEnvelope: codec "${s}" not registered (envelope codec_v=${i})`);return{codec:d,codecVersion:i,payload:a}}function Nn(t){t.registerCodec(jr)}var jr,Mt,Tn,Dt=V(()=>{"use strict";jr={name:"json",version:1,contentType:"application/json",encode(t){let e=JSON.stringify(t);return new TextEncoder().encode(e)},decode(t,e){let n=new TextDecoder().decode(t);return JSON.parse(n)}},Mt=1,Tn=4});function he(t){if(t==null)return ue;let{type:e,id:n,...r}=t;return{type:e??"system",id:n??"",...r}}var ue,Be=V(()=>{"use strict";ue={type:"system",id:""}});function et(){return Me>0||Ve}function Sn(){return Me>0}function ze(t){Me>0?We.push(t):t()}function Ae(t){Me+=1;let e=!1;try{t()}catch(n){throw e=!0,n}finally{if(Me-=1,Me===0)if(e){if(!Ve){let n=We.splice(0);for(let r of n)try{r()}catch{}ge.length=0,me.length=0,De.length=0}}else Br()}}function Br(){let t=!Ve;t&&(Ve=!0);let e=[],n=0;try{for(;ge.length>0||me.length>0||De.length>0||t&&We.length>0;){if(t&&We.length>0){let s=We.splice(0);for(let i of s)try{i()}catch(a){e.push(a)}continue}if(n+=1,n>1e3)throw ge.length=0,me.length=0,De.length=0,new Error("batch drain exceeded 1000 iterations \u2014 likely a reactive cycle");let o=(ge.length>0?ge:me.length>0?me:De).splice(0);for(let s of o)try{s()}catch(i){e.push(i)}}}finally{t&&(Ve=!1)}if(e.length===1)throw e[0];if(e.length>1)throw new AggregateError(e,"batch drain: multiple callbacks threw")}function tt(t,e,n){if(e.length===0)return;if(e.length===1){let u=n(e[0][0]);if(u<3||!et()){t(e);return}(u>=5?De:u===4?me:ge).push(()=>t(e));return}let r=e.length,o=r,s=r,i=r,a=0;for(;a<r&&n(e[a][0])<3;)a++;for(o=a;a<r&&n(e[a][0])===3;)a++;for(s=a;a<r&&n(e[a][0])===4;)a++;i=a;let d=et();if(o>0){let u=e.slice(0,o);t(u)}if(s>o){let u=e.slice(o,s);d?ge.push(()=>t(u)):t(u)}if(i>s){let u=e.slice(s,i);d?me.push(()=>t(u)):t(u)}if(r>i){let u=e.slice(i,r);d?De.push(()=>t(u)):t(u)}}var Me,Ve,ge,me,De,We,Ue=V(()=>{"use strict";Me=0,Ve=!1,ge=[],me=[],De=[],We=[]});function kn(t){t.registerMessageType(Fe,{tier:0,wireCrossing:!1}),t.registerMessageType(W,{tier:1,wireCrossing:!1}),t.registerMessageType(ee,{tier:1,wireCrossing:!1,metaPassthrough:!1}),t.registerMessageType(K,{tier:2,wireCrossing:!1}),t.registerMessageType(te,{tier:2,wireCrossing:!1}),t.registerMessageType(C,{tier:3,wireCrossing:!0}),t.registerMessageType(Z,{tier:3,wireCrossing:!0}),t.registerMessageType(L,{tier:4,wireCrossing:!0,metaPassthrough:!1}),t.registerMessageType(A,{tier:4,wireCrossing:!0,metaPassthrough:!1}),t.registerMessageType(F,{tier:5,wireCrossing:!0,metaPassthrough:!1})}var nt,Rn=V(()=>{"use strict";re();nt=class{_messageTypes=new Map;_codecs=new Map;_onMessage;_onSubscribe;_defaultVersioning;_defaultHashFn;_inspectorEnabled=!(typeof process<"u"&&process.env?.NODE_ENV==="production");_globalInspector;_frozen=!1;tierOf;constructor(e){this._onMessage=e.onMessage,this._onSubscribe=e.onSubscribe,this._defaultVersioning=e.defaultVersioning,this._defaultHashFn=e.defaultHashFn,this.tierOf=n=>{let r=this._messageTypes.get(n);return r!=null?r.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}registerMessageType(e,n){return this._assertUnfrozen(),this._messageTypes.set(e,{tier:n.tier,wireCrossing:n.wireCrossing??n.tier>=3,metaPassthrough:n.metaPassthrough??!0}),this}messageTier(e){let n=this._messageTypes.get(e);return n!=null?n.tier:1}isWireCrossing(e){let n=this._messageTypes.get(e);return n!=null?n.wireCrossing:!0}isLocalOnly(e){return!this.isWireCrossing(e)}isMetaPassthrough(e){let n=this._messageTypes.get(e);return n!=null?n.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 Cn(t){return Array.isArray(t)?[...t]:[t]}function Vr(t,e){return t.has(e)||t.has("*")}function rt(t){let e=[];return t((o,s)=>{e.push({kind:"allow",actions:new Set(Cn(o)),where:s?.where??(()=>!0)})},(o,s)=>{e.push({kind:"deny",actions:new Set(Cn(o)),where:s?.where??(()=>!0)})}),(o,s)=>{let i=!1,a=!1;for(let d of e)Vr(d.actions,s)&&d.where(o)&&(d.kind==="deny"?i=!0:a=!0);return i?!1:a}}function At(t){let e=Wr.filter(n=>t({type:n,id:""},"write"));return e.length===0?"restricted":e.includes("human")&&e.includes("llm")&&e.every(n=>n==="human"||n==="llm"||n==="system")?"both":e.length===1?e[0]:e.join("+")}var J,Wr,Ge=V(()=>{"use strict";J=class extends Error{actor;action;nodeName;constructor(e,n){super(n??`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}};Wr=["human","llm","wallet","system"]});function Gt(t){if(t===void 0)return null;if(typeof t=="number"){if(!Number.isFinite(t))throw new TypeError(`Cannot hash non-finite number: ${t}`);if(Number.isInteger(t)&&!Number.isSafeInteger(t))throw new TypeError(`Cannot hash integer outside safe range (|n| > 2^53-1): ${t}. Cross-language cid parity is not guaranteed for unsafe integers.`);return t}if(typeof t=="string"||typeof t=="boolean"||t===null)return t;if(Array.isArray(t))return t.map(Gt);if(typeof t=="object"&&t!==null){let e={};for(let n of Object.keys(t).sort())e[n]=Gt(t[n]);return e}return null}function Kr(t){let e=Ur.encode(t),n=e.length,r=n*8,o=n+9+63&-64,s=new Uint8Array(o);s.set(e),s[n]=128;let i=new DataView(s.buffer);i.setUint32(o-4,r>>>0,!1),i.setUint32(o-8,Math.floor(r/4294967296)>>>0,!1);let a=1779033703,d=3144134277,u=1013904242,l=2773480762,f=1359893119,p=2600822924,h=528734635,c=1541459225,g=new Uint32Array(64),m=(_,y)=>_>>>y|_<<32-y;for(let _=0;_<o;_+=64){for(let S=0;S<16;S++)g[S]=i.getUint32(_+S*4,!1);for(let S=16;S<64;S++){let R=g[S-15],k=g[S-2],$=m(R,7)^m(R,18)^R>>>3,B=m(k,17)^m(k,19)^k>>>10;g[S]=g[S-16]+$+g[S-7]+B>>>0}let y=a,b=d,x=u,T=l,w=f,E=p,N=h,M=c;for(let S=0;S<64;S++){let R=m(w,6)^m(w,11)^m(w,25),k=w&E^~w&N,$=M+R+k+zr[S]+g[S]>>>0,B=m(y,2)^m(y,13)^m(y,22),X=y&b^y&x^b&x,fe=B+X>>>0;M=N,N=E,E=w,w=T+$>>>0,T=x,x=b,b=y,y=$+fe>>>0}a=a+y>>>0,d=d+b>>>0,u=u+x>>>0,l=l+T>>>0,f=f+w>>>0,p=p+E>>>0,h=h+N>>>0,c=c+M>>>0}let v=_=>_.toString(16).padStart(8,"0");return v(a)+v(d)+v(u)+v(l)+v(f)+v(p)+v(h)+v(c)}function It(t){let e=Gt(t??null),n=JSON.stringify(e);return Kr(n).slice(0,16)}function Yr(){let t=globalThis.crypto;if(t?.randomUUID)return t.randomUUID();let e=()=>Math.floor(Math.random()*4294967296).toString(16).padStart(8,"0"),n=e()+e()+e()+e();return`${n.slice(0,8)}-${n.slice(8,12)}-4${n.slice(13,16)}-${(parseInt(n.slice(16,17),16)&3|8).toString(16)}${n.slice(17,20)}-${n.slice(20,32)}`}function Lt(t,e,n){let r=n?.id??Yr();if(t===0)return{id:r,version:0};let s=(n?.hash??It)(e);return{id:r,version:0,cid:s,prev:null}}function Mn(t,e,n){t.version+=1,"cid"in t&&(t.prev=t.cid,t.cid=n(e))}var zr,Ur,Dn=V(()=>{"use strict";zr=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]),Ur=new TextEncoder});function In(t){return{node:t,unsub:null,prevData:void 0,dirty:!1,involvedThisWave:!1,dataBatch:[],terminal:void 0}}function Pt(t){t.prevData=void 0,t.dirty=!1,t.involvedThisWave=!1,t.dataBatch.length=0,t.terminal=void 0}function ot(t){return t.length===0?t:typeof t[0]=="symbol"?[t]:t}function be(t,e,n){let r=Ln(t)?t:[],o=typeof t=="function"?t:typeof e=="function"?e:void 0,s={};return Ln(t)?s=($t(e)?e:n)??{}:$t(t)?s=t:s=($t(e)?e:n)??{},new P(r,o,s)}var An,Gn,Jr,Qr,ye,P,Ln,$t,Ie=V(()=>{"use strict";Dt();Be();Ue();je();Rn();Ge();re();Dn();An=()=>{},Gn=100;Jr=(t,e,n,r)=>{n.direction==="down-in"&&t._onDepMessage(n.depIndex,e)},Qr=(t,e,n,r)=>{let o=t;if(o._status==="completed"||o._status==="errored")return;let s=o._cached,i=s===void 0?[St]:[St,[C,s]];o._status==="dirty"&&i.push(xe),tt(e,i,o._config.tierOf)},ye=new nt({onMessage:Jr,onSubscribe:Qr});kn(ye);Nn(ye);P=class t{_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,n,r){this._config=r.config??ye,this._config.onMessage,this._optsName=r.name,this._describeKind=r.describeKind,this._equals=r.equals??Object.is,this._resubscribable=r.resubscribable??!1,this._resetOnTeardown=r.resetOnTeardown??!1,this._autoComplete=r.completeWhenDepsComplete??!0,this._autoError=r.errorWhenDepsError??!0,this._pausable=r.pausable??!0,this._guard=r.guard,this._fn=n,this._partial=r.partial??!1,this._cached=r.initial!==void 0?r.initial:void 0,this._status=e.length===0&&n==null&&this._cached!==void 0?"settled":"sentinel",this._hashFn=r.versioningHash??this._config.defaultHashFn??It;let o=r.versioning??this._config.defaultVersioning;this._versioningLevel=o,this._versioning=o!=null?Lt(o,this._cached===void 0?void 0:this._cached,{id:r.versioningId,hash:this._hashFn}):void 0,this._deps=e.map(In);let s={};for(let[a,d]of Object.entries(r.meta??{})){let u={initial:d,name:`${r.name??"node"}:meta:${a}`,describeKind:"state",config:this._config};r.guard!=null&&(u.guard=r.guard),s[a]=new t([],void 0,u)}Object.freeze(s),this.meta=s,this._hasMeta=Object.keys(s).length>0;let i=this;this._actions={emit(a){i._emit([[C,a]])},down(a){i._emit(ot(a))},up(a){i._emitUp(ot(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,n){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 r=this._versioningLevel;if(r!=null&&e<=r)return;let o=n?.hash??this._hashFn;o!==this._hashFn&&(this._hashFn=o);let s=this._cached===void 0?void 0:this._cached,i=this._versioning,a=i?.id??n?.id,d=i?.version??0,u=Lt(e,s,{id:a,hash:o});u.version=d,this._versioning=u,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 n=he(e);if(this._guard!=null&&!this._guard(n,"observe"))return!1;if(this._extraGuards!=null){for(let r of this._extraGuards)if(!r(n,"observe"))return!1}return!0}_checkGuard(e){if(e?.internal)return;let n=this._guard!=null||this._extraGuards!=null,r=e?.actor!=null;if(!n&&!r)return;let o=he(e?.actor),s=e?.delivery==="signal"?"signal":"write";if(this._guard!=null&&!this._guard(o,s))throw new J({actor:o,action:s,nodeName:this.name});if(this._extraGuards!=null){for(let i of this._extraGuards)if(!i(o,s))throw new J({actor:o,action:s,nodeName:this.name})}this._lastMutation={actor:o,timestamp_ns:ae()}}down(e,n){let r=ot(e);r.length!==0&&(this._checkGuard(n),this._emit(r))}emit(e,n){this._checkGuard(n),this._emit([[C,e]])}up(e,n){if(this._deps.length===0)return;let r=ot(e);if(r.length===0)return;this._checkGuard(n);let o=n??{internal:!0};this._validateUpTiers(r);for(let s of this._deps)s.node.up?.(r,o)}_emitUp(e){if(this._deps.length!==0&&e.length!==0){this._validateUpTiers(e);for(let n of this._deps)n.node.up?.(e,{internal:!0})}}_validateUpTiers(e){let n=this._config.tierOf;for(let r of e){let o=n(r[0]);if(o===3||o===4)throw new Error(`Node "${this.name}": tier-${o} 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,n){if(n!=null&&this._guard!=null){let d=he(n);if(!this._guard(d,"observe"))throw new J({actor:d,action:"observe",nodeName:this.name})}let o=this._isTerminal&&this._resubscribable;if(o){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 d of this._deps)Pt(d);if(this._partial===!1){for(let d of this._deps)if(d.prevData!==void 0||d.dataBatch.length!==0||d.terminal!==void 0||d.dirty)throw new Error(`resubscribable-reset invariant: DepRecord not fully reset for node ${this._optsName??"(anonymous)"}`)}}this._sinkCount+=1;let s;try{s=this._config.onSubscribe(this,e,{sinkCount:this._sinkCount,afterTerminalReset:o},this._actions)}catch(d){throw this._sinkCount-=1,d}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(d){if(this._sinkCount-=1,this._removeSink(e),this._sinkCount===0&&(this._status="sentinel"),typeof s=="function")try{s()}catch{}throw d}this._status==="sentinel"&&this._cached===void 0&&(this._status="pending");let a=!1;return()=>{a||(a=!0,this._sinkCount-=1,this._removeSink(e),typeof s=="function"&&s(),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[n]=this._sinks;this._sinks=n}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,n=0;try{for(let r=0;r<e;r++){let o=r,s=this._deps[r];s.unsub=An,s.unsub=s.node.subscribe(i=>{if(s.unsub===null)return;let a=this._config.tierOf,d=!1;for(let u of i)a(u[0])>=3&&(d=!0),this._config.onMessage(this,u,{direction:"down-in",depIndex:o},this._actions);d&&this._maybeRunFnOnSettlement()}),n++}}catch(r){this._deps[n].unsub=null;for(let o=0;o<n;o++){let s=this._deps[o];if(s.unsub!=null){let i=s.unsub;s.unsub=null;try{i()}catch{}Pt(s)}}throw this._dirtyDepCount=0,r}}_addDep(e){for(let o=0;o<this._deps.length;o++)if(this._deps[o].node===e)return o;let n=this._deps.length,r=In(e);if(this._deps.push(r),this._sinks==null)return n;r.dirty=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(kt),r.unsub=An;try{r.unsub=e.subscribe(o=>{if(r.unsub===null)return;let s=this._config.tierOf,i=!1;for(let a of o)s(a[0])>=3&&(i=!0),this._config.onMessage(this,a,{direction:"down-in",depIndex:n},this._actions);i&&this._maybeRunFnOnSettlement()})}catch(o){throw r.unsub=null,this._deps.pop(),this._dirtyDepCount--,o}return n}_deactivate(e=!1){let n=this._cleanup;if(this._cleanup=void 0,typeof n=="function")try{n()}catch(r){this._emit([[A,this._wrapFnError("cleanup threw",r)]])}else if(n!=null&&typeof n=="object"){let r=n.deactivate;if(typeof r=="function")try{r()}catch(o){this._emit([[A,this._wrapFnError("cleanup.deactivate threw",o)]])}}for(let r of this._deps){if(r.unsub!=null){let o=r.unsub;r.unsub=null;try{o()}catch{}}Pt(r)}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,n){let r=this._deps[e],o=n[0];if(this._inspectorHooks!=null){let s={kind:"dep_message",depIndex:e,message:n};for(let i of this._inspectorHooks)i(s)}if(o!==Fe){if(o===W){this._depDirtied(r);return}if(o===ee){this._depInvalidated(r),this._emit(cn);return}if(o===K||o===te){this._emit([n]);return}if(o===F){this._emit(Rt);return}if(o===C)this._depSettledAsData(r,n[1]);else if(o===Z)this._depSettledAsResolved(r);else if(o===L)this._depSettledAsTerminal(r,!0);else if(o===A)this._depSettledAsTerminal(r,n[1]);else{this._emit([n]);return}if(!this._fn){(o===C||o===Z)&&this._emit([n]),(o===L||o===A)&&this._maybeAutoTerminalAfterWave();return}}}_depDirtied(e){e.dirty||(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(kt))}_depSettledAsData(e,n){e.dirty&&(e.dirty=!1,this._dirtyDepCount--),e.involvedThisWave=!0,e.dataBatch.push(n),this._waveHasNewData=!0}_depSettledAsResolved(e){e.dirty&&(e.dirty=!1,this._dirtyDepCount--)}_depSettledAsTerminal(e,n){e.dirty&&(e.dirty=!1,this._dirtyDepCount--),e.terminal=n,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 n=this._deps[e];if(n.dataBatch.length===0&&n.prevData===void 0&&n.terminal===void 0){this._maybeAutoTerminalAfterWave();return}}if(this._paused){this._pendingWave=!0;return}if(!this._waveHasNewData&&!this._hasNewTerminal&&this._hasCalledFnOnce){this._clearWaveFlags(),this._emit(dn),this._maybeAutoTerminalAfterWave();return}this._fn&&this._execFn(),this._maybeAutoTerminalAfterWave()}}_maybeAutoTerminalAfterWave(){if(this._deps.length===0||this._isTerminal)return;let e=this._deps.find(n=>n.terminal!==void 0&&n.terminal!==!0);if(e!=null){this._autoError&&this._emit([[A,e.terminal]]);return}this._autoComplete&&this._deps.every(n=>n.terminal!==void 0)&&this._emit(ln)}_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([[A,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([[A,this._wrapFnError("cleanup.beforeRun threw",a)]]);return}}}let n=this._deps.map(i=>i.involvedThisWave?i.dataBatch.length>0?[...i.dataBatch]:[]:void 0),r=this._deps.map(i=>i.prevData);for(let i=0;i<this._deps.length;i++){let a=n[i];a!=null&&a.length>0&&(this._deps[i].prevData=a[a.length-1])}let o=this._deps.map(i=>i.terminal),s={prevData:r,terminalDeps:o,store:this._store};if(this._hasCalledFnOnce=!0,this._clearWaveFlags(),this._inspectorHooks!=null){let i={kind:"run",batchData:n,prevData:r};for(let a of this._inspectorHooks)a(i)}this._isExecutingFn=!0;try{let i=this._fn(n,this._actions,s);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([[A,this._wrapFnError("fn threw",i)]])}finally{this._isExecutingFn=!1,this._pendingRerun?(this._pendingRerun=!1,this._rerunDepth+=1,this._rerunDepth>Gn?(this._rerunDepth=0,this._emit([[A,new Error(`Node "${this.name}": _pendingRerun depth exceeded ${Gn} \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,n){let r=n instanceof Error?n.message:String(n);return new Error(`Node "${this.name}": ${e}: ${r}`,{cause:n})}_frameBatch(e){let n=this._config.tierOf;if(e.length===1)return n(e[0][0])===3&&this._status!=="dirty"?[xe,e[0]]:e;let r=!0,o=!1,s=!1,i=-1;for(let d of e){let u=n(d[0]);u<i&&(r=!1),u===3&&(o=!0),d[0]===W&&(s=!0),i=u}let a=e;if(!r){let d=e.map((u,l)=>({m:u,i:l,tier:n(u[0])}));d.sort((u,l)=>u.tier-l.tier||u.i-l.i),a=d.map(u=>u.m)}if(o&&!s&&this._status!=="dirty"){let d=0;for(;d<a.length&&n(a[d][0])===0;)d++;return d===0?[xe,...a]:[...a.slice(0,d),xe,...a.slice(d)]}return a}_emit(e){if(e.length===0)return;for(let a=0;a<e.length;a++){let d=e[a];if(d[0]===A&&d[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 n=e;if(this._isTerminal&&!this._resubscribable){let a=e.filter(d=>d[0]===F||d[0]===ee);if(a.length===0)return;n=a}n=this._frameBatch(n);let o=null;for(let a=0;a<n.length;a++){let d=n[a],u=d[0];if(u!==K&&u!==te){o?.push(d);continue}if(d.length<2)throw new Error(`Node "${this.name}": [[${u===K?"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=d[1];if(u===K)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?o?.push(d):o==null&&(o=n.slice(0,a))}if(o!=null){if(o.length===0)return;n=o}if(this._hasMeta&&n.some(a=>a[0]===F))for(let a of Object.keys(this.meta))try{this.meta[a]._emit(Rt)}catch{}let{finalMessages:s,equalsError:i}=this._updateState(n);if(s.length>0&&this._config.inspectorEnabled){let a=this._config.globalInspector;if(a!=null)try{a({kind:"emit",node:this,messages:s})}catch{}}if(s.length>0)if(this._paused&&this._pausable==="resumeAll"&&this._pauseBuffer!=null){let a=this._config.tierOf,d=[];for(let u of s)a(u[0])===3?this._pauseBuffer.push(u):d.push(u);d.length>0&&this._dispatchOrAccumulate(d)}else this._dispatchOrAccumulate(s);i!=null&&this._emit([[A,i]])}_updateState(e){let n=this._config.tierOf,r,o,s=-1,i=0;for(let l of e)n(l[0])===3&&i++;let a=i<=1,d=-1;if(this._versioning!=null&&i>1){for(let l=e.length-1;l>=0;l--)if(e[l][0]===C){d=l;break}}for(let l=0;l<e.length;l++){let f=e[l],p=f[0];if(p===C){if(f.length>=2){let h=!1;if(a&&this._cached!==void 0)try{h=this._equals(this._cached,f[1])}catch(c){o=this._wrapFnError("equals threw",c),s=l;break}if(h){r==null&&(r=e.slice(0,l)),r.push(Nt),this._status="resolved";continue}this._cached=f[1],this._versioning!=null&&(d<0||l===d)&&Mn(this._versioning,f[1],this._hashFn)}this._status="settled",r?.push(f)}else if(r?.push(f),p===W)this._status="dirty";else if(p===Z)this._status="resolved";else if(p===L)this._status="completed";else if(p===A)this._status="errored";else if(p===ee){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===F&&(this._resetOnTeardown&&(this._cached=void 0),this._deactivate(!0),this._status="sentinel")}let u=s>=0?r??e.slice(0,s):r??e;return o!=null?{finalMessages:u,equalsError:o}:{finalMessages:u}}_deliverToSinks=e=>{if(this._sinks==null)return;if(typeof this._sinks=="function"){this._sinks(e);return}let n=[...this._sinks];for(let r of n)r(e)};_dispatchOrAccumulate(e){if(Sn()){this._batchPendingMessages===null&&(this._batchPendingMessages=[],ze(()=>this._flushBatchPending()));for(let n of e)this._batchPendingMessages.push(n);return}tt(this._deliverToSinks,e,this._config.tierOf)}_flushBatchPending(){let e=this._batchPendingMessages;if(e===null||(this._batchPendingMessages=null,e.length===0))return;let n=this._frameBatch(e);tt(this._deliverToSinks,n,this._config.tierOf)}},Ln=t=>Array.isArray(t),$t=t=>typeof t=="object"&&t!=null&&!Array.isArray(t)});function oe(t,e){return be([],{...e,initial:t})}function Le(t,e){return be((r,o,s)=>t(o,s)??void 0,{describeKind:"producer",...e})}function se(t,e,n){return be(t,(o,s,i)=>{let a=o.map((d,u)=>d!=null&&d.length>0?d.at(-1):i.prevData[u]);s.emit(e(a,i))},{describeKind:"derived",...n})}var Ke=V(()=>{"use strict";Ie()});function Ye(t,e,n){let r=new Set;for(let o of t.split(",")){let[s,i]=o.split("/"),a=i?Number.parseInt(i,10):1;if(Number.isNaN(a)||a<1)throw new Error(`Invalid cron step: ${o}`);let d,u;if(s==="*")d=e,u=n;else if(s.includes("-")){let[l,f]=s.split("-");d=Number.parseInt(l,10),u=Number.parseInt(f,10)}else d=Number.parseInt(s,10),u=d;if(Number.isNaN(d)||Number.isNaN(u))throw new Error(`Invalid cron field: ${t}`);if(d<e||u>n)throw new Error(`Cron field out of range: ${t} (${e}-${n})`);if(d>u)throw new Error(`Invalid cron range: ${d}-${u} in ${t}`);for(let l=d;l<=u;l+=a)r.add(l)}return r}function Pn(t){let e=t.trim().split(/\s+/);if(e.length!==5)throw new Error(`Invalid cron: expected 5 fields, got ${e.length}`);return{minutes:Ye(e[0],0,59),hours:Ye(e[1],0,23),daysOfMonth:Ye(e[2],1,31),months:Ye(e[3],1,12),daysOfWeek:Ye(e[4],0,6)}}function $n(t,e){return t.minutes.has(e.getMinutes())&&t.hours.has(e.getHours())&&t.daysOfMonth.has(e.getDate())&&t.months.has(e.getMonth()+1)&&t.daysOfWeek.has(e.getDay())}var Hn=V(()=>{"use strict"});function Fn(t){return{describeKind:"producer",...t}}function qn(t,e){let{signal:n,period:r,...o}=e??{};return Le(s=>{let i=!1,a=0,d,u,l=()=>{i=!0,d!==void 0&&clearTimeout(d),u!==void 0&&clearInterval(u),n?.removeEventListener("abort",p)},f=()=>{i||(r!=null?(s.emit(a++),u=setInterval(()=>{i||s.emit(a++)},r)):(i=!0,n?.removeEventListener("abort",p),s.emit(a++),s.down([[L]])))},p=()=>{i||(l(),s.down([[A,n.reason]]))};if(n?.aborted){p();return}return d=setTimeout(f,t),n?.addEventListener("abort",p,{once:!0}),l},Fn(o))}function jn(t,e){let n=Pn(t),{tickMs:r,output:o,...s}=e??{},i=r??6e4,a=o==="date";return Le(d=>{let u=-1,l=()=>{let p=new Date,h=p.getFullYear()*1e8+(p.getMonth()+1)*1e6+p.getDate()*1e4+p.getHours()*100+p.getMinutes();h!==u&&$n(n,p)&&(u=h,d.emit(a?p:ae()))};l();let f=setInterval(l,i);return()=>clearInterval(f)},{...Fn(s),name:s.name??`cron:${t}`})}function de(t){return t.subscribe(()=>{})}var st=V(()=>{"use strict";je();re();Ke();Hn()});var ct,Yn=V(()=>{"use strict";ct=class{_timer;_gen=0;start(e,n){this.cancel(),this._gen+=1;let r=this._gen;this._timer=setTimeout(()=>{this._timer=void 0,r===this._gen&&n()},e)}cancel(){this._timer!==void 0&&(clearTimeout(this._timer),this._timer=void 0)}get pending(){return this._timer!==void 0}}});var ts={};Dr(ts,{ACTOR_KEY:()=>ut,COMMAND_HANDLERS:()=>Ne,CQRS_EVENT_HANDLERS:()=>Se,CRON_HANDLERS:()=>Oe,CommandHandler:()=>vn,EVENT_HANDLERS:()=>Te,EventHandler:()=>_n,GRAPHREFLY_REQUEST_GRAPH:()=>pe,GRAPHREFLY_ROOT_GRAPH:()=>Y,GraphCron:()=>bn,GraphInterval:()=>yn,GraphReflyEventExplorer:()=>ve,GraphReflyGuard:()=>Kn,GraphReflyGuardImpl:()=>Je,GraphReflyModule:()=>_t,INTERVAL_HANDLERS:()=>Ee,InjectCqrsGraph:()=>hn,InjectGraph:()=>pn,InjectNode:()=>gn,ObserveGateway:()=>at,OnGraphEvent:()=>mn,QUERY_HANDLERS:()=>ke,QueryHandler:()=>wn,SAGA_HANDLERS:()=>Re,SagaHandler:()=>xn,fromHeader:()=>zn,fromJwtPayload:()=>qt,getActor:()=>Un,getGraphToken:()=>j,getNodeToken:()=>ne,observeSSE:()=>Vn,observeSubscription:()=>Wn,toObservable:()=>fn});module.exports=Gr(ts);var Ct=require("rxjs");re();function fn(t,e){return e?.raw?new Ct.Observable(n=>t.subscribe(o=>{if(!n.closed){n.next(o);for(let s of o){if(s[0]===A){n.error(s[1]);return}if(s[0]===L){n.complete();return}}}})):new Ct.Observable(n=>t.subscribe(o=>{for(let s of o){if(n.closed)return;if(s[0]===C)n.next(s[1]);else if(s[0]===A){n.error(s[1]);return}else if(s[0]===L){n.complete();return}}}))}var qe=require("@nestjs/common");var Y=Symbol.for("graphrefly:root-graph");var pe=Symbol.for("graphrefly:request-graph");function j(t){return Symbol.for(`graphrefly:graph:${t}`)}function ne(t){return Symbol.for(`graphrefly:node:${t}`)}var Te=new Map,Ee=new Map,Oe=new Map,Ne=new Map,Se=new Map,ke=new Map,Re=new Map;function pn(t){return t==="request"?(0,qe.Inject)(pe):(0,qe.Inject)(t?j(t):Y)}function hn(t){return(0,qe.Inject)(j(t))}function gn(t){return(0,qe.Inject)(ne(t))}function mn(t){return(e,n)=>{let r=n.name;n.addInitializer(function(){let o=this.constructor,s=Te.get(o)??[];s.push({nodeName:t,methodKey:r}),Te.set(o,s)})}}function yn(t){return(e,n)=>{let r=n.name;n.addInitializer(function(){let o=this.constructor,s=Ee.get(o)??[];s.push({ms:t,methodKey:r}),Ee.set(o,s)})}}function bn(t){return(e,n)=>{let r=n.name;n.addInitializer(function(){let o=this.constructor,s=Oe.get(o)??[];s.push({expr:t,methodKey:r}),Oe.set(o,s)})}}function vn(t,e){return(n,r)=>{let o=r.name;r.addInitializer(function(){let s=this.constructor,i=Ne.get(s)??[];i.push({cqrsName:t,commandName:e,methodKey:o}),Ne.set(s,i)})}}function _n(t,e){return(n,r)=>{let o=r.name;r.addInitializer(function(){let s=this.constructor,i=Se.get(s)??[];i.push({cqrsName:t,eventName:e,methodKey:o}),Se.set(s,i)})}}function wn(t,e){return(n,r)=>{let o=r.name;r.addInitializer(function(){let s=this.constructor,i=ke.get(s)??[];i.push({cqrsName:t,projectionName:e,methodKey:o}),ke.set(s,i)})}}function xn(t,e,n){return(r,o)=>{let s=o.name;o.addInitializer(function(){let i=this.constructor,a=Re.get(i)??[];a.push({cqrsName:t,eventNames:n,sagaName:e,methodKey:s}),Re.set(i,a)})}}re();st();var Bn=0,ve=class{constructor(e,n){this.graph=e;this.moduleRef=n}disposers=[];scheduleNodeNames=[];onModuleInit(){this.wireEvents(),this.wireIntervals(),this.wireCrons(),this.wireCqrsCommands(),this.wireCqrsEvents(),this.wireCqrsQueries(),this.wireCqrsSagas()}onModuleDestroy(){for(let e of this.disposers)e();this.disposers.length=0;for(let e of this.scheduleNodeNames)try{this.graph.remove(e)}catch{}this.scheduleNodeNames.length=0}wireEvents(){for(let[e,n]of Te){let r=this.resolveInstance(e);if(r)for(let o of n)this.wireEventHandler(r,o)}}wireEventHandler(e,n){let r=e[n.methodKey];if(typeof r!="function")return;let o=r.bind(e),i=this.observeNode(n.nodeName).subscribe(a=>{for(let d of a)d[0]===C&&o(d[1])});this.disposers.push(i)}wireIntervals(){for(let[e,n]of Ee){let r=this.resolveInstance(e);if(r)for(let o of n)this.wireIntervalHandler(r,e,o)}}wireIntervalHandler(e,n,r){let o=e[r.methodKey];if(typeof o!="function")return;let s=o.bind(e),a=`__schedule__.${n.name??"anonymous"}.${String(r.methodKey)}.${Bn++}`,d=qn(r.ms,{period:r.ms,name:a});this.graph.add(d),this.scheduleNodeNames.push(a);let l=this.observeNode(a).subscribe(f=>{for(let p of f)p[0]===C&&s(p[1])});this.disposers.push(l)}wireCrons(){for(let[e,n]of Oe){let r=this.resolveInstance(e);if(r)for(let o of n)this.wireCronHandler(r,e,o)}}wireCronHandler(e,n,r){let o=e[r.methodKey];if(typeof o!="function")return;let s=o.bind(e),a=`__schedule__.${n.name??"anonymous"}.${String(r.methodKey)}.${Bn++}`,d=jn(r.expr,{name:a});this.graph.add(d),this.scheduleNodeNames.push(a);let l=this.observeNode(a).subscribe(f=>{for(let p of f)p[0]===C&&s(p[1])});this.disposers.push(l)}wireCqrsCommands(){for(let[e,n]of Ne){let r=this.resolveInstance(e);if(r)for(let o of n)this.wireCqrsCommand(r,o)}}wireCqrsCommand(e,n){let r=e[n.methodKey];if(typeof r!="function")return;let o=r.bind(e),s=this.resolveCqrsGraph(n.cqrsName);s&&s.command(n.commandName,o)}wireCqrsEvents(){for(let[e,n]of Se){let r=this.resolveInstance(e);if(r)for(let o of n)this.wireCqrsEventHandler(r,o)}}wireCqrsEventHandler(e,n){let r=e[n.methodKey];if(typeof r!="function")return;let o=r.bind(e),s=this.resolveCqrsGraph(n.cqrsName);if(!s)return;s.event(n.eventName);let a=s.resolve(n.eventName).cache,d=a&&a.length>0?a[a.length-1].seq:0,l=this.observeNodeOn(s,n.eventName).subscribe(f=>{for(let p of f)if(p[0]===C){let h=p[1];for(let c of h)c.seq>d&&(o(c),d=c.seq)}});this.disposers.push(l)}wireCqrsQueries(){for(let[e,n]of ke){let r=this.resolveInstance(e);if(r)for(let o of n)this.wireCqrsQuery(r,o)}}wireCqrsQuery(e,n){let r=e[n.methodKey];if(typeof r!="function")return;let o=r.bind(e),s=this.resolveCqrsGraph(n.cqrsName);if(!s)return;let a=this.observeNodeOn(s,n.projectionName).subscribe(d=>{for(let u of d)u[0]===C&&o(u[1])});this.disposers.push(a)}wireCqrsSagas(){for(let[e,n]of Re){let r=this.resolveInstance(e);if(r)for(let o of n)this.wireCqrsSaga(r,o)}}wireCqrsSaga(e,n){let r=e[n.methodKey];if(typeof r!="function")return;let o=r.bind(e),s=this.resolveCqrsGraph(n.cqrsName);s&&s.saga(n.sagaName,n.eventNames,o)}observeNode(e){return this.graph.observe(e)}observeNodeOn(e,n){return e.observe(n)}resolveCqrsGraph(e){try{return this.moduleRef.get(j(e),{strict:!1})}catch{return console.warn(`[GraphReFly] CqrsGraph "${e}" not found in DI \u2014 did you import GraphReflyModule.forCqrs({ name: "${e}" })?`),null}}resolveInstance(e){try{return this.moduleRef.get(e,{strict:!1})}catch{return null}}};re();re();var Xr=0;function it(t,e){if(e.highWaterMark<1)throw new RangeError("highWaterMark must be >= 1");if(e.lowWaterMark<0)throw new RangeError("lowWaterMark must be >= 0");if(e.lowWaterMark>=e.highWaterMark)throw new RangeError("lowWaterMark must be < highWaterMark");let n=Symbol(`bp-${++Xr}`),r=0,o=!1;return{onEnqueue(){return r+=1,!o&&r>=e.highWaterMark?(o=!0,t([[K,n]]),!0):!1},onDequeue(){return r>0&&(r-=1),o&&r<=e.lowWaterMark?(o=!1,t([[te,n]]),!0):!1},get pending(){return r},get paused(){return o},dispose(){o&&(o=!1,t([[te,n]]))}}}function Vn(t,e,n){let{actor:r,serialize:o=Zr,keepAliveMs:s,signal:i}=n??{},a=new TextEncoder,d,u=n?.highWaterMark!=null,l,f,p=[],h=!1;return new ReadableStream({start(c){let g,m=()=>{},v=()=>{if(!h){h=!0,g!==void 0&&clearInterval(g),i?.removeEventListener("abort",_),m(),l?.dispose(),f?.(),f=void 0;for(let b of p)c.enqueue(b.frame);p.length=0,c.close()}};d=v;let _=()=>v(),y=t.observe(e,{actor:r});u&&(l=it(b=>y.up(b),{highWaterMark:n.highWaterMark,lowWaterMark:n.lowWaterMark??Math.floor(n.highWaterMark/2)})),m=y.subscribe(b=>{for(let x of b){if(h)return;let T=x[0];if(T===C){let w=a.encode(Ht("data",o(x[1])));u?(p.push({frame:w,counted:!0}),l.onEnqueue(),f?.(),f=void 0):c.enqueue(w)}else if(T===A){let w=a.encode(Ht("error",o(x[1])));u?(p.push({frame:w,counted:!1}),f?.(),f=void 0):c.enqueue(w),v();return}else if(T===L||T===F){if(T===L){let w=a.encode(Ht("complete"));u?(p.push({frame:w,counted:!1}),f?.(),f=void 0):c.enqueue(w)}v();return}}}),s!==void 0&&s>0&&(g=setInterval(()=>{h||(u?(p.push({frame:a.encode(`: keepalive
1
+ "use strict";var kr=Object.create;var we=Object.defineProperty;var nn=Object.getOwnPropertyDescriptor;var Cr=Object.getOwnPropertyNames;var Rr=Object.prototype.hasOwnProperty;var rn=(t,e)=>(e=Symbol[t])?e:Symbol.for("Symbol."+t),He=t=>{throw TypeError(t)};var Mr=(t,e,n)=>e in t?we(t,e,{enumerable:!0,configurable:!0,writable:!0,value:n}):t[e]=n;var Zt=(t,e)=>we(t,"name",{value:e,configurable:!0});var V=(t,e)=>()=>(t&&(e=t(t=0)),e);var Dr=(t,e)=>{for(var n in e)we(t,n,{get:e[n],enumerable:!0})},Ar=(t,e,n,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let o of Cr(e))!Rr.call(t,o)&&o!==n&&we(t,o,{get:()=>e[o],enumerable:!(r=nn(e,o))||r.enumerable});return t};var Gr=t=>Ar(we({},"__esModule",{value:!0}),t);var on=t=>[,,,kr(t?.[rn("metadata")]??null)],sn=["class","method","getter","setter","accessor","field","value","get","set"],$e=t=>t!==void 0&&typeof t!="function"?He("Function expected"):t,Ir=(t,e,n,r,o)=>({kind:sn[t],name:e,metadata:r,addInitializer:s=>n._?He("Already initialized"):o.push($e(s||null))}),Lr=(t,e)=>Mr(e,rn("metadata"),t[3]),an=(t,e,n,r)=>{for(var o=0,s=t[e>>1],i=s&&s.length;o<i;o++)e&1?s[o].call(n):r=s[o].call(n,r);return r},un=(t,e,n,r,o,s)=>{var i,a,d,u,l,f=e&7,p=!!(e&8),h=!!(e&16),c=f>3?t.length+1:f?p?1:2:0,g=sn[f+5],m=f>3&&(t[c-1]=[]),v=t[c]||(t[c]=[]),_=f&&(!h&&!p&&(o=o.prototype),f<5&&(f>3||!h)&&nn(f<4?o:{get[n](){return en(this,s)},set[n](b){return tn(this,s,b)}},n));f?h&&f<4&&Zt(s,(f>2?"set ":f>1?"get ":"")+n):Zt(o,n);for(var y=r.length-1;y>=0;y--)u=Ir(f,n,d={},t[3],v),f&&(u.static=p,u.private=h,l=u.access={has:h?b=>Pr(o,b):b=>n in b},f^3&&(l.get=h?b=>(f^1?en:$r)(b,o,f^4?s:_.get):b=>b[n]),f>2&&(l.set=h?(b,x)=>tn(b,o,x,f^4?s:_.set):(b,x)=>b[n]=x)),a=(0,r[y])(f?f<4?h?s:_[g]:f>4?void 0:{get:_.get,set:_.set}:o,u),d._=1,f^4||a===void 0?$e(a)&&(f>4?m.unshift(a):f?h?s=a:_[g]=a:o=a):typeof a!="object"||a===null?He("Object expected"):($e(i=a.get)&&(_.get=i),$e(i=a.set)&&(_.set=i),$e(i=a.init)&&m.unshift(i));return f||Lr(t,o),_&&we(o,n,_),h?f^4?s:_:o};var Ot=(t,e,n)=>e.has(t)||He("Cannot "+n),Pr=(t,e)=>Object(e)!==e?He('Cannot use the "in" operator on this value'):t.has(e),en=(t,e,n)=>(Ot(t,e,"read from private field"),n?n.call(t):e.get(t));var tn=(t,e,n,r)=>(Ot(t,e,"write to private field"),r?r.call(t,n):e.set(t,n),n),$r=(t,e,n)=>(Ot(t,e,"access private method"),n);var Fe,R,W,Z,ee,K,te,F,L,A,xe,Nt,Hr,St,Fr,qr,kt,dn,cn,ln,Ct,re=V(()=>{"use strict";Fe=Symbol.for("graphrefly/START"),R=Symbol.for("graphrefly/DATA"),W=Symbol.for("graphrefly/DIRTY"),Z=Symbol.for("graphrefly/RESOLVED"),ee=Symbol.for("graphrefly/INVALIDATE"),K=Symbol.for("graphrefly/PAUSE"),te=Symbol.for("graphrefly/RESUME"),F=Symbol.for("graphrefly/TEARDOWN"),L=Symbol.for("graphrefly/COMPLETE"),A=Symbol.for("graphrefly/ERROR"),xe=Object.freeze([W]),Nt=Object.freeze([Z]),Hr=Object.freeze([ee]),St=Object.freeze([Fe]),Fr=Object.freeze([L]),qr=Object.freeze([F]),kt=Object.freeze([xe]),dn=Object.freeze([Nt]),cn=Object.freeze([Hr]),ln=Object.freeze([Fr]),Ct=Object.freeze([qr])});function Re(){return Math.trunc(performance.now()*1e6)}function ae(){return Date.now()*1e6}var je=V(()=>{"use strict"});function En(t,e){let n=new TextEncoder().encode(t.name);if(n.length===0||n.length>255)throw new Error(`encodeEnvelope: codec name "${t.name}" encodes to ${n.length} bytes (must be 1\u2013255)`);let r=t.version;if(!Number.isInteger(r)||r<0||r>65535)throw new Error(`encodeEnvelope: codec.version ${r} out of u16 range (expected integer 0\u201365535)`);let o=2+n.length+2+e.length;if(o>4294967295)throw new Error(`encodeEnvelope: total envelope size ${o} exceeds 2^32-1 bytes (payload ${e.length} bytes)`);let s=new Uint8Array(o),i=0;return s[i++]=Mt,s[i++]=n.length,s.set(n,i),i+=n.length,s[i++]=r>>>8&255,s[i++]=r&255,s.set(e,i),s}function On(t,e){if(t.length<Tn)throw new Error(`decodeEnvelope: bytes too short (${t.length} < ${Tn})`);let n=0,r=t[n++];if(r!==Mt)throw new Error(`decodeEnvelope: unsupported envelope version ${r} (expected ${Mt})`);let o=t[n++];if(o===0)throw new Error("decodeEnvelope: name_len must be >= 1");if(n+o+2>t.length)throw new Error(`decodeEnvelope: envelope truncated (need ${n+o+2} bytes, have ${t.length})`);let s=new TextDecoder().decode(t.subarray(n,n+o));n+=o;let i=(t[n]<<8|t[n+1])>>>0;n+=2;let a=t.subarray(n),d=e.lookupCodec(s);if(d==null)throw new Error(`decodeEnvelope: codec "${s}" not registered (envelope codec_v=${i})`);return{codec:d,codecVersion:i,payload:a}}function Nn(t){t.registerCodec(jr)}var jr,Mt,Tn,Dt=V(()=>{"use strict";jr={name:"json",version:1,contentType:"application/json",encode(t){let e=JSON.stringify(t);return new TextEncoder().encode(e)},decode(t,e){let n=new TextDecoder().decode(t);return JSON.parse(n)}},Mt=1,Tn=4});function he(t){if(t==null)return ue;let{type:e,id:n,...r}=t;return{type:e??"system",id:n??"",...r}}var ue,Be=V(()=>{"use strict";ue={type:"system",id:""}});function et(){return Me>0||Ve}function Sn(){return Me>0}function ze(t){Me>0?We.push(t):t()}function Ae(t){Me+=1;let e=!1;try{t()}catch(n){throw e=!0,n}finally{if(Me-=1,Me===0)if(e){if(!Ve){let n=We.splice(0);for(let r of n)try{r()}catch{}ge.length=0,me.length=0,De.length=0}}else Br()}}function Br(){let t=!Ve;t&&(Ve=!0);let e=[],n=0;try{for(;ge.length>0||me.length>0||De.length>0||t&&We.length>0;){if(t&&We.length>0){let s=We.splice(0);for(let i of s)try{i()}catch(a){e.push(a)}continue}if(n+=1,n>1e3)throw ge.length=0,me.length=0,De.length=0,new Error("batch drain exceeded 1000 iterations \u2014 likely a reactive cycle");let o=(ge.length>0?ge:me.length>0?me:De).splice(0);for(let s of o)try{s()}catch(i){e.push(i)}}}finally{t&&(Ve=!1)}if(e.length===1)throw e[0];if(e.length>1)throw new AggregateError(e,"batch drain: multiple callbacks threw")}function tt(t,e,n){if(e.length===0)return;if(e.length===1){let u=n(e[0][0]);if(u<3||!et()){t(e);return}(u>=5?De:u===4?me:ge).push(()=>t(e));return}let r=e.length,o=r,s=r,i=r,a=0;for(;a<r&&n(e[a][0])<3;)a++;for(o=a;a<r&&n(e[a][0])===3;)a++;for(s=a;a<r&&n(e[a][0])===4;)a++;i=a;let d=et();if(o>0){let u=e.slice(0,o);t(u)}if(s>o){let u=e.slice(o,s);d?ge.push(()=>t(u)):t(u)}if(i>s){let u=e.slice(s,i);d?me.push(()=>t(u)):t(u)}if(r>i){let u=e.slice(i,r);d?De.push(()=>t(u)):t(u)}}var Me,Ve,ge,me,De,We,Ue=V(()=>{"use strict";Me=0,Ve=!1,ge=[],me=[],De=[],We=[]});function kn(t){t.registerMessageType(Fe,{tier:0,wireCrossing:!1}),t.registerMessageType(W,{tier:1,wireCrossing:!1}),t.registerMessageType(ee,{tier:1,wireCrossing:!1,metaPassthrough:!1}),t.registerMessageType(K,{tier:2,wireCrossing:!1}),t.registerMessageType(te,{tier:2,wireCrossing:!1}),t.registerMessageType(R,{tier:3,wireCrossing:!0}),t.registerMessageType(Z,{tier:3,wireCrossing:!0}),t.registerMessageType(L,{tier:4,wireCrossing:!0,metaPassthrough:!1}),t.registerMessageType(A,{tier:4,wireCrossing:!0,metaPassthrough:!1}),t.registerMessageType(F,{tier:5,wireCrossing:!0,metaPassthrough:!1})}var nt,Cn=V(()=>{"use strict";re();nt=class{_messageTypes=new Map;_codecs=new Map;_onMessage;_onSubscribe;_defaultVersioning;_defaultHashFn;_inspectorEnabled=!(typeof process<"u"&&process.env?.NODE_ENV==="production");_globalInspector;_frozen=!1;tierOf;constructor(e){this._onMessage=e.onMessage,this._onSubscribe=e.onSubscribe,this._defaultVersioning=e.defaultVersioning,this._defaultHashFn=e.defaultHashFn,this.tierOf=n=>{let r=this._messageTypes.get(n);return r!=null?r.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}registerMessageType(e,n){return this._assertUnfrozen(),this._messageTypes.set(e,{tier:n.tier,wireCrossing:n.wireCrossing??n.tier>=3,metaPassthrough:n.metaPassthrough??!0}),this}messageTier(e){let n=this._messageTypes.get(e);return n!=null?n.tier:1}isWireCrossing(e){let n=this._messageTypes.get(e);return n!=null?n.wireCrossing:!0}isLocalOnly(e){return!this.isWireCrossing(e)}isMetaPassthrough(e){let n=this._messageTypes.get(e);return n!=null?n.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 Rn(t){return Array.isArray(t)?[...t]:[t]}function Vr(t,e){return t.has(e)||t.has("*")}function rt(t){let e=[];return t((o,s)=>{e.push({kind:"allow",actions:new Set(Rn(o)),where:s?.where??(()=>!0)})},(o,s)=>{e.push({kind:"deny",actions:new Set(Rn(o)),where:s?.where??(()=>!0)})}),(o,s)=>{let i=!1,a=!1;for(let d of e)Vr(d.actions,s)&&d.where(o)&&(d.kind==="deny"?i=!0:a=!0);return i?!1:a}}function At(t){let e=Wr.filter(n=>t({type:n,id:""},"write"));return e.length===0?"restricted":e.includes("human")&&e.includes("llm")&&e.every(n=>n==="human"||n==="llm"||n==="system")?"both":e.length===1?e[0]:e.join("+")}var J,Wr,Ge=V(()=>{"use strict";J=class extends Error{actor;action;nodeName;constructor(e,n){super(n??`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}};Wr=["human","llm","wallet","system"]});function Gt(t){if(t===void 0)return null;if(typeof t=="number"){if(!Number.isFinite(t))throw new TypeError(`Cannot hash non-finite number: ${t}`);if(Number.isInteger(t)&&!Number.isSafeInteger(t))throw new TypeError(`Cannot hash integer outside safe range (|n| > 2^53-1): ${t}. Cross-language cid parity is not guaranteed for unsafe integers.`);return t}if(typeof t=="string"||typeof t=="boolean"||t===null)return t;if(Array.isArray(t))return t.map(Gt);if(typeof t=="object"&&t!==null){let e={};for(let n of Object.keys(t).sort())e[n]=Gt(t[n]);return e}return null}function Kr(t){let e=Ur.encode(t),n=e.length,r=n*8,o=n+9+63&-64,s=new Uint8Array(o);s.set(e),s[n]=128;let i=new DataView(s.buffer);i.setUint32(o-4,r>>>0,!1),i.setUint32(o-8,Math.floor(r/4294967296)>>>0,!1);let a=1779033703,d=3144134277,u=1013904242,l=2773480762,f=1359893119,p=2600822924,h=528734635,c=1541459225,g=new Uint32Array(64),m=(_,y)=>_>>>y|_<<32-y;for(let _=0;_<o;_+=64){for(let S=0;S<16;S++)g[S]=i.getUint32(_+S*4,!1);for(let S=16;S<64;S++){let C=g[S-15],k=g[S-2],$=m(C,7)^m(C,18)^C>>>3,B=m(k,17)^m(k,19)^k>>>10;g[S]=g[S-16]+$+g[S-7]+B>>>0}let y=a,b=d,x=u,T=l,w=f,E=p,N=h,M=c;for(let S=0;S<64;S++){let C=m(w,6)^m(w,11)^m(w,25),k=w&E^~w&N,$=M+C+k+zr[S]+g[S]>>>0,B=m(y,2)^m(y,13)^m(y,22),X=y&b^y&x^b&x,fe=B+X>>>0;M=N,N=E,E=w,w=T+$>>>0,T=x,x=b,b=y,y=$+fe>>>0}a=a+y>>>0,d=d+b>>>0,u=u+x>>>0,l=l+T>>>0,f=f+w>>>0,p=p+E>>>0,h=h+N>>>0,c=c+M>>>0}let v=_=>_.toString(16).padStart(8,"0");return v(a)+v(d)+v(u)+v(l)+v(f)+v(p)+v(h)+v(c)}function It(t){let e=Gt(t??null),n=JSON.stringify(e);return Kr(n).slice(0,16)}function Yr(){let t=globalThis.crypto;if(t?.randomUUID)return t.randomUUID();let e=()=>Math.floor(Math.random()*4294967296).toString(16).padStart(8,"0"),n=e()+e()+e()+e();return`${n.slice(0,8)}-${n.slice(8,12)}-4${n.slice(13,16)}-${(parseInt(n.slice(16,17),16)&3|8).toString(16)}${n.slice(17,20)}-${n.slice(20,32)}`}function Lt(t,e,n){let r=n?.id??Yr();if(t===0)return{id:r,version:0};let s=(n?.hash??It)(e);return{id:r,version:0,cid:s,prev:null}}function Mn(t,e,n){t.version+=1,"cid"in t&&(t.prev=t.cid,t.cid=n(e))}var zr,Ur,Dn=V(()=>{"use strict";zr=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]),Ur=new TextEncoder});function In(t){return{node:t,unsub:null,prevData:void 0,dirty:!1,involvedThisWave:!1,dataBatch:[],terminal:void 0}}function Pt(t){t.prevData=void 0,t.dirty=!1,t.involvedThisWave=!1,t.dataBatch.length=0,t.terminal=void 0}function ot(t){return t.length===0?t:typeof t[0]=="symbol"?[t]:t}function be(t,e,n){let r=Ln(t)?t:[],o=typeof t=="function"?t:typeof e=="function"?e:void 0,s={};return Ln(t)?s=($t(e)?e:n)??{}:$t(t)?s=t:s=($t(e)?e:n)??{},new P(r,o,s)}var An,Gn,Jr,Qr,ye,P,Ln,$t,Ie=V(()=>{"use strict";Dt();Be();Ue();je();Cn();Ge();re();Dn();An=()=>{},Gn=100;Jr=(t,e,n,r)=>{n.direction==="down-in"&&t._onDepMessage(n.depIndex,e)},Qr=(t,e,n,r)=>{let o=t;if(o._status==="completed"||o._status==="errored")return;let s=o._cached,i=s===void 0?[St]:[St,[R,s]];o._status==="dirty"&&i.push(xe),tt(e,i,o._config.tierOf)},ye=new nt({onMessage:Jr,onSubscribe:Qr});kn(ye);Nn(ye);P=class t{_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,n,r){this._config=r.config??ye,this._config.onMessage,this._optsName=r.name,this._describeKind=r.describeKind,this._equals=r.equals??Object.is,this._resubscribable=r.resubscribable??!1,this._resetOnTeardown=r.resetOnTeardown??!1,this._autoComplete=r.completeWhenDepsComplete??!0,this._autoError=r.errorWhenDepsError??!0,this._pausable=r.pausable??!0,this._guard=r.guard,this._fn=n,this._partial=r.partial??!1,this._cached=r.initial!==void 0?r.initial:void 0,this._status=e.length===0&&n==null&&this._cached!==void 0?"settled":"sentinel",this._hashFn=r.versioningHash??this._config.defaultHashFn??It;let o=r.versioning??this._config.defaultVersioning;this._versioningLevel=o,this._versioning=o!=null?Lt(o,this._cached===void 0?void 0:this._cached,{id:r.versioningId,hash:this._hashFn}):void 0,this._deps=e.map(In);let s={};for(let[a,d]of Object.entries(r.meta??{})){let u={initial:d,name:`${r.name??"node"}:meta:${a}`,describeKind:"state",config:this._config};r.guard!=null&&(u.guard=r.guard),s[a]=new t([],void 0,u)}Object.freeze(s),this.meta=s,this._hasMeta=Object.keys(s).length>0;let i=this;this._actions={emit(a){i._emit([[R,a]])},down(a){i._emit(ot(a))},up(a){i._emitUp(ot(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,n){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 r=this._versioningLevel;if(r!=null&&e<=r)return;let o=n?.hash??this._hashFn;o!==this._hashFn&&(this._hashFn=o);let s=this._cached===void 0?void 0:this._cached,i=this._versioning,a=i?.id??n?.id,d=i?.version??0,u=Lt(e,s,{id:a,hash:o});u.version=d,this._versioning=u,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 n=he(e);if(this._guard!=null&&!this._guard(n,"observe"))return!1;if(this._extraGuards!=null){for(let r of this._extraGuards)if(!r(n,"observe"))return!1}return!0}_checkGuard(e){if(e?.internal)return;let n=this._guard!=null||this._extraGuards!=null,r=e?.actor!=null;if(!n&&!r)return;let o=he(e?.actor),s=e?.delivery==="signal"?"signal":"write";if(this._guard!=null&&!this._guard(o,s))throw new J({actor:o,action:s,nodeName:this.name});if(this._extraGuards!=null){for(let i of this._extraGuards)if(!i(o,s))throw new J({actor:o,action:s,nodeName:this.name})}this._lastMutation={actor:o,timestamp_ns:ae()}}down(e,n){let r=ot(e);r.length!==0&&(this._checkGuard(n),this._emit(r))}emit(e,n){this._checkGuard(n),this._emit([[R,e]])}up(e,n){if(this._deps.length===0)return;let r=ot(e);if(r.length===0)return;this._checkGuard(n);let o=n??{internal:!0};this._validateUpTiers(r);for(let s of this._deps)s.node.up?.(r,o)}_emitUp(e){if(this._deps.length!==0&&e.length!==0){this._validateUpTiers(e);for(let n of this._deps)n.node.up?.(e,{internal:!0})}}_validateUpTiers(e){let n=this._config.tierOf;for(let r of e){let o=n(r[0]);if(o===3||o===4)throw new Error(`Node "${this.name}": tier-${o} 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,n){if(n!=null&&this._guard!=null){let d=he(n);if(!this._guard(d,"observe"))throw new J({actor:d,action:"observe",nodeName:this.name})}let o=this._isTerminal&&this._resubscribable;if(o){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 d of this._deps)Pt(d);if(this._partial===!1){for(let d of this._deps)if(d.prevData!==void 0||d.dataBatch.length!==0||d.terminal!==void 0||d.dirty)throw new Error(`resubscribable-reset invariant: DepRecord not fully reset for node ${this._optsName??"(anonymous)"}`)}}this._sinkCount+=1;let s;try{s=this._config.onSubscribe(this,e,{sinkCount:this._sinkCount,afterTerminalReset:o},this._actions)}catch(d){throw this._sinkCount-=1,d}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(d){if(this._sinkCount-=1,this._removeSink(e),this._sinkCount===0&&(this._status="sentinel"),typeof s=="function")try{s()}catch{}throw d}this._status==="sentinel"&&this._cached===void 0&&(this._status="pending");let a=!1;return()=>{a||(a=!0,this._sinkCount-=1,this._removeSink(e),typeof s=="function"&&s(),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[n]=this._sinks;this._sinks=n}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,n=0;try{for(let r=0;r<e;r++){let o=r,s=this._deps[r];s.unsub=An,s.unsub=s.node.subscribe(i=>{if(s.unsub===null)return;let a=this._config.tierOf,d=!1;for(let u of i)a(u[0])>=3&&(d=!0),this._config.onMessage(this,u,{direction:"down-in",depIndex:o},this._actions);d&&this._maybeRunFnOnSettlement()}),n++}}catch(r){this._deps[n].unsub=null;for(let o=0;o<n;o++){let s=this._deps[o];if(s.unsub!=null){let i=s.unsub;s.unsub=null;try{i()}catch{}Pt(s)}}throw this._dirtyDepCount=0,r}}_addDep(e){for(let o=0;o<this._deps.length;o++)if(this._deps[o].node===e)return o;let n=this._deps.length,r=In(e);if(this._deps.push(r),this._sinks==null)return n;r.dirty=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(kt),r.unsub=An;try{r.unsub=e.subscribe(o=>{if(r.unsub===null)return;let s=this._config.tierOf,i=!1;for(let a of o)s(a[0])>=3&&(i=!0),this._config.onMessage(this,a,{direction:"down-in",depIndex:n},this._actions);i&&this._maybeRunFnOnSettlement()})}catch(o){throw r.unsub=null,this._deps.pop(),this._dirtyDepCount--,o}return n}_deactivate(e=!1){let n=this._cleanup;if(this._cleanup=void 0,typeof n=="function")try{n()}catch(r){this._emit([[A,this._wrapFnError("cleanup threw",r)]])}else if(n!=null&&typeof n=="object"){let r=n.deactivate;if(typeof r=="function")try{r()}catch(o){this._emit([[A,this._wrapFnError("cleanup.deactivate threw",o)]])}}for(let r of this._deps){if(r.unsub!=null){let o=r.unsub;r.unsub=null;try{o()}catch{}}Pt(r)}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,n){let r=this._deps[e],o=n[0];if(this._inspectorHooks!=null){let s={kind:"dep_message",depIndex:e,message:n};for(let i of this._inspectorHooks)i(s)}if(o!==Fe){if(o===W){this._depDirtied(r);return}if(o===ee){if(this._depInvalidated(r),this._cached===void 0)return;this._emit(cn);return}if(o===K||o===te){this._emit([n]);return}if(o===F){this._emit(Ct);return}if(o===R)this._depSettledAsData(r,n[1]);else if(o===Z)this._depSettledAsResolved(r);else if(o===L)this._depSettledAsTerminal(r,!0);else if(o===A)this._depSettledAsTerminal(r,n[1]);else{this._emit([n]);return}if(!this._fn){(o===R||o===Z)&&this._emit([n]),(o===L||o===A)&&this._maybeAutoTerminalAfterWave();return}}}_depDirtied(e){e.dirty||(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(kt))}_depSettledAsData(e,n){e.dirty&&(e.dirty=!1,this._dirtyDepCount--),e.involvedThisWave=!0,e.dataBatch.push(n),this._waveHasNewData=!0}_depSettledAsResolved(e){e.dirty&&(e.dirty=!1,this._dirtyDepCount--)}_depSettledAsTerminal(e,n){e.dirty&&(e.dirty=!1,this._dirtyDepCount--),e.terminal=n,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 n=this._deps[e];if(n.dataBatch.length===0&&n.prevData===void 0&&n.terminal===void 0){this._maybeAutoTerminalAfterWave();return}}if(this._paused){this._pendingWave=!0;return}if(!this._waveHasNewData&&!this._hasNewTerminal&&this._hasCalledFnOnce){this._clearWaveFlags(),this._emit(dn),this._maybeAutoTerminalAfterWave();return}this._fn&&this._execFn(),this._maybeAutoTerminalAfterWave()}}_maybeAutoTerminalAfterWave(){if(this._deps.length===0||this._isTerminal)return;let e=this._deps.find(n=>n.terminal!==void 0&&n.terminal!==!0);if(e!=null){this._autoError&&this._emit([[A,e.terminal]]);return}this._autoComplete&&this._deps.every(n=>n.terminal!==void 0)&&this._emit(ln)}_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([[A,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([[A,this._wrapFnError("cleanup.beforeRun threw",a)]]);return}}}let n=this._deps.map(i=>i.involvedThisWave?i.dataBatch.length>0?[...i.dataBatch]:[]:void 0),r=this._deps.map(i=>i.prevData);for(let i=0;i<this._deps.length;i++){let a=n[i];a!=null&&a.length>0&&(this._deps[i].prevData=a[a.length-1])}let o=this._deps.map(i=>i.terminal),s={prevData:r,terminalDeps:o,store:this._store};if(this._hasCalledFnOnce=!0,this._clearWaveFlags(),this._inspectorHooks!=null){let i={kind:"run",batchData:n,prevData:r};for(let a of this._inspectorHooks)a(i)}this._isExecutingFn=!0;try{let i=this._fn(n,this._actions,s);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([[A,this._wrapFnError("fn threw",i)]])}finally{this._isExecutingFn=!1,this._pendingRerun?(this._pendingRerun=!1,this._rerunDepth+=1,this._rerunDepth>Gn?(this._rerunDepth=0,this._emit([[A,new Error(`Node "${this.name}": _pendingRerun depth exceeded ${Gn} \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,n){let r=n instanceof Error?n.message:String(n);return new Error(`Node "${this.name}": ${e}: ${r}`,{cause:n})}_frameBatch(e){let n=this._config.tierOf;if(e.length===1)return n(e[0][0])===3&&this._status!=="dirty"?[xe,e[0]]:e;let r=!0,o=!1,s=!1,i=-1;for(let d of e){let u=n(d[0]);u<i&&(r=!1),u===3&&(o=!0),d[0]===W&&(s=!0),i=u}let a=e;if(!r){let d=e.map((u,l)=>({m:u,i:l,tier:n(u[0])}));d.sort((u,l)=>u.tier-l.tier||u.i-l.i),a=d.map(u=>u.m)}if(o&&!s&&this._status!=="dirty"){let d=0;for(;d<a.length&&n(a[d][0])===0;)d++;return d===0?[xe,...a]:[...a.slice(0,d),xe,...a.slice(d)]}return a}_emit(e){if(e.length===0)return;for(let a=0;a<e.length;a++){let d=e[a];if(d[0]===A&&d[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 n=e;if(this._isTerminal&&!this._resubscribable){let a=e.filter(d=>d[0]===F||d[0]===ee);if(a.length===0)return;n=a}n=this._frameBatch(n);let o=null;for(let a=0;a<n.length;a++){let d=n[a],u=d[0];if(u!==K&&u!==te){o?.push(d);continue}if(d.length<2)throw new Error(`Node "${this.name}": [[${u===K?"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=d[1];if(u===K)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?o?.push(d):o==null&&(o=n.slice(0,a))}if(o!=null){if(o.length===0)return;n=o}if(this._hasMeta&&n.some(a=>a[0]===F))for(let a of Object.keys(this.meta))try{this.meta[a]._emit(Ct)}catch{}let{finalMessages:s,equalsError:i}=this._updateState(n);if(s.length>0&&this._config.inspectorEnabled){let a=this._config.globalInspector;if(a!=null)try{a({kind:"emit",node:this,messages:s})}catch{}}if(s.length>0)if(this._paused&&this._pausable==="resumeAll"&&this._pauseBuffer!=null){let a=this._config.tierOf,d=[];for(let u of s)a(u[0])===3?this._pauseBuffer.push(u):d.push(u);d.length>0&&this._dispatchOrAccumulate(d)}else this._dispatchOrAccumulate(s);i!=null&&this._emit([[A,i]])}_updateState(e){let n=this._config.tierOf,r,o,s=-1,i=0;for(let l of e)n(l[0])===3&&i++;let a=i<=1,d=-1;if(this._versioning!=null&&i>1){for(let l=e.length-1;l>=0;l--)if(e[l][0]===R){d=l;break}}for(let l=0;l<e.length;l++){let f=e[l],p=f[0];if(p===R){if(f.length>=2){let h=!1;if(a&&this._cached!==void 0)try{h=this._equals(this._cached,f[1])}catch(c){o=this._wrapFnError("equals threw",c),s=l;break}if(h){r==null&&(r=e.slice(0,l)),r.push(Nt),this._status="resolved";continue}this._cached=f[1],this._versioning!=null&&(d<0||l===d)&&Mn(this._versioning,f[1],this._hashFn)}this._status="settled",r?.push(f)}else if(r?.push(f),p===W)this._status="dirty";else if(p===Z)this._status="resolved";else if(p===L)this._status="completed";else if(p===A)this._status="errored";else if(p===ee){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===F&&(this._resetOnTeardown&&(this._cached=void 0),this._deactivate(!0),this._status="sentinel")}let u=s>=0?r??e.slice(0,s):r??e;return o!=null?{finalMessages:u,equalsError:o}:{finalMessages:u}}_deliverToSinks=e=>{if(this._sinks==null)return;if(typeof this._sinks=="function"){this._sinks(e);return}let n=[...this._sinks];for(let r of n)r(e)};_dispatchOrAccumulate(e){if(Sn()){this._batchPendingMessages===null&&(this._batchPendingMessages=[],ze(()=>this._flushBatchPending()));for(let n of e)this._batchPendingMessages.push(n);return}tt(this._deliverToSinks,e,this._config.tierOf)}_flushBatchPending(){let e=this._batchPendingMessages;if(e===null||(this._batchPendingMessages=null,e.length===0))return;let n=this._frameBatch(e);tt(this._deliverToSinks,n,this._config.tierOf)}},Ln=t=>Array.isArray(t),$t=t=>typeof t=="object"&&t!=null&&!Array.isArray(t)});function oe(t,e){return be([],{...e,initial:t})}function Le(t,e){return be((r,o,s)=>t(o,s)??void 0,{describeKind:"producer",...e})}function se(t,e,n){return be(t,(o,s,i)=>{let a=o.map((d,u)=>d!=null&&d.length>0?d.at(-1):i.prevData[u]);s.emit(e(a,i))},{describeKind:"derived",...n})}var Ke=V(()=>{"use strict";Ie()});function Ye(t,e,n){let r=new Set;for(let o of t.split(",")){let[s,i]=o.split("/"),a=i?Number.parseInt(i,10):1;if(Number.isNaN(a)||a<1)throw new Error(`Invalid cron step: ${o}`);let d,u;if(s==="*")d=e,u=n;else if(s.includes("-")){let[l,f]=s.split("-");d=Number.parseInt(l,10),u=Number.parseInt(f,10)}else d=Number.parseInt(s,10),u=d;if(Number.isNaN(d)||Number.isNaN(u))throw new Error(`Invalid cron field: ${t}`);if(d<e||u>n)throw new Error(`Cron field out of range: ${t} (${e}-${n})`);if(d>u)throw new Error(`Invalid cron range: ${d}-${u} in ${t}`);for(let l=d;l<=u;l+=a)r.add(l)}return r}function Pn(t){let e=t.trim().split(/\s+/);if(e.length!==5)throw new Error(`Invalid cron: expected 5 fields, got ${e.length}`);return{minutes:Ye(e[0],0,59),hours:Ye(e[1],0,23),daysOfMonth:Ye(e[2],1,31),months:Ye(e[3],1,12),daysOfWeek:Ye(e[4],0,6)}}function $n(t,e){return t.minutes.has(e.getMinutes())&&t.hours.has(e.getHours())&&t.daysOfMonth.has(e.getDate())&&t.months.has(e.getMonth()+1)&&t.daysOfWeek.has(e.getDay())}var Hn=V(()=>{"use strict"});function Fn(t){return{describeKind:"producer",...t}}function qn(t,e){let{signal:n,period:r,...o}=e??{};return Le(s=>{let i=!1,a=0,d,u,l=()=>{i=!0,d!==void 0&&clearTimeout(d),u!==void 0&&clearInterval(u),n?.removeEventListener("abort",p)},f=()=>{i||(r!=null?(s.emit(a++),u=setInterval(()=>{i||s.emit(a++)},r)):(i=!0,n?.removeEventListener("abort",p),s.emit(a++),s.down([[L]])))},p=()=>{i||(l(),s.down([[A,n.reason]]))};if(n?.aborted){p();return}return d=setTimeout(f,t),n?.addEventListener("abort",p,{once:!0}),l},Fn(o))}function jn(t,e){let n=Pn(t),{tickMs:r,output:o,...s}=e??{},i=r??6e4,a=o==="date";return Le(d=>{let u=-1,l=()=>{let p=new Date,h=p.getFullYear()*1e8+(p.getMonth()+1)*1e6+p.getDate()*1e4+p.getHours()*100+p.getMinutes();h!==u&&$n(n,p)&&(u=h,d.emit(a?p:ae()))};l();let f=setInterval(l,i);return()=>clearInterval(f)},{...Fn(s),name:s.name??`cron:${t}`})}function de(t){return t.subscribe(()=>{})}var st=V(()=>{"use strict";je();re();Ke();Hn()});var ct,Yn=V(()=>{"use strict";ct=class{_timer;_gen=0;start(e,n){this.cancel(),this._gen+=1;let r=this._gen;this._timer=setTimeout(()=>{this._timer=void 0,r===this._gen&&n()},e)}cancel(){this._timer!==void 0&&(clearTimeout(this._timer),this._timer=void 0)}get pending(){return this._timer!==void 0}}});var ts={};Dr(ts,{ACTOR_KEY:()=>ut,COMMAND_HANDLERS:()=>Ne,CQRS_EVENT_HANDLERS:()=>Se,CRON_HANDLERS:()=>Oe,CommandHandler:()=>vn,EVENT_HANDLERS:()=>Te,EventHandler:()=>_n,GRAPHREFLY_REQUEST_GRAPH:()=>pe,GRAPHREFLY_ROOT_GRAPH:()=>Y,GraphCron:()=>bn,GraphInterval:()=>yn,GraphReflyEventExplorer:()=>ve,GraphReflyGuard:()=>Kn,GraphReflyGuardImpl:()=>Je,GraphReflyModule:()=>_t,INTERVAL_HANDLERS:()=>Ee,InjectCqrsGraph:()=>hn,InjectGraph:()=>pn,InjectNode:()=>gn,ObserveGateway:()=>at,OnGraphEvent:()=>mn,QUERY_HANDLERS:()=>ke,QueryHandler:()=>wn,SAGA_HANDLERS:()=>Ce,SagaHandler:()=>xn,fromHeader:()=>zn,fromJwtPayload:()=>qt,getActor:()=>Un,getGraphToken:()=>j,getNodeToken:()=>ne,observeSSE:()=>Vn,observeSubscription:()=>Wn,toObservable:()=>fn});module.exports=Gr(ts);var Rt=require("rxjs");re();function fn(t,e){return e?.raw?new Rt.Observable(n=>t.subscribe(o=>{if(!n.closed){n.next(o);for(let s of o){if(s[0]===A){n.error(s[1]);return}if(s[0]===L){n.complete();return}}}})):new Rt.Observable(n=>t.subscribe(o=>{for(let s of o){if(n.closed)return;if(s[0]===R)n.next(s[1]);else if(s[0]===A){n.error(s[1]);return}else if(s[0]===L){n.complete();return}}}))}var qe=require("@nestjs/common");var Y=Symbol.for("graphrefly:root-graph");var pe=Symbol.for("graphrefly:request-graph");function j(t){return Symbol.for(`graphrefly:graph:${t}`)}function ne(t){return Symbol.for(`graphrefly:node:${t}`)}var Te=new Map,Ee=new Map,Oe=new Map,Ne=new Map,Se=new Map,ke=new Map,Ce=new Map;function pn(t){return t==="request"?(0,qe.Inject)(pe):(0,qe.Inject)(t?j(t):Y)}function hn(t){return(0,qe.Inject)(j(t))}function gn(t){return(0,qe.Inject)(ne(t))}function mn(t){return(e,n)=>{let r=n.name;n.addInitializer(function(){let o=this.constructor,s=Te.get(o)??[];s.push({nodeName:t,methodKey:r}),Te.set(o,s)})}}function yn(t){return(e,n)=>{let r=n.name;n.addInitializer(function(){let o=this.constructor,s=Ee.get(o)??[];s.push({ms:t,methodKey:r}),Ee.set(o,s)})}}function bn(t){return(e,n)=>{let r=n.name;n.addInitializer(function(){let o=this.constructor,s=Oe.get(o)??[];s.push({expr:t,methodKey:r}),Oe.set(o,s)})}}function vn(t,e){return(n,r)=>{let o=r.name;r.addInitializer(function(){let s=this.constructor,i=Ne.get(s)??[];i.push({cqrsName:t,commandName:e,methodKey:o}),Ne.set(s,i)})}}function _n(t,e){return(n,r)=>{let o=r.name;r.addInitializer(function(){let s=this.constructor,i=Se.get(s)??[];i.push({cqrsName:t,eventName:e,methodKey:o}),Se.set(s,i)})}}function wn(t,e){return(n,r)=>{let o=r.name;r.addInitializer(function(){let s=this.constructor,i=ke.get(s)??[];i.push({cqrsName:t,projectionName:e,methodKey:o}),ke.set(s,i)})}}function xn(t,e,n){return(r,o)=>{let s=o.name;o.addInitializer(function(){let i=this.constructor,a=Ce.get(i)??[];a.push({cqrsName:t,eventNames:n,sagaName:e,methodKey:s}),Ce.set(i,a)})}}re();st();var Bn=0,ve=class{constructor(e,n){this.graph=e;this.moduleRef=n}disposers=[];scheduleNodeNames=[];onModuleInit(){this.wireEvents(),this.wireIntervals(),this.wireCrons(),this.wireCqrsCommands(),this.wireCqrsEvents(),this.wireCqrsQueries(),this.wireCqrsSagas()}onModuleDestroy(){for(let e of this.disposers)e();this.disposers.length=0;for(let e of this.scheduleNodeNames)try{this.graph.remove(e)}catch{}this.scheduleNodeNames.length=0}wireEvents(){for(let[e,n]of Te){let r=this.resolveInstance(e);if(r)for(let o of n)this.wireEventHandler(r,o)}}wireEventHandler(e,n){let r=e[n.methodKey];if(typeof r!="function")return;let o=r.bind(e),i=this.observeNode(n.nodeName).subscribe(a=>{for(let d of a)d[0]===R&&o(d[1])});this.disposers.push(i)}wireIntervals(){for(let[e,n]of Ee){let r=this.resolveInstance(e);if(r)for(let o of n)this.wireIntervalHandler(r,e,o)}}wireIntervalHandler(e,n,r){let o=e[r.methodKey];if(typeof o!="function")return;let s=o.bind(e),a=`__schedule__.${n.name??"anonymous"}.${String(r.methodKey)}.${Bn++}`,d=qn(r.ms,{period:r.ms,name:a});this.graph.add(d),this.scheduleNodeNames.push(a);let l=this.observeNode(a).subscribe(f=>{for(let p of f)p[0]===R&&s(p[1])});this.disposers.push(l)}wireCrons(){for(let[e,n]of Oe){let r=this.resolveInstance(e);if(r)for(let o of n)this.wireCronHandler(r,e,o)}}wireCronHandler(e,n,r){let o=e[r.methodKey];if(typeof o!="function")return;let s=o.bind(e),a=`__schedule__.${n.name??"anonymous"}.${String(r.methodKey)}.${Bn++}`,d=jn(r.expr,{name:a});this.graph.add(d),this.scheduleNodeNames.push(a);let l=this.observeNode(a).subscribe(f=>{for(let p of f)p[0]===R&&s(p[1])});this.disposers.push(l)}wireCqrsCommands(){for(let[e,n]of Ne){let r=this.resolveInstance(e);if(r)for(let o of n)this.wireCqrsCommand(r,o)}}wireCqrsCommand(e,n){let r=e[n.methodKey];if(typeof r!="function")return;let o=r.bind(e),s=this.resolveCqrsGraph(n.cqrsName);s&&s.command(n.commandName,o)}wireCqrsEvents(){for(let[e,n]of Se){let r=this.resolveInstance(e);if(r)for(let o of n)this.wireCqrsEventHandler(r,o)}}wireCqrsEventHandler(e,n){let r=e[n.methodKey];if(typeof r!="function")return;let o=r.bind(e),s=this.resolveCqrsGraph(n.cqrsName);if(!s)return;s.event(n.eventName);let a=s.resolve(n.eventName).cache,d=a&&a.length>0?a[a.length-1].seq:0,l=this.observeNodeOn(s,n.eventName).subscribe(f=>{for(let p of f)if(p[0]===R){let h=p[1];for(let c of h)c.seq>d&&(o(c),d=c.seq)}});this.disposers.push(l)}wireCqrsQueries(){for(let[e,n]of ke){let r=this.resolveInstance(e);if(r)for(let o of n)this.wireCqrsQuery(r,o)}}wireCqrsQuery(e,n){let r=e[n.methodKey];if(typeof r!="function")return;let o=r.bind(e),s=this.resolveCqrsGraph(n.cqrsName);if(!s)return;let a=this.observeNodeOn(s,n.projectionName).subscribe(d=>{for(let u of d)u[0]===R&&o(u[1])});this.disposers.push(a)}wireCqrsSagas(){for(let[e,n]of Ce){let r=this.resolveInstance(e);if(r)for(let o of n)this.wireCqrsSaga(r,o)}}wireCqrsSaga(e,n){let r=e[n.methodKey];if(typeof r!="function")return;let o=r.bind(e),s=this.resolveCqrsGraph(n.cqrsName);s&&s.saga(n.sagaName,n.eventNames,o)}observeNode(e){return this.graph.observe(e)}observeNodeOn(e,n){return e.observe(n)}resolveCqrsGraph(e){try{return this.moduleRef.get(j(e),{strict:!1})}catch{return console.warn(`[GraphReFly] CqrsGraph "${e}" not found in DI \u2014 did you import GraphReflyModule.forCqrs({ name: "${e}" })?`),null}}resolveInstance(e){try{return this.moduleRef.get(e,{strict:!1})}catch{return null}}};re();re();var Xr=0;function it(t,e){if(e.highWaterMark<1)throw new RangeError("highWaterMark must be >= 1");if(e.lowWaterMark<0)throw new RangeError("lowWaterMark must be >= 0");if(e.lowWaterMark>=e.highWaterMark)throw new RangeError("lowWaterMark must be < highWaterMark");let n=Symbol(`bp-${++Xr}`),r=0,o=!1;return{onEnqueue(){return r+=1,!o&&r>=e.highWaterMark?(o=!0,t([[K,n]]),!0):!1},onDequeue(){return r>0&&(r-=1),o&&r<=e.lowWaterMark?(o=!1,t([[te,n]]),!0):!1},get pending(){return r},get paused(){return o},dispose(){o&&(o=!1,t([[te,n]]))}}}function Vn(t,e,n){let{actor:r,serialize:o=Zr,keepAliveMs:s,signal:i}=n??{},a=new TextEncoder,d,u=n?.highWaterMark!=null,l,f,p=[],h=!1;return new ReadableStream({start(c){let g,m=()=>{},v=()=>{if(!h){h=!0,g!==void 0&&clearInterval(g),i?.removeEventListener("abort",_),m(),l?.dispose(),f?.(),f=void 0;for(let b of p)c.enqueue(b.frame);p.length=0,c.close()}};d=v;let _=()=>v(),y=t.observe(e,{actor:r});u&&(l=it(b=>y.up(b),{highWaterMark:n.highWaterMark,lowWaterMark:n.lowWaterMark??Math.floor(n.highWaterMark/2)})),m=y.subscribe(b=>{for(let x of b){if(h)return;let T=x[0];if(T===R){let w=a.encode(Ht("data",o(x[1])));u?(p.push({frame:w,counted:!0}),l.onEnqueue(),f?.(),f=void 0):c.enqueue(w)}else if(T===A){let w=a.encode(Ht("error",o(x[1])));u?(p.push({frame:w,counted:!1}),f?.(),f=void 0):c.enqueue(w),v();return}else if(T===L||T===F){if(T===L){let w=a.encode(Ht("complete"));u?(p.push({frame:w,counted:!1}),f?.(),f=void 0):c.enqueue(w)}v();return}}}),s!==void 0&&s>0&&(g=setInterval(()=>{h||(u?(p.push({frame:a.encode(`: keepalive
2
2
 
3
3
  `),counted:!1}),f?.(),f=void 0):c.enqueue(a.encode(`: keepalive
4
4
 
5
- `)))},s)),i?.aborted?_():i?.addEventListener("abort",_,{once:!0})},pull(c){if(u&&!h){if(p.length>0){let g=p.shift();c.enqueue(g.frame),g.counted&&l.onDequeue();return}return new Promise(g=>{f=g})}},cancel(){try{d?.()}catch{}}})}function Wn(t,e,n){let{actor:r,filter:o}=n??{},s=[],i=[],a=!1,d=t.observe(e,{actor:r}),u=n?.highWaterMark!=null?it(c=>d.up(c),{highWaterMark:n.highWaterMark,lowWaterMark:n.lowWaterMark??Math.floor(n.highWaterMark/2)}):void 0,l=()=>{a||(a=!0,u?.dispose(),p())},f=c=>{if(!a)if(i.length>0){let g=i.shift();c.done&&c.error?g.reject(c.error):c.done?g.resolve({done:!0,value:void 0}):g.resolve({done:!1,value:c.value})}else s.push(c),c.done||u?.onEnqueue()},p=d.subscribe(c=>{for(let g of c){let m=g[0];if(m===C){let v=g[1];if(o&&!o(v))continue;f({done:!1,value:v})}else if(m===A){let v=g[1]instanceof Error?g[1]:new Error(String(g[1]));f({done:!0,error:v}),l();return}else if(m===L||m===F){f({done:!0}),l();return}}});return{next(){if(s.length>0){let c=s.shift();return c.done||u?.onDequeue(),c.done&&c.error?Promise.reject(c.error):Promise.resolve(c.done?{done:!0,value:void 0}:{done:!1,value:c.value})}return a?Promise.resolve({done:!0,value:void 0}):new Promise((c,g)=>{i.push({resolve:c,reject:g})})},return(){l();for(let c of i)c.resolve({done:!0,value:void 0});return i.length=0,Promise.resolve({done:!0,value:void 0})},throw(c){return l(),Promise.reject(c)},[Symbol.asyncIterator](){return this}}}var at=class{constructor(e,n){this.graph=e;this.extractActor=n?.extractActor??(()=>{}),this.parse=n?.parse??eo,this.highWaterMark=n?.highWaterMark,this.lowWaterMark=n?.lowWaterMark}clients=new Map;extractActor;parse;highWaterMark;lowWaterMark;handleConnection(e){this.clients.has(e)||this.clients.set(e,new Map)}handleDisconnect(e){let n=this.clients.get(e);if(n){for(let r of n.values())r.wm?.dispose(),r.unsub();this.clients.delete(e)}}handleMessage(e,n,r){let o=r??to.bind(null,e),s;try{s=typeof n=="string"?this.parse(n):n}catch{o({type:"err",message:"invalid command"});return}s.type==="subscribe"?this.subscribe(e,s.path,o):s.type==="unsubscribe"?this.unsubscribe(e,s.path,o):s.type==="ack"?this.ack(e,s.path,s.count??1):o({type:"err",message:`unknown command type: ${s.type}`})}subscriptionCount(e){return this.clients.get(e)?.size??0}destroy(){for(let[e]of this.clients)this.handleDisconnect(e)}subscribe(e,n,r){let o=this.clients.get(e);if(o||(o=new Map,this.clients.set(e,o)),o.has(n)){r({type:"subscribed",path:n});return}let s=this.extractActor(e),i;try{i=this.graph.observe(n,{actor:s})}catch(l){let f=l instanceof Error?l.message:String(l);r({type:"err",message:f});return}let a=this.highWaterMark!=null?it(l=>i.up(l),{highWaterMark:this.highWaterMark,lowWaterMark:this.lowWaterMark??Math.floor(this.highWaterMark/2)}):void 0,d=()=>{a?.dispose(),u(),o.delete(n)},u=i.subscribe(l=>{for(let f of l){let p=f[0];if(p===C)a?.onEnqueue(),Ft(r,{type:"data",path:n,value:f[1]});else if(p===A){let h=f[1]instanceof Error?f[1].message:String(f[1]);Ft(r,{type:"error",path:n,error:h}),d();return}else if(p===L||p===F){Ft(r,{type:"complete",path:n}),d();return}}});o.set(n,{unsub:u,wm:a}),r({type:"subscribed",path:n})}unsubscribe(e,n,r){let o=this.clients.get(e),s=o?.get(n);s&&(s.wm?.dispose(),s.unsub(),o.delete(n)),r({type:"unsubscribed",path:n})}ack(e,n,r){let o=this.clients.get(e)?.get(n);if(!o?.wm)return;let s=Math.min(Math.max(0,Math.floor(r)),1024);for(let i=0;i<s;i++)o.wm.onDequeue()}};function Zr(t){if(t instanceof Error)return t.message;try{return JSON.stringify(t)}catch{return String(t)}}function Ht(t,e){let n=`event: ${t}
5
+ `)))},s)),i?.aborted?_():i?.addEventListener("abort",_,{once:!0})},pull(c){if(u&&!h){if(p.length>0){let g=p.shift();c.enqueue(g.frame),g.counted&&l.onDequeue();return}return new Promise(g=>{f=g})}},cancel(){try{d?.()}catch{}}})}function Wn(t,e,n){let{actor:r,filter:o}=n??{},s=[],i=[],a=!1,d=t.observe(e,{actor:r}),u=n?.highWaterMark!=null?it(c=>d.up(c),{highWaterMark:n.highWaterMark,lowWaterMark:n.lowWaterMark??Math.floor(n.highWaterMark/2)}):void 0,l=()=>{a||(a=!0,u?.dispose(),p())},f=c=>{if(!a)if(i.length>0){let g=i.shift();c.done&&c.error?g.reject(c.error):c.done?g.resolve({done:!0,value:void 0}):g.resolve({done:!1,value:c.value})}else s.push(c),c.done||u?.onEnqueue()},p=d.subscribe(c=>{for(let g of c){let m=g[0];if(m===R){let v=g[1];if(o&&!o(v))continue;f({done:!1,value:v})}else if(m===A){let v=g[1]instanceof Error?g[1]:new Error(String(g[1]));f({done:!0,error:v}),l();return}else if(m===L||m===F){f({done:!0}),l();return}}});return{next(){if(s.length>0){let c=s.shift();return c.done||u?.onDequeue(),c.done&&c.error?Promise.reject(c.error):Promise.resolve(c.done?{done:!0,value:void 0}:{done:!1,value:c.value})}return a?Promise.resolve({done:!0,value:void 0}):new Promise((c,g)=>{i.push({resolve:c,reject:g})})},return(){l();for(let c of i)c.resolve({done:!0,value:void 0});return i.length=0,Promise.resolve({done:!0,value:void 0})},throw(c){return l(),Promise.reject(c)},[Symbol.asyncIterator](){return this}}}var at=class{constructor(e,n){this.graph=e;this.extractActor=n?.extractActor??(()=>{}),this.parse=n?.parse??eo,this.highWaterMark=n?.highWaterMark,this.lowWaterMark=n?.lowWaterMark}clients=new Map;extractActor;parse;highWaterMark;lowWaterMark;handleConnection(e){this.clients.has(e)||this.clients.set(e,new Map)}handleDisconnect(e){let n=this.clients.get(e);if(n){for(let r of n.values())r.wm?.dispose(),r.unsub();this.clients.delete(e)}}handleMessage(e,n,r){let o=r??to.bind(null,e),s;try{s=typeof n=="string"?this.parse(n):n}catch{o({type:"err",message:"invalid command"});return}s.type==="subscribe"?this.subscribe(e,s.path,o):s.type==="unsubscribe"?this.unsubscribe(e,s.path,o):s.type==="ack"?this.ack(e,s.path,s.count??1):o({type:"err",message:`unknown command type: ${s.type}`})}subscriptionCount(e){return this.clients.get(e)?.size??0}destroy(){for(let[e]of this.clients)this.handleDisconnect(e)}subscribe(e,n,r){let o=this.clients.get(e);if(o||(o=new Map,this.clients.set(e,o)),o.has(n)){r({type:"subscribed",path:n});return}let s=this.extractActor(e),i;try{i=this.graph.observe(n,{actor:s})}catch(l){let f=l instanceof Error?l.message:String(l);r({type:"err",message:f});return}let a=this.highWaterMark!=null?it(l=>i.up(l),{highWaterMark:this.highWaterMark,lowWaterMark:this.lowWaterMark??Math.floor(this.highWaterMark/2)}):void 0,d=()=>{a?.dispose(),u(),o.delete(n)},u=i.subscribe(l=>{for(let f of l){let p=f[0];if(p===R)a?.onEnqueue(),Ft(r,{type:"data",path:n,value:f[1]});else if(p===A){let h=f[1]instanceof Error?f[1].message:String(f[1]);Ft(r,{type:"error",path:n,error:h}),d();return}else if(p===L||p===F){Ft(r,{type:"complete",path:n}),d();return}}});o.set(n,{unsub:u,wm:a}),r({type:"subscribed",path:n})}unsubscribe(e,n,r){let o=this.clients.get(e),s=o?.get(n);s&&(s.wm?.dispose(),s.unsub(),o.delete(n)),r({type:"unsubscribed",path:n})}ack(e,n,r){let o=this.clients.get(e)?.get(n);if(!o?.wm)return;let s=Math.min(Math.max(0,Math.floor(r)),1024);for(let i=0;i<s;i++)o.wm.onDequeue()}};function Zr(t){if(t instanceof Error)return t.message;try{return JSON.stringify(t)}catch{return String(t)}}function Ht(t,e){let n=`event: ${t}
6
6
  `;if(e!==void 0)for(let r of e.split(`
7
7
  `))n+=`data: ${r}
8
8
  `;return n+=`
9
9
  `,n}function eo(t){return JSON.parse(t)}function to(t,e){try{t.send(JSON.stringify(e))}catch{}}function Ft(t,e){try{t(e)}catch{}}Be();var ut="graphReflyActor";function qt(t){return e=>{let r=e.switchToHttp().getRequest()?.user;if(r!=null)return t?t(r):r}}function zn(t="x-graphrefly-actor"){return e=>{let r=e.switchToHttp().getRequest()?.headers?.[t.toLowerCase()];if(!(typeof r!="string"||r.length===0))try{return JSON.parse(r)}catch{return}}}function Un(t){let e=t?.[ut];return e!=null?he(e):ue}var Je=class{constructor(e){this.extractor=e}canActivate(e){let n=he(this.extractor(e)),r=e.switchToHttp().getRequest();return r!=null&&(r[ut]=n),!0}};function Kn(t){return new Je(t??qt())}var Xe=require("@nestjs/common"),Sr=require("@nestjs/core");Be();Ue();je();Ge();re();Ge();Ie();function dt(t,e){if(e!=null&&e.length>0)return new Set(e);switch(t){case"standard":return new Set(["type","status","value","deps","meta","v"]);case"full":return null;default:return new Set(["type","deps"])}}function no(t){return t._describeKind!=null?t._describeKind:t._deps.length>0?"derived":t._fn!=null?"producer":"state"}function ro(t){let e={};for(let[n,r]of Object.entries(t.meta))try{e[n]=r.cache}catch{}return e}function jt(t,e){let n=e==null,r=!n&&e!=null?[...e].filter(u=>u.startsWith("meta.")).map(u=>u.slice(5)):null,o=n||e.has("meta")||r!=null&&r.length>0,s="state",i=[];t instanceof P&&(s=no(t),i=t._deps.map(u=>u.node.name??""));let a={type:s,deps:i};(n||e.has("status"))&&(a.status=t.status);let d=t instanceof P?t._guard:void 0;if(o){let u={...ro(t)};if(d!=null&&u.access===void 0&&(u.access=At(d)),r!=null&&r.length>0&&!e.has("meta")){let l={};for(let f of r)f in u&&(l[f]=u[f]);a.meta=l}else a.meta=u}if(t.name!=null&&(a.name=t.name),n||e.has("value")){t.status==="sentinel"&&(a.sentinel=!0);try{a.value=t.cache}catch{}}if((n||e.has("v"))&&t.v!=null){let u={id:t.v.id,version:t.v.version};"cid"in t.v&&(u.cid=t.v.cid,u.prev=t.v.prev),a.v=u}return(n||e.has("guard"))&&d!=null&&(a.guard=At(d)),(n||e.has("lastMutation"))&&t.lastMutation!=null&&(a.lastMutation=t.lastMutation),a}Ie();Ke();st();Yn();var Qe=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 n=(this.head+this._size)%this.capacity;this.buf[n]=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 n=e<0?this._size+e:e;if(!(n<0||n>=this._size))return this.buf[(this.head+n)%this.capacity]}toArray(){let e=new Array(this._size);for(let n=0;n<this._size;n++)e[n]=this.buf[(this.head+n)%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}};Dt();function Bt(t){return t>=768&&t<=879||t>=1155&&t<=1161||t>=1425&&t<=1469||t>=1552&&t<=1562||t>=1611&&t<=1631||t>=1648&&t===1648||t>=1750&&t<=1756||t>=1759&&t<=1764||t>=1767&&t<=1768||t>=1770&&t<=1773||t>=1840&&t<=1866||t>=1958&&t<=1968||t>=2304&&t<=2307||t>=2362&&t<=2383||t>=2385&&t<=2391||t>=2402&&t<=2403||t>=2433&&t<=2435||t>=2492&&t<=2509||t>=2561&&t<=2563||t>=2620&&t<=2641||t>=2672&&t<=2673||t>=2677&&t===2677||t>=3633&&t===3633||t>=3636&&t<=3642||t>=3655&&t<=3662||t>=3761&&t===3761||t>=3764&&t<=3772||t>=3784&&t<=3790||t>=7616&&t<=7679||t>=8400&&t<=8447||t>=65024&&t<=65039||t>=65056&&t<=65071||t===8205?0:t>=4352&&t<=4447||t>=8986&&t<=8987||t>=9001&&t<=9002||t>=9193&&t<=9203||t>=9208&&t<=9210||t>=9725&&t<=9726||t>=9748&&t<=9749||t>=9800&&t<=9811||t===9855||t===9875||t===9889||t>=9898&&t<=9899||t>=9917&&t<=9918||t>=9924&&t<=9925||t===9934||t===9940||t===9962||t>=9970&&t<=9971||t===9973||t===9978||t===9981||t===9986||t===9989||t>=9992&&t<=9997||t===9999||t>=10067&&t<=10069||t===10071||t>=10133&&t<=10135||t===10160||t===10175||t>=10548&&t<=10549||t>=11013&&t<=11015||t>=11035&&t<=11036||t===11088||t===11093||t>=11904&&t<=12350||t>=12352&&t<=12447||t>=12448&&t<=12543||t>=12549&&t<=12591||t>=12593&&t<=12686||t>=12688&&t<=12771||t>=12784&&t<=12830||t>=12832&&t<=12871||t>=12880&&t<=19903||t>=19968&&t<=40959||t>=43360&&t<=43388||t>=44032&&t<=55203||t>=63744&&t<=64255||t>=65040&&t<=65049||t>=65072&&t<=65131||t>=65281&&t<=65376||t>=65504&&t<=65510||t>=126980&&t===126980||t===127183||t>=127344&&t<=127345||t===127358||t===127359||t===127374||t>=127377&&t<=127386||t>=127456&&t<=127487||t>=127488&&t<=127490||t===127514||t===127535||t>=127538&&t<=127546||t>=127568&&t<=127569||t>=127744&&t<=129535||t>=129536&&t<=129791||t>=129792&&t<=130047||t>=131072&&t<=196605||t>=196608&&t<=262141?2:1}function lt(t){let e=0;for(let n of t)e+=Bt(n.codePointAt(0));return e}function Jn(t,e){if(e<=0)return"";let n=0,r="";for(let o of t){let s=Bt(o.codePointAt(0));if(n+s>e){if(e<=1)return"\u2026";for(;n+1>e&&r.length>0;){let i=[...r].pop();r=r.slice(0,-i.length),n-=Bt(i.codePointAt(0))}return`${r}\u2026`}r+=o,n+=s}return r}var oo={horizontal:"\u2500",vertical:"\u2502",cornerTL:"\u250C",cornerTR:"\u2510",cornerBL:"\u2514",cornerBR:"\u2518",tDown:"\u252C",tUp:"\u2534",tRight:"\u251C",tLeft:"\u2524",cross:"\u253C",arrowRight:"\u25B6",arrowDown:"\u25BC",arrowLeft:"\u25C0",arrowUp:"\u25B2",boxTL:"\u250C",boxTR:"\u2510",boxBL:"\u2514",boxBR:"\u2518",boxH:"\u2500",boxV:"\u2502"},so={horizontal:"-",vertical:"|",cornerTL:"+",cornerTR:"+",cornerBL:"+",cornerBR:"+",tDown:"+",tUp:"+",tRight:"+",tLeft:"+",cross:"+",arrowRight:">",arrowDown:"v",arrowLeft:"<",arrowUp:"^",boxTL:"+",boxTR:"+",boxBL:"+",boxBR:"+",boxH:"-",boxV:"|"};function er(t,e){let n=e.charset==="ascii"?so:oo,r=t.width,o=t.height,s=Array.from({length:o},()=>Array.from({length:r},()=>" ")),i=Array.from({length:o},()=>Array.from({length:r},()=>"empty"));for(let a of t.edges)ao(s,i,n,a);for(let a of t.boxes)io(s,i,n,a,e.labelOf(a.id));return s.map(a=>fo(a.join(""))).join(`
10
- `)}function io(t,e,n,r,o){let{x:s,y:i,w:a,h:d}=r;if(a<2||d<2){d>0&&Qn(t,e,s,i,a,o);return}ce(t,e,s,i,n.boxTL);for(let l=s+1;l<s+a-1;l+=1)ce(t,e,l,i,n.boxH);ce(t,e,s+a-1,i,n.boxTR);for(let l=i+1;l<i+d-1;l+=1){ce(t,e,s,l,n.boxV);for(let f=s+1;f<s+a-1;f+=1)tr(t,e,f,l," ","empty");ce(t,e,s+a-1,l,n.boxV)}ce(t,e,s,i+d-1,n.boxBL);for(let l=s+1;l<s+a-1;l+=1)ce(t,e,l,i+d-1,n.boxH);ce(t,e,s+a-1,i+d-1,n.boxBR);let u=i+Math.floor(d/2);Qn(t,e,s+1,u,a-2,o)}function ce(t,e,n,r,o){tr(t,e,n,r,o,o===" "?"empty":o==="\u2500"||o==="-"?"boxH":o==="\u2502"||o==="|"?"boxV":"boxCorner")}function tr(t,e,n,r,o,s){if(r<0||r>=t.length)return;let i=t[r];n<0||n>=i.length||(i[n]=o,e[r][n]=s)}function Qn(t,e,n,r,o,s){if(r<0||r>=t.length)return;let i=n,a=o;for(let d of s){let u=lt(d);if(u!==0){if(a<u)break;i>=0&&i<t[r].length&&(t[r][i]=d,e[r][i]="label",u===2&&i+1<t[r].length&&(t[r][i+1]="",e[r][i+1]="label")),i+=u,a-=u}}for(;a>0;)i>=0&&i<t[r].length&&(t[r][i]=" ",e[r][i]="empty"),i+=1,a-=1}function ao(t,e,n,r){let o=r.points;if(o.length<2)return;for(let d=0;d+1<o.length;d+=1)uo(t,e,n,o[d],o[d+1]);for(let d=1;d+1<o.length;d+=1){let u=o[d-1],l=o[d],f=o[d+1],p=co(u,l,f,n);p&&Zn(t,e,l.x,l.y,p,"edgeCorner")}let s=o[o.length-1],i=o[o.length-2],a=lo(i,s,n);a&&Zn(t,e,s.x,s.y,a,"arrow")}function uo(t,e,n,r,o){if(!(r.x===o.x&&r.y===o.y)){if(r.y===o.y){let s=r.y,i=Math.min(r.x,o.x),a=Math.max(r.x,o.x);for(let d=i;d<=a;d+=1)Xn(t,e,d,s,n,"h")}else if(r.x===o.x){let s=r.x,i=Math.min(r.y,o.y),a=Math.max(r.y,o.y);for(let d=i;d<=a;d+=1)Xn(t,e,s,d,n,"v")}}}function Xn(t,e,n,r,o,s){if(r<0||r>=t.length)return;let i=t[r];if(n<0||n>=i.length)return;let a=e[r][n];if(!(a==="boxH"||a==="boxV"||a==="boxCorner"||a==="label")){if(a==="empty"){i[n]=s==="h"?o.horizontal:o.vertical,e[r][n]=s==="h"?"edgeH":"edgeV";return}if(a==="edgeH"&&s==="v"){i[n]=o.cross,e[r][n]="edgeCorner";return}if(a==="edgeV"&&s==="h"){i[n]=o.cross,e[r][n]="edgeCorner";return}}}function Zn(t,e,n,r,o,s){if(r<0||r>=t.length)return;let i=t[r];if(n<0||n>=i.length)return;let a=e[r][n];a==="boxH"||a==="boxV"||a==="boxCorner"||a==="label"||(i[n]=o,e[r][n]=s)}function co(t,e,n,r){let o=t.y===e.y,s=e.y===n.y;if(o===s)return;if(o){let d=t.x<e.x,u=n.y>e.y;return d&&u?r.cornerTR:d&&!u?r.cornerBR:!d&&u?r.cornerTL:r.cornerBL}let i=t.y<e.y,a=n.x>e.x;return i&&a?r.cornerBL:i&&!a?r.cornerBR:!i&&a?r.cornerTL:r.cornerTR}function lo(t,e,n){if(e.x>t.x)return n.arrowRight;if(e.x<t.x)return n.arrowLeft;if(e.y>t.y)return n.arrowDown;if(e.y<t.y)return n.arrowUp}function fo(t){let e=t.length;for(;e>0&&t.charCodeAt(e-1)===32;)e-=1;return t.slice(0,e)}function or(t){let e=po(t);ho(e),go(e),mo(e),yo(e,t);let n=_o(e,t),{width:r,height:o}=xo(e),s=[];for(let i of e.layers)for(let a of i)a.isVirtual||s.push({id:a.id,layer:a.layer,order:a.order,x:a.x,y:a.y,w:a.w,h:a.h});return{boxes:s,edges:n,width:r,height:o}}function po(t){let e=new Map;for(let o of t.nodes)e.set(o,{id:o,isVirtual:!1,layer:-1,order:0,x:0,y:0,w:t.widthCells(o),h:t.heightCells(o),in:[],out:[]});let n=[],r=0;for(let o of t.edges){if(o.from===o.to)continue;let s=e.get(o.from),i=e.get(o.to);if(!s||!i)continue;let a={chainId:r++,chainFrom:o.from,chainTo:o.to,fromId:o.from,toId:o.to,hopIndex:0,chainLen:1};s.out.push(a),i.in.push(a),n.push(a)}return{nodes:e,layers:[],hops:n}}function ho(t){let e=new Map;for(let s of t.nodes.values())e.set(s.id,s.in.length);let n=[];for(let s of t.nodes.values())(e.get(s.id)??0)===0&&(s.layer=0,n.push(s));let r=new Set,o=0;for(;o<n.length;){let s=n[o++];if(!r.has(s.id)){r.add(s.id);for(let i of s.out){let a=t.nodes.get(i.toId);a.layer=Math.max(a.layer,s.layer+1);let d=(e.get(a.id)??0)-1;e.set(a.id,d),d<=0&&n.push(a)}}}for(let s of t.nodes.values())s.layer<0&&(s.layer=0)}function go(t){let e=Math.max(0,...Array.from(t.nodes.values(),s=>s.layer)),n=Array.from({length:e+1},()=>[]);for(let s of t.nodes.values())n[s.layer].push(s);let r=[],o=0;for(let s of t.hops){let i=t.nodes.get(s.fromId),a=t.nodes.get(s.toId),d=a.layer-i.layer;if(d<=0){i.out=i.out.filter(f=>f!==s),a.in=a.in.filter(f=>f!==s);continue}if(d===1){s.hopIndex=0,s.chainLen=1,r.push(s);continue}i.out=i.out.filter(f=>f!==s),a.in=a.in.filter(f=>f!==s);let u=i;for(let f=1;f<d;f+=1){let p=`__virt_${o++}__`,h={id:p,isVirtual:!0,layer:i.layer+f,order:0,x:0,y:0,w:0,h:1,in:[],out:[]};t.nodes.set(p,h),n[h.layer].push(h);let c={chainId:s.chainId,chainFrom:s.chainFrom,chainTo:s.chainTo,fromId:u.id,toId:p,hopIndex:f-1,chainLen:d};u.out.push(c),h.in.push(c),r.push(c),u=h}let l={chainId:s.chainId,chainFrom:s.chainFrom,chainTo:s.chainTo,fromId:u.id,toId:a.id,hopIndex:d-1,chainLen:d};u.out.push(l),a.in.push(l),r.push(l)}for(let s of n)for(let i=0;i<s.length;i+=1)s[i].order=i;t.layers=n,t.hops=r}function mo(t){for(let n=0;n<4;n+=1){for(let r=1;r<t.layers.length;r+=1)nr(t,t.layers[r],"in"),ft(t.layers[r]);for(let r=t.layers.length-2;r>=0;r-=1)nr(t,t.layers[r],"out"),ft(t.layers[r])}for(let n=0;n<2;n+=1){let r=!1;for(let o=1;o<t.layers.length;o+=1){let s=t.layers[o];for(let i=0;i+1<s.length;i+=1){let a=rr(t,s[i],s[i+1],"in");[s[i],s[i+1]]=[s[i+1],s[i]],ft(s),rr(t,s[i],s[i+1],"in")<a?r=!0:([s[i],s[i+1]]=[s[i+1],s[i]],ft(s))}}if(!r)break}}function nr(t,e,n){let r=new Map;for(let o of e){let s=n==="in"?o.in:o.out;if(s.length===0){r.set(o.id,o.order);continue}let i=0,a=0;for(let d of s){let u=t.nodes.get(n==="in"?d.fromId:d.toId);u&&(i+=u.order,a+=1)}r.set(o.id,a===0?o.order:i/a)}e.sort((o,s)=>{let i=r.get(o.id),a=r.get(s.id);return i!==a?i-a:o.order-s.order})}function ft(t){for(let e=0;e<t.length;e+=1)t[e].order=e}function rr(t,e,n,r){let o=r==="in"?e.in:e.out,s=r==="in"?n.in:n.out,i=0;for(let a of o)for(let d of s){let u=t.nodes.get(r==="in"?a.fromId:a.toId)?.order??0,l=t.nodes.get(r==="in"?d.fromId:d.toId)?.order??0;(e.order<n.order&&u>l||e.order>n.order&&u<l)&&(i+=1)}return i}function yo(t,e){e.direction==="LR"?bo(t,e):vo(t,e)}function bo(t,e){let n=[],r=0;for(let o=0;o<t.layers.length;o+=1){n.push(r);let s=0;for(let i of t.layers[o])s=Math.max(s,i.w);r+=s+e.layerGap}for(let o=0;o<t.layers.length;o+=1)for(let s of t.layers[o])s.x=n[o];for(let o of t.layers){let s=0;for(let i of o)i.y=s,s+=i.h+e.nodeGap}sr(t,e,"y")}function vo(t,e){let n=[],r=0;for(let o=0;o<t.layers.length;o+=1){n.push(r);let s=0;for(let i of t.layers[o])s=Math.max(s,i.h);r+=s+e.layerGap}for(let o=0;o<t.layers.length;o+=1)for(let s of t.layers[o])s.y=n[o];for(let o of t.layers){let s=0;for(let i of o)i.x=s,s+=i.w+e.nodeGap}sr(t,e,"x")}function sr(t,e,n){let r=s=>n==="y"?s.h:s.w,o=e.nodeGap;for(let s=0;s<2;s+=1){let i=s===0?t.layers.slice(1):t.layers.slice(0,-1).reverse();for(let a of i){let d=new Map;for(let l of a){let f=s===0?l.in:l.out;if(f.length===0)continue;let p=[];for(let c of f){let g=t.nodes.get(s===0?c.fromId:c.toId);if(!g)continue;let m=n==="y"?g.y:g.x;p.push(m+Math.floor(r(g)/2))}if(p.length===0)continue;p.sort((c,g)=>c-g);let h=p[Math.floor(p.length/2)];d.set(l.id,h-Math.floor(r(l)/2))}let u=0;for(let l of a){let f=d.get(l.id),p=n==="y"?l.y:l.x,c=Math.max(f??p,u);n==="y"?l.y=c:l.x=c,u=c+r(l)+o}}}}function _o(t,e){let n=new Map;for(let u of t.hops){let l=n.get(u.chainId);l?l.push(u):n.set(u.chainId,[u])}for(let u of n.values())u.sort((l,f)=>l.hopIndex-f.hopIndex);let r=e.direction==="LR",o=u=>r?u.x:u.y,s=u=>r?u.w:u.h,i=u=>r?u.y+Math.floor(u.h/2):u.x+Math.floor(u.w/2),a=new Map;for(let u=0;u+1<t.layers.length;u+=1){let l=t.layers[u],f=t.layers[u+1],p=0;for(let E of l)p=Math.max(p,o(E)+s(E));let h=Number.POSITIVE_INFINITY;for(let E of f)h=Math.min(h,o(E));let c=Number.isFinite(h)?h-1:p,g=Math.max(1,c-p+1),m=[];for(let E of l)for(let N of E.out)m.push(N);m.sort((E,N)=>{let M=i(t.nodes.get(E.fromId)),S=i(t.nodes.get(N.fromId));if(M!==S)return M-S;let R=i(t.nodes.get(E.toId)),k=i(t.nodes.get(N.toId));return R-k});let v=[],_=new Map;for(let E of m){let N=i(t.nodes.get(E.fromId)),M=i(t.nodes.get(E.toId)),S=Math.min(N,M),R=Math.max(N,M),k=-1;for(let $=0;$<v.length;$+=1){let B=v[$],X=!0;for(let fe of B)if(fe.lo<=R&&S<=fe.hi){X=!1;break}if(X){B.push({lo:S,hi:R}),k=$;break}}k<0&&(v.push([{lo:S,hi:R}]),k=v.length-1),_.set(E,k)}let y=v.length,b=g>=Math.max(3,y+2),x=b?p+1:p,T=b?c-1:c,w=Math.max(1,T-x+1);for(let E of m){let N=_.get(E),M;if(y<=1)M=x+Math.floor(w/2);else{let S=(w-1)/(y-1);M=x+Math.floor(N*S)}a.set(E,Math.max(p,Math.min(c,M)))}}let d=[];for(let[,u]of n){let l=[];for(let p=0;p<u.length;p+=1){let h=u[p],c=t.nodes.get(h.fromId),g=t.nodes.get(h.toId),m=a.get(h),v=c.isVirtual?o(c):o(c)+s(c),_=g.isVirtual?o(g):o(g)-1,y=i(c),b=i(g);p===0&&pt(l,r,v,y),y!==b&&(pt(l,r,m,y),pt(l,r,m,b)),pt(l,r,_,b)}let f=u[0];d.push({from:f.chainFrom,to:f.chainTo,points:wo(l)})}return d}function pt(t,e,n,r){t.push(e?{x:n,y:r}:{x:r,y:n})}function wo(t){let e=[];for(let n of t){let r=e[e.length-1];(!r||r.x!==n.x||r.y!==n.y)&&e.push(n)}return e}function xo(t){let e=0,n=0;for(let r of t.layers)for(let o of r)e=Math.max(e,o.x+o.w),n=Math.max(n,o.y+o.h);return{width:e,height:n}}var To=24,Eo=4,Oo=1,No=3;function ir(t,e){let n=So(e.direction),r=Math.max(3,e.maxLabelWidth??To),o=e.asciiCharset??"unicode",s=Object.keys(t.nodes).sort(),i=new Set(s),a=t.edges.filter(h=>i.has(h.from)&&i.has(h.to)),d=new Map,u=new Map;for(let h of s){let c=Jn(h,r);d.set(h,c),u.set(h,lt(c)+4)}let l=or({nodes:s,edges:a,widthCells:h=>u.get(h)??3,heightCells:()=>No,layerGap:Eo,nodeGap:Oo,direction:n}),f=er(l,{charset:o,labelOf:h=>d.get(h)??h}),p=e.logger;return p&&p(f),f}function So(t){if(t===void 0||t==="LR")return"LR";if(t==="TD")return"TD";throw new Error(`ascii describe supports direction "LR" or "TD" only; got ${String(t)}`)}function ar(t,e,n,r={}){let o=e in t.nodes,s=n in t.nodes;if(!o)return ht(e,n,"no-such-from");if(!s)return ht(e,n,"no-such-to");let i=r.maxDepth;if(i!=null&&(!Number.isInteger(i)||i<0))throw new Error("explainPath: maxDepth must be an integer >= 0");if(e===n){if(r.findCycle===!0){let u=ko(t,e,r);if(u!=null)return u}let d=gt(e,t.nodes[e],0,r);return mt(e,n,[d])}if(i===0)return ht(e,n,"no-path");let a=ur(t,e,n,i);return a.found?mt(e,n,dr(t,a.pathOrder,r)):ht(e,n,a.truncated?"max-depth-exceeded":"no-path")}function ur(t,e,n,r){let o=new Map,s=[{path:n,depth:0}],i=new Set([n]),a=0,d=!1;for(;a<s.length;){let f=s[a++];if(f.path===e)break;if(r!=null&&f.depth>=r){let g=t.nodes[f.path];g?.deps&&g.deps.length>0&&(d=!0);continue}let p=t.nodes[f.path];if(p==null)continue;let h=p.deps??[],c=new Map;for(let g=0;g<h.length;g++){let m=h[g];if(!m)continue;let v=c.get(m);v==null&&(v=[],c.set(m,v)),v.push(g)}for(let[g,m]of c)i.has(g)||(i.add(g),o.set(g,{from:f.path,depIndices:m}),s.push({path:g,depth:f.depth+1}))}if(!o.has(e))return{found:!1,pathOrder:[],truncated:d};let u=[{path:e}],l=e;for(;l!==n;){let f=o.get(l);if(f==null)return{found:!1,pathOrder:[],truncated:!1};u[u.length-1].depIndices=f.depIndices,u.push({path:f.from}),l=f.from}return{found:!0,pathOrder:u,truncated:!1}}function ko(t,e,n){let r=t.nodes[e];if(r==null)return null;let o=r.deps??[],s=[];for(let a=0;a<o.length;a++)o[a]===e&&s.push(a);if(s.length>0){let a=gt(e,r,0,n);a.dep_index=s[0];let d=gt(e,r,1,n);return mt(e,e,[a,d])}let i=null;for(let a=0;a<o.length;a++){let d=o[a];if(!d||d===e)continue;let u=ur(t,d,e,n.maxDepth);u.found&&(i==null||u.pathOrder.length<i.pathOrder.length)&&(i=u,i={found:!0,pathOrder:[{path:e,depIndices:[a]},...u.pathOrder],truncated:!1})}return i==null?null:mt(e,e,dr(t,i.pathOrder,n))}function dr(t,e,n){return e.map((r,o)=>{let s=t.nodes[r.path],i=gt(r.path,s,o,n);return r.depIndices!=null&&r.depIndices.length>0&&(i.dep_index=r.depIndices[0],r.depIndices.length>1&&(i.dep_indices=[...r.depIndices])),i})}function gt(t,e,n,r){let o={path:t,type:e.type,hop:n};e.status!==void 0&&(o.status=e.status),"value"in e&&(o.value=e.value),e.v!=null&&(o.v=e.v);let s=r.annotations?.get(t)??e.annotation;s!=null&&(o.annotation=s);let i=r.lastMutations?.get(t)??e.lastMutation;return i!=null&&(o.lastMutation=i),o}function mt(t,e,n){return cr(t,e,!0,"ok",n)}function ht(t,e,n){return cr(t,e,!1,n,[])}function cr(t,e,n,r,o){let s=Ro(t,e,n,r,o);return{from:t,to:e,found:n,reason:r,steps:o,text:s,toJSON(){return{from:t,to:e,found:n,reason:r,steps:o}}}}function Ro(t,e,n,r,o){if(!n)switch(r){case"no-such-from":return`explainPath: no node named "${t}"`;case"no-such-to":return`explainPath: no node named "${e}"`;case"max-depth-exceeded":return`explainPath: no path from "${t}" to "${e}" within maxDepth`;default:return`explainPath: no path from "${t}" to "${e}"`}let s=[`Causal path: ${t} \u2192 ${e} (${o.length} step(s))`];for(let i of o){let d=` ${i.hop===0?"\xB7":"\u2193"} ${i.path} (${i.type}${i.status?`/${i.status}`:""})`;if(s.push(d),"value"in i&&s.push(` value: ${Co(i.value)}`),i.annotation!=null&&s.push(` annotation: ${i.annotation}`),i.lastMutation!=null){let u=i.lastMutation.actor;s.push(` actor: ${u.type}${u.id?`:${u.id}`:""}`)}}return s.join(`
11
- `)}function Co(t){if(t===void 0)return"<sentinel>";if(t===null)return"null";if(typeof t=="string")return JSON.stringify(t);if(typeof t=="number"||typeof t=="boolean"||typeof t=="bigint")return String(t);try{let e=JSON.stringify(t);return e.length>80?`${e.slice(0,77)}...`:e}catch{return String(t)}}Ie();var H={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},Mo=Symbol.for("sizeof");function lr(t){let e=new WeakSet,n=new WeakSet,r=[t],o=0;for(;r.length>0;){let s=r.pop();o+=Do(s,e,n,r)}return o}function Do(t,e,n,r){if(t==null)return 0;switch(typeof t){case"number":return H.number;case"boolean":return H.boolean;case"string":return H.string+t.length*2;case"bigint":return H.bigint+Ao(t);case"symbol":return H.symbol;case"function":return e.has(t)?0:(e.add(t),H.function);case"undefined":return 0}let s=t;if(e.has(s))return 0;e.add(s);let i=s[Mo];if(typeof i=="function")try{let u=i.call(s);if(typeof u=="number"&&Number.isFinite(u))return u}catch{}if(s instanceof Date)return H.date;if(s instanceof RegExp)return H.regexp+s.source.length*2;if(s instanceof Error){let u=s.message?s.message.length*2:0,l=s.stack?s.stack.length*2:0;return H.error+u+l}if(typeof URL<"u"&&s instanceof URL)return H.url+s.href.length*2;if(typeof Promise<"u"&&s instanceof Promise)return H.promise;if(s instanceof WeakMap)return H.weakmap;if(s instanceof WeakSet)return H.weakset;if(s instanceof Map){let u=H.map;for(let[l,f]of s)u+=H.mapEntry,r.push(l),r.push(f);return u}if(s instanceof Set){let u=H.set;for(let l of s)u+=H.setEntry,r.push(l);return u}if(Array.isArray(s)){let u=H.array+s.length*8;for(let l of s)r.push(l);return u}if(s instanceof ArrayBuffer)return n.has(s)?0:(n.add(s),s.byteLength);if(ArrayBuffer.isView(s)){let u=s;return n.has(u.buffer)?48:(n.add(u.buffer),u.buffer.byteLength+48)}let a=H.object,d=Object.keys(s);for(let u of d){a+=H.string+u.length*2;try{r.push(s[u])}catch{}}return a}function Ao(t){let e=t<0n?-t:t;if(e===0n)return 0;let n=e.toString(2).length;return Math.ceil(n/32)*8}function fr(t,e){let n=e?.topN??10,r=t.describe({detail:"standard"}),o=[],s=t._collectObserveTargets;typeof s=="function"&&s.call(t,"",o);let i=new Map;for(let[p,h]of o)i.set(p,h);let a=[];for(let[p,h]of Object.entries(r.nodes)){let c=i.get(p),g=c instanceof P?c:null,m=g?lr(g.cache):0,v=g?g._sinkCount:0,_=h.deps?.length??0,y=h.type==="effect"&&v===0,b=v===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:m,subscriberCount:v,depCount:_,isOrphanEffect:y,orphanKind:b})}let d=a.reduce((p,h)=>p+h.valueSizeBytes,0),u=(p,h)=>[...a].sort(h??((c,g)=>g[p]-c[p])).slice(0,n),l=a.filter(p=>p.orphanKind!=null),f=a.filter(p=>p.isOrphanEffect);return{nodeCount:a.length,edgeCount:r.edges.length,subgraphCount:r.subgraphs.length,nodes:a,totalValueSizeBytes:d,hotspots:{byValueSize:u("valueSizeBytes"),bySubscriberCount:u("subscriberCount"),byDepCount:u("depCount")},orphans:l,orphanEffects:f}}var I="::",Q="__meta__",_e=1;function pr(t,e){let n=Math.max(16,t.size*4),r=0;for(;t.size>0;){if(r++>=n){console.error(`[Graph "${e}".destroy] disposer drain exceeded cap (${n}); ${t.size} disposer(s) discarded`),t.clear();return}let o=t.values().next();if(o.done)return;let s=o.value;t.delete(s);try{s()}catch(i){console.error(`[Graph "${e}".destroy] disposer threw:`,i)}}}function Go(t){let e=[];for(let n of Object.keys(t).sort()){let r=t[n].v;r!=null&&e.push(`${n} ${r.id} ${r.version}`)}return e.join(`
10
+ `)}function io(t,e,n,r,o){let{x:s,y:i,w:a,h:d}=r;if(a<2||d<2){d>0&&Qn(t,e,s,i,a,o);return}ce(t,e,s,i,n.boxTL);for(let l=s+1;l<s+a-1;l+=1)ce(t,e,l,i,n.boxH);ce(t,e,s+a-1,i,n.boxTR);for(let l=i+1;l<i+d-1;l+=1){ce(t,e,s,l,n.boxV);for(let f=s+1;f<s+a-1;f+=1)tr(t,e,f,l," ","empty");ce(t,e,s+a-1,l,n.boxV)}ce(t,e,s,i+d-1,n.boxBL);for(let l=s+1;l<s+a-1;l+=1)ce(t,e,l,i+d-1,n.boxH);ce(t,e,s+a-1,i+d-1,n.boxBR);let u=i+Math.floor(d/2);Qn(t,e,s+1,u,a-2,o)}function ce(t,e,n,r,o){tr(t,e,n,r,o,o===" "?"empty":o==="\u2500"||o==="-"?"boxH":o==="\u2502"||o==="|"?"boxV":"boxCorner")}function tr(t,e,n,r,o,s){if(r<0||r>=t.length)return;let i=t[r];n<0||n>=i.length||(i[n]=o,e[r][n]=s)}function Qn(t,e,n,r,o,s){if(r<0||r>=t.length)return;let i=n,a=o;for(let d of s){let u=lt(d);if(u!==0){if(a<u)break;i>=0&&i<t[r].length&&(t[r][i]=d,e[r][i]="label",u===2&&i+1<t[r].length&&(t[r][i+1]="",e[r][i+1]="label")),i+=u,a-=u}}for(;a>0;)i>=0&&i<t[r].length&&(t[r][i]=" ",e[r][i]="empty"),i+=1,a-=1}function ao(t,e,n,r){let o=r.points;if(o.length<2)return;for(let d=0;d+1<o.length;d+=1)uo(t,e,n,o[d],o[d+1]);for(let d=1;d+1<o.length;d+=1){let u=o[d-1],l=o[d],f=o[d+1],p=co(u,l,f,n);p&&Zn(t,e,l.x,l.y,p,"edgeCorner")}let s=o[o.length-1],i=o[o.length-2],a=lo(i,s,n);a&&Zn(t,e,s.x,s.y,a,"arrow")}function uo(t,e,n,r,o){if(!(r.x===o.x&&r.y===o.y)){if(r.y===o.y){let s=r.y,i=Math.min(r.x,o.x),a=Math.max(r.x,o.x);for(let d=i;d<=a;d+=1)Xn(t,e,d,s,n,"h")}else if(r.x===o.x){let s=r.x,i=Math.min(r.y,o.y),a=Math.max(r.y,o.y);for(let d=i;d<=a;d+=1)Xn(t,e,s,d,n,"v")}}}function Xn(t,e,n,r,o,s){if(r<0||r>=t.length)return;let i=t[r];if(n<0||n>=i.length)return;let a=e[r][n];if(!(a==="boxH"||a==="boxV"||a==="boxCorner"||a==="label")){if(a==="empty"){i[n]=s==="h"?o.horizontal:o.vertical,e[r][n]=s==="h"?"edgeH":"edgeV";return}if(a==="edgeH"&&s==="v"){i[n]=o.cross,e[r][n]="edgeCorner";return}if(a==="edgeV"&&s==="h"){i[n]=o.cross,e[r][n]="edgeCorner";return}}}function Zn(t,e,n,r,o,s){if(r<0||r>=t.length)return;let i=t[r];if(n<0||n>=i.length)return;let a=e[r][n];a==="boxH"||a==="boxV"||a==="boxCorner"||a==="label"||(i[n]=o,e[r][n]=s)}function co(t,e,n,r){let o=t.y===e.y,s=e.y===n.y;if(o===s)return;if(o){let d=t.x<e.x,u=n.y>e.y;return d&&u?r.cornerTR:d&&!u?r.cornerBR:!d&&u?r.cornerTL:r.cornerBL}let i=t.y<e.y,a=n.x>e.x;return i&&a?r.cornerBL:i&&!a?r.cornerBR:!i&&a?r.cornerTL:r.cornerTR}function lo(t,e,n){if(e.x>t.x)return n.arrowRight;if(e.x<t.x)return n.arrowLeft;if(e.y>t.y)return n.arrowDown;if(e.y<t.y)return n.arrowUp}function fo(t){let e=t.length;for(;e>0&&t.charCodeAt(e-1)===32;)e-=1;return t.slice(0,e)}function or(t){let e=po(t);ho(e),go(e),mo(e),yo(e,t);let n=_o(e,t),{width:r,height:o}=xo(e),s=[];for(let i of e.layers)for(let a of i)a.isVirtual||s.push({id:a.id,layer:a.layer,order:a.order,x:a.x,y:a.y,w:a.w,h:a.h});return{boxes:s,edges:n,width:r,height:o}}function po(t){let e=new Map;for(let o of t.nodes)e.set(o,{id:o,isVirtual:!1,layer:-1,order:0,x:0,y:0,w:t.widthCells(o),h:t.heightCells(o),in:[],out:[]});let n=[],r=0;for(let o of t.edges){if(o.from===o.to)continue;let s=e.get(o.from),i=e.get(o.to);if(!s||!i)continue;let a={chainId:r++,chainFrom:o.from,chainTo:o.to,fromId:o.from,toId:o.to,hopIndex:0,chainLen:1};s.out.push(a),i.in.push(a),n.push(a)}return{nodes:e,layers:[],hops:n}}function ho(t){let e=new Map;for(let s of t.nodes.values())e.set(s.id,s.in.length);let n=[];for(let s of t.nodes.values())(e.get(s.id)??0)===0&&(s.layer=0,n.push(s));let r=new Set,o=0;for(;o<n.length;){let s=n[o++];if(!r.has(s.id)){r.add(s.id);for(let i of s.out){let a=t.nodes.get(i.toId);a.layer=Math.max(a.layer,s.layer+1);let d=(e.get(a.id)??0)-1;e.set(a.id,d),d<=0&&n.push(a)}}}for(let s of t.nodes.values())s.layer<0&&(s.layer=0)}function go(t){let e=Math.max(0,...Array.from(t.nodes.values(),s=>s.layer)),n=Array.from({length:e+1},()=>[]);for(let s of t.nodes.values())n[s.layer].push(s);let r=[],o=0;for(let s of t.hops){let i=t.nodes.get(s.fromId),a=t.nodes.get(s.toId),d=a.layer-i.layer;if(d<=0){i.out=i.out.filter(f=>f!==s),a.in=a.in.filter(f=>f!==s);continue}if(d===1){s.hopIndex=0,s.chainLen=1,r.push(s);continue}i.out=i.out.filter(f=>f!==s),a.in=a.in.filter(f=>f!==s);let u=i;for(let f=1;f<d;f+=1){let p=`__virt_${o++}__`,h={id:p,isVirtual:!0,layer:i.layer+f,order:0,x:0,y:0,w:0,h:1,in:[],out:[]};t.nodes.set(p,h),n[h.layer].push(h);let c={chainId:s.chainId,chainFrom:s.chainFrom,chainTo:s.chainTo,fromId:u.id,toId:p,hopIndex:f-1,chainLen:d};u.out.push(c),h.in.push(c),r.push(c),u=h}let l={chainId:s.chainId,chainFrom:s.chainFrom,chainTo:s.chainTo,fromId:u.id,toId:a.id,hopIndex:d-1,chainLen:d};u.out.push(l),a.in.push(l),r.push(l)}for(let s of n)for(let i=0;i<s.length;i+=1)s[i].order=i;t.layers=n,t.hops=r}function mo(t){for(let n=0;n<4;n+=1){for(let r=1;r<t.layers.length;r+=1)nr(t,t.layers[r],"in"),ft(t.layers[r]);for(let r=t.layers.length-2;r>=0;r-=1)nr(t,t.layers[r],"out"),ft(t.layers[r])}for(let n=0;n<2;n+=1){let r=!1;for(let o=1;o<t.layers.length;o+=1){let s=t.layers[o];for(let i=0;i+1<s.length;i+=1){let a=rr(t,s[i],s[i+1],"in");[s[i],s[i+1]]=[s[i+1],s[i]],ft(s),rr(t,s[i],s[i+1],"in")<a?r=!0:([s[i],s[i+1]]=[s[i+1],s[i]],ft(s))}}if(!r)break}}function nr(t,e,n){let r=new Map;for(let o of e){let s=n==="in"?o.in:o.out;if(s.length===0){r.set(o.id,o.order);continue}let i=0,a=0;for(let d of s){let u=t.nodes.get(n==="in"?d.fromId:d.toId);u&&(i+=u.order,a+=1)}r.set(o.id,a===0?o.order:i/a)}e.sort((o,s)=>{let i=r.get(o.id),a=r.get(s.id);return i!==a?i-a:o.order-s.order})}function ft(t){for(let e=0;e<t.length;e+=1)t[e].order=e}function rr(t,e,n,r){let o=r==="in"?e.in:e.out,s=r==="in"?n.in:n.out,i=0;for(let a of o)for(let d of s){let u=t.nodes.get(r==="in"?a.fromId:a.toId)?.order??0,l=t.nodes.get(r==="in"?d.fromId:d.toId)?.order??0;(e.order<n.order&&u>l||e.order>n.order&&u<l)&&(i+=1)}return i}function yo(t,e){e.direction==="LR"?bo(t,e):vo(t,e)}function bo(t,e){let n=[],r=0;for(let o=0;o<t.layers.length;o+=1){n.push(r);let s=0;for(let i of t.layers[o])s=Math.max(s,i.w);r+=s+e.layerGap}for(let o=0;o<t.layers.length;o+=1)for(let s of t.layers[o])s.x=n[o];for(let o of t.layers){let s=0;for(let i of o)i.y=s,s+=i.h+e.nodeGap}sr(t,e,"y")}function vo(t,e){let n=[],r=0;for(let o=0;o<t.layers.length;o+=1){n.push(r);let s=0;for(let i of t.layers[o])s=Math.max(s,i.h);r+=s+e.layerGap}for(let o=0;o<t.layers.length;o+=1)for(let s of t.layers[o])s.y=n[o];for(let o of t.layers){let s=0;for(let i of o)i.x=s,s+=i.w+e.nodeGap}sr(t,e,"x")}function sr(t,e,n){let r=s=>n==="y"?s.h:s.w,o=e.nodeGap;for(let s=0;s<2;s+=1){let i=s===0?t.layers.slice(1):t.layers.slice(0,-1).reverse();for(let a of i){let d=new Map;for(let l of a){let f=s===0?l.in:l.out;if(f.length===0)continue;let p=[];for(let c of f){let g=t.nodes.get(s===0?c.fromId:c.toId);if(!g)continue;let m=n==="y"?g.y:g.x;p.push(m+Math.floor(r(g)/2))}if(p.length===0)continue;p.sort((c,g)=>c-g);let h=p[Math.floor(p.length/2)];d.set(l.id,h-Math.floor(r(l)/2))}let u=0;for(let l of a){let f=d.get(l.id),p=n==="y"?l.y:l.x,c=Math.max(f??p,u);n==="y"?l.y=c:l.x=c,u=c+r(l)+o}}}}function _o(t,e){let n=new Map;for(let u of t.hops){let l=n.get(u.chainId);l?l.push(u):n.set(u.chainId,[u])}for(let u of n.values())u.sort((l,f)=>l.hopIndex-f.hopIndex);let r=e.direction==="LR",o=u=>r?u.x:u.y,s=u=>r?u.w:u.h,i=u=>r?u.y+Math.floor(u.h/2):u.x+Math.floor(u.w/2),a=new Map;for(let u=0;u+1<t.layers.length;u+=1){let l=t.layers[u],f=t.layers[u+1],p=0;for(let E of l)p=Math.max(p,o(E)+s(E));let h=Number.POSITIVE_INFINITY;for(let E of f)h=Math.min(h,o(E));let c=Number.isFinite(h)?h-1:p,g=Math.max(1,c-p+1),m=[];for(let E of l)for(let N of E.out)m.push(N);m.sort((E,N)=>{let M=i(t.nodes.get(E.fromId)),S=i(t.nodes.get(N.fromId));if(M!==S)return M-S;let C=i(t.nodes.get(E.toId)),k=i(t.nodes.get(N.toId));return C-k});let v=[],_=new Map;for(let E of m){let N=i(t.nodes.get(E.fromId)),M=i(t.nodes.get(E.toId)),S=Math.min(N,M),C=Math.max(N,M),k=-1;for(let $=0;$<v.length;$+=1){let B=v[$],X=!0;for(let fe of B)if(fe.lo<=C&&S<=fe.hi){X=!1;break}if(X){B.push({lo:S,hi:C}),k=$;break}}k<0&&(v.push([{lo:S,hi:C}]),k=v.length-1),_.set(E,k)}let y=v.length,b=g>=Math.max(3,y+2),x=b?p+1:p,T=b?c-1:c,w=Math.max(1,T-x+1);for(let E of m){let N=_.get(E),M;if(y<=1)M=x+Math.floor(w/2);else{let S=(w-1)/(y-1);M=x+Math.floor(N*S)}a.set(E,Math.max(p,Math.min(c,M)))}}let d=[];for(let[,u]of n){let l=[];for(let p=0;p<u.length;p+=1){let h=u[p],c=t.nodes.get(h.fromId),g=t.nodes.get(h.toId),m=a.get(h),v=c.isVirtual?o(c):o(c)+s(c),_=g.isVirtual?o(g):o(g)-1,y=i(c),b=i(g);p===0&&pt(l,r,v,y),y!==b&&(pt(l,r,m,y),pt(l,r,m,b)),pt(l,r,_,b)}let f=u[0];d.push({from:f.chainFrom,to:f.chainTo,points:wo(l)})}return d}function pt(t,e,n,r){t.push(e?{x:n,y:r}:{x:r,y:n})}function wo(t){let e=[];for(let n of t){let r=e[e.length-1];(!r||r.x!==n.x||r.y!==n.y)&&e.push(n)}return e}function xo(t){let e=0,n=0;for(let r of t.layers)for(let o of r)e=Math.max(e,o.x+o.w),n=Math.max(n,o.y+o.h);return{width:e,height:n}}var To=24,Eo=4,Oo=1,No=3;function ir(t,e){let n=So(e.direction),r=Math.max(3,e.maxLabelWidth??To),o=e.asciiCharset??"unicode",s=Object.keys(t.nodes).sort(),i=new Set(s),a=t.edges.filter(h=>i.has(h.from)&&i.has(h.to)),d=new Map,u=new Map;for(let h of s){let c=Jn(h,r);d.set(h,c),u.set(h,lt(c)+4)}let l=or({nodes:s,edges:a,widthCells:h=>u.get(h)??3,heightCells:()=>No,layerGap:Eo,nodeGap:Oo,direction:n}),f=er(l,{charset:o,labelOf:h=>d.get(h)??h}),p=e.logger;return p&&p(f),f}function So(t){if(t===void 0||t==="LR")return"LR";if(t==="TD")return"TD";throw new Error(`ascii describe supports direction "LR" or "TD" only; got ${String(t)}`)}function ar(t,e,n,r={}){let o=e in t.nodes,s=n in t.nodes;if(!o)return ht(e,n,"no-such-from");if(!s)return ht(e,n,"no-such-to");let i=r.maxDepth;if(i!=null&&(!Number.isInteger(i)||i<0))throw new Error("explainPath: maxDepth must be an integer >= 0");if(e===n){if(r.findCycle===!0){let u=ko(t,e,r);if(u!=null)return u}let d=gt(e,t.nodes[e],0,r);return mt(e,n,[d])}if(i===0)return ht(e,n,"no-path");let a=ur(t,e,n,i);return a.found?mt(e,n,dr(t,a.pathOrder,r)):ht(e,n,a.truncated?"max-depth-exceeded":"no-path")}function ur(t,e,n,r){let o=new Map,s=[{path:n,depth:0}],i=new Set([n]),a=0,d=!1;for(;a<s.length;){let f=s[a++];if(f.path===e)break;if(r!=null&&f.depth>=r){let g=t.nodes[f.path];g?.deps&&g.deps.length>0&&(d=!0);continue}let p=t.nodes[f.path];if(p==null)continue;let h=p.deps??[],c=new Map;for(let g=0;g<h.length;g++){let m=h[g];if(!m)continue;let v=c.get(m);v==null&&(v=[],c.set(m,v)),v.push(g)}for(let[g,m]of c)i.has(g)||(i.add(g),o.set(g,{from:f.path,depIndices:m}),s.push({path:g,depth:f.depth+1}))}if(!o.has(e))return{found:!1,pathOrder:[],truncated:d};let u=[{path:e}],l=e;for(;l!==n;){let f=o.get(l);if(f==null)return{found:!1,pathOrder:[],truncated:!1};u[u.length-1].depIndices=f.depIndices,u.push({path:f.from}),l=f.from}return{found:!0,pathOrder:u,truncated:!1}}function ko(t,e,n){let r=t.nodes[e];if(r==null)return null;let o=r.deps??[],s=[];for(let a=0;a<o.length;a++)o[a]===e&&s.push(a);if(s.length>0){let a=gt(e,r,0,n);a.dep_index=s[0];let d=gt(e,r,1,n);return mt(e,e,[a,d])}let i=null;for(let a=0;a<o.length;a++){let d=o[a];if(!d||d===e)continue;let u=ur(t,d,e,n.maxDepth);u.found&&(i==null||u.pathOrder.length<i.pathOrder.length)&&(i=u,i={found:!0,pathOrder:[{path:e,depIndices:[a]},...u.pathOrder],truncated:!1})}return i==null?null:mt(e,e,dr(t,i.pathOrder,n))}function dr(t,e,n){return e.map((r,o)=>{let s=t.nodes[r.path],i=gt(r.path,s,o,n);return r.depIndices!=null&&r.depIndices.length>0&&(i.dep_index=r.depIndices[0],r.depIndices.length>1&&(i.dep_indices=[...r.depIndices])),i})}function gt(t,e,n,r){let o={path:t,type:e.type,hop:n};e.status!==void 0&&(o.status=e.status),"value"in e&&(o.value=e.value),e.v!=null&&(o.v=e.v);let s=r.annotations?.get(t)??e.annotation;s!=null&&(o.annotation=s);let i=r.lastMutations?.get(t)??e.lastMutation;return i!=null&&(o.lastMutation=i),o}function mt(t,e,n){return cr(t,e,!0,"ok",n)}function ht(t,e,n){return cr(t,e,!1,n,[])}function cr(t,e,n,r,o){let s=Co(t,e,n,r,o);return{from:t,to:e,found:n,reason:r,steps:o,text:s,toJSON(){return{from:t,to:e,found:n,reason:r,steps:o}}}}function Co(t,e,n,r,o){if(!n)switch(r){case"no-such-from":return`explainPath: no node named "${t}"`;case"no-such-to":return`explainPath: no node named "${e}"`;case"max-depth-exceeded":return`explainPath: no path from "${t}" to "${e}" within maxDepth`;default:return`explainPath: no path from "${t}" to "${e}"`}let s=[`Causal path: ${t} \u2192 ${e} (${o.length} step(s))`];for(let i of o){let d=` ${i.hop===0?"\xB7":"\u2193"} ${i.path} (${i.type}${i.status?`/${i.status}`:""})`;if(s.push(d),"value"in i&&s.push(` value: ${Ro(i.value)}`),i.annotation!=null&&s.push(` annotation: ${i.annotation}`),i.lastMutation!=null){let u=i.lastMutation.actor;s.push(` actor: ${u.type}${u.id?`:${u.id}`:""}`)}}return s.join(`
11
+ `)}function Ro(t){if(t===void 0)return"<sentinel>";if(t===null)return"null";if(typeof t=="string")return JSON.stringify(t);if(typeof t=="number"||typeof t=="boolean"||typeof t=="bigint")return String(t);try{let e=JSON.stringify(t);return e.length>80?`${e.slice(0,77)}...`:e}catch{return String(t)}}Ie();var H={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},Mo=Symbol.for("sizeof");function lr(t){let e=new WeakSet,n=new WeakSet,r=[t],o=0;for(;r.length>0;){let s=r.pop();o+=Do(s,e,n,r)}return o}function Do(t,e,n,r){if(t==null)return 0;switch(typeof t){case"number":return H.number;case"boolean":return H.boolean;case"string":return H.string+t.length*2;case"bigint":return H.bigint+Ao(t);case"symbol":return H.symbol;case"function":return e.has(t)?0:(e.add(t),H.function);case"undefined":return 0}let s=t;if(e.has(s))return 0;e.add(s);let i=s[Mo];if(typeof i=="function")try{let u=i.call(s);if(typeof u=="number"&&Number.isFinite(u))return u}catch{}if(s instanceof Date)return H.date;if(s instanceof RegExp)return H.regexp+s.source.length*2;if(s instanceof Error){let u=s.message?s.message.length*2:0,l=s.stack?s.stack.length*2:0;return H.error+u+l}if(typeof URL<"u"&&s instanceof URL)return H.url+s.href.length*2;if(typeof Promise<"u"&&s instanceof Promise)return H.promise;if(s instanceof WeakMap)return H.weakmap;if(s instanceof WeakSet)return H.weakset;if(s instanceof Map){let u=H.map;for(let[l,f]of s)u+=H.mapEntry,r.push(l),r.push(f);return u}if(s instanceof Set){let u=H.set;for(let l of s)u+=H.setEntry,r.push(l);return u}if(Array.isArray(s)){let u=H.array+s.length*8;for(let l of s)r.push(l);return u}if(s instanceof ArrayBuffer)return n.has(s)?0:(n.add(s),s.byteLength);if(ArrayBuffer.isView(s)){let u=s;return n.has(u.buffer)?48:(n.add(u.buffer),u.buffer.byteLength+48)}let a=H.object,d=Object.keys(s);for(let u of d){a+=H.string+u.length*2;try{r.push(s[u])}catch{}}return a}function Ao(t){let e=t<0n?-t:t;if(e===0n)return 0;let n=e.toString(2).length;return Math.ceil(n/32)*8}function fr(t,e){let n=e?.topN??10,r=t.describe({detail:"standard"}),o=[],s=t._collectObserveTargets;typeof s=="function"&&s.call(t,"",o);let i=new Map;for(let[p,h]of o)i.set(p,h);let a=[];for(let[p,h]of Object.entries(r.nodes)){let c=i.get(p),g=c instanceof P?c:null,m=g?lr(g.cache):0,v=g?g._sinkCount:0,_=h.deps?.length??0,y=h.type==="effect"&&v===0,b=v===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:m,subscriberCount:v,depCount:_,isOrphanEffect:y,orphanKind:b})}let d=a.reduce((p,h)=>p+h.valueSizeBytes,0),u=(p,h)=>[...a].sort(h??((c,g)=>g[p]-c[p])).slice(0,n),l=a.filter(p=>p.orphanKind!=null),f=a.filter(p=>p.isOrphanEffect);return{nodeCount:a.length,edgeCount:r.edges.length,subgraphCount:r.subgraphs.length,nodes:a,totalValueSizeBytes:d,hotspots:{byValueSize:u("valueSizeBytes"),bySubscriberCount:u("subscriberCount"),byDepCount:u("depCount")},orphans:l,orphanEffects:f}}var I="::",Q="__meta__",_e=1;function pr(t,e){let n=Math.max(16,t.size*4),r=0;for(;t.size>0;){if(r++>=n){console.error(`[Graph "${e}".destroy] disposer drain exceeded cap (${n}); ${t.size} disposer(s) discarded`),t.clear();return}let o=t.values().next();if(o.done)return;let s=o.value;t.delete(s);try{s()}catch(i){console.error(`[Graph "${e}".destroy] disposer threw:`,i)}}}function Go(t){let e=[];for(let n of Object.keys(t).sort()){let r=t[n].v;r!=null&&e.push(`${n} ${r.id} ${r.version}`)}return e.join(`
12
12
  `)}function hr(t){if(t.version!==_e)throw new Error(`unsupported snapshot version ${String(t.version)} (expected ${_e})`);for(let e of["name","nodes","edges","subgraphs"])if(!(e in t))throw new Error(`snapshot missing required key "${e}"`);if(typeof t.name!="string")throw new TypeError("snapshot 'name' must be a string");if(typeof t.nodes!="object"||t.nodes===null||Array.isArray(t.nodes))throw new TypeError("snapshot 'nodes' must be an object");if(!Array.isArray(t.edges))throw new TypeError("snapshot 'edges' must be an array");if(!Array.isArray(t.subgraphs))throw new TypeError("snapshot 'subgraphs' must be an array")}function Io(t,e){let n=new WeakMap,r=(o,s)=>{if(Object.is(o,s))return!0;if(o==null||s==null||typeof o!="object"||typeof s!="object")return!1;let i=n.get(o);if(i==null&&(i=new WeakSet,n.set(o,i)),i.has(s))return!0;i.add(s);let a=o.constructor,d=s.constructor;if(a!==d)return!1;if(o instanceof Date)return o.getTime()===s.getTime();if(o instanceof RegExp)return o.source===s.source&&o.flags===s.flags;if(Array.isArray(o)){let p=s;if(o.length!==p.length)return!1;for(let h=0;h<o.length;h++)if(!r(o[h],p[h]))return!1;return!0}if(o instanceof Map){let p=s;if(o.size!==p.size)return!1;for(let[h,c]of o)if(!p.has(h)||!r(c,p.get(h)))return!1;return!0}if(o instanceof Set){let p=s;if(o.size!==p.size)return!1;for(let h of o){let c=!1;for(let g of p)if(r(h,g)){c=!0;break}if(!c)return!1}return!0}if(ArrayBuffer.isView(o)){let p=o,h=s;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 u=Object.keys(o),l=Object.keys(s);if(u.length!==l.length)return!1;let f=new Set(l);for(let p of u)if(!f.has(p)||!r(o[p],s[p]))return!1;return!0};return r(t,e)}function Wt(t){if(t===null||typeof t!="object")return t;if(Array.isArray(t))return t.map(Wt);let e=t,n=Object.keys(e).sort(),r={};for(let o of n)r[o]=Wt(e[o]);return r}function Lo(t){return t.replaceAll("\\","\\\\").replaceAll('"','\\"')}function Po(t){return t.replaceAll("\\","\\\\").replaceAll('"','\\"')}function $o(t){return t==="TD"?"down":t==="BT"?"up":t==="RL"?"left":"right"}function mr(t){let e=new Set,n=[];function r(o,s){let i=`${o}\0${s}`;e.has(i)||(e.add(i),n.push([o,s]))}for(let[o,s]of Object.entries(t.nodes)){let i=s.deps;if(i)for(let a of i)r(a,o)}for(let o of t.edges)r(o.from,o.to);return n}function yr(t){if(t===void 0)return"LR";if(t==="TD"||t==="LR"||t==="BT"||t==="RL")return t;throw new Error(`invalid diagram direction ${String(t)}; expected one of: TD, LR, BT, RL`)}function Ho(t,e){let n=e.includeEdges??!0,r=e.includeSubgraphs??!0,{expand:o,...s}=t,i={...s,edges:n?t.edges:[],subgraphs:r?t.subgraphs:[]},a=JSON.stringify(Wt(i),null,e.indent??2);return e.logger?.(a),a}function Fo(t,e){let n=e.includeEdges??!0,r=e.includeSubgraphs??!0,o=[];o.push(`Graph ${t.name}`),o.push("Nodes:");for(let i of Object.keys(t.nodes).sort()){let a=t.nodes[i];o.push(`- ${i} (${a.type}/${a.status}): ${bt(a.value)}`)}if(n){o.push("Edges:");for(let i of t.edges)o.push(`- ${i.from} -> ${i.to}`)}if(r){o.push("Subgraphs:");for(let i of t.subgraphs)o.push(`- ${i}`)}let s=o.join(`
13
13
  `);return e.logger?.(s),s}function br(t,e){let n=yr(e.direction),r=Object.keys(t.nodes).sort(),o=new Map;for(let i=0;i<r.length;i+=1)o.set(r[i],`n${i}`);let s=[`flowchart ${n}`];for(let i of r){let a=o.get(i);s.push(` ${a}["${Lo(i)}"]`)}for(let[i,a]of mr(t)){let d=o.get(i),u=o.get(a);!d||!u||s.push(` ${d} --> ${u}`)}return s.join(`
14
14
  `)}function qo(t,e){let n=br(t,e);return vr(n)}function vr(t,e){let n=e?.theme??"default",r=e?.autoSync??!0,s=JSON.stringify({code:t,mermaid:{theme:n},autoSync:r}),i=new TextEncoder().encode(s),a="";for(let u=0;u<i.length;u++)a+=String.fromCharCode(i[u]);return`https://mermaid.live/edit#base64:${globalThis.btoa(a).replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/,"")}`}function jo(t,e){let n=yr(e.direction),r=Object.keys(t.nodes).sort(),o=new Map;for(let i=0;i<r.length;i+=1)o.set(r[i],`n${i}`);let s=[`direction: ${$o(n)}`];for(let i of r){let a=o.get(i);s.push(`${a}: "${Po(i)}"`)}for(let[i,a]of mr(t)){let d=o.get(i),u=o.get(a);!d||!u||s.push(`${d} -> ${u}`)}return s.join(`
15
- `)}function Bo(t){return t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function yt(t){let e="^";for(let n=0;n<t.length;n+=1){let r=t[n];if(r==="*"){e+=".*";continue}if(r==="?"){e+=".";continue}if(r==="["){let o=t.indexOf("]",n+1);if(o<=n+1){e+="\\[";continue}let s=t.slice(n+1,o);s.startsWith("!")&&(s=`^${s.slice(1)}`),s=s.replace(/\\/g,"\\\\"),e+=`[${s}]`,n=o;continue}e+=Bo(r)}return e+="$",new RegExp(e)}var Vo={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"},Wo={data:"",dirty:"",resolved:"",invalidate:"",pause:"",resume:"",complete:"",error:"",teardown:"",derived:"",path:"",reset:""};function bt(t){if(typeof t=="string")return JSON.stringify(t);if(typeof t=="number"||typeof t=="boolean"||t==null)return String(t);try{return JSON.stringify(t)}catch{return"[unserializable]"}}function zo(t){return t==="none"?Wo:t==="ansi"||t==null?Vo:{data:t.data??"",dirty:t.dirty??"",resolved:t.resolved??"",invalidate:t.invalidate??"",pause:t.pause??"",resume:t.resume??"",complete:t.complete??"",error:t.error??"",teardown:t.teardown??"",derived:t.derived??"",path:t.path??"",reset:t.reset??""}}function gr(t){if(t==null)return{};let e=t.detail;return e==="full"?{...t,structured:t.structured??!0,timeline:t.timeline??!0,causal:t.causal??!0,derived:t.derived??!0}:e==="minimal"?{...t,structured:t.structured??!0}:t.format==="stage-log"?{...t,structured:t.structured??!0,timeline:t.timeline??!0}:t}function Uo(t,e,n){for(let r=0;r<t.length;r++){let o=t.charCodeAt(r);if(o<32||o===127)throw new Error(`Graph "${e}": ${n} "${t}" must not contain control character (U+${o.toString(16).padStart(4,"0").toUpperCase()} at index ${r})`)}}function Vt(t,e,n){if(t==="")throw new Error(`Graph "${e}": ${n} name must be non-empty`);if(t.includes(I))throw new Error(`Graph "${e}": ${n} "${t}" must not contain '${I}' (path separator)`);if(t===Q)throw new Error(`Graph "${e}": ${n} name "${Q}" is reserved for meta companion paths`);Uo(t,e,n)}function Ko(t,e){if(t==="")throw new Error(`Graph "${e}": resolve path must be non-empty`);let n=t.split(I);for(let r of n)if(r==="")throw new Error(`Graph "${e}": resolve path has empty segment`);return n}function Yo(t,e){let n=!1;for(let o of t)if(!e.isMetaPassthrough(o[0])){n=!0;break}return n?t.filter(o=>e.isMetaPassthrough(o[0])):t}function _r(t){for(let e of t._mounts.values())_r(e);for(let e of t._nodes.values())try{e.down([[F]],{internal:!0})}catch{}}var ie=class t{name;opts;config;_nodes=new Map;_nodeToName=new WeakMap;_mounts=new Map;_parent=void 0;_storageDisposers=new Set;_disposers=new Set;_topology;_topologyEmitters=new Set;constructor(e,n){if(e==="")throw new Error("Graph name must be non-empty");if(e.includes(I))throw new Error(`Graph name must not contain '${I}' (got "${e}")`);if(e===Q)throw new Error(`Graph name "${Q}" is reserved for meta companion paths`);this.name=e,this.opts=Object.freeze({...n??{}}),this.config=n?.config??ye,this._traceRing=new Qe(n?.traceCapacity??1e3),n?.versioning!=null&&this.setVersioning(n.versioning)}ancestors(e=!0){let n=[],r=e?this:this._parent;for(;r!=null;)n.push(r),r=r._parent;return n}get topology(){return this._topology==null&&(this._topology=Le(e=>{let n=r=>{e.emit(r)};return this._topologyEmitters.add(n),()=>{this._topologyEmitters.delete(n)}},{name:`${this.name}_topology`})),this._topology}_emitTopology(e){if(!(this._topology==null||this._topologyEmitters.size===0))for(let n of this._topologyEmitters)n(e)}add(e,n){let r=e.name,o=n?.name??r;if(o==null||o==="")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 s=o,i=n?.annotation;if(Vt(s,this.name,"add"),this._mounts.has(s))throw new Error(`Graph "${this.name}": name "${s}" is already a mount point`);if(this._nodes.has(s))throw new Error(`Graph "${this.name}": node "${s}" 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(s,e),this._nodeToName.set(e,s),this._emitTopology({kind:"added",name:s,nodeKind:"node"}),i!=null&&(this._annotations.set(s,i),this.config.inspectorEnabled&&this._traceRing.push({path:s,annotation:i,timestamp_ns:Ce()})),e}setVersioning(e){if(e!=null)for(let n of this._nodes.values())n instanceof P&&n._applyVersioning(e)}remove(e){Vt(e,this.name,"remove");let n=this._mounts.get(e);if(n){let s={kind:"mount",nodes:[],mounts:[]},i=[];n._collectObserveTargets("",i);for(let[a,d]of i)a.includes(`${I}${Q}${I}`)||s.nodes.push(a);return s.nodes.sort(),s.mounts.push(e),s.mounts.push(...n._collectSubgraphs(`${e}${I}`)),this._mounts.delete(e),n._parent=void 0,_r(n),this._emitTopology({kind:"removed",name:e,nodeKind:"mount",audit:s}),s}let r=this._nodes.get(e);if(!r)throw new Error(`Graph "${this.name}": unknown node or mount "${e}"`);this._nodes.delete(e),this._nodeToName.delete(r),r.down([[F]],{internal:!0});let o={kind:"node",nodes:[e],mounts:[]};return this._emitTopology({kind:"removed",name:e,nodeKind:"node",audit:o}),o}removeAll(e){let n=typeof e=="function"?e:(()=>{let s=yt(e);return i=>s.test(i)})(),r={kind:"mount",nodes:[],mounts:[]},o=[...this._nodes.keys(),...this._mounts.keys()].filter(s=>n(s));for(let s of o){let i=this.remove(s);r.nodes.push(...i.nodes),r.mounts.push(...i.mounts)}return r.nodes.sort(),r.mounts.sort(),r}[Symbol.iterator](){let e=[...this._nodes.keys()].sort(),n=this._nodes,r=0;return{[Symbol.iterator](){return this},next(){if(r>=e.length)return{value:void 0,done:!0};let o=e[r++];return{value:[o,n.get(o)],done:!1}}}}node(e){if(e==="")throw new Error(`Graph "${this.name}": node name must be non-empty`);if(e.includes(I))return this.resolve(e);let n=this._nodes.get(e);if(!n)throw new Error(`Graph "${this.name}": unknown node "${e}"`);return n}get(e){return this.node(e).cache}set(e,n,r){let o=r?.internal===!0;this.node(e).down([[C,n]],{actor:r?.actor,internal:o,delivery:"write"})}setAll(e,n){let r=Symbol.iterator in e?e:Object.entries(e);Ae(()=>{for(let[o,s]of r)this.set(o,s,n)})}invalidate(e,n){let r=n?.internal===!0;this.node(e).down([[ee]],{actor:n?.actor,internal:r,delivery:"write"})}error(e,n,r){let o=r?.internal===!0;this.node(e).down([[A,n]],{actor:r?.actor,internal:o,delivery:"write"})}complete(e,n){let r=n?.internal===!0;this.node(e).down([[L]],{actor:n?.actor,internal:r,delivery:"write"})}edges(e){let n=e?.recursive===!0,r=new Map;if(!n){for(let[d,u]of this._nodes)r.set(u,d);let a=[];for(let[d,u]of this._nodes)if(u instanceof P)for(let l of u._deps){let f=r.get(l.node);f!=null&&a.push([f,d])}return a.sort((d,u)=>d[0]<u[0]?-1:d[0]>u[0]?1:d[1]<u[1]?-1:d[1]>u[1]?1:0),a}let o=[];this._collectObserveTargets("",o);let s=new Map;for(let[a,d]of o)s.set(d,a);let i=[];for(let[a,d]of o)if(d instanceof P)for(let u of d._deps){let l=s.get(u.node);l!=null&&i.push([l,a])}return i.sort((a,d)=>a[0]<d[0]?-1:a[0]>d[0]?1:a[1]<d[1]?-1:a[1]>d[1]?1:0),i}mount(e,n){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 r=this;r!=null;r=r._parent)if(r===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 n=Ko(e,this.name);return this._resolveFromSegments(n)}tryResolve(e){try{return this.resolve(e)}catch{return}}_resolveFromSegments(e){let n=e;if(n[0]===this.name&&(n=n.slice(1),n.length===0))throw new Error(`Graph "${this.name}": resolve path ends at graph name only`);let r=n[0],o=n.slice(1);if(o.length===0){let a=this._nodes.get(r);if(a)return a;throw this._mounts.has(r)?new Error(`Graph "${this.name}": path ends at subgraph "${r}" \u2014 not a node (GRAPHREFLY-SPEC \xA73.5)`):new Error(`Graph "${this.name}": unknown name "${r}"`)}let s=this._nodes.get(r);if(s&&o.length>0&&o[0]===Q)return this._resolveMetaChainFromNode(s,o,n.join(I));let i=this._mounts.get(r);if(!i)throw this._nodes.has(r)?new Error(`Graph "${this.name}": "${r}" is a node; trailing path "${o.join(I)}" is invalid`):new Error(`Graph "${this.name}": unknown mount or node "${r}"`);return i.resolve(o.join(I))}_resolveMetaChainFromNode(e,n,r){let o=e,s=0,i=[...n];for(;s<i.length;){if(i[s]!==Q)throw new Error(`Graph "${this.name}": expected ${Q} segment in meta path "${r}"`);if(s+1>=i.length)throw new Error(`Graph "${this.name}": meta path requires a key after ${Q} in "${r}"`);let a=i[s+1],d=o.meta[a];if(!d)throw new Error(`Graph "${this.name}": unknown meta "${a}" in path "${r}"`);o=d,s+=2}return o}signal(e,n){if(n?.internal!==!0){for(let o of e)if(this.config.messageTier(o[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 r=[];if(this._signalDeliver(e,n??{},new Set,r),r.length>0)throw r[0]}_signalDeliver(e,n,r,o){for(let d of this._mounts.values())d._signalDeliver(e,n,r,o);let i=n.internal===!0?{internal:!0}:{actor:n.actor,delivery:"signal"},a=Yo(e,this.config);for(let d of[...this._nodes.keys()].sort()){let u=this._nodes.get(d);if(!r.has(u)){r.add(u);try{u.down(e,i)}catch(l){if(l instanceof J)throw l;o.push(l)}a.length!==0&&this._signalMetaSubtree(u,a,r,i,o)}}}_signalMetaSubtree(e,n,r,o,s){for(let i of Object.keys(e.meta).sort()){let a=e.meta[i];if(!r.has(a)){r.add(a);try{a.down(n,o)}catch(d){if(d instanceof J)throw d;s.push(d)}this._signalMetaSubtree(a,n,r,o,s)}}}describe(e){if(e?.reactive===!0)return this._describeReactive(e);let n=e?.actor,r=e?.filter,o=dt(e?.detail,e?.fields),s=e?.format==="spec",i=s?dt("minimal"):o,a=[];this._collectObserveTargets("",a);let d=new Map;for(let[T,w]of a)d.set(w,T);let u=[];{let T=a.map(([,N])=>N),w=new Set(d.values()),E=0;for(;T.length>0;){let N=T.shift();if(N instanceof P)for(let M of N._deps){let S=M.node;if(d.has(S))continue;let R=S.name??"",k=R;if(!k||w.has(k))if(R){let $=2;for(;w.has(`${R}#${$}`);)$++;k=`${R}#${$}`}else for(k=`__internal__/${E++}`;w.has(k);)k=`__internal__/${E++}`;d.set(S,k),w.add(k),u.push([k,S]),T.push(S)}}}let l=[...a,...u],f={};for(let[T,w]of l){if(n!=null&&!w.allowsObserve(n))continue;let E=jt(w,i),N=w instanceof P?w._deps.map(k=>d.get(k.node)??k.node.name??""):[],{name:M,...S}=E,R={...S,deps:N};if(!s){let k=this._annotations.get(T);k!=null&&(R.annotation=k)}if(r!=null)if(typeof r=="function"){let k=r;if(!(k.length>=2?k(T,R):k(R)))continue}else{let k=!0;for(let[$,B]of Object.entries(r)){let X=$==="deps_includes"?"depsIncludes":$==="meta_has"?"metaHas":$;if(X==="depsIncludes"){if(!R.deps.includes(String(B))){k=!1;break}continue}if(X==="metaHas"){if(!Object.hasOwn(R.meta??{},String(B))){k=!1;break}continue}if(R[X]!==B){k=!1;break}}if(!k)continue}f[T]=R}let p=new Set(Object.keys(f)),h=[];for(let[T,w]of l)if(w instanceof P)for(let E of w._deps){let N=d.get(E.node);N!=null&&h.push([N,T])}h.sort((T,w)=>T[0]<w[0]?-1:T[0]>w[0]?1:T[1]<w[1]?-1:T[1]>w[1]?1:0);let c=h.map(([T,w])=>({from:T,to:w}));(n!=null||r!=null)&&(c=c.filter(T=>p.has(T.from)&&p.has(T.to)));let g=this._collectSubgraphs(""),m=n!=null||r!=null?g.filter(T=>{let w=`${T}${I}`;return[...p].some(E=>E===T||E.startsWith(w))}):g,v=this,_=e,y={name:this.name,nodes:f,edges:c,subgraphs:m,expand(T){let w={..._,format:void 0};return Array.isArray(T)?(w.fields=T,w.detail=void 0):(w.detail=T,w.fields=void 0),v.describe(w)}},b=e??{},x=b.format;return x==="json"?Ho(y,b):x==="pretty"?Fo(y,b):x==="mermaid"?br(y,b):x==="mermaid-url"?qo(y,b):x==="d2"?jo(y,b):x==="ascii"?ir(y,b):y}_collectSubgraphs(e){let n=[];for(let r of[...this._mounts.keys()].sort()){let o=e===""?r:`${e}${r}`;n.push(o),n.push(...this._mounts.get(r)._collectSubgraphs(`${o}${I}`))}return n}resourceProfile(e){return fr(this,e)}reachable(e,n,r={}){return r.withDetail===!0?zt(this.describe(),e,n,{...r,withDetail:!0}):zt(this.describe(),e,n,r)}explain(e,n,r){return r?.reactive===!0?this._explainReactive(e,n,r):this._explainStatic(e,n,r)}_explainStatic(e,n,r){let o=this.describe({detail:"full"}),s=new Map(this._annotations),i=new Map;for(let[a,d]of Object.entries(o.nodes))d.lastMutation!=null&&i.set(a,d.lastMutation);return ar(o,e,n,{...r?.maxDepth!=null?{maxDepth:r.maxDepth}:{},...r?.findCycle===!0?{findCycle:!0}:{},annotations:s,lastMutations:i})}_describeReactive(e){let n={...e,reactive:!1},r=e.reactiveName??"describe",o=0,s=oe(o,{name:`${r}_version`}),i=this.observe({timeline:!0,structured:!0}),a=!1,d=!1,u=()=>{a||d||(a=!0,ze(()=>{a=!1,!d&&(o+=1,s.emit(o))}))},l=i.onEvent(m=>{let v=m.type;v!=="data"&&v!=="error"&&v!=="complete"&&v!=="teardown"||u()}),f=[],p=new WeakSet,h=m=>{if(p.has(m)||d)return;p.add(m);let v=m.topology.subscribe(_=>{for(let y of _){if(y[0]!==C)continue;let b=y[1];if(u(),b.kind==="added"&&b.nodeKind==="mount"){let x=m._mounts.get(b.name);x!=null&&h(x)}}});f.push(v);for(let _ of m._mounts.keys()){let y=m._mounts.get(_);y!=null&&h(y)}};h(this);let c;try{c=se([s],()=>this.describe(n),{name:r,describeKind:"derived",meta:{domain:"audit",kind:"describe"},equals:(m,v)=>m===v})}catch(m){l();for(let v of f)v();throw i.dispose(),m}let g=de(c);return{node:c,dispose(){d=!0,l();for(let m of f)m();f.length=0,i.dispose(),g()}}}_explainReactive(e,n,r){let o=0,s=oe(o,{name:"explain_version"}),i=this.observe({timeline:!0,structured:!0}),a=!1,d=!1,u=i.onEvent(h=>{let c=h.type;c!=="data"&&c!=="error"&&c!=="complete"&&c!=="teardown"||a||d||(a=!0,ze(()=>{a=!1,!d&&(o+=1,s.emit(o))}))}),l={...r?.maxDepth!=null?{maxDepth:r.maxDepth}:{},...r?.findCycle===!0?{findCycle:!0}:{}},f;try{f=se([s],()=>this._explainStatic(e,n,l),{name:r?.name??"explain",describeKind:"derived",meta:{domain:"audit",kind:"explain_path",from:e,to:n},equals:(h,c)=>h.found===c.found&&h.reason===c.reason&&h.steps.length===c.steps.length&&Jo(h.steps,c.steps)})}catch(h){throw u(),i.dispose(),h}let p=de(f);return{node:f,dispose(){d=!0,u(),i.dispose(),p()}}}_pathsMatching(e){let n=yt(e),r=[];return this._collectObserveTargets("",r),r.map(([o])=>o).filter(o=>n.test(o))}_collectObserveTargets(e,n){for(let r of[...this._mounts.keys()].sort()){let o=e===""?r:`${e}${I}${r}`;this._mounts.get(r)._collectObserveTargets(o,n)}for(let r of[...this._nodes.keys()].sort()){let o=this._nodes.get(r),s=e===""?r:`${e}${I}${r}`;n.push([s,o]),this._appendMetaObserveTargets(s,o,n)}}_appendMetaObserveTargets(e,n,r){for(let o of Object.keys(n.meta).sort()){let s=n.meta[o],i=`${e}${I}${Q}${I}${o}`;r.push([i,s]),this._appendMetaObserveTargets(i,s,r)}}observe(e,n){let r=typeof e=="string",s=gr(r?n:e),i=s.structured===!0||s.timeline===!0||s.causal===!0||s.derived===!0||s.detail==="minimal"||s.detail==="full"||s.format!=null,a=s.actor;if(r){let l=e,f=this.resolve(l);if(a!=null&&!f.allowsObserve(a))throw new J({actor:a,action:"observe",nodeName:l});return i?this._buildStructuredObserver([[l,f]],s,"one"):{subscribe(p){return f.subscribe(p)},up(p){try{f.up?.(p)}catch(h){if(h instanceof J)return;throw h}}}}let d=[];this._collectObserveTargets("",d),d.sort((l,f)=>l[0]<f[0]?-1:l[0]>f[0]?1:0);let u=a==null?d:d.filter(([,l])=>l.allowsObserve(a));return i?this._buildStructuredObserver(u,s,"all"):{subscribe:l=>{let f=u.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 J)return;throw p}}}}_buildStructuredObserver(e,n,r){let o=r==="one"?e[0]?.[0]:void 0,s=i=>{if(r==="one"&&o!=null){let l=this.resolve(o);return this._buildStructuredObserver([[o,l]],i,"one")}let a=[];this._collectObserveTargets("",a),a.sort((l,f)=>l[0]<f[0]?-1:l[0]>f[0]?1:0);let d=i.actor,u=d==null?a:a.filter(([,l])=>l.allowsObserve(d));return this._buildStructuredObserver(u,i,"all")};return this._createObserveResult(e,n,s)}_createObserveResult(e,n,r){let o=n.timeline===!0,s=n.causal===!0,i=n.derived===!0,a=n.detail==="minimal",d=this.config.inspectorEnabled,u=(s||i)&&d,l=n.maxEvents,f=l!=null&&l>0?new Qe(l):null,p=[],h=new Set,c={},g=new Set,m=0,v=0,_=0,y=0,b=0,x=0,T=!1,w=!1,E=0,N=new Map,M=new Map,S=new Map,R=O=>{f?f.push(O):p.push(O);for(let G of h)G(O)},k=()=>o?{timestamp_ns:Ce(),in_batch:et(),batch_id:E}:{},$=(O,G)=>{if(!(!u||!(O instanceof P)))return O._setInspectorHook(z=>{if(z.kind==="dep_message")N.set(O,z.depIndex);else if(z.kind==="run"){let Pe=z.batchData.map((D,q)=>D!=null&&D.length>0?D.at(-1):z.prevData[q]);M.set(O,Pe);let U=z.batchData.map(D=>D!=null?[...D]:void 0);S.set(O,U),i&&R({type:"derived",path:G,dep_values:Pe,dep_batches:U,...k()})}})},B=O=>{let G=N.get(O),z=M.get(O);if(!s||z==null)return{};let U=(G!=null&&G>=0&&O instanceof P?O._deps[G]:void 0)?.node,D=U?.v,q=S.get(O);return{trigger_dep_index:G,trigger_dep_name:U?.name,...D!=null?{trigger_version:{id:D.id,version:D.version}}:{},dep_values:[...z],...q!=null?{dep_batches:q}:{}}},X=[],fe=[];for(let[O,G]of e){let z=$(G,O);z&&X.push(z),fe.push(G.subscribe(Pe=>{E++;for(let U of Pe){let D=U[0],q=k();if(D===C){c[O]=U[1];let Et=G instanceof P?G.lastMutation?.actor??ue:ue;R({type:"data",path:O,data:U[1],actor:Et,...q,...B(G)})}else if(a)D===W?m++:D===Z?v++:D===ee?_++:D===K?y++:D===te?b++:D===F?x++:D===L&&!g.has(O)?T=!0:D===A&&(w=!0,g.add(O));else if(D===W)m++,R({type:"dirty",path:O,...q});else if(D===Z)v++,R({type:"resolved",path:O,...q,...B(G)});else if(D===ee)_++,R({type:"invalidate",path:O,...q});else if(D===K)y++,R({type:"pause",path:O,lockId:U[1],...q});else if(D===te)b++,R({type:"resume",path:O,lockId:U[1],...q});else if(D===L)g.has(O)||(T=!0),R({type:"complete",path:O,...q});else if(D===A){w=!0,g.add(O);let Et=G instanceof P?G.lastMutation?.actor??ue:ue;R({type:"error",path:O,data:U[1],actor:Et,...q})}else D===F&&(x++,R({type:"teardown",path:O,...q}))}}))}let wt=!1,xt=()=>{if(!wt){wt=!0;for(let O of fe)O();for(let O of X)O();for(let O of Ze)O({value:void 0,done:!0});Ze.length=0}},Tt=[],Ze=[];h.add(O=>{let G=Ze.shift();G?G({value:O,done:!1}):Tt.push(O)});let Xt={get values(){return c},get dirtyCount(){return m},get resolvedCount(){return v},get invalidateCount(){return _},get pauseCount(){return y},get resumeCount(){return b},get teardownCount(){return x},get events(){return f?f.toArray():[...p]},get anyCompletedCleanly(){return T},get anyErrored(){return w},get completedWithoutErrors(){return T&&!w},onEvent(O){return h.add(O),()=>h.delete(O)},dispose:xt,expand(O){xt();let G={...n};return typeof O=="string"?G.detail=O:Object.assign(G,O),r(gr(G))},[Symbol.asyncIterator](){return{next(){return Tt.length>0?Promise.resolve({value:Tt.shift(),done:!1}):wt?Promise.resolve({value:void 0,done:!0}):new Promise(O=>Ze.push(O))},return(){return xt(),Promise.resolve({value:void 0,done:!0})}}}};return n.format!=null&&this._attachFormatLogger(Xt,n),Xt}_attachFormatLogger(e,n){let r=n.format;if(r==null)return;let o=n.logger??(c=>console.log(c)),s=n.includeTypes?new Set(n.includeTypes):null,i=n.excludeTypes?new Set(n.excludeTypes):null,a=s==null&&i==null?()=>!0:c=>(s==null||s.has(c))&&(i==null||!i.has(c)),d=zo(n.theme),u=r==="stage-log"?Ce():0,l=c=>c==null?"":n.stageLabels?.[c]??c,f=(c,g)=>c.length>g?`${c.slice(0,g-1)}\u2026`:c,p=c=>c.type==="data"||c.type==="error"?f(bt(c.data),120):"",h=c=>{if(r==="stage-log"){let w=(Ce()-u)/1e9,E=l(c.path).padEnd(9);if(c.type==="data"){let N=p(c);return`[${w.toFixed(3)}s] ${E} \u2190${N?` ${N}`:""}`}if(c.type==="error"){let N=p(c);return`[${w.toFixed(3)}s] ${E} \u2717${N?` ${N}`:""}`}return c.type==="complete"?`[${w.toFixed(3)}s] ${E} \u25A0 complete`:`[${w.toFixed(3)}s] ${E} ${c.type}`}if(r==="json")try{return JSON.stringify(c)}catch{return JSON.stringify({type:c.type,path:c.path,data:"[unserializable]"})}let g=d[c.type]??"",m=c.path?`${d.path}${c.path}${d.reset} `:"",v=c.type==="data"||c.type==="error",_=c.type==="pause"||c.type==="resume",y=v?` ${bt(c.data)}`:_?` ${bt(c.lockId)}`:"",b=c.type==="data"||c.type==="resolved"||c.type==="derived"?c:void 0,x=b?.trigger_dep_name!=null?` <- ${b.trigger_dep_name}`:b?.trigger_dep_index!=null?` <- #${b.trigger_dep_index}`:"",T=c.in_batch?" [batch]":"";return`${m}${g}${c.type.toUpperCase()}${d.reset}${y}${x}${T}`};e.onEvent(c=>{a(c.type)&&o(h(c),c)})}addDisposer(e){return this._disposers.add(e),()=>{this._disposers.delete(e)}}destroy(){pr(this._disposers,this.name),this.signal([[F]],{internal:!0}),pr(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}_destroyClearOnly(){for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0}snapshot(e){let{expand:n,...r}=this.describe({detail:"full"}),o={};for(let a of Object.keys(r.nodes).sort()){let{lastMutation:d,guard:u,...l}=r.nodes[a];o[a]=l}let s=[...r.subgraphs].sort(),i={...r,version:1,nodes:o,subgraphs:s};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 En(a,a.encode(i))}throw new Error(`snapshot: unknown format "${String(e.format)}"`)}static decode(e,n){let r=n?.config??ye,{codec:o,codecVersion:s,payload:i}=On(e,r);return o.decode(i,s)}restore(e,n){if(hr(e),e.name!==this.name)throw new Error(`Graph "${this.name}": restore snapshot name "${e.name}" does not match this graph`);let r=n?.only==null?null:(Array.isArray(n.only)?n.only:[n.only]).map(s=>yt(s)),o=n?.includeProducers===!0;for(let s of Object.keys(e.nodes).sort()){if(r!==null&&!r.some(a=>a.test(s)))continue;let i=e.nodes[s];if(i!==void 0){if(!("value"in i)||i.value===void 0){"value"in i&&i.value===void 0&&n?.onError?.(s,new Error(`restore: slice.value is undefined for "${s}" (undefined is the global SENTINEL; not valid DATA)`));continue}if(!(i.type==="derived"||i.type==="effect")&&!(i.type==="producer"&&!o)){if(i.v!=null){let d=this.tryResolve(s)?.v;if(d!=null&&d.id===i.v.id&&d.version===i.v.version)continue}try{this.set(s,i.value)}catch(a){n?.onError?.(s,a)}}}}}static fromSnapshot(e,n){hr(e);let r=typeof n=="function"?n:n?.build,o=typeof n=="function"?void 0:n?.factories,s=new t(e.name);if(r)return r(s),s.restore(e),s;for(let h of[...e.subgraphs].sort((c,g)=>{let m=c.split(I).length,v=g.split(I).length;return m!==v?m-v:c<g?-1:c>g?1:0})){let c=h.split(I),g=s;for(let m of c)g._mounts.has(m)||g.mount(m,new t(m)),g=g._mounts.get(m)}let i=o?Object.entries(o).map(([h,c])=>({re:yt(h),factory:c})):[],a=h=>{for(let c of i)if(c.re.test(h))return c.factory},d=h=>{let c=h.split(I),g=c.pop();if(g==null||g.length===0)throw new Error(`invalid snapshot path "${h}"`);let m=s;for(let v of c){let _=m._mounts.get(v);if(!_)throw new Error(`unknown mount "${v}" in path "${h}"`);m=_}return[m,g]},u=Object.entries(e.nodes).filter(([h])=>!h.includes(`${I}${Q}${I}`)).sort((h,c)=>h[0]<c[0]?-1:h[0]>c[0]?1:0),l=new Map(u),f=new Map,p=!0;for(;l.size>0&&p;){p=!1;for(let[h,c]of[...l.entries()]){let g=c?.deps??[];if(!g.every(x=>f.has(x)))continue;let[m,v]=d(h),_={...c?.meta??{}},y=a(h),b;if(c?.type==="state")b=oe(c.value,{meta:_});else{if(y==null)continue;b=y(v,{path:h,type:c.type,value:c.value,meta:_,deps:g,resolvedDeps:g.map(x=>f.get(x))})}m.add(b,{name:v}),f.set(h,b),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 s.restore(e),s}toJSON(){return this.snapshot()}attachStorage(e,n={}){let r=e.map(u=>({tier:u,debounceMs:Math.max(0,u.debounceMs??0),compactEvery:Math.max(1,u.compactEvery??10),timer:void 0,seq:0,lastSnapshot:void 0,lastFingerprint:"",disposed:!1,savePending:void 0}));n.autoRestore===!0&&this._cascadeRestore(e,n.onError);let o=(u,l)=>{if(u.disposed)return;let f=Go(l.nodes);if(u.lastSnapshot!=null&&f!==""&&f===u.lastFingerprint)return;let p=u.seq+1,h=ae(),m=u.lastSnapshot==null||p%u.compactEvery===0?{mode:"full",snapshot:l,seq:p,timestamp_ns:h,format_version:_e}:{mode:"diff",diff:wr(u.lastSnapshot,l),seq:p,timestamp_ns:h,format_version:_e};if(u.tier.filter&&!u.tier.filter(this.name,m))return;let v;try{v=u.tier.save(this.name,m)}catch(_){n.onError?.(_,u.tier);return}if(v&&typeof v.then=="function"){let b=(u.savePending??Promise.resolve()).then(()=>v,()=>v).then(()=>{u.disposed||(u.seq=p,u.lastSnapshot=l,u.lastFingerprint=f)},x=>{n.onError?.(x,u.tier)});u.savePending=b.finally(()=>{u.savePending===b&&(u.savePending=void 0)})}else u.seq=p,u.lastSnapshot=l,u.lastFingerprint=f},s=(u,l)=>{try{o(u,l)}catch(f){n.onError?.(f,u.tier)}},i=(u,l)=>{if(!l.some(c=>{let g=this.config.messageTier(c[0]);return g>=3&&g<5}))return;if(n.filter){let c=this.tryResolve(u);if(c==null)return;let g=jt(c,dt("standard"));if(!n.filter(u,g))return}let p,h=()=>(p==null&&(p=this.snapshot()),p);for(let c of r)c.disposed||(c.debounceMs===0?s(c,h()):(c.timer==null&&(c.timer=new ct),c.timer.start(c.debounceMs,()=>{c.disposed||s(c,this.snapshot())})))},a;if(n.paths!=null){let l=(typeof n.paths=="string"?this._pathsMatching(n.paths):n.paths).map(f=>{let p=this.tryResolve(f);return p==null?()=>{}:p.subscribe(h=>i(f,h))});a=()=>{for(let f of l)f()}}else a=this.observe().subscribe((u,l)=>i(u,l));let d=()=>{a();for(let u of r)u.disposed=!0,u.timer?.cancel();this._storageDisposers.delete(d)};return this._storageDisposers.add(d),{dispose:d}}async _cascadeRestore(e,n){for(let r of e){let o;try{o=await r.load(this.name)}catch(i){n?.(i,r);continue}if(o==null||typeof o!="object"||Array.isArray(o))continue;let s=o;try{if(s.mode==="full"&&s.snapshot!=null)return this.restore(s.snapshot),!0;if(s.version===_e&&s.nodes!=null)return this.restore(s),!0}catch(i){n?.(i,r)}}return!1}static async fromStorage(e,n,r){for(let o of n){let s;try{s=await o.load(e)}catch(d){r?.onError?.(d,o);continue}if(s==null||typeof s!="object"||Array.isArray(s))continue;let i=s,a=i.mode==="full"&&i.snapshot!=null?i.snapshot:i.version===_e&&i.nodes!=null?i:void 0;if(a!=null)try{return t.fromSnapshot(a,r)}catch(d){r?.onError?.(d,o)}}throw new Error(`Graph.fromStorage: no tier held a restorable record for "${e}" across ${n.length} tier(s)`)}_annotations=new Map;_traceRing;trace(e,n,r){if(e!=null&&n!=null){if(this.tryResolve(e)==null)return;if(this._annotations.set(e,n),this.config.inspectorEnabled){let o={path:e,annotation:n,timestamp_ns:Ce(),...r?.actor!=null?{actor:r.actor}:{}};this._traceRing.push(o)}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 n=this._traceRing.toArray().filter(o=>!e(o)),r=this._traceRing.size-n.length;this._traceRing.clear();for(let o of n)this._traceRing.push(o);return r}static diff(e,n){let r=new Set(Object.keys(e.nodes)),o=new Set(Object.keys(n.nodes)),s=[...o].filter(_=>!r.has(_)).sort(),i=[...r].filter(_=>!o.has(_)).sort(),a=[],d=[];for(let _ of r){if(!o.has(_))continue;let y=e.nodes[_],b=n.nodes[_],x=y.v,T=b.v;x!=null&&T!=null&&x.id===T.id&&x.version!==T.version&&d.push({path:_,id:x.id,from:x.version,to:T.version});let w=x!=null&&T!=null&&x.id===T.id&&x.version===T.version;for(let E of["type","status","sentinel"]){let N=y[E],M=b[E];N!==M&&a.push({path:_,field:E,from:N,to:M})}if(!w)for(let E of["value","meta"]){let N=y[E],M=b[E];Io(N,M)||a.push({path:_,field:E,from:N,to:M})}}let u=_=>`${_.from} ${_.to}`,l=new Set(e.edges.map(u)),f=new Set(n.edges.map(u)),p=n.edges.filter(_=>!l.has(u(_))),h=e.edges.filter(_=>!f.has(u(_))),c=new Set(e.subgraphs),g=new Set(n.subgraphs),m=[...g].filter(_=>!c.has(_)).sort(),v=[...c].filter(_=>!g.has(_)).sort();return{nodesAdded:s,nodesRemoved:i,nodesChanged:a,versionChanges:d,edgesAdded:p,edgesRemoved:h,subgraphsAdded:m,subgraphsRemoved:v}}};function wr(t,e){let n=ie.diff(t,e),r={};for(let o of n.nodesAdded){let s=e.nodes[o];s!=null&&(r[o]=s)}return{...n,nodesAddedFull:r}}function zt(t,e,n,r={}){let o={paths:[],depths:new Map,truncated:!1};if(!e)return r.withDetail?o:[];if(!r.both&&n!=="upstream"&&n!=="downstream")throw new Error('reachable: direction must be "upstream" or "downstream"');let s=r.maxDepth;if(s!=null&&(!Number.isInteger(s)||s<0))throw new Error("reachable: maxDepth must be an integer >= 0");if(s===0)return r.withDetail?o:[];let i=new Map,a=new Map,d=new Map,u=new Map,l=new Set;for(let[y,b]of Object.entries(t.nodes)){if(!y)continue;l.add(y);let x=b.deps??[];i.set(y,x);for(let T of x)T&&(l.add(T),a.has(T)||a.set(T,new Set),a.get(T).add(y))}for(let y of t.edges){if(y==null||typeof y!="object")continue;let b=typeof y.from=="string"?y.from:"",x=typeof y.to=="string"?y.to:"";!b||!x||(l.add(b),l.add(x),u.has(b)||u.set(b,new Set),u.get(b).add(x),d.has(x)||d.set(x,new Set),d.get(x).add(b))}if(!l.has(e))return r.withDetail?o:[];let f=r.both===!0,p=y=>{if(f){let w=i.get(y)??[],E=d.get(y),N=a.get(y),M=u.get(y),S=[...w];return E&&S.push(...E),N&&S.push(...N),M&&S.push(...M),S}if(n==="upstream"){let w=i.get(y)??[],E=d.get(y);return E?[...w,...E]:w}let b=a.get(y),x=u.get(y),T=b?[...b]:[];return x&&T.push(...x),T},h=new Set([e]),c=new Map,g=[{path:e,depth:0}],m=0,v=!1;for(;m<g.length;){let y=g[m++];if(s!=null&&y.depth>=s){p(y.path).length>0&&(v=!0);continue}for(let b of p(y.path))!b||h.has(b)||(h.add(b),c.set(b,y.depth+1),g.push({path:b,depth:y.depth+1}))}let _=[...c.keys()].sort((y,b)=>y<b?-1:y>b?1:0);return r.withDetail?{paths:_,depths:c,truncated:v}:_}function Jo(t,e){if(t.length!==e.length)return!1;for(let n=0;n<t.length;n++){let r=t[n],o=e[n];if(r.path!==o.path||r.type!==o.type||r.status!==o.status||r.hop!==o.hop||r.dep_index!==o.dep_index||r.annotation!==o.annotation||r.value!==o.value||r.lastMutation!==o.lastMutation)return!1;let s=r.v,i=o.v;if(s!==i&&(s==null||i==null||s.id!==i.id||s.version!==i.version))return!1}return!0}Ue();je();Ge();Be();Ge();Ie();Ke();Ue();re();Ke();var Ut=class{_version=0;_maxSize;_buf;_head=0;_size=0;constructor(e,n){if(n!==void 0&&n<1)throw new RangeError("maxSize must be >= 1");if(this._maxSize=n,n!==void 0){if(this._buf=new Array(n),e&&e.length>0){let r=Math.min(e.length,n),o=e.length-r;for(let s=0;s<r;s++)this._buf[s]=e[o+s];this._size=r}}else this._buf=e?[...e]:[],this._size=this._buf.length}get version(){return this._version}get size(){return this._size}at(e){if(!Number.isInteger(e))return;let n=e>=0?e:this._size+e;if(!(n<0||n>=this._size))return this._maxSize!==void 0?this._buf[(this._head+n)%this._maxSize]:this._buf[n]}append(e){this._rawAppend(e),this._version+=1}appendMany(e){if(e.length===0)return;let n=this._maxSize!==void 0&&e.length>this._maxSize?e.length-this._maxSize:0;for(let r=n;r<e.length;r++)this._rawAppend(e[r]);this._version+=1}clear(){if(this._size===0)return 0;let e=this._size;if(this._maxSize===void 0)this._buf.length=0;else for(let n=0;n<e;n++)this._buf[(this._head+n)%this._maxSize]=void 0;return this._head=0,this._size=0,this._version+=1,e}trimHead(e){if(!Number.isInteger(e)||e<0)throw new RangeError(`trimHead: n must be a non-negative integer (got ${e})`);if(e===0||this._size===0)return 0;let n=Math.min(e,this._size);if(this._maxSize===void 0)this._buf.splice(0,n);else{for(let r=0;r<n;r++)this._buf[(this._head+r)%this._maxSize]=void 0;this._head=(this._head+n)%this._maxSize}return this._size-=n,this._version+=1,n}slice(e,n){if(!Number.isInteger(e)||e<0)throw new RangeError(`slice: start must be a non-negative integer (got ${e})`);if(n!==void 0&&(!Number.isInteger(n)||n<0))throw new RangeError(`slice: stop must be a non-negative integer or undefined (got ${n})`);let r=n===void 0?this._size:Math.min(Math.max(n,0),this._size),o=Math.min(e,this._size);if(o>=r)return[];let s=r-o;if(this._maxSize===void 0)return this._buf.slice(o,r);let i=new Array(s);for(let a=0;a<s;a++)i[a]=this._buf[(this._head+o+a)%this._maxSize];return i}tail(e){if(!Number.isInteger(e)||e<0)throw new RangeError(`tail: n must be a non-negative integer (got ${e})`);if(e===0||this._size===0)return[];let n=Math.min(e,this._size);return this.slice(this._size-n,this._size)}toArray(){if(this._maxSize===void 0)return[...this._buf];let e=new Array(this._size);for(let n=0;n<this._size;n++)e[n]=this._buf[(this._head+n)%this._maxSize];return e}_rawAppend(e){if(this._maxSize===void 0){this._buf.push(e),this._size=this._buf.length;return}this._size<this._maxSize?(this._buf[(this._head+this._size)%this._maxSize]=e,this._size+=1):(this._buf[this._head]=e,this._head=(this._head+1)%this._maxSize)}};function xr(t){return t.subscribe(()=>{})}var Qo=64;function Tr(t,e={}){let{name:n,maxSize:r,versioning:o,backend:s}=e,i=s??new Ut(t,r),a=oe(i.toArray(),{name:n,describeKind:"state",equals:(c,g)=>c===g,...o!=null?{versioning:o}:{}});function d(){let c=i.toArray();Ae(()=>{a.down([[W]]),a.down([[C,c]])})}let u=new Map,l=new Map;function f(c,g){return`${c}:${g===void 0?"END":g}`}function p(c){if(c.size<Qo)return;let g=c.keys().next();if(g.done)return;let m=c.get(g.value);m!==void 0&&m.dispose(),c.delete(g.value)}function h(c){let g=i.version;try{return c()}finally{i.version!==g&&d()}}return{entries:a,get size(){return i.size},at(c){return i.at(c)},append(c){h(()=>i.append(c))},appendMany(c){c.length!==0&&h(()=>i.appendMany(c))},clear(){h(()=>i.clear())},trimHead(c){h(()=>i.trimHead(c))},tail(c){if(!Number.isInteger(c)||c<0)throw new RangeError(`tail: n must be a non-negative integer (got ${c})`);let g=u.get(c);if(g!==void 0)return u.delete(c),u.set(c,g),g.node;p(u);let m=se([a],([_])=>{let y=_;return c===0||y.length===0?[]:y.slice(Math.max(0,y.length-c))},{initial:i.tail(c),describeKind:"derived"}),v=xr(m);return u.set(c,{node:m,dispose:v}),m},slice(c,g){if(!Number.isInteger(c)||c<0)throw new RangeError(`slice: start must be a non-negative integer (got ${c})`);if(g!==void 0&&(!Number.isInteger(g)||g<0))throw new RangeError(`slice: stop must be a non-negative integer or undefined (got ${g})`);let m=f(c,g),v=l.get(m);if(v!==void 0)return l.delete(m),l.set(m,v),v.node;p(l);let _=se([a],([b])=>{let x=b;return g===void 0?x.slice(c):x.slice(c,g)},{initial:i.slice(c,g),describeKind:"derived"}),y=xr(_);return l.set(m,{node:_,dispose:y}),_},disposeTail(c){let g=u.get(c);return g===void 0?!1:(g.dispose(),u.delete(c),!0)},disposeSlice(c,g){let m=f(c,g),v=l.get(m);return v===void 0?!1:(v.dispose(),l.delete(m),!0)},disposeAllViews(){for(let c of u.values())c.dispose();u.clear();for(let c of l.values())c.dispose();l.clear()},dispose(){for(let c of u.values())c.dispose();u.clear();for(let c of l.values())c.dispose();l.clear()}}}st();function Er(t,e,n){return{[t]:!0,[`${t}_type`]:e,...n??{}}}var Xo=rt((t,e)=>{t("write"),t("signal"),e("observe")}),Zo=rt((t,e)=>{t("observe"),t("signal"),e("write")}),es=rt((t,e)=>{t("observe"),t("signal"),e("write")});function vt(t,e){return Er("cqrs",t,e)}var Kt=class extends ie{_eventLogs=new Map;_commandHandlers=new Map;_projections=new Set;_sagas=new Set;_keepaliveDisposers=[];_eventStore;_seq=0;constructor(e,n={}){super(e,n.graph)}destroy(){for(let e of this._keepaliveDisposers)e();this._keepaliveDisposers.length=0,super.destroy()}event(e){let n=this._eventLogs.get(e);if(n)return n.node;let r=Tr([],{name:e,versioning:0}),o=r.entries,s=se([o],([i])=>i,{name:e,describeKind:"state",meta:vt("event",{event_name:e}),guard:es,initial:o.cache});return this.add(s,{name:e}),this._keepaliveDisposers.push(de(s)),this._eventLogs.set(e,{log:r,node:s}),s}_appendEvent(e,n){let r=this._eventLogs.get(e);if(r||(this.event(e),r=this._eventLogs.get(e)),r.node.status==="completed"||r.node.status==="errored")throw new Error(`Cannot dispatch to terminated event stream "${e}" (status: ${r.node.status}).`);let o=r.log.entries.v,s={type:e,payload:n,timestampNs:ae(),seq:++this._seq,...o!=null?{v0:{id:o.id,version:o.version}}:{}};r.log.append(s),this._eventStore&&this._eventStore.persist(s)}command(e,n){let r=oe(void 0,{name:e,describeKind:"state",meta:{...vt("command",{command_name:e}),error:null},guard:Xo});return this.add(r,{name:e}),this._commandHandlers.set(e,n),r}dispatch(e,n){let r=this._commandHandlers.get(e);if(!r)throw new Error(`Unknown command: "${e}". Register with .command() first.`);let o=this.resolve(e);Ae(()=>{o.emit(n,{internal:!0});try{r(n,{emit:(s,i)=>this._appendEvent(s,i)}),o.meta.error.emit(null,{internal:!0})}catch(s){throw o.meta.error.emit(s,{internal:!0}),s}})}projection(e,n,r,o){let s=n.map(a=>(this._eventLogs.has(a)||this.event(a),this._eventLogs.get(a).node)),i=se(s,a=>{let d=[];for(let u of a){let l=u;d.push(...l)}return d.sort((u,l)=>u.timestampNs-l.timestampNs||u.seq-l.seq),r(o,d)},{name:e,describeKind:"derived",meta:vt("projection",{projection_name:e,source_events:n}),guard:Zo,initial:o});return this.add(i,{name:e}),this._keepaliveDisposers.push(de(i)),this._projections.add(e),i}saga(e,n,r){let o=n.map(d=>(this._eventLogs.has(d)||this.event(d),this._eventLogs.get(d).node)),s=new Map,i={},a=be(o,(d,u)=>{let l=i.n.meta.error;for(let f=0;f<d.length;f++){let p=d[f];if(p==null||p.length===0)continue;let h=p.at(-1);if(!h)continue;let c=n[f],g=s.get(c)??0;if(h.length>g){let m=h.slice(g);for(let v of m)try{r(v),l.emit(null,{internal:!0})}catch(_){l.emit(_,{internal:!0})}s.set(c,h.length)}}},{name:e,describeKind:"effect",meta:{...vt("saga",{saga_name:e,source_events:n}),error:null}});return i.n=a,this.add(a,{name:e}),this._keepaliveDisposers.push(de(a)),this._sagas.add(e),a}useEventStore(e){this._eventStore=e}async rebuildProjection(e,n,r){if(!this._eventStore)throw new Error("No event store wired. Call useEventStore() first.");let o=[];for(let s of e){let i=await this._eventStore.loadEvents(s);o.push(...i.events)}return o.sort((s,i)=>s.timestampNs-i.timestampNs||s.seq-i.seq),n(r,o)}};function Or(t,e){return new Kt(t,e)}var Jt=class{constructor(e){this.graph=e}onModuleDestroy(){this.graph.destroy()}},Qt=class{graph=new ie("request");onModuleDestroy(){this.graph.destroy()}},Nr,Yt;Nr=[(0,Xe.Module)({})];var le=class le{static forRoot(e){let n=e??{},r=n.name??"root",o=[{provide:Y,useFactory:()=>{let s=new ie(r);return n.build&&n.build(s),n.snapshot&&s.restore(n.snapshot),s}},{provide:Symbol.for("graphrefly:root-lifecycle"),useFactory:s=>new Jt(s),inject:[Y]},{provide:ve,useFactory:(s,i)=>new ve(s,i),inject:[Y,Sr.ModuleRef]}];if(n.nodes)for(let s of n.nodes)o.push({provide:ne(s),useFactory:i=>i.resolve(s),inject:[Y]});return n.requestScope&&o.push({provide:Symbol.for("graphrefly:request-lifecycle"),useFactory:()=>new Qt,scope:Xe.Scope.REQUEST},{provide:pe,useFactory:s=>s.graph,inject:[Symbol.for("graphrefly:request-lifecycle")],scope:Xe.Scope.REQUEST}),{module:le,global:!0,providers:o,exports:[Y,...(n.nodes??[]).map(ne),...n.requestScope?[pe]:[]]}}static forFeature(e){let n=[{provide:j(e.name),useFactory:r=>{let o=new ie(e.name);return e.build&&e.build(o),e.snapshot&&o.restore(e.snapshot),r.mount(e.name,o),o},inject:[Y]}];if(e.nodes)for(let r of e.nodes)n.push({provide:ne(`${e.name}::${r}`),useFactory:o=>o.resolve(r),inject:[j(e.name)]});return{module:le,providers:n,exports:[j(e.name),...(e.nodes??[]).map(r=>ne(`${e.name}::${r}`))]}}static forCqrs(e){let n=[{provide:j(e.name),useFactory:r=>{let o=Or(e.name,e.cqrs);return e.eventStore&&o.useEventStore(e.eventStore),e.build&&e.build(o),r.mount(e.name,o),o},inject:[Y]}];if(e.nodes)for(let r of e.nodes)n.push({provide:ne(`${e.name}::${r}`),useFactory:o=>o.resolve(r),inject:[j(e.name)]});return{module:le,providers:n,exports:[j(e.name),...(e.nodes??[]).map(r=>ne(`${e.name}::${r}`))]}}};Yt=on(null),le=un(Yt,0,"GraphReflyModule",Nr,le),an(Yt,1,le);var _t=le;0&&(module.exports={ACTOR_KEY,COMMAND_HANDLERS,CQRS_EVENT_HANDLERS,CRON_HANDLERS,CommandHandler,EVENT_HANDLERS,EventHandler,GRAPHREFLY_REQUEST_GRAPH,GRAPHREFLY_ROOT_GRAPH,GraphCron,GraphInterval,GraphReflyEventExplorer,GraphReflyGuard,GraphReflyGuardImpl,GraphReflyModule,INTERVAL_HANDLERS,InjectCqrsGraph,InjectGraph,InjectNode,ObserveGateway,OnGraphEvent,QUERY_HANDLERS,QueryHandler,SAGA_HANDLERS,SagaHandler,fromHeader,fromJwtPayload,getActor,getGraphToken,getNodeToken,observeSSE,observeSubscription,toObservable});
15
+ `)}function Bo(t){return t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function yt(t){let e="^";for(let n=0;n<t.length;n+=1){let r=t[n];if(r==="*"){e+=".*";continue}if(r==="?"){e+=".";continue}if(r==="["){let o=t.indexOf("]",n+1);if(o<=n+1){e+="\\[";continue}let s=t.slice(n+1,o);s.startsWith("!")&&(s=`^${s.slice(1)}`),s=s.replace(/\\/g,"\\\\"),e+=`[${s}]`,n=o;continue}e+=Bo(r)}return e+="$",new RegExp(e)}var Vo={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"},Wo={data:"",dirty:"",resolved:"",invalidate:"",pause:"",resume:"",complete:"",error:"",teardown:"",derived:"",path:"",reset:""};function bt(t){if(typeof t=="string")return JSON.stringify(t);if(typeof t=="number"||typeof t=="boolean"||t==null)return String(t);try{return JSON.stringify(t)}catch{return"[unserializable]"}}function zo(t){return t==="none"?Wo:t==="ansi"||t==null?Vo:{data:t.data??"",dirty:t.dirty??"",resolved:t.resolved??"",invalidate:t.invalidate??"",pause:t.pause??"",resume:t.resume??"",complete:t.complete??"",error:t.error??"",teardown:t.teardown??"",derived:t.derived??"",path:t.path??"",reset:t.reset??""}}function gr(t){if(t==null)return{};let e=t.detail;return e==="full"?{...t,structured:t.structured??!0,timeline:t.timeline??!0,causal:t.causal??!0,derived:t.derived??!0}:e==="minimal"?{...t,structured:t.structured??!0}:t.format==="stage-log"?{...t,structured:t.structured??!0,timeline:t.timeline??!0}:t}function Uo(t,e,n){for(let r=0;r<t.length;r++){let o=t.charCodeAt(r);if(o<32||o===127)throw new Error(`Graph "${e}": ${n} "${t}" must not contain control character (U+${o.toString(16).padStart(4,"0").toUpperCase()} at index ${r})`)}}function Vt(t,e,n){if(t==="")throw new Error(`Graph "${e}": ${n} name must be non-empty`);if(t.includes(I))throw new Error(`Graph "${e}": ${n} "${t}" must not contain '${I}' (path separator)`);if(t===Q)throw new Error(`Graph "${e}": ${n} name "${Q}" is reserved for meta companion paths`);Uo(t,e,n)}function Ko(t,e){if(t==="")throw new Error(`Graph "${e}": resolve path must be non-empty`);let n=t.split(I);for(let r of n)if(r==="")throw new Error(`Graph "${e}": resolve path has empty segment`);return n}function Yo(t,e){let n=!1;for(let o of t)if(!e.isMetaPassthrough(o[0])){n=!0;break}return n?t.filter(o=>e.isMetaPassthrough(o[0])):t}function _r(t){for(let e of t._mounts.values())_r(e);for(let e of t._nodes.values())try{e.down([[F]],{internal:!0})}catch{}}var ie=class t{name;opts;config;_nodes=new Map;_nodeToName=new WeakMap;_mounts=new Map;_parent=void 0;_storageDisposers=new Set;_disposers=new Set;_topology;_topologyEmitters=new Set;constructor(e,n){if(e==="")throw new Error("Graph name must be non-empty");if(e.includes(I))throw new Error(`Graph name must not contain '${I}' (got "${e}")`);if(e===Q)throw new Error(`Graph name "${Q}" is reserved for meta companion paths`);this.name=e,this.opts=Object.freeze({...n??{}}),this.config=n?.config??ye,this._traceRing=new Qe(n?.traceCapacity??1e3),n?.versioning!=null&&this.setVersioning(n.versioning)}ancestors(e=!0){let n=[],r=e?this:this._parent;for(;r!=null;)n.push(r),r=r._parent;return n}get topology(){return this._topology==null&&(this._topology=Le(e=>{let n=r=>{e.emit(r)};return this._topologyEmitters.add(n),()=>{this._topologyEmitters.delete(n)}},{name:`${this.name}_topology`})),this._topology}_emitTopology(e){if(!(this._topology==null||this._topologyEmitters.size===0))for(let n of this._topologyEmitters)n(e)}add(e,n){let r=e.name,o=n?.name??r;if(o==null||o==="")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 s=o,i=n?.annotation;if(Vt(s,this.name,"add"),this._mounts.has(s))throw new Error(`Graph "${this.name}": name "${s}" is already a mount point`);if(this._nodes.has(s))throw new Error(`Graph "${this.name}": node "${s}" 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(s,e),this._nodeToName.set(e,s),this._emitTopology({kind:"added",name:s,nodeKind:"node"}),i!=null&&(this._annotations.set(s,i),this.config.inspectorEnabled&&this._traceRing.push({path:s,annotation:i,timestamp_ns:Re()})),e}setVersioning(e){if(e!=null)for(let n of this._nodes.values())n instanceof P&&n._applyVersioning(e)}remove(e){Vt(e,this.name,"remove");let n=this._mounts.get(e);if(n){let s={kind:"mount",nodes:[],mounts:[]},i=[];n._collectObserveTargets("",i);for(let[a,d]of i)a.includes(`${I}${Q}${I}`)||s.nodes.push(a);return s.nodes.sort(),s.mounts.push(e),s.mounts.push(...n._collectSubgraphs(`${e}${I}`)),this._mounts.delete(e),n._parent=void 0,_r(n),this._emitTopology({kind:"removed",name:e,nodeKind:"mount",audit:s}),s}let r=this._nodes.get(e);if(!r)throw new Error(`Graph "${this.name}": unknown node or mount "${e}"`);this._nodes.delete(e),this._nodeToName.delete(r),r.down([[F]],{internal:!0});let o={kind:"node",nodes:[e],mounts:[]};return this._emitTopology({kind:"removed",name:e,nodeKind:"node",audit:o}),o}removeAll(e){let n=typeof e=="function"?e:(()=>{let s=yt(e);return i=>s.test(i)})(),r={kind:"mount",nodes:[],mounts:[]},o=[...this._nodes.keys(),...this._mounts.keys()].filter(s=>n(s));for(let s of o){let i=this.remove(s);r.nodes.push(...i.nodes),r.mounts.push(...i.mounts)}return r.nodes.sort(),r.mounts.sort(),r}[Symbol.iterator](){let e=[...this._nodes.keys()].sort(),n=this._nodes,r=0;return{[Symbol.iterator](){return this},next(){if(r>=e.length)return{value:void 0,done:!0};let o=e[r++];return{value:[o,n.get(o)],done:!1}}}}node(e){if(e==="")throw new Error(`Graph "${this.name}": node name must be non-empty`);if(e.includes(I))return this.resolve(e);let n=this._nodes.get(e);if(!n)throw new Error(`Graph "${this.name}": unknown node "${e}"`);return n}get(e){return this.node(e).cache}set(e,n,r){let o=r?.internal===!0;this.node(e).down([[R,n]],{actor:r?.actor,internal:o,delivery:"write"})}setAll(e,n){let r=Symbol.iterator in e?e:Object.entries(e);Ae(()=>{for(let[o,s]of r)this.set(o,s,n)})}invalidate(e,n){let r=n?.internal===!0;this.node(e).down([[ee]],{actor:n?.actor,internal:r,delivery:"write"})}error(e,n,r){let o=r?.internal===!0;this.node(e).down([[A,n]],{actor:r?.actor,internal:o,delivery:"write"})}complete(e,n){let r=n?.internal===!0;this.node(e).down([[L]],{actor:n?.actor,internal:r,delivery:"write"})}edges(e){let n=e?.recursive===!0,r=new Map;if(!n){for(let[d,u]of this._nodes)r.set(u,d);let a=[];for(let[d,u]of this._nodes)if(u instanceof P)for(let l of u._deps){let f=r.get(l.node);f!=null&&a.push([f,d])}return a.sort((d,u)=>d[0]<u[0]?-1:d[0]>u[0]?1:d[1]<u[1]?-1:d[1]>u[1]?1:0),a}let o=[];this._collectObserveTargets("",o);let s=new Map;for(let[a,d]of o)s.set(d,a);let i=[];for(let[a,d]of o)if(d instanceof P)for(let u of d._deps){let l=s.get(u.node);l!=null&&i.push([l,a])}return i.sort((a,d)=>a[0]<d[0]?-1:a[0]>d[0]?1:a[1]<d[1]?-1:a[1]>d[1]?1:0),i}mount(e,n){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 r=this;r!=null;r=r._parent)if(r===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 n=Ko(e,this.name);return this._resolveFromSegments(n)}tryResolve(e){try{return this.resolve(e)}catch{return}}_resolveFromSegments(e){let n=e;if(n[0]===this.name&&(n=n.slice(1),n.length===0))throw new Error(`Graph "${this.name}": resolve path ends at graph name only`);let r=n[0],o=n.slice(1);if(o.length===0){let a=this._nodes.get(r);if(a)return a;throw this._mounts.has(r)?new Error(`Graph "${this.name}": path ends at subgraph "${r}" \u2014 not a node (GRAPHREFLY-SPEC \xA73.5)`):new Error(`Graph "${this.name}": unknown name "${r}"`)}let s=this._nodes.get(r);if(s&&o.length>0&&o[0]===Q)return this._resolveMetaChainFromNode(s,o,n.join(I));let i=this._mounts.get(r);if(!i)throw this._nodes.has(r)?new Error(`Graph "${this.name}": "${r}" is a node; trailing path "${o.join(I)}" is invalid`):new Error(`Graph "${this.name}": unknown mount or node "${r}"`);return i.resolve(o.join(I))}_resolveMetaChainFromNode(e,n,r){let o=e,s=0,i=[...n];for(;s<i.length;){if(i[s]!==Q)throw new Error(`Graph "${this.name}": expected ${Q} segment in meta path "${r}"`);if(s+1>=i.length)throw new Error(`Graph "${this.name}": meta path requires a key after ${Q} in "${r}"`);let a=i[s+1],d=o.meta[a];if(!d)throw new Error(`Graph "${this.name}": unknown meta "${a}" in path "${r}"`);o=d,s+=2}return o}signal(e,n){if(n?.internal!==!0){for(let o of e)if(this.config.messageTier(o[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 r=[];if(this._signalDeliver(e,n??{},new Set,r),r.length>0)throw r[0]}_signalDeliver(e,n,r,o){for(let d of this._mounts.values())d._signalDeliver(e,n,r,o);let i=n.internal===!0?{internal:!0}:{actor:n.actor,delivery:"signal"},a=Yo(e,this.config);for(let d of[...this._nodes.keys()].sort()){let u=this._nodes.get(d);if(!r.has(u)){r.add(u);try{u.down(e,i)}catch(l){if(l instanceof J)throw l;o.push(l)}a.length!==0&&this._signalMetaSubtree(u,a,r,i,o)}}}_signalMetaSubtree(e,n,r,o,s){for(let i of Object.keys(e.meta).sort()){let a=e.meta[i];if(!r.has(a)){r.add(a);try{a.down(n,o)}catch(d){if(d instanceof J)throw d;s.push(d)}this._signalMetaSubtree(a,n,r,o,s)}}}describe(e){if(e?.reactive===!0)return this._describeReactive(e);let n=e?.actor,r=e?.filter,o=dt(e?.detail,e?.fields),s=e?.format==="spec",i=s?dt("minimal"):o,a=[];this._collectObserveTargets("",a);let d=new Map;for(let[T,w]of a)d.set(w,T);let u=[];{let T=a.map(([,N])=>N),w=new Set(d.values()),E=0;for(;T.length>0;){let N=T.shift();if(N instanceof P)for(let M of N._deps){let S=M.node;if(d.has(S))continue;let C=S.name??"",k=C;if(!k||w.has(k))if(C){let $=2;for(;w.has(`${C}#${$}`);)$++;k=`${C}#${$}`}else for(k=`__internal__/${E++}`;w.has(k);)k=`__internal__/${E++}`;d.set(S,k),w.add(k),u.push([k,S]),T.push(S)}}}let l=[...a,...u],f={};for(let[T,w]of l){if(n!=null&&!w.allowsObserve(n))continue;let E=jt(w,i),N=w instanceof P?w._deps.map(k=>d.get(k.node)??k.node.name??""):[],{name:M,...S}=E,C={...S,deps:N};if(!s){let k=this._annotations.get(T);k!=null&&(C.annotation=k)}if(r!=null)if(typeof r=="function"){let k=r;if(!(k.length>=2?k(T,C):k(C)))continue}else{let k=!0;for(let[$,B]of Object.entries(r)){let X=$==="deps_includes"?"depsIncludes":$==="meta_has"?"metaHas":$;if(X==="depsIncludes"){if(!C.deps.includes(String(B))){k=!1;break}continue}if(X==="metaHas"){if(!Object.hasOwn(C.meta??{},String(B))){k=!1;break}continue}if(C[X]!==B){k=!1;break}}if(!k)continue}f[T]=C}let p=new Set(Object.keys(f)),h=[];for(let[T,w]of l)if(w instanceof P)for(let E of w._deps){let N=d.get(E.node);N!=null&&h.push([N,T])}h.sort((T,w)=>T[0]<w[0]?-1:T[0]>w[0]?1:T[1]<w[1]?-1:T[1]>w[1]?1:0);let c=h.map(([T,w])=>({from:T,to:w}));(n!=null||r!=null)&&(c=c.filter(T=>p.has(T.from)&&p.has(T.to)));let g=this._collectSubgraphs(""),m=n!=null||r!=null?g.filter(T=>{let w=`${T}${I}`;return[...p].some(E=>E===T||E.startsWith(w))}):g,v=this,_=e,y={name:this.name,nodes:f,edges:c,subgraphs:m,expand(T){let w={..._,format:void 0};return Array.isArray(T)?(w.fields=T,w.detail=void 0):(w.detail=T,w.fields=void 0),v.describe(w)}},b=e??{},x=b.format;return x==="json"?Ho(y,b):x==="pretty"?Fo(y,b):x==="mermaid"?br(y,b):x==="mermaid-url"?qo(y,b):x==="d2"?jo(y,b):x==="ascii"?ir(y,b):y}_collectSubgraphs(e){let n=[];for(let r of[...this._mounts.keys()].sort()){let o=e===""?r:`${e}${r}`;n.push(o),n.push(...this._mounts.get(r)._collectSubgraphs(`${o}${I}`))}return n}resourceProfile(e){return fr(this,e)}reachable(e,n,r={}){return r.withDetail===!0?zt(this.describe(),e,n,{...r,withDetail:!0}):zt(this.describe(),e,n,r)}explain(e,n,r){return r?.reactive===!0?this._explainReactive(e,n,r):this._explainStatic(e,n,r)}_explainStatic(e,n,r){let o=this.describe({detail:"full"}),s=new Map(this._annotations),i=new Map;for(let[a,d]of Object.entries(o.nodes))d.lastMutation!=null&&i.set(a,d.lastMutation);return ar(o,e,n,{...r?.maxDepth!=null?{maxDepth:r.maxDepth}:{},...r?.findCycle===!0?{findCycle:!0}:{},annotations:s,lastMutations:i})}_describeReactive(e){let n={...e,reactive:!1},r=e.reactiveName??"describe",o=0,s=oe(o,{name:`${r}_version`}),i=this.observe({timeline:!0,structured:!0}),a=!1,d=!1,u=()=>{a||d||(a=!0,ze(()=>{a=!1,!d&&(o+=1,s.emit(o))}))},l=i.onEvent(m=>{let v=m.type;v!=="data"&&v!=="error"&&v!=="complete"&&v!=="teardown"||u()}),f=[],p=new WeakSet,h=m=>{if(p.has(m)||d)return;p.add(m);let v=m.topology.subscribe(_=>{for(let y of _){if(y[0]!==R)continue;let b=y[1];if(u(),b.kind==="added"&&b.nodeKind==="mount"){let x=m._mounts.get(b.name);x!=null&&h(x)}}});f.push(v);for(let _ of m._mounts.keys()){let y=m._mounts.get(_);y!=null&&h(y)}};h(this);let c;try{c=se([s],()=>this.describe(n),{name:r,describeKind:"derived",meta:{domain:"audit",kind:"describe"},equals:(m,v)=>m===v})}catch(m){l();for(let v of f)v();throw i.dispose(),m}let g=de(c);return{node:c,dispose(){d=!0,l();for(let m of f)m();f.length=0,i.dispose(),g()}}}_explainReactive(e,n,r){let o=0,s=oe(o,{name:"explain_version"}),i=this.observe({timeline:!0,structured:!0}),a=!1,d=!1,u=i.onEvent(h=>{let c=h.type;c!=="data"&&c!=="error"&&c!=="complete"&&c!=="teardown"||a||d||(a=!0,ze(()=>{a=!1,!d&&(o+=1,s.emit(o))}))}),l={...r?.maxDepth!=null?{maxDepth:r.maxDepth}:{},...r?.findCycle===!0?{findCycle:!0}:{}},f;try{f=se([s],()=>this._explainStatic(e,n,l),{name:r?.name??"explain",describeKind:"derived",meta:{domain:"audit",kind:"explain_path",from:e,to:n},equals:(h,c)=>h.found===c.found&&h.reason===c.reason&&h.steps.length===c.steps.length&&Jo(h.steps,c.steps)})}catch(h){throw u(),i.dispose(),h}let p=de(f);return{node:f,dispose(){d=!0,u(),i.dispose(),p()}}}_pathsMatching(e){let n=yt(e),r=[];return this._collectObserveTargets("",r),r.map(([o])=>o).filter(o=>n.test(o))}_collectObserveTargets(e,n){for(let r of[...this._mounts.keys()].sort()){let o=e===""?r:`${e}${I}${r}`;this._mounts.get(r)._collectObserveTargets(o,n)}for(let r of[...this._nodes.keys()].sort()){let o=this._nodes.get(r),s=e===""?r:`${e}${I}${r}`;n.push([s,o]),this._appendMetaObserveTargets(s,o,n)}}_appendMetaObserveTargets(e,n,r){for(let o of Object.keys(n.meta).sort()){let s=n.meta[o],i=`${e}${I}${Q}${I}${o}`;r.push([i,s]),this._appendMetaObserveTargets(i,s,r)}}observe(e,n){let r=typeof e=="string",s=gr(r?n:e),i=s.structured===!0||s.timeline===!0||s.causal===!0||s.derived===!0||s.detail==="minimal"||s.detail==="full"||s.format!=null,a=s.actor;if(r){let l=e,f=this.resolve(l);if(a!=null&&!f.allowsObserve(a))throw new J({actor:a,action:"observe",nodeName:l});return i?this._buildStructuredObserver([[l,f]],s,"one"):{subscribe(p){return f.subscribe(p)},up(p){try{f.up?.(p)}catch(h){if(h instanceof J)return;throw h}}}}let d=[];this._collectObserveTargets("",d),d.sort((l,f)=>l[0]<f[0]?-1:l[0]>f[0]?1:0);let u=a==null?d:d.filter(([,l])=>l.allowsObserve(a));return i?this._buildStructuredObserver(u,s,"all"):{subscribe:l=>{let f=u.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 J)return;throw p}}}}_buildStructuredObserver(e,n,r){let o=r==="one"?e[0]?.[0]:void 0,s=i=>{if(r==="one"&&o!=null){let l=this.resolve(o);return this._buildStructuredObserver([[o,l]],i,"one")}let a=[];this._collectObserveTargets("",a),a.sort((l,f)=>l[0]<f[0]?-1:l[0]>f[0]?1:0);let d=i.actor,u=d==null?a:a.filter(([,l])=>l.allowsObserve(d));return this._buildStructuredObserver(u,i,"all")};return this._createObserveResult(e,n,s)}_createObserveResult(e,n,r){let o=n.timeline===!0,s=n.causal===!0,i=n.derived===!0,a=n.detail==="minimal",d=this.config.inspectorEnabled,u=(s||i)&&d,l=n.maxEvents,f=l!=null&&l>0?new Qe(l):null,p=[],h=new Set,c={},g=new Set,m=0,v=0,_=0,y=0,b=0,x=0,T=!1,w=!1,E=0,N=new Map,M=new Map,S=new Map,C=O=>{f?f.push(O):p.push(O);for(let G of h)G(O)},k=()=>o?{timestamp_ns:Re(),in_batch:et(),batch_id:E}:{},$=(O,G)=>{if(!(!u||!(O instanceof P)))return O._setInspectorHook(z=>{if(z.kind==="dep_message")N.set(O,z.depIndex);else if(z.kind==="run"){let Pe=z.batchData.map((D,q)=>D!=null&&D.length>0?D.at(-1):z.prevData[q]);M.set(O,Pe);let U=z.batchData.map(D=>D!=null?[...D]:void 0);S.set(O,U),i&&C({type:"derived",path:G,dep_values:Pe,dep_batches:U,...k()})}})},B=O=>{let G=N.get(O),z=M.get(O);if(!s||z==null)return{};let U=(G!=null&&G>=0&&O instanceof P?O._deps[G]:void 0)?.node,D=U?.v,q=S.get(O);return{trigger_dep_index:G,trigger_dep_name:U?.name,...D!=null?{trigger_version:{id:D.id,version:D.version}}:{},dep_values:[...z],...q!=null?{dep_batches:q}:{}}},X=[],fe=[];for(let[O,G]of e){let z=$(G,O);z&&X.push(z),fe.push(G.subscribe(Pe=>{E++;for(let U of Pe){let D=U[0],q=k();if(D===R){c[O]=U[1];let Et=G instanceof P?G.lastMutation?.actor??ue:ue;C({type:"data",path:O,data:U[1],actor:Et,...q,...B(G)})}else if(a)D===W?m++:D===Z?v++:D===ee?_++:D===K?y++:D===te?b++:D===F?x++:D===L&&!g.has(O)?T=!0:D===A&&(w=!0,g.add(O));else if(D===W)m++,C({type:"dirty",path:O,...q});else if(D===Z)v++,C({type:"resolved",path:O,...q,...B(G)});else if(D===ee)_++,C({type:"invalidate",path:O,...q});else if(D===K)y++,C({type:"pause",path:O,lockId:U[1],...q});else if(D===te)b++,C({type:"resume",path:O,lockId:U[1],...q});else if(D===L)g.has(O)||(T=!0),C({type:"complete",path:O,...q});else if(D===A){w=!0,g.add(O);let Et=G instanceof P?G.lastMutation?.actor??ue:ue;C({type:"error",path:O,data:U[1],actor:Et,...q})}else D===F&&(x++,C({type:"teardown",path:O,...q}))}}))}let wt=!1,xt=()=>{if(!wt){wt=!0;for(let O of fe)O();for(let O of X)O();for(let O of Ze)O({value:void 0,done:!0});Ze.length=0}},Tt=[],Ze=[];h.add(O=>{let G=Ze.shift();G?G({value:O,done:!1}):Tt.push(O)});let Xt={get values(){return c},get dirtyCount(){return m},get resolvedCount(){return v},get invalidateCount(){return _},get pauseCount(){return y},get resumeCount(){return b},get teardownCount(){return x},get events(){return f?f.toArray():[...p]},get anyCompletedCleanly(){return T},get anyErrored(){return w},get completedWithoutErrors(){return T&&!w},onEvent(O){return h.add(O),()=>h.delete(O)},dispose:xt,expand(O){xt();let G={...n};return typeof O=="string"?G.detail=O:Object.assign(G,O),r(gr(G))},[Symbol.asyncIterator](){return{next(){return Tt.length>0?Promise.resolve({value:Tt.shift(),done:!1}):wt?Promise.resolve({value:void 0,done:!0}):new Promise(O=>Ze.push(O))},return(){return xt(),Promise.resolve({value:void 0,done:!0})}}}};return n.format!=null&&this._attachFormatLogger(Xt,n),Xt}_attachFormatLogger(e,n){let r=n.format;if(r==null)return;let o=n.logger??(c=>console.log(c)),s=n.includeTypes?new Set(n.includeTypes):null,i=n.excludeTypes?new Set(n.excludeTypes):null,a=s==null&&i==null?()=>!0:c=>(s==null||s.has(c))&&(i==null||!i.has(c)),d=zo(n.theme),u=r==="stage-log"?Re():0,l=c=>c==null?"":n.stageLabels?.[c]??c,f=(c,g)=>c.length>g?`${c.slice(0,g-1)}\u2026`:c,p=c=>c.type==="data"||c.type==="error"?f(bt(c.data),120):"",h=c=>{if(r==="stage-log"){let w=(Re()-u)/1e9,E=l(c.path).padEnd(9);if(c.type==="data"){let N=p(c);return`[${w.toFixed(3)}s] ${E} \u2190${N?` ${N}`:""}`}if(c.type==="error"){let N=p(c);return`[${w.toFixed(3)}s] ${E} \u2717${N?` ${N}`:""}`}return c.type==="complete"?`[${w.toFixed(3)}s] ${E} \u25A0 complete`:`[${w.toFixed(3)}s] ${E} ${c.type}`}if(r==="json")try{return JSON.stringify(c)}catch{return JSON.stringify({type:c.type,path:c.path,data:"[unserializable]"})}let g=d[c.type]??"",m=c.path?`${d.path}${c.path}${d.reset} `:"",v=c.type==="data"||c.type==="error",_=c.type==="pause"||c.type==="resume",y=v?` ${bt(c.data)}`:_?` ${bt(c.lockId)}`:"",b=c.type==="data"||c.type==="resolved"||c.type==="derived"?c:void 0,x=b?.trigger_dep_name!=null?` <- ${b.trigger_dep_name}`:b?.trigger_dep_index!=null?` <- #${b.trigger_dep_index}`:"",T=c.in_batch?" [batch]":"";return`${m}${g}${c.type.toUpperCase()}${d.reset}${y}${x}${T}`};e.onEvent(c=>{a(c.type)&&o(h(c),c)})}addDisposer(e){return this._disposers.add(e),()=>{this._disposers.delete(e)}}destroy(){pr(this._disposers,this.name),this.signal([[F]],{internal:!0}),pr(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}_destroyClearOnly(){for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0}snapshot(e){let{expand:n,...r}=this.describe({detail:"full"}),o={};for(let a of Object.keys(r.nodes).sort()){let{lastMutation:d,guard:u,...l}=r.nodes[a];o[a]=l}let s=[...r.subgraphs].sort(),i={...r,version:1,nodes:o,subgraphs:s};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 En(a,a.encode(i))}throw new Error(`snapshot: unknown format "${String(e.format)}"`)}static decode(e,n){let r=n?.config??ye,{codec:o,codecVersion:s,payload:i}=On(e,r);return o.decode(i,s)}restore(e,n){if(hr(e),e.name!==this.name)throw new Error(`Graph "${this.name}": restore snapshot name "${e.name}" does not match this graph`);let r=n?.only==null?null:(Array.isArray(n.only)?n.only:[n.only]).map(s=>yt(s)),o=n?.includeProducers===!0;for(let s of Object.keys(e.nodes).sort()){if(r!==null&&!r.some(a=>a.test(s)))continue;let i=e.nodes[s];if(i!==void 0){if(!("value"in i)||i.value===void 0){"value"in i&&i.value===void 0&&n?.onError?.(s,new Error(`restore: slice.value is undefined for "${s}" (undefined is the global SENTINEL; not valid DATA)`));continue}if(!(i.type==="derived"||i.type==="effect")&&!(i.type==="producer"&&!o)){if(i.v!=null){let d=this.tryResolve(s)?.v;if(d!=null&&d.id===i.v.id&&d.version===i.v.version)continue}try{this.set(s,i.value)}catch(a){n?.onError?.(s,a)}}}}}static fromSnapshot(e,n){hr(e);let r=typeof n=="function"?n:n?.build,o=typeof n=="function"?void 0:n?.factories,s=new t(e.name);if(r)return r(s),s.restore(e),s;for(let h of[...e.subgraphs].sort((c,g)=>{let m=c.split(I).length,v=g.split(I).length;return m!==v?m-v:c<g?-1:c>g?1:0})){let c=h.split(I),g=s;for(let m of c)g._mounts.has(m)||g.mount(m,new t(m)),g=g._mounts.get(m)}let i=o?Object.entries(o).map(([h,c])=>({re:yt(h),factory:c})):[],a=h=>{for(let c of i)if(c.re.test(h))return c.factory},d=h=>{let c=h.split(I),g=c.pop();if(g==null||g.length===0)throw new Error(`invalid snapshot path "${h}"`);let m=s;for(let v of c){let _=m._mounts.get(v);if(!_)throw new Error(`unknown mount "${v}" in path "${h}"`);m=_}return[m,g]},u=Object.entries(e.nodes).filter(([h])=>!h.includes(`${I}${Q}${I}`)).sort((h,c)=>h[0]<c[0]?-1:h[0]>c[0]?1:0),l=new Map(u),f=new Map,p=!0;for(;l.size>0&&p;){p=!1;for(let[h,c]of[...l.entries()]){let g=c?.deps??[];if(!g.every(x=>f.has(x)))continue;let[m,v]=d(h),_={...c?.meta??{}},y=a(h),b;if(c?.type==="state")b=oe(c.value,{meta:_});else{if(y==null)continue;b=y(v,{path:h,type:c.type,value:c.value,meta:_,deps:g,resolvedDeps:g.map(x=>f.get(x))})}m.add(b,{name:v}),f.set(h,b),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 s.restore(e),s}toJSON(){return this.snapshot()}attachStorage(e,n={}){let r=e.map(u=>({tier:u,debounceMs:Math.max(0,u.debounceMs??0),compactEvery:Math.max(1,u.compactEvery??10),timer:void 0,seq:0,lastSnapshot:void 0,lastFingerprint:"",disposed:!1,savePending:void 0}));n.autoRestore===!0&&this._cascadeRestore(e,n.onError);let o=(u,l)=>{if(u.disposed)return;let f=Go(l.nodes);if(u.lastSnapshot!=null&&f!==""&&f===u.lastFingerprint)return;let p=u.seq+1,h=ae(),m=u.lastSnapshot==null||p%u.compactEvery===0?{mode:"full",snapshot:l,seq:p,timestamp_ns:h,format_version:_e}:{mode:"diff",diff:wr(u.lastSnapshot,l),seq:p,timestamp_ns:h,format_version:_e};if(u.tier.filter&&!u.tier.filter(this.name,m))return;let v;try{v=u.tier.save(this.name,m)}catch(_){n.onError?.(_,u.tier);return}if(v&&typeof v.then=="function"){let b=(u.savePending??Promise.resolve()).then(()=>v,()=>v).then(()=>{u.disposed||(u.seq=p,u.lastSnapshot=l,u.lastFingerprint=f)},x=>{n.onError?.(x,u.tier)});u.savePending=b.finally(()=>{u.savePending===b&&(u.savePending=void 0)})}else u.seq=p,u.lastSnapshot=l,u.lastFingerprint=f},s=(u,l)=>{try{o(u,l)}catch(f){n.onError?.(f,u.tier)}},i=(u,l)=>{if(!l.some(c=>{let g=this.config.messageTier(c[0]);return g>=3&&g<5}))return;if(n.filter){let c=this.tryResolve(u);if(c==null)return;let g=jt(c,dt("standard"));if(!n.filter(u,g))return}let p,h=()=>(p==null&&(p=this.snapshot()),p);for(let c of r)c.disposed||(c.debounceMs===0?s(c,h()):(c.timer==null&&(c.timer=new ct),c.timer.start(c.debounceMs,()=>{c.disposed||s(c,this.snapshot())})))},a;if(n.paths!=null){let l=(typeof n.paths=="string"?this._pathsMatching(n.paths):n.paths).map(f=>{let p=this.tryResolve(f);return p==null?()=>{}:p.subscribe(h=>i(f,h))});a=()=>{for(let f of l)f()}}else a=this.observe().subscribe((u,l)=>i(u,l));let d=()=>{a();for(let u of r)u.disposed=!0,u.timer?.cancel();this._storageDisposers.delete(d)};return this._storageDisposers.add(d),{dispose:d}}async _cascadeRestore(e,n){for(let r of e){let o;try{o=await r.load(this.name)}catch(i){n?.(i,r);continue}if(o==null||typeof o!="object"||Array.isArray(o))continue;let s=o;try{if(s.mode==="full"&&s.snapshot!=null)return this.restore(s.snapshot),!0;if(s.version===_e&&s.nodes!=null)return this.restore(s),!0}catch(i){n?.(i,r)}}return!1}static async fromStorage(e,n,r){for(let o of n){let s;try{s=await o.load(e)}catch(d){r?.onError?.(d,o);continue}if(s==null||typeof s!="object"||Array.isArray(s))continue;let i=s,a=i.mode==="full"&&i.snapshot!=null?i.snapshot:i.version===_e&&i.nodes!=null?i:void 0;if(a!=null)try{return t.fromSnapshot(a,r)}catch(d){r?.onError?.(d,o)}}throw new Error(`Graph.fromStorage: no tier held a restorable record for "${e}" across ${n.length} tier(s)`)}_annotations=new Map;_traceRing;trace(e,n,r){if(e!=null&&n!=null){if(this.tryResolve(e)==null)return;if(this._annotations.set(e,n),this.config.inspectorEnabled){let o={path:e,annotation:n,timestamp_ns:Re(),...r?.actor!=null?{actor:r.actor}:{}};this._traceRing.push(o)}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 n=this._traceRing.toArray().filter(o=>!e(o)),r=this._traceRing.size-n.length;this._traceRing.clear();for(let o of n)this._traceRing.push(o);return r}static diff(e,n){let r=new Set(Object.keys(e.nodes)),o=new Set(Object.keys(n.nodes)),s=[...o].filter(_=>!r.has(_)).sort(),i=[...r].filter(_=>!o.has(_)).sort(),a=[],d=[];for(let _ of r){if(!o.has(_))continue;let y=e.nodes[_],b=n.nodes[_],x=y.v,T=b.v;x!=null&&T!=null&&x.id===T.id&&x.version!==T.version&&d.push({path:_,id:x.id,from:x.version,to:T.version});let w=x!=null&&T!=null&&x.id===T.id&&x.version===T.version;for(let E of["type","status","sentinel"]){let N=y[E],M=b[E];N!==M&&a.push({path:_,field:E,from:N,to:M})}if(!w)for(let E of["value","meta"]){let N=y[E],M=b[E];Io(N,M)||a.push({path:_,field:E,from:N,to:M})}}let u=_=>`${_.from} ${_.to}`,l=new Set(e.edges.map(u)),f=new Set(n.edges.map(u)),p=n.edges.filter(_=>!l.has(u(_))),h=e.edges.filter(_=>!f.has(u(_))),c=new Set(e.subgraphs),g=new Set(n.subgraphs),m=[...g].filter(_=>!c.has(_)).sort(),v=[...c].filter(_=>!g.has(_)).sort();return{nodesAdded:s,nodesRemoved:i,nodesChanged:a,versionChanges:d,edgesAdded:p,edgesRemoved:h,subgraphsAdded:m,subgraphsRemoved:v}}};function wr(t,e){let n=ie.diff(t,e),r={};for(let o of n.nodesAdded){let s=e.nodes[o];s!=null&&(r[o]=s)}return{...n,nodesAddedFull:r}}function zt(t,e,n,r={}){let o={paths:[],depths:new Map,truncated:!1};if(!e)return r.withDetail?o:[];if(!r.both&&n!=="upstream"&&n!=="downstream")throw new Error('reachable: direction must be "upstream" or "downstream"');let s=r.maxDepth;if(s!=null&&(!Number.isInteger(s)||s<0))throw new Error("reachable: maxDepth must be an integer >= 0");if(s===0)return r.withDetail?o:[];let i=new Map,a=new Map,d=new Map,u=new Map,l=new Set;for(let[y,b]of Object.entries(t.nodes)){if(!y)continue;l.add(y);let x=b.deps??[];i.set(y,x);for(let T of x)T&&(l.add(T),a.has(T)||a.set(T,new Set),a.get(T).add(y))}for(let y of t.edges){if(y==null||typeof y!="object")continue;let b=typeof y.from=="string"?y.from:"",x=typeof y.to=="string"?y.to:"";!b||!x||(l.add(b),l.add(x),u.has(b)||u.set(b,new Set),u.get(b).add(x),d.has(x)||d.set(x,new Set),d.get(x).add(b))}if(!l.has(e))return r.withDetail?o:[];let f=r.both===!0,p=y=>{if(f){let w=i.get(y)??[],E=d.get(y),N=a.get(y),M=u.get(y),S=[...w];return E&&S.push(...E),N&&S.push(...N),M&&S.push(...M),S}if(n==="upstream"){let w=i.get(y)??[],E=d.get(y);return E?[...w,...E]:w}let b=a.get(y),x=u.get(y),T=b?[...b]:[];return x&&T.push(...x),T},h=new Set([e]),c=new Map,g=[{path:e,depth:0}],m=0,v=!1;for(;m<g.length;){let y=g[m++];if(s!=null&&y.depth>=s){p(y.path).length>0&&(v=!0);continue}for(let b of p(y.path))!b||h.has(b)||(h.add(b),c.set(b,y.depth+1),g.push({path:b,depth:y.depth+1}))}let _=[...c.keys()].sort((y,b)=>y<b?-1:y>b?1:0);return r.withDetail?{paths:_,depths:c,truncated:v}:_}function Jo(t,e){if(t.length!==e.length)return!1;for(let n=0;n<t.length;n++){let r=t[n],o=e[n];if(r.path!==o.path||r.type!==o.type||r.status!==o.status||r.hop!==o.hop||r.dep_index!==o.dep_index||r.annotation!==o.annotation||r.value!==o.value||r.lastMutation!==o.lastMutation)return!1;let s=r.v,i=o.v;if(s!==i&&(s==null||i==null||s.id!==i.id||s.version!==i.version))return!1}return!0}Ue();je();Ge();Be();Ge();Ie();Ke();Ue();re();Ke();var Ut=class{_version=0;_maxSize;_buf;_head=0;_size=0;constructor(e,n){if(n!==void 0&&n<1)throw new RangeError("maxSize must be >= 1");if(this._maxSize=n,n!==void 0){if(this._buf=new Array(n),e&&e.length>0){let r=Math.min(e.length,n),o=e.length-r;for(let s=0;s<r;s++)this._buf[s]=e[o+s];this._size=r}}else this._buf=e?[...e]:[],this._size=this._buf.length}get version(){return this._version}get size(){return this._size}at(e){if(!Number.isInteger(e))return;let n=e>=0?e:this._size+e;if(!(n<0||n>=this._size))return this._maxSize!==void 0?this._buf[(this._head+n)%this._maxSize]:this._buf[n]}append(e){this._rawAppend(e),this._version+=1}appendMany(e){if(e.length===0)return;let n=this._maxSize!==void 0&&e.length>this._maxSize?e.length-this._maxSize:0;for(let r=n;r<e.length;r++)this._rawAppend(e[r]);this._version+=1}clear(){if(this._size===0)return 0;let e=this._size;if(this._maxSize===void 0)this._buf.length=0;else for(let n=0;n<e;n++)this._buf[(this._head+n)%this._maxSize]=void 0;return this._head=0,this._size=0,this._version+=1,e}trimHead(e){if(!Number.isInteger(e)||e<0)throw new RangeError(`trimHead: n must be a non-negative integer (got ${e})`);if(e===0||this._size===0)return 0;let n=Math.min(e,this._size);if(this._maxSize===void 0)this._buf.splice(0,n);else{for(let r=0;r<n;r++)this._buf[(this._head+r)%this._maxSize]=void 0;this._head=(this._head+n)%this._maxSize}return this._size-=n,this._version+=1,n}slice(e,n){if(!Number.isInteger(e)||e<0)throw new RangeError(`slice: start must be a non-negative integer (got ${e})`);if(n!==void 0&&(!Number.isInteger(n)||n<0))throw new RangeError(`slice: stop must be a non-negative integer or undefined (got ${n})`);let r=n===void 0?this._size:Math.min(Math.max(n,0),this._size),o=Math.min(e,this._size);if(o>=r)return[];let s=r-o;if(this._maxSize===void 0)return this._buf.slice(o,r);let i=new Array(s);for(let a=0;a<s;a++)i[a]=this._buf[(this._head+o+a)%this._maxSize];return i}tail(e){if(!Number.isInteger(e)||e<0)throw new RangeError(`tail: n must be a non-negative integer (got ${e})`);if(e===0||this._size===0)return[];let n=Math.min(e,this._size);return this.slice(this._size-n,this._size)}toArray(){if(this._maxSize===void 0)return[...this._buf];let e=new Array(this._size);for(let n=0;n<this._size;n++)e[n]=this._buf[(this._head+n)%this._maxSize];return e}_rawAppend(e){if(this._maxSize===void 0){this._buf.push(e),this._size=this._buf.length;return}this._size<this._maxSize?(this._buf[(this._head+this._size)%this._maxSize]=e,this._size+=1):(this._buf[this._head]=e,this._head=(this._head+1)%this._maxSize)}};function xr(t){return t.subscribe(()=>{})}var Qo=64;function Tr(t,e={}){let{name:n,maxSize:r,versioning:o,backend:s}=e,i=s??new Ut(t,r),a=oe(i.toArray(),{name:n,describeKind:"state",equals:(c,g)=>c===g,...o!=null?{versioning:o}:{}});function d(){let c=i.toArray();Ae(()=>{a.down([[W]]),a.down([[R,c]])})}let u=new Map,l=new Map;function f(c,g){return`${c}:${g===void 0?"END":g}`}function p(c){if(c.size<Qo)return;let g=c.keys().next();if(g.done)return;let m=c.get(g.value);m!==void 0&&m.dispose(),c.delete(g.value)}function h(c){let g=i.version;try{return c()}finally{i.version!==g&&d()}}return{entries:a,get size(){return i.size},at(c){return i.at(c)},append(c){h(()=>i.append(c))},appendMany(c){c.length!==0&&h(()=>i.appendMany(c))},clear(){h(()=>i.clear())},trimHead(c){h(()=>i.trimHead(c))},tail(c){if(!Number.isInteger(c)||c<0)throw new RangeError(`tail: n must be a non-negative integer (got ${c})`);let g=u.get(c);if(g!==void 0)return u.delete(c),u.set(c,g),g.node;p(u);let m=se([a],([_])=>{let y=_;return c===0||y.length===0?[]:y.slice(Math.max(0,y.length-c))},{initial:i.tail(c),describeKind:"derived"}),v=xr(m);return u.set(c,{node:m,dispose:v}),m},slice(c,g){if(!Number.isInteger(c)||c<0)throw new RangeError(`slice: start must be a non-negative integer (got ${c})`);if(g!==void 0&&(!Number.isInteger(g)||g<0))throw new RangeError(`slice: stop must be a non-negative integer or undefined (got ${g})`);let m=f(c,g),v=l.get(m);if(v!==void 0)return l.delete(m),l.set(m,v),v.node;p(l);let _=se([a],([b])=>{let x=b;return g===void 0?x.slice(c):x.slice(c,g)},{initial:i.slice(c,g),describeKind:"derived"}),y=xr(_);return l.set(m,{node:_,dispose:y}),_},disposeTail(c){let g=u.get(c);return g===void 0?!1:(g.dispose(),u.delete(c),!0)},disposeSlice(c,g){let m=f(c,g),v=l.get(m);return v===void 0?!1:(v.dispose(),l.delete(m),!0)},disposeAllViews(){for(let c of u.values())c.dispose();u.clear();for(let c of l.values())c.dispose();l.clear()},dispose(){for(let c of u.values())c.dispose();u.clear();for(let c of l.values())c.dispose();l.clear()}}}st();function Er(t,e,n){return{[t]:!0,[`${t}_type`]:e,...n??{}}}var Xo=rt((t,e)=>{t("write"),t("signal"),e("observe")}),Zo=rt((t,e)=>{t("observe"),t("signal"),e("write")}),es=rt((t,e)=>{t("observe"),t("signal"),e("write")});function vt(t,e){return Er("cqrs",t,e)}var Kt=class extends ie{_eventLogs=new Map;_commandHandlers=new Map;_projections=new Set;_sagas=new Set;_keepaliveDisposers=[];_eventStore;_seq=0;constructor(e,n={}){super(e,n.graph)}destroy(){for(let e of this._keepaliveDisposers)e();this._keepaliveDisposers.length=0,super.destroy()}event(e){let n=this._eventLogs.get(e);if(n)return n.node;let r=Tr([],{name:e,versioning:0}),o=r.entries,s=se([o],([i])=>i,{name:e,describeKind:"state",meta:vt("event",{event_name:e}),guard:es,initial:o.cache});return this.add(s,{name:e}),this._keepaliveDisposers.push(de(s)),this._eventLogs.set(e,{log:r,node:s}),s}_appendEvent(e,n){let r=this._eventLogs.get(e);if(r||(this.event(e),r=this._eventLogs.get(e)),r.node.status==="completed"||r.node.status==="errored")throw new Error(`Cannot dispatch to terminated event stream "${e}" (status: ${r.node.status}).`);let o=r.log.entries.v,s={type:e,payload:n,timestampNs:ae(),seq:++this._seq,...o!=null?{v0:{id:o.id,version:o.version}}:{}};r.log.append(s),this._eventStore&&this._eventStore.persist(s)}command(e,n){let r=oe(void 0,{name:e,describeKind:"state",meta:{...vt("command",{command_name:e}),error:null},guard:Xo});return this.add(r,{name:e}),this._commandHandlers.set(e,n),r}dispatch(e,n){let r=this._commandHandlers.get(e);if(!r)throw new Error(`Unknown command: "${e}". Register with .command() first.`);let o=this.resolve(e);Ae(()=>{o.emit(n,{internal:!0});try{r(n,{emit:(s,i)=>this._appendEvent(s,i)}),o.meta.error.emit(null,{internal:!0})}catch(s){throw o.meta.error.emit(s,{internal:!0}),s}})}projection(e,n,r,o){let s=n.map(a=>(this._eventLogs.has(a)||this.event(a),this._eventLogs.get(a).node)),i=se(s,a=>{let d=[];for(let u of a){let l=u;d.push(...l)}return d.sort((u,l)=>u.timestampNs-l.timestampNs||u.seq-l.seq),r(o,d)},{name:e,describeKind:"derived",meta:vt("projection",{projection_name:e,source_events:n}),guard:Zo,initial:o});return this.add(i,{name:e}),this._keepaliveDisposers.push(de(i)),this._projections.add(e),i}saga(e,n,r){let o=n.map(d=>(this._eventLogs.has(d)||this.event(d),this._eventLogs.get(d).node)),s=new Map,i={},a=be(o,(d,u)=>{let l=i.n.meta.error;for(let f=0;f<d.length;f++){let p=d[f];if(p==null||p.length===0)continue;let h=p.at(-1);if(!h)continue;let c=n[f],g=s.get(c)??0;if(h.length>g){let m=h.slice(g);for(let v of m)try{r(v),l.emit(null,{internal:!0})}catch(_){l.emit(_,{internal:!0})}s.set(c,h.length)}}},{name:e,describeKind:"effect",meta:{...vt("saga",{saga_name:e,source_events:n}),error:null}});return i.n=a,this.add(a,{name:e}),this._keepaliveDisposers.push(de(a)),this._sagas.add(e),a}useEventStore(e){this._eventStore=e}async rebuildProjection(e,n,r){if(!this._eventStore)throw new Error("No event store wired. Call useEventStore() first.");let o=[];for(let s of e){let i=await this._eventStore.loadEvents(s);o.push(...i.events)}return o.sort((s,i)=>s.timestampNs-i.timestampNs||s.seq-i.seq),n(r,o)}};function Or(t,e){return new Kt(t,e)}var Jt=class{constructor(e){this.graph=e}onModuleDestroy(){this.graph.destroy()}},Qt=class{graph=new ie("request");onModuleDestroy(){this.graph.destroy()}},Nr,Yt;Nr=[(0,Xe.Module)({})];var le=class le{static forRoot(e){let n=e??{},r=n.name??"root",o=[{provide:Y,useFactory:()=>{let s=new ie(r);return n.build&&n.build(s),n.snapshot&&s.restore(n.snapshot),s}},{provide:Symbol.for("graphrefly:root-lifecycle"),useFactory:s=>new Jt(s),inject:[Y]},{provide:ve,useFactory:(s,i)=>new ve(s,i),inject:[Y,Sr.ModuleRef]}];if(n.nodes)for(let s of n.nodes)o.push({provide:ne(s),useFactory:i=>i.resolve(s),inject:[Y]});return n.requestScope&&o.push({provide:Symbol.for("graphrefly:request-lifecycle"),useFactory:()=>new Qt,scope:Xe.Scope.REQUEST},{provide:pe,useFactory:s=>s.graph,inject:[Symbol.for("graphrefly:request-lifecycle")],scope:Xe.Scope.REQUEST}),{module:le,global:!0,providers:o,exports:[Y,...(n.nodes??[]).map(ne),...n.requestScope?[pe]:[]]}}static forFeature(e){let n=[{provide:j(e.name),useFactory:r=>{let o=new ie(e.name);return e.build&&e.build(o),e.snapshot&&o.restore(e.snapshot),r.mount(e.name,o),o},inject:[Y]}];if(e.nodes)for(let r of e.nodes)n.push({provide:ne(`${e.name}::${r}`),useFactory:o=>o.resolve(r),inject:[j(e.name)]});return{module:le,providers:n,exports:[j(e.name),...(e.nodes??[]).map(r=>ne(`${e.name}::${r}`))]}}static forCqrs(e){let n=[{provide:j(e.name),useFactory:r=>{let o=Or(e.name,e.cqrs);return e.eventStore&&o.useEventStore(e.eventStore),e.build&&e.build(o),r.mount(e.name,o),o},inject:[Y]}];if(e.nodes)for(let r of e.nodes)n.push({provide:ne(`${e.name}::${r}`),useFactory:o=>o.resolve(r),inject:[j(e.name)]});return{module:le,providers:n,exports:[j(e.name),...(e.nodes??[]).map(r=>ne(`${e.name}::${r}`))]}}};Yt=on(null),le=un(Yt,0,"GraphReflyModule",Nr,le),an(Yt,1,le);var _t=le;0&&(module.exports={ACTOR_KEY,COMMAND_HANDLERS,CQRS_EVENT_HANDLERS,CRON_HANDLERS,CommandHandler,EVENT_HANDLERS,EventHandler,GRAPHREFLY_REQUEST_GRAPH,GRAPHREFLY_ROOT_GRAPH,GraphCron,GraphInterval,GraphReflyEventExplorer,GraphReflyGuard,GraphReflyGuardImpl,GraphReflyModule,INTERVAL_HANDLERS,InjectCqrsGraph,InjectGraph,InjectNode,ObserveGateway,OnGraphEvent,QUERY_HANDLERS,QueryHandler,SAGA_HANDLERS,SagaHandler,fromHeader,fromJwtPayload,getActor,getGraphToken,getNodeToken,observeSSE,observeSubscription,toObservable});
@@ -1 +1 @@
1
- import{A as B,B as C,C as D,D as E,E as F,F as G,a as b,b as c,c as d,d as e,e as f,f as g,g as h,h as i,i as j,j as k,k as l,l as m,m as n,n as o,o as p,p as q,q as r,r as s,s as t,t as u,u as v,v as w,w as x,x as y,y as z,z as A}from"../../chunk-P7JXGKDO.js";import"../../chunk-VIEUJSTT.js";import"../../chunk-5Z4HDCO6.js";import"../../chunk-GNCBXARM.js";import"../../chunk-Y32RJO24.js";import{a}from"../../chunk-5QDBSZBV.js";import"../../chunk-MGKAO4EK.js";import"../../chunk-ESMPEKEV.js";import"../../chunk-TWMEGG45.js";import"../../chunk-AUY2YKCO.js";import"../../chunk-KASHOCF5.js";import"../../chunk-W4TSQ6RJ.js";import"../../chunk-CK2E7BTU.js";import"../../chunk-QYADASLV.js";export{A as ACTOR_KEY,i as COMMAND_HANDLERS,j as CQRS_EVENT_HANDLERS,h as CRON_HANDLERS,s as CommandHandler,f as EVENT_HANDLERS,t as EventHandler,c as GRAPHREFLY_REQUEST_GRAPH,b as GRAPHREFLY_ROOT_GRAPH,r as GraphCron,q as GraphInterval,w as GraphReflyEventExplorer,F as GraphReflyGuard,E as GraphReflyGuardImpl,G as GraphReflyModule,g as INTERVAL_HANDLERS,n as InjectCqrsGraph,m as InjectGraph,o as InjectNode,z as ObserveGateway,p as OnGraphEvent,k as QUERY_HANDLERS,u as QueryHandler,l as SAGA_HANDLERS,v as SagaHandler,C as fromHeader,B as fromJwtPayload,D as getActor,d as getGraphToken,e as getNodeToken,x as observeSSE,y as observeSubscription,a as toObservable};
1
+ import{A as B,B as C,C as D,D as E,E as F,F as G,a as b,b as c,c as d,d as e,e as f,f as g,g as h,h as i,i as j,j as k,k as l,l as m,m as n,n as o,o as p,p as q,q as r,r as s,s as t,t as u,u as v,v as w,w as x,x as y,y as z,z as A}from"../../chunk-GF5T7PGC.js";import"../../chunk-Z3UWIJ3A.js";import"../../chunk-K54OKWNY.js";import"../../chunk-CZVYLXFK.js";import"../../chunk-7EQPXQ7H.js";import{a}from"../../chunk-5QDBSZBV.js";import"../../chunk-XRSHMHEG.js";import"../../chunk-PSQNYY72.js";import"../../chunk-SGS4OJGS.js";import"../../chunk-ESMPEKEV.js";import"../../chunk-N2KKISCE.js";import"../../chunk-UMH3HSP7.js";import"../../chunk-7AJKUA36.js";import"../../chunk-CK2E7BTU.js";import"../../chunk-QYADASLV.js";export{A as ACTOR_KEY,i as COMMAND_HANDLERS,j as CQRS_EVENT_HANDLERS,h as CRON_HANDLERS,s as CommandHandler,f as EVENT_HANDLERS,t as EventHandler,c as GRAPHREFLY_REQUEST_GRAPH,b as GRAPHREFLY_ROOT_GRAPH,r as GraphCron,q as GraphInterval,w as GraphReflyEventExplorer,F as GraphReflyGuard,E as GraphReflyGuardImpl,G as GraphReflyModule,g as INTERVAL_HANDLERS,n as InjectCqrsGraph,m as InjectGraph,o as InjectNode,z as ObserveGateway,p as OnGraphEvent,k as QUERY_HANDLERS,u as QueryHandler,l as SAGA_HANDLERS,v as SagaHandler,C as fromHeader,B as fromJwtPayload,D as getActor,d as getGraphToken,e as getNodeToken,x as observeSSE,y as observeSubscription,a as toObservable};