@decocms/mesh 2.17.1 → 2.18.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 (139) hide show
  1. package/dist/client/assets/{AlertCircle-rclbzics.js → AlertCircle-CahACZDg.js} +1 -1
  2. package/dist/client/assets/{ArrowLeft-ClViT7Hc.js → ArrowLeft-DlLOWSTj.js} +1 -1
  3. package/dist/client/assets/{ArrowUp-BsQNKzS-.js → ArrowUp-Ck0taqJi.js} +1 -1
  4. package/dist/client/assets/{Check-C2R_Lcai.js → Check-Cjgi2ZiG.js} +1 -1
  5. package/dist/client/assets/{ChevronDown-CGAmRXVd.js → ChevronDown-BuVzyKHq.js} +1 -1
  6. package/dist/client/assets/{Code01-CVOtW_Yi.js → Code01-XpAoNs3W.js} +1 -1
  7. package/dist/client/assets/{Copy01-BvrgG3_u.js → Copy01-De4SwxDv.js} +1 -1
  8. package/dist/client/assets/{DotsHorizontal-D-_ECokQ.js → DotsHorizontal-D-Bv2U6B.js} +1 -1
  9. package/dist/client/assets/{DotsVertical-BeOWu8ww.js → DotsVertical-BhTwPxq7.js} +1 -1
  10. package/dist/client/assets/{Download01-C4VXJ4rj.js → Download01-DhkFfGKV.js} +1 -1
  11. package/dist/client/assets/{Edit01-CkDEl3XN.js → Edit01-DsRHb45T.js} +1 -1
  12. package/dist/client/assets/{File06-DcfM98WM.js → File06-BiIPMtEV.js} +1 -1
  13. package/dist/client/assets/{FilterLines-BFhYlm1G.js → FilterLines-C_UJwG_t.js} +1 -1
  14. package/dist/client/assets/{FlipBackward-Bz0fRANc.js → FlipBackward-CQnTJKeB.js} +1 -1
  15. package/dist/client/assets/{GitBranch01-Bc0tKWvO.js → GitBranch01-ClS9Bk6n.js} +1 -1
  16. package/dist/client/assets/{Grid01-SL4tYH2-.js → Grid01-CRALWbj6.js} +1 -1
  17. package/dist/client/assets/{Home02-C2IjHPBI.js → Home02-ofwnyeoV.js} +1 -1
  18. package/dist/client/assets/{Image01-BQtv4av4.js → Image01-Cb4gQMH4.js} +1 -1
  19. package/dist/client/assets/{Inbox01-Dq00_28Z.js → Inbox01-CKGdnZFH.js} +1 -1
  20. package/dist/client/assets/{InfoCircle-Cr1Ezl_g.js → InfoCircle-_4UsKVMw.js} +1 -1
  21. package/dist/client/assets/{Key01-nM2KN2wI.js → Key01-BFJBGJng.js} +1 -1
  22. package/dist/client/assets/{LinkExternal01-Cek4l5LT.js → LinkExternal01-C1dAUI0b.js} +1 -1
  23. package/dist/client/assets/{List-DhHX60HN.js → List-DOmOO2Cw.js} +1 -1
  24. package/dist/client/assets/{Loading01-CpEccvEO.js → Loading01-JwelopeC.js} +1 -1
  25. package/dist/client/assets/{Lock01-DkAqto6l.js → Lock01-B7TIX2sZ.js} +1 -1
  26. package/dist/client/assets/{Play-gy0OXoTQ.js → Play-CMKLF_6n.js} +1 -1
  27. package/dist/client/assets/{Plus-DjzFfDDP.js → Plus-Df2M6Ns2.js} +1 -1
  28. package/dist/client/assets/{SearchMd-Cg2el-z8.js → SearchMd-Cgfgcbdz.js} +1 -1
  29. package/dist/client/assets/{Terminal-Kg8grfTZ.js → Terminal-C8LHfiOW.js} +1 -1
  30. package/dist/client/assets/{Trash01-BnAfsqRe.js → Trash01-KvZ0cVo9.js} +1 -1
  31. package/dist/client/assets/{Upload01-DRgz8NgE.js → Upload01-TiwmYxO-.js} +1 -1
  32. package/dist/client/assets/{X-CBga9b95.js → X-DhyaYbLb.js} +1 -1
  33. package/dist/client/assets/{XClose-DEljIF8n.js → XClose-2bShEltc.js} +1 -1
  34. package/dist/client/assets/{alert-dialog-BNxiLvEc.js → alert-dialog-gZhceV_v.js} +2 -2
  35. package/dist/client/assets/{auth-catchall-DeehfEMz.js → auth-catchall-Dz8qCpUP.js} +1 -1
  36. package/dist/client/assets/{avatar-BXyXgGjh.js → avatar-d8M8JpvZ.js} +1 -1
  37. package/dist/client/assets/{badge-Ctdv4gxt.js → badge-CKe-ib_i.js} +1 -1
  38. package/dist/client/assets/{binder-BxrAqFdA.js → binder-iKe3ndXq.js} +1 -1
  39. package/dist/client/assets/{button-C0pnkZlC.js → button-DXl1hVqx.js} +1 -1
  40. package/dist/client/assets/{card-DUUk5B6T.js → card-D0GcpRPY.js} +1 -1
  41. package/dist/client/assets/{checkbox-DSzJrlMA.js → checkbox-D1tHbcIN.js} +1 -1
  42. package/dist/client/assets/{collection-detail-iIrZ-zZ-.js → collection-detail-BQkjgYb7.js} +1 -1
  43. package/dist/client/assets/{collection-display-button-DDxBelrQ.js → collection-display-button-B_KC-ent.js} +1 -1
  44. package/dist/client/assets/{collection-header-d89fPnWN.js → collection-header-BA9HTLmg.js} +1 -1
  45. package/dist/client/assets/{collection-page-DvY1awQQ.js → collection-page-CDkTC45g.js} +1 -1
  46. package/dist/client/assets/{collection-search-DFSn4A42.js → collection-search-pUdl1eNx.js} +1 -1
  47. package/dist/client/assets/{collection-tab-J4NMpB8P.js → collection-tab-BofyxU3Y.js} +1 -1
  48. package/dist/client/assets/{collection-table-wrapper-CB1f1HNV.js → collection-table-wrapper-wARoPZXo.js} +1 -1
  49. package/dist/client/assets/{connection-CMutAR-q.js → connection-ByVJuREK.js} +1 -1
  50. package/dist/client/assets/{connection-card-DJA7LSPP.js → connection-card-DjK0GZ2u.js} +1 -1
  51. package/dist/client/assets/{connection-detail-AyiveTST.js → connection-detail-BGizcg4Z.js} +1 -1
  52. package/dist/client/assets/connections-B3vaIw3-.js +1 -0
  53. package/dist/client/assets/constants-DQVDVC-J.js +1 -0
  54. package/dist/client/assets/{create-organization-dialog-FpknJphA.js → create-organization-dialog-DKwU0dfN.js} +1 -1
  55. package/dist/client/assets/{dialog-DGipxHKv.js → dialog-1B3YWWMu.js} +1 -1
  56. package/dist/client/assets/{dropdown-menu-DXIsFCVQ.js → dropdown-menu-Hp4qYTud.js} +1 -1
  57. package/dist/client/assets/{dynamic-plugin-layout-p6uYyMI7.js → dynamic-plugin-layout-j2gEmQEr.js} +1 -1
  58. package/dist/client/assets/{empty-state-BOQ8a8rM.js → empty-state-C7Gr5Tg2.js} +1 -1
  59. package/dist/client/assets/{empty-state-CsVvxFp9.js → empty-state-D-JjObLi.js} +1 -1
  60. package/dist/client/assets/{env-vars-editor-DsDwdS2I.js → env-vars-editor-D4XTsyk0.js} +1 -1
  61. package/dist/client/assets/{error-boundary-CiihS5J_.js → error-boundary-rr4tK3fB.js} +1 -1
  62. package/dist/client/assets/{extract-connection-data-CZNqSTSO.js → extract-connection-data-37AfzoCx.js} +1 -1
  63. package/dist/client/assets/{file-browser-DtPxgmLq.js → file-browser-BECnO7FM.js} +2 -2
  64. package/dist/client/assets/{form-Cq3oH5p8.js → form-BQupN7IV.js} +1 -1
  65. package/dist/client/assets/{gateway-detail-Ds9jNsAy.js → gateway-detail-B1f7bt6s.js} +1 -1
  66. package/dist/client/assets/gateways-jpQl136Z.js +1 -0
  67. package/dist/client/assets/{grid-view-DCCLpGyL.js → grid-view-BwLKimb0.js} +1 -1
  68. package/dist/client/assets/{home-C6YGDrtN.js → home-9vMYPTYi.js} +1 -1
  69. package/dist/client/assets/{index-Ct-XKtSm.js → index-Bpy9plQL.js} +1 -1
  70. package/dist/client/assets/{index-sjg7ALLH.js → index-D0CzZUCs.js} +1 -1
  71. package/dist/client/assets/{index-lLPOJwFP.js → index-DEuqpeVv.js} +2 -2
  72. package/dist/client/assets/index-DVolwMvn.js +107 -0
  73. package/dist/client/assets/index-Dh9ePU0t.css +1 -0
  74. package/dist/client/assets/{index-BPAz_Wmi.js → index-u_K3efbu.js} +1 -1
  75. package/dist/client/assets/{infiniteQueryObserver-Cg5Uwm-m.js → infiniteQueryObserver-BXdaScti.js} +1 -1
  76. package/dist/client/assets/{input-BtvEWyY7.js → input-CqqzkfyF.js} +1 -1
  77. package/dist/client/assets/{layout-D_5LiG9u.js → layout-D7T4rJzl.js} +1 -1
  78. package/dist/client/assets/{lazy-highlighter-D262jDd3.js → lazy-highlighter-U-fd28FU.js} +1 -1
  79. package/dist/client/assets/{localstorage-keys-CrsmSVIa.js → localstorage-keys-kemGZMIp.js} +1 -1
  80. package/dist/client/assets/{login-D-eNDgSJ.js → login-AsctHrUh.js} +1 -1
  81. package/dist/client/assets/{mcp-oauth-BlRDBNPG.js → mcp-oauth-DqZqwRXe.js} +1 -1
  82. package/dist/client/assets/{mcp-server-card-h4-acR5C.js → mcp-server-card-DfoQ5M8z.js} +1 -1
  83. package/dist/client/assets/{mcp-server-detail-BIJFOf-1.js → mcp-server-detail-GLsULv7B.js} +1 -1
  84. package/dist/client/assets/{members-JDeSn8de.js → members-eia2aN0I.js} +1 -1
  85. package/dist/client/assets/{monaco-editor-h8_XpHnI.js → monaco-editor-rl0nEzOU.js} +1 -1
  86. package/dist/client/assets/{monitoring-B5veKGER.js → monitoring-DWEGkU9y.js} +1 -1
  87. package/dist/client/assets/{oauth-callback-B7GGjmT2.js → oauth-callback-BFr0fBNT.js} +1 -1
  88. package/dist/client/assets/{page-DRfRpAk9.js → page-BeG_Zpat.js} +1 -1
  89. package/dist/client/assets/page-GoE2bJQh.js +21 -0
  90. package/dist/client/assets/{pin-to-sidebar-button-DNtnmSb8.js → pin-to-sidebar-button-CrzVxc9I.js} +1 -1
  91. package/dist/client/assets/{plugin-empty-state-DrcgOOcq.js → plugin-empty-state-CvQbqnfg.js} +1 -1
  92. package/dist/client/assets/{plugin-header-riFgGbiI.js → plugin-header-BaWUIpLx.js} +1 -1
  93. package/dist/client/assets/{plugins-DoB7Ko8p.js → plugins-Q7uqmYFh.js} +1 -1
  94. package/dist/client/assets/{popover-pNwa1deQ.js → popover-BcOo6EXw.js} +1 -1
  95. package/dist/client/assets/{project-context-provider-BMHXD39x.js → project-context-provider-Dn1-l4h2.js} +1 -1
  96. package/dist/client/assets/{registry-utils-BkBVcE6w.js → registry-utils-85b65tFI.js} +1 -1
  97. package/dist/client/assets/{resizable-jz1SBMEc.js → resizable-DkFmgcsj.js} +1 -1
  98. package/dist/client/assets/{resource-tabs-DqRWX41r.js → resource-tabs-DkDSMlFB.js} +1 -1
  99. package/dist/client/assets/{select-COJ5S7Rq.js → select-Bv7J3zlQ.js} +1 -1
  100. package/dist/client/assets/{settings-CmNkIvY0.js → settings-BK8QvMDL.js} +1 -1
  101. package/dist/client/assets/shell-layout-DImgzYtx.js +3 -0
  102. package/dist/client/assets/{spinner-Deoz6N0J.js → spinner-D0hdWfev.js} +1 -1
  103. package/dist/client/assets/{switch-Z2NGTQao.js → switch-ugX7u7WU.js} +1 -1
  104. package/dist/client/assets/{textarea-fD103gtG.js → textarea-BUrXtpl5.js} +1 -1
  105. package/dist/client/assets/{tool-set-selector-SxQbDynN.js → tool-set-selector-a1uFioE0.js} +1 -1
  106. package/dist/client/assets/{tools-list-9lgpWeKJ.js → tools-list-DpFBj-bw.js} +1 -1
  107. package/dist/client/assets/{tooltip-D0yN_jPS.js → tooltip-vUrxHIt0.js} +1 -1
  108. package/dist/client/assets/typewriter-title-7_SusDya.js +16 -0
  109. package/dist/client/assets/{use-binding-bdIG4ysm.js → use-binding-B0VMz_Ex.js} +1 -1
  110. package/dist/client/assets/{use-collections-DiH8BH96.js → use-collections-Cflasxiq.js} +1 -1
  111. package/dist/client/assets/{use-connection-BvgGy_ae.js → use-connection-DhRUkVvI.js} +1 -1
  112. package/dist/client/assets/{use-connection-resources-CazBLQYp.js → use-connection-resources-C-wyp48q.js} +1 -1
  113. package/dist/client/assets/{use-create-gateway-DWTCcW8J.js → use-create-gateway-DMkdPgfy.js} +1 -1
  114. package/dist/client/assets/{use-gateway-Blme6XE1.js → use-gateway-D5VVN1xE.js} +1 -1
  115. package/dist/client/assets/{use-gateway-system-prompt-DfRYNjlK.js → use-gateway-system-prompt-B3fSaA6r.js} +1 -1
  116. package/dist/client/assets/{use-list-state-C9VeGRXh.js → use-list-state-BYREPRxy.js} +1 -1
  117. package/dist/client/assets/{use-mcp-ByUu9rNa.js → use-mcp-CZeMxRgK.js} +1 -1
  118. package/dist/client/assets/{use-members-A4eH5Mug.js → use-members-Bi0eIvBO.js} +1 -1
  119. package/dist/client/assets/{use-mobile-DQFSnNx5.js → use-mobile-CI2w7svc.js} +1 -1
  120. package/dist/client/assets/{use-organization-settings-CFfwAQvt.js → use-organization-settings-D0kNSjbq.js} +1 -1
  121. package/dist/client/assets/{use-tool-call-q6DaczOv.js → use-tool-call-CoI4ZCZe.js} +1 -1
  122. package/dist/client/assets/useInfiniteQuery-ckN_t7ea.js +1 -0
  123. package/dist/client/assets/{useMutation-8xrpFP-l.js → useMutation-xcmVYLP7.js} +1 -1
  124. package/dist/client/assets/useQuery-BKyLWvSZ.js +1 -0
  125. package/dist/client/assets/{value-_3bvT1Yq.js → value-C7rJ457O.js} +1 -1
  126. package/dist/client/assets/{view-mode-toggle-C7lGZNG7.js → view-mode-toggle-CTWk8Dkt.js} +1 -1
  127. package/dist/client/assets/{workflow-DBXd52Rn.js → workflow-ClKgdB2v.js} +1 -1
  128. package/dist/client/index.html +2 -2
  129. package/package.json +1 -1
  130. package/dist/client/assets/MessageChatSquare-B8VNN8W_.js +0 -1
  131. package/dist/client/assets/connections-B5sVjhUZ.js +0 -1
  132. package/dist/client/assets/constants-Bx2xP4ra.js +0 -1
  133. package/dist/client/assets/gateways--0F8usoj.js +0 -1
  134. package/dist/client/assets/index-BEGxRCwV.js +0 -107
  135. package/dist/client/assets/index-CCciYu2S.css +0 -1
  136. package/dist/client/assets/page-JPTyFV98.js +0 -35
  137. package/dist/client/assets/shell-layout-B43W-k9I.js +0 -17
  138. package/dist/client/assets/useInfiniteQuery-c0A7IUcG.js +0 -1
  139. package/dist/client/assets/useQuery-CLJFoOtO.js +0 -1
@@ -1,35 +0,0 @@
1
- import{F as Rs,H as js,r as $,j as _,c as ue,f as _n,k as Vs,a as Os}from"./index-lLPOJwFP.js";import{C as se,a as Bs}from"./index-BEGxRCwV.js";import{E as Wo}from"./error-boundary-CiihS5J_.js";import{u as Fs}from"./localstorage-keys-CrsmSVIa.js";import{u as bn}from"./project-context-provider-BMHXD39x.js";import{c as qo,B as Go}from"./button-C0pnkZlC.js";import{V as Xs}from"./view-mode-toggle-C7lGZNG7.js";import{i as Ys}from"./GitBranch01-Bc0tKWvO.js";import{t as Ko}from"./MessageChatSquare-B8VNN8W_.js";import{s as Zs}from"./Plus-DjzFfDDP.js";import{c as Ws}from"./connection-CMutAR-q.js";import{I as Uo,n as qs}from"./empty-state-BOQ8a8rM.js";import{u as Gs,i as Ks}from"./use-gateway-Blme6XE1.js";import{u as Us}from"./use-connection-BvgGy_ae.js";import{u as Qs}from"./use-tool-call-q6DaczOv.js";import{i as ke,a as Gn,b as Js,c as Kn,d as Jt,T as en,e as ea}from"./value-_3bvT1Yq.js";import"./X-CBga9b95.js";import"./popover-pNwa1deQ.js";import"./textarea-fD103gtG.js";import"./AlertCircle-rclbzics.js";import"./ArrowUp-BsQNKzS-.js";import"./ChevronDown-CGAmRXVd.js";import"./Edit01-CkDEl3XN.js";import"./use-collections-DiH8BH96.js";import"./useMutation-8xrpFP-l.js";import"./use-binding-bdIG4ysm.js";import"./binder-BxrAqFdA.js";import"./use-gateway-system-prompt-DfRYNjlK.js";import"./input-BtvEWyY7.js";import"./tooltip-D0yN_jPS.js";import"./Check-C2R_Lcai.js";import"./SearchMd-Cg2el-z8.js";import"./use-create-gateway-DWTCcW8J.js";import"./select-COJ5S7Rq.js";import"./File06-DcfM98WM.js";import"./Grid01-SL4tYH2-.js";import"./Image01-BQtv4av4.js";import"./Copy01-BvrgG3_u.js";import"./Terminal-Kg8grfTZ.js";import"./monaco-editor-h8_XpHnI.js";import"./spinner-Deoz6N0J.js";import"./alert-dialog-BNxiLvEc.js";import"./well-known-mcp-DOEdYmKO.js";import"./generate-id-Dyweu44Y.js";import"./Trash01-BnAfsqRe.js";import"./useQuery-CLJFoOtO.js";function ie(e){if(typeof e=="string"||typeof e=="number")return""+e;let t="";if(Array.isArray(e))for(let n=0,o;n<e.length;n++)(o=ie(e[n]))!==""&&(t+=(t&&" ")+o);else for(let n in e)e[n]&&(t+=(t&&" ")+n);return t}var ta={value:()=>{}};function Rt(){for(var e=0,t=arguments.length,n={},o;e<t;++e){if(!(o=arguments[e]+"")||o in n||/[\s.]/.test(o))throw new Error("illegal type: "+o);n[o]=[]}return new St(n)}function St(e){this._=e}function na(e,t){return e.trim().split(/^|\s+/).map(function(n){var o="",r=n.indexOf(".");if(r>=0&&(o=n.slice(r+1),n=n.slice(0,r)),n&&!t.hasOwnProperty(n))throw new Error("unknown type: "+n);return{type:n,name:o}})}St.prototype=Rt.prototype={constructor:St,on:function(e,t){var n=this._,o=na(e+"",n),r,s=-1,i=o.length;if(arguments.length<2){for(;++s<i;)if((r=(e=o[s]).type)&&(r=oa(n[r],e.name)))return r;return}if(t!=null&&typeof t!="function")throw new Error("invalid callback: "+t);for(;++s<i;)if(r=(e=o[s]).type)n[r]=Un(n[r],e.name,t);else if(t==null)for(r in n)n[r]=Un(n[r],e.name,null);return this},copy:function(){var e={},t=this._;for(var n in t)e[n]=t[n].slice();return new St(e)},call:function(e,t){if((r=arguments.length-2)>0)for(var n=new Array(r),o=0,r,s;o<r;++o)n[o]=arguments[o+2];if(!this._.hasOwnProperty(e))throw new Error("unknown type: "+e);for(s=this._[e],o=0,r=s.length;o<r;++o)s[o].value.apply(t,n)},apply:function(e,t,n){if(!this._.hasOwnProperty(e))throw new Error("unknown type: "+e);for(var o=this._[e],r=0,s=o.length;r<s;++r)o[r].value.apply(t,n)}};function oa(e,t){for(var n=0,o=e.length,r;n<o;++n)if((r=e[n]).name===t)return r.value}function Un(e,t,n){for(var o=0,r=e.length;o<r;++o)if(e[o].name===t){e[o]=ta,e=e.slice(0,o).concat(e.slice(o+1));break}return n!=null&&e.push({name:t,value:n}),e}var ln="http://www.w3.org/1999/xhtml";const Qn={svg:"http://www.w3.org/2000/svg",xhtml:ln,xlink:"http://www.w3.org/1999/xlink",xml:"http://www.w3.org/XML/1998/namespace",xmlns:"http://www.w3.org/2000/xmlns/"};function jt(e){var t=e+="",n=t.indexOf(":");return n>=0&&(t=e.slice(0,n))!=="xmlns"&&(e=e.slice(n+1)),Qn.hasOwnProperty(t)?{space:Qn[t],local:e}:e}function ra(e){return function(){var t=this.ownerDocument,n=this.namespaceURI;return n===ln&&t.documentElement.namespaceURI===ln?t.createElement(e):t.createElementNS(n,e)}}function ia(e){return function(){return this.ownerDocument.createElementNS(e.space,e.local)}}function Qo(e){var t=jt(e);return(t.local?ia:ra)(t)}function sa(){}function En(e){return e==null?sa:function(){return this.querySelector(e)}}function aa(e){typeof e!="function"&&(e=En(e));for(var t=this._groups,n=t.length,o=new Array(n),r=0;r<n;++r)for(var s=t[r],i=s.length,a=o[r]=new Array(i),c,l,u=0;u<i;++u)(c=s[u])&&(l=e.call(c,c.__data__,u,s))&&("__data__"in c&&(l.__data__=c.__data__),a[u]=l);return new le(o,this._parents)}function ca(e){return e==null?[]:Array.isArray(e)?e:Array.from(e)}function la(){return[]}function Jo(e){return e==null?la:function(){return this.querySelectorAll(e)}}function ua(e){return function(){return ca(e.apply(this,arguments))}}function da(e){typeof e=="function"?e=ua(e):e=Jo(e);for(var t=this._groups,n=t.length,o=[],r=[],s=0;s<n;++s)for(var i=t[s],a=i.length,c,l=0;l<a;++l)(c=i[l])&&(o.push(e.call(c,c.__data__,l,i)),r.push(c));return new le(o,r)}function er(e){return function(){return this.matches(e)}}function tr(e){return function(t){return t.matches(e)}}var fa=Array.prototype.find;function ha(e){return function(){return fa.call(this.children,e)}}function ga(){return this.firstElementChild}function pa(e){return this.select(e==null?ga:ha(typeof e=="function"?e:tr(e)))}var ma=Array.prototype.filter;function ya(){return Array.from(this.children)}function xa(e){return function(){return ma.call(this.children,e)}}function wa(e){return this.selectAll(e==null?ya:xa(typeof e=="function"?e:tr(e)))}function va(e){typeof e!="function"&&(e=er(e));for(var t=this._groups,n=t.length,o=new Array(n),r=0;r<n;++r)for(var s=t[r],i=s.length,a=o[r]=[],c,l=0;l<i;++l)(c=s[l])&&e.call(c,c.__data__,l,s)&&a.push(c);return new le(o,this._parents)}function nr(e){return new Array(e.length)}function _a(){return new le(this._enter||this._groups.map(nr),this._parents)}function kt(e,t){this.ownerDocument=e.ownerDocument,this.namespaceURI=e.namespaceURI,this._next=null,this._parent=e,this.__data__=t}kt.prototype={constructor:kt,appendChild:function(e){return this._parent.insertBefore(e,this._next)},insertBefore:function(e,t){return this._parent.insertBefore(e,t)},querySelector:function(e){return this._parent.querySelector(e)},querySelectorAll:function(e){return this._parent.querySelectorAll(e)}};function ba(e){return function(){return e}}function Ea(e,t,n,o,r,s){for(var i=0,a,c=t.length,l=s.length;i<l;++i)(a=t[i])?(a.__data__=s[i],o[i]=a):n[i]=new kt(e,s[i]);for(;i<c;++i)(a=t[i])&&(r[i]=a)}function Sa(e,t,n,o,r,s,i){var a,c,l=new Map,u=t.length,f=s.length,d=new Array(u),g;for(a=0;a<u;++a)(c=t[a])&&(d[a]=g=i.call(c,c.__data__,a,t)+"",l.has(g)?r[a]=c:l.set(g,c));for(a=0;a<f;++a)g=i.call(e,s[a],a,s)+"",(c=l.get(g))?(o[a]=c,c.__data__=s[a],l.delete(g)):n[a]=new kt(e,s[a]);for(a=0;a<u;++a)(c=t[a])&&l.get(d[a])===c&&(r[a]=c)}function Na(e){return e.__data__}function Ca(e,t){if(!arguments.length)return Array.from(this,Na);var n=t?Sa:Ea,o=this._parents,r=this._groups;typeof e!="function"&&(e=ba(e));for(var s=r.length,i=new Array(s),a=new Array(s),c=new Array(s),l=0;l<s;++l){var u=o[l],f=r[l],d=f.length,g=Ma(e.call(u,u&&u.__data__,l,o)),p=g.length,x=a[l]=new Array(p),w=i[l]=new Array(p),m=c[l]=new Array(d);n(u,f,x,w,m,g,t);for(var b=0,h=0,y,S;b<p;++b)if(y=x[b]){for(b>=h&&(h=b+1);!(S=w[h])&&++h<p;);y._next=S||null}}return i=new le(i,o),i._enter=a,i._exit=c,i}function Ma(e){return typeof e=="object"&&"length"in e?e:Array.from(e)}function Ia(){return new le(this._exit||this._groups.map(nr),this._parents)}function ka(e,t,n){var o=this.enter(),r=this,s=this.exit();return typeof e=="function"?(o=e(o),o&&(o=o.selection())):o=o.append(e+""),t!=null&&(r=t(r),r&&(r=r.selection())),n==null?s.remove():n(s),o&&r?o.merge(r).order():r}function Aa(e){for(var t=e.selection?e.selection():e,n=this._groups,o=t._groups,r=n.length,s=o.length,i=Math.min(r,s),a=new Array(r),c=0;c<i;++c)for(var l=n[c],u=o[c],f=l.length,d=a[c]=new Array(f),g,p=0;p<f;++p)(g=l[p]||u[p])&&(d[p]=g);for(;c<r;++c)a[c]=n[c];return new le(a,this._parents)}function Pa(){for(var e=this._groups,t=-1,n=e.length;++t<n;)for(var o=e[t],r=o.length-1,s=o[r],i;--r>=0;)(i=o[r])&&(s&&i.compareDocumentPosition(s)^4&&s.parentNode.insertBefore(i,s),s=i);return this}function Da(e){e||(e=Ta);function t(f,d){return f&&d?e(f.__data__,d.__data__):!f-!d}for(var n=this._groups,o=n.length,r=new Array(o),s=0;s<o;++s){for(var i=n[s],a=i.length,c=r[s]=new Array(a),l,u=0;u<a;++u)(l=i[u])&&(c[u]=l);c.sort(t)}return new le(r,this._parents).order()}function Ta(e,t){return e<t?-1:e>t?1:e>=t?0:NaN}function za(){var e=arguments[0];return arguments[0]=this,e.apply(null,arguments),this}function $a(){return Array.from(this)}function Ha(){for(var e=this._groups,t=0,n=e.length;t<n;++t)for(var o=e[t],r=0,s=o.length;r<s;++r){var i=o[r];if(i)return i}return null}function La(){let e=0;for(const t of this)++e;return e}function Ra(){return!this.node()}function ja(e){for(var t=this._groups,n=0,o=t.length;n<o;++n)for(var r=t[n],s=0,i=r.length,a;s<i;++s)(a=r[s])&&e.call(a,a.__data__,s,r);return this}function Va(e){return function(){this.removeAttribute(e)}}function Oa(e){return function(){this.removeAttributeNS(e.space,e.local)}}function Ba(e,t){return function(){this.setAttribute(e,t)}}function Fa(e,t){return function(){this.setAttributeNS(e.space,e.local,t)}}function Xa(e,t){return function(){var n=t.apply(this,arguments);n==null?this.removeAttribute(e):this.setAttribute(e,n)}}function Ya(e,t){return function(){var n=t.apply(this,arguments);n==null?this.removeAttributeNS(e.space,e.local):this.setAttributeNS(e.space,e.local,n)}}function Za(e,t){var n=jt(e);if(arguments.length<2){var o=this.node();return n.local?o.getAttributeNS(n.space,n.local):o.getAttribute(n)}return this.each((t==null?n.local?Oa:Va:typeof t=="function"?n.local?Ya:Xa:n.local?Fa:Ba)(n,t))}function or(e){return e.ownerDocument&&e.ownerDocument.defaultView||e.document&&e||e.defaultView}function Wa(e){return function(){this.style.removeProperty(e)}}function qa(e,t,n){return function(){this.style.setProperty(e,t,n)}}function Ga(e,t,n){return function(){var o=t.apply(this,arguments);o==null?this.style.removeProperty(e):this.style.setProperty(e,o,n)}}function Ka(e,t,n){return arguments.length>1?this.each((t==null?Wa:typeof t=="function"?Ga:qa)(e,t,n??"")):Ve(this.node(),e)}function Ve(e,t){return e.style.getPropertyValue(t)||or(e).getComputedStyle(e,null).getPropertyValue(t)}function Ua(e){return function(){delete this[e]}}function Qa(e,t){return function(){this[e]=t}}function Ja(e,t){return function(){var n=t.apply(this,arguments);n==null?delete this[e]:this[e]=n}}function ec(e,t){return arguments.length>1?this.each((t==null?Ua:typeof t=="function"?Ja:Qa)(e,t)):this.node()[e]}function rr(e){return e.trim().split(/^|\s+/)}function Sn(e){return e.classList||new ir(e)}function ir(e){this._node=e,this._names=rr(e.getAttribute("class")||"")}ir.prototype={add:function(e){var t=this._names.indexOf(e);t<0&&(this._names.push(e),this._node.setAttribute("class",this._names.join(" ")))},remove:function(e){var t=this._names.indexOf(e);t>=0&&(this._names.splice(t,1),this._node.setAttribute("class",this._names.join(" ")))},contains:function(e){return this._names.indexOf(e)>=0}};function sr(e,t){for(var n=Sn(e),o=-1,r=t.length;++o<r;)n.add(t[o])}function ar(e,t){for(var n=Sn(e),o=-1,r=t.length;++o<r;)n.remove(t[o])}function tc(e){return function(){sr(this,e)}}function nc(e){return function(){ar(this,e)}}function oc(e,t){return function(){(t.apply(this,arguments)?sr:ar)(this,e)}}function rc(e,t){var n=rr(e+"");if(arguments.length<2){for(var o=Sn(this.node()),r=-1,s=n.length;++r<s;)if(!o.contains(n[r]))return!1;return!0}return this.each((typeof t=="function"?oc:t?tc:nc)(n,t))}function ic(){this.textContent=""}function sc(e){return function(){this.textContent=e}}function ac(e){return function(){var t=e.apply(this,arguments);this.textContent=t??""}}function cc(e){return arguments.length?this.each(e==null?ic:(typeof e=="function"?ac:sc)(e)):this.node().textContent}function lc(){this.innerHTML=""}function uc(e){return function(){this.innerHTML=e}}function dc(e){return function(){var t=e.apply(this,arguments);this.innerHTML=t??""}}function fc(e){return arguments.length?this.each(e==null?lc:(typeof e=="function"?dc:uc)(e)):this.node().innerHTML}function hc(){this.nextSibling&&this.parentNode.appendChild(this)}function gc(){return this.each(hc)}function pc(){this.previousSibling&&this.parentNode.insertBefore(this,this.parentNode.firstChild)}function mc(){return this.each(pc)}function yc(e){var t=typeof e=="function"?e:Qo(e);return this.select(function(){return this.appendChild(t.apply(this,arguments))})}function xc(){return null}function wc(e,t){var n=typeof e=="function"?e:Qo(e),o=t==null?xc:typeof t=="function"?t:En(t);return this.select(function(){return this.insertBefore(n.apply(this,arguments),o.apply(this,arguments)||null)})}function vc(){var e=this.parentNode;e&&e.removeChild(this)}function _c(){return this.each(vc)}function bc(){var e=this.cloneNode(!1),t=this.parentNode;return t?t.insertBefore(e,this.nextSibling):e}function Ec(){var e=this.cloneNode(!0),t=this.parentNode;return t?t.insertBefore(e,this.nextSibling):e}function Sc(e){return this.select(e?Ec:bc)}function Nc(e){return arguments.length?this.property("__data__",e):this.node().__data__}function Cc(e){return function(t){e.call(this,t,this.__data__)}}function Mc(e){return e.trim().split(/^|\s+/).map(function(t){var n="",o=t.indexOf(".");return o>=0&&(n=t.slice(o+1),t=t.slice(0,o)),{type:t,name:n}})}function Ic(e){return function(){var t=this.__on;if(t){for(var n=0,o=-1,r=t.length,s;n<r;++n)s=t[n],(!e.type||s.type===e.type)&&s.name===e.name?this.removeEventListener(s.type,s.listener,s.options):t[++o]=s;++o?t.length=o:delete this.__on}}}function kc(e,t,n){return function(){var o=this.__on,r,s=Cc(t);if(o){for(var i=0,a=o.length;i<a;++i)if((r=o[i]).type===e.type&&r.name===e.name){this.removeEventListener(r.type,r.listener,r.options),this.addEventListener(r.type,r.listener=s,r.options=n),r.value=t;return}}this.addEventListener(e.type,s,n),r={type:e.type,name:e.name,value:t,listener:s,options:n},o?o.push(r):this.__on=[r]}}function Ac(e,t,n){var o=Mc(e+""),r,s=o.length,i;if(arguments.length<2){var a=this.node().__on;if(a){for(var c=0,l=a.length,u;c<l;++c)for(r=0,u=a[c];r<s;++r)if((i=o[r]).type===u.type&&i.name===u.name)return u.value}return}for(a=t?kc:Ic,r=0;r<s;++r)this.each(a(o[r],t,n));return this}function cr(e,t,n){var o=or(e),r=o.CustomEvent;typeof r=="function"?r=new r(t,n):(r=o.document.createEvent("Event"),n?(r.initEvent(t,n.bubbles,n.cancelable),r.detail=n.detail):r.initEvent(t,!1,!1)),e.dispatchEvent(r)}function Pc(e,t){return function(){return cr(this,e,t)}}function Dc(e,t){return function(){return cr(this,e,t.apply(this,arguments))}}function Tc(e,t){return this.each((typeof t=="function"?Dc:Pc)(e,t))}function*zc(){for(var e=this._groups,t=0,n=e.length;t<n;++t)for(var o=e[t],r=0,s=o.length,i;r<s;++r)(i=o[r])&&(yield i)}var lr=[null];function le(e,t){this._groups=e,this._parents=t}function ut(){return new le([[document.documentElement]],lr)}function $c(){return this}le.prototype=ut.prototype={constructor:le,select:aa,selectAll:da,selectChild:pa,selectChildren:wa,filter:va,data:Ca,enter:_a,exit:Ia,join:ka,merge:Aa,selection:$c,order:Pa,sort:Da,call:za,nodes:$a,node:Ha,size:La,empty:Ra,each:ja,attr:Za,style:Ka,property:ec,classed:rc,text:cc,html:fc,raise:gc,lower:mc,append:yc,insert:wc,remove:_c,clone:Sc,datum:Nc,on:Ac,dispatch:Tc,[Symbol.iterator]:zc};function ce(e){return typeof e=="string"?new le([[document.querySelector(e)]],[document.documentElement]):new le([[e]],lr)}function Hc(e){let t;for(;t=e.sourceEvent;)e=t;return e}function de(e,t){if(e=Hc(e),t===void 0&&(t=e.currentTarget),t){var n=t.ownerSVGElement||t;if(n.createSVGPoint){var o=n.createSVGPoint();return o.x=e.clientX,o.y=e.clientY,o=o.matrixTransform(t.getScreenCTM().inverse()),[o.x,o.y]}if(t.getBoundingClientRect){var r=t.getBoundingClientRect();return[e.clientX-r.left-t.clientLeft,e.clientY-r.top-t.clientTop]}}return[e.pageX,e.pageY]}const Lc={passive:!1},ot={capture:!0,passive:!1};function tn(e){e.stopImmediatePropagation()}function je(e){e.preventDefault(),e.stopImmediatePropagation()}function ur(e){var t=e.document.documentElement,n=ce(e).on("dragstart.drag",je,ot);"onselectstart"in t?n.on("selectstart.drag",je,ot):(t.__noselect=t.style.MozUserSelect,t.style.MozUserSelect="none")}function dr(e,t){var n=e.document.documentElement,o=ce(e).on("dragstart.drag",null);t&&(o.on("click.drag",je,ot),setTimeout(function(){o.on("click.drag",null)},0)),"onselectstart"in n?o.on("selectstart.drag",null):(n.style.MozUserSelect=n.__noselect,delete n.__noselect)}const mt=e=>()=>e;function un(e,{sourceEvent:t,subject:n,target:o,identifier:r,active:s,x:i,y:a,dx:c,dy:l,dispatch:u}){Object.defineProperties(this,{type:{value:e,enumerable:!0,configurable:!0},sourceEvent:{value:t,enumerable:!0,configurable:!0},subject:{value:n,enumerable:!0,configurable:!0},target:{value:o,enumerable:!0,configurable:!0},identifier:{value:r,enumerable:!0,configurable:!0},active:{value:s,enumerable:!0,configurable:!0},x:{value:i,enumerable:!0,configurable:!0},y:{value:a,enumerable:!0,configurable:!0},dx:{value:c,enumerable:!0,configurable:!0},dy:{value:l,enumerable:!0,configurable:!0},_:{value:u}})}un.prototype.on=function(){var e=this._.on.apply(this._,arguments);return e===this._?this:e};function Rc(e){return!e.ctrlKey&&!e.button}function jc(){return this.parentNode}function Vc(e,t){return t??{x:e.x,y:e.y}}function Oc(){return navigator.maxTouchPoints||"ontouchstart"in this}function fr(){var e=Rc,t=jc,n=Vc,o=Oc,r={},s=Rt("start","drag","end"),i=0,a,c,l,u,f=0;function d(y){y.on("mousedown.drag",g).filter(o).on("touchstart.drag",w).on("touchmove.drag",m,Lc).on("touchend.drag touchcancel.drag",b).style("touch-action","none").style("-webkit-tap-highlight-color","rgba(0,0,0,0)")}function g(y,S){if(!(u||!e.call(this,y,S))){var E=h(this,t.call(this,y,S),y,S,"mouse");E&&(ce(y.view).on("mousemove.drag",p,ot).on("mouseup.drag",x,ot),ur(y.view),tn(y),l=!1,a=y.clientX,c=y.clientY,E("start",y))}}function p(y){if(je(y),!l){var S=y.clientX-a,E=y.clientY-c;l=S*S+E*E>f}r.mouse("drag",y)}function x(y){ce(y.view).on("mousemove.drag mouseup.drag",null),dr(y.view,l),je(y),r.mouse("end",y)}function w(y,S){if(e.call(this,y,S)){var E=y.changedTouches,C=t.call(this,y,S),P=E.length,D,V;for(D=0;D<P;++D)(V=h(this,C,y,S,E[D].identifier,E[D]))&&(tn(y),V("start",y,E[D]))}}function m(y){var S=y.changedTouches,E=S.length,C,P;for(C=0;C<E;++C)(P=r[S[C].identifier])&&(je(y),P("drag",y,S[C]))}function b(y){var S=y.changedTouches,E=S.length,C,P;for(u&&clearTimeout(u),u=setTimeout(function(){u=null},500),C=0;C<E;++C)(P=r[S[C].identifier])&&(tn(y),P("end",y,S[C]))}function h(y,S,E,C,P,D){var V=s.copy(),I=de(D||E,S),z,H,v;if((v=n.call(y,new un("beforestart",{sourceEvent:E,target:d,identifier:P,active:i,x:I[0],y:I[1],dx:0,dy:0,dispatch:V}),C))!=null)return z=v.x-I[0]||0,H=v.y-I[1]||0,function M(N,A,k){var T=I,L;switch(N){case"start":r[P]=M,L=i++;break;case"end":delete r[P],--i;case"drag":I=de(k||A,S),L=i;break}V.call(N,y,new un(N,{sourceEvent:A,subject:v,target:d,identifier:P,active:L,x:I[0]+z,y:I[1]+H,dx:I[0]-T[0],dy:I[1]-T[1],dispatch:V}),C)}}return d.filter=function(y){return arguments.length?(e=typeof y=="function"?y:mt(!!y),d):e},d.container=function(y){return arguments.length?(t=typeof y=="function"?y:mt(y),d):t},d.subject=function(y){return arguments.length?(n=typeof y=="function"?y:mt(y),d):n},d.touchable=function(y){return arguments.length?(o=typeof y=="function"?y:mt(!!y),d):o},d.on=function(){var y=s.on.apply(s,arguments);return y===s?d:y},d.clickDistance=function(y){return arguments.length?(f=(y=+y)*y,d):Math.sqrt(f)},d}var Jn=180/Math.PI,dn={translateX:0,translateY:0,rotate:0,skewX:0,scaleX:1,scaleY:1};function hr(e,t,n,o,r,s){var i,a,c;return(i=Math.sqrt(e*e+t*t))&&(e/=i,t/=i),(c=e*n+t*o)&&(n-=e*c,o-=t*c),(a=Math.sqrt(n*n+o*o))&&(n/=a,o/=a,c/=a),e*o<t*n&&(e=-e,t=-t,c=-c,i=-i),{translateX:r,translateY:s,rotate:Math.atan2(t,e)*Jn,skewX:Math.atan(c)*Jn,scaleX:i,scaleY:a}}var yt;function Bc(e){const t=new(typeof DOMMatrix=="function"?DOMMatrix:WebKitCSSMatrix)(e+"");return t.isIdentity?dn:hr(t.a,t.b,t.c,t.d,t.e,t.f)}function Fc(e){return e==null||(yt||(yt=document.createElementNS("http://www.w3.org/2000/svg","g")),yt.setAttribute("transform",e),!(e=yt.transform.baseVal.consolidate()))?dn:(e=e.matrix,hr(e.a,e.b,e.c,e.d,e.e,e.f))}function gr(e,t,n,o){function r(l){return l.length?l.pop()+" ":""}function s(l,u,f,d,g,p){if(l!==f||u!==d){var x=g.push("translate(",null,t,null,n);p.push({i:x-4,x:ke(l,f)},{i:x-2,x:ke(u,d)})}else(f||d)&&g.push("translate("+f+t+d+n)}function i(l,u,f,d){l!==u?(l-u>180?u+=360:u-l>180&&(l+=360),d.push({i:f.push(r(f)+"rotate(",null,o)-2,x:ke(l,u)})):u&&f.push(r(f)+"rotate("+u+o)}function a(l,u,f,d){l!==u?d.push({i:f.push(r(f)+"skewX(",null,o)-2,x:ke(l,u)}):u&&f.push(r(f)+"skewX("+u+o)}function c(l,u,f,d,g,p){if(l!==f||u!==d){var x=g.push(r(g)+"scale(",null,",",null,")");p.push({i:x-4,x:ke(l,f)},{i:x-2,x:ke(u,d)})}else(f!==1||d!==1)&&g.push(r(g)+"scale("+f+","+d+")")}return function(l,u){var f=[],d=[];return l=e(l),u=e(u),s(l.translateX,l.translateY,u.translateX,u.translateY,f,d),i(l.rotate,u.rotate,f,d),a(l.skewX,u.skewX,f,d),c(l.scaleX,l.scaleY,u.scaleX,u.scaleY,f,d),l=u=null,function(g){for(var p=-1,x=d.length,w;++p<x;)f[(w=d[p]).i]=w.x(g);return f.join("")}}}var Xc=gr(Bc,"px, ","px)","deg)"),Yc=gr(Fc,", ",")",")"),Zc=1e-12;function eo(e){return((e=Math.exp(e))+1/e)/2}function Wc(e){return((e=Math.exp(e))-1/e)/2}function qc(e){return((e=Math.exp(2*e))-1)/(e+1)}const Nt=(function e(t,n,o){function r(s,i){var a=s[0],c=s[1],l=s[2],u=i[0],f=i[1],d=i[2],g=u-a,p=f-c,x=g*g+p*p,w,m;if(x<Zc)m=Math.log(d/l)/t,w=function(C){return[a+C*g,c+C*p,l*Math.exp(t*C*m)]};else{var b=Math.sqrt(x),h=(d*d-l*l+o*x)/(2*l*n*b),y=(d*d-l*l-o*x)/(2*d*n*b),S=Math.log(Math.sqrt(h*h+1)-h),E=Math.log(Math.sqrt(y*y+1)-y);m=(E-S)/t,w=function(C){var P=C*m,D=eo(S),V=l/(n*b)*(D*qc(t*P+S)-Wc(S));return[a+V*g,c+V*p,l*D/eo(t*P+S)]}}return w.duration=m*1e3*t/Math.SQRT2,w}return r.rho=function(s){var i=Math.max(.001,+s),a=i*i,c=a*a;return e(i,a,c)},r})(Math.SQRT2,2,4);var Oe=0,Je=0,Ue=0,pr=1e3,At,et,Pt=0,De=0,Vt=0,rt=typeof performance=="object"&&performance.now?performance:Date,mr=typeof window=="object"&&window.requestAnimationFrame?window.requestAnimationFrame.bind(window):function(e){setTimeout(e,17)};function Nn(){return De||(mr(Gc),De=rt.now()+Vt)}function Gc(){De=0}function Dt(){this._call=this._time=this._next=null}Dt.prototype=yr.prototype={constructor:Dt,restart:function(e,t,n){if(typeof e!="function")throw new TypeError("callback is not a function");n=(n==null?Nn():+n)+(t==null?0:+t),!this._next&&et!==this&&(et?et._next=this:At=this,et=this),this._call=e,this._time=n,fn()},stop:function(){this._call&&(this._call=null,this._time=1/0,fn())}};function yr(e,t,n){var o=new Dt;return o.restart(e,t,n),o}function Kc(){Nn(),++Oe;for(var e=At,t;e;)(t=De-e._time)>=0&&e._call.call(void 0,t),e=e._next;--Oe}function to(){De=(Pt=rt.now())+Vt,Oe=Je=0;try{Kc()}finally{Oe=0,Qc(),De=0}}function Uc(){var e=rt.now(),t=e-Pt;t>pr&&(Vt-=t,Pt=e)}function Qc(){for(var e,t=At,n,o=1/0;t;)t._call?(o>t._time&&(o=t._time),e=t,t=t._next):(n=t._next,t._next=null,t=e?e._next=n:At=n);et=e,fn(o)}function fn(e){if(!Oe){Je&&(Je=clearTimeout(Je));var t=e-De;t>24?(e<1/0&&(Je=setTimeout(to,e-rt.now()-Vt)),Ue&&(Ue=clearInterval(Ue))):(Ue||(Pt=rt.now(),Ue=setInterval(Uc,pr)),Oe=1,mr(to))}}function no(e,t,n){var o=new Dt;return t=t==null?0:+t,o.restart(r=>{o.stop(),e(r+t)},t,n),o}var Jc=Rt("start","end","cancel","interrupt"),el=[],xr=0,oo=1,hn=2,Ct=3,ro=4,gn=5,Mt=6;function Ot(e,t,n,o,r,s){var i=e.__transition;if(!i)e.__transition={};else if(n in i)return;tl(e,n,{name:t,index:o,group:r,on:Jc,tween:el,time:s.time,delay:s.delay,duration:s.duration,ease:s.ease,timer:null,state:xr})}function Cn(e,t){var n=ge(e,t);if(n.state>xr)throw new Error("too late; already scheduled");return n}function me(e,t){var n=ge(e,t);if(n.state>Ct)throw new Error("too late; already running");return n}function ge(e,t){var n=e.__transition;if(!n||!(n=n[t]))throw new Error("transition not found");return n}function tl(e,t,n){var o=e.__transition,r;o[t]=n,n.timer=yr(s,0,n.time);function s(l){n.state=oo,n.timer.restart(i,n.delay,n.time),n.delay<=l&&i(l-n.delay)}function i(l){var u,f,d,g;if(n.state!==oo)return c();for(u in o)if(g=o[u],g.name===n.name){if(g.state===Ct)return no(i);g.state===ro?(g.state=Mt,g.timer.stop(),g.on.call("interrupt",e,e.__data__,g.index,g.group),delete o[u]):+u<t&&(g.state=Mt,g.timer.stop(),g.on.call("cancel",e,e.__data__,g.index,g.group),delete o[u])}if(no(function(){n.state===Ct&&(n.state=ro,n.timer.restart(a,n.delay,n.time),a(l))}),n.state=hn,n.on.call("start",e,e.__data__,n.index,n.group),n.state===hn){for(n.state=Ct,r=new Array(d=n.tween.length),u=0,f=-1;u<d;++u)(g=n.tween[u].value.call(e,e.__data__,n.index,n.group))&&(r[++f]=g);r.length=f+1}}function a(l){for(var u=l<n.duration?n.ease.call(null,l/n.duration):(n.timer.restart(c),n.state=gn,1),f=-1,d=r.length;++f<d;)r[f].call(e,u);n.state===gn&&(n.on.call("end",e,e.__data__,n.index,n.group),c())}function c(){n.state=Mt,n.timer.stop(),delete o[t];for(var l in o)return;delete e.__transition}}function It(e,t){var n=e.__transition,o,r,s=!0,i;if(n){t=t==null?null:t+"";for(i in n){if((o=n[i]).name!==t){s=!1;continue}r=o.state>hn&&o.state<gn,o.state=Mt,o.timer.stop(),o.on.call(r?"interrupt":"cancel",e,e.__data__,o.index,o.group),delete n[i]}s&&delete e.__transition}}function nl(e){return this.each(function(){It(this,e)})}function ol(e,t){var n,o;return function(){var r=me(this,e),s=r.tween;if(s!==n){o=n=s;for(var i=0,a=o.length;i<a;++i)if(o[i].name===t){o=o.slice(),o.splice(i,1);break}}r.tween=o}}function rl(e,t,n){var o,r;if(typeof n!="function")throw new Error;return function(){var s=me(this,e),i=s.tween;if(i!==o){r=(o=i).slice();for(var a={name:t,value:n},c=0,l=r.length;c<l;++c)if(r[c].name===t){r[c]=a;break}c===l&&r.push(a)}s.tween=r}}function il(e,t){var n=this._id;if(e+="",arguments.length<2){for(var o=ge(this.node(),n).tween,r=0,s=o.length,i;r<s;++r)if((i=o[r]).name===e)return i.value;return null}return this.each((t==null?ol:rl)(n,e,t))}function Mn(e,t,n){var o=e._id;return e.each(function(){var r=me(this,o);(r.value||(r.value={}))[t]=n.apply(this,arguments)}),function(r){return ge(r,o).value[t]}}function wr(e,t){var n;return(typeof t=="number"?ke:t instanceof Kn?Gn:(n=Kn(t))?(t=n,Gn):Js)(e,t)}function sl(e){return function(){this.removeAttribute(e)}}function al(e){return function(){this.removeAttributeNS(e.space,e.local)}}function cl(e,t,n){var o,r=n+"",s;return function(){var i=this.getAttribute(e);return i===r?null:i===o?s:s=t(o=i,n)}}function ll(e,t,n){var o,r=n+"",s;return function(){var i=this.getAttributeNS(e.space,e.local);return i===r?null:i===o?s:s=t(o=i,n)}}function ul(e,t,n){var o,r,s;return function(){var i,a=n(this),c;return a==null?void this.removeAttribute(e):(i=this.getAttribute(e),c=a+"",i===c?null:i===o&&c===r?s:(r=c,s=t(o=i,a)))}}function dl(e,t,n){var o,r,s;return function(){var i,a=n(this),c;return a==null?void this.removeAttributeNS(e.space,e.local):(i=this.getAttributeNS(e.space,e.local),c=a+"",i===c?null:i===o&&c===r?s:(r=c,s=t(o=i,a)))}}function fl(e,t){var n=jt(e),o=n==="transform"?Yc:wr;return this.attrTween(e,typeof t=="function"?(n.local?dl:ul)(n,o,Mn(this,"attr."+e,t)):t==null?(n.local?al:sl)(n):(n.local?ll:cl)(n,o,t))}function hl(e,t){return function(n){this.setAttribute(e,t.call(this,n))}}function gl(e,t){return function(n){this.setAttributeNS(e.space,e.local,t.call(this,n))}}function pl(e,t){var n,o;function r(){var s=t.apply(this,arguments);return s!==o&&(n=(o=s)&&gl(e,s)),n}return r._value=t,r}function ml(e,t){var n,o;function r(){var s=t.apply(this,arguments);return s!==o&&(n=(o=s)&&hl(e,s)),n}return r._value=t,r}function yl(e,t){var n="attr."+e;if(arguments.length<2)return(n=this.tween(n))&&n._value;if(t==null)return this.tween(n,null);if(typeof t!="function")throw new Error;var o=jt(e);return this.tween(n,(o.local?pl:ml)(o,t))}function xl(e,t){return function(){Cn(this,e).delay=+t.apply(this,arguments)}}function wl(e,t){return t=+t,function(){Cn(this,e).delay=t}}function vl(e){var t=this._id;return arguments.length?this.each((typeof e=="function"?xl:wl)(t,e)):ge(this.node(),t).delay}function _l(e,t){return function(){me(this,e).duration=+t.apply(this,arguments)}}function bl(e,t){return t=+t,function(){me(this,e).duration=t}}function El(e){var t=this._id;return arguments.length?this.each((typeof e=="function"?_l:bl)(t,e)):ge(this.node(),t).duration}function Sl(e,t){if(typeof t!="function")throw new Error;return function(){me(this,e).ease=t}}function Nl(e){var t=this._id;return arguments.length?this.each(Sl(t,e)):ge(this.node(),t).ease}function Cl(e,t){return function(){var n=t.apply(this,arguments);if(typeof n!="function")throw new Error;me(this,e).ease=n}}function Ml(e){if(typeof e!="function")throw new Error;return this.each(Cl(this._id,e))}function Il(e){typeof e!="function"&&(e=er(e));for(var t=this._groups,n=t.length,o=new Array(n),r=0;r<n;++r)for(var s=t[r],i=s.length,a=o[r]=[],c,l=0;l<i;++l)(c=s[l])&&e.call(c,c.__data__,l,s)&&a.push(c);return new ve(o,this._parents,this._name,this._id)}function kl(e){if(e._id!==this._id)throw new Error;for(var t=this._groups,n=e._groups,o=t.length,r=n.length,s=Math.min(o,r),i=new Array(o),a=0;a<s;++a)for(var c=t[a],l=n[a],u=c.length,f=i[a]=new Array(u),d,g=0;g<u;++g)(d=c[g]||l[g])&&(f[g]=d);for(;a<o;++a)i[a]=t[a];return new ve(i,this._parents,this._name,this._id)}function Al(e){return(e+"").trim().split(/^|\s+/).every(function(t){var n=t.indexOf(".");return n>=0&&(t=t.slice(0,n)),!t||t==="start"})}function Pl(e,t,n){var o,r,s=Al(t)?Cn:me;return function(){var i=s(this,e),a=i.on;a!==o&&(r=(o=a).copy()).on(t,n),i.on=r}}function Dl(e,t){var n=this._id;return arguments.length<2?ge(this.node(),n).on.on(e):this.each(Pl(n,e,t))}function Tl(e){return function(){var t=this.parentNode;for(var n in this.__transition)if(+n!==e)return;t&&t.removeChild(this)}}function zl(){return this.on("end.remove",Tl(this._id))}function $l(e){var t=this._name,n=this._id;typeof e!="function"&&(e=En(e));for(var o=this._groups,r=o.length,s=new Array(r),i=0;i<r;++i)for(var a=o[i],c=a.length,l=s[i]=new Array(c),u,f,d=0;d<c;++d)(u=a[d])&&(f=e.call(u,u.__data__,d,a))&&("__data__"in u&&(f.__data__=u.__data__),l[d]=f,Ot(l[d],t,n,d,l,ge(u,n)));return new ve(s,this._parents,t,n)}function Hl(e){var t=this._name,n=this._id;typeof e!="function"&&(e=Jo(e));for(var o=this._groups,r=o.length,s=[],i=[],a=0;a<r;++a)for(var c=o[a],l=c.length,u,f=0;f<l;++f)if(u=c[f]){for(var d=e.call(u,u.__data__,f,c),g,p=ge(u,n),x=0,w=d.length;x<w;++x)(g=d[x])&&Ot(g,t,n,x,d,p);s.push(d),i.push(u)}return new ve(s,i,t,n)}var Ll=ut.prototype.constructor;function Rl(){return new Ll(this._groups,this._parents)}function jl(e,t){var n,o,r;return function(){var s=Ve(this,e),i=(this.style.removeProperty(e),Ve(this,e));return s===i?null:s===n&&i===o?r:r=t(n=s,o=i)}}function vr(e){return function(){this.style.removeProperty(e)}}function Vl(e,t,n){var o,r=n+"",s;return function(){var i=Ve(this,e);return i===r?null:i===o?s:s=t(o=i,n)}}function Ol(e,t,n){var o,r,s;return function(){var i=Ve(this,e),a=n(this),c=a+"";return a==null&&(c=a=(this.style.removeProperty(e),Ve(this,e))),i===c?null:i===o&&c===r?s:(r=c,s=t(o=i,a))}}function Bl(e,t){var n,o,r,s="style."+t,i="end."+s,a;return function(){var c=me(this,e),l=c.on,u=c.value[s]==null?a||(a=vr(t)):void 0;(l!==n||r!==u)&&(o=(n=l).copy()).on(i,r=u),c.on=o}}function Fl(e,t,n){var o=(e+="")=="transform"?Xc:wr;return t==null?this.styleTween(e,jl(e,o)).on("end.style."+e,vr(e)):typeof t=="function"?this.styleTween(e,Ol(e,o,Mn(this,"style."+e,t))).each(Bl(this._id,e)):this.styleTween(e,Vl(e,o,t),n).on("end.style."+e,null)}function Xl(e,t,n){return function(o){this.style.setProperty(e,t.call(this,o),n)}}function Yl(e,t,n){var o,r;function s(){var i=t.apply(this,arguments);return i!==r&&(o=(r=i)&&Xl(e,i,n)),o}return s._value=t,s}function Zl(e,t,n){var o="style."+(e+="");if(arguments.length<2)return(o=this.tween(o))&&o._value;if(t==null)return this.tween(o,null);if(typeof t!="function")throw new Error;return this.tween(o,Yl(e,t,n??""))}function Wl(e){return function(){this.textContent=e}}function ql(e){return function(){var t=e(this);this.textContent=t??""}}function Gl(e){return this.tween("text",typeof e=="function"?ql(Mn(this,"text",e)):Wl(e==null?"":e+""))}function Kl(e){return function(t){this.textContent=e.call(this,t)}}function Ul(e){var t,n;function o(){var r=e.apply(this,arguments);return r!==n&&(t=(n=r)&&Kl(r)),t}return o._value=e,o}function Ql(e){var t="text";if(arguments.length<1)return(t=this.tween(t))&&t._value;if(e==null)return this.tween(t,null);if(typeof e!="function")throw new Error;return this.tween(t,Ul(e))}function Jl(){for(var e=this._name,t=this._id,n=_r(),o=this._groups,r=o.length,s=0;s<r;++s)for(var i=o[s],a=i.length,c,l=0;l<a;++l)if(c=i[l]){var u=ge(c,t);Ot(c,e,n,l,i,{time:u.time+u.delay+u.duration,delay:0,duration:u.duration,ease:u.ease})}return new ve(o,this._parents,e,n)}function eu(){var e,t,n=this,o=n._id,r=n.size();return new Promise(function(s,i){var a={value:i},c={value:function(){--r===0&&s()}};n.each(function(){var l=me(this,o),u=l.on;u!==e&&(t=(e=u).copy(),t._.cancel.push(a),t._.interrupt.push(a),t._.end.push(c)),l.on=t}),r===0&&s()})}var tu=0;function ve(e,t,n,o){this._groups=e,this._parents=t,this._name=n,this._id=o}function _r(){return++tu}var xe=ut.prototype;ve.prototype={constructor:ve,select:$l,selectAll:Hl,selectChild:xe.selectChild,selectChildren:xe.selectChildren,filter:Il,merge:kl,selection:Rl,transition:Jl,call:xe.call,nodes:xe.nodes,node:xe.node,size:xe.size,empty:xe.empty,each:xe.each,on:Dl,attr:fl,attrTween:yl,style:Fl,styleTween:Zl,text:Gl,textTween:Ql,remove:zl,tween:il,delay:vl,duration:El,ease:Nl,easeVarying:Ml,end:eu,[Symbol.iterator]:xe[Symbol.iterator]};function nu(e){return((e*=2)<=1?e*e*e:(e-=2)*e*e+2)/2}var ou={time:null,delay:0,duration:250,ease:nu};function ru(e,t){for(var n;!(n=e.__transition)||!(n=n[t]);)if(!(e=e.parentNode))throw new Error(`transition ${t} not found`);return n}function iu(e){var t,n;e instanceof ve?(t=e._id,e=e._name):(t=_r(),(n=ou).time=Nn(),e=e==null?null:e+"");for(var o=this._groups,r=o.length,s=0;s<r;++s)for(var i=o[s],a=i.length,c,l=0;l<a;++l)(c=i[l])&&Ot(c,e,t,l,i,n||ru(c,t));return new ve(o,this._parents,e,t)}ut.prototype.interrupt=nl;ut.prototype.transition=iu;const xt=e=>()=>e;function su(e,{sourceEvent:t,target:n,transform:o,dispatch:r}){Object.defineProperties(this,{type:{value:e,enumerable:!0,configurable:!0},sourceEvent:{value:t,enumerable:!0,configurable:!0},target:{value:n,enumerable:!0,configurable:!0},transform:{value:o,enumerable:!0,configurable:!0},_:{value:r}})}function we(e,t,n){this.k=e,this.x=t,this.y=n}we.prototype={constructor:we,scale:function(e){return e===1?this:new we(this.k*e,this.x,this.y)},translate:function(e,t){return e===0&t===0?this:new we(this.k,this.x+this.k*e,this.y+this.k*t)},apply:function(e){return[e[0]*this.k+this.x,e[1]*this.k+this.y]},applyX:function(e){return e*this.k+this.x},applyY:function(e){return e*this.k+this.y},invert:function(e){return[(e[0]-this.x)/this.k,(e[1]-this.y)/this.k]},invertX:function(e){return(e-this.x)/this.k},invertY:function(e){return(e-this.y)/this.k},rescaleX:function(e){return e.copy().domain(e.range().map(this.invertX,this).map(e.invert,e))},rescaleY:function(e){return e.copy().domain(e.range().map(this.invertY,this).map(e.invert,e))},toString:function(){return"translate("+this.x+","+this.y+") scale("+this.k+")"}};var Bt=new we(1,0,0);br.prototype=we.prototype;function br(e){for(;!e.__zoom;)if(!(e=e.parentNode))return Bt;return e.__zoom}function nn(e){e.stopImmediatePropagation()}function Qe(e){e.preventDefault(),e.stopImmediatePropagation()}function au(e){return(!e.ctrlKey||e.type==="wheel")&&!e.button}function cu(){var e=this;return e instanceof SVGElement?(e=e.ownerSVGElement||e,e.hasAttribute("viewBox")?(e=e.viewBox.baseVal,[[e.x,e.y],[e.x+e.width,e.y+e.height]]):[[0,0],[e.width.baseVal.value,e.height.baseVal.value]]):[[0,0],[e.clientWidth,e.clientHeight]]}function io(){return this.__zoom||Bt}function lu(e){return-e.deltaY*(e.deltaMode===1?.05:e.deltaMode?1:.002)*(e.ctrlKey?10:1)}function uu(){return navigator.maxTouchPoints||"ontouchstart"in this}function du(e,t,n){var o=e.invertX(t[0][0])-n[0][0],r=e.invertX(t[1][0])-n[1][0],s=e.invertY(t[0][1])-n[0][1],i=e.invertY(t[1][1])-n[1][1];return e.translate(r>o?(o+r)/2:Math.min(0,o)||Math.max(0,r),i>s?(s+i)/2:Math.min(0,s)||Math.max(0,i))}function Er(){var e=au,t=cu,n=du,o=lu,r=uu,s=[0,1/0],i=[[-1/0,-1/0],[1/0,1/0]],a=250,c=Nt,l=Rt("start","zoom","end"),u,f,d,g=500,p=150,x=0,w=10;function m(v){v.property("__zoom",io).on("wheel.zoom",P,{passive:!1}).on("mousedown.zoom",D).on("dblclick.zoom",V).filter(r).on("touchstart.zoom",I).on("touchmove.zoom",z).on("touchend.zoom touchcancel.zoom",H).style("-webkit-tap-highlight-color","rgba(0,0,0,0)")}m.transform=function(v,M,N,A){var k=v.selection?v.selection():v;k.property("__zoom",io),v!==k?S(v,M,N,A):k.interrupt().each(function(){E(this,arguments).event(A).start().zoom(null,typeof M=="function"?M.apply(this,arguments):M).end()})},m.scaleBy=function(v,M,N,A){m.scaleTo(v,function(){var k=this.__zoom.k,T=typeof M=="function"?M.apply(this,arguments):M;return k*T},N,A)},m.scaleTo=function(v,M,N,A){m.transform(v,function(){var k=t.apply(this,arguments),T=this.__zoom,L=N==null?y(k):typeof N=="function"?N.apply(this,arguments):N,j=T.invert(L),R=typeof M=="function"?M.apply(this,arguments):M;return n(h(b(T,R),L,j),k,i)},N,A)},m.translateBy=function(v,M,N,A){m.transform(v,function(){return n(this.__zoom.translate(typeof M=="function"?M.apply(this,arguments):M,typeof N=="function"?N.apply(this,arguments):N),t.apply(this,arguments),i)},null,A)},m.translateTo=function(v,M,N,A,k){m.transform(v,function(){var T=t.apply(this,arguments),L=this.__zoom,j=A==null?y(T):typeof A=="function"?A.apply(this,arguments):A;return n(Bt.translate(j[0],j[1]).scale(L.k).translate(typeof M=="function"?-M.apply(this,arguments):-M,typeof N=="function"?-N.apply(this,arguments):-N),T,i)},A,k)};function b(v,M){return M=Math.max(s[0],Math.min(s[1],M)),M===v.k?v:new we(M,v.x,v.y)}function h(v,M,N){var A=M[0]-N[0]*v.k,k=M[1]-N[1]*v.k;return A===v.x&&k===v.y?v:new we(v.k,A,k)}function y(v){return[(+v[0][0]+ +v[1][0])/2,(+v[0][1]+ +v[1][1])/2]}function S(v,M,N,A){v.on("start.zoom",function(){E(this,arguments).event(A).start()}).on("interrupt.zoom end.zoom",function(){E(this,arguments).event(A).end()}).tween("zoom",function(){var k=this,T=arguments,L=E(k,T).event(A),j=t.apply(k,T),R=N==null?y(j):typeof N=="function"?N.apply(k,T):N,F=Math.max(j[1][0]-j[0][0],j[1][1]-j[0][1]),B=k.__zoom,W=typeof M=="function"?M.apply(k,T):M,K=c(B.invert(R).concat(F/B.k),W.invert(R).concat(F/W.k));return function(Z){if(Z===1)Z=W;else{var O=K(Z),Y=F/O[2];Z=new we(Y,R[0]-O[0]*Y,R[1]-O[1]*Y)}L.zoom(null,Z)}})}function E(v,M,N){return!N&&v.__zooming||new C(v,M)}function C(v,M){this.that=v,this.args=M,this.active=0,this.sourceEvent=null,this.extent=t.apply(v,M),this.taps=0}C.prototype={event:function(v){return v&&(this.sourceEvent=v),this},start:function(){return++this.active===1&&(this.that.__zooming=this,this.emit("start")),this},zoom:function(v,M){return this.mouse&&v!=="mouse"&&(this.mouse[1]=M.invert(this.mouse[0])),this.touch0&&v!=="touch"&&(this.touch0[1]=M.invert(this.touch0[0])),this.touch1&&v!=="touch"&&(this.touch1[1]=M.invert(this.touch1[0])),this.that.__zoom=M,this.emit("zoom"),this},end:function(){return--this.active===0&&(delete this.that.__zooming,this.emit("end")),this},emit:function(v){var M=ce(this.that).datum();l.call(v,this.that,new su(v,{sourceEvent:this.sourceEvent,target:m,transform:this.that.__zoom,dispatch:l}),M)}};function P(v,...M){if(!e.apply(this,arguments))return;var N=E(this,M).event(v),A=this.__zoom,k=Math.max(s[0],Math.min(s[1],A.k*Math.pow(2,o.apply(this,arguments)))),T=de(v);if(N.wheel)(N.mouse[0][0]!==T[0]||N.mouse[0][1]!==T[1])&&(N.mouse[1]=A.invert(N.mouse[0]=T)),clearTimeout(N.wheel);else{if(A.k===k)return;N.mouse=[T,A.invert(T)],It(this),N.start()}Qe(v),N.wheel=setTimeout(L,p),N.zoom("mouse",n(h(b(A,k),N.mouse[0],N.mouse[1]),N.extent,i));function L(){N.wheel=null,N.end()}}function D(v,...M){if(d||!e.apply(this,arguments))return;var N=v.currentTarget,A=E(this,M,!0).event(v),k=ce(v.view).on("mousemove.zoom",R,!0).on("mouseup.zoom",F,!0),T=de(v,N),L=v.clientX,j=v.clientY;ur(v.view),nn(v),A.mouse=[T,this.__zoom.invert(T)],It(this),A.start();function R(B){if(Qe(B),!A.moved){var W=B.clientX-L,K=B.clientY-j;A.moved=W*W+K*K>x}A.event(B).zoom("mouse",n(h(A.that.__zoom,A.mouse[0]=de(B,N),A.mouse[1]),A.extent,i))}function F(B){k.on("mousemove.zoom mouseup.zoom",null),dr(B.view,A.moved),Qe(B),A.event(B).end()}}function V(v,...M){if(e.apply(this,arguments)){var N=this.__zoom,A=de(v.changedTouches?v.changedTouches[0]:v,this),k=N.invert(A),T=N.k*(v.shiftKey?.5:2),L=n(h(b(N,T),A,k),t.apply(this,M),i);Qe(v),a>0?ce(this).transition().duration(a).call(S,L,A,v):ce(this).call(m.transform,L,A,v)}}function I(v,...M){if(e.apply(this,arguments)){var N=v.touches,A=N.length,k=E(this,M,v.changedTouches.length===A).event(v),T,L,j,R;for(nn(v),L=0;L<A;++L)j=N[L],R=de(j,this),R=[R,this.__zoom.invert(R),j.identifier],k.touch0?!k.touch1&&k.touch0[2]!==R[2]&&(k.touch1=R,k.taps=0):(k.touch0=R,T=!0,k.taps=1+!!u);u&&(u=clearTimeout(u)),T&&(k.taps<2&&(f=R[0],u=setTimeout(function(){u=null},g)),It(this),k.start())}}function z(v,...M){if(this.__zooming){var N=E(this,M).event(v),A=v.changedTouches,k=A.length,T,L,j,R;for(Qe(v),T=0;T<k;++T)L=A[T],j=de(L,this),N.touch0&&N.touch0[2]===L.identifier?N.touch0[0]=j:N.touch1&&N.touch1[2]===L.identifier&&(N.touch1[0]=j);if(L=N.that.__zoom,N.touch1){var F=N.touch0[0],B=N.touch0[1],W=N.touch1[0],K=N.touch1[1],Z=(Z=W[0]-F[0])*Z+(Z=W[1]-F[1])*Z,O=(O=K[0]-B[0])*O+(O=K[1]-B[1])*O;L=b(L,Math.sqrt(Z/O)),j=[(F[0]+W[0])/2,(F[1]+W[1])/2],R=[(B[0]+K[0])/2,(B[1]+K[1])/2]}else if(N.touch0)j=N.touch0[0],R=N.touch0[1];else return;N.zoom("touch",n(h(L,j,R),N.extent,i))}}function H(v,...M){if(this.__zooming){var N=E(this,M).event(v),A=v.changedTouches,k=A.length,T,L;for(nn(v),d&&clearTimeout(d),d=setTimeout(function(){d=null},g),T=0;T<k;++T)L=A[T],N.touch0&&N.touch0[2]===L.identifier?delete N.touch0:N.touch1&&N.touch1[2]===L.identifier&&delete N.touch1;if(N.touch1&&!N.touch0&&(N.touch0=N.touch1,delete N.touch1),N.touch0)N.touch0[1]=this.__zoom.invert(N.touch0[0]);else if(N.end(),N.taps===2&&(L=de(L,this),Math.hypot(f[0]-L[0],f[1]-L[1])<w)){var j=ce(this).on("dblclick.zoom");j&&j.apply(this,arguments)}}}return m.wheelDelta=function(v){return arguments.length?(o=typeof v=="function"?v:xt(+v),m):o},m.filter=function(v){return arguments.length?(e=typeof v=="function"?v:xt(!!v),m):e},m.touchable=function(v){return arguments.length?(r=typeof v=="function"?v:xt(!!v),m):r},m.extent=function(v){return arguments.length?(t=typeof v=="function"?v:xt([[+v[0][0],+v[0][1]],[+v[1][0],+v[1][1]]]),m):t},m.scaleExtent=function(v){return arguments.length?(s[0]=+v[0],s[1]=+v[1],m):[s[0],s[1]]},m.translateExtent=function(v){return arguments.length?(i[0][0]=+v[0][0],i[1][0]=+v[1][0],i[0][1]=+v[0][1],i[1][1]=+v[1][1],m):[[i[0][0],i[0][1]],[i[1][0],i[1][1]]]},m.constrain=function(v){return arguments.length?(n=v,m):n},m.duration=function(v){return arguments.length?(a=+v,m):a},m.interpolate=function(v){return arguments.length?(c=v,m):c},m.on=function(){var v=l.on.apply(l,arguments);return v===l?m:v},m.clickDistance=function(v){return arguments.length?(x=(v=+v)*v,m):Math.sqrt(x)},m.tapDistance=function(v){return arguments.length?(w=+v,m):w},m}const pe={error001:()=>"[React Flow]: Seems like you have not used zustand provider as an ancestor. Help: https://reactflow.dev/error#001",error002:()=>"It looks like you've created a new nodeTypes or edgeTypes object. If this wasn't on purpose please define the nodeTypes/edgeTypes outside of the component or memoize them.",error003:e=>`Node type "${e}" not found. Using fallback type "default".`,error004:()=>"The React Flow parent container needs a width and a height to render the graph.",error005:()=>"Only child nodes can use a parent extent.",error006:()=>"Can't create edge. An edge needs a source and a target.",error007:e=>`The old edge with id=${e} does not exist.`,error009:e=>`Marker type "${e}" doesn't exist.`,error008:(e,{id:t,sourceHandle:n,targetHandle:o})=>`Couldn't create edge for ${e} handle id: "${e==="source"?n:o}", edge id: ${t}.`,error010:()=>"Handle: No node id found. Make sure to only use a Handle inside a custom Node.",error011:e=>`Edge type "${e}" not found. Using fallback type "default".`,error012:e=>`Node with id "${e}" does not exist, it may have been removed. This can happen when a node is deleted before the "onNodeClick" handler is called.`,error013:(e="react")=>`It seems that you haven't loaded the styles. Please import '@xyflow/${e}/dist/style.css' or base.css to make sure everything is working properly.`,error014:()=>"useNodeConnections: No node ID found. Call useNodeConnections inside a custom Node or provide a node ID.",error015:()=>"It seems that you are trying to drag a node that is not initialized. Please use onNodesChange as explained in the docs."},it=[[Number.NEGATIVE_INFINITY,Number.NEGATIVE_INFINITY],[Number.POSITIVE_INFINITY,Number.POSITIVE_INFINITY]],Sr=["Enter"," ","Escape"],Nr={"node.a11yDescription.default":"Press enter or space to select a node. Press delete to remove it and escape to cancel.","node.a11yDescription.keyboardDisabled":"Press enter or space to select a node. You can then use the arrow keys to move the node around. Press delete to remove it and escape to cancel.","node.a11yDescription.ariaLiveMessage":({direction:e,x:t,y:n})=>`Moved selected node ${e}. New position, x: ${t}, y: ${n}`,"edge.a11yDescription.default":"Press enter or space to select an edge. You can then press delete to remove it or escape to cancel.","controls.ariaLabel":"Control Panel","controls.zoomIn.ariaLabel":"Zoom In","controls.zoomOut.ariaLabel":"Zoom Out","controls.fitView.ariaLabel":"Fit View","controls.interactive.ariaLabel":"Toggle Interactivity","minimap.ariaLabel":"Mini Map","handle.ariaLabel":"Handle"};var Be;(function(e){e.Strict="strict",e.Loose="loose"})(Be||(Be={}));var Pe;(function(e){e.Free="free",e.Vertical="vertical",e.Horizontal="horizontal"})(Pe||(Pe={}));var st;(function(e){e.Partial="partial",e.Full="full"})(st||(st={}));const Cr={inProgress:!1,isValid:null,from:null,fromHandle:null,fromPosition:null,fromNode:null,to:null,toHandle:null,toPosition:null,toNode:null,pointer:null};var Ne;(function(e){e.Bezier="default",e.Straight="straight",e.Step="step",e.SmoothStep="smoothstep",e.SimpleBezier="simplebezier"})(Ne||(Ne={}));var Tt;(function(e){e.Arrow="arrow",e.ArrowClosed="arrowclosed"})(Tt||(Tt={}));var X;(function(e){e.Left="left",e.Top="top",e.Right="right",e.Bottom="bottom"})(X||(X={}));const so={[X.Left]:X.Right,[X.Right]:X.Left,[X.Top]:X.Bottom,[X.Bottom]:X.Top};function Mr(e){return e===null?null:e?"valid":"invalid"}const Ir=e=>"id"in e&&"source"in e&&"target"in e,fu=e=>"id"in e&&"position"in e&&!("source"in e)&&!("target"in e),In=e=>"id"in e&&"internals"in e&&!("source"in e)&&!("target"in e),dt=(e,t=[0,0])=>{const{width:n,height:o}=_e(e),r=e.origin??t,s=n*r[0],i=o*r[1];return{x:e.position.x-s,y:e.position.y-i}},hu=(e,t={nodeOrigin:[0,0]})=>{if(e.length===0)return{x:0,y:0,width:0,height:0};const n=e.reduce((o,r)=>{const s=typeof r=="string";let i=!t.nodeLookup&&!s?r:void 0;t.nodeLookup&&(i=s?t.nodeLookup.get(r):In(r)?r:t.nodeLookup.get(r.id));const a=i?zt(i,t.nodeOrigin):{x:0,y:0,x2:0,y2:0};return Ft(o,a)},{x:1/0,y:1/0,x2:-1/0,y2:-1/0});return Xt(n)},ft=(e,t={})=>{let n={x:1/0,y:1/0,x2:-1/0,y2:-1/0},o=!1;return e.forEach(r=>{(t.filter===void 0||t.filter(r))&&(n=Ft(n,zt(r)),o=!0)}),o?Xt(n):{x:0,y:0,width:0,height:0}},kn=(e,t,[n,o,r]=[0,0,1],s=!1,i=!1)=>{const a={...gt(t,[n,o,r]),width:t.width/r,height:t.height/r},c=[];for(const l of e.values()){const{measured:u,selectable:f=!0,hidden:d=!1}=l;if(i&&!f||d)continue;const g=u.width??l.width??l.initialWidth??null,p=u.height??l.height??l.initialHeight??null,x=at(a,Xe(l)),w=(g??0)*(p??0),m=s&&x>0;(!l.internals.handleBounds||m||x>=w||l.dragging)&&c.push(l)}return c},gu=(e,t)=>{const n=new Set;return e.forEach(o=>{n.add(o.id)}),t.filter(o=>n.has(o.source)||n.has(o.target))};function pu(e,t){const n=new Map,o=t?.nodes?new Set(t.nodes.map(r=>r.id)):null;return e.forEach(r=>{r.measured.width&&r.measured.height&&(t?.includeHiddenNodes||!r.hidden)&&(!o||o.has(r.id))&&n.set(r.id,r)}),n}async function mu({nodes:e,width:t,height:n,panZoom:o,minZoom:r,maxZoom:s},i){if(e.size===0)return Promise.resolve(!0);const a=pu(e,i),c=ft(a),l=An(c,t,n,i?.minZoom??r,i?.maxZoom??s,i?.padding??.1);return await o.setViewport(l,{duration:i?.duration,ease:i?.ease,interpolate:i?.interpolate}),Promise.resolve(!0)}function kr({nodeId:e,nextPosition:t,nodeLookup:n,nodeOrigin:o=[0,0],nodeExtent:r,onError:s}){const i=n.get(e),a=i.parentId?n.get(i.parentId):void 0,{x:c,y:l}=a?a.internals.positionAbsolute:{x:0,y:0},u=i.origin??o;let f=i.extent||r;if(i.extent==="parent"&&!i.expandParent)if(!a)s?.("005",pe.error005());else{const g=a.measured.width,p=a.measured.height;g&&p&&(f=[[c,l],[c+g,l+p]])}else a&&Ye(i.extent)&&(f=[[i.extent[0][0]+c,i.extent[0][1]+l],[i.extent[1][0]+c,i.extent[1][1]+l]]);const d=Ye(f)?Te(t,f,i.measured):t;return(i.measured.width===void 0||i.measured.height===void 0)&&s?.("015",pe.error015()),{position:{x:d.x-c+(i.measured.width??0)*u[0],y:d.y-l+(i.measured.height??0)*u[1]},positionAbsolute:d}}async function yu({nodesToRemove:e=[],edgesToRemove:t=[],nodes:n,edges:o,onBeforeDelete:r}){const s=new Set(e.map(d=>d.id)),i=[];for(const d of n){if(d.deletable===!1)continue;const g=s.has(d.id),p=!g&&d.parentId&&i.find(x=>x.id===d.parentId);(g||p)&&i.push(d)}const a=new Set(t.map(d=>d.id)),c=o.filter(d=>d.deletable!==!1),u=gu(i,c);for(const d of c)a.has(d.id)&&!u.find(p=>p.id===d.id)&&u.push(d);if(!r)return{edges:u,nodes:i};const f=await r({nodes:i,edges:u});return typeof f=="boolean"?f?{edges:u,nodes:i}:{edges:[],nodes:[]}:f}const Fe=(e,t=0,n=1)=>Math.min(Math.max(e,t),n),Te=(e={x:0,y:0},t,n)=>({x:Fe(e.x,t[0][0],t[1][0]-(n?.width??0)),y:Fe(e.y,t[0][1],t[1][1]-(n?.height??0))});function Ar(e,t,n){const{width:o,height:r}=_e(n),{x:s,y:i}=n.internals.positionAbsolute;return Te(e,[[s,i],[s+o,i+r]],t)}const ao=(e,t,n)=>e<t?Fe(Math.abs(e-t),1,t)/t:e>n?-Fe(Math.abs(e-n),1,t)/t:0,Pr=(e,t,n=15,o=40)=>{const r=ao(e.x,o,t.width-o)*n,s=ao(e.y,o,t.height-o)*n;return[r,s]},Ft=(e,t)=>({x:Math.min(e.x,t.x),y:Math.min(e.y,t.y),x2:Math.max(e.x2,t.x2),y2:Math.max(e.y2,t.y2)}),pn=({x:e,y:t,width:n,height:o})=>({x:e,y:t,x2:e+n,y2:t+o}),Xt=({x:e,y:t,x2:n,y2:o})=>({x:e,y:t,width:n-e,height:o-t}),Xe=(e,t=[0,0])=>{const{x:n,y:o}=In(e)?e.internals.positionAbsolute:dt(e,t);return{x:n,y:o,width:e.measured?.width??e.width??e.initialWidth??0,height:e.measured?.height??e.height??e.initialHeight??0}},zt=(e,t=[0,0])=>{const{x:n,y:o}=In(e)?e.internals.positionAbsolute:dt(e,t);return{x:n,y:o,x2:n+(e.measured?.width??e.width??e.initialWidth??0),y2:o+(e.measured?.height??e.height??e.initialHeight??0)}},Dr=(e,t)=>Xt(Ft(pn(e),pn(t))),at=(e,t)=>{const n=Math.max(0,Math.min(e.x+e.width,t.x+t.width)-Math.max(e.x,t.x)),o=Math.max(0,Math.min(e.y+e.height,t.y+t.height)-Math.max(e.y,t.y));return Math.ceil(n*o)},co=e=>fe(e.width)&&fe(e.height)&&fe(e.x)&&fe(e.y),fe=e=>!isNaN(e)&&isFinite(e),xu=(e,t)=>{},ht=(e,t=[1,1])=>({x:t[0]*Math.round(e.x/t[0]),y:t[1]*Math.round(e.y/t[1])}),gt=({x:e,y:t},[n,o,r],s=!1,i=[1,1])=>{const a={x:(e-n)/r,y:(t-o)/r};return s?ht(a,i):a},$t=({x:e,y:t},[n,o,r])=>({x:e*r+n,y:t*r+o});function He(e,t){if(typeof e=="number")return Math.floor((t-t/(1+e))*.5);if(typeof e=="string"&&e.endsWith("px")){const n=parseFloat(e);if(!Number.isNaN(n))return Math.floor(n)}if(typeof e=="string"&&e.endsWith("%")){const n=parseFloat(e);if(!Number.isNaN(n))return Math.floor(t*n*.01)}return console.error(`[React Flow] The padding value "${e}" is invalid. Please provide a number or a string with a valid unit (px or %).`),0}function wu(e,t,n){if(typeof e=="string"||typeof e=="number"){const o=He(e,n),r=He(e,t);return{top:o,right:r,bottom:o,left:r,x:r*2,y:o*2}}if(typeof e=="object"){const o=He(e.top??e.y??0,n),r=He(e.bottom??e.y??0,n),s=He(e.left??e.x??0,t),i=He(e.right??e.x??0,t);return{top:o,right:i,bottom:r,left:s,x:s+i,y:o+r}}return{top:0,right:0,bottom:0,left:0,x:0,y:0}}function vu(e,t,n,o,r,s){const{x:i,y:a}=$t(e,[t,n,o]),{x:c,y:l}=$t({x:e.x+e.width,y:e.y+e.height},[t,n,o]),u=r-c,f=s-l;return{left:Math.floor(i),top:Math.floor(a),right:Math.floor(u),bottom:Math.floor(f)}}const An=(e,t,n,o,r,s)=>{const i=wu(s,t,n),a=(t-i.x)/e.width,c=(n-i.y)/e.height,l=Math.min(a,c),u=Fe(l,o,r),f=e.x+e.width/2,d=e.y+e.height/2,g=t/2-f*u,p=n/2-d*u,x=vu(e,g,p,u,t,n),w={left:Math.min(x.left-i.left,0),top:Math.min(x.top-i.top,0),right:Math.min(x.right-i.right,0),bottom:Math.min(x.bottom-i.bottom,0)};return{x:g-w.left+w.right,y:p-w.top+w.bottom,zoom:u}},ct=()=>typeof navigator<"u"&&navigator?.userAgent?.indexOf("Mac")>=0;function Ye(e){return e!=null&&e!=="parent"}function _e(e){return{width:e.measured?.width??e.width??e.initialWidth??0,height:e.measured?.height??e.height??e.initialHeight??0}}function Tr(e){return(e.measured?.width??e.width??e.initialWidth)!==void 0&&(e.measured?.height??e.height??e.initialHeight)!==void 0}function zr(e,t={width:0,height:0},n,o,r){const s={...e},i=o.get(n);if(i){const a=i.origin||r;s.x+=i.internals.positionAbsolute.x-(t.width??0)*a[0],s.y+=i.internals.positionAbsolute.y-(t.height??0)*a[1]}return s}function lo(e,t){if(e.size!==t.size)return!1;for(const n of e)if(!t.has(n))return!1;return!0}function _u(){let e,t;return{promise:new Promise((o,r)=>{e=o,t=r}),resolve:e,reject:t}}function bu(e){return{...Nr,...e||{}}}function tt(e,{snapGrid:t=[0,0],snapToGrid:n=!1,transform:o,containerBounds:r}){const{x:s,y:i}=he(e),a=gt({x:s-(r?.left??0),y:i-(r?.top??0)},o),{x:c,y:l}=n?ht(a,t):a;return{xSnapped:c,ySnapped:l,...a}}const Pn=e=>({width:e.offsetWidth,height:e.offsetHeight}),$r=e=>e?.getRootNode?.()||window?.document,Eu=["INPUT","SELECT","TEXTAREA"];function Hr(e){const t=e.composedPath?.()?.[0]||e.target;return t?.nodeType!==1?!1:Eu.includes(t.nodeName)||t.hasAttribute("contenteditable")||!!t.closest(".nokey")}const Lr=e=>"clientX"in e,he=(e,t)=>{const n=Lr(e),o=n?e.clientX:e.touches?.[0].clientX,r=n?e.clientY:e.touches?.[0].clientY;return{x:o-(t?.left??0),y:r-(t?.top??0)}},uo=(e,t,n,o,r)=>{const s=t.querySelectorAll(`.${e}`);return!s||!s.length?null:Array.from(s).map(i=>{const a=i.getBoundingClientRect();return{id:i.getAttribute("data-handleid"),type:e,nodeId:r,position:i.getAttribute("data-handlepos"),x:(a.left-n.left)/o,y:(a.top-n.top)/o,...Pn(i)}})};function Rr({sourceX:e,sourceY:t,targetX:n,targetY:o,sourceControlX:r,sourceControlY:s,targetControlX:i,targetControlY:a}){const c=e*.125+r*.375+i*.375+n*.125,l=t*.125+s*.375+a*.375+o*.125,u=Math.abs(c-e),f=Math.abs(l-t);return[c,l,u,f]}function wt(e,t){return e>=0?.5*e:t*25*Math.sqrt(-e)}function fo({pos:e,x1:t,y1:n,x2:o,y2:r,c:s}){switch(e){case X.Left:return[t-wt(t-o,s),n];case X.Right:return[t+wt(o-t,s),n];case X.Top:return[t,n-wt(n-r,s)];case X.Bottom:return[t,n+wt(r-n,s)]}}function jr({sourceX:e,sourceY:t,sourcePosition:n=X.Bottom,targetX:o,targetY:r,targetPosition:s=X.Top,curvature:i=.25}){const[a,c]=fo({pos:n,x1:e,y1:t,x2:o,y2:r,c:i}),[l,u]=fo({pos:s,x1:o,y1:r,x2:e,y2:t,c:i}),[f,d,g,p]=Rr({sourceX:e,sourceY:t,targetX:o,targetY:r,sourceControlX:a,sourceControlY:c,targetControlX:l,targetControlY:u});return[`M${e},${t} C${a},${c} ${l},${u} ${o},${r}`,f,d,g,p]}function Vr({sourceX:e,sourceY:t,targetX:n,targetY:o}){const r=Math.abs(n-e)/2,s=n<e?n+r:n-r,i=Math.abs(o-t)/2,a=o<t?o+i:o-i;return[s,a,r,i]}function Su({sourceNode:e,targetNode:t,selected:n=!1,zIndex:o=0,elevateOnSelect:r=!1,zIndexMode:s="basic"}){if(s==="manual")return o;const i=r&&n?o+1e3:o,a=Math.max(e.parentId||r&&e.selected?e.internals.z:0,t.parentId||r&&t.selected?t.internals.z:0);return i+a}function Nu({sourceNode:e,targetNode:t,width:n,height:o,transform:r}){const s=Ft(zt(e),zt(t));s.x===s.x2&&(s.x2+=1),s.y===s.y2&&(s.y2+=1);const i={x:-r[0]/r[2],y:-r[1]/r[2],width:n/r[2],height:o/r[2]};return at(i,Xt(s))>0}const Cu=({source:e,sourceHandle:t,target:n,targetHandle:o})=>`xy-edge__${e}${t||""}-${n}${o||""}`,Mu=(e,t)=>t.some(n=>n.source===e.source&&n.target===e.target&&(n.sourceHandle===e.sourceHandle||!n.sourceHandle&&!e.sourceHandle)&&(n.targetHandle===e.targetHandle||!n.targetHandle&&!e.targetHandle)),Iu=(e,t,n={})=>{if(!e.source||!e.target)return t;const o=n.getEdgeId||Cu;let r;return Ir(e)?r={...e}:r={...e,id:o(e)},Mu(r,t)?t:(r.sourceHandle===null&&delete r.sourceHandle,r.targetHandle===null&&delete r.targetHandle,t.concat(r))};function Or({sourceX:e,sourceY:t,targetX:n,targetY:o}){const[r,s,i,a]=Vr({sourceX:e,sourceY:t,targetX:n,targetY:o});return[`M ${e},${t}L ${n},${o}`,r,s,i,a]}const ho={[X.Left]:{x:-1,y:0},[X.Right]:{x:1,y:0},[X.Top]:{x:0,y:-1},[X.Bottom]:{x:0,y:1}},ku=({source:e,sourcePosition:t=X.Bottom,target:n})=>t===X.Left||t===X.Right?e.x<n.x?{x:1,y:0}:{x:-1,y:0}:e.y<n.y?{x:0,y:1}:{x:0,y:-1},go=(e,t)=>Math.sqrt(Math.pow(t.x-e.x,2)+Math.pow(t.y-e.y,2));function Au({source:e,sourcePosition:t=X.Bottom,target:n,targetPosition:o=X.Top,center:r,offset:s,stepPosition:i}){const a=ho[t],c=ho[o],l={x:e.x+a.x*s,y:e.y+a.y*s},u={x:n.x+c.x*s,y:n.y+c.y*s},f=ku({source:l,sourcePosition:t,target:u}),d=f.x!==0?"x":"y",g=f[d];let p=[],x,w;const m={x:0,y:0},b={x:0,y:0},[,,h,y]=Vr({sourceX:e.x,sourceY:e.y,targetX:n.x,targetY:n.y});if(a[d]*c[d]===-1){d==="x"?(x=r.x??l.x+(u.x-l.x)*i,w=r.y??(l.y+u.y)/2):(x=r.x??(l.x+u.x)/2,w=r.y??l.y+(u.y-l.y)*i);const E=[{x,y:l.y},{x,y:u.y}],C=[{x:l.x,y:w},{x:u.x,y:w}];a[d]===g?p=d==="x"?E:C:p=d==="x"?C:E}else{const E=[{x:l.x,y:u.y}],C=[{x:u.x,y:l.y}];if(d==="x"?p=a.x===g?C:E:p=a.y===g?E:C,t===o){const z=Math.abs(e[d]-n[d]);if(z<=s){const H=Math.min(s-1,s-z);a[d]===g?m[d]=(l[d]>e[d]?-1:1)*H:b[d]=(u[d]>n[d]?-1:1)*H}}if(t!==o){const z=d==="x"?"y":"x",H=a[d]===c[z],v=l[z]>u[z],M=l[z]<u[z];(a[d]===1&&(!H&&v||H&&M)||a[d]!==1&&(!H&&M||H&&v))&&(p=d==="x"?E:C)}const P={x:l.x+m.x,y:l.y+m.y},D={x:u.x+b.x,y:u.y+b.y},V=Math.max(Math.abs(P.x-p[0].x),Math.abs(D.x-p[0].x)),I=Math.max(Math.abs(P.y-p[0].y),Math.abs(D.y-p[0].y));V>=I?(x=(P.x+D.x)/2,w=p[0].y):(x=p[0].x,w=(P.y+D.y)/2)}return[[e,{x:l.x+m.x,y:l.y+m.y},...p,{x:u.x+b.x,y:u.y+b.y},n],x,w,h,y]}function Pu(e,t,n,o){const r=Math.min(go(e,t)/2,go(t,n)/2,o),{x:s,y:i}=t;if(e.x===s&&s===n.x||e.y===i&&i===n.y)return`L${s} ${i}`;if(e.y===i){const l=e.x<n.x?-1:1,u=e.y<n.y?1:-1;return`L ${s+r*l},${i}Q ${s},${i} ${s},${i+r*u}`}const a=e.x<n.x?1:-1,c=e.y<n.y?-1:1;return`L ${s},${i+r*c}Q ${s},${i} ${s+r*a},${i}`}function mn({sourceX:e,sourceY:t,sourcePosition:n=X.Bottom,targetX:o,targetY:r,targetPosition:s=X.Top,borderRadius:i=5,centerX:a,centerY:c,offset:l=20,stepPosition:u=.5}){const[f,d,g,p,x]=Au({source:{x:e,y:t},sourcePosition:n,target:{x:o,y:r},targetPosition:s,center:{x:a,y:c},offset:l,stepPosition:u});return[f.reduce((m,b,h)=>{let y="";return h>0&&h<f.length-1?y=Pu(f[h-1],b,f[h+1],i):y=`${h===0?"M":"L"}${b.x} ${b.y}`,m+=y,m},""),d,g,p,x]}function po(e){return e&&!!(e.internals.handleBounds||e.handles?.length)&&!!(e.measured.width||e.width||e.initialWidth)}function Du(e){const{sourceNode:t,targetNode:n}=e;if(!po(t)||!po(n))return null;const o=t.internals.handleBounds||mo(t.handles),r=n.internals.handleBounds||mo(n.handles),s=yo(o?.source??[],e.sourceHandle),i=yo(e.connectionMode===Be.Strict?r?.target??[]:(r?.target??[]).concat(r?.source??[]),e.targetHandle);if(!s||!i)return e.onError?.("008",pe.error008(s?"target":"source",{id:e.id,sourceHandle:e.sourceHandle,targetHandle:e.targetHandle})),null;const a=s?.position||X.Bottom,c=i?.position||X.Top,l=ze(t,s,a),u=ze(n,i,c);return{sourceX:l.x,sourceY:l.y,targetX:u.x,targetY:u.y,sourcePosition:a,targetPosition:c}}function mo(e){if(!e)return null;const t=[],n=[];for(const o of e)o.width=o.width??1,o.height=o.height??1,o.type==="source"?t.push(o):o.type==="target"&&n.push(o);return{source:t,target:n}}function ze(e,t,n=X.Left,o=!1){const r=(t?.x??0)+e.internals.positionAbsolute.x,s=(t?.y??0)+e.internals.positionAbsolute.y,{width:i,height:a}=t??_e(e);if(o)return{x:r+i/2,y:s+a/2};switch(t?.position??n){case X.Top:return{x:r+i/2,y:s};case X.Right:return{x:r+i,y:s+a/2};case X.Bottom:return{x:r+i/2,y:s+a};case X.Left:return{x:r,y:s+a/2}}}function yo(e,t){return e&&(t?e.find(n=>n.id===t):e[0])||null}function yn(e,t){return e?typeof e=="string"?e:`${t?`${t}__`:""}${Object.keys(e).sort().map(o=>`${o}=${e[o]}`).join("&")}`:""}function Tu(e,{id:t,defaultColor:n,defaultMarkerStart:o,defaultMarkerEnd:r}){const s=new Set;return e.reduce((i,a)=>([a.markerStart||o,a.markerEnd||r].forEach(c=>{if(c&&typeof c=="object"){const l=yn(c,t);s.has(l)||(i.push({id:l,color:c.color||n,...c}),s.add(l))}}),i),[]).sort((i,a)=>i.id.localeCompare(a.id))}const Br=1e3,zu=10,Dn={nodeOrigin:[0,0],nodeExtent:it,elevateNodesOnSelect:!0,zIndexMode:"basic",defaults:{}},$u={...Dn,checkEquality:!0};function Tn(e,t){const n={...e};for(const o in t)t[o]!==void 0&&(n[o]=t[o]);return n}function Hu(e,t,n){const o=Tn(Dn,n);for(const r of e.values())if(r.parentId)$n(r,e,t,o);else{const s=dt(r,o.nodeOrigin),i=Ye(r.extent)?r.extent:o.nodeExtent,a=Te(s,i,_e(r));r.internals.positionAbsolute=a}}function Lu(e,t){if(!e.handles)return e.measured?t?.internals.handleBounds:void 0;const n=[],o=[];for(const r of e.handles){const s={id:r.id,width:r.width??1,height:r.height??1,nodeId:e.id,x:r.x,y:r.y,position:r.position,type:r.type};r.type==="source"?n.push(s):r.type==="target"&&o.push(s)}return{source:n,target:o}}function zn(e){return e==="manual"}function xn(e,t,n,o={}){const r=Tn($u,o),s={i:0},i=new Map(t),a=r?.elevateNodesOnSelect&&!zn(r.zIndexMode)?Br:0;let c=e.length>0;t.clear(),n.clear();for(const l of e){let u=i.get(l.id);if(r.checkEquality&&l===u?.internals.userNode)t.set(l.id,u);else{const f=dt(l,r.nodeOrigin),d=Ye(l.extent)?l.extent:r.nodeExtent,g=Te(f,d,_e(l));u={...r.defaults,...l,measured:{width:l.measured?.width,height:l.measured?.height},internals:{positionAbsolute:g,handleBounds:Lu(l,u),z:Fr(l,a,r.zIndexMode),userNode:l}},t.set(l.id,u)}(u.measured===void 0||u.measured.width===void 0||u.measured.height===void 0)&&!u.hidden&&(c=!1),l.parentId&&$n(u,t,n,o,s)}return c}function Ru(e,t){if(!e.parentId)return;const n=t.get(e.parentId);n?n.set(e.id,e):t.set(e.parentId,new Map([[e.id,e]]))}function $n(e,t,n,o,r){const{elevateNodesOnSelect:s,nodeOrigin:i,nodeExtent:a,zIndexMode:c}=Tn(Dn,o),l=e.parentId,u=t.get(l);if(!u){console.warn(`Parent node ${l} not found. Please make sure that parent nodes are in front of their child nodes in the nodes array.`);return}Ru(e,n),r&&!u.parentId&&u.internals.rootParentIndex===void 0&&c==="auto"&&(u.internals.rootParentIndex=++r.i,u.internals.z=u.internals.z+r.i*zu),r&&u.internals.rootParentIndex!==void 0&&(r.i=u.internals.rootParentIndex);const f=s&&!zn(c)?Br:0,{x:d,y:g,z:p}=ju(e,u,i,a,f,c),{positionAbsolute:x}=e.internals,w=d!==x.x||g!==x.y;(w||p!==e.internals.z)&&t.set(e.id,{...e,internals:{...e.internals,positionAbsolute:w?{x:d,y:g}:x,z:p}})}function Fr(e,t,n){const o=fe(e.zIndex)?e.zIndex:0;return zn(n)?o:o+(e.selected?t:0)}function ju(e,t,n,o,r,s){const{x:i,y:a}=t.internals.positionAbsolute,c=_e(e),l=dt(e,n),u=Ye(e.extent)?Te(l,e.extent,c):l;let f=Te({x:i+u.x,y:a+u.y},o,c);e.extent==="parent"&&(f=Ar(f,c,t));const d=Fr(e,r,s),g=t.internals.z??0;return{x:f.x,y:f.y,z:g>=d?g+1:d}}function Hn(e,t,n,o=[0,0]){const r=[],s=new Map;for(const i of e){const a=t.get(i.parentId);if(!a)continue;const c=s.get(i.parentId)?.expandedRect??Xe(a),l=Dr(c,i.rect);s.set(i.parentId,{expandedRect:l,parent:a})}return s.size>0&&s.forEach(({expandedRect:i,parent:a},c)=>{const l=a.internals.positionAbsolute,u=_e(a),f=a.origin??o,d=i.x<l.x?Math.round(Math.abs(l.x-i.x)):0,g=i.y<l.y?Math.round(Math.abs(l.y-i.y)):0,p=Math.max(u.width,Math.round(i.width)),x=Math.max(u.height,Math.round(i.height)),w=(p-u.width)*f[0],m=(x-u.height)*f[1];(d>0||g>0||w||m)&&(r.push({id:c,type:"position",position:{x:a.position.x-d+w,y:a.position.y-g+m}}),n.get(c)?.forEach(b=>{e.some(h=>h.id===b.id)||r.push({id:b.id,type:"position",position:{x:b.position.x+d,y:b.position.y+g}})})),(u.width<i.width||u.height<i.height||d||g)&&r.push({id:c,type:"dimensions",setAttributes:!0,dimensions:{width:p+(d?f[0]*d-w:0),height:x+(g?f[1]*g-m:0)}})}),r}function Vu(e,t,n,o,r,s,i){const a=o?.querySelector(".xyflow__viewport");let c=!1;if(!a)return{changes:[],updatedInternals:c};const l=[],u=window.getComputedStyle(a),{m22:f}=new window.DOMMatrixReadOnly(u.transform),d=[];for(const g of e.values()){const p=t.get(g.id);if(!p)continue;if(p.hidden){t.set(p.id,{...p,internals:{...p.internals,handleBounds:void 0}}),c=!0;continue}const x=Pn(g.nodeElement),w=p.measured.width!==x.width||p.measured.height!==x.height;if(!!(x.width&&x.height&&(w||!p.internals.handleBounds||g.force))){const b=g.nodeElement.getBoundingClientRect(),h=Ye(p.extent)?p.extent:s;let{positionAbsolute:y}=p.internals;p.parentId&&p.extent==="parent"?y=Ar(y,x,t.get(p.parentId)):h&&(y=Te(y,h,x));const S={...p,measured:x,internals:{...p.internals,positionAbsolute:y,handleBounds:{source:uo("source",g.nodeElement,b,f,p.id),target:uo("target",g.nodeElement,b,f,p.id)}}};t.set(p.id,S),p.parentId&&$n(S,t,n,{nodeOrigin:r,zIndexMode:i}),c=!0,w&&(l.push({id:p.id,type:"dimensions",dimensions:x}),p.expandParent&&p.parentId&&d.push({id:p.id,parentId:p.parentId,rect:Xe(S,r)}))}}if(d.length>0){const g=Hn(d,t,n,r);l.push(...g)}return{changes:l,updatedInternals:c}}async function Ou({delta:e,panZoom:t,transform:n,translateExtent:o,width:r,height:s}){if(!t||!e.x&&!e.y)return Promise.resolve(!1);const i=await t.setViewportConstrained({x:n[0]+e.x,y:n[1]+e.y,zoom:n[2]},[[0,0],[r,s]],o),a=!!i&&(i.x!==n[0]||i.y!==n[1]||i.k!==n[2]);return Promise.resolve(a)}function xo(e,t,n,o,r,s){let i=r;const a=o.get(i)||new Map;o.set(i,a.set(n,t)),i=`${r}-${e}`;const c=o.get(i)||new Map;if(o.set(i,c.set(n,t)),s){i=`${r}-${e}-${s}`;const l=o.get(i)||new Map;o.set(i,l.set(n,t))}}function Xr(e,t,n){e.clear(),t.clear();for(const o of n){const{source:r,target:s,sourceHandle:i=null,targetHandle:a=null}=o,c={edgeId:o.id,source:r,target:s,sourceHandle:i,targetHandle:a},l=`${r}-${i}--${s}-${a}`,u=`${s}-${a}--${r}-${i}`;xo("source",c,u,e,r,i),xo("target",c,l,e,s,a),t.set(o.id,o)}}function Yr(e,t){if(!e.parentId)return!1;const n=t.get(e.parentId);return n?n.selected?!0:Yr(n,t):!1}function wo(e,t,n){let o=e;do{if(o?.matches?.(t))return!0;if(o===n)return!1;o=o?.parentElement}while(o);return!1}function Bu(e,t,n,o){const r=new Map;for(const[s,i]of e)if((i.selected||i.id===o)&&(!i.parentId||!Yr(i,e))&&(i.draggable||t&&typeof i.draggable>"u")){const a=e.get(s);a&&r.set(s,{id:s,position:a.position||{x:0,y:0},distance:{x:n.x-a.internals.positionAbsolute.x,y:n.y-a.internals.positionAbsolute.y},extent:a.extent,parentId:a.parentId,origin:a.origin,expandParent:a.expandParent,internals:{positionAbsolute:a.internals.positionAbsolute||{x:0,y:0}},measured:{width:a.measured.width??0,height:a.measured.height??0}})}return r}function on({nodeId:e,dragItems:t,nodeLookup:n,dragging:o=!0}){const r=[];for(const[i,a]of t){const c=n.get(i)?.internals.userNode;c&&r.push({...c,position:a.position,dragging:o})}if(!e)return[r[0],r];const s=n.get(e)?.internals.userNode;return[s?{...s,position:t.get(e)?.position||s.position,dragging:o}:r[0],r]}function Fu({dragItems:e,snapGrid:t,x:n,y:o}){const r=e.values().next().value;if(!r)return null;const s={x:n-r.distance.x,y:o-r.distance.y},i=ht(s,t);return{x:i.x-s.x,y:i.y-s.y}}function Xu({onNodeMouseDown:e,getStoreItems:t,onDragStart:n,onDrag:o,onDragStop:r}){let s={x:null,y:null},i=0,a=new Map,c=!1,l={x:0,y:0},u=null,f=!1,d=null,g=!1,p=!1,x=null;function w({noDragClassName:b,handleSelector:h,domNode:y,isSelectable:S,nodeId:E,nodeClickDistance:C=0}){d=ce(y);function P({x:z,y:H}){const{nodeLookup:v,nodeExtent:M,snapGrid:N,snapToGrid:A,nodeOrigin:k,onNodeDrag:T,onSelectionDrag:L,onError:j,updateNodePositions:R}=t();s={x:z,y:H};let F=!1;const B=a.size>1,W=B&&M?pn(ft(a)):null,K=B&&A?Fu({dragItems:a,snapGrid:N,x:z,y:H}):null;for(const[Z,O]of a){if(!v.has(Z))continue;let Y={x:z-O.distance.x,y:H-O.distance.y};A&&(Y=K?{x:Math.round(Y.x+K.x),y:Math.round(Y.y+K.y)}:ht(Y,N));let Q=null;if(B&&M&&!O.extent&&W){const{positionAbsolute:G}=O.internals,ee=G.x-W.x+M[0][0],ne=G.x+O.measured.width-W.x2+M[1][0],te=G.y-W.y+M[0][1],ae=G.y+O.measured.height-W.y2+M[1][1];Q=[[ee,te],[ne,ae]]}const{position:U,positionAbsolute:q}=kr({nodeId:Z,nextPosition:Y,nodeLookup:v,nodeExtent:Q||M,nodeOrigin:k,onError:j});F=F||O.position.x!==U.x||O.position.y!==U.y,O.position=U,O.internals.positionAbsolute=q}if(p=p||F,!!F&&(R(a,!0),x&&(o||T||!E&&L))){const[Z,O]=on({nodeId:E,dragItems:a,nodeLookup:v});o?.(x,a,Z,O),T?.(x,Z,O),E||L?.(x,O)}}async function D(){if(!u)return;const{transform:z,panBy:H,autoPanSpeed:v,autoPanOnNodeDrag:M}=t();if(!M){c=!1,cancelAnimationFrame(i);return}const[N,A]=Pr(l,u,v);(N!==0||A!==0)&&(s.x=(s.x??0)-N/z[2],s.y=(s.y??0)-A/z[2],await H({x:N,y:A})&&P(s)),i=requestAnimationFrame(D)}function V(z){const{nodeLookup:H,multiSelectionActive:v,nodesDraggable:M,transform:N,snapGrid:A,snapToGrid:k,selectNodesOnDrag:T,onNodeDragStart:L,onSelectionDragStart:j,unselectNodesAndEdges:R}=t();f=!0,(!T||!S)&&!v&&E&&(H.get(E)?.selected||R()),S&&T&&E&&e?.(E);const F=tt(z.sourceEvent,{transform:N,snapGrid:A,snapToGrid:k,containerBounds:u});if(s=F,a=Bu(H,M,F,E),a.size>0&&(n||L||!E&&j)){const[B,W]=on({nodeId:E,dragItems:a,nodeLookup:H});n?.(z.sourceEvent,a,B,W),L?.(z.sourceEvent,B,W),E||j?.(z.sourceEvent,W)}}const I=fr().clickDistance(C).on("start",z=>{const{domNode:H,nodeDragThreshold:v,transform:M,snapGrid:N,snapToGrid:A}=t();u=H?.getBoundingClientRect()||null,g=!1,p=!1,x=z.sourceEvent,v===0&&V(z),s=tt(z.sourceEvent,{transform:M,snapGrid:N,snapToGrid:A,containerBounds:u}),l=he(z.sourceEvent,u)}).on("drag",z=>{const{autoPanOnNodeDrag:H,transform:v,snapGrid:M,snapToGrid:N,nodeDragThreshold:A,nodeLookup:k}=t(),T=tt(z.sourceEvent,{transform:v,snapGrid:M,snapToGrid:N,containerBounds:u});if(x=z.sourceEvent,(z.sourceEvent.type==="touchmove"&&z.sourceEvent.touches.length>1||E&&!k.has(E))&&(g=!0),!g){if(!c&&H&&f&&(c=!0,D()),!f){const L=he(z.sourceEvent,u),j=L.x-l.x,R=L.y-l.y;Math.sqrt(j*j+R*R)>A&&V(z)}(s.x!==T.xSnapped||s.y!==T.ySnapped)&&a&&f&&(l=he(z.sourceEvent,u),P(T))}}).on("end",z=>{if(!(!f||g)&&(c=!1,f=!1,cancelAnimationFrame(i),a.size>0)){const{nodeLookup:H,updateNodePositions:v,onNodeDragStop:M,onSelectionDragStop:N}=t();if(p&&(v(a,!1),p=!1),r||M||!E&&N){const[A,k]=on({nodeId:E,dragItems:a,nodeLookup:H,dragging:!1});r?.(z.sourceEvent,a,A,k),M?.(z.sourceEvent,A,k),E||N?.(z.sourceEvent,k)}}}).filter(z=>{const H=z.target;return!z.button&&(!b||!wo(H,`.${b}`,y))&&(!h||wo(H,h,y))});d.call(I)}function m(){d?.on(".drag",null)}return{update:w,destroy:m}}function Yu(e,t,n){const o=[],r={x:e.x-n,y:e.y-n,width:n*2,height:n*2};for(const s of t.values())at(r,Xe(s))>0&&o.push(s);return o}const Zu=250;function Wu(e,t,n,o){let r=[],s=1/0;const i=Yu(e,n,t+Zu);for(const a of i){const c=[...a.internals.handleBounds?.source??[],...a.internals.handleBounds?.target??[]];for(const l of c){if(o.nodeId===l.nodeId&&o.type===l.type&&o.id===l.id)continue;const{x:u,y:f}=ze(a,l,l.position,!0),d=Math.sqrt(Math.pow(u-e.x,2)+Math.pow(f-e.y,2));d>t||(d<s?(r=[{...l,x:u,y:f}],s=d):d===s&&r.push({...l,x:u,y:f}))}}if(!r.length)return null;if(r.length>1){const a=o.type==="source"?"target":"source";return r.find(c=>c.type===a)??r[0]}return r[0]}function Zr(e,t,n,o,r,s=!1){const i=o.get(e);if(!i)return null;const a=r==="strict"?i.internals.handleBounds?.[t]:[...i.internals.handleBounds?.source??[],...i.internals.handleBounds?.target??[]],c=(n?a?.find(l=>l.id===n):a?.[0])??null;return c&&s?{...c,...ze(i,c,c.position,!0)}:c}function Wr(e,t){return e||(t?.classList.contains("target")?"target":t?.classList.contains("source")?"source":null)}function qu(e,t){let n=null;return t?n=!0:e&&!t&&(n=!1),n}const qr=()=>!0;function Gu(e,{connectionMode:t,connectionRadius:n,handleId:o,nodeId:r,edgeUpdaterType:s,isTarget:i,domNode:a,nodeLookup:c,lib:l,autoPanOnConnect:u,flowId:f,panBy:d,cancelConnection:g,onConnectStart:p,onConnect:x,onConnectEnd:w,isValidConnection:m=qr,onReconnectEnd:b,updateConnection:h,getTransform:y,getFromHandle:S,autoPanSpeed:E,dragThreshold:C=1,handleDomNode:P}){const D=$r(e.target);let V=0,I;const{x:z,y:H}=he(e),v=Wr(s,P),M=a?.getBoundingClientRect();let N=!1;if(!M||!v)return;const A=Zr(r,v,o,c,t);if(!A)return;let k=he(e,M),T=!1,L=null,j=!1,R=null;function F(){if(!u||!M)return;const[U,q]=Pr(k,M,E);d({x:U,y:q}),V=requestAnimationFrame(F)}const B={...A,nodeId:r,type:v,position:A.position},W=c.get(r);let Z={inProgress:!0,isValid:null,from:ze(W,B,X.Left,!0),fromHandle:B,fromPosition:B.position,fromNode:W,to:k,toHandle:null,toPosition:so[B.position],toNode:null,pointer:k};function O(){N=!0,h(Z),p?.(e,{nodeId:r,handleId:o,handleType:v})}C===0&&O();function Y(U){if(!N){const{x:ae,y:be}=he(U),ye=ae-z,Ie=be-H;if(!(ye*ye+Ie*Ie>C*C))return;O()}if(!S()||!B){Q(U);return}const q=y();k=he(U,M),I=Wu(gt(k,q,!1,[1,1]),n,c,B),T||(F(),T=!0);const G=Gr(U,{handle:I,connectionMode:t,fromNodeId:r,fromHandleId:o,fromType:i?"target":"source",isValidConnection:m,doc:D,lib:l,flowId:f,nodeLookup:c});R=G.handleDomNode,L=G.connection,j=qu(!!I,G.isValid);const ee=c.get(r),ne=ee?ze(ee,B,X.Left,!0):Z.from,te={...Z,from:ne,isValid:j,to:G.toHandle&&j?$t({x:G.toHandle.x,y:G.toHandle.y},q):k,toHandle:G.toHandle,toPosition:j&&G.toHandle?G.toHandle.position:so[B.position],toNode:G.toHandle?c.get(G.toHandle.nodeId):null,pointer:k};h(te),Z=te}function Q(U){if(!("touches"in U&&U.touches.length>0)){if(N){(I||R)&&L&&j&&x?.(L);const{inProgress:q,...G}=Z,ee={...G,toPosition:Z.toHandle?Z.toPosition:null};w?.(U,ee),s&&b?.(U,ee)}g(),cancelAnimationFrame(V),T=!1,j=!1,L=null,R=null,D.removeEventListener("mousemove",Y),D.removeEventListener("mouseup",Q),D.removeEventListener("touchmove",Y),D.removeEventListener("touchend",Q)}}D.addEventListener("mousemove",Y),D.addEventListener("mouseup",Q),D.addEventListener("touchmove",Y),D.addEventListener("touchend",Q)}function Gr(e,{handle:t,connectionMode:n,fromNodeId:o,fromHandleId:r,fromType:s,doc:i,lib:a,flowId:c,isValidConnection:l=qr,nodeLookup:u}){const f=s==="target",d=t?i.querySelector(`.${a}-flow__handle[data-id="${c}-${t?.nodeId}-${t?.id}-${t?.type}"]`):null,{x:g,y:p}=he(e),x=i.elementFromPoint(g,p),w=x?.classList.contains(`${a}-flow__handle`)?x:d,m={handleDomNode:w,isValid:!1,connection:null,toHandle:null};if(w){const b=Wr(void 0,w),h=w.getAttribute("data-nodeid"),y=w.getAttribute("data-handleid"),S=w.classList.contains("connectable"),E=w.classList.contains("connectableend");if(!h||!b)return m;const C={source:f?h:o,sourceHandle:f?y:r,target:f?o:h,targetHandle:f?r:y};m.connection=C;const D=S&&E&&(n===Be.Strict?f&&b==="source"||!f&&b==="target":h!==o||y!==r);m.isValid=D&&l(C),m.toHandle=Zr(h,b,y,u,n,!0)}return m}const wn={onPointerDown:Gu,isValid:Gr};function Ku({domNode:e,panZoom:t,getTransform:n,getViewScale:o}){const r=ce(e);function s({translateExtent:a,width:c,height:l,zoomStep:u=1,pannable:f=!0,zoomable:d=!0,inversePan:g=!1}){const p=h=>{if(h.sourceEvent.type!=="wheel"||!t)return;const y=n(),S=h.sourceEvent.ctrlKey&&ct()?10:1,E=-h.sourceEvent.deltaY*(h.sourceEvent.deltaMode===1?.05:h.sourceEvent.deltaMode?1:.002)*u,C=y[2]*Math.pow(2,E*S);t.scaleTo(C)};let x=[0,0];const w=h=>{(h.sourceEvent.type==="mousedown"||h.sourceEvent.type==="touchstart")&&(x=[h.sourceEvent.clientX??h.sourceEvent.touches[0].clientX,h.sourceEvent.clientY??h.sourceEvent.touches[0].clientY])},m=h=>{const y=n();if(h.sourceEvent.type!=="mousemove"&&h.sourceEvent.type!=="touchmove"||!t)return;const S=[h.sourceEvent.clientX??h.sourceEvent.touches[0].clientX,h.sourceEvent.clientY??h.sourceEvent.touches[0].clientY],E=[S[0]-x[0],S[1]-x[1]];x=S;const C=o()*Math.max(y[2],Math.log(y[2]))*(g?-1:1),P={x:y[0]-E[0]*C,y:y[1]-E[1]*C},D=[[0,0],[c,l]];t.setViewportConstrained({x:P.x,y:P.y,zoom:y[2]},D,a)},b=Er().on("start",w).on("zoom",f?m:null).on("zoom.wheel",d?p:null);r.call(b,{})}function i(){r.on("zoom",null)}return{update:s,destroy:i,pointer:de}}const Yt=e=>({x:e.x,y:e.y,zoom:e.k}),rn=({x:e,y:t,zoom:n})=>Bt.translate(e,t).scale(n),Le=(e,t)=>e.target.closest(`.${t}`),Kr=(e,t)=>t===2&&Array.isArray(e)&&e.includes(2),Uu=e=>((e*=2)<=1?e*e*e:(e-=2)*e*e+2)/2,sn=(e,t=0,n=Uu,o=()=>{})=>{const r=typeof t=="number"&&t>0;return r||o(),r?e.transition().duration(t).ease(n).on("end",o):e},Ur=e=>{const t=e.ctrlKey&&ct()?10:1;return-e.deltaY*(e.deltaMode===1?.05:e.deltaMode?1:.002)*t};function Qu({zoomPanValues:e,noWheelClassName:t,d3Selection:n,d3Zoom:o,panOnScrollMode:r,panOnScrollSpeed:s,zoomOnPinch:i,onPanZoomStart:a,onPanZoom:c,onPanZoomEnd:l}){return u=>{if(Le(u,t))return u.ctrlKey&&u.preventDefault(),!1;u.preventDefault(),u.stopImmediatePropagation();const f=n.property("__zoom").k||1;if(u.ctrlKey&&i){const w=de(u),m=Ur(u),b=f*Math.pow(2,m);o.scaleTo(n,b,w,u);return}const d=u.deltaMode===1?20:1;let g=r===Pe.Vertical?0:u.deltaX*d,p=r===Pe.Horizontal?0:u.deltaY*d;!ct()&&u.shiftKey&&r!==Pe.Vertical&&(g=u.deltaY*d,p=0),o.translateBy(n,-(g/f)*s,-(p/f)*s,{internal:!0});const x=Yt(n.property("__zoom"));clearTimeout(e.panScrollTimeout),e.isPanScrolling?(c?.(u,x),e.panScrollTimeout=setTimeout(()=>{l?.(u,x),e.isPanScrolling=!1},150)):(e.isPanScrolling=!0,a?.(u,x))}}function Ju({noWheelClassName:e,preventScrolling:t,d3ZoomHandler:n}){return function(o,r){const s=o.type==="wheel",i=!t&&s&&!o.ctrlKey,a=Le(o,e);if(o.ctrlKey&&s&&a&&o.preventDefault(),i||a)return null;o.preventDefault(),n.call(this,o,r)}}function ed({zoomPanValues:e,onDraggingChange:t,onPanZoomStart:n}){return o=>{if(o.sourceEvent?.internal)return;const r=Yt(o.transform);e.mouseButton=o.sourceEvent?.button||0,e.isZoomingOrPanning=!0,e.prevViewport=r,o.sourceEvent?.type==="mousedown"&&t(!0),n&&n?.(o.sourceEvent,r)}}function td({zoomPanValues:e,panOnDrag:t,onPaneContextMenu:n,onTransformChange:o,onPanZoom:r}){return s=>{e.usedRightMouseButton=!!(n&&Kr(t,e.mouseButton??0)),s.sourceEvent?.sync||o([s.transform.x,s.transform.y,s.transform.k]),r&&!s.sourceEvent?.internal&&r?.(s.sourceEvent,Yt(s.transform))}}function nd({zoomPanValues:e,panOnDrag:t,panOnScroll:n,onDraggingChange:o,onPanZoomEnd:r,onPaneContextMenu:s}){return i=>{if(!i.sourceEvent?.internal&&(e.isZoomingOrPanning=!1,s&&Kr(t,e.mouseButton??0)&&!e.usedRightMouseButton&&i.sourceEvent&&s(i.sourceEvent),e.usedRightMouseButton=!1,o(!1),r)){const a=Yt(i.transform);e.prevViewport=a,clearTimeout(e.timerId),e.timerId=setTimeout(()=>{r?.(i.sourceEvent,a)},n?150:0)}}}function od({zoomActivationKeyPressed:e,zoomOnScroll:t,zoomOnPinch:n,panOnDrag:o,panOnScroll:r,zoomOnDoubleClick:s,userSelectionActive:i,noWheelClassName:a,noPanClassName:c,lib:l,connectionInProgress:u}){return f=>{const d=e||t,g=n&&f.ctrlKey,p=f.type==="wheel";if(f.button===1&&f.type==="mousedown"&&(Le(f,`${l}-flow__node`)||Le(f,`${l}-flow__edge`)))return!0;if(!o&&!d&&!r&&!s&&!n||i||u&&!p||Le(f,a)&&p||Le(f,c)&&(!p||r&&p&&!e)||!n&&f.ctrlKey&&p)return!1;if(!n&&f.type==="touchstart"&&f.touches?.length>1)return f.preventDefault(),!1;if(!d&&!r&&!g&&p||!o&&(f.type==="mousedown"||f.type==="touchstart")||Array.isArray(o)&&!o.includes(f.button)&&f.type==="mousedown")return!1;const x=Array.isArray(o)&&o.includes(f.button)||!f.button||f.button<=1;return(!f.ctrlKey||p)&&x}}function rd({domNode:e,minZoom:t,maxZoom:n,translateExtent:o,viewport:r,onPanZoom:s,onPanZoomStart:i,onPanZoomEnd:a,onDraggingChange:c}){const l={isZoomingOrPanning:!1,usedRightMouseButton:!1,prevViewport:{},mouseButton:0,timerId:void 0,panScrollTimeout:void 0,isPanScrolling:!1},u=e.getBoundingClientRect(),f=Er().scaleExtent([t,n]).translateExtent(o),d=ce(e).call(f);b({x:r.x,y:r.y,zoom:Fe(r.zoom,t,n)},[[0,0],[u.width,u.height]],o);const g=d.on("wheel.zoom"),p=d.on("dblclick.zoom");f.wheelDelta(Ur);function x(I,z){return d?new Promise(H=>{f?.interpolate(z?.interpolate==="linear"?Jt:Nt).transform(sn(d,z?.duration,z?.ease,()=>H(!0)),I)}):Promise.resolve(!1)}function w({noWheelClassName:I,noPanClassName:z,onPaneContextMenu:H,userSelectionActive:v,panOnScroll:M,panOnDrag:N,panOnScrollMode:A,panOnScrollSpeed:k,preventScrolling:T,zoomOnPinch:L,zoomOnScroll:j,zoomOnDoubleClick:R,zoomActivationKeyPressed:F,lib:B,onTransformChange:W,connectionInProgress:K,paneClickDistance:Z,selectionOnDrag:O}){v&&!l.isZoomingOrPanning&&m();const Y=M&&!F&&!v;f.clickDistance(O?1/0:!fe(Z)||Z<0?0:Z);const Q=Y?Qu({zoomPanValues:l,noWheelClassName:I,d3Selection:d,d3Zoom:f,panOnScrollMode:A,panOnScrollSpeed:k,zoomOnPinch:L,onPanZoomStart:i,onPanZoom:s,onPanZoomEnd:a}):Ju({noWheelClassName:I,preventScrolling:T,d3ZoomHandler:g});if(d.on("wheel.zoom",Q,{passive:!1}),!v){const q=ed({zoomPanValues:l,onDraggingChange:c,onPanZoomStart:i});f.on("start",q);const G=td({zoomPanValues:l,panOnDrag:N,onPaneContextMenu:!!H,onPanZoom:s,onTransformChange:W});f.on("zoom",G);const ee=nd({zoomPanValues:l,panOnDrag:N,panOnScroll:M,onPaneContextMenu:H,onPanZoomEnd:a,onDraggingChange:c});f.on("end",ee)}const U=od({zoomActivationKeyPressed:F,panOnDrag:N,zoomOnScroll:j,panOnScroll:M,zoomOnDoubleClick:R,zoomOnPinch:L,userSelectionActive:v,noPanClassName:z,noWheelClassName:I,lib:B,connectionInProgress:K});f.filter(U),R?d.on("dblclick.zoom",p):d.on("dblclick.zoom",null)}function m(){f.on("zoom",null)}async function b(I,z,H){const v=rn(I),M=f?.constrain()(v,z,H);return M&&await x(M),new Promise(N=>N(M))}async function h(I,z){const H=rn(I);return await x(H,z),new Promise(v=>v(H))}function y(I){if(d){const z=rn(I),H=d.property("__zoom");(H.k!==I.zoom||H.x!==I.x||H.y!==I.y)&&f?.transform(d,z,null,{sync:!0})}}function S(){const I=d?br(d.node()):{x:0,y:0,k:1};return{x:I.x,y:I.y,zoom:I.k}}function E(I,z){return d?new Promise(H=>{f?.interpolate(z?.interpolate==="linear"?Jt:Nt).scaleTo(sn(d,z?.duration,z?.ease,()=>H(!0)),I)}):Promise.resolve(!1)}function C(I,z){return d?new Promise(H=>{f?.interpolate(z?.interpolate==="linear"?Jt:Nt).scaleBy(sn(d,z?.duration,z?.ease,()=>H(!0)),I)}):Promise.resolve(!1)}function P(I){f?.scaleExtent(I)}function D(I){f?.translateExtent(I)}function V(I){const z=!fe(I)||I<0?0:I;f?.clickDistance(z)}return{update:w,destroy:m,setViewport:h,setViewportConstrained:b,getViewport:S,scaleTo:E,scaleBy:C,setScaleExtent:P,setTranslateExtent:D,syncViewport:y,setClickDistance:V}}var Ze;(function(e){e.Line="line",e.Handle="handle"})(Ze||(Ze={}));function id({width:e,prevWidth:t,height:n,prevHeight:o,affectsX:r,affectsY:s}){const i=e-t,a=n-o,c=[i>0?1:i<0?-1:0,a>0?1:a<0?-1:0];return i&&r&&(c[0]=c[0]*-1),a&&s&&(c[1]=c[1]*-1),c}function vo(e){const t=e.includes("right")||e.includes("left"),n=e.includes("bottom")||e.includes("top"),o=e.includes("left"),r=e.includes("top");return{isHorizontal:t,isVertical:n,affectsX:o,affectsY:r}}function Ee(e,t){return Math.max(0,t-e)}function Se(e,t){return Math.max(0,e-t)}function vt(e,t,n){return Math.max(0,t-e,e-n)}function _o(e,t){return e?!t:t}function sd(e,t,n,o,r,s,i,a){let{affectsX:c,affectsY:l}=t;const{isHorizontal:u,isVertical:f}=t,d=u&&f,{xSnapped:g,ySnapped:p}=n,{minWidth:x,maxWidth:w,minHeight:m,maxHeight:b}=o,{x:h,y,width:S,height:E,aspectRatio:C}=e;let P=Math.floor(u?g-e.pointerX:0),D=Math.floor(f?p-e.pointerY:0);const V=S+(c?-P:P),I=E+(l?-D:D),z=-s[0]*S,H=-s[1]*E;let v=vt(V,x,w),M=vt(I,m,b);if(i){let k=0,T=0;c&&P<0?k=Ee(h+P+z,i[0][0]):!c&&P>0&&(k=Se(h+V+z,i[1][0])),l&&D<0?T=Ee(y+D+H,i[0][1]):!l&&D>0&&(T=Se(y+I+H,i[1][1])),v=Math.max(v,k),M=Math.max(M,T)}if(a){let k=0,T=0;c&&P>0?k=Se(h+P,a[0][0]):!c&&P<0&&(k=Ee(h+V,a[1][0])),l&&D>0?T=Se(y+D,a[0][1]):!l&&D<0&&(T=Ee(y+I,a[1][1])),v=Math.max(v,k),M=Math.max(M,T)}if(r){if(u){const k=vt(V/C,m,b)*C;if(v=Math.max(v,k),i){let T=0;!c&&!l||c&&!l&&d?T=Se(y+H+V/C,i[1][1])*C:T=Ee(y+H+(c?P:-P)/C,i[0][1])*C,v=Math.max(v,T)}if(a){let T=0;!c&&!l||c&&!l&&d?T=Ee(y+V/C,a[1][1])*C:T=Se(y+(c?P:-P)/C,a[0][1])*C,v=Math.max(v,T)}}if(f){const k=vt(I*C,x,w)/C;if(M=Math.max(M,k),i){let T=0;!c&&!l||l&&!c&&d?T=Se(h+I*C+z,i[1][0])/C:T=Ee(h+(l?D:-D)*C+z,i[0][0])/C,M=Math.max(M,T)}if(a){let T=0;!c&&!l||l&&!c&&d?T=Ee(h+I*C,a[1][0])/C:T=Se(h+(l?D:-D)*C,a[0][0])/C,M=Math.max(M,T)}}}D=D+(D<0?M:-M),P=P+(P<0?v:-v),r&&(d?V>I*C?D=(_o(c,l)?-P:P)/C:P=(_o(c,l)?-D:D)*C:u?(D=P/C,l=c):(P=D*C,c=l));const N=c?h+P:h,A=l?y+D:y;return{width:S+(c?-P:P),height:E+(l?-D:D),x:s[0]*P*(c?-1:1)+N,y:s[1]*D*(l?-1:1)+A}}const Qr={width:0,height:0,x:0,y:0},ad={...Qr,pointerX:0,pointerY:0,aspectRatio:1};function cd(e){return[[0,0],[e.measured.width,e.measured.height]]}function ld(e,t,n){const o=t.position.x+e.position.x,r=t.position.y+e.position.y,s=e.measured.width??0,i=e.measured.height??0,a=n[0]*s,c=n[1]*i;return[[o-a,r-c],[o+s-a,r+i-c]]}function ud({domNode:e,nodeId:t,getStoreItems:n,onChange:o,onEnd:r}){const s=ce(e);let i={controlDirection:vo("bottom-right"),boundaries:{minWidth:0,minHeight:0,maxWidth:Number.MAX_VALUE,maxHeight:Number.MAX_VALUE},resizeDirection:void 0,keepAspectRatio:!1};function a({controlPosition:l,boundaries:u,keepAspectRatio:f,resizeDirection:d,onResizeStart:g,onResize:p,onResizeEnd:x,shouldResize:w}){let m={...Qr},b={...ad};i={boundaries:u,resizeDirection:d,keepAspectRatio:f,controlDirection:vo(l)};let h,y=null,S=[],E,C,P,D=!1;const V=fr().on("start",I=>{const{nodeLookup:z,transform:H,snapGrid:v,snapToGrid:M,nodeOrigin:N,paneDomNode:A}=n();if(h=z.get(t),!h)return;y=A?.getBoundingClientRect()??null;const{xSnapped:k,ySnapped:T}=tt(I.sourceEvent,{transform:H,snapGrid:v,snapToGrid:M,containerBounds:y});m={width:h.measured.width??0,height:h.measured.height??0,x:h.position.x??0,y:h.position.y??0},b={...m,pointerX:k,pointerY:T,aspectRatio:m.width/m.height},E=void 0,h.parentId&&(h.extent==="parent"||h.expandParent)&&(E=z.get(h.parentId),C=E&&h.extent==="parent"?cd(E):void 0),S=[],P=void 0;for(const[L,j]of z)if(j.parentId===t&&(S.push({id:L,position:{...j.position},extent:j.extent}),j.extent==="parent"||j.expandParent)){const R=ld(j,h,j.origin??N);P?P=[[Math.min(R[0][0],P[0][0]),Math.min(R[0][1],P[0][1])],[Math.max(R[1][0],P[1][0]),Math.max(R[1][1],P[1][1])]]:P=R}g?.(I,{...m})}).on("drag",I=>{const{transform:z,snapGrid:H,snapToGrid:v,nodeOrigin:M}=n(),N=tt(I.sourceEvent,{transform:z,snapGrid:H,snapToGrid:v,containerBounds:y}),A=[];if(!h)return;const{x:k,y:T,width:L,height:j}=m,R={},F=h.origin??M,{width:B,height:W,x:K,y:Z}=sd(b,i.controlDirection,N,i.boundaries,i.keepAspectRatio,F,C,P),O=B!==L,Y=W!==j,Q=K!==k&&O,U=Z!==T&&Y;if(!Q&&!U&&!O&&!Y)return;if((Q||U||F[0]===1||F[1]===1)&&(R.x=Q?K:m.x,R.y=U?Z:m.y,m.x=R.x,m.y=R.y,S.length>0)){const ne=K-k,te=Z-T;for(const ae of S)ae.position={x:ae.position.x-ne+F[0]*(B-L),y:ae.position.y-te+F[1]*(W-j)},A.push(ae)}if((O||Y)&&(R.width=O&&(!i.resizeDirection||i.resizeDirection==="horizontal")?B:m.width,R.height=Y&&(!i.resizeDirection||i.resizeDirection==="vertical")?W:m.height,m.width=R.width,m.height=R.height),E&&h.expandParent){const ne=F[0]*(R.width??0);R.x&&R.x<ne&&(m.x=ne,b.x=b.x-(R.x-ne));const te=F[1]*(R.height??0);R.y&&R.y<te&&(m.y=te,b.y=b.y-(R.y-te))}const q=id({width:m.width,prevWidth:L,height:m.height,prevHeight:j,affectsX:i.controlDirection.affectsX,affectsY:i.controlDirection.affectsY}),G={...m,direction:q};w?.(I,G)!==!1&&(D=!0,p?.(I,G),o(R,A))}).on("end",I=>{D&&(x?.(I,{...m}),r?.({...m}),D=!1)});s.call(V)}function c(){s.on(".drag",null)}return{update:a,destroy:c}}const dd={},bo=e=>{let t;const n=new Set,o=(u,f)=>{const d=typeof u=="function"?u(t):u;if(!Object.is(d,t)){const g=t;t=f??(typeof d!="object"||d===null)?d:Object.assign({},t,d),n.forEach(p=>p(t,g))}},r=()=>t,c={setState:o,getState:r,getInitialState:()=>l,subscribe:u=>(n.add(u),()=>n.delete(u)),destroy:()=>{(dd?"production":void 0)!=="production"&&console.warn("[DEPRECATED] The `destroy` method will be unsupported in a future version. Instead use unsubscribe function returned by subscribe. Everything will be garbage-collected if store is garbage-collected."),n.clear()}},l=t=e(o,r,c);return c},fd=e=>e?bo(e):bo,{useDebugValue:hd}=js,{useSyncExternalStoreWithSelector:gd}=Rs,pd=e=>e;function Jr(e,t=pd,n){const o=gd(e.subscribe,e.getState,e.getServerState||e.getInitialState,t,n);return hd(o),o}const Eo=(e,t)=>{const n=fd(e),o=(r,s=t)=>Jr(n,r,s);return Object.assign(o,n),o},md=(e,t)=>e?Eo(e,t):Eo;function oe(e,t){if(Object.is(e,t))return!0;if(typeof e!="object"||e===null||typeof t!="object"||t===null)return!1;if(e instanceof Map&&t instanceof Map){if(e.size!==t.size)return!1;for(const[o,r]of e)if(!Object.is(r,t.get(o)))return!1;return!0}if(e instanceof Set&&t instanceof Set){if(e.size!==t.size)return!1;for(const o of e)if(!t.has(o))return!1;return!0}const n=Object.keys(e);if(n.length!==Object.keys(t).length)return!1;for(const o of n)if(!Object.prototype.hasOwnProperty.call(t,o)||!Object.is(e[o],t[o]))return!1;return!0}const Zt=$.createContext(null),yd=Zt.Provider,ei=pe.error001();function J(e,t){const n=$.useContext(Zt);if(n===null)throw new Error(ei);return Jr(n,e,t)}function re(){const e=$.useContext(Zt);if(e===null)throw new Error(ei);return $.useMemo(()=>({getState:e.getState,setState:e.setState,subscribe:e.subscribe}),[e])}const So={display:"none"},xd={position:"absolute",width:1,height:1,margin:-1,border:0,padding:0,overflow:"hidden",clip:"rect(0px, 0px, 0px, 0px)",clipPath:"inset(100%)"},ti="react-flow__node-desc",ni="react-flow__edge-desc",wd="react-flow__aria-live",vd=e=>e.ariaLiveMessage,_d=e=>e.ariaLabelConfig;function bd({rfId:e}){const t=J(vd);return _.jsx("div",{id:`${wd}-${e}`,"aria-live":"assertive","aria-atomic":"true",style:xd,children:t})}function Ed({rfId:e,disableKeyboardA11y:t}){const n=J(_d);return _.jsxs(_.Fragment,{children:[_.jsx("div",{id:`${ti}-${e}`,style:So,children:t?n["node.a11yDescription.default"]:n["node.a11yDescription.keyboardDisabled"]}),_.jsx("div",{id:`${ni}-${e}`,style:So,children:n["edge.a11yDescription.default"]}),!t&&_.jsx(bd,{rfId:e})]})}const Wt=$.forwardRef(({position:e="top-left",children:t,className:n,style:o,...r},s)=>{const i=`${e}`.split("-");return _.jsx("div",{className:ie(["react-flow__panel",n,...i]),style:o,ref:s,...r,children:t})});Wt.displayName="Panel";function Sd({proOptions:e,position:t="bottom-right"}){return e?.hideAttribution?null:_.jsx(Wt,{position:t,className:"react-flow__attribution","data-message":"Please only hide this attribution when you are subscribed to React Flow Pro: https://pro.reactflow.dev",children:_.jsx("a",{href:"https://reactflow.dev",target:"_blank",rel:"noopener noreferrer","aria-label":"React Flow attribution",children:"React Flow"})})}const Nd=e=>{const t=[],n=[];for(const[,o]of e.nodeLookup)o.selected&&t.push(o.internals.userNode);for(const[,o]of e.edgeLookup)o.selected&&n.push(o);return{selectedNodes:t,selectedEdges:n}},_t=e=>e.id;function Cd(e,t){return oe(e.selectedNodes.map(_t),t.selectedNodes.map(_t))&&oe(e.selectedEdges.map(_t),t.selectedEdges.map(_t))}function Md({onSelectionChange:e}){const t=re(),{selectedNodes:n,selectedEdges:o}=J(Nd,Cd);return $.useEffect(()=>{const r={nodes:n,edges:o};e?.(r),t.getState().onSelectionChangeHandlers.forEach(s=>s(r))},[n,o,e]),null}const Id=e=>!!e.onSelectionChangeHandlers;function kd({onSelectionChange:e}){const t=J(Id);return e||t?_.jsx(Md,{onSelectionChange:e}):null}const oi=[0,0],Ad={x:0,y:0,zoom:1},Pd=["nodes","edges","defaultNodes","defaultEdges","onConnect","onConnectStart","onConnectEnd","onClickConnectStart","onClickConnectEnd","nodesDraggable","autoPanOnNodeFocus","nodesConnectable","nodesFocusable","edgesFocusable","edgesReconnectable","elevateNodesOnSelect","elevateEdgesOnSelect","minZoom","maxZoom","nodeExtent","onNodesChange","onEdgesChange","elementsSelectable","connectionMode","snapGrid","snapToGrid","translateExtent","connectOnClick","defaultEdgeOptions","fitView","fitViewOptions","onNodesDelete","onEdgesDelete","onDelete","onNodeDrag","onNodeDragStart","onNodeDragStop","onSelectionDrag","onSelectionDragStart","onSelectionDragStop","onMoveStart","onMove","onMoveEnd","noPanClassName","nodeOrigin","autoPanOnConnect","autoPanOnNodeDrag","onError","connectionRadius","isValidConnection","selectNodesOnDrag","nodeDragThreshold","connectionDragThreshold","onBeforeDelete","debug","autoPanSpeed","ariaLabelConfig","zIndexMode"],No=[...Pd,"rfId"],Dd=e=>({setNodes:e.setNodes,setEdges:e.setEdges,setMinZoom:e.setMinZoom,setMaxZoom:e.setMaxZoom,setTranslateExtent:e.setTranslateExtent,setNodeExtent:e.setNodeExtent,reset:e.reset,setDefaultNodesAndEdges:e.setDefaultNodesAndEdges}),Co={translateExtent:it,nodeOrigin:oi,minZoom:.5,maxZoom:2,elementsSelectable:!0,noPanClassName:"nopan",rfId:"1"};function Td(e){const{setNodes:t,setEdges:n,setMinZoom:o,setMaxZoom:r,setTranslateExtent:s,setNodeExtent:i,reset:a,setDefaultNodesAndEdges:c}=J(Dd,oe),l=re();$.useEffect(()=>(c(e.defaultNodes,e.defaultEdges),()=>{u.current=Co,a()}),[]);const u=$.useRef(Co);return $.useEffect(()=>{for(const f of No){const d=e[f],g=u.current[f];d!==g&&(typeof e[f]>"u"||(f==="nodes"?t(d):f==="edges"?n(d):f==="minZoom"?o(d):f==="maxZoom"?r(d):f==="translateExtent"?s(d):f==="nodeExtent"?i(d):f==="ariaLabelConfig"?l.setState({ariaLabelConfig:bu(d)}):f==="fitView"?l.setState({fitViewQueued:d}):f==="fitViewOptions"?l.setState({fitViewOptions:d}):l.setState({[f]:d})))}u.current=e},No.map(f=>e[f])),null}function Mo(){return typeof window>"u"||!window.matchMedia?null:window.matchMedia("(prefers-color-scheme: dark)")}function zd(e){const[t,n]=$.useState(e==="system"?null:e);return $.useEffect(()=>{if(e!=="system"){n(e);return}const o=Mo(),r=()=>n(o?.matches?"dark":"light");return r(),o?.addEventListener("change",r),()=>{o?.removeEventListener("change",r)}},[e]),t!==null?t:Mo()?.matches?"dark":"light"}const Io=typeof document<"u"?document:null;function lt(e=null,t={target:Io,actInsideInputWithModifier:!0}){const[n,o]=$.useState(!1),r=$.useRef(!1),s=$.useRef(new Set([])),[i,a]=$.useMemo(()=>{if(e!==null){const l=(Array.isArray(e)?e:[e]).filter(f=>typeof f=="string").map(f=>f.replace("+",`
2
- `).replace(`
3
-
4
- `,`
5
- +`).split(`
6
- `)),u=l.reduce((f,d)=>f.concat(...d),[]);return[l,u]}return[[],[]]},[e]);return $.useEffect(()=>{const c=t?.target??Io,l=t?.actInsideInputWithModifier??!0;if(e!==null){const u=g=>{if(r.current=g.ctrlKey||g.metaKey||g.shiftKey||g.altKey,(!r.current||r.current&&!l)&&Hr(g))return!1;const x=Ao(g.code,a);if(s.current.add(g[x]),ko(i,s.current,!1)){const w=g.composedPath?.()?.[0]||g.target,m=w?.nodeName==="BUTTON"||w?.nodeName==="A";t.preventDefault!==!1&&(r.current||!m)&&g.preventDefault(),o(!0)}},f=g=>{const p=Ao(g.code,a);ko(i,s.current,!0)?(o(!1),s.current.clear()):s.current.delete(g[p]),g.key==="Meta"&&s.current.clear(),r.current=!1},d=()=>{s.current.clear(),o(!1)};return c?.addEventListener("keydown",u),c?.addEventListener("keyup",f),window.addEventListener("blur",d),window.addEventListener("contextmenu",d),()=>{c?.removeEventListener("keydown",u),c?.removeEventListener("keyup",f),window.removeEventListener("blur",d),window.removeEventListener("contextmenu",d)}}},[e,o]),n}function ko(e,t,n){return e.filter(o=>n||o.length===t.size).some(o=>o.every(r=>t.has(r)))}function Ao(e,t){return t.includes(e)?"code":"key"}const $d=()=>{const e=re();return $.useMemo(()=>({zoomIn:t=>{const{panZoom:n}=e.getState();return n?n.scaleBy(1.2,{duration:t?.duration}):Promise.resolve(!1)},zoomOut:t=>{const{panZoom:n}=e.getState();return n?n.scaleBy(1/1.2,{duration:t?.duration}):Promise.resolve(!1)},zoomTo:(t,n)=>{const{panZoom:o}=e.getState();return o?o.scaleTo(t,{duration:n?.duration}):Promise.resolve(!1)},getZoom:()=>e.getState().transform[2],setViewport:async(t,n)=>{const{transform:[o,r,s],panZoom:i}=e.getState();return i?(await i.setViewport({x:t.x??o,y:t.y??r,zoom:t.zoom??s},n),Promise.resolve(!0)):Promise.resolve(!1)},getViewport:()=>{const[t,n,o]=e.getState().transform;return{x:t,y:n,zoom:o}},setCenter:async(t,n,o)=>e.getState().setCenter(t,n,o),fitBounds:async(t,n)=>{const{width:o,height:r,minZoom:s,maxZoom:i,panZoom:a}=e.getState(),c=An(t,o,r,s,i,n?.padding??.1);return a?(await a.setViewport(c,{duration:n?.duration,ease:n?.ease,interpolate:n?.interpolate}),Promise.resolve(!0)):Promise.resolve(!1)},screenToFlowPosition:(t,n={})=>{const{transform:o,snapGrid:r,snapToGrid:s,domNode:i}=e.getState();if(!i)return t;const{x:a,y:c}=i.getBoundingClientRect(),l={x:t.x-a,y:t.y-c},u=n.snapGrid??r,f=n.snapToGrid??s;return gt(l,o,f,u)},flowToScreenPosition:t=>{const{transform:n,domNode:o}=e.getState();if(!o)return t;const{x:r,y:s}=o.getBoundingClientRect(),i=$t(t,n);return{x:i.x+r,y:i.y+s}}}),[])};function ri(e,t){const n=[],o=new Map,r=[];for(const s of e)if(s.type==="add"){r.push(s);continue}else if(s.type==="remove"||s.type==="replace")o.set(s.id,[s]);else{const i=o.get(s.id);i?i.push(s):o.set(s.id,[s])}for(const s of t){const i=o.get(s.id);if(!i){n.push(s);continue}if(i[0].type==="remove")continue;if(i[0].type==="replace"){n.push({...i[0].item});continue}const a={...s};for(const c of i)Hd(c,a);n.push(a)}return r.length&&r.forEach(s=>{s.index!==void 0?n.splice(s.index,0,{...s.item}):n.push({...s.item})}),n}function Hd(e,t){switch(e.type){case"select":{t.selected=e.selected;break}case"position":{typeof e.position<"u"&&(t.position=e.position),typeof e.dragging<"u"&&(t.dragging=e.dragging);break}case"dimensions":{typeof e.dimensions<"u"&&(t.measured={...e.dimensions},e.setAttributes&&((e.setAttributes===!0||e.setAttributes==="width")&&(t.width=e.dimensions.width),(e.setAttributes===!0||e.setAttributes==="height")&&(t.height=e.dimensions.height))),typeof e.resizing=="boolean"&&(t.resizing=e.resizing);break}}}function Ld(e,t){return ri(e,t)}function Rd(e,t){return ri(e,t)}function Ae(e,t){return{id:e,type:"select",selected:t}}function Re(e,t=new Set,n=!1){const o=[];for(const[r,s]of e){const i=t.has(r);!(s.selected===void 0&&!i)&&s.selected!==i&&(n&&(s.selected=i),o.push(Ae(s.id,i)))}return o}function Po({items:e=[],lookup:t}){const n=[],o=new Map(e.map(r=>[r.id,r]));for(const[r,s]of e.entries()){const i=t.get(s.id),a=i?.internals?.userNode??i;a!==void 0&&a!==s&&n.push({id:s.id,item:s,type:"replace"}),a===void 0&&n.push({item:s,type:"add",index:r})}for(const[r]of t)o.get(r)===void 0&&n.push({id:r,type:"remove"});return n}function Do(e){return{id:e.id,type:"remove"}}const To=e=>fu(e),jd=e=>Ir(e);function ii(e){return $.forwardRef(e)}const Vd=typeof window<"u"?$.useLayoutEffect:$.useEffect;function zo(e){const[t,n]=$.useState(BigInt(0)),[o]=$.useState(()=>Od(()=>n(r=>r+BigInt(1))));return Vd(()=>{const r=o.get();r.length&&(e(r),o.reset())},[t]),o}function Od(e){let t=[];return{get:()=>t,reset:()=>{t=[]},push:n=>{t.push(n),e()}}}const si=$.createContext(null);function Bd({children:e}){const t=re(),n=$.useCallback(a=>{const{nodes:c=[],setNodes:l,hasDefaultNodes:u,onNodesChange:f,nodeLookup:d,fitViewQueued:g,onNodesChangeMiddlewareMap:p}=t.getState();let x=c;for(const m of a)x=typeof m=="function"?m(x):m;let w=Po({items:x,lookup:d});for(const m of p.values())w=m(w);u&&l(x),w.length>0?f?.(w):g&&window.requestAnimationFrame(()=>{const{fitViewQueued:m,nodes:b,setNodes:h}=t.getState();m&&h(b)})},[]),o=zo(n),r=$.useCallback(a=>{const{edges:c=[],setEdges:l,hasDefaultEdges:u,onEdgesChange:f,edgeLookup:d}=t.getState();let g=c;for(const p of a)g=typeof p=="function"?p(g):p;u?l(g):f&&f(Po({items:g,lookup:d}))},[]),s=zo(r),i=$.useMemo(()=>({nodeQueue:o,edgeQueue:s}),[]);return _.jsx(si.Provider,{value:i,children:e})}function Fd(){const e=$.useContext(si);if(!e)throw new Error("useBatchContext must be used within a BatchProvider");return e}const Xd=e=>!!e.panZoom;function Ln(){const e=$d(),t=re(),n=Fd(),o=J(Xd),r=$.useMemo(()=>{const s=f=>t.getState().nodeLookup.get(f),i=f=>{n.nodeQueue.push(f)},a=f=>{n.edgeQueue.push(f)},c=f=>{const{nodeLookup:d,nodeOrigin:g}=t.getState(),p=To(f)?f:d.get(f.id),x=p.parentId?zr(p.position,p.measured,p.parentId,d,g):p.position,w={...p,position:x,width:p.measured?.width??p.width,height:p.measured?.height??p.height};return Xe(w)},l=(f,d,g={replace:!1})=>{i(p=>p.map(x=>{if(x.id===f){const w=typeof d=="function"?d(x):d;return g.replace&&To(w)?w:{...x,...w}}return x}))},u=(f,d,g={replace:!1})=>{a(p=>p.map(x=>{if(x.id===f){const w=typeof d=="function"?d(x):d;return g.replace&&jd(w)?w:{...x,...w}}return x}))};return{getNodes:()=>t.getState().nodes.map(f=>({...f})),getNode:f=>s(f)?.internals.userNode,getInternalNode:s,getEdges:()=>{const{edges:f=[]}=t.getState();return f.map(d=>({...d}))},getEdge:f=>t.getState().edgeLookup.get(f),setNodes:i,setEdges:a,addNodes:f=>{const d=Array.isArray(f)?f:[f];n.nodeQueue.push(g=>[...g,...d])},addEdges:f=>{const d=Array.isArray(f)?f:[f];n.edgeQueue.push(g=>[...g,...d])},toObject:()=>{const{nodes:f=[],edges:d=[],transform:g}=t.getState(),[p,x,w]=g;return{nodes:f.map(m=>({...m})),edges:d.map(m=>({...m})),viewport:{x:p,y:x,zoom:w}}},deleteElements:async({nodes:f=[],edges:d=[]})=>{const{nodes:g,edges:p,onNodesDelete:x,onEdgesDelete:w,triggerNodeChanges:m,triggerEdgeChanges:b,onDelete:h,onBeforeDelete:y}=t.getState(),{nodes:S,edges:E}=await yu({nodesToRemove:f,edgesToRemove:d,nodes:g,edges:p,onBeforeDelete:y}),C=E.length>0,P=S.length>0;if(C){const D=E.map(Do);w?.(E),b(D)}if(P){const D=S.map(Do);x?.(S),m(D)}return(P||C)&&h?.({nodes:S,edges:E}),{deletedNodes:S,deletedEdges:E}},getIntersectingNodes:(f,d=!0,g)=>{const p=co(f),x=p?f:c(f),w=g!==void 0;return x?(g||t.getState().nodes).filter(m=>{const b=t.getState().nodeLookup.get(m.id);if(b&&!p&&(m.id===f.id||!b.internals.positionAbsolute))return!1;const h=Xe(w?m:b),y=at(h,x);return d&&y>0||y>=h.width*h.height||y>=x.width*x.height}):[]},isNodeIntersecting:(f,d,g=!0)=>{const x=co(f)?f:c(f);if(!x)return!1;const w=at(x,d);return g&&w>0||w>=d.width*d.height||w>=x.width*x.height},updateNode:l,updateNodeData:(f,d,g={replace:!1})=>{l(f,p=>{const x=typeof d=="function"?d(p):d;return g.replace?{...p,data:x}:{...p,data:{...p.data,...x}}},g)},updateEdge:u,updateEdgeData:(f,d,g={replace:!1})=>{u(f,p=>{const x=typeof d=="function"?d(p):d;return g.replace?{...p,data:x}:{...p,data:{...p.data,...x}}},g)},getNodesBounds:f=>{const{nodeLookup:d,nodeOrigin:g}=t.getState();return hu(f,{nodeLookup:d,nodeOrigin:g})},getHandleConnections:({type:f,id:d,nodeId:g})=>Array.from(t.getState().connectionLookup.get(`${g}-${f}${d?`-${d}`:""}`)?.values()??[]),getNodeConnections:({type:f,handleId:d,nodeId:g})=>Array.from(t.getState().connectionLookup.get(`${g}${f?d?`-${f}-${d}`:`-${f}`:""}`)?.values()??[]),fitView:async f=>{const d=t.getState().fitViewResolver??_u();return t.setState({fitViewQueued:!0,fitViewOptions:f,fitViewResolver:d}),n.nodeQueue.push(g=>[...g]),d.promise}}},[]);return $.useMemo(()=>({...r,...e,viewportInitialized:o}),[o])}const $o=e=>e.selected,Yd=typeof window<"u"?window:void 0;function Zd({deleteKeyCode:e,multiSelectionKeyCode:t}){const n=re(),{deleteElements:o}=Ln(),r=lt(e,{actInsideInputWithModifier:!1}),s=lt(t,{target:Yd});$.useEffect(()=>{if(r){const{edges:i,nodes:a}=n.getState();o({nodes:a.filter($o),edges:i.filter($o)}),n.setState({nodesSelectionActive:!1})}},[r]),$.useEffect(()=>{n.setState({multiSelectionActive:s})},[s])}function Wd(e){const t=re();$.useEffect(()=>{const n=()=>{if(!e.current||!(e.current.checkVisibility?.()??!0))return!1;const o=Pn(e.current);(o.height===0||o.width===0)&&t.getState().onError?.("004",pe.error004()),t.setState({width:o.width||500,height:o.height||500})};if(e.current){n(),window.addEventListener("resize",n);const o=new ResizeObserver(()=>n());return o.observe(e.current),()=>{window.removeEventListener("resize",n),o&&e.current&&o.unobserve(e.current)}}},[])}const qt={position:"absolute",width:"100%",height:"100%",top:0,left:0},qd=e=>({userSelectionActive:e.userSelectionActive,lib:e.lib,connectionInProgress:e.connection.inProgress});function Gd({onPaneContextMenu:e,zoomOnScroll:t=!0,zoomOnPinch:n=!0,panOnScroll:o=!1,panOnScrollSpeed:r=.5,panOnScrollMode:s=Pe.Free,zoomOnDoubleClick:i=!0,panOnDrag:a=!0,defaultViewport:c,translateExtent:l,minZoom:u,maxZoom:f,zoomActivationKeyCode:d,preventScrolling:g=!0,children:p,noWheelClassName:x,noPanClassName:w,onViewportChange:m,isControlledViewport:b,paneClickDistance:h,selectionOnDrag:y}){const S=re(),E=$.useRef(null),{userSelectionActive:C,lib:P,connectionInProgress:D}=J(qd,oe),V=lt(d),I=$.useRef();Wd(E);const z=$.useCallback(H=>{m?.({x:H[0],y:H[1],zoom:H[2]}),b||S.setState({transform:H})},[m,b]);return $.useEffect(()=>{if(E.current){I.current=rd({domNode:E.current,minZoom:u,maxZoom:f,translateExtent:l,viewport:c,onDraggingChange:N=>S.setState({paneDragging:N}),onPanZoomStart:(N,A)=>{const{onViewportChangeStart:k,onMoveStart:T}=S.getState();T?.(N,A),k?.(A)},onPanZoom:(N,A)=>{const{onViewportChange:k,onMove:T}=S.getState();T?.(N,A),k?.(A)},onPanZoomEnd:(N,A)=>{const{onViewportChangeEnd:k,onMoveEnd:T}=S.getState();T?.(N,A),k?.(A)}});const{x:H,y:v,zoom:M}=I.current.getViewport();return S.setState({panZoom:I.current,transform:[H,v,M],domNode:E.current.closest(".react-flow")}),()=>{I.current?.destroy()}}},[]),$.useEffect(()=>{I.current?.update({onPaneContextMenu:e,zoomOnScroll:t,zoomOnPinch:n,panOnScroll:o,panOnScrollSpeed:r,panOnScrollMode:s,zoomOnDoubleClick:i,panOnDrag:a,zoomActivationKeyPressed:V,preventScrolling:g,noPanClassName:w,userSelectionActive:C,noWheelClassName:x,lib:P,onTransformChange:z,connectionInProgress:D,selectionOnDrag:y,paneClickDistance:h})},[e,t,n,o,r,s,i,a,V,g,w,C,x,P,z,D,y,h]),_.jsx("div",{className:"react-flow__renderer",ref:E,style:qt,children:p})}const Kd=e=>({userSelectionActive:e.userSelectionActive,userSelectionRect:e.userSelectionRect});function Ud(){const{userSelectionActive:e,userSelectionRect:t}=J(Kd,oe);return e&&t?_.jsx("div",{className:"react-flow__selection react-flow__container",style:{width:t.width,height:t.height,transform:`translate(${t.x}px, ${t.y}px)`}}):null}const an=(e,t)=>n=>{n.target===t.current&&e?.(n)},Qd=e=>({userSelectionActive:e.userSelectionActive,elementsSelectable:e.elementsSelectable,connectionInProgress:e.connection.inProgress,dragging:e.paneDragging});function Jd({isSelecting:e,selectionKeyPressed:t,selectionMode:n=st.Full,panOnDrag:o,paneClickDistance:r,selectionOnDrag:s,onSelectionStart:i,onSelectionEnd:a,onPaneClick:c,onPaneContextMenu:l,onPaneScroll:u,onPaneMouseEnter:f,onPaneMouseMove:d,onPaneMouseLeave:g,children:p}){const x=re(),{userSelectionActive:w,elementsSelectable:m,dragging:b,connectionInProgress:h}=J(Qd,oe),y=m&&(e||w),S=$.useRef(null),E=$.useRef(),C=$.useRef(new Set),P=$.useRef(new Set),D=$.useRef(!1),V=k=>{if(D.current||h){D.current=!1;return}c?.(k),x.getState().resetSelectedElements(),x.setState({nodesSelectionActive:!1})},I=k=>{if(Array.isArray(o)&&o?.includes(2)){k.preventDefault();return}l?.(k)},z=u?k=>u(k):void 0,H=k=>{D.current&&(k.stopPropagation(),D.current=!1)},v=k=>{const{domNode:T}=x.getState();if(E.current=T?.getBoundingClientRect(),!E.current)return;const L=k.target===S.current;if(!L&&!!k.target.closest(".nokey")||!e||!(s&&L||t)||k.button!==0||!k.isPrimary)return;k.target?.setPointerCapture?.(k.pointerId),D.current=!1;const{x:F,y:B}=he(k.nativeEvent,E.current);x.setState({userSelectionRect:{width:0,height:0,startX:F,startY:B,x:F,y:B}}),L||(k.stopPropagation(),k.preventDefault())},M=k=>{const{userSelectionRect:T,transform:L,nodeLookup:j,edgeLookup:R,connectionLookup:F,triggerNodeChanges:B,triggerEdgeChanges:W,defaultEdgeOptions:K,resetSelectedElements:Z}=x.getState();if(!E.current||!T)return;const{x:O,y:Y}=he(k.nativeEvent,E.current),{startX:Q,startY:U}=T;if(!D.current){const te=t?0:r;if(Math.hypot(O-Q,Y-U)<=te)return;Z(),i?.(k)}D.current=!0;const q={startX:Q,startY:U,x:O<Q?O:Q,y:Y<U?Y:U,width:Math.abs(O-Q),height:Math.abs(Y-U)},G=C.current,ee=P.current;C.current=new Set(kn(j,q,L,n===st.Partial,!0).map(te=>te.id)),P.current=new Set;const ne=K?.selectable??!0;for(const te of C.current){const ae=F.get(te);if(ae)for(const{edgeId:be}of ae.values()){const ye=R.get(be);ye&&(ye.selectable??ne)&&P.current.add(be)}}if(!lo(G,C.current)){const te=Re(j,C.current,!0);B(te)}if(!lo(ee,P.current)){const te=Re(R,P.current);W(te)}x.setState({userSelectionRect:q,userSelectionActive:!0,nodesSelectionActive:!1})},N=k=>{k.button===0&&(k.target?.releasePointerCapture?.(k.pointerId),!w&&k.target===S.current&&x.getState().userSelectionRect&&V?.(k),x.setState({userSelectionActive:!1,userSelectionRect:null}),D.current&&(a?.(k),x.setState({nodesSelectionActive:C.current.size>0})))},A=o===!0||Array.isArray(o)&&o.includes(0);return _.jsxs("div",{className:ie(["react-flow__pane",{draggable:A,dragging:b,selection:e}]),onClick:y?void 0:an(V,S),onContextMenu:an(I,S),onWheel:an(z,S),onPointerEnter:y?void 0:f,onPointerMove:y?M:d,onPointerUp:y?N:void 0,onPointerDownCapture:y?v:void 0,onClickCapture:y?H:void 0,onPointerLeave:g,ref:S,style:qt,children:[p,_.jsx(Ud,{})]})}function vn({id:e,store:t,unselect:n=!1,nodeRef:o}){const{addSelectedNodes:r,unselectNodesAndEdges:s,multiSelectionActive:i,nodeLookup:a,onError:c}=t.getState(),l=a.get(e);if(!l){c?.("012",pe.error012(e));return}t.setState({nodesSelectionActive:!1}),l.selected?(n||l.selected&&i)&&(s({nodes:[l],edges:[]}),requestAnimationFrame(()=>o?.current?.blur())):r([e])}function ai({nodeRef:e,disabled:t=!1,noDragClassName:n,handleSelector:o,nodeId:r,isSelectable:s,nodeClickDistance:i}){const a=re(),[c,l]=$.useState(!1),u=$.useRef();return $.useEffect(()=>{u.current=Xu({getStoreItems:()=>a.getState(),onNodeMouseDown:f=>{vn({id:f,store:a,nodeRef:e})},onDragStart:()=>{l(!0)},onDragStop:()=>{l(!1)}})},[]),$.useEffect(()=>{if(t)u.current?.destroy();else if(e.current)return u.current?.update({noDragClassName:n,handleSelector:o,domNode:e.current,isSelectable:s,nodeId:r,nodeClickDistance:i}),()=>{u.current?.destroy()}},[n,o,t,s,e,r]),c}const ef=e=>t=>t.selected&&(t.draggable||e&&typeof t.draggable>"u");function ci(){const e=re();return $.useCallback(n=>{const{nodeExtent:o,snapToGrid:r,snapGrid:s,nodesDraggable:i,onError:a,updateNodePositions:c,nodeLookup:l,nodeOrigin:u}=e.getState(),f=new Map,d=ef(i),g=r?s[0]:5,p=r?s[1]:5,x=n.direction.x*g*n.factor,w=n.direction.y*p*n.factor;for(const[,m]of l){if(!d(m))continue;let b={x:m.internals.positionAbsolute.x+x,y:m.internals.positionAbsolute.y+w};r&&(b=ht(b,s));const{position:h,positionAbsolute:y}=kr({nodeId:m.id,nextPosition:b,nodeLookup:l,nodeExtent:o,nodeOrigin:u,onError:a});m.position=h,m.internals.positionAbsolute=y,f.set(m.id,m)}c(f)},[])}const Rn=$.createContext(null),tf=Rn.Provider;Rn.Consumer;const li=()=>$.useContext(Rn),nf=e=>({connectOnClick:e.connectOnClick,noPanClassName:e.noPanClassName,rfId:e.rfId}),of=(e,t,n)=>o=>{const{connectionClickStartHandle:r,connectionMode:s,connection:i}=o,{fromHandle:a,toHandle:c,isValid:l}=i,u=c?.nodeId===e&&c?.id===t&&c?.type===n;return{connectingFrom:a?.nodeId===e&&a?.id===t&&a?.type===n,connectingTo:u,clickConnecting:r?.nodeId===e&&r?.id===t&&r?.type===n,isPossibleEndHandle:s===Be.Strict?a?.type!==n:e!==a?.nodeId||t!==a?.id,connectionInProcess:!!a,clickConnectionInProcess:!!r,valid:u&&l}};function rf({type:e="source",position:t=X.Top,isValidConnection:n,isConnectable:o=!0,isConnectableStart:r=!0,isConnectableEnd:s=!0,id:i,onConnect:a,children:c,className:l,onMouseDown:u,onTouchStart:f,...d},g){const p=i||null,x=e==="target",w=re(),m=li(),{connectOnClick:b,noPanClassName:h,rfId:y}=J(nf,oe),{connectingFrom:S,connectingTo:E,clickConnecting:C,isPossibleEndHandle:P,connectionInProcess:D,clickConnectionInProcess:V,valid:I}=J(of(m,p,e),oe);m||w.getState().onError?.("010",pe.error010());const z=M=>{const{defaultEdgeOptions:N,onConnect:A,hasDefaultEdges:k}=w.getState(),T={...N,...M};if(k){const{edges:L,setEdges:j}=w.getState();j(Iu(T,L))}A?.(T),a?.(T)},H=M=>{if(!m)return;const N=Lr(M.nativeEvent);if(r&&(N&&M.button===0||!N)){const A=w.getState();wn.onPointerDown(M.nativeEvent,{handleDomNode:M.currentTarget,autoPanOnConnect:A.autoPanOnConnect,connectionMode:A.connectionMode,connectionRadius:A.connectionRadius,domNode:A.domNode,nodeLookup:A.nodeLookup,lib:A.lib,isTarget:x,handleId:p,nodeId:m,flowId:A.rfId,panBy:A.panBy,cancelConnection:A.cancelConnection,onConnectStart:A.onConnectStart,onConnectEnd:A.onConnectEnd,updateConnection:A.updateConnection,onConnect:z,isValidConnection:n||A.isValidConnection,getTransform:()=>w.getState().transform,getFromHandle:()=>w.getState().connection.fromHandle,autoPanSpeed:A.autoPanSpeed,dragThreshold:A.connectionDragThreshold})}N?u?.(M):f?.(M)},v=M=>{const{onClickConnectStart:N,onClickConnectEnd:A,connectionClickStartHandle:k,connectionMode:T,isValidConnection:L,lib:j,rfId:R,nodeLookup:F,connection:B}=w.getState();if(!m||!k&&!r)return;if(!k){N?.(M.nativeEvent,{nodeId:m,handleId:p,handleType:e}),w.setState({connectionClickStartHandle:{nodeId:m,type:e,id:p}});return}const W=$r(M.target),K=n||L,{connection:Z,isValid:O}=wn.isValid(M.nativeEvent,{handle:{nodeId:m,id:p,type:e},connectionMode:T,fromNodeId:k.nodeId,fromHandleId:k.id||null,fromType:k.type,isValidConnection:K,flowId:R,doc:W,lib:j,nodeLookup:F});O&&Z&&z(Z);const Y=structuredClone(B);delete Y.inProgress,Y.toPosition=Y.toHandle?Y.toHandle.position:null,A?.(M,Y),w.setState({connectionClickStartHandle:null})};return _.jsx("div",{"data-handleid":p,"data-nodeid":m,"data-handlepos":t,"data-id":`${y}-${m}-${p}-${e}`,className:ie(["react-flow__handle",`react-flow__handle-${t}`,"nodrag",h,l,{source:!x,target:x,connectable:o,connectablestart:r,connectableend:s,clickconnecting:C,connectingfrom:S,connectingto:E,valid:I,connectionindicator:o&&(!D||P)&&(D||V?s:r)}]),onMouseDown:H,onTouchStart:H,onClick:b?v:void 0,ref:g,...d,children:c})}const Me=$.memo(ii(rf));function sf({data:e,isConnectable:t,sourcePosition:n=X.Bottom}){return _.jsxs(_.Fragment,{children:[e?.label,_.jsx(Me,{type:"source",position:n,isConnectable:t})]})}function af({data:e,isConnectable:t,targetPosition:n=X.Top,sourcePosition:o=X.Bottom}){return _.jsxs(_.Fragment,{children:[_.jsx(Me,{type:"target",position:n,isConnectable:t}),e?.label,_.jsx(Me,{type:"source",position:o,isConnectable:t})]})}function cf(){return null}function lf({data:e,isConnectable:t,targetPosition:n=X.Top}){return _.jsxs(_.Fragment,{children:[_.jsx(Me,{type:"target",position:n,isConnectable:t}),e?.label]})}const Ht={ArrowUp:{x:0,y:-1},ArrowDown:{x:0,y:1},ArrowLeft:{x:-1,y:0},ArrowRight:{x:1,y:0}},Ho={input:sf,default:af,output:lf,group:cf};function uf(e){return e.internals.handleBounds===void 0?{width:e.width??e.initialWidth??e.style?.width,height:e.height??e.initialHeight??e.style?.height}:{width:e.width??e.style?.width,height:e.height??e.style?.height}}const df=e=>{const{width:t,height:n,x:o,y:r}=ft(e.nodeLookup,{filter:s=>!!s.selected});return{width:fe(t)?t:null,height:fe(n)?n:null,userSelectionActive:e.userSelectionActive,transformString:`translate(${e.transform[0]}px,${e.transform[1]}px) scale(${e.transform[2]}) translate(${o}px,${r}px)`}};function ff({onSelectionContextMenu:e,noPanClassName:t,disableKeyboardA11y:n}){const o=re(),{width:r,height:s,transformString:i,userSelectionActive:a}=J(df,oe),c=ci(),l=$.useRef(null);if($.useEffect(()=>{n||l.current?.focus({preventScroll:!0})},[n]),ai({nodeRef:l}),a||!r||!s)return null;const u=e?d=>{const g=o.getState().nodes.filter(p=>p.selected);e(d,g)}:void 0,f=d=>{Object.prototype.hasOwnProperty.call(Ht,d.key)&&(d.preventDefault(),c({direction:Ht[d.key],factor:d.shiftKey?4:1}))};return _.jsx("div",{className:ie(["react-flow__nodesselection","react-flow__container",t]),style:{transform:i},children:_.jsx("div",{ref:l,className:"react-flow__nodesselection-rect",onContextMenu:u,tabIndex:n?void 0:-1,onKeyDown:n?void 0:f,style:{width:r,height:s}})})}const Lo=typeof window<"u"?window:void 0,hf=e=>({nodesSelectionActive:e.nodesSelectionActive,userSelectionActive:e.userSelectionActive});function ui({children:e,onPaneClick:t,onPaneMouseEnter:n,onPaneMouseMove:o,onPaneMouseLeave:r,onPaneContextMenu:s,onPaneScroll:i,paneClickDistance:a,deleteKeyCode:c,selectionKeyCode:l,selectionOnDrag:u,selectionMode:f,onSelectionStart:d,onSelectionEnd:g,multiSelectionKeyCode:p,panActivationKeyCode:x,zoomActivationKeyCode:w,elementsSelectable:m,zoomOnScroll:b,zoomOnPinch:h,panOnScroll:y,panOnScrollSpeed:S,panOnScrollMode:E,zoomOnDoubleClick:C,panOnDrag:P,defaultViewport:D,translateExtent:V,minZoom:I,maxZoom:z,preventScrolling:H,onSelectionContextMenu:v,noWheelClassName:M,noPanClassName:N,disableKeyboardA11y:A,onViewportChange:k,isControlledViewport:T}){const{nodesSelectionActive:L,userSelectionActive:j}=J(hf,oe),R=lt(l,{target:Lo}),F=lt(x,{target:Lo}),B=F||P,W=F||y,K=u&&B!==!0,Z=R||j||K;return Zd({deleteKeyCode:c,multiSelectionKeyCode:p}),_.jsx(Gd,{onPaneContextMenu:s,elementsSelectable:m,zoomOnScroll:b,zoomOnPinch:h,panOnScroll:W,panOnScrollSpeed:S,panOnScrollMode:E,zoomOnDoubleClick:C,panOnDrag:!R&&B,defaultViewport:D,translateExtent:V,minZoom:I,maxZoom:z,zoomActivationKeyCode:w,preventScrolling:H,noWheelClassName:M,noPanClassName:N,onViewportChange:k,isControlledViewport:T,paneClickDistance:a,selectionOnDrag:K,children:_.jsxs(Jd,{onSelectionStart:d,onSelectionEnd:g,onPaneClick:t,onPaneMouseEnter:n,onPaneMouseMove:o,onPaneMouseLeave:r,onPaneContextMenu:s,onPaneScroll:i,panOnDrag:B,isSelecting:!!Z,selectionMode:f,selectionKeyPressed:R,paneClickDistance:a,selectionOnDrag:K,children:[e,L&&_.jsx(ff,{onSelectionContextMenu:v,noPanClassName:N,disableKeyboardA11y:A})]})})}ui.displayName="FlowRenderer";const gf=$.memo(ui),pf=e=>t=>e?kn(t.nodeLookup,{x:0,y:0,width:t.width,height:t.height},t.transform,!0).map(n=>n.id):Array.from(t.nodeLookup.keys());function mf(e){return J($.useCallback(pf(e),[e]),oe)}const yf=e=>e.updateNodeInternals;function xf(){const e=J(yf),[t]=$.useState(()=>typeof ResizeObserver>"u"?null:new ResizeObserver(n=>{const o=new Map;n.forEach(r=>{const s=r.target.getAttribute("data-id");o.set(s,{id:s,nodeElement:r.target,force:!0})}),e(o)}));return $.useEffect(()=>()=>{t?.disconnect()},[t]),t}function wf({node:e,nodeType:t,hasDimensions:n,resizeObserver:o}){const r=re(),s=$.useRef(null),i=$.useRef(null),a=$.useRef(e.sourcePosition),c=$.useRef(e.targetPosition),l=$.useRef(t),u=n&&!!e.internals.handleBounds;return $.useEffect(()=>{s.current&&!e.hidden&&(!u||i.current!==s.current)&&(i.current&&o?.unobserve(i.current),o?.observe(s.current),i.current=s.current)},[u,e.hidden]),$.useEffect(()=>()=>{i.current&&(o?.unobserve(i.current),i.current=null)},[]),$.useEffect(()=>{if(s.current){const f=l.current!==t,d=a.current!==e.sourcePosition,g=c.current!==e.targetPosition;(f||d||g)&&(l.current=t,a.current=e.sourcePosition,c.current=e.targetPosition,r.getState().updateNodeInternals(new Map([[e.id,{id:e.id,nodeElement:s.current,force:!0}]])))}},[e.id,t,e.sourcePosition,e.targetPosition]),s}function vf({id:e,onClick:t,onMouseEnter:n,onMouseMove:o,onMouseLeave:r,onContextMenu:s,onDoubleClick:i,nodesDraggable:a,elementsSelectable:c,nodesConnectable:l,nodesFocusable:u,resizeObserver:f,noDragClassName:d,noPanClassName:g,disableKeyboardA11y:p,rfId:x,nodeTypes:w,nodeClickDistance:m,onError:b}){const{node:h,internals:y,isParent:S}=J(O=>{const Y=O.nodeLookup.get(e),Q=O.parentLookup.has(e);return{node:Y,internals:Y.internals,isParent:Q}},oe);let E=h.type||"default",C=w?.[E]||Ho[E];C===void 0&&(b?.("003",pe.error003(E)),E="default",C=w?.default||Ho.default);const P=!!(h.draggable||a&&typeof h.draggable>"u"),D=!!(h.selectable||c&&typeof h.selectable>"u"),V=!!(h.connectable||l&&typeof h.connectable>"u"),I=!!(h.focusable||u&&typeof h.focusable>"u"),z=re(),H=Tr(h),v=wf({node:h,nodeType:E,hasDimensions:H,resizeObserver:f}),M=ai({nodeRef:v,disabled:h.hidden||!P,noDragClassName:d,handleSelector:h.dragHandle,nodeId:e,isSelectable:D,nodeClickDistance:m}),N=ci();if(h.hidden)return null;const A=_e(h),k=uf(h),T=D||P||t||n||o||r,L=n?O=>n(O,{...y.userNode}):void 0,j=o?O=>o(O,{...y.userNode}):void 0,R=r?O=>r(O,{...y.userNode}):void 0,F=s?O=>s(O,{...y.userNode}):void 0,B=i?O=>i(O,{...y.userNode}):void 0,W=O=>{const{selectNodesOnDrag:Y,nodeDragThreshold:Q}=z.getState();D&&(!Y||!P||Q>0)&&vn({id:e,store:z,nodeRef:v}),t&&t(O,{...y.userNode})},K=O=>{if(!(Hr(O.nativeEvent)||p)){if(Sr.includes(O.key)&&D){const Y=O.key==="Escape";vn({id:e,store:z,unselect:Y,nodeRef:v})}else if(P&&h.selected&&Object.prototype.hasOwnProperty.call(Ht,O.key)){O.preventDefault();const{ariaLabelConfig:Y}=z.getState();z.setState({ariaLiveMessage:Y["node.a11yDescription.ariaLiveMessage"]({direction:O.key.replace("Arrow","").toLowerCase(),x:~~y.positionAbsolute.x,y:~~y.positionAbsolute.y})}),N({direction:Ht[O.key],factor:O.shiftKey?4:1})}}},Z=()=>{if(p||!v.current?.matches(":focus-visible"))return;const{transform:O,width:Y,height:Q,autoPanOnNodeFocus:U,setCenter:q}=z.getState();if(!U)return;kn(new Map([[e,h]]),{x:0,y:0,width:Y,height:Q},O,!0).length>0||q(h.position.x+A.width/2,h.position.y+A.height/2,{zoom:O[2]})};return _.jsx("div",{className:ie(["react-flow__node",`react-flow__node-${E}`,{[g]:P},h.className,{selected:h.selected,selectable:D,parent:S,draggable:P,dragging:M}]),ref:v,style:{zIndex:y.z,transform:`translate(${y.positionAbsolute.x}px,${y.positionAbsolute.y}px)`,pointerEvents:T?"all":"none",visibility:H?"visible":"hidden",...h.style,...k},"data-id":e,"data-testid":`rf__node-${e}`,onMouseEnter:L,onMouseMove:j,onMouseLeave:R,onContextMenu:F,onClick:W,onDoubleClick:B,onKeyDown:I?K:void 0,tabIndex:I?0:void 0,onFocus:I?Z:void 0,role:h.ariaRole??(I?"group":void 0),"aria-roledescription":"node","aria-describedby":p?void 0:`${ti}-${x}`,"aria-label":h.ariaLabel,...h.domAttributes,children:_.jsx(tf,{value:e,children:_.jsx(C,{id:e,data:h.data,type:E,positionAbsoluteX:y.positionAbsolute.x,positionAbsoluteY:y.positionAbsolute.y,selected:h.selected??!1,selectable:D,draggable:P,deletable:h.deletable??!0,isConnectable:V,sourcePosition:h.sourcePosition,targetPosition:h.targetPosition,dragging:M,dragHandle:h.dragHandle,zIndex:y.z,parentId:h.parentId,...A})})})}var _f=$.memo(vf);const bf=e=>({nodesDraggable:e.nodesDraggable,nodesConnectable:e.nodesConnectable,nodesFocusable:e.nodesFocusable,elementsSelectable:e.elementsSelectable,onError:e.onError});function di(e){const{nodesDraggable:t,nodesConnectable:n,nodesFocusable:o,elementsSelectable:r,onError:s}=J(bf,oe),i=mf(e.onlyRenderVisibleElements),a=xf();return _.jsx("div",{className:"react-flow__nodes",style:qt,children:i.map(c=>_.jsx(_f,{id:c,nodeTypes:e.nodeTypes,nodeExtent:e.nodeExtent,onClick:e.onNodeClick,onMouseEnter:e.onNodeMouseEnter,onMouseMove:e.onNodeMouseMove,onMouseLeave:e.onNodeMouseLeave,onContextMenu:e.onNodeContextMenu,onDoubleClick:e.onNodeDoubleClick,noDragClassName:e.noDragClassName,noPanClassName:e.noPanClassName,rfId:e.rfId,disableKeyboardA11y:e.disableKeyboardA11y,resizeObserver:a,nodesDraggable:t,nodesConnectable:n,nodesFocusable:o,elementsSelectable:r,nodeClickDistance:e.nodeClickDistance,onError:s},c))})}di.displayName="NodeRenderer";const Ef=$.memo(di);function Sf(e){return J($.useCallback(n=>{if(!e)return n.edges.map(r=>r.id);const o=[];if(n.width&&n.height)for(const r of n.edges){const s=n.nodeLookup.get(r.source),i=n.nodeLookup.get(r.target);s&&i&&Nu({sourceNode:s,targetNode:i,width:n.width,height:n.height,transform:n.transform})&&o.push(r.id)}return o},[e]),oe)}const Nf=({color:e="none",strokeWidth:t=1})=>{const n={strokeWidth:t,...e&&{stroke:e}};return _.jsx("polyline",{className:"arrow",style:n,strokeLinecap:"round",fill:"none",strokeLinejoin:"round",points:"-5,-4 0,0 -5,4"})},Cf=({color:e="none",strokeWidth:t=1})=>{const n={strokeWidth:t,...e&&{stroke:e,fill:e}};return _.jsx("polyline",{className:"arrowclosed",style:n,strokeLinecap:"round",strokeLinejoin:"round",points:"-5,-4 0,0 -5,4 -5,-4"})},Ro={[Tt.Arrow]:Nf,[Tt.ArrowClosed]:Cf};function Mf(e){const t=re();return $.useMemo(()=>Object.prototype.hasOwnProperty.call(Ro,e)?Ro[e]:(t.getState().onError?.("009",pe.error009(e)),null),[e])}const If=({id:e,type:t,color:n,width:o=12.5,height:r=12.5,markerUnits:s="strokeWidth",strokeWidth:i,orient:a="auto-start-reverse"})=>{const c=Mf(t);return c?_.jsx("marker",{className:"react-flow__arrowhead",id:e,markerWidth:`${o}`,markerHeight:`${r}`,viewBox:"-10 -10 20 20",markerUnits:s,orient:a,refX:"0",refY:"0",children:_.jsx(c,{color:n,strokeWidth:i})}):null},fi=({defaultColor:e,rfId:t})=>{const n=J(s=>s.edges),o=J(s=>s.defaultEdgeOptions),r=$.useMemo(()=>Tu(n,{id:t,defaultColor:e,defaultMarkerStart:o?.markerStart,defaultMarkerEnd:o?.markerEnd}),[n,o,t,e]);return r.length?_.jsx("svg",{className:"react-flow__marker","aria-hidden":"true",children:_.jsx("defs",{children:r.map(s=>_.jsx(If,{id:s.id,type:s.type,color:s.color,width:s.width,height:s.height,markerUnits:s.markerUnits,strokeWidth:s.strokeWidth,orient:s.orient},s.id))})}):null};fi.displayName="MarkerDefinitions";var kf=$.memo(fi);function hi({x:e,y:t,label:n,labelStyle:o,labelShowBg:r=!0,labelBgStyle:s,labelBgPadding:i=[2,4],labelBgBorderRadius:a=2,children:c,className:l,...u}){const[f,d]=$.useState({x:1,y:0,width:0,height:0}),g=ie(["react-flow__edge-textwrapper",l]),p=$.useRef(null);return $.useEffect(()=>{if(p.current){const x=p.current.getBBox();d({x:x.x,y:x.y,width:x.width,height:x.height})}},[n]),n?_.jsxs("g",{transform:`translate(${e-f.width/2} ${t-f.height/2})`,className:g,visibility:f.width?"visible":"hidden",...u,children:[r&&_.jsx("rect",{width:f.width+2*i[0],x:-i[0],y:-i[1],height:f.height+2*i[1],className:"react-flow__edge-textbg",style:s,rx:a,ry:a}),_.jsx("text",{className:"react-flow__edge-text",y:f.height/2,dy:"0.3em",ref:p,style:o,children:n}),c]}):null}hi.displayName="EdgeText";const Af=$.memo(hi);function Gt({path:e,labelX:t,labelY:n,label:o,labelStyle:r,labelShowBg:s,labelBgStyle:i,labelBgPadding:a,labelBgBorderRadius:c,interactionWidth:l=20,...u}){return _.jsxs(_.Fragment,{children:[_.jsx("path",{...u,d:e,fill:"none",className:ie(["react-flow__edge-path",u.className])}),l?_.jsx("path",{d:e,fill:"none",strokeOpacity:0,strokeWidth:l,className:"react-flow__edge-interaction"}):null,o&&fe(t)&&fe(n)?_.jsx(Af,{x:t,y:n,label:o,labelStyle:r,labelShowBg:s,labelBgStyle:i,labelBgPadding:a,labelBgBorderRadius:c}):null]})}function jo({pos:e,x1:t,y1:n,x2:o,y2:r}){return e===X.Left||e===X.Right?[.5*(t+o),n]:[t,.5*(n+r)]}function gi({sourceX:e,sourceY:t,sourcePosition:n=X.Bottom,targetX:o,targetY:r,targetPosition:s=X.Top}){const[i,a]=jo({pos:n,x1:e,y1:t,x2:o,y2:r}),[c,l]=jo({pos:s,x1:o,y1:r,x2:e,y2:t}),[u,f,d,g]=Rr({sourceX:e,sourceY:t,targetX:o,targetY:r,sourceControlX:i,sourceControlY:a,targetControlX:c,targetControlY:l});return[`M${e},${t} C${i},${a} ${c},${l} ${o},${r}`,u,f,d,g]}function pi(e){return $.memo(({id:t,sourceX:n,sourceY:o,targetX:r,targetY:s,sourcePosition:i,targetPosition:a,label:c,labelStyle:l,labelShowBg:u,labelBgStyle:f,labelBgPadding:d,labelBgBorderRadius:g,style:p,markerEnd:x,markerStart:w,interactionWidth:m})=>{const[b,h,y]=gi({sourceX:n,sourceY:o,sourcePosition:i,targetX:r,targetY:s,targetPosition:a}),S=e.isInternal?void 0:t;return _.jsx(Gt,{id:S,path:b,labelX:h,labelY:y,label:c,labelStyle:l,labelShowBg:u,labelBgStyle:f,labelBgPadding:d,labelBgBorderRadius:g,style:p,markerEnd:x,markerStart:w,interactionWidth:m})})}const Pf=pi({isInternal:!1}),mi=pi({isInternal:!0});Pf.displayName="SimpleBezierEdge";mi.displayName="SimpleBezierEdgeInternal";function yi(e){return $.memo(({id:t,sourceX:n,sourceY:o,targetX:r,targetY:s,label:i,labelStyle:a,labelShowBg:c,labelBgStyle:l,labelBgPadding:u,labelBgBorderRadius:f,style:d,sourcePosition:g=X.Bottom,targetPosition:p=X.Top,markerEnd:x,markerStart:w,pathOptions:m,interactionWidth:b})=>{const[h,y,S]=mn({sourceX:n,sourceY:o,sourcePosition:g,targetX:r,targetY:s,targetPosition:p,borderRadius:m?.borderRadius,offset:m?.offset,stepPosition:m?.stepPosition}),E=e.isInternal?void 0:t;return _.jsx(Gt,{id:E,path:h,labelX:y,labelY:S,label:i,labelStyle:a,labelShowBg:c,labelBgStyle:l,labelBgPadding:u,labelBgBorderRadius:f,style:d,markerEnd:x,markerStart:w,interactionWidth:b})})}const xi=yi({isInternal:!1}),wi=yi({isInternal:!0});xi.displayName="SmoothStepEdge";wi.displayName="SmoothStepEdgeInternal";function vi(e){return $.memo(({id:t,...n})=>{const o=e.isInternal?void 0:t;return _.jsx(xi,{...n,id:o,pathOptions:$.useMemo(()=>({borderRadius:0,offset:n.pathOptions?.offset}),[n.pathOptions?.offset])})})}const Df=vi({isInternal:!1}),_i=vi({isInternal:!0});Df.displayName="StepEdge";_i.displayName="StepEdgeInternal";function bi(e){return $.memo(({id:t,sourceX:n,sourceY:o,targetX:r,targetY:s,label:i,labelStyle:a,labelShowBg:c,labelBgStyle:l,labelBgPadding:u,labelBgBorderRadius:f,style:d,markerEnd:g,markerStart:p,interactionWidth:x})=>{const[w,m,b]=Or({sourceX:n,sourceY:o,targetX:r,targetY:s}),h=e.isInternal?void 0:t;return _.jsx(Gt,{id:h,path:w,labelX:m,labelY:b,label:i,labelStyle:a,labelShowBg:c,labelBgStyle:l,labelBgPadding:u,labelBgBorderRadius:f,style:d,markerEnd:g,markerStart:p,interactionWidth:x})})}const Tf=bi({isInternal:!1}),Ei=bi({isInternal:!0});Tf.displayName="StraightEdge";Ei.displayName="StraightEdgeInternal";function Si(e){return $.memo(({id:t,sourceX:n,sourceY:o,targetX:r,targetY:s,sourcePosition:i=X.Bottom,targetPosition:a=X.Top,label:c,labelStyle:l,labelShowBg:u,labelBgStyle:f,labelBgPadding:d,labelBgBorderRadius:g,style:p,markerEnd:x,markerStart:w,pathOptions:m,interactionWidth:b})=>{const[h,y,S]=jr({sourceX:n,sourceY:o,sourcePosition:i,targetX:r,targetY:s,targetPosition:a,curvature:m?.curvature}),E=e.isInternal?void 0:t;return _.jsx(Gt,{id:E,path:h,labelX:y,labelY:S,label:c,labelStyle:l,labelShowBg:u,labelBgStyle:f,labelBgPadding:d,labelBgBorderRadius:g,style:p,markerEnd:x,markerStart:w,interactionWidth:b})})}const zf=Si({isInternal:!1}),Ni=Si({isInternal:!0});zf.displayName="BezierEdge";Ni.displayName="BezierEdgeInternal";const Vo={default:Ni,straight:Ei,step:_i,smoothstep:wi,simplebezier:mi},Oo={sourceX:null,sourceY:null,targetX:null,targetY:null,sourcePosition:null,targetPosition:null},$f=(e,t,n)=>n===X.Left?e-t:n===X.Right?e+t:e,Hf=(e,t,n)=>n===X.Top?e-t:n===X.Bottom?e+t:e,Bo="react-flow__edgeupdater";function Fo({position:e,centerX:t,centerY:n,radius:o=10,onMouseDown:r,onMouseEnter:s,onMouseOut:i,type:a}){return _.jsx("circle",{onMouseDown:r,onMouseEnter:s,onMouseOut:i,className:ie([Bo,`${Bo}-${a}`]),cx:$f(t,o,e),cy:Hf(n,o,e),r:o,stroke:"transparent",fill:"transparent"})}function Lf({isReconnectable:e,reconnectRadius:t,edge:n,sourceX:o,sourceY:r,targetX:s,targetY:i,sourcePosition:a,targetPosition:c,onReconnect:l,onReconnectStart:u,onReconnectEnd:f,setReconnecting:d,setUpdateHover:g}){const p=re(),x=(y,S)=>{if(y.button!==0)return;const{autoPanOnConnect:E,domNode:C,isValidConnection:P,connectionMode:D,connectionRadius:V,lib:I,onConnectStart:z,onConnectEnd:H,cancelConnection:v,nodeLookup:M,rfId:N,panBy:A,updateConnection:k}=p.getState(),T=S.type==="target",L=(F,B)=>{d(!1),f?.(F,n,S.type,B)},j=F=>l?.(n,F),R=(F,B)=>{d(!0),u?.(y,n,S.type),z?.(F,B)};wn.onPointerDown(y.nativeEvent,{autoPanOnConnect:E,connectionMode:D,connectionRadius:V,domNode:C,handleId:S.id,nodeId:S.nodeId,nodeLookup:M,isTarget:T,edgeUpdaterType:S.type,lib:I,flowId:N,cancelConnection:v,panBy:A,isValidConnection:P,onConnect:j,onConnectStart:R,onConnectEnd:H,onReconnectEnd:L,updateConnection:k,getTransform:()=>p.getState().transform,getFromHandle:()=>p.getState().connection.fromHandle,dragThreshold:p.getState().connectionDragThreshold,handleDomNode:y.currentTarget})},w=y=>x(y,{nodeId:n.target,id:n.targetHandle??null,type:"target"}),m=y=>x(y,{nodeId:n.source,id:n.sourceHandle??null,type:"source"}),b=()=>g(!0),h=()=>g(!1);return _.jsxs(_.Fragment,{children:[(e===!0||e==="source")&&_.jsx(Fo,{position:a,centerX:o,centerY:r,radius:t,onMouseDown:w,onMouseEnter:b,onMouseOut:h,type:"source"}),(e===!0||e==="target")&&_.jsx(Fo,{position:c,centerX:s,centerY:i,radius:t,onMouseDown:m,onMouseEnter:b,onMouseOut:h,type:"target"})]})}function Rf({id:e,edgesFocusable:t,edgesReconnectable:n,elementsSelectable:o,onClick:r,onDoubleClick:s,onContextMenu:i,onMouseEnter:a,onMouseMove:c,onMouseLeave:l,reconnectRadius:u,onReconnect:f,onReconnectStart:d,onReconnectEnd:g,rfId:p,edgeTypes:x,noPanClassName:w,onError:m,disableKeyboardA11y:b}){let h=J(q=>q.edgeLookup.get(e));const y=J(q=>q.defaultEdgeOptions);h=y?{...y,...h}:h;let S=h.type||"default",E=x?.[S]||Vo[S];E===void 0&&(m?.("011",pe.error011(S)),S="default",E=x?.default||Vo.default);const C=!!(h.focusable||t&&typeof h.focusable>"u"),P=typeof f<"u"&&(h.reconnectable||n&&typeof h.reconnectable>"u"),D=!!(h.selectable||o&&typeof h.selectable>"u"),V=$.useRef(null),[I,z]=$.useState(!1),[H,v]=$.useState(!1),M=re(),{zIndex:N,sourceX:A,sourceY:k,targetX:T,targetY:L,sourcePosition:j,targetPosition:R}=J($.useCallback(q=>{const G=q.nodeLookup.get(h.source),ee=q.nodeLookup.get(h.target);if(!G||!ee)return{zIndex:h.zIndex,...Oo};const ne=Du({id:e,sourceNode:G,targetNode:ee,sourceHandle:h.sourceHandle||null,targetHandle:h.targetHandle||null,connectionMode:q.connectionMode,onError:m});return{zIndex:Su({selected:h.selected,zIndex:h.zIndex,sourceNode:G,targetNode:ee,elevateOnSelect:q.elevateEdgesOnSelect,zIndexMode:q.zIndexMode}),...ne||Oo}},[h.source,h.target,h.sourceHandle,h.targetHandle,h.selected,h.zIndex]),oe),F=$.useMemo(()=>h.markerStart?`url('#${yn(h.markerStart,p)}')`:void 0,[h.markerStart,p]),B=$.useMemo(()=>h.markerEnd?`url('#${yn(h.markerEnd,p)}')`:void 0,[h.markerEnd,p]);if(h.hidden||A===null||k===null||T===null||L===null)return null;const W=q=>{const{addSelectedEdges:G,unselectNodesAndEdges:ee,multiSelectionActive:ne}=M.getState();D&&(M.setState({nodesSelectionActive:!1}),h.selected&&ne?(ee({nodes:[],edges:[h]}),V.current?.blur()):G([e])),r&&r(q,h)},K=s?q=>{s(q,{...h})}:void 0,Z=i?q=>{i(q,{...h})}:void 0,O=a?q=>{a(q,{...h})}:void 0,Y=c?q=>{c(q,{...h})}:void 0,Q=l?q=>{l(q,{...h})}:void 0,U=q=>{if(!b&&Sr.includes(q.key)&&D){const{unselectNodesAndEdges:G,addSelectedEdges:ee}=M.getState();q.key==="Escape"?(V.current?.blur(),G({edges:[h]})):ee([e])}};return _.jsx("svg",{style:{zIndex:N},children:_.jsxs("g",{className:ie(["react-flow__edge",`react-flow__edge-${S}`,h.className,w,{selected:h.selected,animated:h.animated,inactive:!D&&!r,updating:I,selectable:D}]),onClick:W,onDoubleClick:K,onContextMenu:Z,onMouseEnter:O,onMouseMove:Y,onMouseLeave:Q,onKeyDown:C?U:void 0,tabIndex:C?0:void 0,role:h.ariaRole??(C?"group":"img"),"aria-roledescription":"edge","data-id":e,"data-testid":`rf__edge-${e}`,"aria-label":h.ariaLabel===null?void 0:h.ariaLabel||`Edge from ${h.source} to ${h.target}`,"aria-describedby":C?`${ni}-${p}`:void 0,ref:V,...h.domAttributes,children:[!H&&_.jsx(E,{id:e,source:h.source,target:h.target,type:h.type,selected:h.selected,animated:h.animated,selectable:D,deletable:h.deletable??!0,label:h.label,labelStyle:h.labelStyle,labelShowBg:h.labelShowBg,labelBgStyle:h.labelBgStyle,labelBgPadding:h.labelBgPadding,labelBgBorderRadius:h.labelBgBorderRadius,sourceX:A,sourceY:k,targetX:T,targetY:L,sourcePosition:j,targetPosition:R,data:h.data,style:h.style,sourceHandleId:h.sourceHandle,targetHandleId:h.targetHandle,markerStart:F,markerEnd:B,pathOptions:"pathOptions"in h?h.pathOptions:void 0,interactionWidth:h.interactionWidth}),P&&_.jsx(Lf,{edge:h,isReconnectable:P,reconnectRadius:u,onReconnect:f,onReconnectStart:d,onReconnectEnd:g,sourceX:A,sourceY:k,targetX:T,targetY:L,sourcePosition:j,targetPosition:R,setUpdateHover:z,setReconnecting:v})]})})}var jf=$.memo(Rf);const Vf=e=>({edgesFocusable:e.edgesFocusable,edgesReconnectable:e.edgesReconnectable,elementsSelectable:e.elementsSelectable,connectionMode:e.connectionMode,onError:e.onError});function Ci({defaultMarkerColor:e,onlyRenderVisibleElements:t,rfId:n,edgeTypes:o,noPanClassName:r,onReconnect:s,onEdgeContextMenu:i,onEdgeMouseEnter:a,onEdgeMouseMove:c,onEdgeMouseLeave:l,onEdgeClick:u,reconnectRadius:f,onEdgeDoubleClick:d,onReconnectStart:g,onReconnectEnd:p,disableKeyboardA11y:x}){const{edgesFocusable:w,edgesReconnectable:m,elementsSelectable:b,onError:h}=J(Vf,oe),y=Sf(t);return _.jsxs("div",{className:"react-flow__edges",children:[_.jsx(kf,{defaultColor:e,rfId:n}),y.map(S=>_.jsx(jf,{id:S,edgesFocusable:w,edgesReconnectable:m,elementsSelectable:b,noPanClassName:r,onReconnect:s,onContextMenu:i,onMouseEnter:a,onMouseMove:c,onMouseLeave:l,onClick:u,reconnectRadius:f,onDoubleClick:d,onReconnectStart:g,onReconnectEnd:p,rfId:n,onError:h,edgeTypes:o,disableKeyboardA11y:x},S))]})}Ci.displayName="EdgeRenderer";const Of=$.memo(Ci),Bf=e=>`translate(${e.transform[0]}px,${e.transform[1]}px) scale(${e.transform[2]})`;function Ff({children:e}){const t=J(Bf);return _.jsx("div",{className:"react-flow__viewport xyflow__viewport react-flow__container",style:{transform:t},children:e})}function Xf(e){const t=Ln(),n=$.useRef(!1);$.useEffect(()=>{!n.current&&t.viewportInitialized&&e&&(setTimeout(()=>e(t),1),n.current=!0)},[e,t.viewportInitialized])}const Yf=e=>e.panZoom?.syncViewport;function Zf(e){const t=J(Yf),n=re();return $.useEffect(()=>{e&&(t?.(e),n.setState({transform:[e.x,e.y,e.zoom]}))},[e,t]),null}function Wf(e){return e.connection.inProgress?{...e.connection,to:gt(e.connection.to,e.transform)}:{...e.connection}}function qf(e){return Wf}function Gf(e){const t=qf();return J(t,oe)}const Kf=e=>({nodesConnectable:e.nodesConnectable,isValid:e.connection.isValid,inProgress:e.connection.inProgress,width:e.width,height:e.height});function Uf({containerStyle:e,style:t,type:n,component:o}){const{nodesConnectable:r,width:s,height:i,isValid:a,inProgress:c}=J(Kf,oe);return!(s&&r&&c)?null:_.jsx("svg",{style:e,width:s,height:i,className:"react-flow__connectionline react-flow__container",children:_.jsx("g",{className:ie(["react-flow__connection",Mr(a)]),children:_.jsx(Mi,{style:t,type:n,CustomComponent:o,isValid:a})})})}const Mi=({style:e,type:t=Ne.Bezier,CustomComponent:n,isValid:o})=>{const{inProgress:r,from:s,fromNode:i,fromHandle:a,fromPosition:c,to:l,toNode:u,toHandle:f,toPosition:d,pointer:g}=Gf();if(!r)return;if(n)return _.jsx(n,{connectionLineType:t,connectionLineStyle:e,fromNode:i,fromHandle:a,fromX:s.x,fromY:s.y,toX:l.x,toY:l.y,fromPosition:c,toPosition:d,connectionStatus:Mr(o),toNode:u,toHandle:f,pointer:g});let p="";const x={sourceX:s.x,sourceY:s.y,sourcePosition:c,targetX:l.x,targetY:l.y,targetPosition:d};switch(t){case Ne.Bezier:[p]=jr(x);break;case Ne.SimpleBezier:[p]=gi(x);break;case Ne.Step:[p]=mn({...x,borderRadius:0});break;case Ne.SmoothStep:[p]=mn(x);break;default:[p]=Or(x)}return _.jsx("path",{d:p,fill:"none",className:"react-flow__connection-path",style:e})};Mi.displayName="ConnectionLine";const Qf={};function Xo(e=Qf){$.useRef(e),re(),$.useEffect(()=>{},[e])}function Jf(){re(),$.useRef(!1),$.useEffect(()=>{},[])}function Ii({nodeTypes:e,edgeTypes:t,onInit:n,onNodeClick:o,onEdgeClick:r,onNodeDoubleClick:s,onEdgeDoubleClick:i,onNodeMouseEnter:a,onNodeMouseMove:c,onNodeMouseLeave:l,onNodeContextMenu:u,onSelectionContextMenu:f,onSelectionStart:d,onSelectionEnd:g,connectionLineType:p,connectionLineStyle:x,connectionLineComponent:w,connectionLineContainerStyle:m,selectionKeyCode:b,selectionOnDrag:h,selectionMode:y,multiSelectionKeyCode:S,panActivationKeyCode:E,zoomActivationKeyCode:C,deleteKeyCode:P,onlyRenderVisibleElements:D,elementsSelectable:V,defaultViewport:I,translateExtent:z,minZoom:H,maxZoom:v,preventScrolling:M,defaultMarkerColor:N,zoomOnScroll:A,zoomOnPinch:k,panOnScroll:T,panOnScrollSpeed:L,panOnScrollMode:j,zoomOnDoubleClick:R,panOnDrag:F,onPaneClick:B,onPaneMouseEnter:W,onPaneMouseMove:K,onPaneMouseLeave:Z,onPaneScroll:O,onPaneContextMenu:Y,paneClickDistance:Q,nodeClickDistance:U,onEdgeContextMenu:q,onEdgeMouseEnter:G,onEdgeMouseMove:ee,onEdgeMouseLeave:ne,reconnectRadius:te,onReconnect:ae,onReconnectStart:be,onReconnectEnd:ye,noDragClassName:Ie,noWheelClassName:We,noPanClassName:qe,disableKeyboardA11y:Ge,nodeExtent:Kt,rfId:pt,viewport:$e,onViewportChange:Ke}){return Xo(e),Xo(t),Jf(),Xf(n),Zf($e),_.jsx(gf,{onPaneClick:B,onPaneMouseEnter:W,onPaneMouseMove:K,onPaneMouseLeave:Z,onPaneContextMenu:Y,onPaneScroll:O,paneClickDistance:Q,deleteKeyCode:P,selectionKeyCode:b,selectionOnDrag:h,selectionMode:y,onSelectionStart:d,onSelectionEnd:g,multiSelectionKeyCode:S,panActivationKeyCode:E,zoomActivationKeyCode:C,elementsSelectable:V,zoomOnScroll:A,zoomOnPinch:k,zoomOnDoubleClick:R,panOnScroll:T,panOnScrollSpeed:L,panOnScrollMode:j,panOnDrag:F,defaultViewport:I,translateExtent:z,minZoom:H,maxZoom:v,onSelectionContextMenu:f,preventScrolling:M,noDragClassName:Ie,noWheelClassName:We,noPanClassName:qe,disableKeyboardA11y:Ge,onViewportChange:Ke,isControlledViewport:!!$e,children:_.jsxs(Ff,{children:[_.jsx(Of,{edgeTypes:t,onEdgeClick:r,onEdgeDoubleClick:i,onReconnect:ae,onReconnectStart:be,onReconnectEnd:ye,onlyRenderVisibleElements:D,onEdgeContextMenu:q,onEdgeMouseEnter:G,onEdgeMouseMove:ee,onEdgeMouseLeave:ne,reconnectRadius:te,defaultMarkerColor:N,noPanClassName:qe,disableKeyboardA11y:Ge,rfId:pt}),_.jsx(Uf,{style:x,type:p,component:w,containerStyle:m}),_.jsx("div",{className:"react-flow__edgelabel-renderer"}),_.jsx(Ef,{nodeTypes:e,onNodeClick:o,onNodeDoubleClick:s,onNodeMouseEnter:a,onNodeMouseMove:c,onNodeMouseLeave:l,onNodeContextMenu:u,nodeClickDistance:U,onlyRenderVisibleElements:D,noPanClassName:qe,noDragClassName:Ie,disableKeyboardA11y:Ge,nodeExtent:Kt,rfId:pt}),_.jsx("div",{className:"react-flow__viewport-portal"})]})})}Ii.displayName="GraphView";const eh=$.memo(Ii),Yo=({nodes:e,edges:t,defaultNodes:n,defaultEdges:o,width:r,height:s,fitView:i,fitViewOptions:a,minZoom:c=.5,maxZoom:l=2,nodeOrigin:u,nodeExtent:f,zIndexMode:d="basic"}={})=>{const g=new Map,p=new Map,x=new Map,w=new Map,m=o??t??[],b=n??e??[],h=u??[0,0],y=f??it;Xr(x,w,m);const S=xn(b,g,p,{nodeOrigin:h,nodeExtent:y,zIndexMode:d});let E=[0,0,1];if(i&&r&&s){const C=ft(g,{filter:I=>!!((I.width||I.initialWidth)&&(I.height||I.initialHeight))}),{x:P,y:D,zoom:V}=An(C,r,s,c,l,a?.padding??.1);E=[P,D,V]}return{rfId:"1",width:r??0,height:s??0,transform:E,nodes:b,nodesInitialized:S,nodeLookup:g,parentLookup:p,edges:m,edgeLookup:w,connectionLookup:x,onNodesChange:null,onEdgesChange:null,hasDefaultNodes:n!==void 0,hasDefaultEdges:o!==void 0,panZoom:null,minZoom:c,maxZoom:l,translateExtent:it,nodeExtent:y,nodesSelectionActive:!1,userSelectionActive:!1,userSelectionRect:null,connectionMode:Be.Strict,domNode:null,paneDragging:!1,noPanClassName:"nopan",nodeOrigin:h,nodeDragThreshold:1,connectionDragThreshold:1,snapGrid:[15,15],snapToGrid:!1,nodesDraggable:!0,nodesConnectable:!0,nodesFocusable:!0,edgesFocusable:!0,edgesReconnectable:!0,elementsSelectable:!0,elevateNodesOnSelect:!0,elevateEdgesOnSelect:!0,selectNodesOnDrag:!0,multiSelectionActive:!1,fitViewQueued:i??!1,fitViewOptions:a,fitViewResolver:null,connection:{...Cr},connectionClickStartHandle:null,connectOnClick:!0,ariaLiveMessage:"",autoPanOnConnect:!0,autoPanOnNodeDrag:!0,autoPanOnNodeFocus:!0,autoPanSpeed:15,connectionRadius:20,onError:xu,isValidConnection:void 0,onSelectionChangeHandlers:[],lib:"react",debug:!1,ariaLabelConfig:Nr,zIndexMode:d,onNodesChangeMiddlewareMap:new Map,onEdgesChangeMiddlewareMap:new Map}},th=({nodes:e,edges:t,defaultNodes:n,defaultEdges:o,width:r,height:s,fitView:i,fitViewOptions:a,minZoom:c,maxZoom:l,nodeOrigin:u,nodeExtent:f,zIndexMode:d})=>md((g,p)=>{async function x(){const{nodeLookup:w,panZoom:m,fitViewOptions:b,fitViewResolver:h,width:y,height:S,minZoom:E,maxZoom:C}=p();m&&(await mu({nodes:w,width:y,height:S,panZoom:m,minZoom:E,maxZoom:C},b),h?.resolve(!0),g({fitViewResolver:null}))}return{...Yo({nodes:e,edges:t,width:r,height:s,fitView:i,fitViewOptions:a,minZoom:c,maxZoom:l,nodeOrigin:u,nodeExtent:f,defaultNodes:n,defaultEdges:o,zIndexMode:d}),setNodes:w=>{const{nodeLookup:m,parentLookup:b,nodeOrigin:h,elevateNodesOnSelect:y,fitViewQueued:S,zIndexMode:E}=p(),C=xn(w,m,b,{nodeOrigin:h,nodeExtent:f,elevateNodesOnSelect:y,checkEquality:!0,zIndexMode:E});S&&C?(x(),g({nodes:w,nodesInitialized:C,fitViewQueued:!1,fitViewOptions:void 0})):g({nodes:w,nodesInitialized:C})},setEdges:w=>{const{connectionLookup:m,edgeLookup:b}=p();Xr(m,b,w),g({edges:w})},setDefaultNodesAndEdges:(w,m)=>{if(w){const{setNodes:b}=p();b(w),g({hasDefaultNodes:!0})}if(m){const{setEdges:b}=p();b(m),g({hasDefaultEdges:!0})}},updateNodeInternals:w=>{const{triggerNodeChanges:m,nodeLookup:b,parentLookup:h,domNode:y,nodeOrigin:S,nodeExtent:E,debug:C,fitViewQueued:P,zIndexMode:D}=p(),{changes:V,updatedInternals:I}=Vu(w,b,h,y,S,E,D);I&&(Hu(b,h,{nodeOrigin:S,nodeExtent:E,zIndexMode:D}),P?(x(),g({fitViewQueued:!1,fitViewOptions:void 0})):g({}),V?.length>0&&(C&&console.log("React Flow: trigger node changes",V),m?.(V)))},updateNodePositions:(w,m=!1)=>{const b=[];let h=[];const{nodeLookup:y,triggerNodeChanges:S,connection:E,updateConnection:C,onNodesChangeMiddlewareMap:P}=p();for(const[D,V]of w){const I=y.get(D),z=!!(I?.expandParent&&I?.parentId&&V?.position),H={id:D,type:"position",position:z?{x:Math.max(0,V.position.x),y:Math.max(0,V.position.y)}:V.position,dragging:m};if(I&&E.inProgress&&E.fromNode.id===I.id){const v=ze(I,E.fromHandle,X.Left,!0);C({...E,from:v})}z&&I.parentId&&b.push({id:D,parentId:I.parentId,rect:{...V.internals.positionAbsolute,width:V.measured.width??0,height:V.measured.height??0}}),h.push(H)}if(b.length>0){const{parentLookup:D,nodeOrigin:V}=p(),I=Hn(b,y,D,V);h.push(...I)}for(const D of P.values())h=D(h);S(h)},triggerNodeChanges:w=>{const{onNodesChange:m,setNodes:b,nodes:h,hasDefaultNodes:y,debug:S}=p();if(w?.length){if(y){const E=Ld(w,h);b(E)}S&&console.log("React Flow: trigger node changes",w),m?.(w)}},triggerEdgeChanges:w=>{const{onEdgesChange:m,setEdges:b,edges:h,hasDefaultEdges:y,debug:S}=p();if(w?.length){if(y){const E=Rd(w,h);b(E)}S&&console.log("React Flow: trigger edge changes",w),m?.(w)}},addSelectedNodes:w=>{const{multiSelectionActive:m,edgeLookup:b,nodeLookup:h,triggerNodeChanges:y,triggerEdgeChanges:S}=p();if(m){const E=w.map(C=>Ae(C,!0));y(E);return}y(Re(h,new Set([...w]),!0)),S(Re(b))},addSelectedEdges:w=>{const{multiSelectionActive:m,edgeLookup:b,nodeLookup:h,triggerNodeChanges:y,triggerEdgeChanges:S}=p();if(m){const E=w.map(C=>Ae(C,!0));S(E);return}S(Re(b,new Set([...w]))),y(Re(h,new Set,!0))},unselectNodesAndEdges:({nodes:w,edges:m}={})=>{const{edges:b,nodes:h,nodeLookup:y,triggerNodeChanges:S,triggerEdgeChanges:E}=p(),C=w||h,P=m||b,D=C.map(I=>{const z=y.get(I.id);return z&&(z.selected=!1),Ae(I.id,!1)}),V=P.map(I=>Ae(I.id,!1));S(D),E(V)},setMinZoom:w=>{const{panZoom:m,maxZoom:b}=p();m?.setScaleExtent([w,b]),g({minZoom:w})},setMaxZoom:w=>{const{panZoom:m,minZoom:b}=p();m?.setScaleExtent([b,w]),g({maxZoom:w})},setTranslateExtent:w=>{p().panZoom?.setTranslateExtent(w),g({translateExtent:w})},resetSelectedElements:()=>{const{edges:w,nodes:m,triggerNodeChanges:b,triggerEdgeChanges:h,elementsSelectable:y}=p();if(!y)return;const S=m.reduce((C,P)=>P.selected?[...C,Ae(P.id,!1)]:C,[]),E=w.reduce((C,P)=>P.selected?[...C,Ae(P.id,!1)]:C,[]);b(S),h(E)},setNodeExtent:w=>{const{nodes:m,nodeLookup:b,parentLookup:h,nodeOrigin:y,elevateNodesOnSelect:S,nodeExtent:E,zIndexMode:C}=p();w[0][0]===E[0][0]&&w[0][1]===E[0][1]&&w[1][0]===E[1][0]&&w[1][1]===E[1][1]||(xn(m,b,h,{nodeOrigin:y,nodeExtent:w,elevateNodesOnSelect:S,checkEquality:!1,zIndexMode:C}),g({nodeExtent:w}))},panBy:w=>{const{transform:m,width:b,height:h,panZoom:y,translateExtent:S}=p();return Ou({delta:w,panZoom:y,transform:m,translateExtent:S,width:b,height:h})},setCenter:async(w,m,b)=>{const{width:h,height:y,maxZoom:S,panZoom:E}=p();if(!E)return Promise.resolve(!1);const C=typeof b?.zoom<"u"?b.zoom:S;return await E.setViewport({x:h/2-w*C,y:y/2-m*C,zoom:C},{duration:b?.duration,ease:b?.ease,interpolate:b?.interpolate}),Promise.resolve(!0)},cancelConnection:()=>{g({connection:{...Cr}})},updateConnection:w=>{g({connection:w})},reset:()=>g({...Yo()})}},Object.is);function nh({initialNodes:e,initialEdges:t,defaultNodes:n,defaultEdges:o,initialWidth:r,initialHeight:s,initialMinZoom:i,initialMaxZoom:a,initialFitViewOptions:c,fitView:l,nodeOrigin:u,nodeExtent:f,zIndexMode:d,children:g}){const[p]=$.useState(()=>th({nodes:e,edges:t,defaultNodes:n,defaultEdges:o,width:r,height:s,fitView:l,minZoom:i,maxZoom:a,fitViewOptions:c,nodeOrigin:u,nodeExtent:f,zIndexMode:d}));return _.jsx(yd,{value:p,children:_.jsx(Bd,{children:g})})}function oh({children:e,nodes:t,edges:n,defaultNodes:o,defaultEdges:r,width:s,height:i,fitView:a,fitViewOptions:c,minZoom:l,maxZoom:u,nodeOrigin:f,nodeExtent:d,zIndexMode:g}){return $.useContext(Zt)?_.jsx(_.Fragment,{children:e}):_.jsx(nh,{initialNodes:t,initialEdges:n,defaultNodes:o,defaultEdges:r,initialWidth:s,initialHeight:i,fitView:a,initialFitViewOptions:c,initialMinZoom:l,initialMaxZoom:u,nodeOrigin:f,nodeExtent:d,zIndexMode:g,children:e})}const rh={width:"100%",height:"100%",overflow:"hidden",position:"relative",zIndex:0};function ih({nodes:e,edges:t,defaultNodes:n,defaultEdges:o,className:r,nodeTypes:s,edgeTypes:i,onNodeClick:a,onEdgeClick:c,onInit:l,onMove:u,onMoveStart:f,onMoveEnd:d,onConnect:g,onConnectStart:p,onConnectEnd:x,onClickConnectStart:w,onClickConnectEnd:m,onNodeMouseEnter:b,onNodeMouseMove:h,onNodeMouseLeave:y,onNodeContextMenu:S,onNodeDoubleClick:E,onNodeDragStart:C,onNodeDrag:P,onNodeDragStop:D,onNodesDelete:V,onEdgesDelete:I,onDelete:z,onSelectionChange:H,onSelectionDragStart:v,onSelectionDrag:M,onSelectionDragStop:N,onSelectionContextMenu:A,onSelectionStart:k,onSelectionEnd:T,onBeforeDelete:L,connectionMode:j,connectionLineType:R=Ne.Bezier,connectionLineStyle:F,connectionLineComponent:B,connectionLineContainerStyle:W,deleteKeyCode:K="Backspace",selectionKeyCode:Z="Shift",selectionOnDrag:O=!1,selectionMode:Y=st.Full,panActivationKeyCode:Q="Space",multiSelectionKeyCode:U=ct()?"Meta":"Control",zoomActivationKeyCode:q=ct()?"Meta":"Control",snapToGrid:G,snapGrid:ee,onlyRenderVisibleElements:ne=!1,selectNodesOnDrag:te,nodesDraggable:ae,autoPanOnNodeFocus:be,nodesConnectable:ye,nodesFocusable:Ie,nodeOrigin:We=oi,edgesFocusable:qe,edgesReconnectable:Ge,elementsSelectable:Kt=!0,defaultViewport:pt=Ad,minZoom:$e=.5,maxZoom:Ke=2,translateExtent:Vn=it,preventScrolling:$i=!0,nodeExtent:Ut,defaultMarkerColor:Hi="#b1b1b7",zoomOnScroll:Li=!0,zoomOnPinch:Ri=!0,panOnScroll:ji=!1,panOnScrollSpeed:Vi=.5,panOnScrollMode:Oi=Pe.Free,zoomOnDoubleClick:Bi=!0,panOnDrag:Fi=!0,onPaneClick:Xi,onPaneMouseEnter:Yi,onPaneMouseMove:Zi,onPaneMouseLeave:Wi,onPaneScroll:qi,onPaneContextMenu:Gi,paneClickDistance:Ki=1,nodeClickDistance:Ui=0,children:Qi,onReconnect:Ji,onReconnectStart:es,onReconnectEnd:ts,onEdgeContextMenu:ns,onEdgeDoubleClick:os,onEdgeMouseEnter:rs,onEdgeMouseMove:is,onEdgeMouseLeave:ss,reconnectRadius:as=10,onNodesChange:cs,onEdgesChange:ls,noDragClassName:us="nodrag",noWheelClassName:ds="nowheel",noPanClassName:On="nopan",fitView:Bn,fitViewOptions:Fn,connectOnClick:fs,attributionPosition:hs,proOptions:gs,defaultEdgeOptions:ps,elevateNodesOnSelect:ms=!0,elevateEdgesOnSelect:ys=!1,disableKeyboardA11y:Xn=!1,autoPanOnConnect:xs,autoPanOnNodeDrag:ws,autoPanSpeed:vs,connectionRadius:_s,isValidConnection:bs,onError:Es,style:Ss,id:Yn,nodeDragThreshold:Ns,connectionDragThreshold:Cs,viewport:Ms,onViewportChange:Is,width:ks,height:As,colorMode:Ps="light",debug:Ds,onScroll:Zn,ariaLabelConfig:Ts,zIndexMode:Wn="basic",...zs},$s){const Qt=Yn||"1",Hs=zd(Ps),Ls=$.useCallback(qn=>{qn.currentTarget.scrollTo({top:0,left:0,behavior:"instant"}),Zn?.(qn)},[Zn]);return _.jsx("div",{"data-testid":"rf__wrapper",...zs,onScroll:Ls,style:{...Ss,...rh},ref:$s,className:ie(["react-flow",r,Hs]),id:Yn,role:"application",children:_.jsxs(oh,{nodes:e,edges:t,width:ks,height:As,fitView:Bn,fitViewOptions:Fn,minZoom:$e,maxZoom:Ke,nodeOrigin:We,nodeExtent:Ut,zIndexMode:Wn,children:[_.jsx(eh,{onInit:l,onNodeClick:a,onEdgeClick:c,onNodeMouseEnter:b,onNodeMouseMove:h,onNodeMouseLeave:y,onNodeContextMenu:S,onNodeDoubleClick:E,nodeTypes:s,edgeTypes:i,connectionLineType:R,connectionLineStyle:F,connectionLineComponent:B,connectionLineContainerStyle:W,selectionKeyCode:Z,selectionOnDrag:O,selectionMode:Y,deleteKeyCode:K,multiSelectionKeyCode:U,panActivationKeyCode:Q,zoomActivationKeyCode:q,onlyRenderVisibleElements:ne,defaultViewport:pt,translateExtent:Vn,minZoom:$e,maxZoom:Ke,preventScrolling:$i,zoomOnScroll:Li,zoomOnPinch:Ri,zoomOnDoubleClick:Bi,panOnScroll:ji,panOnScrollSpeed:Vi,panOnScrollMode:Oi,panOnDrag:Fi,onPaneClick:Xi,onPaneMouseEnter:Yi,onPaneMouseMove:Zi,onPaneMouseLeave:Wi,onPaneScroll:qi,onPaneContextMenu:Gi,paneClickDistance:Ki,nodeClickDistance:Ui,onSelectionContextMenu:A,onSelectionStart:k,onSelectionEnd:T,onReconnect:Ji,onReconnectStart:es,onReconnectEnd:ts,onEdgeContextMenu:ns,onEdgeDoubleClick:os,onEdgeMouseEnter:rs,onEdgeMouseMove:is,onEdgeMouseLeave:ss,reconnectRadius:as,defaultMarkerColor:Hi,noDragClassName:us,noWheelClassName:ds,noPanClassName:On,rfId:Qt,disableKeyboardA11y:Xn,nodeExtent:Ut,viewport:Ms,onViewportChange:Is}),_.jsx(Td,{nodes:e,edges:t,defaultNodes:n,defaultEdges:o,onConnect:g,onConnectStart:p,onConnectEnd:x,onClickConnectStart:w,onClickConnectEnd:m,nodesDraggable:ae,autoPanOnNodeFocus:be,nodesConnectable:ye,nodesFocusable:Ie,edgesFocusable:qe,edgesReconnectable:Ge,elementsSelectable:Kt,elevateNodesOnSelect:ms,elevateEdgesOnSelect:ys,minZoom:$e,maxZoom:Ke,nodeExtent:Ut,onNodesChange:cs,onEdgesChange:ls,snapToGrid:G,snapGrid:ee,connectionMode:j,translateExtent:Vn,connectOnClick:fs,defaultEdgeOptions:ps,fitView:Bn,fitViewOptions:Fn,onNodesDelete:V,onEdgesDelete:I,onDelete:z,onNodeDragStart:C,onNodeDrag:P,onNodeDragStop:D,onSelectionDrag:M,onSelectionDragStart:v,onSelectionDragStop:N,onMove:u,onMoveStart:f,onMoveEnd:d,noPanClassName:On,nodeOrigin:We,rfId:Qt,autoPanOnConnect:xs,autoPanOnNodeDrag:ws,autoPanSpeed:vs,onError:Es,connectionRadius:_s,isValidConnection:bs,selectNodesOnDrag:te,nodeDragThreshold:Ns,connectionDragThreshold:Cs,onBeforeDelete:L,debug:Ds,ariaLabelConfig:Ts,zIndexMode:Wn}),_.jsx(kd,{onSelectionChange:H}),Qi,_.jsx(Sd,{proOptions:gs,position:hs}),_.jsx(Ed,{rfId:Qt,disableKeyboardA11y:Xn})]})})}var sh=ii(ih);function ah({dimensions:e,lineWidth:t,variant:n,className:o}){return _.jsx("path",{strokeWidth:t,d:`M${e[0]/2} 0 V${e[1]} M0 ${e[1]/2} H${e[0]}`,className:ie(["react-flow__background-pattern",n,o])})}function ch({radius:e,className:t}){return _.jsx("circle",{cx:e,cy:e,r:e,className:ie(["react-flow__background-pattern","dots",t])})}var Ce;(function(e){e.Lines="lines",e.Dots="dots",e.Cross="cross"})(Ce||(Ce={}));const lh={[Ce.Dots]:1,[Ce.Lines]:1,[Ce.Cross]:6},uh=e=>({transform:e.transform,patternId:`pattern-${e.rfId}`});function ki({id:e,variant:t=Ce.Dots,gap:n=20,size:o,lineWidth:r=1,offset:s=0,color:i,bgColor:a,style:c,className:l,patternClassName:u}){const f=$.useRef(null),{transform:d,patternId:g}=J(uh,oe),p=o||lh[t],x=t===Ce.Dots,w=t===Ce.Cross,m=Array.isArray(n)?n:[n,n],b=[m[0]*d[2]||1,m[1]*d[2]||1],h=p*d[2],y=Array.isArray(s)?s:[s,s],S=w?[h,h]:b,E=[y[0]*d[2]||1+S[0]/2,y[1]*d[2]||1+S[1]/2],C=`${g}${e||""}`;return _.jsxs("svg",{className:ie(["react-flow__background",l]),style:{...c,...qt,"--xy-background-color-props":a,"--xy-background-pattern-color-props":i},ref:f,"data-testid":"rf__background",children:[_.jsx("pattern",{id:C,x:d[0]%b[0],y:d[1]%b[1],width:b[0],height:b[1],patternUnits:"userSpaceOnUse",patternTransform:`translate(-${E[0]},-${E[1]})`,children:x?_.jsx(ch,{radius:h/2,className:u}):_.jsx(ah,{dimensions:S,lineWidth:r,variant:t,className:u})}),_.jsx("rect",{x:"0",y:"0",width:"100%",height:"100%",fill:`url(#${C})`})]})}ki.displayName="Background";$.memo(ki);function dh(){return _.jsx("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 32 32",children:_.jsx("path",{d:"M32 18.133H18.133V32h-4.266V18.133H0v-4.266h13.867V0h4.266v13.867H32z"})})}function fh(){return _.jsx("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 32 5",children:_.jsx("path",{d:"M0 0h32v4.2H0z"})})}function hh(){return _.jsx("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 32 30",children:_.jsx("path",{d:"M3.692 4.63c0-.53.4-.938.939-.938h5.215V0H4.708C2.13 0 0 2.054 0 4.63v5.216h3.692V4.631zM27.354 0h-5.2v3.692h5.17c.53 0 .984.4.984.939v5.215H32V4.631A4.624 4.624 0 0027.354 0zm.954 24.83c0 .532-.4.94-.939.94h-5.215v3.768h5.215c2.577 0 4.631-2.13 4.631-4.707v-5.139h-3.692v5.139zm-23.677.94c-.531 0-.939-.4-.939-.94v-5.138H0v5.139c0 2.577 2.13 4.707 4.708 4.707h5.138V25.77H4.631z"})})}function gh(){return _.jsx("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 25 32",children:_.jsx("path",{d:"M21.333 10.667H19.81V7.619C19.81 3.429 16.38 0 12.19 0 8 0 4.571 3.429 4.571 7.619v3.048H3.048A3.056 3.056 0 000 13.714v15.238A3.056 3.056 0 003.048 32h18.285a3.056 3.056 0 003.048-3.048V13.714a3.056 3.056 0 00-3.048-3.047zM12.19 24.533a3.056 3.056 0 01-3.047-3.047 3.056 3.056 0 013.047-3.048 3.056 3.056 0 013.048 3.048 3.056 3.056 0 01-3.048 3.047zm4.724-13.866H7.467V7.619c0-2.59 2.133-4.724 4.723-4.724 2.591 0 4.724 2.133 4.724 4.724v3.048z"})})}function ph(){return _.jsx("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 25 32",children:_.jsx("path",{d:"M21.333 10.667H19.81V7.619C19.81 3.429 16.38 0 12.19 0c-4.114 1.828-1.37 2.133.305 2.438 1.676.305 4.42 2.59 4.42 5.181v3.048H3.047A3.056 3.056 0 000 13.714v15.238A3.056 3.056 0 003.048 32h18.285a3.056 3.056 0 003.048-3.048V13.714a3.056 3.056 0 00-3.048-3.047zM12.19 24.533a3.056 3.056 0 01-3.047-3.047 3.056 3.056 0 013.047-3.048 3.056 3.056 0 013.048 3.048 3.056 3.056 0 01-3.048 3.047z"})})}function bt({children:e,className:t,...n}){return _.jsx("button",{type:"button",className:ie(["react-flow__controls-button",t]),...n,children:e})}const mh=e=>({isInteractive:e.nodesDraggable||e.nodesConnectable||e.elementsSelectable,minZoomReached:e.transform[2]<=e.minZoom,maxZoomReached:e.transform[2]>=e.maxZoom,ariaLabelConfig:e.ariaLabelConfig});function Ai({style:e,showZoom:t=!0,showFitView:n=!0,showInteractive:o=!0,fitViewOptions:r,onZoomIn:s,onZoomOut:i,onFitView:a,onInteractiveChange:c,className:l,children:u,position:f="bottom-left",orientation:d="vertical","aria-label":g}){const p=re(),{isInteractive:x,minZoomReached:w,maxZoomReached:m,ariaLabelConfig:b}=J(mh,oe),{zoomIn:h,zoomOut:y,fitView:S}=Ln(),E=()=>{h(),s?.()},C=()=>{y(),i?.()},P=()=>{S(r),a?.()},D=()=>{p.setState({nodesDraggable:!x,nodesConnectable:!x,elementsSelectable:!x}),c?.(!x)},V=d==="horizontal"?"horizontal":"vertical";return _.jsxs(Wt,{className:ie(["react-flow__controls",V,l]),position:f,style:e,"data-testid":"rf__controls","aria-label":g??b["controls.ariaLabel"],children:[t&&_.jsxs(_.Fragment,{children:[_.jsx(bt,{onClick:E,className:"react-flow__controls-zoomin",title:b["controls.zoomIn.ariaLabel"],"aria-label":b["controls.zoomIn.ariaLabel"],disabled:m,children:_.jsx(dh,{})}),_.jsx(bt,{onClick:C,className:"react-flow__controls-zoomout",title:b["controls.zoomOut.ariaLabel"],"aria-label":b["controls.zoomOut.ariaLabel"],disabled:w,children:_.jsx(fh,{})})]}),n&&_.jsx(bt,{className:"react-flow__controls-fitview",onClick:P,title:b["controls.fitView.ariaLabel"],"aria-label":b["controls.fitView.ariaLabel"],children:_.jsx(hh,{})}),o&&_.jsx(bt,{className:"react-flow__controls-interactive",onClick:D,title:b["controls.interactive.ariaLabel"],"aria-label":b["controls.interactive.ariaLabel"],children:x?_.jsx(ph,{}):_.jsx(gh,{})}),u]})}Ai.displayName="Controls";$.memo(Ai);function yh({id:e,x:t,y:n,width:o,height:r,style:s,color:i,strokeColor:a,strokeWidth:c,className:l,borderRadius:u,shapeRendering:f,selected:d,onClick:g}){const{background:p,backgroundColor:x}=s||{},w=i||p||x;return _.jsx("rect",{className:ie(["react-flow__minimap-node",{selected:d},l]),x:t,y:n,rx:u,ry:u,width:o,height:r,style:{fill:w,stroke:a,strokeWidth:c},shapeRendering:f,onClick:g?m=>g(m,e):void 0})}const xh=$.memo(yh),wh=e=>e.nodes.map(t=>t.id),cn=e=>e instanceof Function?e:()=>e;function vh({nodeStrokeColor:e,nodeColor:t,nodeClassName:n="",nodeBorderRadius:o=5,nodeStrokeWidth:r,nodeComponent:s=xh,onClick:i}){const a=J(wh,oe),c=cn(t),l=cn(e),u=cn(n),f=typeof window>"u"||window.chrome?"crispEdges":"geometricPrecision";return _.jsx(_.Fragment,{children:a.map(d=>_.jsx(bh,{id:d,nodeColorFunc:c,nodeStrokeColorFunc:l,nodeClassNameFunc:u,nodeBorderRadius:o,nodeStrokeWidth:r,NodeComponent:s,onClick:i,shapeRendering:f},d))})}function _h({id:e,nodeColorFunc:t,nodeStrokeColorFunc:n,nodeClassNameFunc:o,nodeBorderRadius:r,nodeStrokeWidth:s,shapeRendering:i,NodeComponent:a,onClick:c}){const{node:l,x:u,y:f,width:d,height:g}=J(p=>{const{internals:x}=p.nodeLookup.get(e),w=x.userNode,{x:m,y:b}=x.positionAbsolute,{width:h,height:y}=_e(w);return{node:w,x:m,y:b,width:h,height:y}},oe);return!l||l.hidden||!Tr(l)?null:_.jsx(a,{x:u,y:f,width:d,height:g,style:l.style,selected:!!l.selected,className:o(l),color:t(l),borderRadius:r,strokeColor:n(l),strokeWidth:s,shapeRendering:i,onClick:c,id:l.id})}const bh=$.memo(_h);var Eh=$.memo(vh);const Sh=200,Nh=150,Ch=e=>!e.hidden,Mh=e=>{const t={x:-e.transform[0]/e.transform[2],y:-e.transform[1]/e.transform[2],width:e.width/e.transform[2],height:e.height/e.transform[2]};return{viewBB:t,boundingRect:e.nodeLookup.size>0?Dr(ft(e.nodeLookup,{filter:Ch}),t):t,rfId:e.rfId,panZoom:e.panZoom,translateExtent:e.translateExtent,flowWidth:e.width,flowHeight:e.height,ariaLabelConfig:e.ariaLabelConfig}},Ih="react-flow__minimap-desc";function Pi({style:e,className:t,nodeStrokeColor:n,nodeColor:o,nodeClassName:r="",nodeBorderRadius:s=5,nodeStrokeWidth:i,nodeComponent:a,bgColor:c,maskColor:l,maskStrokeColor:u,maskStrokeWidth:f,position:d="bottom-right",onClick:g,onNodeClick:p,pannable:x=!1,zoomable:w=!1,ariaLabel:m,inversePan:b,zoomStep:h=1,offsetScale:y=5}){const S=re(),E=$.useRef(null),{boundingRect:C,viewBB:P,rfId:D,panZoom:V,translateExtent:I,flowWidth:z,flowHeight:H,ariaLabelConfig:v}=J(Mh,oe),M=e?.width??Sh,N=e?.height??Nh,A=C.width/M,k=C.height/N,T=Math.max(A,k),L=T*M,j=T*N,R=y*T,F=C.x-(L-C.width)/2-R,B=C.y-(j-C.height)/2-R,W=L+R*2,K=j+R*2,Z=`${Ih}-${D}`,O=$.useRef(0),Y=$.useRef();O.current=T,$.useEffect(()=>{if(E.current&&V)return Y.current=Ku({domNode:E.current,panZoom:V,getTransform:()=>S.getState().transform,getViewScale:()=>O.current}),()=>{Y.current?.destroy()}},[V]),$.useEffect(()=>{Y.current?.update({translateExtent:I,width:z,height:H,inversePan:b,pannable:x,zoomStep:h,zoomable:w})},[x,w,b,h,I,z,H]);const Q=g?G=>{const[ee,ne]=Y.current?.pointer(G)||[0,0];g(G,{x:ee,y:ne})}:void 0,U=p?$.useCallback((G,ee)=>{const ne=S.getState().nodeLookup.get(ee).internals.userNode;p(G,ne)},[]):void 0,q=m??v["minimap.ariaLabel"];return _.jsx(Wt,{position:d,style:{...e,"--xy-minimap-background-color-props":typeof c=="string"?c:void 0,"--xy-minimap-mask-background-color-props":typeof l=="string"?l:void 0,"--xy-minimap-mask-stroke-color-props":typeof u=="string"?u:void 0,"--xy-minimap-mask-stroke-width-props":typeof f=="number"?f*T:void 0,"--xy-minimap-node-background-color-props":typeof o=="string"?o:void 0,"--xy-minimap-node-stroke-color-props":typeof n=="string"?n:void 0,"--xy-minimap-node-stroke-width-props":typeof i=="number"?i:void 0},className:ie(["react-flow__minimap",t]),"data-testid":"rf__minimap",children:_.jsxs("svg",{width:M,height:N,viewBox:`${F} ${B} ${W} ${K}`,className:"react-flow__minimap-svg",role:"img","aria-labelledby":Z,ref:E,onClick:Q,children:[q&&_.jsx("title",{id:Z,children:q}),_.jsx(Eh,{onClick:U,nodeColor:o,nodeStrokeColor:n,nodeBorderRadius:s,nodeClassName:r,nodeStrokeWidth:i,nodeComponent:a}),_.jsx("path",{className:"react-flow__minimap-mask",d:`M${F-R},${B-R}h${W+R*2}v${K+R*2}h${-W-R*2}z
7
- M${P.x},${P.y}h${P.width}v${P.height}h${-P.width}z`,fillRule:"evenodd",pointerEvents:"none"})]})})}Pi.displayName="MiniMap";$.memo(Pi);const kh=e=>t=>e?`${Math.max(1/t.transform[2],1)}`:void 0,Ah={[Ze.Line]:"right",[Ze.Handle]:"bottom-right"};function Ph({nodeId:e,position:t,variant:n=Ze.Handle,className:o,style:r=void 0,children:s,color:i,minWidth:a=10,minHeight:c=10,maxWidth:l=Number.MAX_VALUE,maxHeight:u=Number.MAX_VALUE,keepAspectRatio:f=!1,resizeDirection:d,autoScale:g=!0,shouldResize:p,onResizeStart:x,onResize:w,onResizeEnd:m}){const b=li(),h=typeof e=="string"?e:b,y=re(),S=$.useRef(null),E=n===Ze.Handle,C=J($.useCallback(kh(E&&g),[E,g]),oe),P=$.useRef(null),D=t??Ah[n];$.useEffect(()=>{if(!(!S.current||!h))return P.current||(P.current=ud({domNode:S.current,nodeId:h,getStoreItems:()=>{const{nodeLookup:I,transform:z,snapGrid:H,snapToGrid:v,nodeOrigin:M,domNode:N}=y.getState();return{nodeLookup:I,transform:z,snapGrid:H,snapToGrid:v,nodeOrigin:M,paneDomNode:N}},onChange:(I,z)=>{const{triggerNodeChanges:H,nodeLookup:v,parentLookup:M,nodeOrigin:N}=y.getState(),A=[],k={x:I.x,y:I.y},T=v.get(h);if(T&&T.expandParent&&T.parentId){const L=T.origin??N,j=I.width??T.measured.width??0,R=I.height??T.measured.height??0,F={id:T.id,parentId:T.parentId,rect:{width:j,height:R,...zr({x:I.x??T.position.x,y:I.y??T.position.y},{width:j,height:R},T.parentId,v,L)}},B=Hn([F],v,M,N);A.push(...B),k.x=I.x?Math.max(L[0]*j,I.x):void 0,k.y=I.y?Math.max(L[1]*R,I.y):void 0}if(k.x!==void 0&&k.y!==void 0){const L={id:h,type:"position",position:{...k}};A.push(L)}if(I.width!==void 0&&I.height!==void 0){const j={id:h,type:"dimensions",resizing:!0,setAttributes:d?d==="horizontal"?"width":"height":!0,dimensions:{width:I.width,height:I.height}};A.push(j)}for(const L of z){const j={...L,type:"position"};A.push(j)}H(A)},onEnd:({width:I,height:z})=>{const H={id:h,type:"dimensions",resizing:!1,dimensions:{width:I,height:z}};y.getState().triggerNodeChanges([H])}})),P.current.update({controlPosition:D,boundaries:{minWidth:a,minHeight:c,maxWidth:l,maxHeight:u},keepAspectRatio:f,resizeDirection:d,onResizeStart:x,onResize:w,onResizeEnd:m,shouldResize:p}),()=>{P.current?.destroy()}},[D,a,c,l,u,f,x,w,m,p]);const V=D.split("-");return _.jsx("div",{className:ie(["react-flow__resize-control","nodrag",...V,n,o]),ref:S,style:{...r,scale:C,...i&&{[E?"backgroundColor":"borderColor"]:i}},children:s})}$.memo(Ph);const Di=$.createContext(void 0);function Ti(){const e=$.useContext(Di);if(!e)throw new Error("useMetricsMode must be used within MetricsModeProvider");return e}function Dh(e){const t=ue.c(5),{children:n}=e,[o,r]=$.useState("requests");let s;t[0]!==o?(s={metricsMode:o,setMetricsMode:r},t[0]=o,t[1]=s):s=t[1];let i;return t[2]!==n||t[3]!==s?(i=_.jsx(Di.Provider,{value:s,children:n}),t[2]=n,t[3]=s,t[4]=i):i=t[4],i}const Zo=10,Lt=56,jn=220,nt=56,Th={requests:{edgeColor:"var(--chart-1)",textClass:"text-chart-1"},errors:{edgeColor:"var(--chart-3)",textClass:"text-chart-3"},latency:{edgeColor:"var(--chart-4)",textClass:"text-chart-4"}};function zh(){const e=Date.now(),t=300*1e3,n=Math.floor(e/t)*t,o=new Date(n);return{startDate:new Date(n-1440*60*1e3).toISOString(),endDate:o.toISOString()}}function $h(e){const t=new Map,n=new Map;for(const s of e){const i=s.connectionId;if(i){const c=n.get(i)??{requests:0,errors:0,totalLatency:0};n.set(i,{requests:c.requests+1,errors:c.errors+(s.isError?1:0),totalLatency:c.totalLatency+s.durationMs})}const a=s.gatewayId;if(a){const c=t.get(a)??{requests:0,errors:0,totalLatency:0};t.set(a,{requests:c.requests+1,errors:c.errors+(s.isError?1:0),totalLatency:c.totalLatency+s.durationMs})}}const o=new Map;for(const[s,i]of t)o.set(s,{requests:i.requests,errors:i.errors,errorRate:i.requests>0?i.errors/i.requests*100:0,avgLatencyMs:i.requests>0?i.totalLatency/i.requests:0});const r=new Map;for(const[s,i]of n)r.set(s,{requests:i.requests,errors:i.errors,errorRate:i.requests>0?i.errors/i.requests*100:0,avgLatencyMs:i.requests>0?i.totalLatency/i.requests:0});return{gateways:o,connections:r}}function zi(e,t){if(!e)return"—";switch(t){case"requests":return e.requests===0?"—":e.requests.toLocaleString();case"errors":return e.errorRate===0?"—":`${e.errorRate.toFixed(1)}%`;case"latency":return e.avgLatencyMs===0?"—":`${Math.round(e.avgLatencyMs)}ms`}}function Et(e,t){if(!e)return 0;switch(t){case"requests":return e.requests;case"errors":return e.errorRate;case"latency":return e.avgLatencyMs}}function Hh(){const e=ue.c(9),{locator:t}=bn();let n;e[0]===Symbol.for("react.memo_cache_sentinel")?(n=Ws(),e[0]=n):n=e[0];const o=n;let r;e[1]===Symbol.for("react.memo_cache_sentinel")?(r=zh(),e[1]=r):r=e[1];const s=r;let i;e[2]===Symbol.for("react.memo_cache_sentinel")?(i={...s,limit:1e3,offset:0},e[2]=i):i=e[2];let a;e[3]!==t?(a={toolCaller:o,toolName:"MONITORING_LOGS_LIST",toolInputParams:i,scope:t,staleTime:3e4},e[3]=t,e[4]=a):a=e[4];const{data:c}=Qs(a);let l;e[5]!==c?.logs?(l=c?.logs??[],e[5]=c?.logs,e[6]=l):l=e[6];const u=l;let f;return e[7]!==u?(f=$h(u),e[7]=u,e[8]=f):f=e[8],f}function Lh(e){const t=ue.c(29),{data:n}=e,o=_n();let r;t[0]!==n.metric||t[1]!==n.metricsMode?(r=zi(n.metric,n.metricsMode),t[0]=n.metric,t[1]=n.metricsMode,t[2]=r):r=t[2];const s=r;let i;t[3]!==n.gateway.id||t[4]!==n.org||t[5]!==o?(i=()=>{o({to:"/$org/gateways/$gatewayId",params:{org:n.org,gatewayId:n.gateway.id}})},t[3]=n.gateway.id,t[4]=n.org,t[5]=o,t[6]=i):i=t[6];const a=i;let c;t[7]===Symbol.for("react.memo_cache_sentinel")?(c={height:Lt,width:jn},t[7]=c):c=t[7];let l;t[8]===Symbol.for("react.memo_cache_sentinel")?(l=_.jsx(Ks,{}),t[8]=l):l=t[8];let u;t[9]!==n.gateway.icon||t[10]!==n.gateway.title?(u=_.jsx(Uo,{icon:n.gateway.icon,name:n.gateway.title,size:"md",fallbackIcon:l,className:"relative z-10"}),t[9]=n.gateway.icon,t[10]=n.gateway.title,t[11]=u):u=t[11];let f;t[12]!==n.gateway.title?(f=_.jsx("span",{className:"text-sm text-muted-foreground truncate",children:n.gateway.title}),t[12]=n.gateway.title,t[13]=f):f=t[13];let d;t[14]!==n.colorScheme.textClass?(d=qo("text-base leading-none font-semibold tabular-nums",n.colorScheme.textClass),t[14]=n.colorScheme.textClass,t[15]=d):d=t[15];let g;t[16]!==s||t[17]!==d?(g=_.jsx("span",{className:d,children:s}),t[16]=s,t[17]=d,t[18]=g):g=t[18];let p;t[19]!==f||t[20]!==g?(p=_.jsxs("div",{className:"relative z-10 flex flex-col min-w-0 flex-1",children:[f,g]}),t[19]=f,t[20]=g,t[21]=p):p=t[21];let x;t[22]!==n.colorScheme.edgeColor?(x=_.jsx(Me,{type:"source",position:X.Right,style:{width:"8px",height:"8px",background:n.colorScheme.edgeColor,border:"none"}}),t[22]=n.colorScheme.edgeColor,t[23]=x):x=t[23];let w;return t[24]!==a||t[25]!==x||t[26]!==u||t[27]!==p?(w=_.jsxs("div",{className:"relative flex shrink-0 items-center gap-2 pl-1.5 pr-3 bg-background rounded-lg border-shadow nodrag nopan cursor-pointer pointer-events-auto before:absolute before:inset-0 before:rounded-lg before:bg-accent/25 before:opacity-0 hover:before:opacity-100 before:transition-opacity before:duration-800 before:pointer-events-none",style:c,onClick:a,children:[u,p,x]}),t[24]=a,t[25]=x,t[26]=u,t[27]=p,t[28]=w):w=t[28],w}function Rh(e){const t=ue.c(29),{data:n}=e,o=_n();let r;t[0]!==n.metric||t[1]!==n.metricsMode?(r=zi(n.metric,n.metricsMode),t[0]=n.metric,t[1]=n.metricsMode,t[2]=r):r=t[2];const s=r;let i;t[3]!==n.connection.id||t[4]!==n.org||t[5]!==o?(i=()=>{o({to:"/$org/mcps/$connectionId",params:{org:n.org,connectionId:n.connection.id}})},t[3]=n.connection.id,t[4]=n.org,t[5]=o,t[6]=i):i=t[6];const a=i;let c;t[7]===Symbol.for("react.memo_cache_sentinel")?(c={height:Lt,width:jn},t[7]=c):c=t[7];const l=`1px solid ${n.colorScheme.edgeColor}`;let u;t[8]!==l?(u=_.jsx(Me,{type:"target",position:X.Left,style:{width:"8px",height:"8px",background:"var(--background)",border:l,pointerEvents:"none",cursor:"default"}}),t[8]=l,t[9]=u):u=t[9];let f;t[10]===Symbol.for("react.memo_cache_sentinel")?(f=_.jsx(qs,{}),t[10]=f):f=t[10];let d;t[11]!==n.connection.icon||t[12]!==n.connection.title?(d=_.jsx(Uo,{icon:n.connection.icon,name:n.connection.title,size:"md",fallbackIcon:f,className:"relative z-10"}),t[11]=n.connection.icon,t[12]=n.connection.title,t[13]=d):d=t[13];let g;t[14]!==n.connection.title?(g=_.jsx("span",{className:"text-sm text-muted-foreground truncate",children:n.connection.title}),t[14]=n.connection.title,t[15]=g):g=t[15];let p;t[16]!==n.colorScheme.textClass?(p=qo("text-base leading-[1.35] font-semibold tabular-nums",n.colorScheme.textClass),t[16]=n.colorScheme.textClass,t[17]=p):p=t[17];let x;t[18]!==s||t[19]!==p?(x=_.jsx("span",{className:p,children:s}),t[18]=s,t[19]=p,t[20]=x):x=t[20];let w;t[21]!==x||t[22]!==g?(w=_.jsxs("div",{className:"relative z-10 flex flex-col min-w-0 flex-1",children:[g,x]}),t[21]=x,t[22]=g,t[23]=w):w=t[23];let m;return t[24]!==a||t[25]!==w||t[26]!==u||t[27]!==d?(m=_.jsxs("div",{className:"relative flex shrink-0 items-center gap-2 pl-1.5 pr-3 bg-background rounded-lg border-shadow nodrag nopan cursor-pointer pointer-events-auto before:absolute before:inset-0 before:rounded-lg before:bg-accent/25 before:opacity-0 hover:before:opacity-100 before:transition-opacity before:duration-800 before:pointer-events-none",style:c,onClick:a,children:[u,d,w]}),t[24]=a,t[25]=w,t[26]=u,t[27]=d,t[28]=m):m=t[28],m}function jh(e){const t=ue.c(9),{data:n}=e,o=_n();let r;t[0]!==n.org||t[1]!==o?(r=()=>{o({to:"/$org/store",params:{org:n.org}})},t[0]=n.org,t[1]=o,t[2]=r):r=t[2];const s=r;let i;t[3]===Symbol.for("react.memo_cache_sentinel")?(i={height:nt,width:nt},t[3]=i):i=t[3];let a,c;t[4]===Symbol.for("react.memo_cache_sentinel")?(a=_.jsx(Me,{type:"target",position:X.Left,style:{opacity:0,pointerEvents:"none"}}),c=_.jsx("img",{src:"/logos/deco logo.svg",alt:"Deco",className:"h-8 w-8"}),t[4]=a,t[5]=c):(a=t[4],c=t[5]);let l;t[6]===Symbol.for("react.memo_cache_sentinel")?(l=_.jsx(Me,{type:"source",position:X.Right,style:{opacity:0,pointerEvents:"none"}}),t[6]=l):l=t[6];let u;return t[7]!==s?(u=_.jsxs("div",{className:"flex items-center justify-center p-2 bg-primary border border-primary-foreground/50 rounded-lg shadow-sm cursor-pointer pointer-events-auto",style:i,onClick:s,children:[a,c,l]}),t[7]=s,t[8]=u):u=t[8],u}const Vh={gateway:Lh,server:Rh,mesh:jh};function Oh(){const e=ue.c(8),{metricsMode:t,setMetricsMode:n}=Ti();let o;e[0]!==n?(o=c=>c&&n(c),e[0]=n,e[1]=o):o=e[1];let r,s,i;e[2]===Symbol.for("react.memo_cache_sentinel")?(r=_.jsx(en,{value:"requests",className:"text-xs px-3 cursor-pointer",children:"Tool Calls"}),s=_.jsx(en,{value:"errors",className:"text-xs px-3 cursor-pointer",children:"Errors"}),i=_.jsx(en,{value:"latency",className:"text-xs px-3 cursor-pointer",children:"Latency"}),e[2]=r,e[3]=s,e[4]=i):(r=e[2],s=e[3],i=e[4]);let a;return e[5]!==t||e[6]!==o?(a=_.jsxs(ea,{type:"single",value:t,onValueChange:o,variant:"outline",size:"sm",className:"bg-background/80 backdrop-blur-sm",children:[r,s,i]}),e[5]=t,e[6]=o,e[7]=a):a=e[7],a}function Bh(){const e=ue.c(36),{metricsMode:t}=Ti(),{org:n}=bn();let o;e[0]===Symbol.for("react.memo_cache_sentinel")?(o={pageSize:Zo},e[0]=o):o=e[0];const r=Gs(o);let s;e[1]===Symbol.for("react.memo_cache_sentinel")?(s={pageSize:Zo},e[1]=s):s=e[1];const i=Us(s),a=Hh();let c,l,u,f,d;if(e[2]!==t||e[3]!==a||e[4]!==i||e[5]!==r){let I;e[11]!==t||e[12]!==a?(I=(H,v)=>Et(a.gateways.get(v.id),t)-Et(a.gateways.get(H.id),t),e[11]=t,e[12]=a,e[13]=I):I=e[13],d=[...r].sort(I);let z;e[14]!==t||e[15]!==a?(z=(H,v)=>Et(a.connections.get(v.id),t)-Et(a.connections.get(H.id),t),e[14]=t,e[15]=a,e[16]=z):z=e[16],f=[...i].sort(z),c=Th[t],u=new Map,d.forEach((H,v)=>u.set(H.id,v)),l=new Map,f.forEach((H,v)=>l.set(H.id,v)),e[2]=t,e[3]=a,e[4]=i,e[5]=r,e[6]=c,e[7]=l,e[8]=u,e[9]=f,e[10]=d}else c=e[6],l=e[7],u=e[8],f=e[9],d=e[10];const g=-nt/2,p=nt/2,x=g-100-jn,w=p+100,m=d.length,b=f.length;let h,y;if(e[17]!==c||e[18]!==l||e[19]!==u||e[20]!==m||e[21]!==t||e[22]!==a||e[23]!==n.slug||e[24]!==i||e[25]!==r||e[26]!==b){const I={stroke:c.edgeColor,strokeWidth:1.25,strokeDasharray:"8 6",strokeLinecap:"square"};y=[],h=[],y.push({id:"mesh",type:"mesh",position:{x:g,y:-nt/2},data:{org:n.slug,colorScheme:c},draggable:!1,selectable:!1}),[...r].sort(Xh).forEach(v=>{const A=((u.get(v.id)??0)-(m-1)/2)*70-Lt/2;y.push({id:`gateway-${v.id}`,type:"gateway",position:{x,y:A},data:{gateway:v,metricsMode:t,metric:a.gateways.get(v.id),colorScheme:c,org:n.slug},draggable:!1,selectable:!1}),h.push({id:`e-gw-${v.id}`,source:`gateway-${v.id}`,target:"mesh",type:"smoothstep",animated:!0,style:I})}),[...i].sort(Fh).forEach(v=>{const A=((l.get(v.id)??0)-(b-1)/2)*70-Lt/2;y.push({id:`server-${v.id}`,type:"server",position:{x:w,y:A},data:{connection:v,metricsMode:t,metric:a.connections.get(v.id),colorScheme:c,org:n.slug},draggable:!1,selectable:!1}),h.push({id:`e-srv-${v.id}`,source:"mesh",target:`server-${v.id}`,type:"smoothstep",animated:!0,style:I})}),e[17]=c,e[18]=l,e[19]=u,e[20]=m,e[21]=t,e[22]=a,e[23]=n.slug,e[24]=i,e[25]=r,e[26]=b,e[27]=h,e[28]=y}else h=e[27],y=e[28];let S;e[29]===Symbol.for("react.memo_cache_sentinel")?(S={backgroundImage:"radial-gradient(circle, var(--border) 1px, transparent 1.5px)",backgroundSize:"32px 32px"},e[29]=S):S=e[29];const E=S;let C;e[30]===Symbol.for("react.memo_cache_sentinel")?(C=_.jsx("style",{children:`
8
- .mesh-minimap .react-flow__node { transition: transform 300ms ease-out; }
9
- .mesh-minimap .react-flow__edge path { transition: d 300ms ease-out; }
10
- .mesh-minimap .react-flow__edge.animated path {
11
- animation: dashdraw 0.8s linear infinite;
12
- }
13
- @keyframes dashdraw {
14
- from {
15
- stroke-dashoffset: 0;
16
- }
17
- to {
18
- stroke-dashoffset: -14;
19
- }
20
- }
21
- `}),e[30]=C):C=e[30];let P;e[31]===Symbol.for("react.memo_cache_sentinel")?(P={padding:.3},e[31]=P):P=e[31];let D;e[32]===Symbol.for("react.memo_cache_sentinel")?(D={hideAttribution:!0},e[32]=D):D=e[32];let V;return e[33]!==h||e[34]!==y?(V=_.jsxs("div",{className:"w-full h-full min-h-[420px] relative mesh-minimap bg-background",style:E,children:[C,_.jsx(sh,{nodes:y,edges:h,nodeTypes:Vh,fitView:!0,fitViewOptions:P,nodesDraggable:!1,nodesConnectable:!1,elementsSelectable:!0,zoomOnScroll:!0,zoomOnPinch:!0,zoomOnDoubleClick:!0,panOnScroll:!1,panOnDrag:!0,preventScrolling:!0,proOptions:D,className:"bg-transparent"})]}),e[33]=h,e[34]=y,e[35]=V):V=e[35],V}function Fh(e,t){return e.id.localeCompare(t.id)}function Xh(e,t){return e.id.localeCompare(t.id)}function Yh(){const e=ue.c(3);let t,n;e[0]===Symbol.for("react.memo_cache_sentinel")?(t=_.jsx("div",{className:"flex flex-col gap-3",children:[1,2,3,4,5].map(Wh)}),n=_.jsx("div",{className:"h-14 w-28 bg-muted animate-pulse rounded-xl"}),e[0]=t,e[1]=n):(t=e[0],n=e[1]);let o;return e[2]===Symbol.for("react.memo_cache_sentinel")?(o=_.jsx("div",{className:"bg-background p-5 h-full min-h-[420px] flex items-center justify-center",children:_.jsxs("div",{className:"flex items-center gap-16",children:[t,n,_.jsx("div",{className:"flex flex-col gap-3",children:[1,2,3,4,5].map(Zh)})]})}),e[2]=o):o=e[2],o}function Zh(e){return _.jsx("div",{className:"h-14 w-[220px] bg-muted animate-pulse rounded-lg"},e)}function Wh(e){return _.jsx("div",{className:"h-14 w-[220px] bg-muted animate-pulse rounded-lg"},e)}function qh(){const e=new Date().getHours();return e>=5&&e<12?"Morning":e>=12&&e<17?"Afternoon":e>=17&&e<22?"Evening":"Night"}function Gh(e){const t=ue.c(12),{text:n,className:o,speed:r}=e,s=o===void 0?"":o,i=r===void 0?30:r,a=n.length/i*1e3,c=n.length,l=`${n.length}ch`,u=`${a}ms`;let f;t[0]!==l||t[1]!==c||t[2]!==u?(f={"--typewriter-duration":u,"--typewriter-steps":c,"--typewriter-max-width":l},t[0]=l,t[1]=c,t[2]=u,t[3]=f):f=t[3];const d=f;let g;t[4]!==n?(g=_.jsx("span",{className:"typewriter-text",children:n}),t[4]=n,t[5]=g):g=t[5];let p;t[6]===Symbol.for("react.memo_cache_sentinel")?(p=_.jsx("style",{children:`
22
- .typewriter-text {
23
- display: inline-block;
24
- width: 0;
25
- overflow: hidden;
26
- white-space: nowrap;
27
- animation: typewriter var(--typewriter-duration) steps(var(--typewriter-steps)) forwards;
28
- }
29
-
30
- @keyframes typewriter {
31
- to {
32
- width: var(--typewriter-max-width);
33
- }
34
- }
35
- `}),t[6]=p):p=t[6];let x;return t[7]!==s||t[8]!==d||t[9]!==g||t[10]!==n?(x=_.jsxs("span",{className:s,style:d,children:[g,p]},n),t[7]=s,t[8]=d,t[9]=g,t[10]=n,t[11]=x):x=t[11],x}function Kh(){const e=ue.c(33),{org:t,locator:n}=bn(),{createThread:o,activeThread:r,modelsConnections:s,isChatEmpty:i}=Bs(),{data:a}=Os.useSession(),[c,l]=Fs(`${n}:home-view-mode`,"chat");let u;e[0]!==a?.user?.name?(u=a?.user?.name?.split(" ")[0]||"there",e[0]=a?.user?.name,e[1]=u):u=e[1];const f=u;let d;e[2]===Symbol.for("react.memo_cache_sentinel")?(d=qh(),e[2]=d):d=e[2];const g=d;if(s.length===0){let P;return e[3]!==t?(P=_.jsx("div",{className:"flex flex-col size-full bg-background items-center justify-center",children:_.jsx(se.NoLlmBindingEmptyState,{org:t})}),e[3]=t,e[4]=P):P=e[4],P}let p;e[5]!==r||e[6]!==i||e[7]!==c?(p=_.jsx(se.Header.Left,{children:c==="graph"?_.jsx("span",{className:"text-sm font-medium text-foreground",children:"Summary"}):!i&&r?.title?_.jsx(Gh,{text:r.title,className:"text-sm font-medium text-foreground"}):_.jsx("span",{className:"text-sm font-medium text-foreground",children:"Chat"})}),e[5]=r,e[6]=i,e[7]=c,e[8]=p):p=e[8];let x;e[9]!==c?(x=c==="graph"&&_.jsx(Oh,{}),e[9]=c,e[10]=x):x=e[10];let w;e[11]!==o||e[12]!==c?(w=c!=="graph"&&_.jsxs(_.Fragment,{children:[_.jsx(Go,{type:"button",variant:"outline",size:"icon",className:"size-7 border border-input",onClick:()=>o(),"aria-label":"New chat",children:_.jsx(Zs,{size:16})}),_.jsx(se.ThreadHistoryPopover,{variant:"outline"})]}),e[11]=o,e[12]=c,e[13]=w):w=e[13];let m;e[14]===Symbol.for("react.memo_cache_sentinel")?(m={value:"chat",icon:_.jsx(Ko,{})},e[14]=m):m=e[14];let b;e[15]===Symbol.for("react.memo_cache_sentinel")?(b=[m,{value:"graph",icon:_.jsx(Ys,{})}],e[15]=b):b=e[15];let h;e[16]!==l||e[17]!==c?(h=_.jsx(Xs,{value:c,onValueChange:l,size:"sm",options:b}),e[16]=l,e[17]=c,e[18]=h):h=e[18];let y;e[19]!==x||e[20]!==w||e[21]!==h?(y=_.jsxs(se.Header.Right,{children:[x,w,h]}),e[19]=x,e[20]=w,e[21]=h,e[22]=y):y=e[22];let S;e[23]!==p||e[24]!==y?(S=_.jsxs(se.Header,{children:[p,y]}),e[23]=p,e[24]=y,e[25]=S):S=e[25];let E;e[26]!==i||e[27]!==f||e[28]!==c?(E=c==="graph"?_.jsx("div",{className:"flex-1 overflow-hidden relative",children:_.jsx(Wo,{fallback:_.jsx("div",{className:"bg-background p-5 text-sm text-muted-foreground h-full flex items-center justify-center",children:"Failed to load mesh visualization"}),children:_.jsx($.Suspense,{fallback:_.jsx(Yh,{}),children:_.jsx(Bh,{})})})}):i?_.jsx("div",{className:"flex-1 min-h-0 flex flex-col items-center justify-center px-10 pb-32 pt-10",children:_.jsxs("div",{className:"flex flex-col items-center gap-6 w-full max-w-[550px]",children:[_.jsxs("div",{className:"text-center",children:[_.jsxs("p",{className:"text-lg font-medium text-foreground",children:[g," ",f,","]}),_.jsx("p",{className:"text-base text-muted-foreground",children:"What are we building today?"})]}),_.jsx(se.Input,{}),_.jsx(se.IceBreakers,{className:"w-full"})]})}):_.jsxs(_.Fragment,{children:[_.jsx(se.Main,{children:_.jsx(se.Messages,{minHeightOffset:280})}),_.jsx(se.Footer,{children:_.jsx(se.Input,{})})]}),e[26]=i,e[27]=f,e[28]=c,e[29]=E):E=e[29];let C;return e[30]!==E||e[31]!==S?(C=_.jsx(Dh,{children:_.jsxs(se,{children:[S,E]})}),e[30]=E,e[31]=S,e[32]=C):C=e[32],C}function Uh(e){const t=ue.c(14),{error:n,onRetry:o}=e,r=n?.message?.includes("401")||n?.message?.toLowerCase().includes("unauthorized");let s;t[0]===Symbol.for("react.memo_cache_sentinel")?(s=_.jsxs(se.Header,{children:[_.jsx(se.Header.Left,{children:_.jsx("span",{className:"text-sm font-medium text-foreground",children:"Chat"})}),_.jsx(se.Header.Right,{})]}),t[0]=s):s=t[0];let i;t[1]===Symbol.for("react.memo_cache_sentinel")?(i=_.jsx("div",{className:"bg-destructive/10 p-3 rounded-full mx-auto w-fit",children:_.jsx(Ko,{className:"h-6 w-6 text-destructive"})}),t[1]=i):i=t[1];const a=r?"Unable to load models":"Something went wrong";let c;t[2]!==a?(c=_.jsx("h3",{className:"text-lg font-medium",children:a}),t[2]=a,t[3]=c):c=t[3];const l=r?"There was an authentication error while loading the models. This might be due to an expired session or invalid API key.":n?.message||"An unexpected error occurred";let u;t[4]!==l?(u=_.jsx("p",{className:"text-sm text-muted-foreground",children:l}),t[4]=l,t[5]=u):u=t[5];let f;t[6]!==c||t[7]!==u?(f=_.jsxs("div",{className:"space-y-2",children:[c,u]}),t[6]=c,t[7]=u,t[8]=f):f=t[8];let d;t[9]!==o?(d=_.jsx(Go,{variant:"outline",onClick:o,children:"Try again"}),t[9]=o,t[10]=d):d=t[10];let g;return t[11]!==f||t[12]!==d?(g=_.jsxs(se,{children:[s,_.jsx("div",{className:"flex-1 flex flex-col items-center justify-center p-6 text-center",children:_.jsxs("div",{className:"max-w-sm space-y-4",children:[i,f,d]})})]}),t[11]=f,t[12]=d,t[13]=g):g=t[13],g}function Yg(){const e=ue.c(4),t=Vs();let n;e[0]===Symbol.for("react.memo_cache_sentinel")?(n=_.jsx(se.Skeleton,{}),e[0]=n):n=e[0];let o;e[1]===Symbol.for("react.memo_cache_sentinel")?(o=_.jsx(Kh,{}),e[1]=o):o=e[1];let r;return e[2]!==t.location.pathname?(r=_.jsx(Wo,{fallback:Qh,children:_.jsx($.Suspense,{fallback:n,children:_.jsx(se.Provider,{children:o},t.location.pathname)})}),e[2]=t.location.pathname,e[3]=r):r=e[3],r}function Qh(e){const{error:t,resetError:n}=e;return _.jsx(Uh,{error:t,onRetry:n})}export{Yg as default};