@decocms/mesh 2.4.0 → 2.4.2

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 (108) hide show
  1. package/dist/client/assets/{AlertCircle-BZ4bvRfi.js → AlertCircle-CZPV4eTQ.js} +1 -1
  2. package/dist/client/assets/{ArrowLeft-CoE0Hi8I.js → ArrowLeft-DQOG1GuJ.js} +1 -1
  3. package/dist/client/assets/{ChevronDown-Bd6n8txO.js → ChevronDown-Cdy__m-8.js} +1 -1
  4. package/dist/client/assets/{ChevronRight-Bc43l_p6.js → ChevronRight-SzPzGSNO.js} +1 -1
  5. package/dist/client/assets/{Copy01-BTTTCefb.js → Copy01-DS49wIzW.js} +1 -1
  6. package/dist/client/assets/{DotsHorizontal-Dh410BM1.js → DotsHorizontal-BSoB0mo2.js} +1 -1
  7. package/dist/client/assets/{DotsVertical-C-Nfqo18.js → DotsVertical-eZBspOrA.js} +1 -1
  8. package/dist/client/assets/{File06-td5gmARz.js → File06-CUqAuIUq.js} +1 -1
  9. package/dist/client/assets/{FilterLines-nczF4lnr.js → FilterLines-BTBF9JAn.js} +1 -1
  10. package/dist/client/assets/{FlipBackward-BLl0wh4k.js → FlipBackward-BRcPqCms.js} +1 -1
  11. package/dist/client/assets/{GitBranch01-38L6KUpt.js → GitBranch01-DovnqKJf.js} +1 -1
  12. package/dist/client/assets/{Grid01-Dl_1kAd5.js → Grid01-R-k411L-.js} +1 -1
  13. package/dist/client/assets/{Inbox01-CDma1les.js → Inbox01-bvdCozgs.js} +1 -1
  14. package/dist/client/assets/{InfoCircle-D8z5_ZlN.js → InfoCircle-r2yyYHHv.js} +1 -1
  15. package/dist/client/assets/{Key01-Cn9byqjY.js → Key01-BWe_1dg2.js} +1 -1
  16. package/dist/client/assets/{LinkExternal01-BP_6WzCI.js → LinkExternal01-BklnopGx.js} +1 -1
  17. package/dist/client/assets/{Loading01-5lHx4rM1.js → Loading01-C0_l8AxO.js} +1 -1
  18. package/dist/client/assets/{Lock01-S5DjMaRE.js → Lock01-C7_8eECJ.js} +1 -1
  19. package/dist/client/assets/{Play-DIUg73qU.js → Play-CWJY4nY_.js} +1 -1
  20. package/dist/client/assets/{Plus-wptRVGuY.js → Plus-KTlOMNSY.js} +1 -1
  21. package/dist/client/assets/{Terminal-BC7AwEkQ.js → Terminal-DDfP4x2i.js} +1 -1
  22. package/dist/client/assets/{Trash01-DMq1QD3Y.js → Trash01-BMJLKtdF.js} +1 -1
  23. package/dist/client/assets/{X-C6XvUpZP.js → X-BFdZnqth.js} +1 -1
  24. package/dist/client/assets/{XClose-Cb-zeLTZ.js → XClose-DTyQuBBY.js} +1 -1
  25. package/dist/client/assets/{alert-dialog-BJHrUd_j.js → alert-dialog-Dz8Vs8_m.js} +1 -1
  26. package/dist/client/assets/{auth-BIu7r9Ac.js → auth-CJNQiaii.js} +1 -1
  27. package/dist/client/assets/{auth-catchall-DC241-OB.js → auth-catchall-qU76xBKm.js} +1 -1
  28. package/dist/client/assets/{avatar-CLQivMfK.js → avatar-D4SXwEgs.js} +1 -1
  29. package/dist/client/assets/{badge-DQeqBGBY.js → badge-99kEJDtp.js} +1 -1
  30. package/dist/client/assets/{card-DCkJD1G_.js → card-DZuxbKf1.js} +1 -1
  31. package/dist/client/assets/{checkbox-BPcJKnx2.js → checkbox-Bp9oZUjM.js} +1 -1
  32. package/dist/client/assets/{collection-detail-BUFgqbfO.js → collection-detail-BB7cjHq1.js} +1 -1
  33. package/dist/client/assets/{collection-display-button-BT-sOTV4.js → collection-display-button-CqzsQ6A1.js} +1 -1
  34. package/dist/client/assets/{collection-header-Bf2EdT32.js → collection-header-BQqQNO9q.js} +1 -1
  35. package/dist/client/assets/{collection-page-C8XZ4WVW.js → collection-page-DlOERJnr.js} +1 -1
  36. package/dist/client/assets/{collection-search-UsqkgDWW.js → collection-search-CIs95Rnw.js} +1 -1
  37. package/dist/client/assets/{collection-tab-BOGtz91v.js → collection-tab-BPPicFWO.js} +1 -1
  38. package/dist/client/assets/{collection-table-wrapper-DXxcxGiG.js → collection-table-wrapper-D1OlmFUL.js} +1 -1
  39. package/dist/client/assets/{connection-card-uFFVVLla.js → connection-card-Dm43-Wul.js} +1 -1
  40. package/dist/client/assets/{connection-detail-C1_qwCFU.js → connection-detail-DXNZMYLL.js} +1 -1
  41. package/dist/client/assets/{connections-DK3N1G3E.js → connections-BB4IEP_5.js} +1 -1
  42. package/dist/client/assets/constants-BSLIcG1u.js +1 -0
  43. package/dist/client/assets/{create-organization-dialog-D5-XNsnx.js → create-organization-dialog-miyo8zQR.js} +1 -1
  44. package/dist/client/assets/{dialog-Ib7U8pHy.js → dialog-DK6VaggX.js} +1 -1
  45. package/dist/client/assets/{dropdown-menu-BiS4AW--.js → dropdown-menu-DTGJCwi0.js} +1 -1
  46. package/dist/client/assets/{empty-state-DClJbSUV.js → empty-state-DVGQ1BWZ.js} +1 -1
  47. package/dist/client/assets/{env-vars-editor-BoJcH29X.js → env-vars-editor-BG99RDNZ.js} +1 -1
  48. package/dist/client/assets/error-boundary-9rVpFVah.js +1 -0
  49. package/dist/client/assets/{extract-connection-data-jQgimjIZ.js → extract-connection-data-E0zDRO9-.js} +1 -1
  50. package/dist/client/assets/{form-BuxbGg5N.js → form-BGufVhpJ.js} +1 -1
  51. package/dist/client/assets/{gateway-detail-Dc2FefpC.js → gateway-detail-IUdVxLB4.js} +1 -1
  52. package/dist/client/assets/{gateway-selector-D3Qx1Iib.js → gateway-selector-CuwGVcxw.js} +1 -1
  53. package/dist/client/assets/{gateways-DpUjszQm.js → gateways-BA7lpBES.js} +1 -1
  54. package/dist/client/assets/{home-DNXIjorG.js → home-B5o9i0BD.js} +1 -1
  55. package/dist/client/assets/{index-B8j3yBaa.js → index-CaBiIG-r.js} +1 -1
  56. package/dist/client/assets/{index-DZBFXaT_.js → index-DHr9tFb0.js} +26 -26
  57. package/dist/client/assets/{index-Ci11bImk.js → index-Rcp5vvtf.js} +1 -1
  58. package/dist/client/assets/{input-KWjuSjzn.js → input-C4WvdKkR.js} +1 -1
  59. package/dist/client/assets/{layout-B02TxUA9.js → layout-9R3rtCy3.js} +1 -1
  60. package/dist/client/assets/{lazy-highlighter-BVbwM6hf.js → lazy-highlighter-rNRrmjMV.js} +1 -1
  61. package/dist/client/assets/{localstorage-keys-ziXXhpvN.js → localstorage-keys-DrIZl-Oa.js} +1 -1
  62. package/dist/client/assets/{login-B5NkbJv_.js → login-CaUUYoaL.js} +1 -1
  63. package/dist/client/assets/{mcp-oauth-C-LpRTvB.js → mcp-oauth-BPterAhB.js} +1 -1
  64. package/dist/client/assets/{mcp-server-detail-CFf8gW0D.js → mcp-server-detail-BmtUegeN.js} +1 -1
  65. package/dist/client/assets/{members-ZCeYH7ZZ.js → members-Dha-TTi3.js} +1 -1
  66. package/dist/client/assets/{monaco-editor-BmgaGs_i.js → monaco-editor-fWj67pSD.js} +1 -1
  67. package/dist/client/assets/{monitoring-Ct3-0i82.js → monitoring-BHqKCRpc.js} +1 -1
  68. package/dist/client/assets/{oauth-callback-BvCvOyK1.js → oauth-callback-C8SrcUYM.js} +1 -1
  69. package/dist/client/assets/page-CB2Kbqif.js +35 -0
  70. package/dist/client/assets/{page-CLwNDLuV.js → page-D_pWRusE.js} +1 -1
  71. package/dist/client/assets/{pin-to-sidebar-button-CeunWdra.js → pin-to-sidebar-button-Bau5uIKK.js} +1 -1
  72. package/dist/client/assets/{popover-CYHZWxlr.js → popover-B1hj_ypq.js} +1 -1
  73. package/dist/client/assets/{project-context-provider-6vMfUBpq.js → project-context-provider-SYQQWwHt.js} +1 -1
  74. package/dist/client/assets/{resizable-DSb7rXgM.js → resizable-oOXY1Kb2.js} +1 -1
  75. package/dist/client/assets/{resource-tabs-ChCUbmUR.js → resource-tabs-DXcOsIua.js} +1 -1
  76. package/dist/client/assets/{select-bHRpmvzh.js → select-58kzPmSH.js} +1 -1
  77. package/dist/client/assets/{settings-Czh6I7v0.js → settings-C8uZUL9P.js} +1 -1
  78. package/dist/client/assets/{shell-layout-DYtHZc0q.js → shell-layout-BXan9A9l.js} +1 -1
  79. package/dist/client/assets/{spinner-A1jsF1CN.js → spinner-BmiYLJkt.js} +1 -1
  80. package/dist/client/assets/{switch-RYFLASzA.js → switch-D3qS-cJT.js} +1 -1
  81. package/dist/client/assets/{textarea-_Mx18lUV.js → textarea-KpHZNzGY.js} +1 -1
  82. package/dist/client/assets/{thread-history-popover-CbjIrBTu.js → thread-history-popover-DrZ24omE.js} +4 -4
  83. package/dist/client/assets/{tools-list-DqY4kR2l.js → tools-list-BQ6I_zS0.js} +1 -1
  84. package/dist/client/assets/{use-binding-Dh7eSguQ.js → use-binding-DxCldqD_.js} +9 -9
  85. package/dist/client/assets/{use-connection-BVMsW9fR.js → use-connection-gZqQ1FAI.js} +1 -1
  86. package/dist/client/assets/{use-connection-resources-Cp6HGagD.js → use-connection-resources-CBnleHDw.js} +1 -1
  87. package/dist/client/assets/{use-gateway-DJ2wz6GD.js → use-gateway-BAeublLm.js} +1 -1
  88. package/dist/client/assets/{use-gateway-system-prompt-FrFSJufL.js → use-gateway-system-prompt-DcPNvMKK.js} +1 -1
  89. package/dist/client/assets/{use-list-state-2Noltein.js → use-list-state-_DXZxdCV.js} +1 -1
  90. package/dist/client/assets/{use-mcp-DbxIdwzm.js → use-mcp-DVQixgJB.js} +1 -1
  91. package/dist/client/assets/{use-members-CvEmo-Qp.js → use-members-Ba-WS8jO.js} +1 -1
  92. package/dist/client/assets/{use-mobile-Cj5IONVM.js → use-mobile-CXfyAVoY.js} +1 -1
  93. package/dist/client/assets/{use-organization-settings-Bz3g4Zpi.js → use-organization-settings-g1OUF8Uc.js} +1 -1
  94. package/dist/client/assets/{use-tool-call-VY44CqK6.js → use-tool-call-DYbV_cs9.js} +1 -1
  95. package/dist/client/assets/{useQueries-BiKtsYpJ.js → useQueries-DAJGlQiv.js} +1 -1
  96. package/dist/client/assets/useQuery--jXLy0yb.js +1 -0
  97. package/dist/client/assets/{value-BXXW8rnd.js → value-DqDh9HyF.js} +1 -1
  98. package/dist/client/assets/{view-mode-toggle-CYuFxr7p.js → view-mode-toggle-DAKbBF5Z.js} +1 -1
  99. package/dist/client/assets/{workflow-RTyKsxRT.js → workflow-BO9cHs1L.js} +1 -1
  100. package/dist/client/index.html +1 -1
  101. package/dist/server/cli.js +122 -122
  102. package/dist/server/migrate.js +2 -2
  103. package/dist/server/server.js +126 -126
  104. package/package.json +1 -1
  105. package/dist/client/assets/constants-Bx_FLkPa.js +0 -1
  106. package/dist/client/assets/error-boundary-C3biDnWK.js +0 -1
  107. package/dist/client/assets/page-C9ZDngiM.js +0 -35
  108. package/dist/client/assets/useQuery-DW8RlKsd.js +0 -1
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@decocms/mesh",
3
- "version": "2.4.0",
3
+ "version": "2.4.2",
4
4
  "description": "MCP Mesh - Self-hostable MCP Gateway for managing AI connections and tools",
5
5
  "author": "Deco team",
6
6
  "license": "MIT",
@@ -1 +0,0 @@
1
- import{B as o}from"./use-binding-Dh7eSguQ.js";import{F as t}from"./index-DZBFXaT_.js";const s="mcp.mesh",m=t(o,{target:"draft-7"});export{m as B,s as M};
@@ -1 +0,0 @@
1
- import{r as a,j as e}from"./index-DZBFXaT_.js";import{B as n}from"./input-KWjuSjzn.js";const o=({size:t=24,color:r="currentColor",...s})=>a.createElement("svg",{viewBox:"0 0 24 24",width:t,height:t,stroke:r,strokeWidth:"2",fill:"none",strokeLinecap:"round",strokeLinejoin:"round","aria-hidden":"true",...s},a.createElement("path",{d:"M12 9v4m0 4h.01M10.615 3.892 2.39 18.098c-.456.788-.684 1.182-.65 1.506a1 1 0 0 0 .406.705c.263.191.718.191 1.629.191h16.45c.91 0 1.365 0 1.628-.191a1 1 0 0 0 .407-.705c.034-.324-.195-.718-.65-1.506L13.383 3.892c-.454-.785-.681-1.178-.978-1.31a1 1 0 0 0-.813 0c-.296.132-.523.525-.978 1.31Z"}));o.displayName="AlertTriangle";class l extends a.Component{state={hasError:!1,error:null};static getDerivedStateFromError(r){return{hasError:!0,error:r}}componentDidCatch(r,s){console.error("Uncaught error:",r,s)}render(){return this.state.hasError?this.props.fallback?this.props.fallback:e.jsxs("div",{className:"flex-1 flex flex-col items-center justify-center h-full p-6 text-center space-y-4",children:[e.jsx("div",{className:"bg-destructive/10 p-3 rounded-full",children:e.jsx(o,{className:"h-6 w-6 text-destructive"})}),e.jsxs("div",{className:"space-y-2",children:[e.jsx("h3",{className:"text-lg font-medium",children:"Something went wrong"}),e.jsx("p",{className:"text-sm text-muted-foreground max-w-xs mx-auto",children:this.state.error?.message||"An unexpected error occurred"})]}),e.jsx(n,{variant:"outline",onClick:()=>this.setState({hasError:!1,error:null}),children:"Try again"})]}):this.props.children}}export{l as E,o as i};
@@ -1,35 +0,0 @@
1
- import{r as z,y as Ys,z as Zs,j as _,c as ge,h as Rt,i as Ws,a as Gs,t as qn}from"./index-DZBFXaT_.js";import{f as qs,D as Ks,u as Kn,a as Us,b as Qs,d as Js,c as ea,e as ta,N as na,C as pe,M as Un,U as oa,G as ra,g as ia,T as sa}from"./thread-history-popover-CbjIrBTu.js";import{E as Qn}from"./error-boundary-C3biDnWK.js";import{u as Jo,c as aa,I as er,n as ca}from"./use-connection-BVMsW9fR.js";import{u as tr,i as la}from"./use-gateway-DJ2wz6GD.js";import{u as ua}from"./use-binding-Dh7eSguQ.js";import{u as nr,L as da}from"./localstorage-keys-ziXXhpvN.js";import{u as bn}from"./project-context-provider-6vMfUBpq.js";import{c as or,B as fa}from"./input-KWjuSjzn.js";import{V as ha}from"./view-mode-toggle-CYuFxr7p.js";import{i as ga}from"./GitBranch01-38L6KUpt.js";import{i as pa}from"./Loading01-5lHx4rM1.js";import{s as ma}from"./Plus-wptRVGuY.js";import{u as ya}from"./use-tool-call-VY44CqK6.js";import{i as Te,a as Jn,b as xa,c as eo,d as en,T as tn,e as wa}from"./value-BXXW8rnd.js";import{G as to}from"./gateway-selector-D3Qx1Iib.js";import"./use-gateway-system-prompt-FrFSJufL.js";import"./popover-CYHZWxlr.js";import"./AlertCircle-BZ4bvRfi.js";import"./X-C6XvUpZP.js";import"./Grid01-Dl_1kAd5.js";import"./textarea-_Mx18lUV.js";import"./ChevronRight-Bc43l_p6.js";import"./Copy01-BTTTCefb.js";import"./Terminal-BC7AwEkQ.js";import"./monaco-editor-BmgaGs_i.js";import"./spinner-A1jsF1CN.js";import"./alert-dialog-BJHrUd_j.js";import"./File06-td5gmARz.js";import"./InfoCircle-D8z5_ZlN.js";import"./well-known-mcp-D13f-8h2.js";import"./generate-id-Dyweu44Y.js";import"./Trash01-DMq1QD3Y.js";import"./auth-BIu7r9Ac.js";import"./useQuery-DW8RlKsd.js";import"./select-bHRpmvzh.js";import"./ChevronDown-Bd6n8txO.js";import"./use-mobile-Cj5IONVM.js";const rr=({size:e=24,color:t="currentColor",...n})=>z.createElement("svg",{viewBox:"0 0 24 24",width:e,height:e,stroke:t,strokeWidth:"2",fill:"none",strokeLinecap:"round",strokeLinejoin:"round","aria-hidden":"true",...n},z.createElement("path",{d:"m10 15-3.075 3.114c-.43.434-.644.651-.828.666a.5.5 0 0 1-.421-.172c-.12-.14-.12-.446-.12-1.056v-1.56c0-.548-.449-.944-.99-1.024v0a3 3 0 0 1-2.534-2.533C2 12.219 2 11.96 2 11.445V6.8c0-1.68 0-2.52.327-3.162a3 3 0 0 1 1.311-1.311C4.28 2 5.12 2 6.8 2h7.4c1.68 0 2.52 0 3.162.327a3 3 0 0 1 1.311 1.311C19 4.28 19 5.12 19 6.8V11m0 11-2.176-1.513c-.306-.213-.46-.32-.626-.395a2.002 2.002 0 0 0-.462-.145c-.18-.033-.367-.033-.74-.033H13.2c-1.12 0-1.68 0-2.108-.218a2 2 0 0 1-.874-.874C10 18.394 10 17.834 10 16.714V14.2c0-1.12 0-1.68.218-2.108a2 2 0 0 1 .874-.874C11.52 11 12.08 11 13.2 11h5.6c1.12 0 1.68 0 2.108.218a2 2 0 0 1 .874.874C22 12.52 22 13.08 22 14.2v2.714c0 .932 0 1.398-.152 1.766a2 2 0 0 1-1.083 1.082c-.367.152-.833.152-1.765.152V22Z"}));rr.displayName="MessageChatSquare";function ae(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=ae(e[n]))!==""&&(t+=(t&&" ")+o);else for(let n in e)e[n]&&(t+=(t&&" ")+n);return t}var va={value:()=>{}};function jt(){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 Et(n)}function Et(e){this._=e}function _a(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}})}Et.prototype=jt.prototype={constructor:Et,on:function(e,t){var n=this._,o=_a(e+"",n),r,s=-1,i=o.length;if(arguments.length<2){for(;++s<i;)if((r=(e=o[s]).type)&&(r=ba(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]=no(n[r],e.name,t);else if(t==null)for(r in n)n[r]=no(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 Et(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 ba(e,t){for(var n=0,o=e.length,r;n<o;++n)if((r=e[n]).name===t)return r.value}function no(e,t,n){for(var o=0,r=e.length;o<r;++o)if(e[o].name===t){e[o]=va,e=e.slice(0,o).concat(e.slice(o+1));break}return n!=null&&e.push({name:t,value:n}),e}var un="http://www.w3.org/1999/xhtml";const oo={svg:"http://www.w3.org/2000/svg",xhtml:un,xlink:"http://www.w3.org/1999/xlink",xml:"http://www.w3.org/XML/1998/namespace",xmlns:"http://www.w3.org/2000/xmlns/"};function Vt(e){var t=e+="",n=t.indexOf(":");return n>=0&&(t=e.slice(0,n))!=="xmlns"&&(e=e.slice(n+1)),oo.hasOwnProperty(t)?{space:oo[t],local:e}:e}function Sa(e){return function(){var t=this.ownerDocument,n=this.namespaceURI;return n===un&&t.documentElement.namespaceURI===un?t.createElement(e):t.createElementNS(n,e)}}function Ea(e){return function(){return this.ownerDocument.createElementNS(e.space,e.local)}}function ir(e){var t=Vt(e);return(t.local?Ea:Sa)(t)}function Ca(){}function Sn(e){return e==null?Ca:function(){return this.querySelector(e)}}function Na(e){typeof e!="function"&&(e=Sn(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),l,c,u=0;u<i;++u)(l=s[u])&&(c=e.call(l,l.__data__,u,s))&&("__data__"in l&&(c.__data__=l.__data__),a[u]=c);return new fe(o,this._parents)}function Ma(e){return e==null?[]:Array.isArray(e)?e:Array.from(e)}function Ia(){return[]}function sr(e){return e==null?Ia:function(){return this.querySelectorAll(e)}}function ka(e){return function(){return Ma(e.apply(this,arguments))}}function Aa(e){typeof e=="function"?e=ka(e):e=sr(e);for(var t=this._groups,n=t.length,o=[],r=[],s=0;s<n;++s)for(var i=t[s],a=i.length,l,c=0;c<a;++c)(l=i[c])&&(o.push(e.call(l,l.__data__,c,i)),r.push(l));return new fe(o,r)}function ar(e){return function(){return this.matches(e)}}function cr(e){return function(t){return t.matches(e)}}var Pa=Array.prototype.find;function Ta(e){return function(){return Pa.call(this.children,e)}}function Da(){return this.firstElementChild}function $a(e){return this.select(e==null?Da:Ta(typeof e=="function"?e:cr(e)))}var za=Array.prototype.filter;function La(){return Array.from(this.children)}function Ha(e){return function(){return za.call(this.children,e)}}function Ra(e){return this.selectAll(e==null?La:Ha(typeof e=="function"?e:cr(e)))}function ja(e){typeof e!="function"&&(e=ar(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]=[],l,c=0;c<i;++c)(l=s[c])&&e.call(l,l.__data__,c,s)&&a.push(l);return new fe(o,this._parents)}function lr(e){return new Array(e.length)}function Va(){return new fe(this._enter||this._groups.map(lr),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 Oa(e){return function(){return e}}function Ba(e,t,n,o,r,s){for(var i=0,a,l=t.length,c=s.length;i<c;++i)(a=t[i])?(a.__data__=s[i],o[i]=a):n[i]=new kt(e,s[i]);for(;i<l;++i)(a=t[i])&&(r[i]=a)}function Fa(e,t,n,o,r,s,i){var a,l,c=new Map,u=t.length,f=s.length,d=new Array(u),p;for(a=0;a<u;++a)(l=t[a])&&(d[a]=p=i.call(l,l.__data__,a,t)+"",c.has(p)?r[a]=l:c.set(p,l));for(a=0;a<f;++a)p=i.call(e,s[a],a,s)+"",(l=c.get(p))?(o[a]=l,l.__data__=s[a],c.delete(p)):n[a]=new kt(e,s[a]);for(a=0;a<u;++a)(l=t[a])&&c.get(d[a])===l&&(r[a]=l)}function Xa(e){return e.__data__}function Ya(e,t){if(!arguments.length)return Array.from(this,Xa);var n=t?Fa:Ba,o=this._parents,r=this._groups;typeof e!="function"&&(e=Oa(e));for(var s=r.length,i=new Array(s),a=new Array(s),l=new Array(s),c=0;c<s;++c){var u=o[c],f=r[c],d=f.length,p=Za(e.call(u,u&&u.__data__,c,o)),h=p.length,w=a[c]=new Array(h),v=i[c]=new Array(h),m=l[c]=new Array(d);n(u,f,w,v,m,p,t);for(var b=0,g=0,x,N;b<h;++b)if(x=w[b]){for(b>=g&&(g=b+1);!(N=v[g])&&++g<h;);x._next=N||null}}return i=new fe(i,o),i._enter=a,i._exit=l,i}function Za(e){return typeof e=="object"&&"length"in e?e:Array.from(e)}function Wa(){return new fe(this._exit||this._groups.map(lr),this._parents)}function Ga(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 qa(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),l=0;l<i;++l)for(var c=n[l],u=o[l],f=c.length,d=a[l]=new Array(f),p,h=0;h<f;++h)(p=c[h]||u[h])&&(d[h]=p);for(;l<r;++l)a[l]=n[l];return new fe(a,this._parents)}function Ka(){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 Ua(e){e||(e=Qa);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,l=r[s]=new Array(a),c,u=0;u<a;++u)(c=i[u])&&(l[u]=c);l.sort(t)}return new fe(r,this._parents).order()}function Qa(e,t){return e<t?-1:e>t?1:e>=t?0:NaN}function Ja(){var e=arguments[0];return arguments[0]=this,e.apply(null,arguments),this}function ec(){return Array.from(this)}function tc(){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 nc(){let e=0;for(const t of this)++e;return e}function oc(){return!this.node()}function rc(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 ic(e){return function(){this.removeAttribute(e)}}function sc(e){return function(){this.removeAttributeNS(e.space,e.local)}}function ac(e,t){return function(){this.setAttribute(e,t)}}function cc(e,t){return function(){this.setAttributeNS(e.space,e.local,t)}}function lc(e,t){return function(){var n=t.apply(this,arguments);n==null?this.removeAttribute(e):this.setAttribute(e,n)}}function uc(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 dc(e,t){var n=Vt(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?sc:ic:typeof t=="function"?n.local?uc:lc:n.local?cc:ac)(n,t))}function ur(e){return e.ownerDocument&&e.ownerDocument.defaultView||e.document&&e||e.defaultView}function fc(e){return function(){this.style.removeProperty(e)}}function hc(e,t,n){return function(){this.style.setProperty(e,t,n)}}function gc(e,t,n){return function(){var o=t.apply(this,arguments);o==null?this.style.removeProperty(e):this.style.setProperty(e,o,n)}}function pc(e,t,n){return arguments.length>1?this.each((t==null?fc:typeof t=="function"?gc:hc)(e,t,n??"")):Fe(this.node(),e)}function Fe(e,t){return e.style.getPropertyValue(t)||ur(e).getComputedStyle(e,null).getPropertyValue(t)}function mc(e){return function(){delete this[e]}}function yc(e,t){return function(){this[e]=t}}function xc(e,t){return function(){var n=t.apply(this,arguments);n==null?delete this[e]:this[e]=n}}function wc(e,t){return arguments.length>1?this.each((t==null?mc:typeof t=="function"?xc:yc)(e,t)):this.node()[e]}function dr(e){return e.trim().split(/^|\s+/)}function En(e){return e.classList||new fr(e)}function fr(e){this._node=e,this._names=dr(e.getAttribute("class")||"")}fr.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 hr(e,t){for(var n=En(e),o=-1,r=t.length;++o<r;)n.add(t[o])}function gr(e,t){for(var n=En(e),o=-1,r=t.length;++o<r;)n.remove(t[o])}function vc(e){return function(){hr(this,e)}}function _c(e){return function(){gr(this,e)}}function bc(e,t){return function(){(t.apply(this,arguments)?hr:gr)(this,e)}}function Sc(e,t){var n=dr(e+"");if(arguments.length<2){for(var o=En(this.node()),r=-1,s=n.length;++r<s;)if(!o.contains(n[r]))return!1;return!0}return this.each((typeof t=="function"?bc:t?vc:_c)(n,t))}function Ec(){this.textContent=""}function Cc(e){return function(){this.textContent=e}}function Nc(e){return function(){var t=e.apply(this,arguments);this.textContent=t??""}}function Mc(e){return arguments.length?this.each(e==null?Ec:(typeof e=="function"?Nc:Cc)(e)):this.node().textContent}function Ic(){this.innerHTML=""}function kc(e){return function(){this.innerHTML=e}}function Ac(e){return function(){var t=e.apply(this,arguments);this.innerHTML=t??""}}function Pc(e){return arguments.length?this.each(e==null?Ic:(typeof e=="function"?Ac:kc)(e)):this.node().innerHTML}function Tc(){this.nextSibling&&this.parentNode.appendChild(this)}function Dc(){return this.each(Tc)}function $c(){this.previousSibling&&this.parentNode.insertBefore(this,this.parentNode.firstChild)}function zc(){return this.each($c)}function Lc(e){var t=typeof e=="function"?e:ir(e);return this.select(function(){return this.appendChild(t.apply(this,arguments))})}function Hc(){return null}function Rc(e,t){var n=typeof e=="function"?e:ir(e),o=t==null?Hc:typeof t=="function"?t:Sn(t);return this.select(function(){return this.insertBefore(n.apply(this,arguments),o.apply(this,arguments)||null)})}function jc(){var e=this.parentNode;e&&e.removeChild(this)}function Vc(){return this.each(jc)}function Oc(){var e=this.cloneNode(!1),t=this.parentNode;return t?t.insertBefore(e,this.nextSibling):e}function Bc(){var e=this.cloneNode(!0),t=this.parentNode;return t?t.insertBefore(e,this.nextSibling):e}function Fc(e){return this.select(e?Bc:Oc)}function Xc(e){return arguments.length?this.property("__data__",e):this.node().__data__}function Yc(e){return function(t){e.call(this,t,this.__data__)}}function Zc(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 Wc(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 Gc(e,t,n){return function(){var o=this.__on,r,s=Yc(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 qc(e,t,n){var o=Zc(e+""),r,s=o.length,i;if(arguments.length<2){var a=this.node().__on;if(a){for(var l=0,c=a.length,u;l<c;++l)for(r=0,u=a[l];r<s;++r)if((i=o[r]).type===u.type&&i.name===u.name)return u.value}return}for(a=t?Gc:Wc,r=0;r<s;++r)this.each(a(o[r],t,n));return this}function pr(e,t,n){var o=ur(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 Kc(e,t){return function(){return pr(this,e,t)}}function Uc(e,t){return function(){return pr(this,e,t.apply(this,arguments))}}function Qc(e,t){return this.each((typeof t=="function"?Uc:Kc)(e,t))}function*Jc(){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 mr=[null];function fe(e,t){this._groups=e,this._parents=t}function ut(){return new fe([[document.documentElement]],mr)}function el(){return this}fe.prototype=ut.prototype={constructor:fe,select:Na,selectAll:Aa,selectChild:$a,selectChildren:Ra,filter:ja,data:Ya,enter:Va,exit:Wa,join:Ga,merge:qa,selection:el,order:Ka,sort:Ua,call:Ja,nodes:ec,node:tc,size:nc,empty:oc,each:rc,attr:dc,style:pc,property:wc,classed:Sc,text:Mc,html:Pc,raise:Dc,lower:zc,append:Lc,insert:Rc,remove:Vc,clone:Fc,datum:Xc,on:qc,dispatch:Qc,[Symbol.iterator]:Jc};function de(e){return typeof e=="string"?new fe([[document.querySelector(e)]],[document.documentElement]):new fe([[e]],mr)}function tl(e){let t;for(;t=e.sourceEvent;)e=t;return e}function me(e,t){if(e=tl(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 nl={passive:!1},ot={capture:!0,passive:!1};function nn(e){e.stopImmediatePropagation()}function Be(e){e.preventDefault(),e.stopImmediatePropagation()}function yr(e){var t=e.document.documentElement,n=de(e).on("dragstart.drag",Be,ot);"onselectstart"in t?n.on("selectstart.drag",Be,ot):(t.__noselect=t.style.MozUserSelect,t.style.MozUserSelect="none")}function xr(e,t){var n=e.document.documentElement,o=de(e).on("dragstart.drag",null);t&&(o.on("click.drag",Be,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 dn(e,{sourceEvent:t,subject:n,target:o,identifier:r,active:s,x:i,y:a,dx:l,dy:c,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:l,enumerable:!0,configurable:!0},dy:{value:c,enumerable:!0,configurable:!0},_:{value:u}})}dn.prototype.on=function(){var e=this._.on.apply(this._,arguments);return e===this._?this:e};function ol(e){return!e.ctrlKey&&!e.button}function rl(){return this.parentNode}function il(e,t){return t??{x:e.x,y:e.y}}function sl(){return navigator.maxTouchPoints||"ontouchstart"in this}function wr(){var e=ol,t=rl,n=il,o=sl,r={},s=jt("start","drag","end"),i=0,a,l,c,u,f=0;function d(x){x.on("mousedown.drag",p).filter(o).on("touchstart.drag",v).on("touchmove.drag",m,nl).on("touchend.drag touchcancel.drag",b).style("touch-action","none").style("-webkit-tap-highlight-color","rgba(0,0,0,0)")}function p(x,N){if(!(u||!e.call(this,x,N))){var S=g(this,t.call(this,x,N),x,N,"mouse");S&&(de(x.view).on("mousemove.drag",h,ot).on("mouseup.drag",w,ot),yr(x.view),nn(x),c=!1,a=x.clientX,l=x.clientY,S("start",x))}}function h(x){if(Be(x),!c){var N=x.clientX-a,S=x.clientY-l;c=N*N+S*S>f}r.mouse("drag",x)}function w(x){de(x.view).on("mousemove.drag mouseup.drag",null),xr(x.view,c),Be(x),r.mouse("end",x)}function v(x,N){if(e.call(this,x,N)){var S=x.changedTouches,E=t.call(this,x,N),D=S.length,k,V;for(k=0;k<D;++k)(V=g(this,E,x,N,S[k].identifier,S[k]))&&(nn(x),V("start",x,S[k]))}}function m(x){var N=x.changedTouches,S=N.length,E,D;for(E=0;E<S;++E)(D=r[N[E].identifier])&&(Be(x),D("drag",x,N[E]))}function b(x){var N=x.changedTouches,S=N.length,E,D;for(u&&clearTimeout(u),u=setTimeout(function(){u=null},500),E=0;E<S;++E)(D=r[N[E].identifier])&&(nn(x),D("end",x,N[E]))}function g(x,N,S,E,D,k){var V=s.copy(),A=me(k||S,N),$,L,y;if((y=n.call(x,new dn("beforestart",{sourceEvent:S,target:d,identifier:D,active:i,x:A[0],y:A[1],dx:0,dy:0,dispatch:V}),E))!=null)return $=y.x-A[0]||0,L=y.y-A[1]||0,function M(C,P,T){var I=A,H;switch(C){case"start":r[D]=M,H=i++;break;case"end":delete r[D],--i;case"drag":A=me(T||P,N),H=i;break}V.call(C,x,new dn(C,{sourceEvent:P,subject:y,target:d,identifier:D,active:H,x:A[0]+$,y:A[1]+L,dx:A[0]-I[0],dy:A[1]-I[1],dispatch:V}),E)}}return d.filter=function(x){return arguments.length?(e=typeof x=="function"?x:mt(!!x),d):e},d.container=function(x){return arguments.length?(t=typeof x=="function"?x:mt(x),d):t},d.subject=function(x){return arguments.length?(n=typeof x=="function"?x:mt(x),d):n},d.touchable=function(x){return arguments.length?(o=typeof x=="function"?x:mt(!!x),d):o},d.on=function(){var x=s.on.apply(s,arguments);return x===s?d:x},d.clickDistance=function(x){return arguments.length?(f=(x=+x)*x,d):Math.sqrt(f)},d}var ro=180/Math.PI,fn={translateX:0,translateY:0,rotate:0,skewX:0,scaleX:1,scaleY:1};function vr(e,t,n,o,r,s){var i,a,l;return(i=Math.sqrt(e*e+t*t))&&(e/=i,t/=i),(l=e*n+t*o)&&(n-=e*l,o-=t*l),(a=Math.sqrt(n*n+o*o))&&(n/=a,o/=a,l/=a),e*o<t*n&&(e=-e,t=-t,l=-l,i=-i),{translateX:r,translateY:s,rotate:Math.atan2(t,e)*ro,skewX:Math.atan(l)*ro,scaleX:i,scaleY:a}}var yt;function al(e){const t=new(typeof DOMMatrix=="function"?DOMMatrix:WebKitCSSMatrix)(e+"");return t.isIdentity?fn:vr(t.a,t.b,t.c,t.d,t.e,t.f)}function cl(e){return e==null||(yt||(yt=document.createElementNS("http://www.w3.org/2000/svg","g")),yt.setAttribute("transform",e),!(e=yt.transform.baseVal.consolidate()))?fn:(e=e.matrix,vr(e.a,e.b,e.c,e.d,e.e,e.f))}function _r(e,t,n,o){function r(c){return c.length?c.pop()+" ":""}function s(c,u,f,d,p,h){if(c!==f||u!==d){var w=p.push("translate(",null,t,null,n);h.push({i:w-4,x:Te(c,f)},{i:w-2,x:Te(u,d)})}else(f||d)&&p.push("translate("+f+t+d+n)}function i(c,u,f,d){c!==u?(c-u>180?u+=360:u-c>180&&(c+=360),d.push({i:f.push(r(f)+"rotate(",null,o)-2,x:Te(c,u)})):u&&f.push(r(f)+"rotate("+u+o)}function a(c,u,f,d){c!==u?d.push({i:f.push(r(f)+"skewX(",null,o)-2,x:Te(c,u)}):u&&f.push(r(f)+"skewX("+u+o)}function l(c,u,f,d,p,h){if(c!==f||u!==d){var w=p.push(r(p)+"scale(",null,",",null,")");h.push({i:w-4,x:Te(c,f)},{i:w-2,x:Te(u,d)})}else(f!==1||d!==1)&&p.push(r(p)+"scale("+f+","+d+")")}return function(c,u){var f=[],d=[];return c=e(c),u=e(u),s(c.translateX,c.translateY,u.translateX,u.translateY,f,d),i(c.rotate,u.rotate,f,d),a(c.skewX,u.skewX,f,d),l(c.scaleX,c.scaleY,u.scaleX,u.scaleY,f,d),c=u=null,function(p){for(var h=-1,w=d.length,v;++h<w;)f[(v=d[h]).i]=v.x(p);return f.join("")}}}var ll=_r(al,"px, ","px)","deg)"),ul=_r(cl,", ",")",")"),dl=1e-12;function io(e){return((e=Math.exp(e))+1/e)/2}function fl(e){return((e=Math.exp(e))-1/e)/2}function hl(e){return((e=Math.exp(2*e))-1)/(e+1)}const Ct=(function e(t,n,o){function r(s,i){var a=s[0],l=s[1],c=s[2],u=i[0],f=i[1],d=i[2],p=u-a,h=f-l,w=p*p+h*h,v,m;if(w<dl)m=Math.log(d/c)/t,v=function(E){return[a+E*p,l+E*h,c*Math.exp(t*E*m)]};else{var b=Math.sqrt(w),g=(d*d-c*c+o*w)/(2*c*n*b),x=(d*d-c*c-o*w)/(2*d*n*b),N=Math.log(Math.sqrt(g*g+1)-g),S=Math.log(Math.sqrt(x*x+1)-x);m=(S-N)/t,v=function(E){var D=E*m,k=io(N),V=c/(n*b)*(k*hl(t*D+N)-fl(N));return[a+V*p,l+V*h,c*k/io(t*D+N)]}}return v.duration=m*1e3*t/Math.SQRT2,v}return r.rho=function(s){var i=Math.max(.001,+s),a=i*i,l=a*a;return e(i,a,l)},r})(Math.SQRT2,2,4);var Xe=0,Je=0,Ue=0,br=1e3,At,et,Pt=0,ze=0,Ot=0,rt=typeof performance=="object"&&performance.now?performance:Date,Sr=typeof window=="object"&&window.requestAnimationFrame?window.requestAnimationFrame.bind(window):function(e){setTimeout(e,17)};function Cn(){return ze||(Sr(gl),ze=rt.now()+Ot)}function gl(){ze=0}function Tt(){this._call=this._time=this._next=null}Tt.prototype=Er.prototype={constructor:Tt,restart:function(e,t,n){if(typeof e!="function")throw new TypeError("callback is not a function");n=(n==null?Cn():+n)+(t==null?0:+t),!this._next&&et!==this&&(et?et._next=this:At=this,et=this),this._call=e,this._time=n,hn()},stop:function(){this._call&&(this._call=null,this._time=1/0,hn())}};function Er(e,t,n){var o=new Tt;return o.restart(e,t,n),o}function pl(){Cn(),++Xe;for(var e=At,t;e;)(t=ze-e._time)>=0&&e._call.call(void 0,t),e=e._next;--Xe}function so(){ze=(Pt=rt.now())+Ot,Xe=Je=0;try{pl()}finally{Xe=0,yl(),ze=0}}function ml(){var e=rt.now(),t=e-Pt;t>br&&(Ot-=t,Pt=e)}function yl(){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,hn(o)}function hn(e){if(!Xe){Je&&(Je=clearTimeout(Je));var t=e-ze;t>24?(e<1/0&&(Je=setTimeout(so,e-rt.now()-Ot)),Ue&&(Ue=clearInterval(Ue))):(Ue||(Pt=rt.now(),Ue=setInterval(ml,br)),Xe=1,Sr(so))}}function ao(e,t,n){var o=new Tt;return t=t==null?0:+t,o.restart(r=>{o.stop(),e(r+t)},t,n),o}var xl=jt("start","end","cancel","interrupt"),wl=[],Cr=0,co=1,gn=2,Nt=3,lo=4,pn=5,Mt=6;function Bt(e,t,n,o,r,s){var i=e.__transition;if(!i)e.__transition={};else if(n in i)return;vl(e,n,{name:t,index:o,group:r,on:xl,tween:wl,time:s.time,delay:s.delay,duration:s.duration,ease:s.ease,timer:null,state:Cr})}function Nn(e,t){var n=we(e,t);if(n.state>Cr)throw new Error("too late; already scheduled");return n}function be(e,t){var n=we(e,t);if(n.state>Nt)throw new Error("too late; already running");return n}function we(e,t){var n=e.__transition;if(!n||!(n=n[t]))throw new Error("transition not found");return n}function vl(e,t,n){var o=e.__transition,r;o[t]=n,n.timer=Er(s,0,n.time);function s(c){n.state=co,n.timer.restart(i,n.delay,n.time),n.delay<=c&&i(c-n.delay)}function i(c){var u,f,d,p;if(n.state!==co)return l();for(u in o)if(p=o[u],p.name===n.name){if(p.state===Nt)return ao(i);p.state===lo?(p.state=Mt,p.timer.stop(),p.on.call("interrupt",e,e.__data__,p.index,p.group),delete o[u]):+u<t&&(p.state=Mt,p.timer.stop(),p.on.call("cancel",e,e.__data__,p.index,p.group),delete o[u])}if(ao(function(){n.state===Nt&&(n.state=lo,n.timer.restart(a,n.delay,n.time),a(c))}),n.state=gn,n.on.call("start",e,e.__data__,n.index,n.group),n.state===gn){for(n.state=Nt,r=new Array(d=n.tween.length),u=0,f=-1;u<d;++u)(p=n.tween[u].value.call(e,e.__data__,n.index,n.group))&&(r[++f]=p);r.length=f+1}}function a(c){for(var u=c<n.duration?n.ease.call(null,c/n.duration):(n.timer.restart(l),n.state=pn,1),f=-1,d=r.length;++f<d;)r[f].call(e,u);n.state===pn&&(n.on.call("end",e,e.__data__,n.index,n.group),l())}function l(){n.state=Mt,n.timer.stop(),delete o[t];for(var c 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>gn&&o.state<pn,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 _l(e){return this.each(function(){It(this,e)})}function bl(e,t){var n,o;return function(){var r=be(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 Sl(e,t,n){var o,r;if(typeof n!="function")throw new Error;return function(){var s=be(this,e),i=s.tween;if(i!==o){r=(o=i).slice();for(var a={name:t,value:n},l=0,c=r.length;l<c;++l)if(r[l].name===t){r[l]=a;break}l===c&&r.push(a)}s.tween=r}}function El(e,t){var n=this._id;if(e+="",arguments.length<2){for(var o=we(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?bl:Sl)(n,e,t))}function Mn(e,t,n){var o=e._id;return e.each(function(){var r=be(this,o);(r.value||(r.value={}))[t]=n.apply(this,arguments)}),function(r){return we(r,o).value[t]}}function Nr(e,t){var n;return(typeof t=="number"?Te:t instanceof eo?Jn:(n=eo(t))?(t=n,Jn):xa)(e,t)}function Cl(e){return function(){this.removeAttribute(e)}}function Nl(e){return function(){this.removeAttributeNS(e.space,e.local)}}function Ml(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 Il(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 kl(e,t,n){var o,r,s;return function(){var i,a=n(this),l;return a==null?void this.removeAttribute(e):(i=this.getAttribute(e),l=a+"",i===l?null:i===o&&l===r?s:(r=l,s=t(o=i,a)))}}function Al(e,t,n){var o,r,s;return function(){var i,a=n(this),l;return a==null?void this.removeAttributeNS(e.space,e.local):(i=this.getAttributeNS(e.space,e.local),l=a+"",i===l?null:i===o&&l===r?s:(r=l,s=t(o=i,a)))}}function Pl(e,t){var n=Vt(e),o=n==="transform"?ul:Nr;return this.attrTween(e,typeof t=="function"?(n.local?Al:kl)(n,o,Mn(this,"attr."+e,t)):t==null?(n.local?Nl:Cl)(n):(n.local?Il:Ml)(n,o,t))}function Tl(e,t){return function(n){this.setAttribute(e,t.call(this,n))}}function Dl(e,t){return function(n){this.setAttributeNS(e.space,e.local,t.call(this,n))}}function $l(e,t){var n,o;function r(){var s=t.apply(this,arguments);return s!==o&&(n=(o=s)&&Dl(e,s)),n}return r._value=t,r}function zl(e,t){var n,o;function r(){var s=t.apply(this,arguments);return s!==o&&(n=(o=s)&&Tl(e,s)),n}return r._value=t,r}function Ll(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=Vt(e);return this.tween(n,(o.local?$l:zl)(o,t))}function Hl(e,t){return function(){Nn(this,e).delay=+t.apply(this,arguments)}}function Rl(e,t){return t=+t,function(){Nn(this,e).delay=t}}function jl(e){var t=this._id;return arguments.length?this.each((typeof e=="function"?Hl:Rl)(t,e)):we(this.node(),t).delay}function Vl(e,t){return function(){be(this,e).duration=+t.apply(this,arguments)}}function Ol(e,t){return t=+t,function(){be(this,e).duration=t}}function Bl(e){var t=this._id;return arguments.length?this.each((typeof e=="function"?Vl:Ol)(t,e)):we(this.node(),t).duration}function Fl(e,t){if(typeof t!="function")throw new Error;return function(){be(this,e).ease=t}}function Xl(e){var t=this._id;return arguments.length?this.each(Fl(t,e)):we(this.node(),t).ease}function Yl(e,t){return function(){var n=t.apply(this,arguments);if(typeof n!="function")throw new Error;be(this,e).ease=n}}function Zl(e){if(typeof e!="function")throw new Error;return this.each(Yl(this._id,e))}function Wl(e){typeof e!="function"&&(e=ar(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]=[],l,c=0;c<i;++c)(l=s[c])&&e.call(l,l.__data__,c,s)&&a.push(l);return new Ce(o,this._parents,this._name,this._id)}function Gl(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 l=t[a],c=n[a],u=l.length,f=i[a]=new Array(u),d,p=0;p<u;++p)(d=l[p]||c[p])&&(f[p]=d);for(;a<o;++a)i[a]=t[a];return new Ce(i,this._parents,this._name,this._id)}function ql(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 Kl(e,t,n){var o,r,s=ql(t)?Nn:be;return function(){var i=s(this,e),a=i.on;a!==o&&(r=(o=a).copy()).on(t,n),i.on=r}}function Ul(e,t){var n=this._id;return arguments.length<2?we(this.node(),n).on.on(e):this.each(Kl(n,e,t))}function Ql(e){return function(){var t=this.parentNode;for(var n in this.__transition)if(+n!==e)return;t&&t.removeChild(this)}}function Jl(){return this.on("end.remove",Ql(this._id))}function eu(e){var t=this._name,n=this._id;typeof e!="function"&&(e=Sn(e));for(var o=this._groups,r=o.length,s=new Array(r),i=0;i<r;++i)for(var a=o[i],l=a.length,c=s[i]=new Array(l),u,f,d=0;d<l;++d)(u=a[d])&&(f=e.call(u,u.__data__,d,a))&&("__data__"in u&&(f.__data__=u.__data__),c[d]=f,Bt(c[d],t,n,d,c,we(u,n)));return new Ce(s,this._parents,t,n)}function tu(e){var t=this._name,n=this._id;typeof e!="function"&&(e=sr(e));for(var o=this._groups,r=o.length,s=[],i=[],a=0;a<r;++a)for(var l=o[a],c=l.length,u,f=0;f<c;++f)if(u=l[f]){for(var d=e.call(u,u.__data__,f,l),p,h=we(u,n),w=0,v=d.length;w<v;++w)(p=d[w])&&Bt(p,t,n,w,d,h);s.push(d),i.push(u)}return new Ce(s,i,t,n)}var nu=ut.prototype.constructor;function ou(){return new nu(this._groups,this._parents)}function ru(e,t){var n,o,r;return function(){var s=Fe(this,e),i=(this.style.removeProperty(e),Fe(this,e));return s===i?null:s===n&&i===o?r:r=t(n=s,o=i)}}function Mr(e){return function(){this.style.removeProperty(e)}}function iu(e,t,n){var o,r=n+"",s;return function(){var i=Fe(this,e);return i===r?null:i===o?s:s=t(o=i,n)}}function su(e,t,n){var o,r,s;return function(){var i=Fe(this,e),a=n(this),l=a+"";return a==null&&(l=a=(this.style.removeProperty(e),Fe(this,e))),i===l?null:i===o&&l===r?s:(r=l,s=t(o=i,a))}}function au(e,t){var n,o,r,s="style."+t,i="end."+s,a;return function(){var l=be(this,e),c=l.on,u=l.value[s]==null?a||(a=Mr(t)):void 0;(c!==n||r!==u)&&(o=(n=c).copy()).on(i,r=u),l.on=o}}function cu(e,t,n){var o=(e+="")=="transform"?ll:Nr;return t==null?this.styleTween(e,ru(e,o)).on("end.style."+e,Mr(e)):typeof t=="function"?this.styleTween(e,su(e,o,Mn(this,"style."+e,t))).each(au(this._id,e)):this.styleTween(e,iu(e,o,t),n).on("end.style."+e,null)}function lu(e,t,n){return function(o){this.style.setProperty(e,t.call(this,o),n)}}function uu(e,t,n){var o,r;function s(){var i=t.apply(this,arguments);return i!==r&&(o=(r=i)&&lu(e,i,n)),o}return s._value=t,s}function du(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,uu(e,t,n??""))}function fu(e){return function(){this.textContent=e}}function hu(e){return function(){var t=e(this);this.textContent=t??""}}function gu(e){return this.tween("text",typeof e=="function"?hu(Mn(this,"text",e)):fu(e==null?"":e+""))}function pu(e){return function(t){this.textContent=e.call(this,t)}}function mu(e){var t,n;function o(){var r=e.apply(this,arguments);return r!==n&&(t=(n=r)&&pu(r)),t}return o._value=e,o}function yu(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,mu(e))}function xu(){for(var e=this._name,t=this._id,n=Ir(),o=this._groups,r=o.length,s=0;s<r;++s)for(var i=o[s],a=i.length,l,c=0;c<a;++c)if(l=i[c]){var u=we(l,t);Bt(l,e,n,c,i,{time:u.time+u.delay+u.duration,delay:0,duration:u.duration,ease:u.ease})}return new Ce(o,this._parents,e,n)}function wu(){var e,t,n=this,o=n._id,r=n.size();return new Promise(function(s,i){var a={value:i},l={value:function(){--r===0&&s()}};n.each(function(){var c=be(this,o),u=c.on;u!==e&&(t=(e=u).copy(),t._.cancel.push(a),t._.interrupt.push(a),t._.end.push(l)),c.on=t}),r===0&&s()})}var vu=0;function Ce(e,t,n,o){this._groups=e,this._parents=t,this._name=n,this._id=o}function Ir(){return++vu}var Se=ut.prototype;Ce.prototype={constructor:Ce,select:eu,selectAll:tu,selectChild:Se.selectChild,selectChildren:Se.selectChildren,filter:Wl,merge:Gl,selection:ou,transition:xu,call:Se.call,nodes:Se.nodes,node:Se.node,size:Se.size,empty:Se.empty,each:Se.each,on:Ul,attr:Pl,attrTween:Ll,style:cu,styleTween:du,text:gu,textTween:yu,remove:Jl,tween:El,delay:jl,duration:Bl,ease:Xl,easeVarying:Zl,end:wu,[Symbol.iterator]:Se[Symbol.iterator]};function _u(e){return((e*=2)<=1?e*e*e:(e-=2)*e*e+2)/2}var bu={time:null,delay:0,duration:250,ease:_u};function Su(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 Eu(e){var t,n;e instanceof Ce?(t=e._id,e=e._name):(t=Ir(),(n=bu).time=Cn(),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,l,c=0;c<a;++c)(l=i[c])&&Bt(l,e,t,c,i,n||Su(l,t));return new Ce(o,this._parents,e,t)}ut.prototype.interrupt=_l;ut.prototype.transition=Eu;const xt=e=>()=>e;function Cu(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 Ee(e,t,n){this.k=e,this.x=t,this.y=n}Ee.prototype={constructor:Ee,scale:function(e){return e===1?this:new Ee(this.k*e,this.x,this.y)},translate:function(e,t){return e===0&t===0?this:new Ee(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 Ft=new Ee(1,0,0);kr.prototype=Ee.prototype;function kr(e){for(;!e.__zoom;)if(!(e=e.parentNode))return Ft;return e.__zoom}function on(e){e.stopImmediatePropagation()}function Qe(e){e.preventDefault(),e.stopImmediatePropagation()}function Nu(e){return(!e.ctrlKey||e.type==="wheel")&&!e.button}function Mu(){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 uo(){return this.__zoom||Ft}function Iu(e){return-e.deltaY*(e.deltaMode===1?.05:e.deltaMode?1:.002)*(e.ctrlKey?10:1)}function ku(){return navigator.maxTouchPoints||"ontouchstart"in this}function Au(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 Ar(){var e=Nu,t=Mu,n=Au,o=Iu,r=ku,s=[0,1/0],i=[[-1/0,-1/0],[1/0,1/0]],a=250,l=Ct,c=jt("start","zoom","end"),u,f,d,p=500,h=150,w=0,v=10;function m(y){y.property("__zoom",uo).on("wheel.zoom",D,{passive:!1}).on("mousedown.zoom",k).on("dblclick.zoom",V).filter(r).on("touchstart.zoom",A).on("touchmove.zoom",$).on("touchend.zoom touchcancel.zoom",L).style("-webkit-tap-highlight-color","rgba(0,0,0,0)")}m.transform=function(y,M,C,P){var T=y.selection?y.selection():y;T.property("__zoom",uo),y!==T?N(y,M,C,P):T.interrupt().each(function(){S(this,arguments).event(P).start().zoom(null,typeof M=="function"?M.apply(this,arguments):M).end()})},m.scaleBy=function(y,M,C,P){m.scaleTo(y,function(){var T=this.__zoom.k,I=typeof M=="function"?M.apply(this,arguments):M;return T*I},C,P)},m.scaleTo=function(y,M,C,P){m.transform(y,function(){var T=t.apply(this,arguments),I=this.__zoom,H=C==null?x(T):typeof C=="function"?C.apply(this,arguments):C,j=I.invert(H),R=typeof M=="function"?M.apply(this,arguments):M;return n(g(b(I,R),H,j),T,i)},C,P)},m.translateBy=function(y,M,C,P){m.transform(y,function(){return n(this.__zoom.translate(typeof M=="function"?M.apply(this,arguments):M,typeof C=="function"?C.apply(this,arguments):C),t.apply(this,arguments),i)},null,P)},m.translateTo=function(y,M,C,P,T){m.transform(y,function(){var I=t.apply(this,arguments),H=this.__zoom,j=P==null?x(I):typeof P=="function"?P.apply(this,arguments):P;return n(Ft.translate(j[0],j[1]).scale(H.k).translate(typeof M=="function"?-M.apply(this,arguments):-M,typeof C=="function"?-C.apply(this,arguments):-C),I,i)},P,T)};function b(y,M){return M=Math.max(s[0],Math.min(s[1],M)),M===y.k?y:new Ee(M,y.x,y.y)}function g(y,M,C){var P=M[0]-C[0]*y.k,T=M[1]-C[1]*y.k;return P===y.x&&T===y.y?y:new Ee(y.k,P,T)}function x(y){return[(+y[0][0]+ +y[1][0])/2,(+y[0][1]+ +y[1][1])/2]}function N(y,M,C,P){y.on("start.zoom",function(){S(this,arguments).event(P).start()}).on("interrupt.zoom end.zoom",function(){S(this,arguments).event(P).end()}).tween("zoom",function(){var T=this,I=arguments,H=S(T,I).event(P),j=t.apply(T,I),R=C==null?x(j):typeof C=="function"?C.apply(T,I):C,F=Math.max(j[1][0]-j[0][0],j[1][1]-j[0][1]),B=T.__zoom,G=typeof M=="function"?M.apply(T,I):M,K=l(B.invert(R).concat(F/B.k),G.invert(R).concat(F/G.k));return function(W){if(W===1)W=G;else{var O=K(W),X=F/O[2];W=new Ee(X,R[0]-O[0]*X,R[1]-O[1]*X)}H.zoom(null,W)}})}function S(y,M,C){return!C&&y.__zooming||new E(y,M)}function E(y,M){this.that=y,this.args=M,this.active=0,this.sourceEvent=null,this.extent=t.apply(y,M),this.taps=0}E.prototype={event:function(y){return y&&(this.sourceEvent=y),this},start:function(){return++this.active===1&&(this.that.__zooming=this,this.emit("start")),this},zoom:function(y,M){return this.mouse&&y!=="mouse"&&(this.mouse[1]=M.invert(this.mouse[0])),this.touch0&&y!=="touch"&&(this.touch0[1]=M.invert(this.touch0[0])),this.touch1&&y!=="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(y){var M=de(this.that).datum();c.call(y,this.that,new Cu(y,{sourceEvent:this.sourceEvent,target:m,transform:this.that.__zoom,dispatch:c}),M)}};function D(y,...M){if(!e.apply(this,arguments))return;var C=S(this,M).event(y),P=this.__zoom,T=Math.max(s[0],Math.min(s[1],P.k*Math.pow(2,o.apply(this,arguments)))),I=me(y);if(C.wheel)(C.mouse[0][0]!==I[0]||C.mouse[0][1]!==I[1])&&(C.mouse[1]=P.invert(C.mouse[0]=I)),clearTimeout(C.wheel);else{if(P.k===T)return;C.mouse=[I,P.invert(I)],It(this),C.start()}Qe(y),C.wheel=setTimeout(H,h),C.zoom("mouse",n(g(b(P,T),C.mouse[0],C.mouse[1]),C.extent,i));function H(){C.wheel=null,C.end()}}function k(y,...M){if(d||!e.apply(this,arguments))return;var C=y.currentTarget,P=S(this,M,!0).event(y),T=de(y.view).on("mousemove.zoom",R,!0).on("mouseup.zoom",F,!0),I=me(y,C),H=y.clientX,j=y.clientY;yr(y.view),on(y),P.mouse=[I,this.__zoom.invert(I)],It(this),P.start();function R(B){if(Qe(B),!P.moved){var G=B.clientX-H,K=B.clientY-j;P.moved=G*G+K*K>w}P.event(B).zoom("mouse",n(g(P.that.__zoom,P.mouse[0]=me(B,C),P.mouse[1]),P.extent,i))}function F(B){T.on("mousemove.zoom mouseup.zoom",null),xr(B.view,P.moved),Qe(B),P.event(B).end()}}function V(y,...M){if(e.apply(this,arguments)){var C=this.__zoom,P=me(y.changedTouches?y.changedTouches[0]:y,this),T=C.invert(P),I=C.k*(y.shiftKey?.5:2),H=n(g(b(C,I),P,T),t.apply(this,M),i);Qe(y),a>0?de(this).transition().duration(a).call(N,H,P,y):de(this).call(m.transform,H,P,y)}}function A(y,...M){if(e.apply(this,arguments)){var C=y.touches,P=C.length,T=S(this,M,y.changedTouches.length===P).event(y),I,H,j,R;for(on(y),H=0;H<P;++H)j=C[H],R=me(j,this),R=[R,this.__zoom.invert(R),j.identifier],T.touch0?!T.touch1&&T.touch0[2]!==R[2]&&(T.touch1=R,T.taps=0):(T.touch0=R,I=!0,T.taps=1+!!u);u&&(u=clearTimeout(u)),I&&(T.taps<2&&(f=R[0],u=setTimeout(function(){u=null},p)),It(this),T.start())}}function $(y,...M){if(this.__zooming){var C=S(this,M).event(y),P=y.changedTouches,T=P.length,I,H,j,R;for(Qe(y),I=0;I<T;++I)H=P[I],j=me(H,this),C.touch0&&C.touch0[2]===H.identifier?C.touch0[0]=j:C.touch1&&C.touch1[2]===H.identifier&&(C.touch1[0]=j);if(H=C.that.__zoom,C.touch1){var F=C.touch0[0],B=C.touch0[1],G=C.touch1[0],K=C.touch1[1],W=(W=G[0]-F[0])*W+(W=G[1]-F[1])*W,O=(O=K[0]-B[0])*O+(O=K[1]-B[1])*O;H=b(H,Math.sqrt(W/O)),j=[(F[0]+G[0])/2,(F[1]+G[1])/2],R=[(B[0]+K[0])/2,(B[1]+K[1])/2]}else if(C.touch0)j=C.touch0[0],R=C.touch0[1];else return;C.zoom("touch",n(g(H,j,R),C.extent,i))}}function L(y,...M){if(this.__zooming){var C=S(this,M).event(y),P=y.changedTouches,T=P.length,I,H;for(on(y),d&&clearTimeout(d),d=setTimeout(function(){d=null},p),I=0;I<T;++I)H=P[I],C.touch0&&C.touch0[2]===H.identifier?delete C.touch0:C.touch1&&C.touch1[2]===H.identifier&&delete C.touch1;if(C.touch1&&!C.touch0&&(C.touch0=C.touch1,delete C.touch1),C.touch0)C.touch0[1]=this.__zoom.invert(C.touch0[0]);else if(C.end(),C.taps===2&&(H=me(H,this),Math.hypot(f[0]-H[0],f[1]-H[1])<v)){var j=de(this).on("dblclick.zoom");j&&j.apply(this,arguments)}}}return m.wheelDelta=function(y){return arguments.length?(o=typeof y=="function"?y:xt(+y),m):o},m.filter=function(y){return arguments.length?(e=typeof y=="function"?y:xt(!!y),m):e},m.touchable=function(y){return arguments.length?(r=typeof y=="function"?y:xt(!!y),m):r},m.extent=function(y){return arguments.length?(t=typeof y=="function"?y:xt([[+y[0][0],+y[0][1]],[+y[1][0],+y[1][1]]]),m):t},m.scaleExtent=function(y){return arguments.length?(s[0]=+y[0],s[1]=+y[1],m):[s[0],s[1]]},m.translateExtent=function(y){return arguments.length?(i[0][0]=+y[0][0],i[1][0]=+y[1][0],i[0][1]=+y[0][1],i[1][1]=+y[1][1],m):[[i[0][0],i[0][1]],[i[1][0],i[1][1]]]},m.constrain=function(y){return arguments.length?(n=y,m):n},m.duration=function(y){return arguments.length?(a=+y,m):a},m.interpolate=function(y){return arguments.length?(l=y,m):l},m.on=function(){var y=c.on.apply(c,arguments);return y===c?m:y},m.clickDistance=function(y){return arguments.length?(w=(y=+y)*y,m):Math.sqrt(w)},m.tapDistance=function(y){return arguments.length?(v=+y,m):v},m}const _e={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]],Pr=["Enter"," ","Escape"],Tr={"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 Ye;(function(e){e.Strict="strict",e.Loose="loose"})(Ye||(Ye={}));var $e;(function(e){e.Free="free",e.Vertical="vertical",e.Horizontal="horizontal"})($e||($e={}));var st;(function(e){e.Partial="partial",e.Full="full"})(st||(st={}));const Dr={inProgress:!1,isValid:null,from:null,fromHandle:null,fromPosition:null,fromNode:null,to:null,toHandle:null,toPosition:null,toNode:null,pointer:null};var ke;(function(e){e.Bezier="default",e.Straight="straight",e.Step="step",e.SmoothStep="smoothstep",e.SimpleBezier="simplebezier"})(ke||(ke={}));var Dt;(function(e){e.Arrow="arrow",e.ArrowClosed="arrowclosed"})(Dt||(Dt={}));var Y;(function(e){e.Left="left",e.Top="top",e.Right="right",e.Bottom="bottom"})(Y||(Y={}));const fo={[Y.Left]:Y.Right,[Y.Right]:Y.Left,[Y.Top]:Y.Bottom,[Y.Bottom]:Y.Top};function $r(e){return e===null?null:e?"valid":"invalid"}const zr=e=>"id"in e&&"source"in e&&"target"in e,Pu=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}=Ne(e),r=e.origin??t,s=n*r[0],i=o*r[1];return{x:e.position.x-s,y:e.position.y-i}},Tu=(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?$t(i,t.nodeOrigin):{x:0,y:0,x2:0,y2:0};return Xt(o,a)},{x:1/0,y:1/0,x2:-1/0,y2:-1/0});return Yt(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=Xt(n,$t(r)),o=!0)}),o?Yt(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},l=[];for(const c of e.values()){const{measured:u,selectable:f=!0,hidden:d=!1}=c;if(i&&!f||d)continue;const p=u.width??c.width??c.initialWidth??null,h=u.height??c.height??c.initialHeight??null,w=at(a,We(c)),v=(p??0)*(h??0),m=s&&w>0;(!c.internals.handleBounds||m||w>=v||c.dragging)&&l.push(c)}return l},Du=(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 $u(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 zu({nodes:e,width:t,height:n,panZoom:o,minZoom:r,maxZoom:s},i){if(e.size===0)return Promise.resolve(!0);const a=$u(e,i),l=ft(a),c=An(l,t,n,i?.minZoom??r,i?.maxZoom??s,i?.padding??.1);return await o.setViewport(c,{duration:i?.duration,ease:i?.ease,interpolate:i?.interpolate}),Promise.resolve(!0)}function Lr({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:l,y:c}=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",_e.error005());else{const p=a.measured.width,h=a.measured.height;p&&h&&(f=[[l,c],[l+p,c+h]])}else a&&Ge(i.extent)&&(f=[[i.extent[0][0]+l,i.extent[0][1]+c],[i.extent[1][0]+l,i.extent[1][1]+c]]);const d=Ge(f)?Le(t,f,i.measured):t;return(i.measured.width===void 0||i.measured.height===void 0)&&s?.("015",_e.error015()),{position:{x:d.x-l+(i.measured.width??0)*u[0],y:d.y-c+(i.measured.height??0)*u[1]},positionAbsolute:d}}async function Lu({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 p=s.has(d.id),h=!p&&d.parentId&&i.find(w=>w.id===d.parentId);(p||h)&&i.push(d)}const a=new Set(t.map(d=>d.id)),l=o.filter(d=>d.deletable!==!1),u=Du(i,l);for(const d of l)a.has(d.id)&&!u.find(h=>h.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 Ze=(e,t=0,n=1)=>Math.min(Math.max(e,t),n),Le=(e={x:0,y:0},t,n)=>({x:Ze(e.x,t[0][0],t[1][0]-(n?.width??0)),y:Ze(e.y,t[0][1],t[1][1]-(n?.height??0))});function Hr(e,t,n){const{width:o,height:r}=Ne(n),{x:s,y:i}=n.internals.positionAbsolute;return Le(e,[[s,i],[s+o,i+r]],t)}const ho=(e,t,n)=>e<t?Ze(Math.abs(e-t),1,t)/t:e>n?-Ze(Math.abs(e-n),1,t)/t:0,Rr=(e,t,n=15,o=40)=>{const r=ho(e.x,o,t.width-o)*n,s=ho(e.y,o,t.height-o)*n;return[r,s]},Xt=(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)}),mn=({x:e,y:t,width:n,height:o})=>({x:e,y:t,x2:e+n,y2:t+o}),Yt=({x:e,y:t,x2:n,y2:o})=>({x:e,y:t,width:n-e,height:o-t}),We=(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}},$t=(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)}},jr=(e,t)=>Yt(Xt(mn(e),mn(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)},go=e=>ye(e.width)&&ye(e.height)&&ye(e.x)&&ye(e.y),ye=e=>!isNaN(e)&&isFinite(e),Hu=(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},zt=({x:e,y:t},[n,o,r])=>({x:e*r+n,y:t*r+o});function je(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 Ru(e,t,n){if(typeof e=="string"||typeof e=="number"){const o=je(e,n),r=je(e,t);return{top:o,right:r,bottom:o,left:r,x:r*2,y:o*2}}if(typeof e=="object"){const o=je(e.top??e.y??0,n),r=je(e.bottom??e.y??0,n),s=je(e.left??e.x??0,t),i=je(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 ju(e,t,n,o,r,s){const{x:i,y:a}=zt(e,[t,n,o]),{x:l,y:c}=zt({x:e.x+e.width,y:e.y+e.height},[t,n,o]),u=r-l,f=s-c;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=Ru(s,t,n),a=(t-i.x)/e.width,l=(n-i.y)/e.height,c=Math.min(a,l),u=Ze(c,o,r),f=e.x+e.width/2,d=e.y+e.height/2,p=t/2-f*u,h=n/2-d*u,w=ju(e,p,h,u,t,n),v={left:Math.min(w.left-i.left,0),top:Math.min(w.top-i.top,0),right:Math.min(w.right-i.right,0),bottom:Math.min(w.bottom-i.bottom,0)};return{x:p-v.left+v.right,y:h-v.top+v.bottom,zoom:u}},ct=()=>typeof navigator<"u"&&navigator?.userAgent?.indexOf("Mac")>=0;function Ge(e){return e!=null&&e!=="parent"}function Ne(e){return{width:e.measured?.width??e.width??e.initialWidth??0,height:e.measured?.height??e.height??e.initialHeight??0}}function Vr(e){return(e.measured?.width??e.width??e.initialWidth)!==void 0&&(e.measured?.height??e.height??e.initialHeight)!==void 0}function Or(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 po(e,t){if(e.size!==t.size)return!1;for(const n of e)if(!t.has(n))return!1;return!0}function Vu(){let e,t;return{promise:new Promise((o,r)=>{e=o,t=r}),resolve:e,reject:t}}function Ou(e){return{...Tr,...e||{}}}function tt(e,{snapGrid:t=[0,0],snapToGrid:n=!1,transform:o,containerBounds:r}){const{x:s,y:i}=xe(e),a=gt({x:s-(r?.left??0),y:i-(r?.top??0)},o),{x:l,y:c}=n?ht(a,t):a;return{xSnapped:l,ySnapped:c,...a}}const Pn=e=>({width:e.offsetWidth,height:e.offsetHeight}),Br=e=>e?.getRootNode?.()||window?.document,Bu=["INPUT","SELECT","TEXTAREA"];function Fr(e){const t=e.composedPath?.()?.[0]||e.target;return t?.nodeType!==1?!1:Bu.includes(t.nodeName)||t.hasAttribute("contenteditable")||!!t.closest(".nokey")}const Xr=e=>"clientX"in e,xe=(e,t)=>{const n=Xr(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)}},mo=(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 Yr({sourceX:e,sourceY:t,targetX:n,targetY:o,sourceControlX:r,sourceControlY:s,targetControlX:i,targetControlY:a}){const l=e*.125+r*.375+i*.375+n*.125,c=t*.125+s*.375+a*.375+o*.125,u=Math.abs(l-e),f=Math.abs(c-t);return[l,c,u,f]}function wt(e,t){return e>=0?.5*e:t*25*Math.sqrt(-e)}function yo({pos:e,x1:t,y1:n,x2:o,y2:r,c:s}){switch(e){case Y.Left:return[t-wt(t-o,s),n];case Y.Right:return[t+wt(o-t,s),n];case Y.Top:return[t,n-wt(n-r,s)];case Y.Bottom:return[t,n+wt(r-n,s)]}}function Zr({sourceX:e,sourceY:t,sourcePosition:n=Y.Bottom,targetX:o,targetY:r,targetPosition:s=Y.Top,curvature:i=.25}){const[a,l]=yo({pos:n,x1:e,y1:t,x2:o,y2:r,c:i}),[c,u]=yo({pos:s,x1:o,y1:r,x2:e,y2:t,c:i}),[f,d,p,h]=Yr({sourceX:e,sourceY:t,targetX:o,targetY:r,sourceControlX:a,sourceControlY:l,targetControlX:c,targetControlY:u});return[`M${e},${t} C${a},${l} ${c},${u} ${o},${r}`,f,d,p,h]}function Wr({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 Fu({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 Xu({sourceNode:e,targetNode:t,width:n,height:o,transform:r}){const s=Xt($t(e),$t(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,Yt(s))>0}const Yu=({source:e,sourceHandle:t,target:n,targetHandle:o})=>`xy-edge__${e}${t||""}-${n}${o||""}`,Zu=(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)),Wu=(e,t,n={})=>{if(!e.source||!e.target)return t;const o=n.getEdgeId||Yu;let r;return zr(e)?r={...e}:r={...e,id:o(e)},Zu(r,t)?t:(r.sourceHandle===null&&delete r.sourceHandle,r.targetHandle===null&&delete r.targetHandle,t.concat(r))};function Gr({sourceX:e,sourceY:t,targetX:n,targetY:o}){const[r,s,i,a]=Wr({sourceX:e,sourceY:t,targetX:n,targetY:o});return[`M ${e},${t}L ${n},${o}`,r,s,i,a]}const xo={[Y.Left]:{x:-1,y:0},[Y.Right]:{x:1,y:0},[Y.Top]:{x:0,y:-1},[Y.Bottom]:{x:0,y:1}},Gu=({source:e,sourcePosition:t=Y.Bottom,target:n})=>t===Y.Left||t===Y.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},wo=(e,t)=>Math.sqrt(Math.pow(t.x-e.x,2)+Math.pow(t.y-e.y,2));function qu({source:e,sourcePosition:t=Y.Bottom,target:n,targetPosition:o=Y.Top,center:r,offset:s,stepPosition:i}){const a=xo[t],l=xo[o],c={x:e.x+a.x*s,y:e.y+a.y*s},u={x:n.x+l.x*s,y:n.y+l.y*s},f=Gu({source:c,sourcePosition:t,target:u}),d=f.x!==0?"x":"y",p=f[d];let h=[],w,v;const m={x:0,y:0},b={x:0,y:0},[,,g,x]=Wr({sourceX:e.x,sourceY:e.y,targetX:n.x,targetY:n.y});if(a[d]*l[d]===-1){d==="x"?(w=r.x??c.x+(u.x-c.x)*i,v=r.y??(c.y+u.y)/2):(w=r.x??(c.x+u.x)/2,v=r.y??c.y+(u.y-c.y)*i);const S=[{x:w,y:c.y},{x:w,y:u.y}],E=[{x:c.x,y:v},{x:u.x,y:v}];a[d]===p?h=d==="x"?S:E:h=d==="x"?E:S}else{const S=[{x:c.x,y:u.y}],E=[{x:u.x,y:c.y}];if(d==="x"?h=a.x===p?E:S:h=a.y===p?S:E,t===o){const $=Math.abs(e[d]-n[d]);if($<=s){const L=Math.min(s-1,s-$);a[d]===p?m[d]=(c[d]>e[d]?-1:1)*L:b[d]=(u[d]>n[d]?-1:1)*L}}if(t!==o){const $=d==="x"?"y":"x",L=a[d]===l[$],y=c[$]>u[$],M=c[$]<u[$];(a[d]===1&&(!L&&y||L&&M)||a[d]!==1&&(!L&&M||L&&y))&&(h=d==="x"?S:E)}const D={x:c.x+m.x,y:c.y+m.y},k={x:u.x+b.x,y:u.y+b.y},V=Math.max(Math.abs(D.x-h[0].x),Math.abs(k.x-h[0].x)),A=Math.max(Math.abs(D.y-h[0].y),Math.abs(k.y-h[0].y));V>=A?(w=(D.x+k.x)/2,v=h[0].y):(w=h[0].x,v=(D.y+k.y)/2)}return[[e,{x:c.x+m.x,y:c.y+m.y},...h,{x:u.x+b.x,y:u.y+b.y},n],w,v,g,x]}function Ku(e,t,n,o){const r=Math.min(wo(e,t)/2,wo(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 c=e.x<n.x?-1:1,u=e.y<n.y?1:-1;return`L ${s+r*c},${i}Q ${s},${i} ${s},${i+r*u}`}const a=e.x<n.x?1:-1,l=e.y<n.y?-1:1;return`L ${s},${i+r*l}Q ${s},${i} ${s+r*a},${i}`}function yn({sourceX:e,sourceY:t,sourcePosition:n=Y.Bottom,targetX:o,targetY:r,targetPosition:s=Y.Top,borderRadius:i=5,centerX:a,centerY:l,offset:c=20,stepPosition:u=.5}){const[f,d,p,h,w]=qu({source:{x:e,y:t},sourcePosition:n,target:{x:o,y:r},targetPosition:s,center:{x:a,y:l},offset:c,stepPosition:u});return[f.reduce((m,b,g)=>{let x="";return g>0&&g<f.length-1?x=Ku(f[g-1],b,f[g+1],i):x=`${g===0?"M":"L"}${b.x} ${b.y}`,m+=x,m},""),d,p,h,w]}function vo(e){return e&&!!(e.internals.handleBounds||e.handles?.length)&&!!(e.measured.width||e.width||e.initialWidth)}function Uu(e){const{sourceNode:t,targetNode:n}=e;if(!vo(t)||!vo(n))return null;const o=t.internals.handleBounds||_o(t.handles),r=n.internals.handleBounds||_o(n.handles),s=bo(o?.source??[],e.sourceHandle),i=bo(e.connectionMode===Ye.Strict?r?.target??[]:(r?.target??[]).concat(r?.source??[]),e.targetHandle);if(!s||!i)return e.onError?.("008",_e.error008(s?"target":"source",{id:e.id,sourceHandle:e.sourceHandle,targetHandle:e.targetHandle})),null;const a=s?.position||Y.Bottom,l=i?.position||Y.Top,c=He(t,s,a),u=He(n,i,l);return{sourceX:c.x,sourceY:c.y,targetX:u.x,targetY:u.y,sourcePosition:a,targetPosition:l}}function _o(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 He(e,t,n=Y.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??Ne(e);if(o)return{x:r+i/2,y:s+a/2};switch(t?.position??n){case Y.Top:return{x:r+i/2,y:s};case Y.Right:return{x:r+i,y:s+a/2};case Y.Bottom:return{x:r+i/2,y:s+a};case Y.Left:return{x:r,y:s+a/2}}}function bo(e,t){return e&&(t?e.find(n=>n.id===t):e[0])||null}function xn(e,t){return e?typeof e=="string"?e:`${t?`${t}__`:""}${Object.keys(e).sort().map(o=>`${o}=${e[o]}`).join("&")}`:""}function Qu(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(l=>{if(l&&typeof l=="object"){const c=xn(l,t);s.has(c)||(i.push({id:c,color:l.color||n,...l}),s.add(c))}}),i),[]).sort((i,a)=>i.id.localeCompare(a.id))}const qr=1e3,Ju=10,Tn={nodeOrigin:[0,0],nodeExtent:it,elevateNodesOnSelect:!0,zIndexMode:"basic",defaults:{}},ed={...Tn,checkEquality:!0};function Dn(e,t){const n={...e};for(const o in t)t[o]!==void 0&&(n[o]=t[o]);return n}function td(e,t,n){const o=Dn(Tn,n);for(const r of e.values())if(r.parentId)zn(r,e,t,o);else{const s=dt(r,o.nodeOrigin),i=Ge(r.extent)?r.extent:o.nodeExtent,a=Le(s,i,Ne(r));r.internals.positionAbsolute=a}}function nd(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 $n(e){return e==="manual"}function wn(e,t,n,o={}){const r=Dn(ed,o),s={i:0},i=new Map(t),a=r?.elevateNodesOnSelect&&!$n(r.zIndexMode)?qr:0;let l=e.length>0;t.clear(),n.clear();for(const c of e){let u=i.get(c.id);if(r.checkEquality&&c===u?.internals.userNode)t.set(c.id,u);else{const f=dt(c,r.nodeOrigin),d=Ge(c.extent)?c.extent:r.nodeExtent,p=Le(f,d,Ne(c));u={...r.defaults,...c,measured:{width:c.measured?.width,height:c.measured?.height},internals:{positionAbsolute:p,handleBounds:nd(c,u),z:Kr(c,a,r.zIndexMode),userNode:c}},t.set(c.id,u)}(u.measured===void 0||u.measured.width===void 0||u.measured.height===void 0)&&!u.hidden&&(l=!1),c.parentId&&zn(u,t,n,o,s)}return l}function od(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 zn(e,t,n,o,r){const{elevateNodesOnSelect:s,nodeOrigin:i,nodeExtent:a,zIndexMode:l}=Dn(Tn,o),c=e.parentId,u=t.get(c);if(!u){console.warn(`Parent node ${c} not found. Please make sure that parent nodes are in front of their child nodes in the nodes array.`);return}od(e,n),r&&!u.parentId&&u.internals.rootParentIndex===void 0&&l==="auto"&&(u.internals.rootParentIndex=++r.i,u.internals.z=u.internals.z+r.i*Ju),r&&u.internals.rootParentIndex!==void 0&&(r.i=u.internals.rootParentIndex);const f=s&&!$n(l)?qr:0,{x:d,y:p,z:h}=rd(e,u,i,a,f,l),{positionAbsolute:w}=e.internals,v=d!==w.x||p!==w.y;(v||h!==e.internals.z)&&t.set(e.id,{...e,internals:{...e.internals,positionAbsolute:v?{x:d,y:p}:w,z:h}})}function Kr(e,t,n){const o=ye(e.zIndex)?e.zIndex:0;return $n(n)?o:o+(e.selected?t:0)}function rd(e,t,n,o,r,s){const{x:i,y:a}=t.internals.positionAbsolute,l=Ne(e),c=dt(e,n),u=Ge(e.extent)?Le(c,e.extent,l):c;let f=Le({x:i+u.x,y:a+u.y},o,l);e.extent==="parent"&&(f=Hr(f,l,t));const d=Kr(e,r,s),p=t.internals.z??0;return{x:f.x,y:f.y,z:p>=d?p+1:d}}function Ln(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 l=s.get(i.parentId)?.expandedRect??We(a),c=jr(l,i.rect);s.set(i.parentId,{expandedRect:c,parent:a})}return s.size>0&&s.forEach(({expandedRect:i,parent:a},l)=>{const c=a.internals.positionAbsolute,u=Ne(a),f=a.origin??o,d=i.x<c.x?Math.round(Math.abs(c.x-i.x)):0,p=i.y<c.y?Math.round(Math.abs(c.y-i.y)):0,h=Math.max(u.width,Math.round(i.width)),w=Math.max(u.height,Math.round(i.height)),v=(h-u.width)*f[0],m=(w-u.height)*f[1];(d>0||p>0||v||m)&&(r.push({id:l,type:"position",position:{x:a.position.x-d+v,y:a.position.y-p+m}}),n.get(l)?.forEach(b=>{e.some(g=>g.id===b.id)||r.push({id:b.id,type:"position",position:{x:b.position.x+d,y:b.position.y+p}})})),(u.width<i.width||u.height<i.height||d||p)&&r.push({id:l,type:"dimensions",setAttributes:!0,dimensions:{width:h+(d?f[0]*d-v:0),height:w+(p?f[1]*p-m:0)}})}),r}function id(e,t,n,o,r,s,i){const a=o?.querySelector(".xyflow__viewport");let l=!1;if(!a)return{changes:[],updatedInternals:l};const c=[],u=window.getComputedStyle(a),{m22:f}=new window.DOMMatrixReadOnly(u.transform),d=[];for(const p of e.values()){const h=t.get(p.id);if(!h)continue;if(h.hidden){t.set(h.id,{...h,internals:{...h.internals,handleBounds:void 0}}),l=!0;continue}const w=Pn(p.nodeElement),v=h.measured.width!==w.width||h.measured.height!==w.height;if(!!(w.width&&w.height&&(v||!h.internals.handleBounds||p.force))){const b=p.nodeElement.getBoundingClientRect(),g=Ge(h.extent)?h.extent:s;let{positionAbsolute:x}=h.internals;h.parentId&&h.extent==="parent"?x=Hr(x,w,t.get(h.parentId)):g&&(x=Le(x,g,w));const N={...h,measured:w,internals:{...h.internals,positionAbsolute:x,handleBounds:{source:mo("source",p.nodeElement,b,f,h.id),target:mo("target",p.nodeElement,b,f,h.id)}}};t.set(h.id,N),h.parentId&&zn(N,t,n,{nodeOrigin:r,zIndexMode:i}),l=!0,v&&(c.push({id:h.id,type:"dimensions",dimensions:w}),h.expandParent&&h.parentId&&d.push({id:h.id,parentId:h.parentId,rect:We(N,r)}))}}if(d.length>0){const p=Ln(d,t,n,r);c.push(...p)}return{changes:c,updatedInternals:l}}async function sd({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 So(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 l=o.get(i)||new Map;if(o.set(i,l.set(n,t)),s){i=`${r}-${e}-${s}`;const c=o.get(i)||new Map;o.set(i,c.set(n,t))}}function Ur(e,t,n){e.clear(),t.clear();for(const o of n){const{source:r,target:s,sourceHandle:i=null,targetHandle:a=null}=o,l={edgeId:o.id,source:r,target:s,sourceHandle:i,targetHandle:a},c=`${r}-${i}--${s}-${a}`,u=`${s}-${a}--${r}-${i}`;So("source",l,u,e,r,i),So("target",l,c,e,s,a),t.set(o.id,o)}}function Qr(e,t){if(!e.parentId)return!1;const n=t.get(e.parentId);return n?n.selected?!0:Qr(n,t):!1}function Eo(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 ad(e,t,n,o){const r=new Map;for(const[s,i]of e)if((i.selected||i.id===o)&&(!i.parentId||!Qr(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 rn({nodeId:e,dragItems:t,nodeLookup:n,dragging:o=!0}){const r=[];for(const[i,a]of t){const l=n.get(i)?.internals.userNode;l&&r.push({...l,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 cd({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 ld({onNodeMouseDown:e,getStoreItems:t,onDragStart:n,onDrag:o,onDragStop:r}){let s={x:null,y:null},i=0,a=new Map,l=!1,c={x:0,y:0},u=null,f=!1,d=null,p=!1,h=!1,w=null;function v({noDragClassName:b,handleSelector:g,domNode:x,isSelectable:N,nodeId:S,nodeClickDistance:E=0}){d=de(x);function D({x:$,y:L}){const{nodeLookup:y,nodeExtent:M,snapGrid:C,snapToGrid:P,nodeOrigin:T,onNodeDrag:I,onSelectionDrag:H,onError:j,updateNodePositions:R}=t();s={x:$,y:L};let F=!1;const B=a.size>1,G=B&&M?mn(ft(a)):null,K=B&&P?cd({dragItems:a,snapGrid:C,x:$,y:L}):null;for(const[W,O]of a){if(!y.has(W))continue;let X={x:$-O.distance.x,y:L-O.distance.y};P&&(X=K?{x:Math.round(X.x+K.x),y:Math.round(X.y+K.y)}:ht(X,C));let Q=null;if(B&&M&&!O.extent&&G){const{positionAbsolute:q}=O.internals,ee=q.x-G.x+M[0][0],ne=q.x+O.measured.width-G.x2+M[1][0],te=q.y-G.y+M[0][1],se=q.y+O.measured.height-G.y2+M[1][1];Q=[[ee,te],[ne,se]]}const{position:U,positionAbsolute:Z}=Lr({nodeId:W,nextPosition:X,nodeLookup:y,nodeExtent:Q||M,nodeOrigin:T,onError:j});F=F||O.position.x!==U.x||O.position.y!==U.y,O.position=U,O.internals.positionAbsolute=Z}if(h=h||F,!!F&&(R(a,!0),w&&(o||I||!S&&H))){const[W,O]=rn({nodeId:S,dragItems:a,nodeLookup:y});o?.(w,a,W,O),I?.(w,W,O),S||H?.(w,O)}}async function k(){if(!u)return;const{transform:$,panBy:L,autoPanSpeed:y,autoPanOnNodeDrag:M}=t();if(!M){l=!1,cancelAnimationFrame(i);return}const[C,P]=Rr(c,u,y);(C!==0||P!==0)&&(s.x=(s.x??0)-C/$[2],s.y=(s.y??0)-P/$[2],await L({x:C,y:P})&&D(s)),i=requestAnimationFrame(k)}function V($){const{nodeLookup:L,multiSelectionActive:y,nodesDraggable:M,transform:C,snapGrid:P,snapToGrid:T,selectNodesOnDrag:I,onNodeDragStart:H,onSelectionDragStart:j,unselectNodesAndEdges:R}=t();f=!0,(!I||!N)&&!y&&S&&(L.get(S)?.selected||R()),N&&I&&S&&e?.(S);const F=tt($.sourceEvent,{transform:C,snapGrid:P,snapToGrid:T,containerBounds:u});if(s=F,a=ad(L,M,F,S),a.size>0&&(n||H||!S&&j)){const[B,G]=rn({nodeId:S,dragItems:a,nodeLookup:L});n?.($.sourceEvent,a,B,G),H?.($.sourceEvent,B,G),S||j?.($.sourceEvent,G)}}const A=wr().clickDistance(E).on("start",$=>{const{domNode:L,nodeDragThreshold:y,transform:M,snapGrid:C,snapToGrid:P}=t();u=L?.getBoundingClientRect()||null,p=!1,h=!1,w=$.sourceEvent,y===0&&V($),s=tt($.sourceEvent,{transform:M,snapGrid:C,snapToGrid:P,containerBounds:u}),c=xe($.sourceEvent,u)}).on("drag",$=>{const{autoPanOnNodeDrag:L,transform:y,snapGrid:M,snapToGrid:C,nodeDragThreshold:P,nodeLookup:T}=t(),I=tt($.sourceEvent,{transform:y,snapGrid:M,snapToGrid:C,containerBounds:u});if(w=$.sourceEvent,($.sourceEvent.type==="touchmove"&&$.sourceEvent.touches.length>1||S&&!T.has(S))&&(p=!0),!p){if(!l&&L&&f&&(l=!0,k()),!f){const H=xe($.sourceEvent,u),j=H.x-c.x,R=H.y-c.y;Math.sqrt(j*j+R*R)>P&&V($)}(s.x!==I.xSnapped||s.y!==I.ySnapped)&&a&&f&&(c=xe($.sourceEvent,u),D(I))}}).on("end",$=>{if(!(!f||p)&&(l=!1,f=!1,cancelAnimationFrame(i),a.size>0)){const{nodeLookup:L,updateNodePositions:y,onNodeDragStop:M,onSelectionDragStop:C}=t();if(h&&(y(a,!1),h=!1),r||M||!S&&C){const[P,T]=rn({nodeId:S,dragItems:a,nodeLookup:L,dragging:!1});r?.($.sourceEvent,a,P,T),M?.($.sourceEvent,P,T),S||C?.($.sourceEvent,T)}}}).filter($=>{const L=$.target;return!$.button&&(!b||!Eo(L,`.${b}`,x))&&(!g||Eo(L,g,x))});d.call(A)}function m(){d?.on(".drag",null)}return{update:v,destroy:m}}function ud(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,We(s))>0&&o.push(s);return o}const dd=250;function fd(e,t,n,o){let r=[],s=1/0;const i=ud(e,n,t+dd);for(const a of i){const l=[...a.internals.handleBounds?.source??[],...a.internals.handleBounds?.target??[]];for(const c of l){if(o.nodeId===c.nodeId&&o.type===c.type&&o.id===c.id)continue;const{x:u,y:f}=He(a,c,c.position,!0),d=Math.sqrt(Math.pow(u-e.x,2)+Math.pow(f-e.y,2));d>t||(d<s?(r=[{...c,x:u,y:f}],s=d):d===s&&r.push({...c,x:u,y:f}))}}if(!r.length)return null;if(r.length>1){const a=o.type==="source"?"target":"source";return r.find(l=>l.type===a)??r[0]}return r[0]}function Jr(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??[]],l=(n?a?.find(c=>c.id===n):a?.[0])??null;return l&&s?{...l,...He(i,l,l.position,!0)}:l}function ei(e,t){return e||(t?.classList.contains("target")?"target":t?.classList.contains("source")?"source":null)}function hd(e,t){let n=null;return t?n=!0:e&&!t&&(n=!1),n}const ti=()=>!0;function gd(e,{connectionMode:t,connectionRadius:n,handleId:o,nodeId:r,edgeUpdaterType:s,isTarget:i,domNode:a,nodeLookup:l,lib:c,autoPanOnConnect:u,flowId:f,panBy:d,cancelConnection:p,onConnectStart:h,onConnect:w,onConnectEnd:v,isValidConnection:m=ti,onReconnectEnd:b,updateConnection:g,getTransform:x,getFromHandle:N,autoPanSpeed:S,dragThreshold:E=1,handleDomNode:D}){const k=Br(e.target);let V=0,A;const{x:$,y:L}=xe(e),y=ei(s,D),M=a?.getBoundingClientRect();let C=!1;if(!M||!y)return;const P=Jr(r,y,o,l,t);if(!P)return;let T=xe(e,M),I=!1,H=null,j=!1,R=null;function F(){if(!u||!M)return;const[U,Z]=Rr(T,M,S);d({x:U,y:Z}),V=requestAnimationFrame(F)}const B={...P,nodeId:r,type:y,position:P.position},G=l.get(r);let W={inProgress:!0,isValid:null,from:He(G,B,Y.Left,!0),fromHandle:B,fromPosition:B.position,fromNode:G,to:T,toHandle:null,toPosition:fo[B.position],toNode:null,pointer:T};function O(){C=!0,g(W),h?.(e,{nodeId:r,handleId:o,handleType:y})}E===0&&O();function X(U){if(!C){const{x:se,y:ce}=xe(U),le=se-$,oe=ce-L;if(!(le*le+oe*oe>E*E))return;O()}if(!N()||!B){Q(U);return}const Z=x();T=xe(U,M),A=fd(gt(T,Z,!1,[1,1]),n,l,B),I||(F(),I=!0);const q=ni(U,{handle:A,connectionMode:t,fromNodeId:r,fromHandleId:o,fromType:i?"target":"source",isValidConnection:m,doc:k,lib:c,flowId:f,nodeLookup:l});R=q.handleDomNode,H=q.connection,j=hd(!!A,q.isValid);const ee=l.get(r),ne=ee?He(ee,B,Y.Left,!0):W.from,te={...W,from:ne,isValid:j,to:q.toHandle&&j?zt({x:q.toHandle.x,y:q.toHandle.y},Z):T,toHandle:q.toHandle,toPosition:j&&q.toHandle?q.toHandle.position:fo[B.position],toNode:q.toHandle?l.get(q.toHandle.nodeId):null,pointer:T};g(te),W=te}function Q(U){if(!("touches"in U&&U.touches.length>0)){if(C){(A||R)&&H&&j&&w?.(H);const{inProgress:Z,...q}=W,ee={...q,toPosition:W.toHandle?W.toPosition:null};v?.(U,ee),s&&b?.(U,ee)}p(),cancelAnimationFrame(V),I=!1,j=!1,H=null,R=null,k.removeEventListener("mousemove",X),k.removeEventListener("mouseup",Q),k.removeEventListener("touchmove",X),k.removeEventListener("touchend",Q)}}k.addEventListener("mousemove",X),k.addEventListener("mouseup",Q),k.addEventListener("touchmove",X),k.addEventListener("touchend",Q)}function ni(e,{handle:t,connectionMode:n,fromNodeId:o,fromHandleId:r,fromType:s,doc:i,lib:a,flowId:l,isValidConnection:c=ti,nodeLookup:u}){const f=s==="target",d=t?i.querySelector(`.${a}-flow__handle[data-id="${l}-${t?.nodeId}-${t?.id}-${t?.type}"]`):null,{x:p,y:h}=xe(e),w=i.elementFromPoint(p,h),v=w?.classList.contains(`${a}-flow__handle`)?w:d,m={handleDomNode:v,isValid:!1,connection:null,toHandle:null};if(v){const b=ei(void 0,v),g=v.getAttribute("data-nodeid"),x=v.getAttribute("data-handleid"),N=v.classList.contains("connectable"),S=v.classList.contains("connectableend");if(!g||!b)return m;const E={source:f?g:o,sourceHandle:f?x:r,target:f?o:g,targetHandle:f?r:x};m.connection=E;const k=N&&S&&(n===Ye.Strict?f&&b==="source"||!f&&b==="target":g!==o||x!==r);m.isValid=k&&c(E),m.toHandle=Jr(g,b,x,u,n,!0)}return m}const vn={onPointerDown:gd,isValid:ni};function pd({domNode:e,panZoom:t,getTransform:n,getViewScale:o}){const r=de(e);function s({translateExtent:a,width:l,height:c,zoomStep:u=1,pannable:f=!0,zoomable:d=!0,inversePan:p=!1}){const h=g=>{if(g.sourceEvent.type!=="wheel"||!t)return;const x=n(),N=g.sourceEvent.ctrlKey&&ct()?10:1,S=-g.sourceEvent.deltaY*(g.sourceEvent.deltaMode===1?.05:g.sourceEvent.deltaMode?1:.002)*u,E=x[2]*Math.pow(2,S*N);t.scaleTo(E)};let w=[0,0];const v=g=>{(g.sourceEvent.type==="mousedown"||g.sourceEvent.type==="touchstart")&&(w=[g.sourceEvent.clientX??g.sourceEvent.touches[0].clientX,g.sourceEvent.clientY??g.sourceEvent.touches[0].clientY])},m=g=>{const x=n();if(g.sourceEvent.type!=="mousemove"&&g.sourceEvent.type!=="touchmove"||!t)return;const N=[g.sourceEvent.clientX??g.sourceEvent.touches[0].clientX,g.sourceEvent.clientY??g.sourceEvent.touches[0].clientY],S=[N[0]-w[0],N[1]-w[1]];w=N;const E=o()*Math.max(x[2],Math.log(x[2]))*(p?-1:1),D={x:x[0]-S[0]*E,y:x[1]-S[1]*E},k=[[0,0],[l,c]];t.setViewportConstrained({x:D.x,y:D.y,zoom:x[2]},k,a)},b=Ar().on("start",v).on("zoom",f?m:null).on("zoom.wheel",d?h:null);r.call(b,{})}function i(){r.on("zoom",null)}return{update:s,destroy:i,pointer:me}}const Zt=e=>({x:e.x,y:e.y,zoom:e.k}),sn=({x:e,y:t,zoom:n})=>Ft.translate(e,t).scale(n),Ve=(e,t)=>e.target.closest(`.${t}`),oi=(e,t)=>t===2&&Array.isArray(e)&&e.includes(2),md=e=>((e*=2)<=1?e*e*e:(e-=2)*e*e+2)/2,an=(e,t=0,n=md,o=()=>{})=>{const r=typeof t=="number"&&t>0;return r||o(),r?e.transition().duration(t).ease(n).on("end",o):e},ri=e=>{const t=e.ctrlKey&&ct()?10:1;return-e.deltaY*(e.deltaMode===1?.05:e.deltaMode?1:.002)*t};function yd({zoomPanValues:e,noWheelClassName:t,d3Selection:n,d3Zoom:o,panOnScrollMode:r,panOnScrollSpeed:s,zoomOnPinch:i,onPanZoomStart:a,onPanZoom:l,onPanZoomEnd:c}){return u=>{if(Ve(u,t))return u.ctrlKey&&u.preventDefault(),!1;u.preventDefault(),u.stopImmediatePropagation();const f=n.property("__zoom").k||1;if(u.ctrlKey&&i){const v=me(u),m=ri(u),b=f*Math.pow(2,m);o.scaleTo(n,b,v,u);return}const d=u.deltaMode===1?20:1;let p=r===$e.Vertical?0:u.deltaX*d,h=r===$e.Horizontal?0:u.deltaY*d;!ct()&&u.shiftKey&&r!==$e.Vertical&&(p=u.deltaY*d,h=0),o.translateBy(n,-(p/f)*s,-(h/f)*s,{internal:!0});const w=Zt(n.property("__zoom"));clearTimeout(e.panScrollTimeout),e.isPanScrolling?(l?.(u,w),e.panScrollTimeout=setTimeout(()=>{c?.(u,w),e.isPanScrolling=!1},150)):(e.isPanScrolling=!0,a?.(u,w))}}function xd({noWheelClassName:e,preventScrolling:t,d3ZoomHandler:n}){return function(o,r){const s=o.type==="wheel",i=!t&&s&&!o.ctrlKey,a=Ve(o,e);if(o.ctrlKey&&s&&a&&o.preventDefault(),i||a)return null;o.preventDefault(),n.call(this,o,r)}}function wd({zoomPanValues:e,onDraggingChange:t,onPanZoomStart:n}){return o=>{if(o.sourceEvent?.internal)return;const r=Zt(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 vd({zoomPanValues:e,panOnDrag:t,onPaneContextMenu:n,onTransformChange:o,onPanZoom:r}){return s=>{e.usedRightMouseButton=!!(n&&oi(t,e.mouseButton??0)),s.sourceEvent?.sync||o([s.transform.x,s.transform.y,s.transform.k]),r&&!s.sourceEvent?.internal&&r?.(s.sourceEvent,Zt(s.transform))}}function _d({zoomPanValues:e,panOnDrag:t,panOnScroll:n,onDraggingChange:o,onPanZoomEnd:r,onPaneContextMenu:s}){return i=>{if(!i.sourceEvent?.internal&&(e.isZoomingOrPanning=!1,s&&oi(t,e.mouseButton??0)&&!e.usedRightMouseButton&&i.sourceEvent&&s(i.sourceEvent),e.usedRightMouseButton=!1,o(!1),r)){const a=Zt(i.transform);e.prevViewport=a,clearTimeout(e.timerId),e.timerId=setTimeout(()=>{r?.(i.sourceEvent,a)},n?150:0)}}}function bd({zoomActivationKeyPressed:e,zoomOnScroll:t,zoomOnPinch:n,panOnDrag:o,panOnScroll:r,zoomOnDoubleClick:s,userSelectionActive:i,noWheelClassName:a,noPanClassName:l,lib:c,connectionInProgress:u}){return f=>{const d=e||t,p=n&&f.ctrlKey,h=f.type==="wheel";if(f.button===1&&f.type==="mousedown"&&(Ve(f,`${c}-flow__node`)||Ve(f,`${c}-flow__edge`)))return!0;if(!o&&!d&&!r&&!s&&!n||i||u&&!h||Ve(f,a)&&h||Ve(f,l)&&(!h||r&&h&&!e)||!n&&f.ctrlKey&&h)return!1;if(!n&&f.type==="touchstart"&&f.touches?.length>1)return f.preventDefault(),!1;if(!d&&!r&&!p&&h||!o&&(f.type==="mousedown"||f.type==="touchstart")||Array.isArray(o)&&!o.includes(f.button)&&f.type==="mousedown")return!1;const w=Array.isArray(o)&&o.includes(f.button)||!f.button||f.button<=1;return(!f.ctrlKey||h)&&w}}function Sd({domNode:e,minZoom:t,maxZoom:n,translateExtent:o,viewport:r,onPanZoom:s,onPanZoomStart:i,onPanZoomEnd:a,onDraggingChange:l}){const c={isZoomingOrPanning:!1,usedRightMouseButton:!1,prevViewport:{},mouseButton:0,timerId:void 0,panScrollTimeout:void 0,isPanScrolling:!1},u=e.getBoundingClientRect(),f=Ar().scaleExtent([t,n]).translateExtent(o),d=de(e).call(f);b({x:r.x,y:r.y,zoom:Ze(r.zoom,t,n)},[[0,0],[u.width,u.height]],o);const p=d.on("wheel.zoom"),h=d.on("dblclick.zoom");f.wheelDelta(ri);function w(A,$){return d?new Promise(L=>{f?.interpolate($?.interpolate==="linear"?en:Ct).transform(an(d,$?.duration,$?.ease,()=>L(!0)),A)}):Promise.resolve(!1)}function v({noWheelClassName:A,noPanClassName:$,onPaneContextMenu:L,userSelectionActive:y,panOnScroll:M,panOnDrag:C,panOnScrollMode:P,panOnScrollSpeed:T,preventScrolling:I,zoomOnPinch:H,zoomOnScroll:j,zoomOnDoubleClick:R,zoomActivationKeyPressed:F,lib:B,onTransformChange:G,connectionInProgress:K,paneClickDistance:W,selectionOnDrag:O}){y&&!c.isZoomingOrPanning&&m();const X=M&&!F&&!y;f.clickDistance(O?1/0:!ye(W)||W<0?0:W);const Q=X?yd({zoomPanValues:c,noWheelClassName:A,d3Selection:d,d3Zoom:f,panOnScrollMode:P,panOnScrollSpeed:T,zoomOnPinch:H,onPanZoomStart:i,onPanZoom:s,onPanZoomEnd:a}):xd({noWheelClassName:A,preventScrolling:I,d3ZoomHandler:p});if(d.on("wheel.zoom",Q,{passive:!1}),!y){const Z=wd({zoomPanValues:c,onDraggingChange:l,onPanZoomStart:i});f.on("start",Z);const q=vd({zoomPanValues:c,panOnDrag:C,onPaneContextMenu:!!L,onPanZoom:s,onTransformChange:G});f.on("zoom",q);const ee=_d({zoomPanValues:c,panOnDrag:C,panOnScroll:M,onPaneContextMenu:L,onPanZoomEnd:a,onDraggingChange:l});f.on("end",ee)}const U=bd({zoomActivationKeyPressed:F,panOnDrag:C,zoomOnScroll:j,panOnScroll:M,zoomOnDoubleClick:R,zoomOnPinch:H,userSelectionActive:y,noPanClassName:$,noWheelClassName:A,lib:B,connectionInProgress:K});f.filter(U),R?d.on("dblclick.zoom",h):d.on("dblclick.zoom",null)}function m(){f.on("zoom",null)}async function b(A,$,L){const y=sn(A),M=f?.constrain()(y,$,L);return M&&await w(M),new Promise(C=>C(M))}async function g(A,$){const L=sn(A);return await w(L,$),new Promise(y=>y(L))}function x(A){if(d){const $=sn(A),L=d.property("__zoom");(L.k!==A.zoom||L.x!==A.x||L.y!==A.y)&&f?.transform(d,$,null,{sync:!0})}}function N(){const A=d?kr(d.node()):{x:0,y:0,k:1};return{x:A.x,y:A.y,zoom:A.k}}function S(A,$){return d?new Promise(L=>{f?.interpolate($?.interpolate==="linear"?en:Ct).scaleTo(an(d,$?.duration,$?.ease,()=>L(!0)),A)}):Promise.resolve(!1)}function E(A,$){return d?new Promise(L=>{f?.interpolate($?.interpolate==="linear"?en:Ct).scaleBy(an(d,$?.duration,$?.ease,()=>L(!0)),A)}):Promise.resolve(!1)}function D(A){f?.scaleExtent(A)}function k(A){f?.translateExtent(A)}function V(A){const $=!ye(A)||A<0?0:A;f?.clickDistance($)}return{update:v,destroy:m,setViewport:g,setViewportConstrained:b,getViewport:N,scaleTo:S,scaleBy:E,setScaleExtent:D,setTranslateExtent:k,syncViewport:x,setClickDistance:V}}var qe;(function(e){e.Line="line",e.Handle="handle"})(qe||(qe={}));function Ed({width:e,prevWidth:t,height:n,prevHeight:o,affectsX:r,affectsY:s}){const i=e-t,a=n-o,l=[i>0?1:i<0?-1:0,a>0?1:a<0?-1:0];return i&&r&&(l[0]=l[0]*-1),a&&s&&(l[1]=l[1]*-1),l}function Co(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 Me(e,t){return Math.max(0,t-e)}function Ie(e,t){return Math.max(0,e-t)}function vt(e,t,n){return Math.max(0,t-e,e-n)}function No(e,t){return e?!t:t}function Cd(e,t,n,o,r,s,i,a){let{affectsX:l,affectsY:c}=t;const{isHorizontal:u,isVertical:f}=t,d=u&&f,{xSnapped:p,ySnapped:h}=n,{minWidth:w,maxWidth:v,minHeight:m,maxHeight:b}=o,{x:g,y:x,width:N,height:S,aspectRatio:E}=e;let D=Math.floor(u?p-e.pointerX:0),k=Math.floor(f?h-e.pointerY:0);const V=N+(l?-D:D),A=S+(c?-k:k),$=-s[0]*N,L=-s[1]*S;let y=vt(V,w,v),M=vt(A,m,b);if(i){let T=0,I=0;l&&D<0?T=Me(g+D+$,i[0][0]):!l&&D>0&&(T=Ie(g+V+$,i[1][0])),c&&k<0?I=Me(x+k+L,i[0][1]):!c&&k>0&&(I=Ie(x+A+L,i[1][1])),y=Math.max(y,T),M=Math.max(M,I)}if(a){let T=0,I=0;l&&D>0?T=Ie(g+D,a[0][0]):!l&&D<0&&(T=Me(g+V,a[1][0])),c&&k>0?I=Ie(x+k,a[0][1]):!c&&k<0&&(I=Me(x+A,a[1][1])),y=Math.max(y,T),M=Math.max(M,I)}if(r){if(u){const T=vt(V/E,m,b)*E;if(y=Math.max(y,T),i){let I=0;!l&&!c||l&&!c&&d?I=Ie(x+L+V/E,i[1][1])*E:I=Me(x+L+(l?D:-D)/E,i[0][1])*E,y=Math.max(y,I)}if(a){let I=0;!l&&!c||l&&!c&&d?I=Me(x+V/E,a[1][1])*E:I=Ie(x+(l?D:-D)/E,a[0][1])*E,y=Math.max(y,I)}}if(f){const T=vt(A*E,w,v)/E;if(M=Math.max(M,T),i){let I=0;!l&&!c||c&&!l&&d?I=Ie(g+A*E+$,i[1][0])/E:I=Me(g+(c?k:-k)*E+$,i[0][0])/E,M=Math.max(M,I)}if(a){let I=0;!l&&!c||c&&!l&&d?I=Me(g+A*E,a[1][0])/E:I=Ie(g+(c?k:-k)*E,a[0][0])/E,M=Math.max(M,I)}}}k=k+(k<0?M:-M),D=D+(D<0?y:-y),r&&(d?V>A*E?k=(No(l,c)?-D:D)/E:D=(No(l,c)?-k:k)*E:u?(k=D/E,c=l):(D=k*E,l=c));const C=l?g+D:g,P=c?x+k:x;return{width:N+(l?-D:D),height:S+(c?-k:k),x:s[0]*D*(l?-1:1)+C,y:s[1]*k*(c?-1:1)+P}}const ii={width:0,height:0,x:0,y:0},Nd={...ii,pointerX:0,pointerY:0,aspectRatio:1};function Md(e){return[[0,0],[e.measured.width,e.measured.height]]}function Id(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,l=n[1]*i;return[[o-a,r-l],[o+s-a,r+i-l]]}function kd({domNode:e,nodeId:t,getStoreItems:n,onChange:o,onEnd:r}){const s=de(e);let i={controlDirection:Co("bottom-right"),boundaries:{minWidth:0,minHeight:0,maxWidth:Number.MAX_VALUE,maxHeight:Number.MAX_VALUE},resizeDirection:void 0,keepAspectRatio:!1};function a({controlPosition:c,boundaries:u,keepAspectRatio:f,resizeDirection:d,onResizeStart:p,onResize:h,onResizeEnd:w,shouldResize:v}){let m={...ii},b={...Nd};i={boundaries:u,resizeDirection:d,keepAspectRatio:f,controlDirection:Co(c)};let g,x=null,N=[],S,E,D,k=!1;const V=wr().on("start",A=>{const{nodeLookup:$,transform:L,snapGrid:y,snapToGrid:M,nodeOrigin:C,paneDomNode:P}=n();if(g=$.get(t),!g)return;x=P?.getBoundingClientRect()??null;const{xSnapped:T,ySnapped:I}=tt(A.sourceEvent,{transform:L,snapGrid:y,snapToGrid:M,containerBounds:x});m={width:g.measured.width??0,height:g.measured.height??0,x:g.position.x??0,y:g.position.y??0},b={...m,pointerX:T,pointerY:I,aspectRatio:m.width/m.height},S=void 0,g.parentId&&(g.extent==="parent"||g.expandParent)&&(S=$.get(g.parentId),E=S&&g.extent==="parent"?Md(S):void 0),N=[],D=void 0;for(const[H,j]of $)if(j.parentId===t&&(N.push({id:H,position:{...j.position},extent:j.extent}),j.extent==="parent"||j.expandParent)){const R=Id(j,g,j.origin??C);D?D=[[Math.min(R[0][0],D[0][0]),Math.min(R[0][1],D[0][1])],[Math.max(R[1][0],D[1][0]),Math.max(R[1][1],D[1][1])]]:D=R}p?.(A,{...m})}).on("drag",A=>{const{transform:$,snapGrid:L,snapToGrid:y,nodeOrigin:M}=n(),C=tt(A.sourceEvent,{transform:$,snapGrid:L,snapToGrid:y,containerBounds:x}),P=[];if(!g)return;const{x:T,y:I,width:H,height:j}=m,R={},F=g.origin??M,{width:B,height:G,x:K,y:W}=Cd(b,i.controlDirection,C,i.boundaries,i.keepAspectRatio,F,E,D),O=B!==H,X=G!==j,Q=K!==T&&O,U=W!==I&&X;if(!Q&&!U&&!O&&!X)return;if((Q||U||F[0]===1||F[1]===1)&&(R.x=Q?K:m.x,R.y=U?W:m.y,m.x=R.x,m.y=R.y,N.length>0)){const ne=K-T,te=W-I;for(const se of N)se.position={x:se.position.x-ne+F[0]*(B-H),y:se.position.y-te+F[1]*(G-j)},P.push(se)}if((O||X)&&(R.width=O&&(!i.resizeDirection||i.resizeDirection==="horizontal")?B:m.width,R.height=X&&(!i.resizeDirection||i.resizeDirection==="vertical")?G:m.height,m.width=R.width,m.height=R.height),S&&g.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 Z=Ed({width:m.width,prevWidth:H,height:m.height,prevHeight:j,affectsX:i.controlDirection.affectsX,affectsY:i.controlDirection.affectsY}),q={...m,direction:Z};v?.(A,q)!==!1&&(k=!0,h?.(A,q),o(R,P))}).on("end",A=>{k&&(w?.(A,{...m}),r?.({...m}),k=!1)});s.call(V)}function l(){s.on(".drag",null)}return{update:a,destroy:l}}const Ad={},Mo=e=>{let t;const n=new Set,o=(u,f)=>{const d=typeof u=="function"?u(t):u;if(!Object.is(d,t)){const p=t;t=f??(typeof d!="object"||d===null)?d:Object.assign({},t,d),n.forEach(h=>h(t,p))}},r=()=>t,l={setState:o,getState:r,getInitialState:()=>c,subscribe:u=>(n.add(u),()=>n.delete(u)),destroy:()=>{(Ad?"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()}},c=t=e(o,r,l);return l},Pd=e=>e?Mo(e):Mo,{useDebugValue:Td}=Zs,{useSyncExternalStoreWithSelector:Dd}=Ys,$d=e=>e;function si(e,t=$d,n){const o=Dd(e.subscribe,e.getState,e.getServerState||e.getInitialState,t,n);return Td(o),o}const Io=(e,t)=>{const n=Pd(e),o=(r,s=t)=>si(n,r,s);return Object.assign(o,n),o},zd=(e,t)=>e?Io(e,t):Io;function re(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 Wt=z.createContext(null),Ld=Wt.Provider,ai=_e.error001();function J(e,t){const n=z.useContext(Wt);if(n===null)throw new Error(ai);return si(n,e,t)}function ie(){const e=z.useContext(Wt);if(e===null)throw new Error(ai);return z.useMemo(()=>({getState:e.getState,setState:e.setState,subscribe:e.subscribe}),[e])}const ko={display:"none"},Hd={position:"absolute",width:1,height:1,margin:-1,border:0,padding:0,overflow:"hidden",clip:"rect(0px, 0px, 0px, 0px)",clipPath:"inset(100%)"},ci="react-flow__node-desc",li="react-flow__edge-desc",Rd="react-flow__aria-live",jd=e=>e.ariaLiveMessage,Vd=e=>e.ariaLabelConfig;function Od({rfId:e}){const t=J(jd);return _.jsx("div",{id:`${Rd}-${e}`,"aria-live":"assertive","aria-atomic":"true",style:Hd,children:t})}function Bd({rfId:e,disableKeyboardA11y:t}){const n=J(Vd);return _.jsxs(_.Fragment,{children:[_.jsx("div",{id:`${ci}-${e}`,style:ko,children:t?n["node.a11yDescription.default"]:n["node.a11yDescription.keyboardDisabled"]}),_.jsx("div",{id:`${li}-${e}`,style:ko,children:n["edge.a11yDescription.default"]}),!t&&_.jsx(Od,{rfId:e})]})}const Gt=z.forwardRef(({position:e="top-left",children:t,className:n,style:o,...r},s)=>{const i=`${e}`.split("-");return _.jsx("div",{className:ae(["react-flow__panel",n,...i]),style:o,ref:s,...r,children:t})});Gt.displayName="Panel";function Fd({proOptions:e,position:t="bottom-right"}){return e?.hideAttribution?null:_.jsx(Gt,{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 Xd=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 Yd(e,t){return re(e.selectedNodes.map(_t),t.selectedNodes.map(_t))&&re(e.selectedEdges.map(_t),t.selectedEdges.map(_t))}function Zd({onSelectionChange:e}){const t=ie(),{selectedNodes:n,selectedEdges:o}=J(Xd,Yd);return z.useEffect(()=>{const r={nodes:n,edges:o};e?.(r),t.getState().onSelectionChangeHandlers.forEach(s=>s(r))},[n,o,e]),null}const Wd=e=>!!e.onSelectionChangeHandlers;function Gd({onSelectionChange:e}){const t=J(Wd);return e||t?_.jsx(Zd,{onSelectionChange:e}):null}const ui=[0,0],qd={x:0,y:0,zoom:1},Kd=["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"],Ao=[...Kd,"rfId"],Ud=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}),Po={translateExtent:it,nodeOrigin:ui,minZoom:.5,maxZoom:2,elementsSelectable:!0,noPanClassName:"nopan",rfId:"1"};function Qd(e){const{setNodes:t,setEdges:n,setMinZoom:o,setMaxZoom:r,setTranslateExtent:s,setNodeExtent:i,reset:a,setDefaultNodesAndEdges:l}=J(Ud,re),c=ie();z.useEffect(()=>(l(e.defaultNodes,e.defaultEdges),()=>{u.current=Po,a()}),[]);const u=z.useRef(Po);return z.useEffect(()=>{for(const f of Ao){const d=e[f],p=u.current[f];d!==p&&(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"?c.setState({ariaLabelConfig:Ou(d)}):f==="fitView"?c.setState({fitViewQueued:d}):f==="fitViewOptions"?c.setState({fitViewOptions:d}):c.setState({[f]:d})))}u.current=e},Ao.map(f=>e[f])),null}function To(){return typeof window>"u"||!window.matchMedia?null:window.matchMedia("(prefers-color-scheme: dark)")}function Jd(e){const[t,n]=z.useState(e==="system"?null:e);return z.useEffect(()=>{if(e!=="system"){n(e);return}const o=To(),r=()=>n(o?.matches?"dark":"light");return r(),o?.addEventListener("change",r),()=>{o?.removeEventListener("change",r)}},[e]),t!==null?t:To()?.matches?"dark":"light"}const Do=typeof document<"u"?document:null;function lt(e=null,t={target:Do,actInsideInputWithModifier:!0}){const[n,o]=z.useState(!1),r=z.useRef(!1),s=z.useRef(new Set([])),[i,a]=z.useMemo(()=>{if(e!==null){const c=(Array.isArray(e)?e:[e]).filter(f=>typeof f=="string").map(f=>f.replace("+",`
2
- `).replace(`
3
-
4
- `,`
5
- +`).split(`
6
- `)),u=c.reduce((f,d)=>f.concat(...d),[]);return[c,u]}return[[],[]]},[e]);return z.useEffect(()=>{const l=t?.target??Do,c=t?.actInsideInputWithModifier??!0;if(e!==null){const u=p=>{if(r.current=p.ctrlKey||p.metaKey||p.shiftKey||p.altKey,(!r.current||r.current&&!c)&&Fr(p))return!1;const w=zo(p.code,a);if(s.current.add(p[w]),$o(i,s.current,!1)){const v=p.composedPath?.()?.[0]||p.target,m=v?.nodeName==="BUTTON"||v?.nodeName==="A";t.preventDefault!==!1&&(r.current||!m)&&p.preventDefault(),o(!0)}},f=p=>{const h=zo(p.code,a);$o(i,s.current,!0)?(o(!1),s.current.clear()):s.current.delete(p[h]),p.key==="Meta"&&s.current.clear(),r.current=!1},d=()=>{s.current.clear(),o(!1)};return l?.addEventListener("keydown",u),l?.addEventListener("keyup",f),window.addEventListener("blur",d),window.addEventListener("contextmenu",d),()=>{l?.removeEventListener("keydown",u),l?.removeEventListener("keyup",f),window.removeEventListener("blur",d),window.removeEventListener("contextmenu",d)}}},[e,o]),n}function $o(e,t,n){return e.filter(o=>n||o.length===t.size).some(o=>o.every(r=>t.has(r)))}function zo(e,t){return t.includes(e)?"code":"key"}const ef=()=>{const e=ie();return z.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(),l=An(t,o,r,s,i,n?.padding??.1);return a?(await a.setViewport(l,{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:l}=i.getBoundingClientRect(),c={x:t.x-a,y:t.y-l},u=n.snapGrid??r,f=n.snapToGrid??s;return gt(c,o,f,u)},flowToScreenPosition:t=>{const{transform:n,domNode:o}=e.getState();if(!o)return t;const{x:r,y:s}=o.getBoundingClientRect(),i=zt(t,n);return{x:i.x+r,y:i.y+s}}}),[])};function di(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 l of i)tf(l,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 tf(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 nf(e,t){return di(e,t)}function of(e,t){return di(e,t)}function De(e,t){return{id:e,type:"select",selected:t}}function Oe(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(De(s.id,i)))}return o}function Lo({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 Ho(e){return{id:e.id,type:"remove"}}const Ro=e=>Pu(e),rf=e=>zr(e);function fi(e){return z.forwardRef(e)}const sf=typeof window<"u"?z.useLayoutEffect:z.useEffect;function jo(e){const[t,n]=z.useState(BigInt(0)),[o]=z.useState(()=>af(()=>n(r=>r+BigInt(1))));return sf(()=>{const r=o.get();r.length&&(e(r),o.reset())},[t]),o}function af(e){let t=[];return{get:()=>t,reset:()=>{t=[]},push:n=>{t.push(n),e()}}}const hi=z.createContext(null);function cf({children:e}){const t=ie(),n=z.useCallback(a=>{const{nodes:l=[],setNodes:c,hasDefaultNodes:u,onNodesChange:f,nodeLookup:d,fitViewQueued:p,onNodesChangeMiddlewareMap:h}=t.getState();let w=l;for(const m of a)w=typeof m=="function"?m(w):m;let v=Lo({items:w,lookup:d});for(const m of h.values())v=m(v);u&&c(w),v.length>0?f?.(v):p&&window.requestAnimationFrame(()=>{const{fitViewQueued:m,nodes:b,setNodes:g}=t.getState();m&&g(b)})},[]),o=jo(n),r=z.useCallback(a=>{const{edges:l=[],setEdges:c,hasDefaultEdges:u,onEdgesChange:f,edgeLookup:d}=t.getState();let p=l;for(const h of a)p=typeof h=="function"?h(p):h;u?c(p):f&&f(Lo({items:p,lookup:d}))},[]),s=jo(r),i=z.useMemo(()=>({nodeQueue:o,edgeQueue:s}),[]);return _.jsx(hi.Provider,{value:i,children:e})}function lf(){const e=z.useContext(hi);if(!e)throw new Error("useBatchContext must be used within a BatchProvider");return e}const uf=e=>!!e.panZoom;function Hn(){const e=ef(),t=ie(),n=lf(),o=J(uf),r=z.useMemo(()=>{const s=f=>t.getState().nodeLookup.get(f),i=f=>{n.nodeQueue.push(f)},a=f=>{n.edgeQueue.push(f)},l=f=>{const{nodeLookup:d,nodeOrigin:p}=t.getState(),h=Ro(f)?f:d.get(f.id),w=h.parentId?Or(h.position,h.measured,h.parentId,d,p):h.position,v={...h,position:w,width:h.measured?.width??h.width,height:h.measured?.height??h.height};return We(v)},c=(f,d,p={replace:!1})=>{i(h=>h.map(w=>{if(w.id===f){const v=typeof d=="function"?d(w):d;return p.replace&&Ro(v)?v:{...w,...v}}return w}))},u=(f,d,p={replace:!1})=>{a(h=>h.map(w=>{if(w.id===f){const v=typeof d=="function"?d(w):d;return p.replace&&rf(v)?v:{...w,...v}}return w}))};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(p=>[...p,...d])},addEdges:f=>{const d=Array.isArray(f)?f:[f];n.edgeQueue.push(p=>[...p,...d])},toObject:()=>{const{nodes:f=[],edges:d=[],transform:p}=t.getState(),[h,w,v]=p;return{nodes:f.map(m=>({...m})),edges:d.map(m=>({...m})),viewport:{x:h,y:w,zoom:v}}},deleteElements:async({nodes:f=[],edges:d=[]})=>{const{nodes:p,edges:h,onNodesDelete:w,onEdgesDelete:v,triggerNodeChanges:m,triggerEdgeChanges:b,onDelete:g,onBeforeDelete:x}=t.getState(),{nodes:N,edges:S}=await Lu({nodesToRemove:f,edgesToRemove:d,nodes:p,edges:h,onBeforeDelete:x}),E=S.length>0,D=N.length>0;if(E){const k=S.map(Ho);v?.(S),b(k)}if(D){const k=N.map(Ho);w?.(N),m(k)}return(D||E)&&g?.({nodes:N,edges:S}),{deletedNodes:N,deletedEdges:S}},getIntersectingNodes:(f,d=!0,p)=>{const h=go(f),w=h?f:l(f),v=p!==void 0;return w?(p||t.getState().nodes).filter(m=>{const b=t.getState().nodeLookup.get(m.id);if(b&&!h&&(m.id===f.id||!b.internals.positionAbsolute))return!1;const g=We(v?m:b),x=at(g,w);return d&&x>0||x>=g.width*g.height||x>=w.width*w.height}):[]},isNodeIntersecting:(f,d,p=!0)=>{const w=go(f)?f:l(f);if(!w)return!1;const v=at(w,d);return p&&v>0||v>=d.width*d.height||v>=w.width*w.height},updateNode:c,updateNodeData:(f,d,p={replace:!1})=>{c(f,h=>{const w=typeof d=="function"?d(h):d;return p.replace?{...h,data:w}:{...h,data:{...h.data,...w}}},p)},updateEdge:u,updateEdgeData:(f,d,p={replace:!1})=>{u(f,h=>{const w=typeof d=="function"?d(h):d;return p.replace?{...h,data:w}:{...h,data:{...h.data,...w}}},p)},getNodesBounds:f=>{const{nodeLookup:d,nodeOrigin:p}=t.getState();return Tu(f,{nodeLookup:d,nodeOrigin:p})},getHandleConnections:({type:f,id:d,nodeId:p})=>Array.from(t.getState().connectionLookup.get(`${p}-${f}${d?`-${d}`:""}`)?.values()??[]),getNodeConnections:({type:f,handleId:d,nodeId:p})=>Array.from(t.getState().connectionLookup.get(`${p}${f?d?`-${f}-${d}`:`-${f}`:""}`)?.values()??[]),fitView:async f=>{const d=t.getState().fitViewResolver??Vu();return t.setState({fitViewQueued:!0,fitViewOptions:f,fitViewResolver:d}),n.nodeQueue.push(p=>[...p]),d.promise}}},[]);return z.useMemo(()=>({...r,...e,viewportInitialized:o}),[o])}const Vo=e=>e.selected,df=typeof window<"u"?window:void 0;function ff({deleteKeyCode:e,multiSelectionKeyCode:t}){const n=ie(),{deleteElements:o}=Hn(),r=lt(e,{actInsideInputWithModifier:!1}),s=lt(t,{target:df});z.useEffect(()=>{if(r){const{edges:i,nodes:a}=n.getState();o({nodes:a.filter(Vo),edges:i.filter(Vo)}),n.setState({nodesSelectionActive:!1})}},[r]),z.useEffect(()=>{n.setState({multiSelectionActive:s})},[s])}function hf(e){const t=ie();z.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",_e.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},gf=e=>({userSelectionActive:e.userSelectionActive,lib:e.lib,connectionInProgress:e.connection.inProgress});function pf({onPaneContextMenu:e,zoomOnScroll:t=!0,zoomOnPinch:n=!0,panOnScroll:o=!1,panOnScrollSpeed:r=.5,panOnScrollMode:s=$e.Free,zoomOnDoubleClick:i=!0,panOnDrag:a=!0,defaultViewport:l,translateExtent:c,minZoom:u,maxZoom:f,zoomActivationKeyCode:d,preventScrolling:p=!0,children:h,noWheelClassName:w,noPanClassName:v,onViewportChange:m,isControlledViewport:b,paneClickDistance:g,selectionOnDrag:x}){const N=ie(),S=z.useRef(null),{userSelectionActive:E,lib:D,connectionInProgress:k}=J(gf,re),V=lt(d),A=z.useRef();hf(S);const $=z.useCallback(L=>{m?.({x:L[0],y:L[1],zoom:L[2]}),b||N.setState({transform:L})},[m,b]);return z.useEffect(()=>{if(S.current){A.current=Sd({domNode:S.current,minZoom:u,maxZoom:f,translateExtent:c,viewport:l,onDraggingChange:C=>N.setState({paneDragging:C}),onPanZoomStart:(C,P)=>{const{onViewportChangeStart:T,onMoveStart:I}=N.getState();I?.(C,P),T?.(P)},onPanZoom:(C,P)=>{const{onViewportChange:T,onMove:I}=N.getState();I?.(C,P),T?.(P)},onPanZoomEnd:(C,P)=>{const{onViewportChangeEnd:T,onMoveEnd:I}=N.getState();I?.(C,P),T?.(P)}});const{x:L,y,zoom:M}=A.current.getViewport();return N.setState({panZoom:A.current,transform:[L,y,M],domNode:S.current.closest(".react-flow")}),()=>{A.current?.destroy()}}},[]),z.useEffect(()=>{A.current?.update({onPaneContextMenu:e,zoomOnScroll:t,zoomOnPinch:n,panOnScroll:o,panOnScrollSpeed:r,panOnScrollMode:s,zoomOnDoubleClick:i,panOnDrag:a,zoomActivationKeyPressed:V,preventScrolling:p,noPanClassName:v,userSelectionActive:E,noWheelClassName:w,lib:D,onTransformChange:$,connectionInProgress:k,selectionOnDrag:x,paneClickDistance:g})},[e,t,n,o,r,s,i,a,V,p,v,E,w,D,$,k,x,g]),_.jsx("div",{className:"react-flow__renderer",ref:S,style:qt,children:h})}const mf=e=>({userSelectionActive:e.userSelectionActive,userSelectionRect:e.userSelectionRect});function yf(){const{userSelectionActive:e,userSelectionRect:t}=J(mf,re);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 cn=(e,t)=>n=>{n.target===t.current&&e?.(n)},xf=e=>({userSelectionActive:e.userSelectionActive,elementsSelectable:e.elementsSelectable,connectionInProgress:e.connection.inProgress,dragging:e.paneDragging});function wf({isSelecting:e,selectionKeyPressed:t,selectionMode:n=st.Full,panOnDrag:o,paneClickDistance:r,selectionOnDrag:s,onSelectionStart:i,onSelectionEnd:a,onPaneClick:l,onPaneContextMenu:c,onPaneScroll:u,onPaneMouseEnter:f,onPaneMouseMove:d,onPaneMouseLeave:p,children:h}){const w=ie(),{userSelectionActive:v,elementsSelectable:m,dragging:b,connectionInProgress:g}=J(xf,re),x=m&&(e||v),N=z.useRef(null),S=z.useRef(),E=z.useRef(new Set),D=z.useRef(new Set),k=z.useRef(!1),V=T=>{if(k.current||g){k.current=!1;return}l?.(T),w.getState().resetSelectedElements(),w.setState({nodesSelectionActive:!1})},A=T=>{if(Array.isArray(o)&&o?.includes(2)){T.preventDefault();return}c?.(T)},$=u?T=>u(T):void 0,L=T=>{k.current&&(T.stopPropagation(),k.current=!1)},y=T=>{const{domNode:I}=w.getState();if(S.current=I?.getBoundingClientRect(),!S.current)return;const H=T.target===N.current;if(!H&&!!T.target.closest(".nokey")||!e||!(s&&H||t)||T.button!==0||!T.isPrimary)return;T.target?.setPointerCapture?.(T.pointerId),k.current=!1;const{x:F,y:B}=xe(T.nativeEvent,S.current);w.setState({userSelectionRect:{width:0,height:0,startX:F,startY:B,x:F,y:B}}),H||(T.stopPropagation(),T.preventDefault())},M=T=>{const{userSelectionRect:I,transform:H,nodeLookup:j,edgeLookup:R,connectionLookup:F,triggerNodeChanges:B,triggerEdgeChanges:G,defaultEdgeOptions:K,resetSelectedElements:W}=w.getState();if(!S.current||!I)return;const{x:O,y:X}=xe(T.nativeEvent,S.current),{startX:Q,startY:U}=I;if(!k.current){const te=t?0:r;if(Math.hypot(O-Q,X-U)<=te)return;W(),i?.(T)}k.current=!0;const Z={startX:Q,startY:U,x:O<Q?O:Q,y:X<U?X:U,width:Math.abs(O-Q),height:Math.abs(X-U)},q=E.current,ee=D.current;E.current=new Set(kn(j,Z,H,n===st.Partial,!0).map(te=>te.id)),D.current=new Set;const ne=K?.selectable??!0;for(const te of E.current){const se=F.get(te);if(se)for(const{edgeId:ce}of se.values()){const le=R.get(ce);le&&(le.selectable??ne)&&D.current.add(ce)}}if(!po(q,E.current)){const te=Oe(j,E.current,!0);B(te)}if(!po(ee,D.current)){const te=Oe(R,D.current);G(te)}w.setState({userSelectionRect:Z,userSelectionActive:!0,nodesSelectionActive:!1})},C=T=>{T.button===0&&(T.target?.releasePointerCapture?.(T.pointerId),!v&&T.target===N.current&&w.getState().userSelectionRect&&V?.(T),w.setState({userSelectionActive:!1,userSelectionRect:null}),k.current&&(a?.(T),w.setState({nodesSelectionActive:E.current.size>0})))},P=o===!0||Array.isArray(o)&&o.includes(0);return _.jsxs("div",{className:ae(["react-flow__pane",{draggable:P,dragging:b,selection:e}]),onClick:x?void 0:cn(V,N),onContextMenu:cn(A,N),onWheel:cn($,N),onPointerEnter:x?void 0:f,onPointerMove:x?M:d,onPointerUp:x?C:void 0,onPointerDownCapture:x?y:void 0,onClickCapture:x?L:void 0,onPointerLeave:p,ref:N,style:qt,children:[h,_.jsx(yf,{})]})}function _n({id:e,store:t,unselect:n=!1,nodeRef:o}){const{addSelectedNodes:r,unselectNodesAndEdges:s,multiSelectionActive:i,nodeLookup:a,onError:l}=t.getState(),c=a.get(e);if(!c){l?.("012",_e.error012(e));return}t.setState({nodesSelectionActive:!1}),c.selected?(n||c.selected&&i)&&(s({nodes:[c],edges:[]}),requestAnimationFrame(()=>o?.current?.blur())):r([e])}function gi({nodeRef:e,disabled:t=!1,noDragClassName:n,handleSelector:o,nodeId:r,isSelectable:s,nodeClickDistance:i}){const a=ie(),[l,c]=z.useState(!1),u=z.useRef();return z.useEffect(()=>{u.current=ld({getStoreItems:()=>a.getState(),onNodeMouseDown:f=>{_n({id:f,store:a,nodeRef:e})},onDragStart:()=>{c(!0)},onDragStop:()=>{c(!1)}})},[]),z.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]),l}const vf=e=>t=>t.selected&&(t.draggable||e&&typeof t.draggable>"u");function pi(){const e=ie();return z.useCallback(n=>{const{nodeExtent:o,snapToGrid:r,snapGrid:s,nodesDraggable:i,onError:a,updateNodePositions:l,nodeLookup:c,nodeOrigin:u}=e.getState(),f=new Map,d=vf(i),p=r?s[0]:5,h=r?s[1]:5,w=n.direction.x*p*n.factor,v=n.direction.y*h*n.factor;for(const[,m]of c){if(!d(m))continue;let b={x:m.internals.positionAbsolute.x+w,y:m.internals.positionAbsolute.y+v};r&&(b=ht(b,s));const{position:g,positionAbsolute:x}=Lr({nodeId:m.id,nextPosition:b,nodeLookup:c,nodeExtent:o,nodeOrigin:u,onError:a});m.position=g,m.internals.positionAbsolute=x,f.set(m.id,m)}l(f)},[])}const Rn=z.createContext(null),_f=Rn.Provider;Rn.Consumer;const mi=()=>z.useContext(Rn),bf=e=>({connectOnClick:e.connectOnClick,noPanClassName:e.noPanClassName,rfId:e.rfId}),Sf=(e,t,n)=>o=>{const{connectionClickStartHandle:r,connectionMode:s,connection:i}=o,{fromHandle:a,toHandle:l,isValid:c}=i,u=l?.nodeId===e&&l?.id===t&&l?.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===Ye.Strict?a?.type!==n:e!==a?.nodeId||t!==a?.id,connectionInProcess:!!a,clickConnectionInProcess:!!r,valid:u&&c}};function Ef({type:e="source",position:t=Y.Top,isValidConnection:n,isConnectable:o=!0,isConnectableStart:r=!0,isConnectableEnd:s=!0,id:i,onConnect:a,children:l,className:c,onMouseDown:u,onTouchStart:f,...d},p){const h=i||null,w=e==="target",v=ie(),m=mi(),{connectOnClick:b,noPanClassName:g,rfId:x}=J(bf,re),{connectingFrom:N,connectingTo:S,clickConnecting:E,isPossibleEndHandle:D,connectionInProcess:k,clickConnectionInProcess:V,valid:A}=J(Sf(m,h,e),re);m||v.getState().onError?.("010",_e.error010());const $=M=>{const{defaultEdgeOptions:C,onConnect:P,hasDefaultEdges:T}=v.getState(),I={...C,...M};if(T){const{edges:H,setEdges:j}=v.getState();j(Wu(I,H))}P?.(I),a?.(I)},L=M=>{if(!m)return;const C=Xr(M.nativeEvent);if(r&&(C&&M.button===0||!C)){const P=v.getState();vn.onPointerDown(M.nativeEvent,{handleDomNode:M.currentTarget,autoPanOnConnect:P.autoPanOnConnect,connectionMode:P.connectionMode,connectionRadius:P.connectionRadius,domNode:P.domNode,nodeLookup:P.nodeLookup,lib:P.lib,isTarget:w,handleId:h,nodeId:m,flowId:P.rfId,panBy:P.panBy,cancelConnection:P.cancelConnection,onConnectStart:P.onConnectStart,onConnectEnd:P.onConnectEnd,updateConnection:P.updateConnection,onConnect:$,isValidConnection:n||P.isValidConnection,getTransform:()=>v.getState().transform,getFromHandle:()=>v.getState().connection.fromHandle,autoPanSpeed:P.autoPanSpeed,dragThreshold:P.connectionDragThreshold})}C?u?.(M):f?.(M)},y=M=>{const{onClickConnectStart:C,onClickConnectEnd:P,connectionClickStartHandle:T,connectionMode:I,isValidConnection:H,lib:j,rfId:R,nodeLookup:F,connection:B}=v.getState();if(!m||!T&&!r)return;if(!T){C?.(M.nativeEvent,{nodeId:m,handleId:h,handleType:e}),v.setState({connectionClickStartHandle:{nodeId:m,type:e,id:h}});return}const G=Br(M.target),K=n||H,{connection:W,isValid:O}=vn.isValid(M.nativeEvent,{handle:{nodeId:m,id:h,type:e},connectionMode:I,fromNodeId:T.nodeId,fromHandleId:T.id||null,fromType:T.type,isValidConnection:K,flowId:R,doc:G,lib:j,nodeLookup:F});O&&W&&$(W);const X=structuredClone(B);delete X.inProgress,X.toPosition=X.toHandle?X.toHandle.position:null,P?.(M,X),v.setState({connectionClickStartHandle:null})};return _.jsx("div",{"data-handleid":h,"data-nodeid":m,"data-handlepos":t,"data-id":`${x}-${m}-${h}-${e}`,className:ae(["react-flow__handle",`react-flow__handle-${t}`,"nodrag",g,c,{source:!w,target:w,connectable:o,connectablestart:r,connectableend:s,clickconnecting:E,connectingfrom:N,connectingto:S,valid:A,connectionindicator:o&&(!k||D)&&(k||V?s:r)}]),onMouseDown:L,onTouchStart:L,onClick:b?y:void 0,ref:p,...d,children:l})}const Pe=z.memo(fi(Ef));function Cf({data:e,isConnectable:t,sourcePosition:n=Y.Bottom}){return _.jsxs(_.Fragment,{children:[e?.label,_.jsx(Pe,{type:"source",position:n,isConnectable:t})]})}function Nf({data:e,isConnectable:t,targetPosition:n=Y.Top,sourcePosition:o=Y.Bottom}){return _.jsxs(_.Fragment,{children:[_.jsx(Pe,{type:"target",position:n,isConnectable:t}),e?.label,_.jsx(Pe,{type:"source",position:o,isConnectable:t})]})}function Mf(){return null}function If({data:e,isConnectable:t,targetPosition:n=Y.Top}){return _.jsxs(_.Fragment,{children:[_.jsx(Pe,{type:"target",position:n,isConnectable:t}),e?.label]})}const Lt={ArrowUp:{x:0,y:-1},ArrowDown:{x:0,y:1},ArrowLeft:{x:-1,y:0},ArrowRight:{x:1,y:0}},Oo={input:Cf,default:Nf,output:If,group:Mf};function kf(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 Af=e=>{const{width:t,height:n,x:o,y:r}=ft(e.nodeLookup,{filter:s=>!!s.selected});return{width:ye(t)?t:null,height:ye(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 Pf({onSelectionContextMenu:e,noPanClassName:t,disableKeyboardA11y:n}){const o=ie(),{width:r,height:s,transformString:i,userSelectionActive:a}=J(Af,re),l=pi(),c=z.useRef(null);if(z.useEffect(()=>{n||c.current?.focus({preventScroll:!0})},[n]),gi({nodeRef:c}),a||!r||!s)return null;const u=e?d=>{const p=o.getState().nodes.filter(h=>h.selected);e(d,p)}:void 0,f=d=>{Object.prototype.hasOwnProperty.call(Lt,d.key)&&(d.preventDefault(),l({direction:Lt[d.key],factor:d.shiftKey?4:1}))};return _.jsx("div",{className:ae(["react-flow__nodesselection","react-flow__container",t]),style:{transform:i},children:_.jsx("div",{ref:c,className:"react-flow__nodesselection-rect",onContextMenu:u,tabIndex:n?void 0:-1,onKeyDown:n?void 0:f,style:{width:r,height:s}})})}const Bo=typeof window<"u"?window:void 0,Tf=e=>({nodesSelectionActive:e.nodesSelectionActive,userSelectionActive:e.userSelectionActive});function yi({children:e,onPaneClick:t,onPaneMouseEnter:n,onPaneMouseMove:o,onPaneMouseLeave:r,onPaneContextMenu:s,onPaneScroll:i,paneClickDistance:a,deleteKeyCode:l,selectionKeyCode:c,selectionOnDrag:u,selectionMode:f,onSelectionStart:d,onSelectionEnd:p,multiSelectionKeyCode:h,panActivationKeyCode:w,zoomActivationKeyCode:v,elementsSelectable:m,zoomOnScroll:b,zoomOnPinch:g,panOnScroll:x,panOnScrollSpeed:N,panOnScrollMode:S,zoomOnDoubleClick:E,panOnDrag:D,defaultViewport:k,translateExtent:V,minZoom:A,maxZoom:$,preventScrolling:L,onSelectionContextMenu:y,noWheelClassName:M,noPanClassName:C,disableKeyboardA11y:P,onViewportChange:T,isControlledViewport:I}){const{nodesSelectionActive:H,userSelectionActive:j}=J(Tf,re),R=lt(c,{target:Bo}),F=lt(w,{target:Bo}),B=F||D,G=F||x,K=u&&B!==!0,W=R||j||K;return ff({deleteKeyCode:l,multiSelectionKeyCode:h}),_.jsx(pf,{onPaneContextMenu:s,elementsSelectable:m,zoomOnScroll:b,zoomOnPinch:g,panOnScroll:G,panOnScrollSpeed:N,panOnScrollMode:S,zoomOnDoubleClick:E,panOnDrag:!R&&B,defaultViewport:k,translateExtent:V,minZoom:A,maxZoom:$,zoomActivationKeyCode:v,preventScrolling:L,noWheelClassName:M,noPanClassName:C,onViewportChange:T,isControlledViewport:I,paneClickDistance:a,selectionOnDrag:K,children:_.jsxs(wf,{onSelectionStart:d,onSelectionEnd:p,onPaneClick:t,onPaneMouseEnter:n,onPaneMouseMove:o,onPaneMouseLeave:r,onPaneContextMenu:s,onPaneScroll:i,panOnDrag:B,isSelecting:!!W,selectionMode:f,selectionKeyPressed:R,paneClickDistance:a,selectionOnDrag:K,children:[e,H&&_.jsx(Pf,{onSelectionContextMenu:y,noPanClassName:C,disableKeyboardA11y:P})]})})}yi.displayName="FlowRenderer";const Df=z.memo(yi),$f=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 zf(e){return J(z.useCallback($f(e),[e]),re)}const Lf=e=>e.updateNodeInternals;function Hf(){const e=J(Lf),[t]=z.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 z.useEffect(()=>()=>{t?.disconnect()},[t]),t}function Rf({node:e,nodeType:t,hasDimensions:n,resizeObserver:o}){const r=ie(),s=z.useRef(null),i=z.useRef(null),a=z.useRef(e.sourcePosition),l=z.useRef(e.targetPosition),c=z.useRef(t),u=n&&!!e.internals.handleBounds;return z.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]),z.useEffect(()=>()=>{i.current&&(o?.unobserve(i.current),i.current=null)},[]),z.useEffect(()=>{if(s.current){const f=c.current!==t,d=a.current!==e.sourcePosition,p=l.current!==e.targetPosition;(f||d||p)&&(c.current=t,a.current=e.sourcePosition,l.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 jf({id:e,onClick:t,onMouseEnter:n,onMouseMove:o,onMouseLeave:r,onContextMenu:s,onDoubleClick:i,nodesDraggable:a,elementsSelectable:l,nodesConnectable:c,nodesFocusable:u,resizeObserver:f,noDragClassName:d,noPanClassName:p,disableKeyboardA11y:h,rfId:w,nodeTypes:v,nodeClickDistance:m,onError:b}){const{node:g,internals:x,isParent:N}=J(O=>{const X=O.nodeLookup.get(e),Q=O.parentLookup.has(e);return{node:X,internals:X.internals,isParent:Q}},re);let S=g.type||"default",E=v?.[S]||Oo[S];E===void 0&&(b?.("003",_e.error003(S)),S="default",E=v?.default||Oo.default);const D=!!(g.draggable||a&&typeof g.draggable>"u"),k=!!(g.selectable||l&&typeof g.selectable>"u"),V=!!(g.connectable||c&&typeof g.connectable>"u"),A=!!(g.focusable||u&&typeof g.focusable>"u"),$=ie(),L=Vr(g),y=Rf({node:g,nodeType:S,hasDimensions:L,resizeObserver:f}),M=gi({nodeRef:y,disabled:g.hidden||!D,noDragClassName:d,handleSelector:g.dragHandle,nodeId:e,isSelectable:k,nodeClickDistance:m}),C=pi();if(g.hidden)return null;const P=Ne(g),T=kf(g),I=k||D||t||n||o||r,H=n?O=>n(O,{...x.userNode}):void 0,j=o?O=>o(O,{...x.userNode}):void 0,R=r?O=>r(O,{...x.userNode}):void 0,F=s?O=>s(O,{...x.userNode}):void 0,B=i?O=>i(O,{...x.userNode}):void 0,G=O=>{const{selectNodesOnDrag:X,nodeDragThreshold:Q}=$.getState();k&&(!X||!D||Q>0)&&_n({id:e,store:$,nodeRef:y}),t&&t(O,{...x.userNode})},K=O=>{if(!(Fr(O.nativeEvent)||h)){if(Pr.includes(O.key)&&k){const X=O.key==="Escape";_n({id:e,store:$,unselect:X,nodeRef:y})}else if(D&&g.selected&&Object.prototype.hasOwnProperty.call(Lt,O.key)){O.preventDefault();const{ariaLabelConfig:X}=$.getState();$.setState({ariaLiveMessage:X["node.a11yDescription.ariaLiveMessage"]({direction:O.key.replace("Arrow","").toLowerCase(),x:~~x.positionAbsolute.x,y:~~x.positionAbsolute.y})}),C({direction:Lt[O.key],factor:O.shiftKey?4:1})}}},W=()=>{if(h||!y.current?.matches(":focus-visible"))return;const{transform:O,width:X,height:Q,autoPanOnNodeFocus:U,setCenter:Z}=$.getState();if(!U)return;kn(new Map([[e,g]]),{x:0,y:0,width:X,height:Q},O,!0).length>0||Z(g.position.x+P.width/2,g.position.y+P.height/2,{zoom:O[2]})};return _.jsx("div",{className:ae(["react-flow__node",`react-flow__node-${S}`,{[p]:D},g.className,{selected:g.selected,selectable:k,parent:N,draggable:D,dragging:M}]),ref:y,style:{zIndex:x.z,transform:`translate(${x.positionAbsolute.x}px,${x.positionAbsolute.y}px)`,pointerEvents:I?"all":"none",visibility:L?"visible":"hidden",...g.style,...T},"data-id":e,"data-testid":`rf__node-${e}`,onMouseEnter:H,onMouseMove:j,onMouseLeave:R,onContextMenu:F,onClick:G,onDoubleClick:B,onKeyDown:A?K:void 0,tabIndex:A?0:void 0,onFocus:A?W:void 0,role:g.ariaRole??(A?"group":void 0),"aria-roledescription":"node","aria-describedby":h?void 0:`${ci}-${w}`,"aria-label":g.ariaLabel,...g.domAttributes,children:_.jsx(_f,{value:e,children:_.jsx(E,{id:e,data:g.data,type:S,positionAbsoluteX:x.positionAbsolute.x,positionAbsoluteY:x.positionAbsolute.y,selected:g.selected??!1,selectable:k,draggable:D,deletable:g.deletable??!0,isConnectable:V,sourcePosition:g.sourcePosition,targetPosition:g.targetPosition,dragging:M,dragHandle:g.dragHandle,zIndex:x.z,parentId:g.parentId,...P})})})}var Vf=z.memo(jf);const Of=e=>({nodesDraggable:e.nodesDraggable,nodesConnectable:e.nodesConnectable,nodesFocusable:e.nodesFocusable,elementsSelectable:e.elementsSelectable,onError:e.onError});function xi(e){const{nodesDraggable:t,nodesConnectable:n,nodesFocusable:o,elementsSelectable:r,onError:s}=J(Of,re),i=zf(e.onlyRenderVisibleElements),a=Hf();return _.jsx("div",{className:"react-flow__nodes",style:qt,children:i.map(l=>_.jsx(Vf,{id:l,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},l))})}xi.displayName="NodeRenderer";const Bf=z.memo(xi);function Ff(e){return J(z.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&&Xu({sourceNode:s,targetNode:i,width:n.width,height:n.height,transform:n.transform})&&o.push(r.id)}return o},[e]),re)}const Xf=({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"})},Yf=({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"})},Fo={[Dt.Arrow]:Xf,[Dt.ArrowClosed]:Yf};function Zf(e){const t=ie();return z.useMemo(()=>Object.prototype.hasOwnProperty.call(Fo,e)?Fo[e]:(t.getState().onError?.("009",_e.error009(e)),null),[e])}const Wf=({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 l=Zf(t);return l?_.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(l,{color:n,strokeWidth:i})}):null},wi=({defaultColor:e,rfId:t})=>{const n=J(s=>s.edges),o=J(s=>s.defaultEdgeOptions),r=z.useMemo(()=>Qu(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(Wf,{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};wi.displayName="MarkerDefinitions";var Gf=z.memo(wi);function vi({x:e,y:t,label:n,labelStyle:o,labelShowBg:r=!0,labelBgStyle:s,labelBgPadding:i=[2,4],labelBgBorderRadius:a=2,children:l,className:c,...u}){const[f,d]=z.useState({x:1,y:0,width:0,height:0}),p=ae(["react-flow__edge-textwrapper",c]),h=z.useRef(null);return z.useEffect(()=>{if(h.current){const w=h.current.getBBox();d({x:w.x,y:w.y,width:w.width,height:w.height})}},[n]),n?_.jsxs("g",{transform:`translate(${e-f.width/2} ${t-f.height/2})`,className:p,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:h,style:o,children:n}),l]}):null}vi.displayName="EdgeText";const qf=z.memo(vi);function Kt({path:e,labelX:t,labelY:n,label:o,labelStyle:r,labelShowBg:s,labelBgStyle:i,labelBgPadding:a,labelBgBorderRadius:l,interactionWidth:c=20,...u}){return _.jsxs(_.Fragment,{children:[_.jsx("path",{...u,d:e,fill:"none",className:ae(["react-flow__edge-path",u.className])}),c?_.jsx("path",{d:e,fill:"none",strokeOpacity:0,strokeWidth:c,className:"react-flow__edge-interaction"}):null,o&&ye(t)&&ye(n)?_.jsx(qf,{x:t,y:n,label:o,labelStyle:r,labelShowBg:s,labelBgStyle:i,labelBgPadding:a,labelBgBorderRadius:l}):null]})}function Xo({pos:e,x1:t,y1:n,x2:o,y2:r}){return e===Y.Left||e===Y.Right?[.5*(t+o),n]:[t,.5*(n+r)]}function _i({sourceX:e,sourceY:t,sourcePosition:n=Y.Bottom,targetX:o,targetY:r,targetPosition:s=Y.Top}){const[i,a]=Xo({pos:n,x1:e,y1:t,x2:o,y2:r}),[l,c]=Xo({pos:s,x1:o,y1:r,x2:e,y2:t}),[u,f,d,p]=Yr({sourceX:e,sourceY:t,targetX:o,targetY:r,sourceControlX:i,sourceControlY:a,targetControlX:l,targetControlY:c});return[`M${e},${t} C${i},${a} ${l},${c} ${o},${r}`,u,f,d,p]}function bi(e){return z.memo(({id:t,sourceX:n,sourceY:o,targetX:r,targetY:s,sourcePosition:i,targetPosition:a,label:l,labelStyle:c,labelShowBg:u,labelBgStyle:f,labelBgPadding:d,labelBgBorderRadius:p,style:h,markerEnd:w,markerStart:v,interactionWidth:m})=>{const[b,g,x]=_i({sourceX:n,sourceY:o,sourcePosition:i,targetX:r,targetY:s,targetPosition:a}),N=e.isInternal?void 0:t;return _.jsx(Kt,{id:N,path:b,labelX:g,labelY:x,label:l,labelStyle:c,labelShowBg:u,labelBgStyle:f,labelBgPadding:d,labelBgBorderRadius:p,style:h,markerEnd:w,markerStart:v,interactionWidth:m})})}const Kf=bi({isInternal:!1}),Si=bi({isInternal:!0});Kf.displayName="SimpleBezierEdge";Si.displayName="SimpleBezierEdgeInternal";function Ei(e){return z.memo(({id:t,sourceX:n,sourceY:o,targetX:r,targetY:s,label:i,labelStyle:a,labelShowBg:l,labelBgStyle:c,labelBgPadding:u,labelBgBorderRadius:f,style:d,sourcePosition:p=Y.Bottom,targetPosition:h=Y.Top,markerEnd:w,markerStart:v,pathOptions:m,interactionWidth:b})=>{const[g,x,N]=yn({sourceX:n,sourceY:o,sourcePosition:p,targetX:r,targetY:s,targetPosition:h,borderRadius:m?.borderRadius,offset:m?.offset,stepPosition:m?.stepPosition}),S=e.isInternal?void 0:t;return _.jsx(Kt,{id:S,path:g,labelX:x,labelY:N,label:i,labelStyle:a,labelShowBg:l,labelBgStyle:c,labelBgPadding:u,labelBgBorderRadius:f,style:d,markerEnd:w,markerStart:v,interactionWidth:b})})}const Ci=Ei({isInternal:!1}),Ni=Ei({isInternal:!0});Ci.displayName="SmoothStepEdge";Ni.displayName="SmoothStepEdgeInternal";function Mi(e){return z.memo(({id:t,...n})=>{const o=e.isInternal?void 0:t;return _.jsx(Ci,{...n,id:o,pathOptions:z.useMemo(()=>({borderRadius:0,offset:n.pathOptions?.offset}),[n.pathOptions?.offset])})})}const Uf=Mi({isInternal:!1}),Ii=Mi({isInternal:!0});Uf.displayName="StepEdge";Ii.displayName="StepEdgeInternal";function ki(e){return z.memo(({id:t,sourceX:n,sourceY:o,targetX:r,targetY:s,label:i,labelStyle:a,labelShowBg:l,labelBgStyle:c,labelBgPadding:u,labelBgBorderRadius:f,style:d,markerEnd:p,markerStart:h,interactionWidth:w})=>{const[v,m,b]=Gr({sourceX:n,sourceY:o,targetX:r,targetY:s}),g=e.isInternal?void 0:t;return _.jsx(Kt,{id:g,path:v,labelX:m,labelY:b,label:i,labelStyle:a,labelShowBg:l,labelBgStyle:c,labelBgPadding:u,labelBgBorderRadius:f,style:d,markerEnd:p,markerStart:h,interactionWidth:w})})}const Qf=ki({isInternal:!1}),Ai=ki({isInternal:!0});Qf.displayName="StraightEdge";Ai.displayName="StraightEdgeInternal";function Pi(e){return z.memo(({id:t,sourceX:n,sourceY:o,targetX:r,targetY:s,sourcePosition:i=Y.Bottom,targetPosition:a=Y.Top,label:l,labelStyle:c,labelShowBg:u,labelBgStyle:f,labelBgPadding:d,labelBgBorderRadius:p,style:h,markerEnd:w,markerStart:v,pathOptions:m,interactionWidth:b})=>{const[g,x,N]=Zr({sourceX:n,sourceY:o,sourcePosition:i,targetX:r,targetY:s,targetPosition:a,curvature:m?.curvature}),S=e.isInternal?void 0:t;return _.jsx(Kt,{id:S,path:g,labelX:x,labelY:N,label:l,labelStyle:c,labelShowBg:u,labelBgStyle:f,labelBgPadding:d,labelBgBorderRadius:p,style:h,markerEnd:w,markerStart:v,interactionWidth:b})})}const Jf=Pi({isInternal:!1}),Ti=Pi({isInternal:!0});Jf.displayName="BezierEdge";Ti.displayName="BezierEdgeInternal";const Yo={default:Ti,straight:Ai,step:Ii,smoothstep:Ni,simplebezier:Si},Zo={sourceX:null,sourceY:null,targetX:null,targetY:null,sourcePosition:null,targetPosition:null},eh=(e,t,n)=>n===Y.Left?e-t:n===Y.Right?e+t:e,th=(e,t,n)=>n===Y.Top?e-t:n===Y.Bottom?e+t:e,Wo="react-flow__edgeupdater";function Go({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:ae([Wo,`${Wo}-${a}`]),cx:eh(t,o,e),cy:th(n,o,e),r:o,stroke:"transparent",fill:"transparent"})}function nh({isReconnectable:e,reconnectRadius:t,edge:n,sourceX:o,sourceY:r,targetX:s,targetY:i,sourcePosition:a,targetPosition:l,onReconnect:c,onReconnectStart:u,onReconnectEnd:f,setReconnecting:d,setUpdateHover:p}){const h=ie(),w=(x,N)=>{if(x.button!==0)return;const{autoPanOnConnect:S,domNode:E,isValidConnection:D,connectionMode:k,connectionRadius:V,lib:A,onConnectStart:$,onConnectEnd:L,cancelConnection:y,nodeLookup:M,rfId:C,panBy:P,updateConnection:T}=h.getState(),I=N.type==="target",H=(F,B)=>{d(!1),f?.(F,n,N.type,B)},j=F=>c?.(n,F),R=(F,B)=>{d(!0),u?.(x,n,N.type),$?.(F,B)};vn.onPointerDown(x.nativeEvent,{autoPanOnConnect:S,connectionMode:k,connectionRadius:V,domNode:E,handleId:N.id,nodeId:N.nodeId,nodeLookup:M,isTarget:I,edgeUpdaterType:N.type,lib:A,flowId:C,cancelConnection:y,panBy:P,isValidConnection:D,onConnect:j,onConnectStart:R,onConnectEnd:L,onReconnectEnd:H,updateConnection:T,getTransform:()=>h.getState().transform,getFromHandle:()=>h.getState().connection.fromHandle,dragThreshold:h.getState().connectionDragThreshold,handleDomNode:x.currentTarget})},v=x=>w(x,{nodeId:n.target,id:n.targetHandle??null,type:"target"}),m=x=>w(x,{nodeId:n.source,id:n.sourceHandle??null,type:"source"}),b=()=>p(!0),g=()=>p(!1);return _.jsxs(_.Fragment,{children:[(e===!0||e==="source")&&_.jsx(Go,{position:a,centerX:o,centerY:r,radius:t,onMouseDown:v,onMouseEnter:b,onMouseOut:g,type:"source"}),(e===!0||e==="target")&&_.jsx(Go,{position:l,centerX:s,centerY:i,radius:t,onMouseDown:m,onMouseEnter:b,onMouseOut:g,type:"target"})]})}function oh({id:e,edgesFocusable:t,edgesReconnectable:n,elementsSelectable:o,onClick:r,onDoubleClick:s,onContextMenu:i,onMouseEnter:a,onMouseMove:l,onMouseLeave:c,reconnectRadius:u,onReconnect:f,onReconnectStart:d,onReconnectEnd:p,rfId:h,edgeTypes:w,noPanClassName:v,onError:m,disableKeyboardA11y:b}){let g=J(Z=>Z.edgeLookup.get(e));const x=J(Z=>Z.defaultEdgeOptions);g=x?{...x,...g}:g;let N=g.type||"default",S=w?.[N]||Yo[N];S===void 0&&(m?.("011",_e.error011(N)),N="default",S=w?.default||Yo.default);const E=!!(g.focusable||t&&typeof g.focusable>"u"),D=typeof f<"u"&&(g.reconnectable||n&&typeof g.reconnectable>"u"),k=!!(g.selectable||o&&typeof g.selectable>"u"),V=z.useRef(null),[A,$]=z.useState(!1),[L,y]=z.useState(!1),M=ie(),{zIndex:C,sourceX:P,sourceY:T,targetX:I,targetY:H,sourcePosition:j,targetPosition:R}=J(z.useCallback(Z=>{const q=Z.nodeLookup.get(g.source),ee=Z.nodeLookup.get(g.target);if(!q||!ee)return{zIndex:g.zIndex,...Zo};const ne=Uu({id:e,sourceNode:q,targetNode:ee,sourceHandle:g.sourceHandle||null,targetHandle:g.targetHandle||null,connectionMode:Z.connectionMode,onError:m});return{zIndex:Fu({selected:g.selected,zIndex:g.zIndex,sourceNode:q,targetNode:ee,elevateOnSelect:Z.elevateEdgesOnSelect,zIndexMode:Z.zIndexMode}),...ne||Zo}},[g.source,g.target,g.sourceHandle,g.targetHandle,g.selected,g.zIndex]),re),F=z.useMemo(()=>g.markerStart?`url('#${xn(g.markerStart,h)}')`:void 0,[g.markerStart,h]),B=z.useMemo(()=>g.markerEnd?`url('#${xn(g.markerEnd,h)}')`:void 0,[g.markerEnd,h]);if(g.hidden||P===null||T===null||I===null||H===null)return null;const G=Z=>{const{addSelectedEdges:q,unselectNodesAndEdges:ee,multiSelectionActive:ne}=M.getState();k&&(M.setState({nodesSelectionActive:!1}),g.selected&&ne?(ee({nodes:[],edges:[g]}),V.current?.blur()):q([e])),r&&r(Z,g)},K=s?Z=>{s(Z,{...g})}:void 0,W=i?Z=>{i(Z,{...g})}:void 0,O=a?Z=>{a(Z,{...g})}:void 0,X=l?Z=>{l(Z,{...g})}:void 0,Q=c?Z=>{c(Z,{...g})}:void 0,U=Z=>{if(!b&&Pr.includes(Z.key)&&k){const{unselectNodesAndEdges:q,addSelectedEdges:ee}=M.getState();Z.key==="Escape"?(V.current?.blur(),q({edges:[g]})):ee([e])}};return _.jsx("svg",{style:{zIndex:C},children:_.jsxs("g",{className:ae(["react-flow__edge",`react-flow__edge-${N}`,g.className,v,{selected:g.selected,animated:g.animated,inactive:!k&&!r,updating:A,selectable:k}]),onClick:G,onDoubleClick:K,onContextMenu:W,onMouseEnter:O,onMouseMove:X,onMouseLeave:Q,onKeyDown:E?U:void 0,tabIndex:E?0:void 0,role:g.ariaRole??(E?"group":"img"),"aria-roledescription":"edge","data-id":e,"data-testid":`rf__edge-${e}`,"aria-label":g.ariaLabel===null?void 0:g.ariaLabel||`Edge from ${g.source} to ${g.target}`,"aria-describedby":E?`${li}-${h}`:void 0,ref:V,...g.domAttributes,children:[!L&&_.jsx(S,{id:e,source:g.source,target:g.target,type:g.type,selected:g.selected,animated:g.animated,selectable:k,deletable:g.deletable??!0,label:g.label,labelStyle:g.labelStyle,labelShowBg:g.labelShowBg,labelBgStyle:g.labelBgStyle,labelBgPadding:g.labelBgPadding,labelBgBorderRadius:g.labelBgBorderRadius,sourceX:P,sourceY:T,targetX:I,targetY:H,sourcePosition:j,targetPosition:R,data:g.data,style:g.style,sourceHandleId:g.sourceHandle,targetHandleId:g.targetHandle,markerStart:F,markerEnd:B,pathOptions:"pathOptions"in g?g.pathOptions:void 0,interactionWidth:g.interactionWidth}),D&&_.jsx(nh,{edge:g,isReconnectable:D,reconnectRadius:u,onReconnect:f,onReconnectStart:d,onReconnectEnd:p,sourceX:P,sourceY:T,targetX:I,targetY:H,sourcePosition:j,targetPosition:R,setUpdateHover:$,setReconnecting:y})]})})}var rh=z.memo(oh);const ih=e=>({edgesFocusable:e.edgesFocusable,edgesReconnectable:e.edgesReconnectable,elementsSelectable:e.elementsSelectable,connectionMode:e.connectionMode,onError:e.onError});function Di({defaultMarkerColor:e,onlyRenderVisibleElements:t,rfId:n,edgeTypes:o,noPanClassName:r,onReconnect:s,onEdgeContextMenu:i,onEdgeMouseEnter:a,onEdgeMouseMove:l,onEdgeMouseLeave:c,onEdgeClick:u,reconnectRadius:f,onEdgeDoubleClick:d,onReconnectStart:p,onReconnectEnd:h,disableKeyboardA11y:w}){const{edgesFocusable:v,edgesReconnectable:m,elementsSelectable:b,onError:g}=J(ih,re),x=Ff(t);return _.jsxs("div",{className:"react-flow__edges",children:[_.jsx(Gf,{defaultColor:e,rfId:n}),x.map(N=>_.jsx(rh,{id:N,edgesFocusable:v,edgesReconnectable:m,elementsSelectable:b,noPanClassName:r,onReconnect:s,onContextMenu:i,onMouseEnter:a,onMouseMove:l,onMouseLeave:c,onClick:u,reconnectRadius:f,onDoubleClick:d,onReconnectStart:p,onReconnectEnd:h,rfId:n,onError:g,edgeTypes:o,disableKeyboardA11y:w},N))]})}Di.displayName="EdgeRenderer";const sh=z.memo(Di),ah=e=>`translate(${e.transform[0]}px,${e.transform[1]}px) scale(${e.transform[2]})`;function ch({children:e}){const t=J(ah);return _.jsx("div",{className:"react-flow__viewport xyflow__viewport react-flow__container",style:{transform:t},children:e})}function lh(e){const t=Hn(),n=z.useRef(!1);z.useEffect(()=>{!n.current&&t.viewportInitialized&&e&&(setTimeout(()=>e(t),1),n.current=!0)},[e,t.viewportInitialized])}const uh=e=>e.panZoom?.syncViewport;function dh(e){const t=J(uh),n=ie();return z.useEffect(()=>{e&&(t?.(e),n.setState({transform:[e.x,e.y,e.zoom]}))},[e,t]),null}function fh(e){return e.connection.inProgress?{...e.connection,to:gt(e.connection.to,e.transform)}:{...e.connection}}function hh(e){return fh}function gh(e){const t=hh();return J(t,re)}const ph=e=>({nodesConnectable:e.nodesConnectable,isValid:e.connection.isValid,inProgress:e.connection.inProgress,width:e.width,height:e.height});function mh({containerStyle:e,style:t,type:n,component:o}){const{nodesConnectable:r,width:s,height:i,isValid:a,inProgress:l}=J(ph,re);return!(s&&r&&l)?null:_.jsx("svg",{style:e,width:s,height:i,className:"react-flow__connectionline react-flow__container",children:_.jsx("g",{className:ae(["react-flow__connection",$r(a)]),children:_.jsx($i,{style:t,type:n,CustomComponent:o,isValid:a})})})}const $i=({style:e,type:t=ke.Bezier,CustomComponent:n,isValid:o})=>{const{inProgress:r,from:s,fromNode:i,fromHandle:a,fromPosition:l,to:c,toNode:u,toHandle:f,toPosition:d,pointer:p}=gh();if(!r)return;if(n)return _.jsx(n,{connectionLineType:t,connectionLineStyle:e,fromNode:i,fromHandle:a,fromX:s.x,fromY:s.y,toX:c.x,toY:c.y,fromPosition:l,toPosition:d,connectionStatus:$r(o),toNode:u,toHandle:f,pointer:p});let h="";const w={sourceX:s.x,sourceY:s.y,sourcePosition:l,targetX:c.x,targetY:c.y,targetPosition:d};switch(t){case ke.Bezier:[h]=Zr(w);break;case ke.SimpleBezier:[h]=_i(w);break;case ke.Step:[h]=yn({...w,borderRadius:0});break;case ke.SmoothStep:[h]=yn(w);break;default:[h]=Gr(w)}return _.jsx("path",{d:h,fill:"none",className:"react-flow__connection-path",style:e})};$i.displayName="ConnectionLine";const yh={};function qo(e=yh){z.useRef(e),ie(),z.useEffect(()=>{},[e])}function xh(){ie(),z.useRef(!1),z.useEffect(()=>{},[])}function zi({nodeTypes:e,edgeTypes:t,onInit:n,onNodeClick:o,onEdgeClick:r,onNodeDoubleClick:s,onEdgeDoubleClick:i,onNodeMouseEnter:a,onNodeMouseMove:l,onNodeMouseLeave:c,onNodeContextMenu:u,onSelectionContextMenu:f,onSelectionStart:d,onSelectionEnd:p,connectionLineType:h,connectionLineStyle:w,connectionLineComponent:v,connectionLineContainerStyle:m,selectionKeyCode:b,selectionOnDrag:g,selectionMode:x,multiSelectionKeyCode:N,panActivationKeyCode:S,zoomActivationKeyCode:E,deleteKeyCode:D,onlyRenderVisibleElements:k,elementsSelectable:V,defaultViewport:A,translateExtent:$,minZoom:L,maxZoom:y,preventScrolling:M,defaultMarkerColor:C,zoomOnScroll:P,zoomOnPinch:T,panOnScroll:I,panOnScrollSpeed:H,panOnScrollMode:j,zoomOnDoubleClick:R,panOnDrag:F,onPaneClick:B,onPaneMouseEnter:G,onPaneMouseMove:K,onPaneMouseLeave:W,onPaneScroll:O,onPaneContextMenu:X,paneClickDistance:Q,nodeClickDistance:U,onEdgeContextMenu:Z,onEdgeMouseEnter:q,onEdgeMouseMove:ee,onEdgeMouseLeave:ne,reconnectRadius:te,onReconnect:se,onReconnectStart:ce,onReconnectEnd:le,noDragClassName:oe,noWheelClassName:ue,noPanClassName:he,disableKeyboardA11y:ve,nodeExtent:Ut,rfId:pt,viewport:Re,onViewportChange:Ke}){return qo(e),qo(t),xh(),lh(n),dh(Re),_.jsx(Df,{onPaneClick:B,onPaneMouseEnter:G,onPaneMouseMove:K,onPaneMouseLeave:W,onPaneContextMenu:X,onPaneScroll:O,paneClickDistance:Q,deleteKeyCode:D,selectionKeyCode:b,selectionOnDrag:g,selectionMode:x,onSelectionStart:d,onSelectionEnd:p,multiSelectionKeyCode:N,panActivationKeyCode:S,zoomActivationKeyCode:E,elementsSelectable:V,zoomOnScroll:P,zoomOnPinch:T,zoomOnDoubleClick:R,panOnScroll:I,panOnScrollSpeed:H,panOnScrollMode:j,panOnDrag:F,defaultViewport:A,translateExtent:$,minZoom:L,maxZoom:y,onSelectionContextMenu:f,preventScrolling:M,noDragClassName:oe,noWheelClassName:ue,noPanClassName:he,disableKeyboardA11y:ve,onViewportChange:Ke,isControlledViewport:!!Re,children:_.jsxs(ch,{children:[_.jsx(sh,{edgeTypes:t,onEdgeClick:r,onEdgeDoubleClick:i,onReconnect:se,onReconnectStart:ce,onReconnectEnd:le,onlyRenderVisibleElements:k,onEdgeContextMenu:Z,onEdgeMouseEnter:q,onEdgeMouseMove:ee,onEdgeMouseLeave:ne,reconnectRadius:te,defaultMarkerColor:C,noPanClassName:he,disableKeyboardA11y:ve,rfId:pt}),_.jsx(mh,{style:w,type:h,component:v,containerStyle:m}),_.jsx("div",{className:"react-flow__edgelabel-renderer"}),_.jsx(Bf,{nodeTypes:e,onNodeClick:o,onNodeDoubleClick:s,onNodeMouseEnter:a,onNodeMouseMove:l,onNodeMouseLeave:c,onNodeContextMenu:u,nodeClickDistance:U,onlyRenderVisibleElements:k,noPanClassName:he,noDragClassName:oe,disableKeyboardA11y:ve,nodeExtent:Ut,rfId:pt}),_.jsx("div",{className:"react-flow__viewport-portal"})]})})}zi.displayName="GraphView";const wh=z.memo(zi),Ko=({nodes:e,edges:t,defaultNodes:n,defaultEdges:o,width:r,height:s,fitView:i,fitViewOptions:a,minZoom:l=.5,maxZoom:c=2,nodeOrigin:u,nodeExtent:f,zIndexMode:d="basic"}={})=>{const p=new Map,h=new Map,w=new Map,v=new Map,m=o??t??[],b=n??e??[],g=u??[0,0],x=f??it;Ur(w,v,m);const N=wn(b,p,h,{nodeOrigin:g,nodeExtent:x,zIndexMode:d});let S=[0,0,1];if(i&&r&&s){const E=ft(p,{filter:A=>!!((A.width||A.initialWidth)&&(A.height||A.initialHeight))}),{x:D,y:k,zoom:V}=An(E,r,s,l,c,a?.padding??.1);S=[D,k,V]}return{rfId:"1",width:r??0,height:s??0,transform:S,nodes:b,nodesInitialized:N,nodeLookup:p,parentLookup:h,edges:m,edgeLookup:v,connectionLookup:w,onNodesChange:null,onEdgesChange:null,hasDefaultNodes:n!==void 0,hasDefaultEdges:o!==void 0,panZoom:null,minZoom:l,maxZoom:c,translateExtent:it,nodeExtent:x,nodesSelectionActive:!1,userSelectionActive:!1,userSelectionRect:null,connectionMode:Ye.Strict,domNode:null,paneDragging:!1,noPanClassName:"nopan",nodeOrigin:g,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:{...Dr},connectionClickStartHandle:null,connectOnClick:!0,ariaLiveMessage:"",autoPanOnConnect:!0,autoPanOnNodeDrag:!0,autoPanOnNodeFocus:!0,autoPanSpeed:15,connectionRadius:20,onError:Hu,isValidConnection:void 0,onSelectionChangeHandlers:[],lib:"react",debug:!1,ariaLabelConfig:Tr,zIndexMode:d,onNodesChangeMiddlewareMap:new Map,onEdgesChangeMiddlewareMap:new Map}},vh=({nodes:e,edges:t,defaultNodes:n,defaultEdges:o,width:r,height:s,fitView:i,fitViewOptions:a,minZoom:l,maxZoom:c,nodeOrigin:u,nodeExtent:f,zIndexMode:d})=>zd((p,h)=>{async function w(){const{nodeLookup:v,panZoom:m,fitViewOptions:b,fitViewResolver:g,width:x,height:N,minZoom:S,maxZoom:E}=h();m&&(await zu({nodes:v,width:x,height:N,panZoom:m,minZoom:S,maxZoom:E},b),g?.resolve(!0),p({fitViewResolver:null}))}return{...Ko({nodes:e,edges:t,width:r,height:s,fitView:i,fitViewOptions:a,minZoom:l,maxZoom:c,nodeOrigin:u,nodeExtent:f,defaultNodes:n,defaultEdges:o,zIndexMode:d}),setNodes:v=>{const{nodeLookup:m,parentLookup:b,nodeOrigin:g,elevateNodesOnSelect:x,fitViewQueued:N,zIndexMode:S}=h(),E=wn(v,m,b,{nodeOrigin:g,nodeExtent:f,elevateNodesOnSelect:x,checkEquality:!0,zIndexMode:S});N&&E?(w(),p({nodes:v,nodesInitialized:E,fitViewQueued:!1,fitViewOptions:void 0})):p({nodes:v,nodesInitialized:E})},setEdges:v=>{const{connectionLookup:m,edgeLookup:b}=h();Ur(m,b,v),p({edges:v})},setDefaultNodesAndEdges:(v,m)=>{if(v){const{setNodes:b}=h();b(v),p({hasDefaultNodes:!0})}if(m){const{setEdges:b}=h();b(m),p({hasDefaultEdges:!0})}},updateNodeInternals:v=>{const{triggerNodeChanges:m,nodeLookup:b,parentLookup:g,domNode:x,nodeOrigin:N,nodeExtent:S,debug:E,fitViewQueued:D,zIndexMode:k}=h(),{changes:V,updatedInternals:A}=id(v,b,g,x,N,S,k);A&&(td(b,g,{nodeOrigin:N,nodeExtent:S,zIndexMode:k}),D?(w(),p({fitViewQueued:!1,fitViewOptions:void 0})):p({}),V?.length>0&&(E&&console.log("React Flow: trigger node changes",V),m?.(V)))},updateNodePositions:(v,m=!1)=>{const b=[];let g=[];const{nodeLookup:x,triggerNodeChanges:N,connection:S,updateConnection:E,onNodesChangeMiddlewareMap:D}=h();for(const[k,V]of v){const A=x.get(k),$=!!(A?.expandParent&&A?.parentId&&V?.position),L={id:k,type:"position",position:$?{x:Math.max(0,V.position.x),y:Math.max(0,V.position.y)}:V.position,dragging:m};if(A&&S.inProgress&&S.fromNode.id===A.id){const y=He(A,S.fromHandle,Y.Left,!0);E({...S,from:y})}$&&A.parentId&&b.push({id:k,parentId:A.parentId,rect:{...V.internals.positionAbsolute,width:V.measured.width??0,height:V.measured.height??0}}),g.push(L)}if(b.length>0){const{parentLookup:k,nodeOrigin:V}=h(),A=Ln(b,x,k,V);g.push(...A)}for(const k of D.values())g=k(g);N(g)},triggerNodeChanges:v=>{const{onNodesChange:m,setNodes:b,nodes:g,hasDefaultNodes:x,debug:N}=h();if(v?.length){if(x){const S=nf(v,g);b(S)}N&&console.log("React Flow: trigger node changes",v),m?.(v)}},triggerEdgeChanges:v=>{const{onEdgesChange:m,setEdges:b,edges:g,hasDefaultEdges:x,debug:N}=h();if(v?.length){if(x){const S=of(v,g);b(S)}N&&console.log("React Flow: trigger edge changes",v),m?.(v)}},addSelectedNodes:v=>{const{multiSelectionActive:m,edgeLookup:b,nodeLookup:g,triggerNodeChanges:x,triggerEdgeChanges:N}=h();if(m){const S=v.map(E=>De(E,!0));x(S);return}x(Oe(g,new Set([...v]),!0)),N(Oe(b))},addSelectedEdges:v=>{const{multiSelectionActive:m,edgeLookup:b,nodeLookup:g,triggerNodeChanges:x,triggerEdgeChanges:N}=h();if(m){const S=v.map(E=>De(E,!0));N(S);return}N(Oe(b,new Set([...v]))),x(Oe(g,new Set,!0))},unselectNodesAndEdges:({nodes:v,edges:m}={})=>{const{edges:b,nodes:g,nodeLookup:x,triggerNodeChanges:N,triggerEdgeChanges:S}=h(),E=v||g,D=m||b,k=E.map(A=>{const $=x.get(A.id);return $&&($.selected=!1),De(A.id,!1)}),V=D.map(A=>De(A.id,!1));N(k),S(V)},setMinZoom:v=>{const{panZoom:m,maxZoom:b}=h();m?.setScaleExtent([v,b]),p({minZoom:v})},setMaxZoom:v=>{const{panZoom:m,minZoom:b}=h();m?.setScaleExtent([b,v]),p({maxZoom:v})},setTranslateExtent:v=>{h().panZoom?.setTranslateExtent(v),p({translateExtent:v})},resetSelectedElements:()=>{const{edges:v,nodes:m,triggerNodeChanges:b,triggerEdgeChanges:g,elementsSelectable:x}=h();if(!x)return;const N=m.reduce((E,D)=>D.selected?[...E,De(D.id,!1)]:E,[]),S=v.reduce((E,D)=>D.selected?[...E,De(D.id,!1)]:E,[]);b(N),g(S)},setNodeExtent:v=>{const{nodes:m,nodeLookup:b,parentLookup:g,nodeOrigin:x,elevateNodesOnSelect:N,nodeExtent:S,zIndexMode:E}=h();v[0][0]===S[0][0]&&v[0][1]===S[0][1]&&v[1][0]===S[1][0]&&v[1][1]===S[1][1]||(wn(m,b,g,{nodeOrigin:x,nodeExtent:v,elevateNodesOnSelect:N,checkEquality:!1,zIndexMode:E}),p({nodeExtent:v}))},panBy:v=>{const{transform:m,width:b,height:g,panZoom:x,translateExtent:N}=h();return sd({delta:v,panZoom:x,transform:m,translateExtent:N,width:b,height:g})},setCenter:async(v,m,b)=>{const{width:g,height:x,maxZoom:N,panZoom:S}=h();if(!S)return Promise.resolve(!1);const E=typeof b?.zoom<"u"?b.zoom:N;return await S.setViewport({x:g/2-v*E,y:x/2-m*E,zoom:E},{duration:b?.duration,ease:b?.ease,interpolate:b?.interpolate}),Promise.resolve(!0)},cancelConnection:()=>{p({connection:{...Dr}})},updateConnection:v=>{p({connection:v})},reset:()=>p({...Ko()})}},Object.is);function _h({initialNodes:e,initialEdges:t,defaultNodes:n,defaultEdges:o,initialWidth:r,initialHeight:s,initialMinZoom:i,initialMaxZoom:a,initialFitViewOptions:l,fitView:c,nodeOrigin:u,nodeExtent:f,zIndexMode:d,children:p}){const[h]=z.useState(()=>vh({nodes:e,edges:t,defaultNodes:n,defaultEdges:o,width:r,height:s,fitView:c,minZoom:i,maxZoom:a,fitViewOptions:l,nodeOrigin:u,nodeExtent:f,zIndexMode:d}));return _.jsx(Ld,{value:h,children:_.jsx(cf,{children:p})})}function bh({children:e,nodes:t,edges:n,defaultNodes:o,defaultEdges:r,width:s,height:i,fitView:a,fitViewOptions:l,minZoom:c,maxZoom:u,nodeOrigin:f,nodeExtent:d,zIndexMode:p}){return z.useContext(Wt)?_.jsx(_.Fragment,{children:e}):_.jsx(_h,{initialNodes:t,initialEdges:n,defaultNodes:o,defaultEdges:r,initialWidth:s,initialHeight:i,fitView:a,initialFitViewOptions:l,initialMinZoom:c,initialMaxZoom:u,nodeOrigin:f,nodeExtent:d,zIndexMode:p,children:e})}const Sh={width:"100%",height:"100%",overflow:"hidden",position:"relative",zIndex:0};function Eh({nodes:e,edges:t,defaultNodes:n,defaultEdges:o,className:r,nodeTypes:s,edgeTypes:i,onNodeClick:a,onEdgeClick:l,onInit:c,onMove:u,onMoveStart:f,onMoveEnd:d,onConnect:p,onConnectStart:h,onConnectEnd:w,onClickConnectStart:v,onClickConnectEnd:m,onNodeMouseEnter:b,onNodeMouseMove:g,onNodeMouseLeave:x,onNodeContextMenu:N,onNodeDoubleClick:S,onNodeDragStart:E,onNodeDrag:D,onNodeDragStop:k,onNodesDelete:V,onEdgesDelete:A,onDelete:$,onSelectionChange:L,onSelectionDragStart:y,onSelectionDrag:M,onSelectionDragStop:C,onSelectionContextMenu:P,onSelectionStart:T,onSelectionEnd:I,onBeforeDelete:H,connectionMode:j,connectionLineType:R=ke.Bezier,connectionLineStyle:F,connectionLineComponent:B,connectionLineContainerStyle:G,deleteKeyCode:K="Backspace",selectionKeyCode:W="Shift",selectionOnDrag:O=!1,selectionMode:X=st.Full,panActivationKeyCode:Q="Space",multiSelectionKeyCode:U=ct()?"Meta":"Control",zoomActivationKeyCode:Z=ct()?"Meta":"Control",snapToGrid:q,snapGrid:ee,onlyRenderVisibleElements:ne=!1,selectNodesOnDrag:te,nodesDraggable:se,autoPanOnNodeFocus:ce,nodesConnectable:le,nodesFocusable:oe,nodeOrigin:ue=ui,edgesFocusable:he,edgesReconnectable:ve,elementsSelectable:Ut=!0,defaultViewport:pt=qd,minZoom:Re=.5,maxZoom:Ke=2,translateExtent:Vn=it,preventScrolling:Bi=!0,nodeExtent:Qt,defaultMarkerColor:Fi="#b1b1b7",zoomOnScroll:Xi=!0,zoomOnPinch:Yi=!0,panOnScroll:Zi=!1,panOnScrollSpeed:Wi=.5,panOnScrollMode:Gi=$e.Free,zoomOnDoubleClick:qi=!0,panOnDrag:Ki=!0,onPaneClick:Ui,onPaneMouseEnter:Qi,onPaneMouseMove:Ji,onPaneMouseLeave:es,onPaneScroll:ts,onPaneContextMenu:ns,paneClickDistance:os=1,nodeClickDistance:rs=0,children:is,onReconnect:ss,onReconnectStart:as,onReconnectEnd:cs,onEdgeContextMenu:ls,onEdgeDoubleClick:us,onEdgeMouseEnter:ds,onEdgeMouseMove:fs,onEdgeMouseLeave:hs,reconnectRadius:gs=10,onNodesChange:ps,onEdgesChange:ms,noDragClassName:ys="nodrag",noWheelClassName:xs="nowheel",noPanClassName:On="nopan",fitView:Bn,fitViewOptions:Fn,connectOnClick:ws,attributionPosition:vs,proOptions:_s,defaultEdgeOptions:bs,elevateNodesOnSelect:Ss=!0,elevateEdgesOnSelect:Es=!1,disableKeyboardA11y:Xn=!1,autoPanOnConnect:Cs,autoPanOnNodeDrag:Ns,autoPanSpeed:Ms,connectionRadius:Is,isValidConnection:ks,onError:As,style:Ps,id:Yn,nodeDragThreshold:Ts,connectionDragThreshold:Ds,viewport:$s,onViewportChange:zs,width:Ls,height:Hs,colorMode:Rs="light",debug:js,onScroll:Zn,ariaLabelConfig:Vs,zIndexMode:Wn="basic",...Os},Bs){const Jt=Yn||"1",Fs=Jd(Rs),Xs=z.useCallback(Gn=>{Gn.currentTarget.scrollTo({top:0,left:0,behavior:"instant"}),Zn?.(Gn)},[Zn]);return _.jsx("div",{"data-testid":"rf__wrapper",...Os,onScroll:Xs,style:{...Ps,...Sh},ref:Bs,className:ae(["react-flow",r,Fs]),id:Yn,role:"application",children:_.jsxs(bh,{nodes:e,edges:t,width:Ls,height:Hs,fitView:Bn,fitViewOptions:Fn,minZoom:Re,maxZoom:Ke,nodeOrigin:ue,nodeExtent:Qt,zIndexMode:Wn,children:[_.jsx(wh,{onInit:c,onNodeClick:a,onEdgeClick:l,onNodeMouseEnter:b,onNodeMouseMove:g,onNodeMouseLeave:x,onNodeContextMenu:N,onNodeDoubleClick:S,nodeTypes:s,edgeTypes:i,connectionLineType:R,connectionLineStyle:F,connectionLineComponent:B,connectionLineContainerStyle:G,selectionKeyCode:W,selectionOnDrag:O,selectionMode:X,deleteKeyCode:K,multiSelectionKeyCode:U,panActivationKeyCode:Q,zoomActivationKeyCode:Z,onlyRenderVisibleElements:ne,defaultViewport:pt,translateExtent:Vn,minZoom:Re,maxZoom:Ke,preventScrolling:Bi,zoomOnScroll:Xi,zoomOnPinch:Yi,zoomOnDoubleClick:qi,panOnScroll:Zi,panOnScrollSpeed:Wi,panOnScrollMode:Gi,panOnDrag:Ki,onPaneClick:Ui,onPaneMouseEnter:Qi,onPaneMouseMove:Ji,onPaneMouseLeave:es,onPaneScroll:ts,onPaneContextMenu:ns,paneClickDistance:os,nodeClickDistance:rs,onSelectionContextMenu:P,onSelectionStart:T,onSelectionEnd:I,onReconnect:ss,onReconnectStart:as,onReconnectEnd:cs,onEdgeContextMenu:ls,onEdgeDoubleClick:us,onEdgeMouseEnter:ds,onEdgeMouseMove:fs,onEdgeMouseLeave:hs,reconnectRadius:gs,defaultMarkerColor:Fi,noDragClassName:ys,noWheelClassName:xs,noPanClassName:On,rfId:Jt,disableKeyboardA11y:Xn,nodeExtent:Qt,viewport:$s,onViewportChange:zs}),_.jsx(Qd,{nodes:e,edges:t,defaultNodes:n,defaultEdges:o,onConnect:p,onConnectStart:h,onConnectEnd:w,onClickConnectStart:v,onClickConnectEnd:m,nodesDraggable:se,autoPanOnNodeFocus:ce,nodesConnectable:le,nodesFocusable:oe,edgesFocusable:he,edgesReconnectable:ve,elementsSelectable:Ut,elevateNodesOnSelect:Ss,elevateEdgesOnSelect:Es,minZoom:Re,maxZoom:Ke,nodeExtent:Qt,onNodesChange:ps,onEdgesChange:ms,snapToGrid:q,snapGrid:ee,connectionMode:j,translateExtent:Vn,connectOnClick:ws,defaultEdgeOptions:bs,fitView:Bn,fitViewOptions:Fn,onNodesDelete:V,onEdgesDelete:A,onDelete:$,onNodeDragStart:E,onNodeDrag:D,onNodeDragStop:k,onSelectionDrag:M,onSelectionDragStart:y,onSelectionDragStop:C,onMove:u,onMoveStart:f,onMoveEnd:d,noPanClassName:On,nodeOrigin:ue,rfId:Jt,autoPanOnConnect:Cs,autoPanOnNodeDrag:Ns,autoPanSpeed:Ms,onError:As,connectionRadius:Is,isValidConnection:ks,selectNodesOnDrag:te,nodeDragThreshold:Ts,connectionDragThreshold:Ds,onBeforeDelete:H,debug:js,ariaLabelConfig:Vs,zIndexMode:Wn}),_.jsx(Gd,{onSelectionChange:L}),is,_.jsx(Fd,{proOptions:_s,position:vs}),_.jsx(Bd,{rfId:Jt,disableKeyboardA11y:Xn})]})})}var Ch=fi(Eh);function Nh({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:ae(["react-flow__background-pattern",n,o])})}function Mh({radius:e,className:t}){return _.jsx("circle",{cx:e,cy:e,r:e,className:ae(["react-flow__background-pattern","dots",t])})}var Ae;(function(e){e.Lines="lines",e.Dots="dots",e.Cross="cross"})(Ae||(Ae={}));const Ih={[Ae.Dots]:1,[Ae.Lines]:1,[Ae.Cross]:6},kh=e=>({transform:e.transform,patternId:`pattern-${e.rfId}`});function Li({id:e,variant:t=Ae.Dots,gap:n=20,size:o,lineWidth:r=1,offset:s=0,color:i,bgColor:a,style:l,className:c,patternClassName:u}){const f=z.useRef(null),{transform:d,patternId:p}=J(kh,re),h=o||Ih[t],w=t===Ae.Dots,v=t===Ae.Cross,m=Array.isArray(n)?n:[n,n],b=[m[0]*d[2]||1,m[1]*d[2]||1],g=h*d[2],x=Array.isArray(s)?s:[s,s],N=v?[g,g]:b,S=[x[0]*d[2]||1+N[0]/2,x[1]*d[2]||1+N[1]/2],E=`${p}${e||""}`;return _.jsxs("svg",{className:ae(["react-flow__background",c]),style:{...l,...qt,"--xy-background-color-props":a,"--xy-background-pattern-color-props":i},ref:f,"data-testid":"rf__background",children:[_.jsx("pattern",{id:E,x:d[0]%b[0],y:d[1]%b[1],width:b[0],height:b[1],patternUnits:"userSpaceOnUse",patternTransform:`translate(-${S[0]},-${S[1]})`,children:w?_.jsx(Mh,{radius:g/2,className:u}):_.jsx(Nh,{dimensions:N,lineWidth:r,variant:t,className:u})}),_.jsx("rect",{x:"0",y:"0",width:"100%",height:"100%",fill:`url(#${E})`})]})}Li.displayName="Background";z.memo(Li);function Ah(){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 Ph(){return _.jsx("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 32 5",children:_.jsx("path",{d:"M0 0h32v4.2H0z"})})}function Th(){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 Dh(){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 $h(){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:ae(["react-flow__controls-button",t]),...n,children:e})}const zh=e=>({isInteractive:e.nodesDraggable||e.nodesConnectable||e.elementsSelectable,minZoomReached:e.transform[2]<=e.minZoom,maxZoomReached:e.transform[2]>=e.maxZoom,ariaLabelConfig:e.ariaLabelConfig});function Hi({style:e,showZoom:t=!0,showFitView:n=!0,showInteractive:o=!0,fitViewOptions:r,onZoomIn:s,onZoomOut:i,onFitView:a,onInteractiveChange:l,className:c,children:u,position:f="bottom-left",orientation:d="vertical","aria-label":p}){const h=ie(),{isInteractive:w,minZoomReached:v,maxZoomReached:m,ariaLabelConfig:b}=J(zh,re),{zoomIn:g,zoomOut:x,fitView:N}=Hn(),S=()=>{g(),s?.()},E=()=>{x(),i?.()},D=()=>{N(r),a?.()},k=()=>{h.setState({nodesDraggable:!w,nodesConnectable:!w,elementsSelectable:!w}),l?.(!w)},V=d==="horizontal"?"horizontal":"vertical";return _.jsxs(Gt,{className:ae(["react-flow__controls",V,c]),position:f,style:e,"data-testid":"rf__controls","aria-label":p??b["controls.ariaLabel"],children:[t&&_.jsxs(_.Fragment,{children:[_.jsx(bt,{onClick:S,className:"react-flow__controls-zoomin",title:b["controls.zoomIn.ariaLabel"],"aria-label":b["controls.zoomIn.ariaLabel"],disabled:m,children:_.jsx(Ah,{})}),_.jsx(bt,{onClick:E,className:"react-flow__controls-zoomout",title:b["controls.zoomOut.ariaLabel"],"aria-label":b["controls.zoomOut.ariaLabel"],disabled:v,children:_.jsx(Ph,{})})]}),n&&_.jsx(bt,{className:"react-flow__controls-fitview",onClick:D,title:b["controls.fitView.ariaLabel"],"aria-label":b["controls.fitView.ariaLabel"],children:_.jsx(Th,{})}),o&&_.jsx(bt,{className:"react-flow__controls-interactive",onClick:k,title:b["controls.interactive.ariaLabel"],"aria-label":b["controls.interactive.ariaLabel"],children:w?_.jsx($h,{}):_.jsx(Dh,{})}),u]})}Hi.displayName="Controls";z.memo(Hi);function Lh({id:e,x:t,y:n,width:o,height:r,style:s,color:i,strokeColor:a,strokeWidth:l,className:c,borderRadius:u,shapeRendering:f,selected:d,onClick:p}){const{background:h,backgroundColor:w}=s||{},v=i||h||w;return _.jsx("rect",{className:ae(["react-flow__minimap-node",{selected:d},c]),x:t,y:n,rx:u,ry:u,width:o,height:r,style:{fill:v,stroke:a,strokeWidth:l},shapeRendering:f,onClick:p?m=>p(m,e):void 0})}const Hh=z.memo(Lh),Rh=e=>e.nodes.map(t=>t.id),ln=e=>e instanceof Function?e:()=>e;function jh({nodeStrokeColor:e,nodeColor:t,nodeClassName:n="",nodeBorderRadius:o=5,nodeStrokeWidth:r,nodeComponent:s=Hh,onClick:i}){const a=J(Rh,re),l=ln(t),c=ln(e),u=ln(n),f=typeof window>"u"||window.chrome?"crispEdges":"geometricPrecision";return _.jsx(_.Fragment,{children:a.map(d=>_.jsx(Oh,{id:d,nodeColorFunc:l,nodeStrokeColorFunc:c,nodeClassNameFunc:u,nodeBorderRadius:o,nodeStrokeWidth:r,NodeComponent:s,onClick:i,shapeRendering:f},d))})}function Vh({id:e,nodeColorFunc:t,nodeStrokeColorFunc:n,nodeClassNameFunc:o,nodeBorderRadius:r,nodeStrokeWidth:s,shapeRendering:i,NodeComponent:a,onClick:l}){const{node:c,x:u,y:f,width:d,height:p}=J(h=>{const{internals:w}=h.nodeLookup.get(e),v=w.userNode,{x:m,y:b}=w.positionAbsolute,{width:g,height:x}=Ne(v);return{node:v,x:m,y:b,width:g,height:x}},re);return!c||c.hidden||!Vr(c)?null:_.jsx(a,{x:u,y:f,width:d,height:p,style:c.style,selected:!!c.selected,className:o(c),color:t(c),borderRadius:r,strokeColor:n(c),strokeWidth:s,shapeRendering:i,onClick:l,id:c.id})}const Oh=z.memo(Vh);var Bh=z.memo(jh);const Fh=200,Xh=150,Yh=e=>!e.hidden,Zh=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?jr(ft(e.nodeLookup,{filter:Yh}),t):t,rfId:e.rfId,panZoom:e.panZoom,translateExtent:e.translateExtent,flowWidth:e.width,flowHeight:e.height,ariaLabelConfig:e.ariaLabelConfig}},Wh="react-flow__minimap-desc";function Ri({style:e,className:t,nodeStrokeColor:n,nodeColor:o,nodeClassName:r="",nodeBorderRadius:s=5,nodeStrokeWidth:i,nodeComponent:a,bgColor:l,maskColor:c,maskStrokeColor:u,maskStrokeWidth:f,position:d="bottom-right",onClick:p,onNodeClick:h,pannable:w=!1,zoomable:v=!1,ariaLabel:m,inversePan:b,zoomStep:g=1,offsetScale:x=5}){const N=ie(),S=z.useRef(null),{boundingRect:E,viewBB:D,rfId:k,panZoom:V,translateExtent:A,flowWidth:$,flowHeight:L,ariaLabelConfig:y}=J(Zh,re),M=e?.width??Fh,C=e?.height??Xh,P=E.width/M,T=E.height/C,I=Math.max(P,T),H=I*M,j=I*C,R=x*I,F=E.x-(H-E.width)/2-R,B=E.y-(j-E.height)/2-R,G=H+R*2,K=j+R*2,W=`${Wh}-${k}`,O=z.useRef(0),X=z.useRef();O.current=I,z.useEffect(()=>{if(S.current&&V)return X.current=pd({domNode:S.current,panZoom:V,getTransform:()=>N.getState().transform,getViewScale:()=>O.current}),()=>{X.current?.destroy()}},[V]),z.useEffect(()=>{X.current?.update({translateExtent:A,width:$,height:L,inversePan:b,pannable:w,zoomStep:g,zoomable:v})},[w,v,b,g,A,$,L]);const Q=p?q=>{const[ee,ne]=X.current?.pointer(q)||[0,0];p(q,{x:ee,y:ne})}:void 0,U=h?z.useCallback((q,ee)=>{const ne=N.getState().nodeLookup.get(ee).internals.userNode;h(q,ne)},[]):void 0,Z=m??y["minimap.ariaLabel"];return _.jsx(Gt,{position:d,style:{...e,"--xy-minimap-background-color-props":typeof l=="string"?l:void 0,"--xy-minimap-mask-background-color-props":typeof c=="string"?c:void 0,"--xy-minimap-mask-stroke-color-props":typeof u=="string"?u:void 0,"--xy-minimap-mask-stroke-width-props":typeof f=="number"?f*I: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:ae(["react-flow__minimap",t]),"data-testid":"rf__minimap",children:_.jsxs("svg",{width:M,height:C,viewBox:`${F} ${B} ${G} ${K}`,className:"react-flow__minimap-svg",role:"img","aria-labelledby":W,ref:S,onClick:Q,children:[Z&&_.jsx("title",{id:W,children:Z}),_.jsx(Bh,{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${G+R*2}v${K+R*2}h${-G-R*2}z
7
- M${D.x},${D.y}h${D.width}v${D.height}h${-D.width}z`,fillRule:"evenodd",pointerEvents:"none"})]})})}Ri.displayName="MiniMap";z.memo(Ri);const Gh=e=>t=>e?`${Math.max(1/t.transform[2],1)}`:void 0,qh={[qe.Line]:"right",[qe.Handle]:"bottom-right"};function Kh({nodeId:e,position:t,variant:n=qe.Handle,className:o,style:r=void 0,children:s,color:i,minWidth:a=10,minHeight:l=10,maxWidth:c=Number.MAX_VALUE,maxHeight:u=Number.MAX_VALUE,keepAspectRatio:f=!1,resizeDirection:d,autoScale:p=!0,shouldResize:h,onResizeStart:w,onResize:v,onResizeEnd:m}){const b=mi(),g=typeof e=="string"?e:b,x=ie(),N=z.useRef(null),S=n===qe.Handle,E=J(z.useCallback(Gh(S&&p),[S,p]),re),D=z.useRef(null),k=t??qh[n];z.useEffect(()=>{if(!(!N.current||!g))return D.current||(D.current=kd({domNode:N.current,nodeId:g,getStoreItems:()=>{const{nodeLookup:A,transform:$,snapGrid:L,snapToGrid:y,nodeOrigin:M,domNode:C}=x.getState();return{nodeLookup:A,transform:$,snapGrid:L,snapToGrid:y,nodeOrigin:M,paneDomNode:C}},onChange:(A,$)=>{const{triggerNodeChanges:L,nodeLookup:y,parentLookup:M,nodeOrigin:C}=x.getState(),P=[],T={x:A.x,y:A.y},I=y.get(g);if(I&&I.expandParent&&I.parentId){const H=I.origin??C,j=A.width??I.measured.width??0,R=A.height??I.measured.height??0,F={id:I.id,parentId:I.parentId,rect:{width:j,height:R,...Or({x:A.x??I.position.x,y:A.y??I.position.y},{width:j,height:R},I.parentId,y,H)}},B=Ln([F],y,M,C);P.push(...B),T.x=A.x?Math.max(H[0]*j,A.x):void 0,T.y=A.y?Math.max(H[1]*R,A.y):void 0}if(T.x!==void 0&&T.y!==void 0){const H={id:g,type:"position",position:{...T}};P.push(H)}if(A.width!==void 0&&A.height!==void 0){const j={id:g,type:"dimensions",resizing:!0,setAttributes:d?d==="horizontal"?"width":"height":!0,dimensions:{width:A.width,height:A.height}};P.push(j)}for(const H of $){const j={...H,type:"position"};P.push(j)}L(P)},onEnd:({width:A,height:$})=>{const L={id:g,type:"dimensions",resizing:!1,dimensions:{width:A,height:$}};x.getState().triggerNodeChanges([L])}})),D.current.update({controlPosition:k,boundaries:{minWidth:a,minHeight:l,maxWidth:c,maxHeight:u},keepAspectRatio:f,resizeDirection:d,onResizeStart:w,onResize:v,onResizeEnd:m,shouldResize:h}),()=>{D.current?.destroy()}},[k,a,l,c,u,f,w,v,m,h]);const V=k.split("-");return _.jsx("div",{className:ae(["react-flow__resize-control","nodrag",...V,n,o]),ref:N,style:{...r,scale:E,...i&&{[S?"backgroundColor":"borderColor"]:i}},children:s})}z.memo(Kh);const ji=z.createContext(void 0);function Vi(){const e=z.useContext(ji);if(!e)throw new Error("useMetricsMode must be used within MetricsModeProvider");return e}function Uh(e){const t=ge.c(5),{children:n}=e,[o,r]=z.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(ji.Provider,{value:s,children:n}),t[2]=n,t[3]=s,t[4]=i):i=t[4],i}const Uo=10,Ht=56,jn=220,nt=56,Qh={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 Jh(){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 eg(e){const t=new Map,n=new Map;for(const s of e){const i=s.connectionId;if(i){const l=n.get(i)??{requests:0,errors:0,totalLatency:0};n.set(i,{requests:l.requests+1,errors:l.errors+(s.isError?1:0),totalLatency:l.totalLatency+s.durationMs})}const a=s.gatewayId;if(a){const l=t.get(a)??{requests:0,errors:0,totalLatency:0};t.set(a,{requests:l.requests+1,errors:l.errors+(s.isError?1:0),totalLatency:l.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 Oi(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 St(e,t){if(!e)return 0;switch(t){case"requests":return e.requests;case"errors":return e.errorRate;case"latency":return e.avgLatencyMs}}function tg(){const e=ge.c(9),{locator:t}=bn();let n;e[0]===Symbol.for("react.memo_cache_sentinel")?(n=aa(),e[0]=n):n=e[0];const o=n;let r;e[1]===Symbol.for("react.memo_cache_sentinel")?(r=Jh(),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:l}=ya(a);let c;e[5]!==l?.logs?(c=l?.logs??[],e[5]=l?.logs,e[6]=c):c=e[6];const u=c;let f;return e[7]!==u?(f=eg(u),e[7]=u,e[8]=f):f=e[8],f}function ng(e){const t=ge.c(29),{data:n}=e,o=Rt();let r;t[0]!==n.metric||t[1]!==n.metricsMode?(r=Oi(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 l;t[7]===Symbol.for("react.memo_cache_sentinel")?(l={height:Ht,width:jn},t[7]=l):l=t[7];let c;t[8]===Symbol.for("react.memo_cache_sentinel")?(c=_.jsx(la,{}),t[8]=c):c=t[8];let u;t[9]!==n.gateway.icon||t[10]!==n.gateway.title?(u=_.jsx(er,{icon:n.gateway.icon,name:n.gateway.title,size:"md",fallbackIcon:c,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=or("text-base leading-none font-semibold tabular-nums",n.colorScheme.textClass),t[14]=n.colorScheme.textClass,t[15]=d):d=t[15];let p;t[16]!==s||t[17]!==d?(p=_.jsx("span",{className:d,children:s}),t[16]=s,t[17]=d,t[18]=p):p=t[18];let h;t[19]!==f||t[20]!==p?(h=_.jsxs("div",{className:"relative z-10 flex flex-col min-w-0 flex-1",children:[f,p]}),t[19]=f,t[20]=p,t[21]=h):h=t[21];let w;t[22]!==n.colorScheme.edgeColor?(w=_.jsx(Pe,{type:"source",position:Y.Right,style:{width:"8px",height:"8px",background:n.colorScheme.edgeColor,border:"none"}}),t[22]=n.colorScheme.edgeColor,t[23]=w):w=t[23];let v;return t[24]!==a||t[25]!==w||t[26]!==u||t[27]!==h?(v=_.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:l,onClick:a,children:[u,h,w]}),t[24]=a,t[25]=w,t[26]=u,t[27]=h,t[28]=v):v=t[28],v}function og(e){const t=ge.c(29),{data:n}=e,o=Rt();let r;t[0]!==n.metric||t[1]!==n.metricsMode?(r=Oi(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 l;t[7]===Symbol.for("react.memo_cache_sentinel")?(l={height:Ht,width:jn},t[7]=l):l=t[7];const c=`1px solid ${n.colorScheme.edgeColor}`;let u;t[8]!==c?(u=_.jsx(Pe,{type:"target",position:Y.Left,style:{width:"8px",height:"8px",background:"var(--background)",border:c,pointerEvents:"none",cursor:"default"}}),t[8]=c,t[9]=u):u=t[9];let f;t[10]===Symbol.for("react.memo_cache_sentinel")?(f=_.jsx(ca,{}),t[10]=f):f=t[10];let d;t[11]!==n.connection.icon||t[12]!==n.connection.title?(d=_.jsx(er,{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 p;t[14]!==n.connection.title?(p=_.jsx("span",{className:"text-sm text-muted-foreground truncate",children:n.connection.title}),t[14]=n.connection.title,t[15]=p):p=t[15];let h;t[16]!==n.colorScheme.textClass?(h=or("text-base leading-[1.35] font-semibold tabular-nums",n.colorScheme.textClass),t[16]=n.colorScheme.textClass,t[17]=h):h=t[17];let w;t[18]!==s||t[19]!==h?(w=_.jsx("span",{className:h,children:s}),t[18]=s,t[19]=h,t[20]=w):w=t[20];let v;t[21]!==w||t[22]!==p?(v=_.jsxs("div",{className:"relative z-10 flex flex-col min-w-0 flex-1",children:[p,w]}),t[21]=w,t[22]=p,t[23]=v):v=t[23];let m;return t[24]!==a||t[25]!==v||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:l,onClick:a,children:[u,d,v]}),t[24]=a,t[25]=v,t[26]=u,t[27]=d,t[28]=m):m=t[28],m}function rg(e){const t=ge.c(9),{data:n}=e,o=Rt();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,l;t[4]===Symbol.for("react.memo_cache_sentinel")?(a=_.jsx(Pe,{type:"target",position:Y.Left,style:{opacity:0,pointerEvents:"none"}}),l=_.jsx("img",{src:"/logos/deco logo.svg",alt:"Deco",className:"h-8 w-8"}),t[4]=a,t[5]=l):(a=t[4],l=t[5]);let c;t[6]===Symbol.for("react.memo_cache_sentinel")?(c=_.jsx(Pe,{type:"source",position:Y.Right,style:{opacity:0,pointerEvents:"none"}}),t[6]=c):c=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,l,c]}),t[7]=s,t[8]=u):u=t[8],u}const ig={gateway:ng,server:og,mesh:rg};function sg(){const e=ge.c(8),{metricsMode:t,setMetricsMode:n}=Vi();let o;e[0]!==n?(o=l=>l&&n(l),e[0]=n,e[1]=o):o=e[1];let r,s,i;e[2]===Symbol.for("react.memo_cache_sentinel")?(r=_.jsx(tn,{value:"requests",className:"text-xs px-3 cursor-pointer",children:"Tool Calls"}),s=_.jsx(tn,{value:"errors",className:"text-xs px-3 cursor-pointer",children:"Errors"}),i=_.jsx(tn,{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(wa,{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 ag(){const e=ge.c(36),{metricsMode:t}=Vi(),{org:n}=bn();let o;e[0]===Symbol.for("react.memo_cache_sentinel")?(o={pageSize:Uo},e[0]=o):o=e[0];const r=tr(o);let s;e[1]===Symbol.for("react.memo_cache_sentinel")?(s={pageSize:Uo},e[1]=s):s=e[1];const i=Jo(s),a=tg();let l,c,u,f,d;if(e[2]!==t||e[3]!==a||e[4]!==i||e[5]!==r){let A;e[11]!==t||e[12]!==a?(A=(L,y)=>St(a.gateways.get(y.id),t)-St(a.gateways.get(L.id),t),e[11]=t,e[12]=a,e[13]=A):A=e[13],d=[...r].sort(A);let $;e[14]!==t||e[15]!==a?($=(L,y)=>St(a.connections.get(y.id),t)-St(a.connections.get(L.id),t),e[14]=t,e[15]=a,e[16]=$):$=e[16],f=[...i].sort($),l=Qh[t],u=new Map,d.forEach((L,y)=>u.set(L.id,y)),c=new Map,f.forEach((L,y)=>c.set(L.id,y)),e[2]=t,e[3]=a,e[4]=i,e[5]=r,e[6]=l,e[7]=c,e[8]=u,e[9]=f,e[10]=d}else l=e[6],c=e[7],u=e[8],f=e[9],d=e[10];const p=-nt/2,h=nt/2,w=p-100-jn,v=h+100,m=d.length,b=f.length;let g,x;if(e[17]!==l||e[18]!==c||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 A={stroke:l.edgeColor,strokeWidth:1.25,strokeDasharray:"8 6",strokeLinecap:"square"};x=[],g=[],x.push({id:"mesh",type:"mesh",position:{x:p,y:-nt/2},data:{org:n.slug,colorScheme:l},draggable:!1,selectable:!1}),[...r].sort(lg).forEach(y=>{const P=((u.get(y.id)??0)-(m-1)/2)*70-Ht/2;x.push({id:`gateway-${y.id}`,type:"gateway",position:{x:w,y:P},data:{gateway:y,metricsMode:t,metric:a.gateways.get(y.id),colorScheme:l,org:n.slug},draggable:!1,selectable:!1}),g.push({id:`e-gw-${y.id}`,source:`gateway-${y.id}`,target:"mesh",type:"smoothstep",animated:!0,style:A})}),[...i].sort(cg).forEach(y=>{const P=((c.get(y.id)??0)-(b-1)/2)*70-Ht/2;x.push({id:`server-${y.id}`,type:"server",position:{x:v,y:P},data:{connection:y,metricsMode:t,metric:a.connections.get(y.id),colorScheme:l,org:n.slug},draggable:!1,selectable:!1}),g.push({id:`e-srv-${y.id}`,source:"mesh",target:`server-${y.id}`,type:"smoothstep",animated:!0,style:A})}),e[17]=l,e[18]=c,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]=g,e[28]=x}else g=e[27],x=e[28];let N;e[29]===Symbol.for("react.memo_cache_sentinel")?(N={backgroundImage:"radial-gradient(circle, var(--border) 1px, transparent 1.5px)",backgroundSize:"32px 32px"},e[29]=N):N=e[29];const S=N;let E;e[30]===Symbol.for("react.memo_cache_sentinel")?(E=_.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]=E):E=e[30];let D;e[31]===Symbol.for("react.memo_cache_sentinel")?(D={padding:.3},e[31]=D):D=e[31];let k;e[32]===Symbol.for("react.memo_cache_sentinel")?(k={hideAttribution:!0},e[32]=k):k=e[32];let V;return e[33]!==g||e[34]!==x?(V=_.jsxs("div",{className:"w-full h-full min-h-[420px] relative mesh-minimap bg-background",style:S,children:[E,_.jsx(Ch,{nodes:x,edges:g,nodeTypes:ig,fitView:!0,fitViewOptions:D,nodesDraggable:!1,nodesConnectable:!1,elementsSelectable:!0,zoomOnScroll:!0,zoomOnPinch:!0,zoomOnDoubleClick:!0,panOnScroll:!1,panOnDrag:!0,preventScrolling:!0,proOptions:k,className:"bg-transparent"})]}),e[33]=g,e[34]=x,e[35]=V):V=e[35],V}function cg(e,t){return e.id.localeCompare(t.id)}function lg(e,t){return e.id.localeCompare(t.id)}function ug(){const e=ge.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(fg)}),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(dg)})]})}),e[2]=o):o=e[2],o}function dg(e){return _.jsx("div",{className:"h-14 w-[220px] bg-muted animate-pulse rounded-lg"},e)}function fg(e){return _.jsx("div",{className:"h-14 w-[220px] bg-muted animate-pulse rounded-lg"},e)}function hg(){const e=new Date().getHours();return e>=5&&e<12?"Morning":e>=12&&e<17?"Afternoon":e>=17&&e<22?"Evening":"Night"}function gg(e,t){return e.find(t)??e[0]}function Qo(e,t,n,o){const r=ge.c(9),s=null,[i,a]=nr(e,s);let l;r[0]!==n||r[1]!==i?(l=d=>i?n(d,i):!1,r[0]=n,r[1]=i,r[2]=l):l=r[2];let c;r[3]!==t||r[4]!==l?(c=gg(t,l),r[3]=t,r[4]=l,r[5]=c):c=r[5];const u=c;let f;return r[6]!==u||r[7]!==a?(f=[u,a],r[6]=u,r[7]=a,r[8]=f):f=r[8],f}function pg(e){const t=ge.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,l=n.length,c=`${n.length}ch`,u=`${a}ms`;let f;t[0]!==c||t[1]!==l||t[2]!==u?(f={"--typewriter-duration":u,"--typewriter-steps":l,"--typewriter-max-width":c},t[0]=c,t[1]=l,t[2]=u,t[3]=f):f=t[3];const d=f;let p;t[4]!==n?(p=_.jsx("span",{className:"typewriter-text",children:n}),t[4]=n,t[5]=p):p=t[5];let h;t[6]===Symbol.for("react.memo_cache_sentinel")?(h=_.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]=h):h=t[6];let w;return t[7]!==s||t[8]!==d||t[9]!==p||t[10]!==n?(w=_.jsxs("span",{className:s,style:d,children:[p,h]},n),t[7]=s,t[8]=d,t[9]=p,t[10]=n,t[11]=w):w=t[11],w}function mg(){const e=ge.c(85),{org:t,locator:n}=bn(),{data:o}=Gs.useSession(),r=o?.user,s=Rt(),{inputValue:i,setInputValue:a,createThread:l,activeThreadId:c,setActiveThreadId:u,hideThread:f}=Kn(),{threads:d,refetch:p}=Us(),[h,w]=nr(`${n}:home-view-mode`,"chat"),v=tr(),m=Qs(),b=Jo();let g;e[0]!==b?(g={connections:b,binding:"LLMS"},e[0]=b,e[1]=g):g=e[1];const[x]=ua(g),N=!!x;let S;e[2]!==n?(S=da.chatSelectedModel(n),e[2]=n,e[3]=S):S=e[3];const[E,D]=Qo(S,m,xg),[k,V]=Qo(`${n}:selected-gateway`,v,yg);let A;e[4]!==D?(A=oe=>{D(oe)},e[4]=D,e[5]=A):A=e[5];const $=A;let L;e[6]!==V?(L=oe=>{V({gatewayId:oe})},e[6]=V,e[7]=L):L=e[7];const y=L,M=Js(),C=ea(k?.id);let P;e[8]!==l||e[9]!==k?.id?(P=oe=>l({id:oe.id,title:oe.title,gatewayId:k?.id}),e[8]=l,e[9]=k?.id,e[10]=P):P=e[10];let T;e[11]!==c||e[12]!==M||e[13]!==C||e[14]!==P?(T={threadId:c,systemPrompt:C,onToolCall:M,onCreateThread:P},e[11]=c,e[12]=M,e[13]=C,e[14]=P,e[15]=T):T=e[15];const I=ta(T),{branchContext:H,clearBranch:j}=Kn();let R;e[16]!==c||e[17]!==I||e[18]!==j||e[19]!==k||e[20]!==E||e[21]!==a||e[22]!==r?.image||e[23]!==r?.name?(R=async oe=>{if(!E){qn.error("No model configured");return}if(!k?.id){qn.error("No Agent configured");return}a(""),j();const ue={created_at:new Date().toISOString(),thread_id:c,model:{id:E.id,connectionId:E.connectionId,provider:E.provider??void 0,limits:E.limits??void 0},gateway:{id:k.id},user:{avatar:r?.image??void 0,name:r?.name??"you"}};await I.sendMessage(oe,ue)},e[16]=c,e[17]=I,e[18]=j,e[19]=k,e[20]=E,e[21]=a,e[22]=r?.image,e[23]=r?.name,e[24]=R):R=e[24];const F=R;let B;e[25]!==r?.name?(B=r?.name?.split(" ")[0]||"there",e[25]=r?.name,e[26]=B):B=e[26];const G=B;let K;e[27]===Symbol.for("react.memo_cache_sentinel")?(K=hg(),e[27]=K):K=e[27];const W=K;let O;e[28]!==c||e[29]!==d?(O=d?.find(oe=>oe.id===c),e[28]=c,e[29]=d,e[30]=O):O=e[30];const X=O;if(!N){const oe=r?.id||"";let ue;e[31]!==b?(ue=b??[],e[31]=b,e[32]=ue):ue=e[32];let he;e[33]!==s||e[34]!==t.slug?(he=()=>{s({to:"/$org/mcps",params:{org:t.slug},search:{action:"create"}})},e[33]=s,e[34]=t.slug,e[35]=he):he=e[35];let ve;return e[36]!==t.id||e[37]!==t.slug||e[38]!==oe||e[39]!==ue||e[40]!==he?(ve=_.jsx("div",{className:"flex flex-col size-full bg-background items-center justify-center",children:_.jsx(na,{orgSlug:t.slug,orgId:t.id,userId:oe,allConnections:ue,onInstallMcpServer:he})}),e[36]=t.id,e[37]=t.slug,e[38]=oe,e[39]=ue,e[40]=he,e[41]=ve):ve=e[41],ve}let Q;e[42]!==X||e[43]!==I||e[44]!==h?(Q=_.jsx(pe.Header.Left,{children:h==="graph"?_.jsx("span",{className:"text-sm font-medium text-foreground",children:"Summary"}):!I.isEmpty&&X?.title?_.jsx(pg,{text:X.title,className:"text-sm font-medium text-foreground"}):_.jsx("span",{className:"text-sm font-medium text-foreground",children:"Chat"})}),e[42]=X,e[43]=I,e[44]=h,e[45]=Q):Q=e[45];let U;e[46]!==h?(U=h==="graph"&&_.jsx(sg,{}),e[46]=h,e[47]=U):U=e[47];let Z;e[48]!==c||e[49]!==l||e[50]!==f||e[51]!==p||e[52]!==u||e[53]!==d||e[54]!==h?(Z=h!=="graph"&&_.jsxs(_.Fragment,{children:[_.jsx(fa,{type:"button",variant:"outline",size:"icon",className:"size-7 border border-input",onClick:()=>l(),"aria-label":"New chat",children:_.jsx(ma,{size:16})}),_.jsx(sa,{threads:d,activeThreadId:c,onSelectThread:u,onRemoveThread:f,onOpen:()=>p(),variant:"outline"})]}),e[48]=c,e[49]=l,e[50]=f,e[51]=p,e[52]=u,e[53]=d,e[54]=h,e[55]=Z):Z=e[55];let q;e[56]===Symbol.for("react.memo_cache_sentinel")?(q={value:"chat",icon:_.jsx(rr,{})},e[56]=q):q=e[56];let ee;e[57]===Symbol.for("react.memo_cache_sentinel")?(ee=[q,{value:"graph",icon:_.jsx(ga,{})}],e[57]=ee):ee=e[57];let ne;e[58]!==w||e[59]!==h?(ne=_.jsx(ha,{value:h,onValueChange:w,size:"sm",options:ee}),e[58]=w,e[59]=h,e[60]=ne):ne=e[60];let te;e[61]!==U||e[62]!==Z||e[63]!==ne?(te=_.jsxs(pe.Header.Right,{children:[U,Z,ne]}),e[61]=U,e[62]=Z,e[63]=ne,e[64]=te):te=e[64];let se;e[65]!==Q||e[66]!==te?(se=_.jsxs(pe.Header,{children:[Q,te]}),e[65]=Q,e[66]=te,e[67]=se):se=e[67];let ce;e[68]!==H||e[69]!==I||e[70]!==j||e[71]!==y||e[72]!==$||e[73]!==F||e[74]!==i||e[75]!==k||e[76]!==E||e[77]!==u||e[78]!==a||e[79]!==G||e[80]!==h?(ce=h==="graph"?_.jsx("div",{className:"flex-1 overflow-hidden relative",children:_.jsx(Qn,{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(z.Suspense,{fallback:_.jsx(ug,{}),children:_.jsx(ag,{})})})}):I.isEmpty?_.jsx("div",{className:"flex-1 min-h-0 flex flex-col items-center justify-center px-10 py-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:[W," ",G,","]}),_.jsx("p",{className:"text-base text-muted-foreground",children:"What are we building today?"})]}),k?.id&&_.jsx(Qn,{fallback:null,children:_.jsx(z.Suspense,{fallback:_.jsx("div",{className:"flex justify-center",children:_.jsx(pa,{size:20,className:"animate-spin text-muted-foreground"})}),children:_.jsx(ra,{gatewayId:k.id,onSelect:oe=>{F(oe.description??oe.name)},className:"w-full"})})},k.id),_.jsx("div",{className:"w-full shadow-sm rounded-xl",children:_.jsxs(ia,{value:i,onChange:a,onSubmit:async()=>{i.trim()&&await F(i.trim())},placeholder:"Ask anything or @ for context",maxTextHeight:"65px",children:[_.jsx(to,{selectedGatewayId:k?.id,onGatewayChange:y,placeholder:"Agent",variant:"borderless"}),_.jsx(Un,{selectedModel:E??void 0,onModelChange:$,placeholder:"Model",variant:"borderless"})]})})]})}):_.jsxs(_.Fragment,{children:[_.jsx(pe.Main,{children:_.jsx(pe.Messages,{messages:I.messages,status:I.status,minHeightOffset:240})}),_.jsx(pe.Footer,{children:_.jsxs("div",{className:"flex flex-col gap-2",children:[_.jsx(pe.ErrorBanner,{error:I.error,onFixInChat:()=>{I.error&&F(`I encountered this error: ${I.error.message}. Can you help me fix it?`)},onDismiss:I.clearError}),_.jsx(pe.FinishReasonWarning,{finishReason:I.finishReason,onContinue:()=>{F("Please continue.")},onDismiss:I.clearFinishReason}),_.jsx(pe.BranchPreview,{branchContext:H,clearBranchContext:j,onGoToOriginalMessage:()=>{H&&(u(H.originalThreadId),j(),a(""))},setInputValue:a}),_.jsxs(pe.Input,{value:i,onChange:a,onSubmit:async()=>{i.trim()&&await F(i.trim())},onStop:I.stop,disabled:!E||!k?.id,isStreaming:I.status==="submitted"||I.status==="streaming",placeholder:E?"Ask anything or @ for context":"Select a model to start chatting",children:[_.jsx(to,{selectedGatewayId:k?.id,onGatewayChange:y,placeholder:"Agent",variant:"borderless"}),_.jsx(Un,{selectedModel:E??void 0,onModelChange:$,placeholder:"Model",variant:"borderless"}),_.jsx(oa,{messages:I.messages})]})]})})]}),e[68]=H,e[69]=I,e[70]=j,e[71]=y,e[72]=$,e[73]=F,e[74]=i,e[75]=k,e[76]=E,e[77]=u,e[78]=a,e[79]=G,e[80]=h,e[81]=ce):ce=e[81];let le;return e[82]!==se||e[83]!==ce?(le=_.jsx(Uh,{children:_.jsxs(pe,{children:[se,ce]})}),e[82]=se,e[83]=ce,e[84]=le):le=e[84],le}function yg(e,t){return e.id===t.gatewayId}function xg(e,t){return e.id===t.id&&e.connectionId===t.connectionId}function op(){const e=ge.c(3),t=Ws();let n;e[0]===Symbol.for("react.memo_cache_sentinel")?(n=_.jsx(z.Suspense,{fallback:_.jsx(Ks,{}),children:_.jsx(mg,{})}),e[0]=n):n=e[0];let o;return e[1]!==t.location.pathname?(o=_.jsx(qs,{children:n},t.location.pathname),e[1]=t.location.pathname,e[2]=o):o=e[2],o}export{op as default};
@@ -1 +0,0 @@
1
- import{a3 as u,ap as s}from"./index-DZBFXaT_.js";function o(e,r){return u(e,s,r)}export{o as u};