@agent-spaces/server 0.1.2 → 0.2.1
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.
- package/dist/adapters/claude-code-runtime/index.js +4 -1
- package/dist/adapters/git.js +2 -21
- package/dist/agents/issue-agent-runner.js +35 -21
- package/dist/agents/issue-task-controller.js +120 -73
- package/dist/agents/planner-agent.js +9 -12
- package/dist/app.js +10 -0
- package/dist/hooks/agent-hooks.js +5 -8
- package/dist/package.json +1 -1
- package/dist/routes/agent.js +40 -17
- package/dist/routes/channel.js +4 -1
- package/dist/routes/command.js +108 -0
- package/dist/routes/folder.js +44 -7
- package/dist/routes/issue.js +57 -23
- package/dist/routes/mcp.js +50 -0
- package/dist/routes/skill.js +57 -0
- package/dist/routes/subscription.js +49 -0
- package/dist/routes/task.js +16 -1
- package/dist/routes/workflow.js +63 -0
- package/dist/routes/workspace.js +2 -21
- package/dist/services/agent.js +140 -76
- package/dist/services/builtin-tools.js +72 -0
- package/dist/services/channel.js +5 -5
- package/dist/services/command-process-manager.js +136 -0
- package/dist/services/command.js +48 -0
- package/dist/services/issue.js +5 -6
- package/dist/services/mcp.js +120 -0
- package/dist/services/notification-hub/bot-commands.js +48 -16
- package/dist/services/notification-hub/helpers.js +12 -0
- package/dist/services/pty.js +10 -3
- package/dist/services/skill.js +171 -0
- package/dist/services/subscription/aicode.js +45 -0
- package/dist/services/subscription/base.js +3 -0
- package/dist/services/subscription/index.js +20 -0
- package/dist/services/subscription/minimax.js +60 -0
- package/dist/services/subscription/zhipu.js +39 -0
- package/dist/services/workflow.js +203 -0
- package/dist/services/workspace.js +0 -1
- package/dist/storage/command-store.js +17 -0
- package/dist/storage/subscription-store.js +44 -0
- package/dist/storage/workflow-store.js +40 -0
- package/dist/web/404.html +1 -1
- package/dist/web/__next.__PAGE__.txt +4 -4
- package/dist/web/__next._full.txt +22 -21
- package/dist/web/__next._head.txt +4 -4
- package/dist/web/__next._index.txt +9 -8
- package/dist/web/__next._tree.txt +2 -2
- package/dist/web/_next/static/MpJepsgfsHGGcc7rwFU8Y/_buildManifest.js +11 -0
- package/dist/web/_next/static/chunks/0-245kun-watp.js +2 -0
- package/dist/web/_next/static/chunks/0-ca_fo-yp3~z.js +1 -0
- package/dist/web/_next/static/chunks/0-vgd3j-zh3m8.js +2 -0
- package/dist/web/_next/static/chunks/0.4.g.8yf4rs0.js +3 -0
- package/dist/web/_next/static/chunks/02m_-ngl9w8co.js +1 -0
- package/dist/web/_next/static/chunks/03jbh7ud0jw~g.js +1 -0
- package/dist/web/_next/static/chunks/07kqxmubf5dua.js +1 -0
- package/dist/web/_next/static/chunks/088q-5_51dsrw.js +1 -0
- package/dist/web/_next/static/chunks/09_ki3dc5cfwv.css +1 -0
- package/dist/web/_next/static/chunks/09jryrjps0vl2.js +1 -0
- package/dist/web/_next/static/chunks/0b2tump5duj9j.js +1 -0
- package/dist/web/_next/static/chunks/0dctkv_2d2r0g.js +8 -0
- package/dist/web/_next/static/chunks/0efgv37kxyht8.js +1 -0
- package/dist/web/_next/static/chunks/0fwvdy-ml8wpk.js +1 -0
- package/dist/web/_next/static/chunks/0g4vm6.v0o_lt.js +1 -0
- package/dist/web/_next/static/chunks/0g_b4t~000.o~.js +179 -0
- package/dist/web/_next/static/chunks/0gyede80jpy3n.js +4 -0
- package/dist/web/_next/static/chunks/0h256h-tu4e0r.js +2 -0
- package/dist/web/_next/static/chunks/0ib18ul605e~a.js +1 -0
- package/dist/web/_next/static/chunks/0j1g_rd9t5ot1.js +1 -0
- package/dist/web/_next/static/chunks/0jn~llaqcxo4q.js +1 -0
- package/dist/web/_next/static/chunks/0jvmviuftg5e2.css +1 -0
- package/dist/web/_next/static/chunks/0lb8l2~6s_owo.js +1 -0
- package/dist/web/_next/static/chunks/0ni5ot2603_28.js +1 -0
- package/dist/web/_next/static/chunks/0pep4mkvt3.rh.js +31 -0
- package/dist/web/_next/static/chunks/0pq2670_ezbcj.js +1 -0
- package/dist/web/_next/static/chunks/0q_scqkk9.t53.js +2 -0
- package/dist/web/_next/static/chunks/0rrdur.v1a5r7.js +1 -0
- package/dist/web/_next/static/chunks/0spo.tmfeas-o.js +1 -0
- package/dist/web/_next/static/chunks/0tta_56qj1z8-.js +1 -0
- package/dist/web/_next/static/chunks/0u88ij9dqqh~-.js +1 -0
- package/dist/web/_next/static/chunks/0zl19l5tuoppw.js +1 -0
- package/dist/web/_next/static/chunks/11n16hogah-5..js +1 -0
- package/dist/web/_next/static/chunks/1250wo~-5dgyx.js +1 -0
- package/dist/web/_next/static/chunks/14n8i2xz4_y-e.js +1 -0
- package/dist/web/_next/static/chunks/160ji-.dfvm20.js +1 -0
- package/dist/web/_next/static/chunks/turbopack-0lxiiw.jhevml.js +1 -0
- package/dist/web/_next/static/media/favicon.0~ekuj.zhggpa.ico +0 -0
- package/dist/web/_not-found/__next._full.txt +24 -19
- package/dist/web/_not-found/__next._head.txt +4 -4
- package/dist/web/_not-found/__next._index.txt +9 -8
- package/dist/web/_not-found/__next._not-found.__PAGE__.txt +2 -2
- package/dist/web/_not-found/__next._not-found.txt +3 -3
- package/dist/web/_not-found/__next._tree.txt +2 -2
- package/dist/web/_not-found.html +1 -1
- package/dist/web/_not-found.txt +24 -19
- package/dist/web/apple-touch-icon.png +0 -0
- package/dist/web/favicon.ico +0 -0
- package/dist/web/icon-192.png +0 -0
- package/dist/web/icon-512.png +0 -0
- package/dist/web/index.html +1 -1
- package/dist/web/index.txt +22 -21
- package/dist/web/login/__next._full.txt +24 -23
- package/dist/web/login/__next._head.txt +4 -4
- package/dist/web/login/__next._index.txt +9 -8
- package/dist/web/login/__next._tree.txt +2 -2
- package/dist/web/login/__next.login.__PAGE__.txt +4 -4
- package/dist/web/login/__next.login.txt +3 -3
- package/dist/web/login.html +1 -1
- package/dist/web/login.txt +24 -23
- package/dist/web/settings/__next._full.txt +34 -0
- package/dist/web/settings/__next._head.txt +6 -0
- package/dist/web/settings/__next._index.txt +11 -0
- package/dist/web/settings/__next._tree.txt +8 -0
- package/dist/web/settings/__next.settings.__PAGE__.txt +9 -0
- package/dist/web/settings/__next.settings.txt +7 -0
- package/dist/web/settings/agents/__next._full.txt +38 -0
- package/dist/web/settings/agents/__next._head.txt +6 -0
- package/dist/web/settings/agents/__next._index.txt +11 -0
- package/dist/web/settings/agents/__next._tree.txt +8 -0
- package/dist/web/settings/agents/__next.settings.agents.__PAGE__.txt +9 -0
- package/dist/web/settings/agents/__next.settings.agents.txt +5 -0
- package/dist/web/settings/agents/__next.settings.txt +7 -0
- package/dist/web/settings/agents.html +1 -0
- package/dist/web/settings/agents.txt +38 -0
- package/dist/web/settings/mcps/__next._full.txt +38 -0
- package/dist/web/settings/mcps/__next._head.txt +6 -0
- package/dist/web/settings/mcps/__next._index.txt +11 -0
- package/dist/web/settings/mcps/__next._tree.txt +8 -0
- package/dist/web/settings/mcps/__next.settings.mcps.__PAGE__.txt +9 -0
- package/dist/web/settings/mcps/__next.settings.mcps.txt +5 -0
- package/dist/web/settings/mcps/__next.settings.txt +7 -0
- package/dist/web/settings/mcps.html +1 -0
- package/dist/web/settings/mcps.txt +38 -0
- package/dist/web/settings/models/__next._full.txt +38 -0
- package/dist/web/settings/models/__next._head.txt +6 -0
- package/dist/web/settings/models/__next._index.txt +11 -0
- package/dist/web/settings/models/__next._tree.txt +8 -0
- package/dist/web/settings/models/__next.settings.models.__PAGE__.txt +9 -0
- package/dist/web/settings/models/__next.settings.models.txt +5 -0
- package/dist/web/settings/models/__next.settings.txt +7 -0
- package/dist/web/settings/models.html +1 -0
- package/dist/web/settings/models.txt +38 -0
- package/dist/web/settings/providers/__next._full.txt +38 -0
- package/dist/web/settings/providers/__next._head.txt +6 -0
- package/dist/web/settings/providers/__next._index.txt +11 -0
- package/dist/web/settings/providers/__next._tree.txt +8 -0
- package/dist/web/settings/providers/__next.settings.providers.__PAGE__.txt +9 -0
- package/dist/web/settings/providers/__next.settings.providers.txt +5 -0
- package/dist/web/settings/providers/__next.settings.txt +7 -0
- package/dist/web/settings/providers.html +1 -0
- package/dist/web/settings/providers.txt +38 -0
- package/dist/web/settings/skills/__next._full.txt +38 -0
- package/dist/web/settings/skills/__next._head.txt +6 -0
- package/dist/web/settings/skills/__next._index.txt +11 -0
- package/dist/web/settings/skills/__next._tree.txt +8 -0
- package/dist/web/settings/skills/__next.settings.skills.__PAGE__.txt +9 -0
- package/dist/web/settings/skills/__next.settings.skills.txt +5 -0
- package/dist/web/settings/skills/__next.settings.txt +7 -0
- package/dist/web/settings/skills.html +1 -0
- package/dist/web/settings/skills.txt +38 -0
- package/dist/web/settings.html +1 -0
- package/dist/web/settings.txt +34 -0
- package/dist/web/workflows/__next._full.txt +35 -0
- package/dist/web/workflows/__next._head.txt +6 -0
- package/dist/web/workflows/__next._index.txt +11 -0
- package/dist/web/workflows/__next._tree.txt +9 -0
- package/dist/web/workflows/__next.workflows.__PAGE__.txt +10 -0
- package/dist/web/workflows/__next.workflows.txt +5 -0
- package/dist/web/workflows.html +1 -0
- package/dist/web/workflows.txt +35 -0
- package/dist/web/workspace/_/__next._full.txt +25 -20
- package/dist/web/workspace/_/__next._head.txt +4 -4
- package/dist/web/workspace/_/__next._index.txt +9 -8
- package/dist/web/workspace/_/__next._tree.txt +2 -2
- package/dist/web/workspace/_/__next.workspace.$d$id.__PAGE__.txt +3 -3
- package/dist/web/workspace/_/__next.workspace.$d$id.txt +3 -3
- package/dist/web/workspace/_/__next.workspace.txt +3 -3
- package/dist/web/workspace/_.html +1 -1
- package/dist/web/workspace/_.txt +25 -20
- package/dist/web/workspaces/__next._full.txt +24 -23
- package/dist/web/workspaces/__next._head.txt +4 -4
- package/dist/web/workspaces/__next._index.txt +9 -8
- package/dist/web/workspaces/__next._tree.txt +2 -2
- package/dist/web/workspaces/__next.workspaces.__PAGE__.txt +4 -4
- package/dist/web/workspaces/__next.workspaces.txt +3 -3
- package/dist/web/workspaces.html +1 -1
- package/dist/web/workspaces.txt +24 -23
- package/dist/ws/agent-prompt.js +84 -0
- package/dist/ws/agent-runner.js +592 -0
- package/dist/ws/handler.js +9 -1200
- package/dist/ws/html-utils.js +30 -0
- package/dist/ws/message-parts.js +498 -0
- package/package.json +3 -2
- package/dist/web/_next/static/chunks/038whpa0zpnas.js +0 -1
- package/dist/web/_next/static/chunks/06q5go~xoz5a3.js +0 -1
- package/dist/web/_next/static/chunks/095.wizobwtyg.js +0 -2
- package/dist/web/_next/static/chunks/0bfg.w~u-83h5.js +0 -1
- package/dist/web/_next/static/chunks/0ce7i6~sb20rv.js +0 -113
- package/dist/web/_next/static/chunks/0d4~pcva1uk-a.js +0 -1
- package/dist/web/_next/static/chunks/0iq70n_u75nyu.js +0 -1
- package/dist/web/_next/static/chunks/0memz-8zsbxpu.js +0 -1
- package/dist/web/_next/static/chunks/0nw~w.3~twebx.js +0 -2
- package/dist/web/_next/static/chunks/0pyytgz~5vt0f.js +0 -31
- package/dist/web/_next/static/chunks/0ujjcrz~1nq.q.css +0 -1
- package/dist/web/_next/static/chunks/0vdnx9n41dyjl.js +0 -1
- package/dist/web/_next/static/chunks/0yl4mqmxtll6g.js +0 -1
- package/dist/web/_next/static/chunks/0zcbfka5tcle3.js +0 -1
- package/dist/web/_next/static/chunks/0~eo58u99i.fr.js +0 -8
- package/dist/web/_next/static/chunks/13_2vxyccsv84.js +0 -4
- package/dist/web/_next/static/chunks/13wfs~urgxu0w.js +0 -1
- package/dist/web/_next/static/chunks/157~3c6wqkt83.js +0 -1
- package/dist/web/_next/static/chunks/15jvow_z4uq-..js +0 -1
- package/dist/web/_next/static/chunks/15v697nf~r-cy.js +0 -2
- package/dist/web/_next/static/chunks/turbopack-164~7ulq9o9yc.js +0 -1
- package/dist/web/_next/static/media/favicon.0x3dzn~oxb6tn.ico +0 -0
- package/dist/web/_next/static/owMnKmxATbtXK_J_k_uHh/_buildManifest.js +0 -21
- /package/dist/web/_next/static/{owMnKmxATbtXK_J_k_uHh → MpJepsgfsHGGcc7rwFU8Y}/_clientMiddlewareManifest.js +0 -0
- /package/dist/web/_next/static/{owMnKmxATbtXK_J_k_uHh → MpJepsgfsHGGcc7rwFU8Y}/_ssgManifest.js +0 -0
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
(globalThis.TURBOPACK||(globalThis.TURBOPACK=[])).push(["object"==typeof document?document.currentScript:void 0,322432,e=>{"use strict";var t,n,r,o,i,a,s,l,d,u,c,h,f,p,g,m,y,v=e.i(344180),x=e.i(764556);function w(e){if("string"==typeof e||"number"==typeof e)return""+e;let t="";if(Array.isArray(e))for(let n=0,r;n<e.length;n++)""!==(r=w(e[n]))&&(t+=(t&&" ")+r);else for(let n in e)e[n]&&(t+=(t&&" ")+n);return t}e.i(8890);var b={value:()=>{}};function _(){for(var e,t=0,n=arguments.length,r={};t<n;++t){if(!(e=arguments[t]+"")||e in r||/[\s.]/.test(e))throw Error("illegal type: "+e);r[e]=[]}return new E(r)}function E(e){this._=e}function k(e,t,n){for(var r=0,o=e.length;r<o;++r)if(e[r].name===t){e[r]=b,e=e.slice(0,r).concat(e.slice(r+1));break}return null!=n&&e.push({name:t,value:n}),e}function C(){}function S(e){return null==e?C:function(){return this.querySelector(e)}}function N(){return[]}function M(e){return null==e?N:function(){return this.querySelectorAll(e)}}function j(e){return function(){return this.matches(e)}}function O(e){return function(t){return t.matches(e)}}E.prototype=_.prototype={constructor:E,on:function(e,t){var n,r=this._,o=(e+"").trim().split(/^|\s+/).map(function(e){var t="",n=e.indexOf(".");if(n>=0&&(t=e.slice(n+1),e=e.slice(0,n)),e&&!r.hasOwnProperty(e))throw Error("unknown type: "+e);return{type:e,name:t}}),i=-1,a=o.length;if(arguments.length<2){for(;++i<a;)if((n=(e=o[i]).type)&&(n=function(e,t){for(var n,r=0,o=e.length;r<o;++r)if((n=e[r]).name===t)return n.value}(r[n],e.name)))return n;return}if(null!=t&&"function"!=typeof t)throw Error("invalid callback: "+t);for(;++i<a;)if(n=(e=o[i]).type)r[n]=k(r[n],e.name,t);else if(null==t)for(n in r)r[n]=k(r[n],e.name,null);return this},copy:function(){var e={},t=this._;for(var n in t)e[n]=t[n].slice();return new E(e)},call:function(e,t){if((n=arguments.length-2)>0)for(var n,r,o=Array(n),i=0;i<n;++i)o[i]=arguments[i+2];if(!this._.hasOwnProperty(e))throw Error("unknown type: "+e);for(r=this._[e],i=0,n=r.length;i<n;++i)r[i].value.apply(t,o)},apply:function(e,t,n){if(!this._.hasOwnProperty(e))throw Error("unknown type: "+e);for(var r=this._[e],o=0,i=r.length;o<i;++o)r[o].value.apply(t,n)}};var P=Array.prototype.find;function A(){return this.firstElementChild}var I=Array.prototype.filter;function z(){return Array.from(this.children)}function D(e){return Array(e.length)}function L(e,t){this.ownerDocument=e.ownerDocument,this.namespaceURI=e.namespaceURI,this._next=null,this._parent=e,this.__data__=t}function R(e,t,n,r,o,i){for(var a,s=0,l=t.length,d=i.length;s<d;++s)(a=t[s])?(a.__data__=i[s],r[s]=a):n[s]=new L(e,i[s]);for(;s<l;++s)(a=t[s])&&(o[s]=a)}function B(e,t,n,r,o,i,a){var s,l,d,u=new Map,c=t.length,h=i.length,f=Array(c);for(s=0;s<c;++s)(l=t[s])&&(f[s]=d=a.call(l,l.__data__,s,t)+"",u.has(d)?o[s]=l:u.set(d,l));for(s=0;s<h;++s)d=a.call(e,i[s],s,i)+"",(l=u.get(d))?(r[s]=l,l.__data__=i[s],u.delete(d)):n[s]=new L(e,i[s]);for(s=0;s<c;++s)(l=t[s])&&u.get(f[s])===l&&(o[s]=l)}function T(e){return e.__data__}function $(e,t){return e<t?-1:e>t?1:e>=t?0:NaN}L.prototype={constructor:L,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)}};var H="http://www.w3.org/1999/xhtml";let V={svg:"http://www.w3.org/2000/svg",xhtml:H,xlink:"http://www.w3.org/1999/xlink",xml:"http://www.w3.org/XML/1998/namespace",xmlns:"http://www.w3.org/2000/xmlns/"};function F(e){var t=e+="",n=t.indexOf(":");return n>=0&&"xmlns"!==(t=e.slice(0,n))&&(e=e.slice(n+1)),V.hasOwnProperty(t)?{space:V[t],local:e}:e}function X(e){return e.ownerDocument&&e.ownerDocument.defaultView||e.document&&e||e.defaultView}function Y(e,t){return e.style.getPropertyValue(t)||X(e).getComputedStyle(e,null).getPropertyValue(t)}function K(e){return e.trim().split(/^|\s+/)}function W(e){return e.classList||new Z(e)}function Z(e){this._node=e,this._names=K(e.getAttribute("class")||"")}function q(e,t){for(var n=W(e),r=-1,o=t.length;++r<o;)n.add(t[r])}function U(e,t){for(var n=W(e),r=-1,o=t.length;++r<o;)n.remove(t[r])}function G(){this.textContent=""}function Q(){this.innerHTML=""}function J(){this.nextSibling&&this.parentNode.appendChild(this)}function ee(){this.previousSibling&&this.parentNode.insertBefore(this,this.parentNode.firstChild)}function et(e){var t=F(e);return(t.local?function(e){return function(){return this.ownerDocument.createElementNS(e.space,e.local)}}:function(e){return function(){var t=this.ownerDocument,n=this.namespaceURI;return n===H&&t.documentElement.namespaceURI===H?t.createElement(e):t.createElementNS(n,e)}})(t)}function en(){return null}function er(){var e=this.parentNode;e&&e.removeChild(this)}function eo(){var e=this.cloneNode(!1),t=this.parentNode;return t?t.insertBefore(e,this.nextSibling):e}function ei(){var e=this.cloneNode(!0),t=this.parentNode;return t?t.insertBefore(e,this.nextSibling):e}function ea(e){return function(){var t=this.__on;if(t){for(var n,r=0,o=-1,i=t.length;r<i;++r)(n=t[r],e.type&&n.type!==e.type||n.name!==e.name)?t[++o]=n:this.removeEventListener(n.type,n.listener,n.options);++o?t.length=o:delete this.__on}}}function es(e,t,n){return function(){var r,o=this.__on,i=function(e){t.call(this,e,this.__data__)};if(o){for(var a=0,s=o.length;a<s;++a)if((r=o[a]).type===e.type&&r.name===e.name){this.removeEventListener(r.type,r.listener,r.options),this.addEventListener(r.type,r.listener=i,r.options=n),r.value=t;return}}this.addEventListener(e.type,i,n),r={type:e.type,name:e.name,value:t,listener:i,options:n},o?o.push(r):this.__on=[r]}}function el(e,t,n){var r=X(e),o=r.CustomEvent;"function"==typeof o?o=new o(t,n):(o=r.document.createEvent("Event"),n?(o.initEvent(t,n.bubbles,n.cancelable),o.detail=n.detail):o.initEvent(t,!1,!1)),e.dispatchEvent(o)}Z.prototype={add:function(e){0>this._names.indexOf(e)&&(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}};var ed=[null];function eu(e,t){this._groups=e,this._parents=t}function ec(){return new eu([[document.documentElement]],ed)}function eh(e){return"string"==typeof e?new eu([[document.querySelector(e)]],[document.documentElement]):new eu([[e]],ed)}function ef(e,t){if(e=function(e){let t;for(;t=e.sourceEvent;)e=t;return e}(e),void 0===t&&(t=e.currentTarget),t){var n=t.ownerSVGElement||t;if(n.createSVGPoint){var r=n.createSVGPoint();return r.x=e.clientX,r.y=e.clientY,[(r=r.matrixTransform(t.getScreenCTM().inverse())).x,r.y]}if(t.getBoundingClientRect){var o=t.getBoundingClientRect();return[e.clientX-o.left-t.clientLeft,e.clientY-o.top-t.clientTop]}}return[e.pageX,e.pageY]}eu.prototype=ec.prototype={constructor:eu,select:function(e){"function"!=typeof e&&(e=S(e));for(var t=this._groups,n=t.length,r=Array(n),o=0;o<n;++o)for(var i,a,s=t[o],l=s.length,d=r[o]=Array(l),u=0;u<l;++u)(i=s[u])&&(a=e.call(i,i.__data__,u,s))&&("__data__"in i&&(a.__data__=i.__data__),d[u]=a);return new eu(r,this._parents)},selectAll:function(e){if("function"==typeof e){var t;t=e,e=function(){var e;return e=t.apply(this,arguments),null==e?[]:Array.isArray(e)?e:Array.from(e)}}else e=M(e);for(var n=this._groups,r=n.length,o=[],i=[],a=0;a<r;++a)for(var s,l=n[a],d=l.length,u=0;u<d;++u)(s=l[u])&&(o.push(e.call(s,s.__data__,u,l)),i.push(s));return new eu(o,i)},selectChild:function(e){var t;return this.select(null==e?A:(t="function"==typeof e?e:O(e),function(){return P.call(this.children,t)}))},selectChildren:function(e){var t;return this.selectAll(null==e?z:(t="function"==typeof e?e:O(e),function(){return I.call(this.children,t)}))},filter:function(e){"function"!=typeof e&&(e=j(e));for(var t=this._groups,n=t.length,r=Array(n),o=0;o<n;++o)for(var i,a=t[o],s=a.length,l=r[o]=[],d=0;d<s;++d)(i=a[d])&&e.call(i,i.__data__,d,a)&&l.push(i);return new eu(r,this._parents)},data:function(e,t){if(!arguments.length)return Array.from(this,T);var n=t?B:R,r=this._parents,o=this._groups;"function"!=typeof e&&(v=e,e=function(){return v});for(var i=o.length,a=Array(i),s=Array(i),l=Array(i),d=0;d<i;++d){var u=r[d],c=o[d],h=c.length,f="object"==typeof(y=e.call(u,u&&u.__data__,d,r))&&"length"in y?y:Array.from(y),p=f.length,g=s[d]=Array(p),m=a[d]=Array(p);n(u,c,g,m,l[d]=Array(h),f,t);for(var y,v,x,w,b=0,_=0;b<p;++b)if(x=g[b]){for(b>=_&&(_=b+1);!(w=m[_])&&++_<p;);x._next=w||null}}return(a=new eu(a,r))._enter=s,a._exit=l,a},enter:function(){return new eu(this._enter||this._groups.map(D),this._parents)},exit:function(){return new eu(this._exit||this._groups.map(D),this._parents)},join:function(e,t,n){var r=this.enter(),o=this,i=this.exit();return"function"==typeof e?(r=e(r))&&(r=r.selection()):r=r.append(e+""),null!=t&&(o=t(o))&&(o=o.selection()),null==n?i.remove():n(i),r&&o?r.merge(o).order():o},merge:function(e){for(var t=e.selection?e.selection():e,n=this._groups,r=t._groups,o=n.length,i=r.length,a=Math.min(o,i),s=Array(o),l=0;l<a;++l)for(var d,u=n[l],c=r[l],h=u.length,f=s[l]=Array(h),p=0;p<h;++p)(d=u[p]||c[p])&&(f[p]=d);for(;l<o;++l)s[l]=n[l];return new eu(s,this._parents)},selection:function(){return this},order:function(){for(var e=this._groups,t=-1,n=e.length;++t<n;)for(var r,o=e[t],i=o.length-1,a=o[i];--i>=0;)(r=o[i])&&(a&&4^r.compareDocumentPosition(a)&&a.parentNode.insertBefore(r,a),a=r);return this},sort:function(e){function t(t,n){return t&&n?e(t.__data__,n.__data__):!t-!n}e||(e=$);for(var n=this._groups,r=n.length,o=Array(r),i=0;i<r;++i){for(var a,s=n[i],l=s.length,d=o[i]=Array(l),u=0;u<l;++u)(a=s[u])&&(d[u]=a);d.sort(t)}return new eu(o,this._parents).order()},call:function(){var e=arguments[0];return arguments[0]=this,e.apply(null,arguments),this},nodes:function(){return Array.from(this)},node:function(){for(var e=this._groups,t=0,n=e.length;t<n;++t)for(var r=e[t],o=0,i=r.length;o<i;++o){var a=r[o];if(a)return a}return null},size:function(){let e=0;for(let t of this)++e;return e},empty:function(){return!this.node()},each:function(e){for(var t=this._groups,n=0,r=t.length;n<r;++n)for(var o,i=t[n],a=0,s=i.length;a<s;++a)(o=i[a])&&e.call(o,o.__data__,a,i);return this},attr:function(e,t){var n=F(e);if(arguments.length<2){var r=this.node();return n.local?r.getAttributeNS(n.space,n.local):r.getAttribute(n)}return this.each((null==t?n.local?function(e){return function(){this.removeAttributeNS(e.space,e.local)}}:function(e){return function(){this.removeAttribute(e)}}:"function"==typeof t?n.local?function(e,t){return function(){var n=t.apply(this,arguments);null==n?this.removeAttributeNS(e.space,e.local):this.setAttributeNS(e.space,e.local,n)}}:function(e,t){return function(){var n=t.apply(this,arguments);null==n?this.removeAttribute(e):this.setAttribute(e,n)}}:n.local?function(e,t){return function(){this.setAttributeNS(e.space,e.local,t)}}:function(e,t){return function(){this.setAttribute(e,t)}})(n,t))},style:function(e,t,n){return arguments.length>1?this.each((null==t?function(e){return function(){this.style.removeProperty(e)}}:"function"==typeof t?function(e,t,n){return function(){var r=t.apply(this,arguments);null==r?this.style.removeProperty(e):this.style.setProperty(e,r,n)}}:function(e,t,n){return function(){this.style.setProperty(e,t,n)}})(e,t,null==n?"":n)):Y(this.node(),e)},property:function(e,t){return arguments.length>1?this.each((null==t?function(e){return function(){delete this[e]}}:"function"==typeof t?function(e,t){return function(){var n=t.apply(this,arguments);null==n?delete this[e]:this[e]=n}}:function(e,t){return function(){this[e]=t}})(e,t)):this.node()[e]},classed:function(e,t){var n=K(e+"");if(arguments.length<2){for(var r=W(this.node()),o=-1,i=n.length;++o<i;)if(!r.contains(n[o]))return!1;return!0}return this.each(("function"==typeof t?function(e,t){return function(){(t.apply(this,arguments)?q:U)(this,e)}}:t?function(e){return function(){q(this,e)}}:function(e){return function(){U(this,e)}})(n,t))},text:function(e){return arguments.length?this.each(null==e?G:("function"==typeof e?function(e){return function(){var t=e.apply(this,arguments);this.textContent=null==t?"":t}}:function(e){return function(){this.textContent=e}})(e)):this.node().textContent},html:function(e){return arguments.length?this.each(null==e?Q:("function"==typeof e?function(e){return function(){var t=e.apply(this,arguments);this.innerHTML=null==t?"":t}}:function(e){return function(){this.innerHTML=e}})(e)):this.node().innerHTML},raise:function(){return this.each(J)},lower:function(){return this.each(ee)},append:function(e){var t="function"==typeof e?e:et(e);return this.select(function(){return this.appendChild(t.apply(this,arguments))})},insert:function(e,t){var n="function"==typeof e?e:et(e),r=null==t?en:"function"==typeof t?t:S(t);return this.select(function(){return this.insertBefore(n.apply(this,arguments),r.apply(this,arguments)||null)})},remove:function(){return this.each(er)},clone:function(e){return this.select(e?ei:eo)},datum:function(e){return arguments.length?this.property("__data__",e):this.node().__data__},on:function(e,t,n){var r,o,i=(e+"").trim().split(/^|\s+/).map(function(e){var t="",n=e.indexOf(".");return n>=0&&(t=e.slice(n+1),e=e.slice(0,n)),{type:e,name:t}}),a=i.length;if(arguments.length<2){var s=this.node().__on;if(s){for(var l,d=0,u=s.length;d<u;++d)for(r=0,l=s[d];r<a;++r)if((o=i[r]).type===l.type&&o.name===l.name)return l.value}return}for(r=0,s=t?es:ea;r<a;++r)this.each(s(i[r],t,n));return this},dispatch:function(e,t){return this.each(("function"==typeof t?function(e,t){return function(){return el(this,e,t.apply(this,arguments))}}:function(e,t){return function(){return el(this,e,t)}})(e,t))},[Symbol.iterator]:function*(){for(var e=this._groups,t=0,n=e.length;t<n;++t)for(var r,o=e[t],i=0,a=o.length;i<a;++i)(r=o[i])&&(yield r)}};let ep={passive:!1},eg={capture:!0,passive:!1};function em(e){e.stopImmediatePropagation()}function ey(e){e.preventDefault(),e.stopImmediatePropagation()}function ev(e){var t=e.document.documentElement,n=eh(e).on("dragstart.drag",ey,eg);"onselectstart"in t?n.on("selectstart.drag",ey,eg):(t.__noselect=t.style.MozUserSelect,t.style.MozUserSelect="none")}function ex(e,t){var n=e.document.documentElement,r=eh(e).on("dragstart.drag",null);t&&(r.on("click.drag",ey,eg),setTimeout(function(){r.on("click.drag",null)},0)),"onselectstart"in n?r.on("selectstart.drag",null):(n.style.MozUserSelect=n.__noselect,delete n.__noselect)}let ew=e=>()=>e;function eb(e,{sourceEvent:t,subject:n,target:r,identifier:o,active:i,x:a,y:s,dx:l,dy:d,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:r,enumerable:!0,configurable:!0},identifier:{value:o,enumerable:!0,configurable:!0},active:{value:i,enumerable:!0,configurable:!0},x:{value:a,enumerable:!0,configurable:!0},y:{value:s,enumerable:!0,configurable:!0},dx:{value:l,enumerable:!0,configurable:!0},dy:{value:d,enumerable:!0,configurable:!0},_:{value:u}})}function e_(e){return!e.ctrlKey&&!e.button}function eE(){return this.parentNode}function ek(e,t){return null==t?{x:e.x,y:e.y}:t}function eC(){return navigator.maxTouchPoints||"ontouchstart"in this}function eS(){var e,t,n,r,o=e_,i=eE,a=ek,s=eC,l={},d=_("start","drag","end"),u=0,c=0;function h(e){e.on("mousedown.drag",f).filter(s).on("touchstart.drag",m).on("touchmove.drag",y,ep).on("touchend.drag touchcancel.drag",v).style("touch-action","none").style("-webkit-tap-highlight-color","rgba(0,0,0,0)")}function f(a,s){if(!r&&o.call(this,a,s)){var l=x(this,i.call(this,a,s),a,s,"mouse");l&&(eh(a.view).on("mousemove.drag",p,eg).on("mouseup.drag",g,eg),ev(a.view),em(a),n=!1,e=a.clientX,t=a.clientY,l("start",a))}}function p(r){if(ey(r),!n){var o=r.clientX-e,i=r.clientY-t;n=o*o+i*i>c}l.mouse("drag",r)}function g(e){eh(e.view).on("mousemove.drag mouseup.drag",null),ex(e.view,n),ey(e),l.mouse("end",e)}function m(e,t){if(o.call(this,e,t)){var n,r,a=e.changedTouches,s=i.call(this,e,t),l=a.length;for(n=0;n<l;++n)(r=x(this,s,e,t,a[n].identifier,a[n]))&&(em(e),r("start",e,a[n]))}}function y(e){var t,n,r=e.changedTouches,o=r.length;for(t=0;t<o;++t)(n=l[r[t].identifier])&&(ey(e),n("drag",e,r[t]))}function v(e){var t,n,o=e.changedTouches,i=o.length;for(r&&clearTimeout(r),r=setTimeout(function(){r=null},500),t=0;t<i;++t)(n=l[o[t].identifier])&&(em(e),n("end",e,o[t]))}function x(e,t,n,r,o,i){var s,c,f,p=d.copy(),g=ef(i||n,t);if(null!=(f=a.call(e,new eb("beforestart",{sourceEvent:n,target:h,identifier:o,active:u,x:g[0],y:g[1],dx:0,dy:0,dispatch:p}),r)))return s=f.x-g[0]||0,c=f.y-g[1]||0,function n(i,a,d){var m,y=g;switch(i){case"start":l[o]=n,m=u++;break;case"end":delete l[o],--u;case"drag":g=ef(d||a,t),m=u}p.call(i,e,new eb(i,{sourceEvent:a,subject:f,target:h,identifier:o,active:m,x:g[0]+s,y:g[1]+c,dx:g[0]-y[0],dy:g[1]-y[1],dispatch:p}),r)}}return h.filter=function(e){return arguments.length?(o="function"==typeof e?e:ew(!!e),h):o},h.container=function(e){return arguments.length?(i="function"==typeof e?e:ew(e),h):i},h.subject=function(e){return arguments.length?(a="function"==typeof e?e:ew(e),h):a},h.touchable=function(e){return arguments.length?(s="function"==typeof e?e:ew(!!e),h):s},h.on=function(){var e=d.on.apply(d,arguments);return e===d?h:e},h.clickDistance=function(e){return arguments.length?(c=(e*=1)*e,h):Math.sqrt(c)},h}function eN(e){return((e=Math.exp(e))+1/e)/2}eb.prototype.on=function(){var e=this._.on.apply(this._,arguments);return e===this._?this:e};let eM=function e(t,n,r){function o(e,o){var i,a,s=e[0],l=e[1],d=e[2],u=o[0],c=o[1],h=o[2],f=u-s,p=c-l,g=f*f+p*p;if(g<1e-12)a=Math.log(h/d)/t,i=function(e){return[s+e*f,l+e*p,d*Math.exp(t*e*a)]};else{var m=Math.sqrt(g),y=(h*h-d*d+r*g)/(2*d*n*m),v=(h*h-d*d-r*g)/(2*h*n*m),x=Math.log(Math.sqrt(y*y+1)-y);a=(Math.log(Math.sqrt(v*v+1)-v)-x)/t,i=function(e){var r,o,i=e*a,u=eN(x),c=d/(n*m)*(u*(((r=Math.exp(2*(r=t*i+x)))-1)/(r+1))-((o=Math.exp(o=x))-1/o)/2);return[s+c*f,l+c*p,d*u/eN(t*i+x)]}}return i.duration=1e3*a*t/Math.SQRT2,i}return o.rho=function(t){var n=Math.max(.001,+t),r=n*n;return e(n,r,r*r)},o}(Math.SQRT2,2,4);var ej,eO,eP=0,eA=0,eI=0,ez=0,eD=0,eL=0,eR="object"==typeof performance&&performance.now?performance:Date,eB="object"==typeof window&&window.requestAnimationFrame?window.requestAnimationFrame.bind(window):function(e){setTimeout(e,17)};function eT(){return eD||(eB(e$),eD=eR.now()+eL)}function e$(){eD=0}function eH(){this._call=this._time=this._next=null}function eV(e,t,n){var r=new eH;return r.restart(e,t,n),r}function eF(){eD=(ez=eR.now())+eL,eP=eA=0;try{eT(),++eP;for(var e,t=ej;t;)(e=eD-t._time)>=0&&t._call.call(void 0,e),t=t._next;--eP}finally{eP=0,function(){for(var e,t,n=ej,r=1/0;n;)n._call?(r>n._time&&(r=n._time),e=n,n=n._next):(t=n._next,n._next=null,n=e?e._next=t:ej=t);eO=e,eY(r)}(),eD=0}}function eX(){var e=eR.now(),t=e-ez;t>1e3&&(eL-=t,ez=e)}function eY(e){!eP&&(eA&&(eA=clearTimeout(eA)),e-eD>24?(e<1/0&&(eA=setTimeout(eF,e-eR.now()-eL)),eI&&(eI=clearInterval(eI))):(eI||(ez=eR.now(),eI=setInterval(eX,1e3)),eP=1,eB(eF)))}function eK(e,t,n){var r=new eH;return t=null==t?0:+t,r.restart(n=>{r.stop(),e(n+t)},t,n),r}eH.prototype=eV.prototype={constructor:eH,restart:function(e,t,n){if("function"!=typeof e)throw TypeError("callback is not a function");n=(null==n?eT():+n)+(null==t?0:+t),this._next||eO===this||(eO?eO._next=this:ej=this,eO=this),this._call=e,this._time=n,eY()},stop:function(){this._call&&(this._call=null,this._time=1/0,eY())}};var eW=_("start","end","cancel","interrupt"),eZ=[];function eq(e,t,n,r,o,i){var a=e.__transition;if(a){if(n in a)return}else e.__transition={};!function(e,t,n){var r,o=e.__transition;function i(l){var d,u,c,h;if(1!==n.state)return s();for(d in o)if((h=o[d]).name===n.name){if(3===h.state)return eK(i);4===h.state?(h.state=6,h.timer.stop(),h.on.call("interrupt",e,e.__data__,h.index,h.group),delete o[d]):+d<t&&(h.state=6,h.timer.stop(),h.on.call("cancel",e,e.__data__,h.index,h.group),delete o[d])}if(eK(function(){3===n.state&&(n.state=4,n.timer.restart(a,n.delay,n.time),a(l))}),n.state=2,n.on.call("start",e,e.__data__,n.index,n.group),2===n.state){for(d=0,n.state=3,r=Array(c=n.tween.length),u=-1;d<c;++d)(h=n.tween[d].value.call(e,e.__data__,n.index,n.group))&&(r[++u]=h);r.length=u+1}}function a(t){for(var o=t<n.duration?n.ease.call(null,t/n.duration):(n.timer.restart(s),n.state=5,1),i=-1,a=r.length;++i<a;)r[i].call(e,o);5===n.state&&(n.on.call("end",e,e.__data__,n.index,n.group),s())}function s(){for(var r in n.state=6,n.timer.stop(),delete o[t],o)return;delete e.__transition}o[t]=n,n.timer=eV(function(e){n.state=1,n.timer.restart(i,n.delay,n.time),n.delay<=e&&i(e-n.delay)},0,n.time)}(e,n,{name:t,index:r,group:o,on:eW,tween:eZ,time:i.time,delay:i.delay,duration:i.duration,ease:i.ease,timer:null,state:0})}function eU(e,t){var n=eQ(e,t);if(n.state>0)throw Error("too late; already scheduled");return n}function eG(e,t){var n=eQ(e,t);if(n.state>3)throw Error("too late; already running");return n}function eQ(e,t){var n=e.__transition;if(!n||!(n=n[t]))throw Error("transition not found");return n}function eJ(e,t){var n,r,o,i=e.__transition,a=!0;if(i){for(o in t=null==t?null:t+"",i){if((n=i[o]).name!==t){a=!1;continue}r=n.state>2&&n.state<5,n.state=6,n.timer.stop(),n.on.call(r?"interrupt":"cancel",e,e.__data__,n.index,n.group),delete i[o]}a&&delete e.__transition}}var e0=e.i(842541),e1=180/Math.PI,e2={translateX:0,translateY:0,rotate:0,skewX:0,scaleX:1,scaleY:1};function e3(e,t,n,r,o,i){var a,s,l;return(a=Math.sqrt(e*e+t*t))&&(e/=a,t/=a),(l=e*n+t*r)&&(n-=e*l,r-=t*l),(s=Math.sqrt(n*n+r*r))&&(n/=s,r/=s,l/=s),e*r<t*n&&(e=-e,t=-t,l=-l,a=-a),{translateX:o,translateY:i,rotate:Math.atan2(t,e)*e1,skewX:Math.atan(l)*e1,scaleX:a,scaleY:s}}function e5(e,t,n,r){function o(e){return e.length?e.pop()+" ":""}return function(i,a){var s,l,d,u,c=[],h=[];return i=e(i),a=e(a),!function(e,r,o,i,a,s){if(e!==o||r!==i){var l=a.push("translate(",null,t,null,n);s.push({i:l-4,x:(0,e0.default)(e,o)},{i:l-2,x:(0,e0.default)(r,i)})}else(o||i)&&a.push("translate("+o+t+i+n)}(i.translateX,i.translateY,a.translateX,a.translateY,c,h),s=i.rotate,l=a.rotate,s!==l?(s-l>180?l+=360:l-s>180&&(s+=360),h.push({i:c.push(o(c)+"rotate(",null,r)-2,x:(0,e0.default)(s,l)})):l&&c.push(o(c)+"rotate("+l+r),d=i.skewX,u=a.skewX,d!==u?h.push({i:c.push(o(c)+"skewX(",null,r)-2,x:(0,e0.default)(d,u)}):u&&c.push(o(c)+"skewX("+u+r),!function(e,t,n,r,i,a){if(e!==n||t!==r){var s=i.push(o(i)+"scale(",null,",",null,")");a.push({i:s-4,x:(0,e0.default)(e,n)},{i:s-2,x:(0,e0.default)(t,r)})}else(1!==n||1!==r)&&i.push(o(i)+"scale("+n+","+r+")")}(i.scaleX,i.scaleY,a.scaleX,a.scaleY,c,h),i=a=null,function(e){for(var t,n=-1,r=h.length;++n<r;)c[(t=h[n]).i]=t.x(e);return c.join("")}}}var e4=e5(function(e){let t=new("function"==typeof DOMMatrix?DOMMatrix:WebKitCSSMatrix)(e+"");return t.isIdentity?e2:e3(t.a,t.b,t.c,t.d,t.e,t.f)},"px, ","px)","deg)"),e6=e5(function(e){return null==e?e2:(d||(d=document.createElementNS("http://www.w3.org/2000/svg","g")),d.setAttribute("transform",e),e=d.transform.baseVal.consolidate())?e3((e=e.matrix).a,e.b,e.c,e.d,e.e,e.f):e2},", ",")",")");function e7(e,t,n){var r=e._id;return e.each(function(){var e=eG(this,r);(e.value||(e.value={}))[t]=n.apply(this,arguments)}),function(e){return eQ(e,r).value[t]}}var e8=e.i(161610),e9=e.i(77075),te=e.i(145665),te=te,tt=e.i(647483),tt=tt;function tn(e,t){var n;return("number"==typeof t?e9.interpolateNumber:t instanceof e8.color?te.default:(n=(0,e8.color)(t))?(t=n,te.default):tt.default)(e,t)}var tr=ec.prototype.constructor;function to(e){return function(){this.style.removeProperty(e)}}var ti=0;function ta(e,t,n,r){this._groups=e,this._parents=t,this._name=n,this._id=r}var ts=ec.prototype;ta.prototype=(function(e){return ec().transition(e)}).prototype={constructor:ta,select:function(e){var t=this._name,n=this._id;"function"!=typeof e&&(e=S(e));for(var r=this._groups,o=r.length,i=Array(o),a=0;a<o;++a)for(var s,l,d=r[a],u=d.length,c=i[a]=Array(u),h=0;h<u;++h)(s=d[h])&&(l=e.call(s,s.__data__,h,d))&&("__data__"in s&&(l.__data__=s.__data__),c[h]=l,eq(c[h],t,n,h,c,eQ(s,n)));return new ta(i,this._parents,t,n)},selectAll:function(e){var t=this._name,n=this._id;"function"!=typeof e&&(e=M(e));for(var r=this._groups,o=r.length,i=[],a=[],s=0;s<o;++s)for(var l,d=r[s],u=d.length,c=0;c<u;++c)if(l=d[c]){for(var h,f=e.call(l,l.__data__,c,d),p=eQ(l,n),g=0,m=f.length;g<m;++g)(h=f[g])&&eq(h,t,n,g,f,p);i.push(f),a.push(l)}return new ta(i,a,t,n)},selectChild:ts.selectChild,selectChildren:ts.selectChildren,filter:function(e){"function"!=typeof e&&(e=j(e));for(var t=this._groups,n=t.length,r=Array(n),o=0;o<n;++o)for(var i,a=t[o],s=a.length,l=r[o]=[],d=0;d<s;++d)(i=a[d])&&e.call(i,i.__data__,d,a)&&l.push(i);return new ta(r,this._parents,this._name,this._id)},merge:function(e){if(e._id!==this._id)throw Error();for(var t=this._groups,n=e._groups,r=t.length,o=n.length,i=Math.min(r,o),a=Array(r),s=0;s<i;++s)for(var l,d=t[s],u=n[s],c=d.length,h=a[s]=Array(c),f=0;f<c;++f)(l=d[f]||u[f])&&(h[f]=l);for(;s<r;++s)a[s]=t[s];return new ta(a,this._parents,this._name,this._id)},selection:function(){return new tr(this._groups,this._parents)},transition:function(){for(var e=this._name,t=this._id,n=++ti,r=this._groups,o=r.length,i=0;i<o;++i)for(var a,s=r[i],l=s.length,d=0;d<l;++d)if(a=s[d]){var u=eQ(a,t);eq(a,e,n,d,s,{time:u.time+u.delay+u.duration,delay:0,duration:u.duration,ease:u.ease})}return new ta(r,this._parents,e,n)},call:ts.call,nodes:ts.nodes,node:ts.node,size:ts.size,empty:ts.empty,each:ts.each,on:function(e,t){var n,r,o,i,a,s,l=this._id;return arguments.length<2?eQ(this.node(),l).on.on(e):this.each((n=l,r=e,o=t,s=(r+"").trim().split(/^|\s+/).every(function(e){var t=e.indexOf(".");return t>=0&&(e=e.slice(0,t)),!e||"start"===e})?eU:eG,function(){var e=s(this,n),t=e.on;t!==i&&(a=(i=t).copy()).on(r,o),e.on=a}))},attr:function(e,t){var n=F(e),r="transform"===n?e6:tn;return this.attrTween(e,"function"==typeof t?(n.local?function(e,t,n){var r,o,i;return function(){var a,s,l=n(this);return null==l?void this.removeAttributeNS(e.space,e.local):(a=this.getAttributeNS(e.space,e.local))===(s=l+"")?null:a===r&&s===o?i:(o=s,i=t(r=a,l))}}:function(e,t,n){var r,o,i;return function(){var a,s,l=n(this);return null==l?void this.removeAttribute(e):(a=this.getAttribute(e))===(s=l+"")?null:a===r&&s===o?i:(o=s,i=t(r=a,l))}})(n,r,e7(this,"attr."+e,t)):null==t?(n.local?function(e){return function(){this.removeAttributeNS(e.space,e.local)}}:function(e){return function(){this.removeAttribute(e)}})(n):(n.local?function(e,t,n){var r,o,i=n+"";return function(){var a=this.getAttributeNS(e.space,e.local);return a===i?null:a===r?o:o=t(r=a,n)}}:function(e,t,n){var r,o,i=n+"";return function(){var a=this.getAttribute(e);return a===i?null:a===r?o:o=t(r=a,n)}})(n,r,t))},attrTween:function(e,t){var n="attr."+e;if(arguments.length<2)return(n=this.tween(n))&&n._value;if(null==t)return this.tween(n,null);if("function"!=typeof t)throw Error();var r=F(e);return this.tween(n,(r.local?function(e,t){var n,r;function o(){var o=t.apply(this,arguments);return o!==r&&(n=(r=o)&&function(t){this.setAttributeNS(e.space,e.local,o.call(this,t))}),n}return o._value=t,o}:function(e,t){var n,r;function o(){var o=t.apply(this,arguments);return o!==r&&(n=(r=o)&&function(t){this.setAttribute(e,o.call(this,t))}),n}return o._value=t,o})(r,t))},style:function(e,t,n){var r,o,i,a,s,l,d,u,c,h,f,p,g,m,y,v,x,w,b,_,E,k="transform"==(e+="")?e4:tn;return null==t?this.styleTween(e,(r=e,function(){var e=Y(this,r),t=(this.style.removeProperty(r),Y(this,r));return e===t?null:e===o&&t===i?a:a=k(o=e,i=t)})).on("end.style."+e,to(e)):"function"==typeof t?this.styleTween(e,(s=e,l=e7(this,"style."+e,t),function(){var e=Y(this,s),t=l(this),n=t+"";return null==t&&(this.style.removeProperty(s),n=t=Y(this,s)),e===n?null:e===d&&n===u?c:(u=n,c=k(d=e,t))})).each((h=this._id,x="end."+(v="style."+(f=e)),function(){var e=eG(this,h),t=e.on,n=null==e.value[v]?y||(y=to(f)):void 0;(t!==p||m!==n)&&(g=(p=t).copy()).on(x,m=n),e.on=g})):this.styleTween(e,(w=e,E=t+"",function(){var e=Y(this,w);return e===E?null:e===b?_:_=k(b=e,t)}),n).on("end.style."+e,null)},styleTween:function(e,t,n){var r="style."+(e+="");if(arguments.length<2)return(r=this.tween(r))&&r._value;if(null==t)return this.tween(r,null);if("function"!=typeof t)throw Error();return this.tween(r,function(e,t,n){var r,o;function i(){var i=t.apply(this,arguments);return i!==o&&(r=(o=i)&&function(t){this.style.setProperty(e,i.call(this,t),n)}),r}return i._value=t,i}(e,t,null==n?"":n))},text:function(e){var t,n;return this.tween("text","function"==typeof e?(t=e7(this,"text",e),function(){var e=t(this);this.textContent=null==e?"":e}):(n=null==e?"":e+"",function(){this.textContent=n}))},textTween:function(e){var t="text";if(arguments.length<1)return(t=this.tween(t))&&t._value;if(null==e)return this.tween(t,null);if("function"!=typeof e)throw Error();return this.tween(t,function(e){var t,n;function r(){var r=e.apply(this,arguments);return r!==n&&(t=(n=r)&&function(e){this.textContent=r.call(this,e)}),t}return r._value=e,r}(e))},remove:function(){var e;return this.on("end.remove",(e=this._id,function(){var t=this.parentNode;for(var n in this.__transition)if(+n!==e)return;t&&t.removeChild(this)}))},tween:function(e,t){var n=this._id;if(e+="",arguments.length<2){for(var r,o=eQ(this.node(),n).tween,i=0,a=o.length;i<a;++i)if((r=o[i]).name===e)return r.value;return null}return this.each((null==t?function(e,t){var n,r;return function(){var o=eG(this,e),i=o.tween;if(i!==n){r=n=i;for(var a=0,s=r.length;a<s;++a)if(r[a].name===t){(r=r.slice()).splice(a,1);break}}o.tween=r}}:function(e,t,n){var r,o;if("function"!=typeof n)throw Error();return function(){var i=eG(this,e),a=i.tween;if(a!==r){o=(r=a).slice();for(var s={name:t,value:n},l=0,d=o.length;l<d;++l)if(o[l].name===t){o[l]=s;break}l===d&&o.push(s)}i.tween=o}})(n,e,t))},delay:function(e){var t=this._id;return arguments.length?this.each(("function"==typeof e?function(e,t){return function(){eU(this,e).delay=+t.apply(this,arguments)}}:function(e,t){return t*=1,function(){eU(this,e).delay=t}})(t,e)):eQ(this.node(),t).delay},duration:function(e){var t=this._id;return arguments.length?this.each(("function"==typeof e?function(e,t){return function(){eG(this,e).duration=+t.apply(this,arguments)}}:function(e,t){return t*=1,function(){eG(this,e).duration=t}})(t,e)):eQ(this.node(),t).duration},ease:function(e){var t=this._id;return arguments.length?this.each(function(e,t){if("function"!=typeof t)throw Error();return function(){eG(this,e).ease=t}}(t,e)):eQ(this.node(),t).ease},easeVarying:function(e){var t;if("function"!=typeof e)throw Error();return this.each((t=this._id,function(){var n=e.apply(this,arguments);if("function"!=typeof n)throw Error();eG(this,t).ease=n}))},end:function(){var e,t,n=this,r=n._id,o=n.size();return new Promise(function(i,a){var s={value:a},l={value:function(){0==--o&&i()}};n.each(function(){var n=eG(this,r),o=n.on;o!==e&&((t=(e=o).copy())._.cancel.push(s),t._.interrupt.push(s),t._.end.push(l)),n.on=t}),0===o&&i()})},[Symbol.iterator]:ts[Symbol.iterator]};var tl={time:null,delay:0,duration:250,ease:function(e){return((e*=2)<=1?e*e*e:(e-=2)*e*e+2)/2}};ec.prototype.interrupt=function(e){return this.each(function(){eJ(this,e)})},ec.prototype.transition=function(e){var t,n;e instanceof ta?(t=e._id,e=e._name):(t=++ti,(n=tl).time=eT(),e=null==e?null:e+"");for(var r=this._groups,o=r.length,i=0;i<o;++i)for(var a,s=r[i],l=s.length,d=0;d<l;++d)(a=s[d])&&eq(a,e,t,d,s,n||function(e,t){for(var n;!(n=e.__transition)||!(n=n[t]);)if(!(e=e.parentNode))throw Error(`transition ${t} not found`);return n}(a,t));return new ta(r,this._parents,e,t)};let td=e=>()=>e;function tu(e,{sourceEvent:t,target:n,transform:r,dispatch:o}){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:r,enumerable:!0,configurable:!0},_:{value:o}})}function tc(e,t,n){this.k=e,this.x=t,this.y=n}tc.prototype={constructor:tc,scale:function(e){return 1===e?this:new tc(this.k*e,this.x,this.y)},translate:function(e,t){return 0===e&0===t?this:new tc(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 th=new tc(1,0,0);function tf(e){for(;!e.__zoom;)if(!(e=e.parentNode))return th;return e.__zoom}function tp(e){e.stopImmediatePropagation()}function tg(e){e.preventDefault(),e.stopImmediatePropagation()}function tm(e){return(!e.ctrlKey||"wheel"===e.type)&&!e.button}function ty(){var e=this;return e instanceof SVGElement?(e=e.ownerSVGElement||e).hasAttribute("viewBox")?[[(e=e.viewBox.baseVal).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 tv(){return this.__zoom||th}function tx(e){return-e.deltaY*(1===e.deltaMode?.05:e.deltaMode?1:.002)*(e.ctrlKey?10:1)}function tw(){return navigator.maxTouchPoints||"ontouchstart"in this}function tb(e,t,n){var r=e.invertX(t[0][0])-n[0][0],o=e.invertX(t[1][0])-n[1][0],i=e.invertY(t[0][1])-n[0][1],a=e.invertY(t[1][1])-n[1][1];return e.translate(o>r?(r+o)/2:Math.min(0,r)||Math.max(0,o),a>i?(i+a)/2:Math.min(0,i)||Math.max(0,a))}function t_(){var e,t,n,r=tm,o=ty,i=tb,a=tx,s=tw,l=[0,1/0],d=[[-1/0,-1/0],[1/0,1/0]],u=250,c=eM,h=_("start","zoom","end"),f=0,p=10;function g(e){e.property("__zoom",tv).on("wheel.zoom",E,{passive:!1}).on("mousedown.zoom",k).on("dblclick.zoom",C).filter(s).on("touchstart.zoom",S).on("touchmove.zoom",N).on("touchend.zoom touchcancel.zoom",M).style("-webkit-tap-highlight-color","rgba(0,0,0,0)")}function m(e,t){return(t=Math.max(l[0],Math.min(l[1],t)))===e.k?e:new tc(t,e.x,e.y)}function y(e,t,n){var r=t[0]-n[0]*e.k,o=t[1]-n[1]*e.k;return r===e.x&&o===e.y?e:new tc(e.k,r,o)}function v(e){return[(+e[0][0]+ +e[1][0])/2,(+e[0][1]+ +e[1][1])/2]}function x(e,t,n,r){e.on("start.zoom",function(){w(this,arguments).event(r).start()}).on("interrupt.zoom end.zoom",function(){w(this,arguments).event(r).end()}).tween("zoom",function(){var e=arguments,i=w(this,e).event(r),a=o.apply(this,e),s=null==n?v(a):"function"==typeof n?n.apply(this,e):n,l=Math.max(a[1][0]-a[0][0],a[1][1]-a[0][1]),d=this.__zoom,u="function"==typeof t?t.apply(this,e):t,h=c(d.invert(s).concat(l/d.k),u.invert(s).concat(l/u.k));return function(e){if(1===e)e=u;else{var t=h(e),n=l/t[2];e=new tc(n,s[0]-t[0]*n,s[1]-t[1]*n)}i.zoom(null,e)}})}function w(e,t,n){return!n&&e.__zooming||new b(e,t)}function b(e,t){this.that=e,this.args=t,this.active=0,this.sourceEvent=null,this.extent=o.apply(e,t),this.taps=0}function E(e,...t){if(r.apply(this,arguments)){var n=w(this,t).event(e),o=this.__zoom,s=Math.max(l[0],Math.min(l[1],o.k*Math.pow(2,a.apply(this,arguments)))),u=ef(e);if(n.wheel)(n.mouse[0][0]!==u[0]||n.mouse[0][1]!==u[1])&&(n.mouse[1]=o.invert(n.mouse[0]=u)),clearTimeout(n.wheel);else{if(o.k===s)return;n.mouse=[u,o.invert(u)],eJ(this),n.start()}tg(e),n.wheel=setTimeout(function(){n.wheel=null,n.end()},150),n.zoom("mouse",i(y(m(o,s),n.mouse[0],n.mouse[1]),n.extent,d))}}function k(e,...t){if(!n&&r.apply(this,arguments)){var o=e.currentTarget,a=w(this,t,!0).event(e),s=eh(e.view).on("mousemove.zoom",function(e){if(tg(e),!a.moved){var t=e.clientX-u,n=e.clientY-c;a.moved=t*t+n*n>f}a.event(e).zoom("mouse",i(y(a.that.__zoom,a.mouse[0]=ef(e,o),a.mouse[1]),a.extent,d))},!0).on("mouseup.zoom",function(e){s.on("mousemove.zoom mouseup.zoom",null),ex(e.view,a.moved),tg(e),a.event(e).end()},!0),l=ef(e,o),u=e.clientX,c=e.clientY;ev(e.view),tp(e),a.mouse=[l,this.__zoom.invert(l)],eJ(this),a.start()}}function C(e,...t){if(r.apply(this,arguments)){var n=this.__zoom,a=ef(e.changedTouches?e.changedTouches[0]:e,this),s=n.invert(a),l=n.k*(e.shiftKey?.5:2),c=i(y(m(n,l),a,s),o.apply(this,t),d);tg(e),u>0?eh(this).transition().duration(u).call(x,c,a,e):eh(this).call(g.transform,c,a,e)}}function S(n,...o){if(r.apply(this,arguments)){var i,a,s,l,d=n.touches,u=d.length,c=w(this,o,n.changedTouches.length===u).event(n);for(tp(n),a=0;a<u;++a)l=[l=ef(s=d[a],this),this.__zoom.invert(l),s.identifier],c.touch0?c.touch1||c.touch0[2]===l[2]||(c.touch1=l,c.taps=0):(c.touch0=l,i=!0,c.taps=1+!!e);e&&(e=clearTimeout(e)),i&&(c.taps<2&&(t=l[0],e=setTimeout(function(){e=null},500)),eJ(this),c.start())}}function N(e,...t){if(this.__zooming){var n,r,o,a,s=w(this,t).event(e),l=e.changedTouches,u=l.length;for(tg(e),n=0;n<u;++n)o=ef(r=l[n],this),s.touch0&&s.touch0[2]===r.identifier?s.touch0[0]=o:s.touch1&&s.touch1[2]===r.identifier&&(s.touch1[0]=o);if(r=s.that.__zoom,s.touch1){var c=s.touch0[0],h=s.touch0[1],f=s.touch1[0],p=s.touch1[1],g=(g=f[0]-c[0])*g+(g=f[1]-c[1])*g,v=(v=p[0]-h[0])*v+(v=p[1]-h[1])*v;r=m(r,Math.sqrt(g/v)),o=[(c[0]+f[0])/2,(c[1]+f[1])/2],a=[(h[0]+p[0])/2,(h[1]+p[1])/2]}else{if(!s.touch0)return;o=s.touch0[0],a=s.touch0[1]}s.zoom("touch",i(y(r,o,a),s.extent,d))}}function M(e,...r){if(this.__zooming){var o,i,a=w(this,r).event(e),s=e.changedTouches,l=s.length;for(tp(e),n&&clearTimeout(n),n=setTimeout(function(){n=null},500),o=0;o<l;++o)i=s[o],a.touch0&&a.touch0[2]===i.identifier?delete a.touch0:a.touch1&&a.touch1[2]===i.identifier&&delete a.touch1;if(a.touch1&&!a.touch0&&(a.touch0=a.touch1,delete a.touch1),a.touch0)a.touch0[1]=this.__zoom.invert(a.touch0[0]);else if(a.end(),2===a.taps&&(i=ef(i,this),Math.hypot(t[0]-i[0],t[1]-i[1])<p)){var d=eh(this).on("dblclick.zoom");d&&d.apply(this,arguments)}}}return g.transform=function(e,t,n,r){var o=e.selection?e.selection():e;o.property("__zoom",tv),e!==o?x(e,t,n,r):o.interrupt().each(function(){w(this,arguments).event(r).start().zoom(null,"function"==typeof t?t.apply(this,arguments):t).end()})},g.scaleBy=function(e,t,n,r){g.scaleTo(e,function(){var e=this.__zoom.k,n="function"==typeof t?t.apply(this,arguments):t;return e*n},n,r)},g.scaleTo=function(e,t,n,r){g.transform(e,function(){var e=o.apply(this,arguments),r=this.__zoom,a=null==n?v(e):"function"==typeof n?n.apply(this,arguments):n,s=r.invert(a),l="function"==typeof t?t.apply(this,arguments):t;return i(y(m(r,l),a,s),e,d)},n,r)},g.translateBy=function(e,t,n,r){g.transform(e,function(){return i(this.__zoom.translate("function"==typeof t?t.apply(this,arguments):t,"function"==typeof n?n.apply(this,arguments):n),o.apply(this,arguments),d)},null,r)},g.translateTo=function(e,t,n,r,a){g.transform(e,function(){var e=o.apply(this,arguments),a=this.__zoom,s=null==r?v(e):"function"==typeof r?r.apply(this,arguments):r;return i(th.translate(s[0],s[1]).scale(a.k).translate("function"==typeof t?-t.apply(this,arguments):-t,"function"==typeof n?-n.apply(this,arguments):-n),e,d)},r,a)},b.prototype={event:function(e){return e&&(this.sourceEvent=e),this},start:function(){return 1==++this.active&&(this.that.__zooming=this,this.emit("start")),this},zoom:function(e,t){return this.mouse&&"mouse"!==e&&(this.mouse[1]=t.invert(this.mouse[0])),this.touch0&&"touch"!==e&&(this.touch0[1]=t.invert(this.touch0[0])),this.touch1&&"touch"!==e&&(this.touch1[1]=t.invert(this.touch1[0])),this.that.__zoom=t,this.emit("zoom"),this},end:function(){return 0==--this.active&&(delete this.that.__zooming,this.emit("end")),this},emit:function(e){var t=eh(this.that).datum();h.call(e,this.that,new tu(e,{sourceEvent:this.sourceEvent,target:g,type:e,transform:this.that.__zoom,dispatch:h}),t)}},g.wheelDelta=function(e){return arguments.length?(a="function"==typeof e?e:td(+e),g):a},g.filter=function(e){return arguments.length?(r="function"==typeof e?e:td(!!e),g):r},g.touchable=function(e){return arguments.length?(s="function"==typeof e?e:td(!!e),g):s},g.extent=function(e){return arguments.length?(o="function"==typeof e?e:td([[+e[0][0],+e[0][1]],[+e[1][0],+e[1][1]]]),g):o},g.scaleExtent=function(e){return arguments.length?(l[0]=+e[0],l[1]=+e[1],g):[l[0],l[1]]},g.translateExtent=function(e){return arguments.length?(d[0][0]=+e[0][0],d[1][0]=+e[1][0],d[0][1]=+e[0][1],d[1][1]=+e[1][1],g):[[d[0][0],d[0][1]],[d[1][0],d[1][1]]]},g.constrain=function(e){return arguments.length?(i=e,g):i},g.duration=function(e){return arguments.length?(u=+e,g):u},g.interpolate=function(e){return arguments.length?(c=e,g):c},g.on=function(){var e=h.on.apply(h,arguments);return e===h?g:e},g.clickDistance=function(e){return arguments.length?(f=(e*=1)*e,g):Math.sqrt(f)},g.tapDistance=function(e){return arguments.length?(p=+e,g):p},g}tf.prototype=tc.prototype;var tE=e.i(678152);let tk=[[-1/0,-1/0],[1/0,1/0]],tC=["Enter"," ","Escape"],tS={"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"};(t=u||(u={})).Strict="strict",t.Loose="loose",(n=c||(c={})).Free="free",n.Vertical="vertical",n.Horizontal="horizontal",(r=h||(h={})).Partial="partial",r.Full="full";let tN={inProgress:!1,isValid:null,from:null,fromHandle:null,fromPosition:null,fromNode:null,to:null,toHandle:null,toPosition:null,toNode:null,pointer:null};(o=f||(f={})).Bezier="default",o.Straight="straight",o.Step="step",o.SmoothStep="smoothstep",o.SimpleBezier="simplebezier",(i=p||(p={})).Arrow="arrow",i.ArrowClosed="arrowclosed",(a=g||(g={})).Left="left",a.Top="top",a.Right="right",a.Bottom="bottom";let tM={[g.Left]:g.Right,[g.Right]:g.Left,[g.Top]:g.Bottom,[g.Bottom]:g.Top};function tj(e){return null===e?null:e?"valid":"invalid"}let tO=e=>"id"in e&&"source"in e&&"target"in e,tP=e=>"id"in e&&"internals"in e&&!("source"in e)&&!("target"in e),tA=(e,t=[0,0])=>{let{width:n,height:r}=t6(e),o=e.origin??t,i=n*o[0],a=r*o[1];return{x:e.position.x-i,y:e.position.y-a}},tI=(e,t={})=>{let n={x:1/0,y:1/0,x2:-1/0,y2:-1/0},r=!1;return e.forEach(e=>{(void 0===t.filter||t.filter(e))&&(n=tF(n,tW(e)),r=!0)}),r?tY(n):{x:0,y:0,width:0,height:0}},tz=(e,t,[n,r,o]=[0,0,1],i=!1,a=!1)=>{let s={...t0(t,[n,r,o]),width:t.width/o,height:t.height/o},l=[];for(let t of e.values()){let{measured:e,selectable:n=!0,hidden:r=!1}=t;if(a&&!n||r)continue;let o=e.width??t.width??t.initialWidth??null,d=e.height??t.height??t.initialHeight??null,u=tq(s,tK(t)),c=(o??0)*(d??0),h=i&&u>0;(!t.internals.handleBounds||h||u>=c||t.dragging)&&l.push(t)}return l};async function tD({nodes:e,width:t,height:n,panZoom:r,minZoom:o,maxZoom:i},a){let s,l;if(0===e.size)return Promise.resolve(!0);let d=t3(tI((s=new Map,l=a?.nodes?new Set(a.nodes.map(e=>e.id)):null,e.forEach(e=>{e.measured.width&&e.measured.height&&(a?.includeHiddenNodes||!e.hidden)&&(!l||l.has(e.id))&&s.set(e.id,e)}),s)),t,n,a?.minZoom??o,a?.maxZoom??i,a?.padding??.1);return await r.setViewport(d,{duration:a?.duration,ease:a?.ease,interpolate:a?.interpolate}),Promise.resolve(!0)}function tL({nodeId:e,nextPosition:t,nodeLookup:n,nodeOrigin:r=[0,0],nodeExtent:o,onError:i}){let a=n.get(e),s=a.parentId?n.get(a.parentId):void 0,{x:l,y:d}=s?s.internals.positionAbsolute:{x:0,y:0},u=a.origin??r,c=a.extent||o;if("parent"!==a.extent||a.expandParent)s&&t4(a.extent)&&(c=[[a.extent[0][0]+l,a.extent[0][1]+d],[a.extent[1][0]+l,a.extent[1][1]+d]]);else if(s){let e=s.measured.width,t=s.measured.height;e&&t&&(c=[[l,d],[l+e,d+t]])}else i?.("005","Only child nodes can use a parent extent.");let h=t4(c)?tT(t,c,a.measured):t;return(void 0===a.measured.width||void 0===a.measured.height)&&i?.("015","It seems that you are trying to drag a node that is not initialized. Please use onNodesChange as explained in the docs."),{position:{x:h.x-l+(a.measured.width??0)*u[0],y:h.y-d+(a.measured.height??0)*u[1]},positionAbsolute:h}}async function tR({nodesToRemove:e=[],edgesToRemove:t=[],nodes:n,edges:r,onBeforeDelete:o}){let i,a=new Set(e.map(e=>e.id)),s=[];for(let e of n){if(!1===e.deletable)continue;let t=a.has(e.id),n=!t&&e.parentId&&s.find(t=>t.id===e.parentId);(t||n)&&s.push(e)}let l=new Set(t.map(e=>e.id)),d=r.filter(e=>!1!==e.deletable),u=(i=new Set,s.forEach(e=>{i.add(e.id)}),d.filter(e=>i.has(e.source)||i.has(e.target)));for(let e of d)l.has(e.id)&&!u.find(t=>t.id===e.id)&&u.push(e);if(!o)return{edges:u,nodes:s};let c=await o({nodes:s,edges:u});return"boolean"==typeof c?c?{edges:u,nodes:s}:{edges:[],nodes:[]}:c}let tB=(e,t=0,n=1)=>Math.min(Math.max(e,t),n),tT=(e={x:0,y:0},t,n)=>({x:tB(e.x,t[0][0],t[1][0]-(n?.width??0)),y:tB(e.y,t[0][1],t[1][1]-(n?.height??0))});function t$(e,t,n){let{width:r,height:o}=t6(n),{x:i,y:a}=n.internals.positionAbsolute;return tT(e,[[i,a],[i+r,a+o]],t)}let tH=(e,t,n)=>e<t?tB(Math.abs(e-t),1,t)/t:e>n?-tB(Math.abs(e-n),1,t)/t:0,tV=(e,t,n=15,r=40)=>[tH(e.x,r,t.width-r)*n,tH(e.y,r,t.height-r)*n],tF=(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)}),tX=({x:e,y:t,width:n,height:r})=>({x:e,y:t,x2:e+n,y2:t+r}),tY=({x:e,y:t,x2:n,y2:r})=>({x:e,y:t,width:n-e,height:r-t}),tK=(e,t=[0,0])=>{let{x:n,y:r}=tP(e)?e.internals.positionAbsolute:tA(e,t);return{x:n,y:r,width:e.measured?.width??e.width??e.initialWidth??0,height:e.measured?.height??e.height??e.initialHeight??0}},tW=(e,t=[0,0])=>{let{x:n,y:r}=tP(e)?e.internals.positionAbsolute:tA(e,t);return{x:n,y:r,x2:n+(e.measured?.width??e.width??e.initialWidth??0),y2:r+(e.measured?.height??e.height??e.initialHeight??0)}},tZ=(e,t)=>tY(tF(tX(e),tX(t))),tq=(e,t)=>Math.ceil(Math.max(0,Math.min(e.x+e.width,t.x+t.width)-Math.max(e.x,t.x))*Math.max(0,Math.min(e.y+e.height,t.y+t.height)-Math.max(e.y,t.y))),tU=e=>tG(e.width)&&tG(e.height)&&tG(e.x)&&tG(e.y),tG=e=>!isNaN(e)&&isFinite(e),tQ=(e,t)=>{},tJ=(e,t=[1,1])=>({x:t[0]*Math.round(e.x/t[0]),y:t[1]*Math.round(e.y/t[1])}),t0=({x:e,y:t},[n,r,o],i=!1,a=[1,1])=>{let s={x:(e-n)/o,y:(t-r)/o};return i?tJ(s,a):s},t1=({x:e,y:t},[n,r,o])=>({x:e*o+n,y:t*o+r});function t2(e,t){if("number"==typeof e)return Math.floor((t-t/(1+e))*.5);if("string"==typeof e&&e.endsWith("px")){let t=parseFloat(e);if(!Number.isNaN(t))return Math.floor(t)}if("string"==typeof e&&e.endsWith("%")){let 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}let t3=(e,t,n,r,o,i)=>{let a=function(e,t,n){if("string"==typeof e||"number"==typeof e){let r=t2(e,n),o=t2(e,t);return{top:r,right:o,bottom:r,left:o,x:2*o,y:2*r}}if("object"==typeof e){let r=t2(e.top??e.y??0,n),o=t2(e.bottom??e.y??0,n),i=t2(e.left??e.x??0,t),a=t2(e.right??e.x??0,t);return{top:r,right:a,bottom:o,left:i,x:i+a,y:r+o}}return{top:0,right:0,bottom:0,left:0,x:0,y:0}}(i,t,n),s=tB(Math.min((t-a.x)/e.width,(n-a.y)/e.height),r,o),l=e.x+e.width/2,d=e.y+e.height/2,u=t/2-l*s,c=n/2-d*s,h=function(e,t,n,r,o,i){let{x:a,y:s}=t1(e,[t,n,r]),{x:l,y:d}=t1({x:e.x+e.width,y:e.y+e.height},[t,n,r]);return{left:Math.floor(a),top:Math.floor(s),right:Math.floor(o-l),bottom:Math.floor(i-d)}}(e,u,c,s,t,n),f={left:Math.min(h.left-a.left,0),top:Math.min(h.top-a.top,0),right:Math.min(h.right-a.right,0),bottom:Math.min(h.bottom-a.bottom,0)};return{x:u-f.left+f.right,y:c-f.top+f.bottom,zoom:s}},t5=()=>"u">typeof navigator&&navigator?.userAgent?.indexOf("Mac")>=0;function t4(e){return null!=e&&"parent"!==e}function t6(e){return{width:e.measured?.width??e.width??e.initialWidth??0,height:e.measured?.height??e.height??e.initialHeight??0}}function t7(e){return(e.measured?.width??e.width??e.initialWidth)!==void 0&&(e.measured?.height??e.height??e.initialHeight)!==void 0}function t8(e,t={width:0,height:0},n,r,o){let i={...e},a=r.get(n);if(a){let e=a.origin||o;i.x+=a.internals.positionAbsolute.x-(t.width??0)*e[0],i.y+=a.internals.positionAbsolute.y-(t.height??0)*e[1]}return i}function t9(e,t){if(e.size!==t.size)return!1;for(let n of e)if(!t.has(n))return!1;return!0}function ne(e,{snapGrid:t=[0,0],snapToGrid:n=!1,transform:r,containerBounds:o}){let{x:i,y:a}=ni(e),s=t0({x:i-(o?.left??0),y:a-(o?.top??0)},r),{x:l,y:d}=n?tJ(s,t):s;return{xSnapped:l,ySnapped:d,...s}}let nt=e=>({width:e.offsetWidth,height:e.offsetHeight}),nn=e=>e?.getRootNode?.()||window?.document,nr=["INPUT","SELECT","TEXTAREA"];function no(e){let t=e.composedPath?.()?.[0]||e.target;return t?.nodeType===1&&(nr.includes(t.nodeName)||t.hasAttribute("contenteditable")||!!t.closest(".nokey"))}let ni=(e,t)=>{let n="clientX"in e,r=n?e.clientX:e.touches?.[0].clientX,o=n?e.clientY:e.touches?.[0].clientY;return{x:r-(t?.left??0),y:o-(t?.top??0)}},na=(e,t,n,r,o)=>{let i=t.querySelectorAll(`.${e}`);return i&&i.length?Array.from(i).map(t=>{let i=t.getBoundingClientRect();return{id:t.getAttribute("data-handleid"),type:e,nodeId:o,position:t.getAttribute("data-handlepos"),x:(i.left-n.left)/r,y:(i.top-n.top)/r,...nt(t)}}):null};function ns({sourceX:e,sourceY:t,targetX:n,targetY:r,sourceControlX:o,sourceControlY:i,targetControlX:a,targetControlY:s}){let l=.125*e+.375*o+.375*a+.125*n,d=.125*t+.375*i+.375*s+.125*r,u=Math.abs(l-e),c=Math.abs(d-t);return[l,d,u,c]}function nl(e,t){return e>=0?.5*e:25*t*Math.sqrt(-e)}function nd({pos:e,x1:t,y1:n,x2:r,y2:o,c:i}){switch(e){case g.Left:return[t-nl(t-r,i),n];case g.Right:return[t+nl(r-t,i),n];case g.Top:return[t,n-nl(n-o,i)];case g.Bottom:return[t,n+nl(o-n,i)]}}function nu({sourceX:e,sourceY:t,sourcePosition:n=g.Bottom,targetX:r,targetY:o,targetPosition:i=g.Top,curvature:a=.25}){let[s,l]=nd({pos:n,x1:e,y1:t,x2:r,y2:o,c:a}),[d,u]=nd({pos:i,x1:r,y1:o,x2:e,y2:t,c:a}),[c,h,f,p]=ns({sourceX:e,sourceY:t,targetX:r,targetY:o,sourceControlX:s,sourceControlY:l,targetControlX:d,targetControlY:u});return[`M${e},${t} C${s},${l} ${d},${u} ${r},${o}`,c,h,f,p]}function nc({sourceX:e,sourceY:t,targetX:n,targetY:r}){let o=Math.abs(n-e)/2,i=Math.abs(r-t)/2;return[n<e?n+o:n-o,r<t?r+i:r-i,o,i]}let nh=({source:e,sourceHandle:t,target:n,targetHandle:r})=>`xy-edge__${e}${t||""}-${n}${r||""}`,nf=(e,t,n={})=>{let r,o;if(!e.source||!e.target)return tQ("006","Can't create edge. An edge needs a source and a target."),t;let i=n.getEdgeId||nh;return(o=r=tO(e)?{...e}:{...e,id:i(e)},t.some(e=>e.source===o.source&&e.target===o.target&&(e.sourceHandle===o.sourceHandle||!e.sourceHandle&&!o.sourceHandle)&&(e.targetHandle===o.targetHandle||!e.targetHandle&&!o.targetHandle)))?t:(null===r.sourceHandle&&delete r.sourceHandle,null===r.targetHandle&&delete r.targetHandle,t.concat(r))};function np({sourceX:e,sourceY:t,targetX:n,targetY:r}){let[o,i,a,s]=nc({sourceX:e,sourceY:t,targetX:n,targetY:r});return[`M ${e},${t}L ${n},${r}`,o,i,a,s]}let ng={[g.Left]:{x:-1,y:0},[g.Right]:{x:1,y:0},[g.Top]:{x:0,y:-1},[g.Bottom]:{x:0,y:1}},nm=({source:e,sourcePosition:t=g.Bottom,target:n})=>t===g.Left||t===g.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},ny=(e,t)=>Math.sqrt(Math.pow(t.x-e.x,2)+Math.pow(t.y-e.y,2));function nv({sourceX:e,sourceY:t,sourcePosition:n=g.Bottom,targetX:r,targetY:o,targetPosition:i=g.Top,borderRadius:a=5,centerX:s,centerY:l,offset:d=20,stepPosition:u=.5}){let[c,h,f,p,m]=function({source:e,sourcePosition:t=g.Bottom,target:n,targetPosition:r=g.Top,center:o,offset:i,stepPosition:a}){let s,l,d=ng[t],u=ng[r],c={x:e.x+d.x*i,y:e.y+d.y*i},h={x:n.x+u.x*i,y:n.y+u.y*i},f=nm({source:c,sourcePosition:t,target:h}),p=0!==f.x?"x":"y",m=f[p],y=[],v={x:0,y:0},x={x:0,y:0},[,,w,b]=nc({sourceX:e.x,sourceY:e.y,targetX:n.x,targetY:n.y});if(d[p]*u[p]==-1){"x"===p?(s=o.x??c.x+(h.x-c.x)*a,l=o.y??(c.y+h.y)/2):(s=o.x??(c.x+h.x)/2,l=o.y??c.y+(h.y-c.y)*a);let e=[{x:s,y:c.y},{x:s,y:h.y}],t=[{x:c.x,y:l},{x:h.x,y:l}];y=d[p]===m?"x"===p?e:t:"x"===p?t:e}else{let o=[{x:c.x,y:h.y}],a=[{x:h.x,y:c.y}];if(y="x"===p?d.x===m?a:o:d.y===m?o:a,t===r){let t=Math.abs(e[p]-n[p]);if(t<=i){let r=Math.min(i-1,i-t);d[p]===m?v[p]=(c[p]>e[p]?-1:1)*r:x[p]=(h[p]>n[p]?-1:1)*r}}if(t!==r){let e="x"===p?"y":"x",t=d[p]===u[e],n=c[e]>h[e],r=c[e]<h[e];(1===d[p]&&(!t&&n||t&&r)||1!==d[p]&&(!t&&r||t&&n))&&(y="x"===p?o:a)}let f={x:c.x+v.x,y:c.y+v.y},g={x:h.x+x.x,y:h.y+x.y};Math.max(Math.abs(f.x-y[0].x),Math.abs(g.x-y[0].x))>=Math.max(Math.abs(f.y-y[0].y),Math.abs(g.y-y[0].y))?(s=(f.x+g.x)/2,l=y[0].y):(s=y[0].x,l=(f.y+g.y)/2)}let _={x:c.x+v.x,y:c.y+v.y},E={x:h.x+x.x,y:h.y+x.y};return[[e,..._.x!==y[0].x||_.y!==y[0].y?[_]:[],...y,...E.x!==y[y.length-1].x||E.y!==y[y.length-1].y?[E]:[],n],s,l,w,b]}({source:{x:e,y:t},sourcePosition:n,target:{x:r,y:o},targetPosition:i,center:{x:s,y:l},offset:d,stepPosition:u}),y=`M${c[0].x} ${c[0].y}`;for(let e=1;e<c.length-1;e++)y+=function(e,t,n,r){let o=Math.min(ny(e,t)/2,ny(t,n)/2,r),{x:i,y:a}=t;if(e.x===i&&i===n.x||e.y===a&&a===n.y)return`L${i} ${a}`;if(e.y===a){let t=e.x<n.x?-1:1,r=e.y<n.y?1:-1;return`L ${i+o*t},${a}Q ${i},${a} ${i},${a+o*r}`}let s=e.x<n.x?1:-1,l=e.y<n.y?-1:1;return`L ${i},${a+o*l}Q ${i},${a} ${i+o*s},${a}`}(c[e-1],c[e],c[e+1],a);return[y+=`L${c[c.length-1].x} ${c[c.length-1].y}`,h,f,p,m]}function nx(e){return e&&!!(e.internals.handleBounds||e.handles?.length)&&!!(e.measured.width||e.width||e.initialWidth)}function nw(e){if(!e)return null;let t=[],n=[];for(let r of e)r.width=r.width??1,r.height=r.height??1,"source"===r.type?t.push(r):"target"===r.type&&n.push(r);return{source:t,target:n}}function nb(e,t,n=g.Left,r=!1){let o=(t?.x??0)+e.internals.positionAbsolute.x,i=(t?.y??0)+e.internals.positionAbsolute.y,{width:a,height:s}=t??t6(e);if(r)return{x:o+a/2,y:i+s/2};switch(t?.position??n){case g.Top:return{x:o+a/2,y:i};case g.Right:return{x:o+a,y:i+s/2};case g.Bottom:return{x:o+a/2,y:i+s};case g.Left:return{x:o,y:i+s/2}}}function n_(e,t){return e&&(t?e.find(e=>e.id===t):e[0])||null}function nE(e,t){if(!e)return"";if("string"==typeof e)return e;let n=t?`${t}__`:"";return`${n}${Object.keys(e).sort().map(t=>`${t}=${e[t]}`).join("&")}`}let nk={nodeOrigin:[0,0],nodeExtent:tk,elevateNodesOnSelect:!0,zIndexMode:"basic",defaults:{}},nC={...nk,checkEquality:!0};function nS(e,t){let n={...e};for(let e in t)void 0!==t[e]&&(n[e]=t[e]);return n}function nN(e){return"manual"===e}function nM(e,t,n,r={}){let o=nS(nC,r),i={i:0},a=new Map(t),s=o?.elevateNodesOnSelect&&!nN(o.zIndexMode)?1e3:0,l=e.length>0,d=!1;for(let u of(t.clear(),n.clear(),e)){let e=a.get(u.id);if(o.checkEquality&&u===e?.internals.userNode)t.set(u.id,e);else{let n=tT(tA(u,o.nodeOrigin),t4(u.extent)?u.extent:o.nodeExtent,t6(u));e={...o.defaults,...u,measured:{width:u.measured?.width,height:u.measured?.height},internals:{positionAbsolute:n,handleBounds:function(e,t){if(!e.handles)return e.measured?t?.internals.handleBounds:void 0;let n=[],r=[];for(let t of e.handles){let o={id:t.id,width:t.width??1,height:t.height??1,nodeId:e.id,x:t.x,y:t.y,position:t.position,type:t.type};"source"===t.type?n.push(o):"target"===t.type&&r.push(o)}return{source:n,target:r}}(u,e),z:nO(u,s,o.zIndexMode),userNode:u}},t.set(u.id,e)}void 0!==e.measured&&void 0!==e.measured.width&&void 0!==e.measured.height||e.hidden||(l=!1),u.parentId&&nj(e,t,n,r,i),d||=u.selected??!1}return{nodesInitialized:l,hasSelectedNodes:d}}function nj(e,t,n,r,o){let{elevateNodesOnSelect:i,nodeOrigin:a,nodeExtent:s,zIndexMode:l}=nS(nk,r),d=e.parentId,u=t.get(d);if(!u)return void console.warn(`Parent node ${d} not found. Please make sure that parent nodes are in front of their child nodes in the nodes array.`);!function(e,t){if(!e.parentId)return;let n=t.get(e.parentId);n?n.set(e.id,e):t.set(e.parentId,new Map([[e.id,e]]))}(e,n),o&&!u.parentId&&void 0===u.internals.rootParentIndex&&"auto"===l&&(u.internals.rootParentIndex=++o.i,u.internals.z=u.internals.z+10*o.i),o&&void 0!==u.internals.rootParentIndex&&(o.i=u.internals.rootParentIndex);let{x:c,y:h,z:f}=function(e,t,n,r,o,i){let{x:a,y:s}=t.internals.positionAbsolute,l=t6(e),d=tA(e,n),u=t4(e.extent)?tT(d,e.extent,l):d,c=tT({x:a+u.x,y:s+u.y},r,l);"parent"===e.extent&&(c=t$(c,l,t));let h=nO(e,o,i),f=t.internals.z??0;return{x:c.x,y:c.y,z:f>=h?f+1:h}}(e,u,a,s,i&&!nN(l)?1e3:0,l),{positionAbsolute:p}=e.internals,g=c!==p.x||h!==p.y;(g||f!==e.internals.z)&&t.set(e.id,{...e,internals:{...e.internals,positionAbsolute:g?{x:c,y:h}:p,z:f}})}function nO(e,t,n){let r=tG(e.zIndex)?e.zIndex:0;return nN(n)?r:r+(e.selected?t:0)}function nP(e,t,n,r=[0,0]){let o=[],i=new Map;for(let n of e){let e=t.get(n.parentId);if(!e)continue;let r=tZ(i.get(n.parentId)?.expandedRect??tK(e),n.rect);i.set(n.parentId,{expandedRect:r,parent:e})}return i.size>0&&i.forEach(({expandedRect:t,parent:i},a)=>{let s=i.internals.positionAbsolute,l=t6(i),d=i.origin??r,u=t.x<s.x?Math.round(Math.abs(s.x-t.x)):0,c=t.y<s.y?Math.round(Math.abs(s.y-t.y)):0,h=Math.max(l.width,Math.round(t.width)),f=Math.max(l.height,Math.round(t.height)),p=(h-l.width)*d[0],g=(f-l.height)*d[1];(u>0||c>0||p||g)&&(o.push({id:a,type:"position",position:{x:i.position.x-u+p,y:i.position.y-c+g}}),n.get(a)?.forEach(t=>{e.some(e=>e.id===t.id)||o.push({id:t.id,type:"position",position:{x:t.position.x+u,y:t.position.y+c}})})),(l.width<t.width||l.height<t.height||u||c)&&o.push({id:a,type:"dimensions",setAttributes:!0,dimensions:{width:h+(u?d[0]*u-p:0),height:f+(c?d[1]*c-g:0)}})}),o}async function nA({delta:e,panZoom:t,transform:n,translateExtent:r,width:o,height:i}){if(!t||!e.x&&!e.y)return Promise.resolve(!1);let a=await t.setViewportConstrained({x:n[0]+e.x,y:n[1]+e.y,zoom:n[2]},[[0,0],[o,i]],r);return Promise.resolve(!!a&&(a.x!==n[0]||a.y!==n[1]||a.k!==n[2]))}function nI(e,t,n,r,o,i){let a=o,s=r.get(a)||new Map;r.set(a,s.set(n,t)),a=`${o}-${e}`;let l=r.get(a)||new Map;if(r.set(a,l.set(n,t)),i){a=`${o}-${e}-${i}`;let s=r.get(a)||new Map;r.set(a,s.set(n,t))}}function nz(e,t,n){for(let r of(e.clear(),t.clear(),n)){let{source:n,target:o,sourceHandle:i=null,targetHandle:a=null}=r,s={edgeId:r.id,source:n,target:o,sourceHandle:i,targetHandle:a},l=`${n}-${i}--${o}-${a}`;nI("source",s,`${o}-${a}--${n}-${i}`,e,n,i),nI("target",s,l,e,o,a),t.set(r.id,r)}}function nD(e,t,n){let r=e;do{if(r?.matches?.(t))return!0;if(r===n)break;r=r?.parentElement}while(r)return!1}function nL({nodeId:e,dragItems:t,nodeLookup:n,dragging:r=!0}){let o=[];for(let[e,i]of t){let t=n.get(e)?.internals.userNode;t&&o.push({...t,position:i.position,dragging:r})}if(!e)return[o[0],o];let i=n.get(e)?.internals.userNode;return[i?{...i,position:t.get(e)?.position||i.position,dragging:r}:o[0],o]}function nR(e,t,n,r,o,i=!1){let a=r.get(e);if(!a)return null;let s="strict"===o?a.internals.handleBounds?.[t]:[...a.internals.handleBounds?.source??[],...a.internals.handleBounds?.target??[]],l=(n?s?.find(e=>e.id===n):s?.[0])??null;return l&&i?{...l,...nb(a,l,l.position,!0)}:l}function nB(e,t){return e?e:t?.classList.contains("target")?"target":t?.classList.contains("source")?"source":null}let nT=()=>!0;function n$(e,{handle:t,connectionMode:n,fromNodeId:r,fromHandleId:o,fromType:i,doc:a,lib:s,flowId:l,isValidConnection:d=nT,nodeLookup:c}){let h="target"===i,f=t?a.querySelector(`.${s}-flow__handle[data-id="${l}-${t?.nodeId}-${t?.id}-${t?.type}"]`):null,{x:p,y:g}=ni(e),m=a.elementFromPoint(p,g),y=m?.classList.contains(`${s}-flow__handle`)?m:f,v={handleDomNode:y,isValid:!1,connection:null,toHandle:null};if(y){let e=nB(void 0,y),t=y.getAttribute("data-nodeid"),i=y.getAttribute("data-handleid"),a=y.classList.contains("connectable"),s=y.classList.contains("connectableend");if(!t||!e)return v;let l={source:h?t:r,sourceHandle:h?i:o,target:h?r:t,targetHandle:h?o:i};v.connection=l,v.isValid=a&&s&&(n===u.Strict?h&&"source"===e||!h&&"target"===e:t!==r||i!==o)&&d(l),v.toHandle=nR(t,e,i,c,n,!0)}return v}let nH=function(e,{connectionMode:t,connectionRadius:n,handleId:r,nodeId:o,edgeUpdaterType:i,isTarget:a,domNode:s,nodeLookup:l,lib:d,autoPanOnConnect:u,flowId:c,panBy:h,cancelConnection:f,onConnectStart:p,onConnect:m,onConnectEnd:y,isValidConnection:v=nT,onReconnectEnd:x,updateConnection:w,getTransform:b,getFromHandle:_,autoPanSpeed:E,dragThreshold:k=1,handleDomNode:C}){let S,N=nn(e.target),M=0,{x:j,y:O}=ni(e),P=nB(i,C),A=s?.getBoundingClientRect(),I=!1;if(!A||!P)return;let z=nR(o,P,r,l,t);if(!z)return;let D=ni(e,A),L=!1,R=null,B=!1,T=null,$={...z,nodeId:o,type:P,position:z.position},H=l.get(o),V={inProgress:!0,isValid:null,from:nb(H,$,g.Left,!0),fromHandle:$,fromPosition:$.position,fromNode:H,to:D,toHandle:null,toPosition:tM[$.position],toNode:null,pointer:D};function F(){I=!0,w(V),p?.(e,{nodeId:o,handleId:r,handleType:P})}function X(e){var i,s;let f;if(!I){let{x:t,y:n}=ni(e),r=t-j,o=n-O;if(!(r*r+o*o>k*k))return;F()}if(!_()||!$)return void Y(e);let p=b();S=function(e,t,n,r){let o=[],i=1/0;for(let a of function(e,t,n){let r=[],o={x:e.x-n,y:e.y-n,width:2*n,height:2*n};for(let e of t.values())tq(o,tK(e))>0&&r.push(e);return r}(e,n,t+250))for(let n of[...a.internals.handleBounds?.source??[],...a.internals.handleBounds?.target??[]]){if(r.nodeId===n.nodeId&&r.type===n.type&&r.id===n.id)continue;let{x:s,y:l}=nb(a,n,n.position,!0),d=Math.sqrt(Math.pow(s-e.x,2)+Math.pow(l-e.y,2));d>t||(d<i?(o=[{...n,x:s,y:l}],i=d):d===i&&o.push({...n,x:s,y:l}))}if(!o.length)return null;if(o.length>1){let e="source"===r.type?"target":"source";return o.find(t=>t.type===e)??o[0]}return o[0]}(t0(D=ni(e,A),p,!1,[1,1]),n,l,$),L||(!function e(){if(!u||!A)return;let[t,n]=tV(D,A,E);h({x:t,y:n}),M=requestAnimationFrame(e)}(),L=!0);let m=n$(e,{handle:S,connectionMode:t,fromNodeId:o,fromHandleId:r,fromType:a?"target":"source",isValidConnection:v,doc:N,lib:d,flowId:c,nodeLookup:l});T=m.handleDomNode,R=m.connection,i=!!S,s=m.isValid,f=null,s?f=!0:i&&!s&&(f=!1),B=f;let y=l.get(o),x=y?nb(y,$,g.Left,!0):V.from,C={...V,from:x,isValid:B,to:m.toHandle&&B?t1({x:m.toHandle.x,y:m.toHandle.y},p):D,toHandle:m.toHandle,toPosition:B&&m.toHandle?m.toHandle.position:tM[$.position],toNode:m.toHandle?l.get(m.toHandle.nodeId):null,pointer:D};w(C),V=C}function Y(e){if(!("touches"in e)||!(e.touches.length>0)){if(I){(S||T)&&R&&B&&m?.(R);let{inProgress:t,...n}=V,r={...n,toPosition:V.toHandle?V.toPosition:null};y?.(e,r),i&&x?.(e,r)}f(),cancelAnimationFrame(M),L=!1,B=!1,R=null,T=null,N.removeEventListener("mousemove",X),N.removeEventListener("mouseup",Y),N.removeEventListener("touchmove",X),N.removeEventListener("touchend",Y)}}0===k&&F(),N.addEventListener("mousemove",X),N.addEventListener("mouseup",Y),N.addEventListener("touchmove",X),N.addEventListener("touchend",Y)},nV=e=>({x:e.x,y:e.y,zoom:e.k}),nF=({x:e,y:t,zoom:n})=>th.translate(e,t).scale(n),nX=(e,t)=>e.target.closest(`.${t}`),nY=(e,t)=>2===t&&Array.isArray(e)&&e.includes(2),nK=e=>((e*=2)<=1?e*e*e:(e-=2)*e*e+2)/2,nW=(e,t=0,n=nK,r=()=>{})=>{let o="number"==typeof t&&t>0;return o||r(),o?e.transition().duration(t).ease(n).on("end",r):e},nZ=e=>{let t=e.ctrlKey&&t5()?10:1;return-e.deltaY*(1===e.deltaMode?.05:e.deltaMode?1:.002)*t};function nq(e){let t=e.includes("right")||e.includes("left"),n=e.includes("bottom")||e.includes("top");return{isHorizontal:t,isVertical:n,affectsX:e.includes("left"),affectsY:e.includes("top")}}function nU(e,t){return Math.max(0,t-e)}function nG(e,t){return Math.max(0,e-t)}function nQ(e,t,n){return Math.max(0,t-e,e-n)}(s=m||(m={})).Line="line",s.Handle="handle";let nJ={width:0,height:0,x:0,y:0},n0={...nJ,pointerX:0,pointerY:0,aspectRatio:1};var n1=e.i(596482);let n2={get url(){return`file://${e.P("node_modules/.pnpm/zustand@4.5.7_@types+react@19.2.14_immer@11.1.4_react@19.2.4/node_modules/zustand/esm/vanilla.mjs")}`}},n3=e=>{let t,n=new Set,r=(e,r)=>{let o="function"==typeof e?e(t):e;if(!Object.is(o,t)){let e=t;t=(null!=r?r:"object"!=typeof o||null===o)?o:Object.assign({},t,o),n.forEach(n=>n(t,e))}},o=()=>t,i={setState:r,getState:o,getInitialState:()=>a,subscribe:e=>(n.add(e),()=>n.delete(e)),destroy:()=>{(n2.env?n2.env.MODE: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()}},a=t=e(r,o,i);return i},{useDebugValue:n5}=x.default,{useSyncExternalStoreWithSelector:n4}=n1.default,n6=e=>e;function n7(e,t=n6,n){let r=n4(e.subscribe,e.getState,e.getServerState||e.getInitialState,t,n);return n5(r),r}let n8=(e,t)=>{let n=e?n3(e):n3,r=(e,r=t)=>n7(n,e,r);return Object.assign(r,n),r};function n9(e,t){if(Object.is(e,t))return!0;if("object"!=typeof e||null===e||"object"!=typeof t||null===t)return!1;if(e instanceof Map&&t instanceof Map){if(e.size!==t.size)return!1;for(let[n,r]of e)if(!Object.is(r,t.get(n)))return!1;return!0}if(e instanceof Set&&t instanceof Set){if(e.size!==t.size)return!1;for(let n of e)if(!t.has(n))return!1;return!0}let n=Object.keys(e);if(n.length!==Object.keys(t).length)return!1;for(let r of n)if(!Object.prototype.hasOwnProperty.call(t,r)||!Object.is(e[r],t[r]))return!1;return!0}var re=e.i(106206);let rt=(0,x.createContext)(null),rn=rt.Provider,rr="[React Flow]: Seems like you have not used zustand provider as an ancestor. Help: https://reactflow.dev/error#001";function ro(e,t){let n=(0,x.useContext)(rt);if(null===n)throw Error(rr);return n7(n,e,t)}function ri(){let e=(0,x.useContext)(rt);if(null===e)throw Error(rr);return(0,x.useMemo)(()=>({getState:e.getState,setState:e.setState,subscribe:e.subscribe}),[e])}let ra={display:"none"},rs={position:"absolute",width:1,height:1,margin:-1,border:0,padding:0,overflow:"hidden",clip:"rect(0px, 0px, 0px, 0px)",clipPath:"inset(100%)"},rl="react-flow__node-desc",rd="react-flow__edge-desc",ru=e=>e.ariaLiveMessage,rc=e=>e.ariaLabelConfig;function rh({rfId:e}){let t=ro(ru);return(0,v.jsx)("div",{id:`react-flow__aria-live-${e}`,"aria-live":"assertive","aria-atomic":"true",style:rs,children:t})}function rf({rfId:e,disableKeyboardA11y:t}){let n=ro(rc);return(0,v.jsxs)(v.Fragment,{children:[(0,v.jsx)("div",{id:`${rl}-${e}`,style:ra,children:t?n["node.a11yDescription.default"]:n["node.a11yDescription.keyboardDisabled"]}),(0,v.jsx)("div",{id:`${rd}-${e}`,style:ra,children:n["edge.a11yDescription.default"]}),!t&&(0,v.jsx)(rh,{rfId:e})]})}let rp=(0,x.forwardRef)(({position:e="top-left",children:t,className:n,style:r,...o},i)=>{let a=`${e}`.split("-");return(0,v.jsx)("div",{className:w(["react-flow__panel",n,...a]),style:r,ref:i,...o,children:t})});function rg({proOptions:e,position:t="bottom-right"}){return e?.hideAttribution?null:(0,v.jsx)(rp,{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:(0,v.jsx)("a",{href:"https://reactflow.dev",target:"_blank",rel:"noopener noreferrer","aria-label":"React Flow attribution",children:"React Flow"})})}rp.displayName="Panel";let rm=e=>{let t=[],n=[];for(let[,n]of e.nodeLookup)n.selected&&t.push(n.internals.userNode);for(let[,t]of e.edgeLookup)t.selected&&n.push(t);return{selectedNodes:t,selectedEdges:n}},ry=e=>e.id;function rv(e,t){return n9(e.selectedNodes.map(ry),t.selectedNodes.map(ry))&&n9(e.selectedEdges.map(ry),t.selectedEdges.map(ry))}function rx({onSelectionChange:e}){let t=ri(),{selectedNodes:n,selectedEdges:r}=ro(rm,rv);return(0,x.useEffect)(()=>{let o={nodes:n,edges:r};e?.(o),t.getState().onSelectionChangeHandlers.forEach(e=>e(o))},[n,r,e]),null}let rw=e=>!!e.onSelectionChangeHandlers;function rb({onSelectionChange:e}){let t=ro(rw);return e||t?(0,v.jsx)(rx,{onSelectionChange:e}):null}let r_="u">typeof window?x.useLayoutEffect:x.useEffect,rE=[0,0],rk={x:0,y:0,zoom:1},rC=["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","rfId"],rS=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}),rN={translateExtent:tk,nodeOrigin:rE,minZoom:.5,maxZoom:2,elementsSelectable:!0,noPanClassName:"nopan",rfId:"1"};function rM(e){let{setNodes:t,setEdges:n,setMinZoom:r,setMaxZoom:o,setTranslateExtent:i,setNodeExtent:a,reset:s,setDefaultNodesAndEdges:l}=ro(rS,n9),d=ri();r_(()=>(l(e.defaultNodes,e.defaultEdges),()=>{u.current=rN,s()}),[]);let u=(0,x.useRef)(rN);return r_(()=>{for(let s of rC){let l=e[s];if(l!==u.current[s]&&void 0!==e[s])if("nodes"===s)t(l);else if("edges"===s)n(l);else if("minZoom"===s)r(l);else if("maxZoom"===s)o(l);else if("translateExtent"===s)i(l);else if("nodeExtent"===s)a(l);else if("ariaLabelConfig"===s)d.setState({ariaLabelConfig:{...tS,...l||{}}});else"fitView"===s?d.setState({fitViewQueued:l}):"fitViewOptions"===s?d.setState({fitViewOptions:l}):d.setState({[s]:l})}u.current=e},rC.map(t=>e[t])),null}function rj(){return"u"<typeof window||!window.matchMedia?null:window.matchMedia("(prefers-color-scheme: dark)")}let rO="u">typeof document?document:null;function rP(e=null,t={target:rO,actInsideInputWithModifier:!0}){let[n,r]=(0,x.useState)(!1),o=(0,x.useRef)(!1),i=(0,x.useRef)(new Set([])),[a,s]=(0,x.useMemo)(()=>{if(null!==e){let t=(Array.isArray(e)?e:[e]).filter(e=>"string"==typeof e).map(e=>e.replace("+","\n").replace("\n\n","\n+").split("\n")),n=t.reduce((e,t)=>e.concat(...t),[]);return[t,n]}return[[],[]]},[e]);return(0,x.useEffect)(()=>{let n=t?.target??rO,l=t?.actInsideInputWithModifier??!0;if(null!==e){let e=e=>{if(o.current=e.ctrlKey||e.metaKey||e.shiftKey||e.altKey,(!o.current||o.current&&!l)&&no(e))return!1;let n=rI(e.code,s);if(i.current.add(e[n]),rA(a,i.current,!1)){let n=e.composedPath?.()?.[0]||e.target,i=n?.nodeName==="BUTTON"||n?.nodeName==="A";!1!==t.preventDefault&&(o.current||!i)&&e.preventDefault(),r(!0)}},d=e=>{let t=rI(e.code,s);rA(a,i.current,!0)?(r(!1),i.current.clear()):i.current.delete(e[t]),"Meta"===e.key&&i.current.clear(),o.current=!1},u=()=>{i.current.clear(),r(!1)};return n?.addEventListener("keydown",e),n?.addEventListener("keyup",d),window.addEventListener("blur",u),window.addEventListener("contextmenu",u),()=>{n?.removeEventListener("keydown",e),n?.removeEventListener("keyup",d),window.removeEventListener("blur",u),window.removeEventListener("contextmenu",u)}}},[e,r]),n}function rA(e,t,n){return e.filter(e=>n||e.length===t.size).some(e=>e.every(e=>t.has(e)))}function rI(e,t){return t.includes(e)?"code":"key"}function rz(e,t){let n=[],r=new Map,o=[];for(let t of e)if("add"===t.type){o.push(t);continue}else if("remove"===t.type||"replace"===t.type)r.set(t.id,[t]);else{let e=r.get(t.id);e?e.push(t):r.set(t.id,[t])}for(let e of t){let t=r.get(e.id);if(!t){n.push(e);continue}if("remove"===t[0].type)continue;if("replace"===t[0].type){n.push({...t[0].item});continue}let o={...e};for(let e of t){var i=e,a=o;switch(i.type){case"select":a.selected=i.selected;break;case"position":void 0!==i.position&&(a.position=i.position),void 0!==i.dragging&&(a.dragging=i.dragging);break;case"dimensions":void 0!==i.dimensions&&(a.measured={...i.dimensions},i.setAttributes&&((!0===i.setAttributes||"width"===i.setAttributes)&&(a.width=i.dimensions.width),(!0===i.setAttributes||"height"===i.setAttributes)&&(a.height=i.dimensions.height))),"boolean"==typeof i.resizing&&(a.resizing=i.resizing)}}n.push(o)}return o.length&&o.forEach(e=>{void 0!==e.index?n.splice(e.index,0,{...e.item}):n.push({...e.item})}),n}function rD(e,t){return{id:e,type:"select",selected:t}}function rL(e,t=new Set,n=!1){let r=[];for(let[o,i]of e){let e=t.has(o);(void 0!==i.selected||e)&&i.selected!==e&&(n&&(i.selected=e),r.push(rD(i.id,e)))}return r}function rR({items:e=[],lookup:t}){let n=[],r=new Map(e.map(e=>[e.id,e]));for(let[r,o]of e.entries()){let e=t.get(o.id),i=e?.internals?.userNode??e;void 0!==i&&i!==o&&n.push({id:o.id,item:o,type:"replace"}),void 0===i&&n.push({item:o,type:"add",index:r})}for(let[e]of t)void 0===r.get(e)&&n.push({id:e,type:"remove"});return n}function rB(e){return{id:e.id,type:"remove"}}let rT=e=>"id"in e&&"position"in e&&!("source"in e)&&!("target"in e);function r$(e){return(0,x.forwardRef)(e)}function rH(e){let[t,n]=(0,x.useState)(BigInt(0)),[r]=(0,x.useState)(()=>{var e;let t;return e=()=>n(e=>e+BigInt(1)),t=[],{get:()=>t,reset:()=>{t=[]},push:n=>{t.push(n),e()}}});return r_(()=>{let t=r.get();t.length&&(e(t),r.reset())},[t]),r}let rV=(0,x.createContext)(null);function rF({children:e}){let t=ri(),n=rH((0,x.useCallback)(e=>{let{nodes:n=[],setNodes:r,hasDefaultNodes:o,onNodesChange:i,nodeLookup:a,fitViewQueued:s,onNodesChangeMiddlewareMap:l}=t.getState(),d=n;for(let t of e)d="function"==typeof t?t(d):t;let u=rR({items:d,lookup:a});for(let e of l.values())u=e(u);o&&r(d),u.length>0?i?.(u):s&&window.requestAnimationFrame(()=>{let{fitViewQueued:e,nodes:n,setNodes:r}=t.getState();e&&r(n)})},[])),r=rH((0,x.useCallback)(e=>{let{edges:n=[],setEdges:r,hasDefaultEdges:o,onEdgesChange:i,edgeLookup:a}=t.getState(),s=n;for(let t of e)s="function"==typeof t?t(s):t;o?r(s):i&&i(rR({items:s,lookup:a}))},[])),o=(0,x.useMemo)(()=>({nodeQueue:n,edgeQueue:r}),[]);return(0,v.jsx)(rV.Provider,{value:o,children:e})}let rX=e=>!!e.panZoom;function rY(){let e,t=(e=ri(),(0,x.useMemo)(()=>({zoomIn:t=>{let{panZoom:n}=e.getState();return n?n.scaleBy(1.2,t):Promise.resolve(!1)},zoomOut:t=>{let{panZoom:n}=e.getState();return n?n.scaleBy(1/1.2,t):Promise.resolve(!1)},zoomTo:(t,n)=>{let{panZoom:r}=e.getState();return r?r.scaleTo(t,n):Promise.resolve(!1)},getZoom:()=>e.getState().transform[2],setViewport:async(t,n)=>{let{transform:[r,o,i],panZoom:a}=e.getState();return a?(await a.setViewport({x:t.x??r,y:t.y??o,zoom:t.zoom??i},n),Promise.resolve(!0)):Promise.resolve(!1)},getViewport:()=>{let[t,n,r]=e.getState().transform;return{x:t,y:n,zoom:r}},setCenter:async(t,n,r)=>e.getState().setCenter(t,n,r),fitBounds:async(t,n)=>{let{width:r,height:o,minZoom:i,maxZoom:a,panZoom:s}=e.getState(),l=t3(t,r,o,i,a,n?.padding??.1);return s?(await s.setViewport(l,{duration:n?.duration,ease:n?.ease,interpolate:n?.interpolate}),Promise.resolve(!0)):Promise.resolve(!1)},screenToFlowPosition:(t,n={})=>{let{transform:r,snapGrid:o,snapToGrid:i,domNode:a}=e.getState();if(!a)return t;let{x:s,y:l}=a.getBoundingClientRect(),d={x:t.x-s,y:t.y-l},u=n.snapGrid??o;return t0(d,r,n.snapToGrid??i,u)},flowToScreenPosition:t=>{let{transform:n,domNode:r}=e.getState();if(!r)return t;let{x:o,y:i}=r.getBoundingClientRect(),a=t1(t,n);return{x:a.x+o,y:a.y+i}}}),[])),n=ri(),r=function(){let e=(0,x.useContext)(rV);if(!e)throw Error("useBatchContext must be used within a BatchProvider");return e}(),o=ro(rX),i=(0,x.useMemo)(()=>{let e=e=>n.getState().nodeLookup.get(e),t=e=>{r.nodeQueue.push(e)},o=e=>{r.edgeQueue.push(e)},i=e=>{let{nodeLookup:t,nodeOrigin:r}=n.getState(),o=rT(e)?e:t.get(e.id),i=o.parentId?t8(o.position,o.measured,o.parentId,t,r):o.position;return tK({...o,position:i,width:o.measured?.width??o.width,height:o.measured?.height??o.height})},a=(e,n,r={replace:!1})=>{t(t=>t.map(t=>{if(t.id===e){let e="function"==typeof n?n(t):n;return r.replace&&rT(e)?e:{...t,...e}}return t}))},s=(e,t,n={replace:!1})=>{o(r=>r.map(r=>{if(r.id===e){let e="function"==typeof t?t(r):t;return n.replace&&tO(e)?e:{...r,...e}}return r}))};return{getNodes:()=>n.getState().nodes.map(e=>({...e})),getNode:t=>e(t)?.internals.userNode,getInternalNode:e,getEdges:()=>{let{edges:e=[]}=n.getState();return e.map(e=>({...e}))},getEdge:e=>n.getState().edgeLookup.get(e),setNodes:t,setEdges:o,addNodes:e=>{let t=Array.isArray(e)?e:[e];r.nodeQueue.push(e=>[...e,...t])},addEdges:e=>{let t=Array.isArray(e)?e:[e];r.edgeQueue.push(e=>[...e,...t])},toObject:()=>{let{nodes:e=[],edges:t=[],transform:r}=n.getState(),[o,i,a]=r;return{nodes:e.map(e=>({...e})),edges:t.map(e=>({...e})),viewport:{x:o,y:i,zoom:a}}},deleteElements:async({nodes:e=[],edges:t=[]})=>{let{nodes:r,edges:o,onNodesDelete:i,onEdgesDelete:a,triggerNodeChanges:s,triggerEdgeChanges:l,onDelete:d,onBeforeDelete:u}=n.getState(),{nodes:c,edges:h}=await tR({nodesToRemove:e,edgesToRemove:t,nodes:r,edges:o,onBeforeDelete:u}),f=h.length>0,p=c.length>0;if(f){let e=h.map(rB);a?.(h),l(e)}if(p){let e=c.map(rB);i?.(c),s(e)}return(p||f)&&d?.({nodes:c,edges:h}),{deletedNodes:c,deletedEdges:h}},getIntersectingNodes:(e,t=!0,r)=>{let o=tU(e),a=o?e:i(e),s=void 0!==r;return a?(r||n.getState().nodes).filter(r=>{let i=n.getState().nodeLookup.get(r.id);if(i&&!o&&(r.id===e.id||!i.internals.positionAbsolute))return!1;let l=tK(s?r:i),d=tq(l,a);return t&&d>0||d>=l.width*l.height||d>=a.width*a.height}):[]},isNodeIntersecting:(e,t,n=!0)=>{let r=tU(e)?e:i(e);if(!r)return!1;let o=tq(r,t);return n&&o>0||o>=t.width*t.height||o>=r.width*r.height},updateNode:a,updateNodeData:(e,t,n={replace:!1})=>{a(e,e=>{let r="function"==typeof t?t(e):t;return n.replace?{...e,data:r}:{...e,data:{...e.data,...r}}},n)},updateEdge:s,updateEdgeData:(e,t,n={replace:!1})=>{s(e,e=>{let r="function"==typeof t?t(e):t;return n.replace?{...e,data:r}:{...e,data:{...e.data,...r}}},n)},getNodesBounds:e=>{let{nodeLookup:t,nodeOrigin:r}=n.getState();return((e,t={nodeOrigin:[0,0]})=>0===e.length?{x:0,y:0,width:0,height:0}:tY(e.reduce((e,n)=>{let r="string"==typeof n,o=t.nodeLookup||r?void 0:n;return t.nodeLookup&&(o=r?t.nodeLookup.get(n):tP(n)?n:t.nodeLookup.get(n.id)),tF(e,o?tW(o,t.nodeOrigin):{x:0,y:0,x2:0,y2:0})},{x:1/0,y:1/0,x2:-1/0,y2:-1/0})))(e,{nodeLookup:t,nodeOrigin:r})},getHandleConnections:({type:e,id:t,nodeId:r})=>Array.from(n.getState().connectionLookup.get(`${r}-${e}${t?`-${t}`:""}`)?.values()??[]),getNodeConnections:({type:e,handleId:t,nodeId:r})=>Array.from(n.getState().connectionLookup.get(`${r}${e?t?`-${e}-${t}`:`-${e}`:""}`)?.values()??[]),fitView:async e=>{let t,o,i=n.getState().fitViewResolver??{promise:new Promise((e,n)=>{t=e,o=n}),resolve:t,reject:o};return n.setState({fitViewQueued:!0,fitViewOptions:e,fitViewResolver:i}),r.nodeQueue.push(e=>[...e]),i.promise}}},[]);return(0,x.useMemo)(()=>({...i,...t,viewportInitialized:o}),[o])}let rK=e=>e.selected,rW="u">typeof window?window:void 0,rZ={position:"absolute",width:"100%",height:"100%",top:0,left:0},rq=e=>({userSelectionActive:e.userSelectionActive,lib:e.lib,connectionInProgress:e.connection.inProgress});function rU({onPaneContextMenu:e,zoomOnScroll:t=!0,zoomOnPinch:n=!0,panOnScroll:r=!1,panOnScrollSpeed:o=.5,panOnScrollMode:i=c.Free,zoomOnDoubleClick:a=!0,panOnDrag:s=!0,defaultViewport:l,translateExtent:d,minZoom:u,maxZoom:h,zoomActivationKeyCode:f,preventScrolling:p=!0,children:g,noWheelClassName:m,noPanClassName:y,onViewportChange:w,isControlledViewport:b,paneClickDistance:_,selectionOnDrag:E}){let k,C=ri(),S=(0,x.useRef)(null),{userSelectionActive:N,lib:M,connectionInProgress:j}=ro(rq,n9),O=rP(f),P=(0,x.useRef)();k=ri(),(0,x.useEffect)(()=>{let e=()=>{if(!S.current||!(S.current.checkVisibility?.()??!0))return!1;let e=nt(S.current);(0===e.height||0===e.width)&&k.getState().onError?.("004","The React Flow parent container needs a width and a height to render the graph."),k.setState({width:e.width||500,height:e.height||500})};if(S.current){e(),window.addEventListener("resize",e);let t=new ResizeObserver(()=>e());return t.observe(S.current),()=>{window.removeEventListener("resize",e),t&&S.current&&t.unobserve(S.current)}}},[]);let A=(0,x.useCallback)(e=>{w?.({x:e[0],y:e[1],zoom:e[2]}),b||C.setState({transform:e})},[w,b]);return(0,x.useEffect)(()=>{if(S.current){P.current=function({domNode:e,minZoom:t,maxZoom:n,translateExtent:r,viewport:o,onPanZoom:i,onPanZoomStart:a,onPanZoomEnd:s,onDraggingChange:l}){let d={isZoomingOrPanning:!1,usedRightMouseButton:!1,prevViewport:{x:0,y:0,zoom:0},mouseButton:0,timerId:void 0,panScrollTimeout:void 0,isPanScrolling:!1},u=e.getBoundingClientRect(),h=t_().scaleExtent([t,n]).translateExtent(r),f=eh(e).call(h);v({x:o.x,y:o.y,zoom:tB(o.zoom,t,n)},[[0,0],[u.width,u.height]],r);let p=f.on("wheel.zoom"),g=f.on("dblclick.zoom");function m(e,t){return f?new Promise(n=>{h?.interpolate(t?.interpolate==="linear"?tE.interpolate:eM).transform(nW(f,t?.duration,t?.ease,()=>n(!0)),e)}):Promise.resolve(!1)}function y(){h.on("zoom",null)}async function v(e,t,n){let r=nF(e),o=h?.constrain()(r,t,n);return o&&await m(o),new Promise(e=>e(o))}return h.wheelDelta(nZ),{update:function({noWheelClassName:e,noPanClassName:t,onPaneContextMenu:n,userSelectionActive:r,panOnScroll:o,panOnDrag:u,panOnScrollMode:m,panOnScrollSpeed:v,preventScrolling:x,zoomOnPinch:w,zoomOnScroll:b,zoomOnDoubleClick:_,zoomActivationKeyPressed:E,lib:k,onTransformChange:C,connectionInProgress:S,paneClickDistance:N,selectionOnDrag:M}){r&&!d.isZoomingOrPanning&&y();let j=o&&!E&&!r;h.clickDistance(M?1/0:!tG(N)||N<0?0:N);let O=j?function({zoomPanValues:e,noWheelClassName:t,d3Selection:n,d3Zoom:r,panOnScrollMode:o,panOnScrollSpeed:i,zoomOnPinch:a,onPanZoomStart:s,onPanZoom:l,onPanZoomEnd:d}){return u=>{if(nX(u,t))return u.ctrlKey&&u.preventDefault(),!1;u.preventDefault(),u.stopImmediatePropagation();let h=n.property("__zoom").k||1;if(u.ctrlKey&&a){let e=ef(u),t=h*Math.pow(2,nZ(u));r.scaleTo(n,t,e,u);return}let f=1===u.deltaMode?20:1,p=o===c.Vertical?0:u.deltaX*f,g=o===c.Horizontal?0:u.deltaY*f;!t5()&&u.shiftKey&&o!==c.Vertical&&(p=u.deltaY*f,g=0),r.translateBy(n,-(p/h)*i,-(g/h)*i,{internal:!0});let m=nV(n.property("__zoom"));clearTimeout(e.panScrollTimeout),e.isPanScrolling?(l?.(u,m),e.panScrollTimeout=setTimeout(()=>{d?.(u,m),e.isPanScrolling=!1},150)):(e.isPanScrolling=!0,s?.(u,m))}}({zoomPanValues:d,noWheelClassName:e,d3Selection:f,d3Zoom:h,panOnScrollMode:m,panOnScrollSpeed:v,zoomOnPinch:w,onPanZoomStart:a,onPanZoom:i,onPanZoomEnd:s}):function({noWheelClassName:e,preventScrolling:t,d3ZoomHandler:n}){return function(r,o){let i="wheel"===r.type,a=!t&&i&&!r.ctrlKey,s=nX(r,e);if(r.ctrlKey&&i&&s&&r.preventDefault(),a||s)return null;r.preventDefault(),n.call(this,r,o)}}({noWheelClassName:e,preventScrolling:x,d3ZoomHandler:p});if(f.on("wheel.zoom",O,{passive:!1}),!r){let e=function({zoomPanValues:e,onDraggingChange:t,onPanZoomStart:n}){return r=>{if(r.sourceEvent?.internal)return;let o=nV(r.transform);e.mouseButton=r.sourceEvent?.button||0,e.isZoomingOrPanning=!0,e.prevViewport=o,r.sourceEvent?.type==="mousedown"&&t(!0),n&&n?.(r.sourceEvent,o)}}({zoomPanValues:d,onDraggingChange:l,onPanZoomStart:a});h.on("start",e);let t=function({zoomPanValues:e,panOnDrag:t,onPaneContextMenu:n,onTransformChange:r,onPanZoom:o}){return i=>{e.usedRightMouseButton=!!(n&&nY(t,e.mouseButton??0)),i.sourceEvent?.sync||r([i.transform.x,i.transform.y,i.transform.k]),o&&!i.sourceEvent?.internal&&o?.(i.sourceEvent,nV(i.transform))}}({zoomPanValues:d,panOnDrag:u,onPaneContextMenu:!!n,onPanZoom:i,onTransformChange:C});h.on("zoom",t);let r=function({zoomPanValues:e,panOnDrag:t,panOnScroll:n,onDraggingChange:r,onPanZoomEnd:o,onPaneContextMenu:i}){return a=>{if(!a.sourceEvent?.internal&&(e.isZoomingOrPanning=!1,i&&nY(t,e.mouseButton??0)&&!e.usedRightMouseButton&&a.sourceEvent&&i(a.sourceEvent),e.usedRightMouseButton=!1,r(!1),o)){let t=nV(a.transform);e.prevViewport=t,clearTimeout(e.timerId),e.timerId=setTimeout(()=>{o?.(a.sourceEvent,t)},150*!!n)}}}({zoomPanValues:d,panOnDrag:u,panOnScroll:o,onPaneContextMenu:n,onPanZoomEnd:s,onDraggingChange:l});h.on("end",r)}let P=function({zoomActivationKeyPressed:e,zoomOnScroll:t,zoomOnPinch:n,panOnDrag:r,panOnScroll:o,zoomOnDoubleClick:i,userSelectionActive:a,noWheelClassName:s,noPanClassName:l,lib:d,connectionInProgress:u}){return c=>{let h=e||t,f=n&&c.ctrlKey,p="wheel"===c.type;if(1===c.button&&"mousedown"===c.type&&(nX(c,`${d}-flow__node`)||nX(c,`${d}-flow__edge`)))return!0;if(!r&&!h&&!o&&!i&&!n||a||u&&!p||nX(c,s)&&p||nX(c,l)&&(!p||o&&p&&!e)||!n&&c.ctrlKey&&p)return!1;if(!n&&"touchstart"===c.type&&c.touches?.length>1)return c.preventDefault(),!1;if(!h&&!o&&!f&&p||!r&&("mousedown"===c.type||"touchstart"===c.type)||Array.isArray(r)&&!r.includes(c.button)&&"mousedown"===c.type)return!1;let g=Array.isArray(r)&&r.includes(c.button)||!c.button||c.button<=1;return(!c.ctrlKey||p)&&g}}({zoomActivationKeyPressed:E,panOnDrag:u,zoomOnScroll:b,panOnScroll:o,zoomOnDoubleClick:_,zoomOnPinch:w,userSelectionActive:r,noPanClassName:t,noWheelClassName:e,lib:k,connectionInProgress:S});h.filter(P),_?f.on("dblclick.zoom",g):f.on("dblclick.zoom",null)},destroy:y,setViewport:async function e(e,t){let n=nF(e);return await m(n,t),new Promise(e=>e(n))},setViewportConstrained:v,getViewport:function(){let e=f?tf(f.node()):{x:0,y:0,k:1};return{x:e.x,y:e.y,zoom:e.k}},scaleTo:function(e,t){return f?new Promise(n=>{h?.interpolate(t?.interpolate==="linear"?tE.interpolate:eM).scaleTo(nW(f,t?.duration,t?.ease,()=>n(!0)),e)}):Promise.resolve(!1)},scaleBy:function(e,t){return f?new Promise(n=>{h?.interpolate(t?.interpolate==="linear"?tE.interpolate:eM).scaleBy(nW(f,t?.duration,t?.ease,()=>n(!0)),e)}):Promise.resolve(!1)},setScaleExtent:function(e){h?.scaleExtent(e)},setTranslateExtent:function(e){h?.translateExtent(e)},syncViewport:function(e){if(f){let t=nF(e),n=f.property("__zoom");(n.k!==e.zoom||n.x!==e.x||n.y!==e.y)&&h?.transform(f,t,null,{sync:!0})}},setClickDistance:function(e){let t=!tG(e)||e<0?0:e;h?.clickDistance(t)}}}({domNode:S.current,minZoom:u,maxZoom:h,translateExtent:d,viewport:l,onDraggingChange:e=>C.setState(t=>t.paneDragging===e?t:{paneDragging:e}),onPanZoomStart:(e,t)=>{let{onViewportChangeStart:n,onMoveStart:r}=C.getState();r?.(e,t),n?.(t)},onPanZoom:(e,t)=>{let{onViewportChange:n,onMove:r}=C.getState();r?.(e,t),n?.(t)},onPanZoomEnd:(e,t)=>{let{onViewportChangeEnd:n,onMoveEnd:r}=C.getState();r?.(e,t),n?.(t)}});let{x:e,y:t,zoom:n}=P.current.getViewport();return C.setState({panZoom:P.current,transform:[e,t,n],domNode:S.current.closest(".react-flow")}),()=>{P.current?.destroy()}}},[]),(0,x.useEffect)(()=>{P.current?.update({onPaneContextMenu:e,zoomOnScroll:t,zoomOnPinch:n,panOnScroll:r,panOnScrollSpeed:o,panOnScrollMode:i,zoomOnDoubleClick:a,panOnDrag:s,zoomActivationKeyPressed:O,preventScrolling:p,noPanClassName:y,userSelectionActive:N,noWheelClassName:m,lib:M,onTransformChange:A,connectionInProgress:j,selectionOnDrag:E,paneClickDistance:_})},[e,t,n,r,o,i,a,s,O,p,y,N,m,M,A,j,E,_]),(0,v.jsx)("div",{className:"react-flow__renderer",ref:S,style:rZ,children:g})}let rG=e=>({userSelectionActive:e.userSelectionActive,userSelectionRect:e.userSelectionRect});function rQ(){let{userSelectionActive:e,userSelectionRect:t}=ro(rG,n9);return e&&t?(0,v.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}let rJ=(e,t)=>n=>{n.target===t.current&&e?.(n)},r0=e=>({userSelectionActive:e.userSelectionActive,elementsSelectable:e.elementsSelectable,connectionInProgress:e.connection.inProgress,dragging:e.paneDragging});function r1({isSelecting:e,selectionKeyPressed:t,selectionMode:n=h.Full,panOnDrag:r,paneClickDistance:o,selectionOnDrag:i,onSelectionStart:a,onSelectionEnd:s,onPaneClick:l,onPaneContextMenu:d,onPaneScroll:u,onPaneMouseEnter:c,onPaneMouseMove:f,onPaneMouseLeave:p,children:g}){let m=ri(),{userSelectionActive:y,elementsSelectable:b,dragging:_,connectionInProgress:E}=ro(r0,n9),k=b&&(e||y),C=(0,x.useRef)(null),S=(0,x.useRef)(),N=(0,x.useRef)(new Set),M=(0,x.useRef)(new Set),j=(0,x.useRef)(!1),O=e=>{if(j.current||E){j.current=!1;return}l?.(e),m.getState().resetSelectedElements(),m.setState({nodesSelectionActive:!1})},P=!0===r||Array.isArray(r)&&r.includes(0);return(0,v.jsxs)("div",{className:w(["react-flow__pane",{draggable:P,dragging:_,selection:e}]),onClick:k?void 0:rJ(O,C),onContextMenu:rJ(e=>{Array.isArray(r)&&r?.includes(2)?e.preventDefault():d?.(e)},C),onWheel:rJ(u?e=>u(e):void 0,C),onPointerEnter:k?void 0:c,onPointerMove:k?e=>{let{userSelectionRect:r,transform:i,nodeLookup:s,edgeLookup:l,connectionLookup:d,triggerNodeChanges:u,triggerEdgeChanges:c,defaultEdgeOptions:f,resetSelectedElements:p}=m.getState();if(!S.current||!r)return;let{x:g,y:y}=ni(e.nativeEvent,S.current),{startX:v,startY:x}=r;if(!j.current){if(Math.hypot(g-v,y-x)<=(t?0:o))return;p(),a?.(e)}j.current=!0;let w={startX:v,startY:x,x:g<v?g:v,y:y<x?y:x,width:Math.abs(g-v),height:Math.abs(y-x)},b=N.current,_=M.current;N.current=new Set(tz(s,w,i,n===h.Partial,!0).map(e=>e.id)),M.current=new Set;let E=f?.selectable??!0;for(let e of N.current){let t=d.get(e);if(t)for(let{edgeId:e}of t.values()){let t=l.get(e);t&&(t.selectable??E)&&M.current.add(e)}}t9(b,N.current)||u(rL(s,N.current,!0)),t9(_,M.current)||c(rL(l,M.current)),m.setState({userSelectionRect:w,userSelectionActive:!0,nodesSelectionActive:!1})}:f,onPointerUp:k?e=>{0===e.button&&(e.target?.releasePointerCapture?.(e.pointerId),!y&&e.target===C.current&&m.getState().userSelectionRect&&O?.(e),m.setState({userSelectionActive:!1,userSelectionRect:null}),j.current&&(s?.(e),m.setState({nodesSelectionActive:N.current.size>0})))}:void 0,onPointerDownCapture:k?n=>{let{domNode:r}=m.getState();if(S.current=r?.getBoundingClientRect(),!S.current)return;let o=n.target===C.current;if(!o&&n.target.closest(".nokey")||!e||!(i&&o||t)||0!==n.button||!n.isPrimary)return;n.target?.setPointerCapture?.(n.pointerId),j.current=!1;let{x:a,y:s}=ni(n.nativeEvent,S.current);m.setState({userSelectionRect:{width:0,height:0,startX:a,startY:s,x:a,y:s}}),o||(n.stopPropagation(),n.preventDefault())}:void 0,onClickCapture:k?e=>{j.current&&(e.stopPropagation(),j.current=!1)}:void 0,onPointerLeave:p,ref:C,style:rZ,children:[g,(0,v.jsx)(rQ,{})]})}function r2({id:e,store:t,unselect:n=!1,nodeRef:r}){let o,{addSelectedNodes:i,unselectNodesAndEdges:a,multiSelectionActive:s,nodeLookup:l,onError:d}=t.getState(),u=l.get(e);u?(t.setState({nodesSelectionActive:!1}),u.selected?(n||u.selected&&s)&&(a({nodes:[u],edges:[]}),requestAnimationFrame(()=>r?.current?.blur())):i([e])):d?.("012",(o=e,`Node with id "${o}" does not exist, it may have been removed. This can happen when a node is deleted before the "onNodeClick" handler is called.`))}function r3({nodeRef:e,disabled:t=!1,noDragClassName:n,handleSelector:r,nodeId:o,isSelectable:i,nodeClickDistance:a}){let s=ri(),[l,d]=(0,x.useState)(!1),u=(0,x.useRef)();return(0,x.useEffect)(()=>{u.current=function({onNodeMouseDown:e,getStoreItems:t,onDragStart:n,onDrag:r,onDragStop:o}){let i={x:null,y:null},a=0,s=new Map,l=!1,d={x:0,y:0},u=null,c=!1,h=null,f=!1,p=!1,g=null;return{update:function({noDragClassName:m,handleSelector:y,domNode:v,isSelectable:x,nodeId:w,nodeClickDistance:b=0}){function _({x:e,y:n}){let{nodeLookup:o,nodeExtent:a,snapGrid:l,snapToGrid:d,nodeOrigin:u,onNodeDrag:c,onSelectionDrag:h,onError:f,updateNodePositions:m}=t();i={x:e,y:n};let y=!1,v=s.size>1,x=v&&a?tX(tI(s)):null,b=v&&d?function({dragItems:e,snapGrid:t,x:n,y:r}){let o=e.values().next().value;if(!o)return null;let i={x:n-o.distance.x,y:r-o.distance.y},a=tJ(i,t);return{x:a.x-i.x,y:a.y-i.y}}({dragItems:s,snapGrid:l,x:e,y:n}):null;for(let[t,r]of s){if(!o.has(t))continue;let i={x:e-r.distance.x,y:n-r.distance.y};d&&(i=b?{x:Math.round(i.x+b.x),y:Math.round(i.y+b.y)}:tJ(i,l));let s=null;if(v&&a&&!r.extent&&x){let{positionAbsolute:e}=r.internals,t=e.x-x.x+a[0][0],n=e.x+r.measured.width-x.x2+a[1][0];s=[[t,e.y-x.y+a[0][1]],[n,e.y+r.measured.height-x.y2+a[1][1]]]}let{position:c,positionAbsolute:h}=tL({nodeId:t,nextPosition:i,nodeLookup:o,nodeExtent:s||a,nodeOrigin:u,onError:f});y=y||r.position.x!==c.x||r.position.y!==c.y,r.position=c,r.internals.positionAbsolute=h}if(p=p||y,y&&(m(s,!0),g&&(r||c||!w&&h))){let[e,t]=nL({nodeId:w,dragItems:s,nodeLookup:o});r?.(g,s,e,t),c?.(g,e,t),w||h?.(g,t)}}async function E(){if(!u)return;let{transform:e,panBy:n,autoPanSpeed:r,autoPanOnNodeDrag:o}=t();if(!o){l=!1,cancelAnimationFrame(a);return}let[s,c]=tV(d,u,r);(0!==s||0!==c)&&(i.x=(i.x??0)-s/e[2],i.y=(i.y??0)-c/e[2],await n({x:s,y:c})&&_(i)),a=requestAnimationFrame(E)}function k(r){let{nodeLookup:o,multiSelectionActive:a,nodesDraggable:l,transform:d,snapGrid:h,snapToGrid:f,selectNodesOnDrag:p,onNodeDragStart:g,onSelectionDragStart:m,unselectNodesAndEdges:y}=t();c=!0,p&&x||a||!w||o.get(w)?.selected||y(),x&&p&&w&&e?.(w);let v=ne(r.sourceEvent,{transform:d,snapGrid:h,snapToGrid:f,containerBounds:u});if(i=v,(s=function(e,t,n,r){let o=new Map;for(let[i,a]of e)if((a.selected||a.id===r)&&(!a.parentId||!function e(t,n){if(!t.parentId)return!1;let r=n.get(t.parentId);return!!r&&(!!r.selected||e(r,n))}(a,e))&&(a.draggable||t&&void 0===a.draggable)){let t=e.get(i);t&&o.set(i,{id:i,position:t.position||{x:0,y:0},distance:{x:n.x-t.internals.positionAbsolute.x,y:n.y-t.internals.positionAbsolute.y},extent:t.extent,parentId:t.parentId,origin:t.origin,expandParent:t.expandParent,internals:{positionAbsolute:t.internals.positionAbsolute||{x:0,y:0}},measured:{width:t.measured.width??0,height:t.measured.height??0}})}return o}(o,l,v,w)).size>0&&(n||g||!w&&m)){let[e,t]=nL({nodeId:w,dragItems:s,nodeLookup:o});n?.(r.sourceEvent,s,e,t),g?.(r.sourceEvent,e,t),w||m?.(r.sourceEvent,t)}}h=eh(v);let C=eS().clickDistance(b).on("start",e=>{let{domNode:n,nodeDragThreshold:r,transform:o,snapGrid:a,snapToGrid:s}=t();u=n?.getBoundingClientRect()||null,f=!1,p=!1,g=e.sourceEvent,0===r&&k(e),i=ne(e.sourceEvent,{transform:o,snapGrid:a,snapToGrid:s,containerBounds:u}),d=ni(e.sourceEvent,u)}).on("drag",e=>{let{autoPanOnNodeDrag:n,transform:r,snapGrid:o,snapToGrid:a,nodeDragThreshold:h,nodeLookup:p}=t(),m=ne(e.sourceEvent,{transform:r,snapGrid:o,snapToGrid:a,containerBounds:u});if(g=e.sourceEvent,("touchmove"===e.sourceEvent.type&&e.sourceEvent.touches.length>1||w&&!p.has(w))&&(f=!0),!f){if(!l&&n&&c&&(l=!0,E()),!c){let t=ni(e.sourceEvent,u),n=t.x-d.x,r=t.y-d.y;Math.sqrt(n*n+r*r)>h&&k(e)}(i.x!==m.xSnapped||i.y!==m.ySnapped)&&s&&c&&(d=ni(e.sourceEvent,u),_(m))}}).on("end",e=>{if(c&&!f&&(l=!1,c=!1,cancelAnimationFrame(a),s.size>0)){let{nodeLookup:n,updateNodePositions:r,onNodeDragStop:i,onSelectionDragStop:a}=t();if(p&&(r(s,!1),p=!1),o||i||!w&&a){let[t,r]=nL({nodeId:w,dragItems:s,nodeLookup:n,dragging:!1});o?.(e.sourceEvent,s,t,r),i?.(e.sourceEvent,t,r),w||a?.(e.sourceEvent,r)}}}).filter(e=>{let t=e.target;return!e.button&&(!m||!nD(t,`.${m}`,v))&&(!y||nD(t,y,v))});h.call(C)},destroy:function(){h?.on(".drag",null)}}}({getStoreItems:()=>s.getState(),onNodeMouseDown:t=>{r2({id:t,store:s,nodeRef:e})},onDragStart:()=>{d(!0)},onDragStop:()=>{d(!1)}})},[]),(0,x.useEffect)(()=>{if(!t&&e.current&&u.current)return u.current.update({noDragClassName:n,handleSelector:r,domNode:e.current,isSelectable:i,nodeId:o,nodeClickDistance:a}),()=>{u.current?.destroy()}},[n,r,t,i,e,o,a]),l}function r5(){let e=ri();return(0,x.useCallback)(t=>{let{nodeExtent:n,snapToGrid:r,snapGrid:o,nodesDraggable:i,onError:a,updateNodePositions:s,nodeLookup:l,nodeOrigin:d}=e.getState(),u=new Map,c=e=>e.selected&&(e.draggable||i&&void 0===e.draggable),h=r?o[0]:5,f=r?o[1]:5,p=t.direction.x*h*t.factor,g=t.direction.y*f*t.factor;for(let[,e]of l){if(!c(e))continue;let t={x:e.internals.positionAbsolute.x+p,y:e.internals.positionAbsolute.y+g};r&&(t=tJ(t,o));let{position:i,positionAbsolute:s}=tL({nodeId:e.id,nextPosition:t,nodeLookup:l,nodeExtent:n,nodeOrigin:d,onError:a});e.position=i,e.internals.positionAbsolute=s,u.set(e.id,e)}s(u)},[])}let r4=(0,x.createContext)(null),r6=r4.Provider;r4.Consumer;let r7=()=>(0,x.useContext)(r4),r8=e=>({connectOnClick:e.connectOnClick,noPanClassName:e.noPanClassName,rfId:e.rfId}),r9=(0,x.memo)(r$(function({type:e="source",position:t=g.Top,isValidConnection:n,isConnectable:r=!0,isConnectableStart:o=!0,isConnectableEnd:i=!0,id:a,onConnect:s,children:l,className:d,onMouseDown:c,onTouchStart:h,...f},p){let m=a||null,y="target"===e,x=ri(),b=r7(),{connectOnClick:_,noPanClassName:E,rfId:k}=ro(r8,n9),{connectingFrom:C,connectingTo:S,clickConnecting:N,isPossibleEndHandle:M,connectionInProcess:j,clickConnectionInProcess:O,valid:P}=ro(t=>{let{connectionClickStartHandle:n,connectionMode:r,connection:o}=t,{fromHandle:i,toHandle:a,isValid:s}=o,l=a?.nodeId===b&&a?.id===m&&a?.type===e;return{connectingFrom:i?.nodeId===b&&i?.id===m&&i?.type===e,connectingTo:l,clickConnecting:n?.nodeId===b&&n?.id===m&&n?.type===e,isPossibleEndHandle:r===u.Strict?i?.type!==e:b!==i?.nodeId||m!==i?.id,connectionInProcess:!!i,clickConnectionInProcess:!!n,valid:l&&s}},n9);b||x.getState().onError?.("010","Handle: No node id found. Make sure to only use a Handle inside a custom Node.");let A=e=>{let{defaultEdgeOptions:t,onConnect:n,hasDefaultEdges:r}=x.getState(),o={...t,...e};if(r){let{edges:e,setEdges:t}=x.getState();t(nf(o,e))}n?.(o),s?.(o)},I=e=>{if(!b)return;let t="clientX"in e.nativeEvent;if(o&&(t&&0===e.button||!t)){let t=x.getState();nH(e.nativeEvent,{handleDomNode:e.currentTarget,autoPanOnConnect:t.autoPanOnConnect,connectionMode:t.connectionMode,connectionRadius:t.connectionRadius,domNode:t.domNode,nodeLookup:t.nodeLookup,lib:t.lib,isTarget:y,handleId:m,nodeId:b,flowId:t.rfId,panBy:t.panBy,cancelConnection:t.cancelConnection,onConnectStart:t.onConnectStart,onConnectEnd:(...e)=>x.getState().onConnectEnd?.(...e),updateConnection:t.updateConnection,onConnect:A,isValidConnection:n||((...e)=>x.getState().isValidConnection?.(...e)??!0),getTransform:()=>x.getState().transform,getFromHandle:()=>x.getState().connection.fromHandle,autoPanSpeed:t.autoPanSpeed,dragThreshold:t.connectionDragThreshold})}t?c?.(e):h?.(e)};return(0,v.jsx)("div",{"data-handleid":m,"data-nodeid":b,"data-handlepos":t,"data-id":`${k}-${b}-${m}-${e}`,className:w(["react-flow__handle",`react-flow__handle-${t}`,"nodrag",E,d,{source:!y,target:y,connectable:r,connectablestart:o,connectableend:i,clickconnecting:N,connectingfrom:C,connectingto:S,valid:P,connectionindicator:r&&(!j||M)&&(j||O?i:o)}]),onMouseDown:I,onTouchStart:I,onClick:_?t=>{let{onClickConnectStart:r,onClickConnectEnd:i,connectionClickStartHandle:a,connectionMode:s,isValidConnection:l,lib:d,rfId:u,nodeLookup:c,connection:h}=x.getState();if(!b||!a&&!o)return;if(!a){r?.(t.nativeEvent,{nodeId:b,handleId:m,handleType:e}),x.setState({connectionClickStartHandle:{nodeId:b,type:e,id:m}});return}let f=nn(t.target),p=n||l,{connection:g,isValid:y}=n$(t.nativeEvent,{handle:{nodeId:b,id:m,type:e},connectionMode:s,fromNodeId:a.nodeId,fromHandleId:a.id||null,fromType:a.type,isValidConnection:p,flowId:u,doc:f,lib:d,nodeLookup:c});y&&g&&A(g);let v=structuredClone(h);delete v.inProgress,v.toPosition=v.toHandle?v.toHandle.position:null,i?.(t,v),x.setState({connectionClickStartHandle:null})}:void 0,ref:p,...f,children:l})})),oe={ArrowUp:{x:0,y:-1},ArrowDown:{x:0,y:1},ArrowLeft:{x:-1,y:0},ArrowRight:{x:1,y:0}},ot={input:function({data:e,isConnectable:t,sourcePosition:n=g.Bottom}){return(0,v.jsxs)(v.Fragment,{children:[e?.label,(0,v.jsx)(r9,{type:"source",position:n,isConnectable:t})]})},default:function({data:e,isConnectable:t,targetPosition:n=g.Top,sourcePosition:r=g.Bottom}){return(0,v.jsxs)(v.Fragment,{children:[(0,v.jsx)(r9,{type:"target",position:n,isConnectable:t}),e?.label,(0,v.jsx)(r9,{type:"source",position:r,isConnectable:t})]})},output:function({data:e,isConnectable:t,targetPosition:n=g.Top}){return(0,v.jsxs)(v.Fragment,{children:[(0,v.jsx)(r9,{type:"target",position:n,isConnectable:t}),e?.label]})},group:function(){return null}},on=e=>{let{width:t,height:n,x:r,y:o}=tI(e.nodeLookup,{filter:e=>!!e.selected});return{width:tG(t)?t:null,height:tG(n)?n:null,userSelectionActive:e.userSelectionActive,transformString:`translate(${e.transform[0]}px,${e.transform[1]}px) scale(${e.transform[2]}) translate(${r}px,${o}px)`}};function or({onSelectionContextMenu:e,noPanClassName:t,disableKeyboardA11y:n}){let r=ri(),{width:o,height:i,transformString:a,userSelectionActive:s}=ro(on,n9),l=r5(),d=(0,x.useRef)(null);(0,x.useEffect)(()=>{n||d.current?.focus({preventScroll:!0})},[n]);let u=!s&&null!==o&&null!==i;if(r3({nodeRef:d,disabled:!u}),!u)return null;let c=e?t=>{e(t,r.getState().nodes.filter(e=>e.selected))}:void 0;return(0,v.jsx)("div",{className:w(["react-flow__nodesselection","react-flow__container",t]),style:{transform:a},children:(0,v.jsx)("div",{ref:d,className:"react-flow__nodesselection-rect",onContextMenu:c,tabIndex:n?void 0:-1,onKeyDown:n?void 0:e=>{Object.prototype.hasOwnProperty.call(oe,e.key)&&(e.preventDefault(),l({direction:oe[e.key],factor:e.shiftKey?4:1}))},style:{width:o,height:i}})})}let oo="u">typeof window?window:void 0,oi=e=>({nodesSelectionActive:e.nodesSelectionActive,userSelectionActive:e.userSelectionActive});function oa({children:e,onPaneClick:t,onPaneMouseEnter:n,onPaneMouseMove:r,onPaneMouseLeave:o,onPaneContextMenu:i,onPaneScroll:a,paneClickDistance:s,deleteKeyCode:l,selectionKeyCode:d,selectionOnDrag:u,selectionMode:c,onSelectionStart:h,onSelectionEnd:f,multiSelectionKeyCode:p,panActivationKeyCode:g,zoomActivationKeyCode:m,elementsSelectable:y,zoomOnScroll:w,zoomOnPinch:b,panOnScroll:_,panOnScrollSpeed:E,panOnScrollMode:k,zoomOnDoubleClick:C,panOnDrag:S,defaultViewport:N,translateExtent:M,minZoom:j,maxZoom:O,preventScrolling:P,onSelectionContextMenu:A,noWheelClassName:I,noPanClassName:z,disableKeyboardA11y:D,onViewportChange:L,isControlledViewport:R}){let{nodesSelectionActive:B,userSelectionActive:T}=ro(oi,n9),$=rP(d,{target:oo}),H=rP(g,{target:oo}),V=H||S,F=H||_,X=u&&!0!==V,Y=$||T||X;return!function({deleteKeyCode:e,multiSelectionKeyCode:t}){let n=ri(),{deleteElements:r}=rY(),o=rP(e,{actInsideInputWithModifier:!1}),i=rP(t,{target:rW});(0,x.useEffect)(()=>{if(o){let{edges:e,nodes:t}=n.getState();r({nodes:t.filter(rK),edges:e.filter(rK)}),n.setState({nodesSelectionActive:!1})}},[o]),(0,x.useEffect)(()=>{n.setState({multiSelectionActive:i})},[i])}({deleteKeyCode:l,multiSelectionKeyCode:p}),(0,v.jsx)(rU,{onPaneContextMenu:i,elementsSelectable:y,zoomOnScroll:w,zoomOnPinch:b,panOnScroll:F,panOnScrollSpeed:E,panOnScrollMode:k,zoomOnDoubleClick:C,panOnDrag:!$&&V,defaultViewport:N,translateExtent:M,minZoom:j,maxZoom:O,zoomActivationKeyCode:m,preventScrolling:P,noWheelClassName:I,noPanClassName:z,onViewportChange:L,isControlledViewport:R,paneClickDistance:s,selectionOnDrag:X,children:(0,v.jsxs)(r1,{onSelectionStart:h,onSelectionEnd:f,onPaneClick:t,onPaneMouseEnter:n,onPaneMouseMove:r,onPaneMouseLeave:o,onPaneContextMenu:i,onPaneScroll:a,panOnDrag:V,isSelecting:!!Y,selectionMode:c,selectionKeyPressed:$,paneClickDistance:s,selectionOnDrag:X,children:[e,B&&(0,v.jsx)(or,{onSelectionContextMenu:A,noPanClassName:z,disableKeyboardA11y:D})]})})}oa.displayName="FlowRenderer";let os=(0,x.memo)(oa),ol=e=>e.updateNodeInternals;var od=(0,x.memo)(function({id:e,onClick:t,onMouseEnter:n,onMouseMove:r,onMouseLeave:o,onContextMenu:i,onDoubleClick:a,nodesDraggable:s,elementsSelectable:l,nodesConnectable:d,nodesFocusable:u,resizeObserver:c,noDragClassName:h,noPanClassName:f,disableKeyboardA11y:p,rfId:g,nodeTypes:m,nodeClickDistance:y,onError:b}){let _,{node:E,internals:k,isParent:C}=ro(t=>{let n=t.nodeLookup.get(e),r=t.parentLookup.has(e);return{node:n,internals:n.internals,isParent:r}},n9),S=E.type||"default",N=m?.[S]||ot[S];void 0===N&&(b?.("003",(_=S,`Node type "${_}" not found. Using fallback type "default".`)),S="default",N=m?.default||ot.default);let M=!!(E.draggable||s&&void 0===E.draggable),j=!!(E.selectable||l&&void 0===E.selectable),O=!!(E.connectable||d&&void 0===E.connectable),P=!!(E.focusable||u&&void 0===E.focusable),A=ri(),I=t7(E),z=function({node:e,nodeType:t,hasDimensions:n,resizeObserver:r}){let o=ri(),i=(0,x.useRef)(null),a=(0,x.useRef)(null),s=(0,x.useRef)(e.sourcePosition),l=(0,x.useRef)(e.targetPosition),d=(0,x.useRef)(t),u=n&&!!e.internals.handleBounds;return(0,x.useEffect)(()=>{!i.current||e.hidden||u&&a.current===i.current||(a.current&&r?.unobserve(a.current),r?.observe(i.current),a.current=i.current)},[u,e.hidden]),(0,x.useEffect)(()=>()=>{a.current&&(r?.unobserve(a.current),a.current=null)},[]),(0,x.useEffect)(()=>{if(i.current){let n=d.current!==t,r=s.current!==e.sourcePosition,a=l.current!==e.targetPosition;(n||r||a)&&(d.current=t,s.current=e.sourcePosition,l.current=e.targetPosition,o.getState().updateNodeInternals(new Map([[e.id,{id:e.id,nodeElement:i.current,force:!0}]])))}},[e.id,t,e.sourcePosition,e.targetPosition]),i}({node:E,nodeType:S,hasDimensions:I,resizeObserver:c}),D=r3({nodeRef:z,disabled:E.hidden||!M,noDragClassName:h,handleSelector:E.dragHandle,nodeId:e,isSelectable:j,nodeClickDistance:y}),L=r5();if(E.hidden)return null;let R=t6(E),B=void 0===E.internals.handleBounds?{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},T=j||M||t||n||r||o,$=n?e=>n(e,{...k.userNode}):void 0,H=r?e=>r(e,{...k.userNode}):void 0,V=o?e=>o(e,{...k.userNode}):void 0,F=i?e=>i(e,{...k.userNode}):void 0,X=a?e=>a(e,{...k.userNode}):void 0;return(0,v.jsx)("div",{className:w(["react-flow__node",`react-flow__node-${S}`,{[f]:M},E.className,{selected:E.selected,selectable:j,parent:C,draggable:M,dragging:D}]),ref:z,style:{zIndex:k.z,transform:`translate(${k.positionAbsolute.x}px,${k.positionAbsolute.y}px)`,pointerEvents:T?"all":"none",visibility:I?"visible":"hidden",...E.style,...B},"data-id":e,"data-testid":`rf__node-${e}`,onMouseEnter:$,onMouseMove:H,onMouseLeave:V,onContextMenu:F,onClick:n=>{let{selectNodesOnDrag:r,nodeDragThreshold:o}=A.getState();j&&(!r||!M||o>0)&&r2({id:e,store:A,nodeRef:z}),t&&t(n,{...k.userNode})},onDoubleClick:X,onKeyDown:P?t=>{if(!no(t.nativeEvent)&&!p){if(tC.includes(t.key)&&j)r2({id:e,store:A,unselect:"Escape"===t.key,nodeRef:z});else if(M&&E.selected&&Object.prototype.hasOwnProperty.call(oe,t.key)){t.preventDefault();let{ariaLabelConfig:e}=A.getState();A.setState({ariaLiveMessage:e["node.a11yDescription.ariaLiveMessage"]({direction:t.key.replace("Arrow","").toLowerCase(),x:~~k.positionAbsolute.x,y:~~k.positionAbsolute.y})}),L({direction:oe[t.key],factor:t.shiftKey?4:1})}}}:void 0,tabIndex:P?0:void 0,onFocus:P?()=>{if(p||!z.current?.matches(":focus-visible"))return;let{transform:t,width:n,height:r,autoPanOnNodeFocus:o,setCenter:i}=A.getState();!o||tz(new Map([[e,E]]),{x:0,y:0,width:n,height:r},t,!0).length>0||i(E.position.x+R.width/2,E.position.y+R.height/2,{zoom:t[2]})}:void 0,role:E.ariaRole??(P?"group":void 0),"aria-roledescription":"node","aria-describedby":p?void 0:`${rl}-${g}`,"aria-label":E.ariaLabel,...E.domAttributes,children:(0,v.jsx)(r6,{value:e,children:(0,v.jsx)(N,{id:e,data:E.data,type:S,positionAbsoluteX:k.positionAbsolute.x,positionAbsoluteY:k.positionAbsolute.y,selected:E.selected??!1,selectable:j,draggable:M,deletable:E.deletable??!0,isConnectable:O,sourcePosition:E.sourcePosition,targetPosition:E.targetPosition,dragging:D,dragHandle:E.dragHandle,zIndex:k.z,parentId:E.parentId,...R})})})});let ou=e=>({nodesDraggable:e.nodesDraggable,nodesConnectable:e.nodesConnectable,nodesFocusable:e.nodesFocusable,elementsSelectable:e.elementsSelectable,onError:e.onError});function oc(e){var t;let{nodesDraggable:n,nodesConnectable:r,nodesFocusable:o,elementsSelectable:i,onError:a}=ro(ou,n9),s=(t=e.onlyRenderVisibleElements,ro((0,x.useCallback)(e=>t?tz(e.nodeLookup,{x:0,y:0,width:e.width,height:e.height},e.transform,!0).map(e=>e.id):Array.from(e.nodeLookup.keys()),[t]),n9)),l=function(){let e=ro(ol),[t]=(0,x.useState)(()=>"u"<typeof ResizeObserver?null:new ResizeObserver(t=>{let n=new Map;t.forEach(e=>{let t=e.target.getAttribute("data-id");n.set(t,{id:t,nodeElement:e.target,force:!0})}),e(n)}));return(0,x.useEffect)(()=>()=>{t?.disconnect()},[t]),t}();return(0,v.jsx)("div",{className:"react-flow__nodes",style:rZ,children:s.map(t=>(0,v.jsx)(od,{id:t,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:l,nodesDraggable:n,nodesConnectable:r,nodesFocusable:o,elementsSelectable:i,nodeClickDistance:e.nodeClickDistance,onError:a},t))})}oc.displayName="NodeRenderer";let oh=(0,x.memo)(oc),of={[p.Arrow]:({color:e="none",strokeWidth:t=1})=>{let n={strokeWidth:t,...e&&{stroke:e}};return(0,v.jsx)("polyline",{className:"arrow",style:n,strokeLinecap:"round",fill:"none",strokeLinejoin:"round",points:"-5,-4 0,0 -5,4"})},[p.ArrowClosed]:({color:e="none",strokeWidth:t=1})=>{let n={strokeWidth:t,...e&&{stroke:e,fill:e}};return(0,v.jsx)("polyline",{className:"arrowclosed",style:n,strokeLinecap:"round",strokeLinejoin:"round",points:"-5,-4 0,0 -5,4 -5,-4"})}},op=({id:e,type:t,color:n,width:r=12.5,height:o=12.5,markerUnits:i="strokeWidth",strokeWidth:a,orient:s="auto-start-reverse"})=>{let l,d=(l=ri(),(0,x.useMemo)(()=>{let e;return Object.prototype.hasOwnProperty.call(of,t)?of[t]:(l.getState().onError?.("009",(e=t,`Marker type "${e}" doesn't exist.`)),null)},[t]));return d?(0,v.jsx)("marker",{className:"react-flow__arrowhead",id:e,markerWidth:`${r}`,markerHeight:`${o}`,viewBox:"-10 -10 20 20",markerUnits:i,orient:s,refX:"0",refY:"0",children:(0,v.jsx)(d,{color:n,strokeWidth:a})}):null},og=({defaultColor:e,rfId:t})=>{let n=ro(e=>e.edges),r=ro(e=>e.defaultEdgeOptions),o=(0,x.useMemo)(()=>(function(e,{id:t,defaultColor:n,defaultMarkerStart:r,defaultMarkerEnd:o}){let i=new Set;return e.reduce((e,a)=>([a.markerStart||r,a.markerEnd||o].forEach(r=>{if(r&&"object"==typeof r){let o=nE(r,t);i.has(o)||(e.push({id:o,color:r.color||n,...r}),i.add(o))}}),e),[]).sort((e,t)=>e.id.localeCompare(t.id))})(n,{id:t,defaultColor:e,defaultMarkerStart:r?.markerStart,defaultMarkerEnd:r?.markerEnd}),[n,r,t,e]);return o.length?(0,v.jsx)("svg",{className:"react-flow__marker","aria-hidden":"true",children:(0,v.jsx)("defs",{children:o.map(e=>(0,v.jsx)(op,{id:e.id,type:e.type,color:e.color,width:e.width,height:e.height,markerUnits:e.markerUnits,strokeWidth:e.strokeWidth,orient:e.orient},e.id))})}):null};og.displayName="MarkerDefinitions";var om=(0,x.memo)(og);function oy({x:e,y:t,label:n,labelStyle:r,labelShowBg:o=!0,labelBgStyle:i,labelBgPadding:a=[2,4],labelBgBorderRadius:s=2,children:l,className:d,...u}){let[c,h]=(0,x.useState)({x:1,y:0,width:0,height:0}),f=w(["react-flow__edge-textwrapper",d]),p=(0,x.useRef)(null);return((0,x.useEffect)(()=>{if(p.current){let e=p.current.getBBox();h({x:e.x,y:e.y,width:e.width,height:e.height})}},[n]),n)?(0,v.jsxs)("g",{transform:`translate(${e-c.width/2} ${t-c.height/2})`,className:f,visibility:c.width?"visible":"hidden",...u,children:[o&&(0,v.jsx)("rect",{width:c.width+2*a[0],x:-a[0],y:-a[1],height:c.height+2*a[1],className:"react-flow__edge-textbg",style:i,rx:s,ry:s}),(0,v.jsx)("text",{className:"react-flow__edge-text",y:c.height/2,dy:"0.3em",ref:p,style:r,children:n}),l]}):null}oy.displayName="EdgeText";let ov=(0,x.memo)(oy);function ox({path:e,labelX:t,labelY:n,label:r,labelStyle:o,labelShowBg:i,labelBgStyle:a,labelBgPadding:s,labelBgBorderRadius:l,interactionWidth:d=20,...u}){return(0,v.jsxs)(v.Fragment,{children:[(0,v.jsx)("path",{...u,d:e,fill:"none",className:w(["react-flow__edge-path",u.className])}),d?(0,v.jsx)("path",{d:e,fill:"none",strokeOpacity:0,strokeWidth:d,className:"react-flow__edge-interaction"}):null,r&&tG(t)&&tG(n)?(0,v.jsx)(ov,{x:t,y:n,label:r,labelStyle:o,labelShowBg:i,labelBgStyle:a,labelBgPadding:s,labelBgBorderRadius:l}):null]})}function ow({pos:e,x1:t,y1:n,x2:r,y2:o}){return e===g.Left||e===g.Right?[.5*(t+r),n]:[t,.5*(n+o)]}function ob({sourceX:e,sourceY:t,sourcePosition:n=g.Bottom,targetX:r,targetY:o,targetPosition:i=g.Top}){let[a,s]=ow({pos:n,x1:e,y1:t,x2:r,y2:o}),[l,d]=ow({pos:i,x1:r,y1:o,x2:e,y2:t}),[u,c,h,f]=ns({sourceX:e,sourceY:t,targetX:r,targetY:o,sourceControlX:a,sourceControlY:s,targetControlX:l,targetControlY:d});return[`M${e},${t} C${a},${s} ${l},${d} ${r},${o}`,u,c,h,f]}function o_(e){return(0,x.memo)(({id:t,sourceX:n,sourceY:r,targetX:o,targetY:i,sourcePosition:a,targetPosition:s,label:l,labelStyle:d,labelShowBg:u,labelBgStyle:c,labelBgPadding:h,labelBgBorderRadius:f,style:p,markerEnd:g,markerStart:m,interactionWidth:y})=>{let[x,w,b]=ob({sourceX:n,sourceY:r,sourcePosition:a,targetX:o,targetY:i,targetPosition:s}),_=e.isInternal?void 0:t;return(0,v.jsx)(ox,{id:_,path:x,labelX:w,labelY:b,label:l,labelStyle:d,labelShowBg:u,labelBgStyle:c,labelBgPadding:h,labelBgBorderRadius:f,style:p,markerEnd:g,markerStart:m,interactionWidth:y})})}let oE=o_({isInternal:!1}),ok=o_({isInternal:!0});function oC(e){return(0,x.memo)(({id:t,sourceX:n,sourceY:r,targetX:o,targetY:i,label:a,labelStyle:s,labelShowBg:l,labelBgStyle:d,labelBgPadding:u,labelBgBorderRadius:c,style:h,sourcePosition:f=g.Bottom,targetPosition:p=g.Top,markerEnd:m,markerStart:y,pathOptions:x,interactionWidth:w})=>{let[b,_,E]=nv({sourceX:n,sourceY:r,sourcePosition:f,targetX:o,targetY:i,targetPosition:p,borderRadius:x?.borderRadius,offset:x?.offset,stepPosition:x?.stepPosition}),k=e.isInternal?void 0:t;return(0,v.jsx)(ox,{id:k,path:b,labelX:_,labelY:E,label:a,labelStyle:s,labelShowBg:l,labelBgStyle:d,labelBgPadding:u,labelBgBorderRadius:c,style:h,markerEnd:m,markerStart:y,interactionWidth:w})})}oE.displayName="SimpleBezierEdge",ok.displayName="SimpleBezierEdgeInternal";let oS=oC({isInternal:!1}),oN=oC({isInternal:!0});function oM(e){return(0,x.memo)(({id:t,...n})=>{let r=e.isInternal?void 0:t;return(0,v.jsx)(oS,{...n,id:r,pathOptions:(0,x.useMemo)(()=>({borderRadius:0,offset:n.pathOptions?.offset}),[n.pathOptions?.offset])})})}oS.displayName="SmoothStepEdge",oN.displayName="SmoothStepEdgeInternal";let oj=oM({isInternal:!1}),oO=oM({isInternal:!0});function oP(e){return(0,x.memo)(({id:t,sourceX:n,sourceY:r,targetX:o,targetY:i,label:a,labelStyle:s,labelShowBg:l,labelBgStyle:d,labelBgPadding:u,labelBgBorderRadius:c,style:h,markerEnd:f,markerStart:p,interactionWidth:g})=>{let[m,y,x]=np({sourceX:n,sourceY:r,targetX:o,targetY:i}),w=e.isInternal?void 0:t;return(0,v.jsx)(ox,{id:w,path:m,labelX:y,labelY:x,label:a,labelStyle:s,labelShowBg:l,labelBgStyle:d,labelBgPadding:u,labelBgBorderRadius:c,style:h,markerEnd:f,markerStart:p,interactionWidth:g})})}oj.displayName="StepEdge",oO.displayName="StepEdgeInternal";let oA=oP({isInternal:!1}),oI=oP({isInternal:!0});function oz(e){return(0,x.memo)(({id:t,sourceX:n,sourceY:r,targetX:o,targetY:i,sourcePosition:a=g.Bottom,targetPosition:s=g.Top,label:l,labelStyle:d,labelShowBg:u,labelBgStyle:c,labelBgPadding:h,labelBgBorderRadius:f,style:p,markerEnd:m,markerStart:y,pathOptions:x,interactionWidth:w})=>{let[b,_,E]=nu({sourceX:n,sourceY:r,sourcePosition:a,targetX:o,targetY:i,targetPosition:s,curvature:x?.curvature}),k=e.isInternal?void 0:t;return(0,v.jsx)(ox,{id:k,path:b,labelX:_,labelY:E,label:l,labelStyle:d,labelShowBg:u,labelBgStyle:c,labelBgPadding:h,labelBgBorderRadius:f,style:p,markerEnd:m,markerStart:y,interactionWidth:w})})}oA.displayName="StraightEdge",oI.displayName="StraightEdgeInternal";let oD=oz({isInternal:!1}),oL=oz({isInternal:!0});oD.displayName="BezierEdge",oL.displayName="BezierEdgeInternal";let oR={default:oL,straight:oI,step:oO,smoothstep:oN,simplebezier:ok},oB={sourceX:null,sourceY:null,targetX:null,targetY:null,sourcePosition:null,targetPosition:null},oT="react-flow__edgeupdater";function o$({position:e,centerX:t,centerY:n,radius:r=10,onMouseDown:o,onMouseEnter:i,onMouseOut:a,type:s}){return(0,v.jsx)("circle",{onMouseDown:o,onMouseEnter:i,onMouseOut:a,className:w([oT,`${oT}-${s}`]),cx:e===g.Left?t-r:e===g.Right?t+r:t,cy:e===g.Top?n-r:e===g.Bottom?n+r:n,r:r,stroke:"transparent",fill:"transparent"})}function oH({isReconnectable:e,reconnectRadius:t,edge:n,sourceX:r,sourceY:o,targetX:i,targetY:a,sourcePosition:s,targetPosition:l,onReconnect:d,onReconnectStart:u,onReconnectEnd:c,setReconnecting:h,setUpdateHover:f}){let p=ri(),g=(e,t)=>{if(0!==e.button)return;let{autoPanOnConnect:r,domNode:o,connectionMode:i,connectionRadius:a,lib:s,onConnectStart:l,cancelConnection:f,nodeLookup:g,rfId:m,panBy:y,updateConnection:v}=p.getState(),x="target"===t.type;nH(e.nativeEvent,{autoPanOnConnect:r,connectionMode:i,connectionRadius:a,domNode:o,handleId:t.id,nodeId:t.nodeId,nodeLookup:g,isTarget:x,edgeUpdaterType:t.type,lib:s,flowId:m,cancelConnection:f,panBy:y,isValidConnection:(...e)=>p.getState().isValidConnection?.(...e)??!0,onConnect:e=>d?.(n,e),onConnectStart:(r,o)=>{h(!0),u?.(e,n,t.type),l?.(r,o)},onConnectEnd:(...e)=>p.getState().onConnectEnd?.(...e),onReconnectEnd:(e,r)=>{h(!1),c?.(e,n,t.type,r)},updateConnection:v,getTransform:()=>p.getState().transform,getFromHandle:()=>p.getState().connection.fromHandle,dragThreshold:p.getState().connectionDragThreshold,handleDomNode:e.currentTarget})},m=()=>f(!0),y=()=>f(!1);return(0,v.jsxs)(v.Fragment,{children:[(!0===e||"source"===e)&&(0,v.jsx)(o$,{position:s,centerX:r,centerY:o,radius:t,onMouseDown:e=>g(e,{nodeId:n.target,id:n.targetHandle??null,type:"target"}),onMouseEnter:m,onMouseOut:y,type:"source"}),(!0===e||"target"===e)&&(0,v.jsx)(o$,{position:l,centerX:i,centerY:a,radius:t,onMouseDown:e=>g(e,{nodeId:n.source,id:n.sourceHandle??null,type:"source"}),onMouseEnter:m,onMouseOut:y,type:"target"})]})}var oV=(0,x.memo)(function({id:e,edgesFocusable:t,edgesReconnectable:n,elementsSelectable:r,onClick:o,onDoubleClick:i,onContextMenu:a,onMouseEnter:s,onMouseMove:l,onMouseLeave:d,reconnectRadius:c,onReconnect:h,onReconnectStart:f,onReconnectEnd:p,rfId:m,edgeTypes:y,noPanClassName:b,onError:_,disableKeyboardA11y:E}){let k,C=ro(t=>t.edgeLookup.get(e)),S=ro(e=>e.defaultEdgeOptions),N=(C=S?{...S,...C}:C).type||"default",M=y?.[N]||oR[N];void 0===M&&(_?.("011",(k=N,`Edge type "${k}" not found. Using fallback type "default".`)),N="default",M=y?.default||oR.default);let j=!!(C.focusable||t&&void 0===C.focusable),O=void 0!==h&&(C.reconnectable||n&&void 0===C.reconnectable),P=!!(C.selectable||r&&void 0===C.selectable),A=(0,x.useRef)(null),[I,z]=(0,x.useState)(!1),[D,L]=(0,x.useState)(!1),R=ri(),{zIndex:B,sourceX:T,sourceY:$,targetX:H,targetY:V,sourcePosition:F,targetPosition:X}=ro((0,x.useCallback)(t=>{let n=t.nodeLookup.get(C.source),r=t.nodeLookup.get(C.target);if(!n||!r)return{zIndex:C.zIndex,...oB};let o=function(e){let{sourceNode:t,targetNode:n}=e;if(!nx(t)||!nx(n))return null;let r=t.internals.handleBounds||nw(t.handles),o=n.internals.handleBounds||nw(n.handles),i=n_(r?.source??[],e.sourceHandle),a=n_(e.connectionMode===u.Strict?o?.target??[]:(o?.target??[]).concat(o?.source??[]),e.targetHandle);if(!i||!a)return e.onError?.("008",((e,{id:t,sourceHandle:n,targetHandle:r})=>`Couldn't create edge for ${e} handle id: "${"source"===e?n:r}", edge id: ${t}.`)(!i?"source":"target",{id:e.id,sourceHandle:e.sourceHandle,targetHandle:e.targetHandle})),null;let s=i?.position||g.Bottom,l=a?.position||g.Top,d=nb(t,i,s),c=nb(n,a,l);return{sourceX:d.x,sourceY:d.y,targetX:c.x,targetY:c.y,sourcePosition:s,targetPosition:l}}({id:e,sourceNode:n,targetNode:r,sourceHandle:C.sourceHandle||null,targetHandle:C.targetHandle||null,connectionMode:t.connectionMode,onError:_});return{zIndex:function({sourceNode:e,targetNode:t,selected:n=!1,zIndex:r=0,elevateOnSelect:o=!1,zIndexMode:i="basic"}){if("manual"===i)return r;let a=Math.max(e.parentId||o&&e.selected?e.internals.z:0,t.parentId||o&&t.selected?t.internals.z:0);return(o&&n?r+1e3:r)+a}({selected:C.selected,zIndex:C.zIndex,sourceNode:n,targetNode:r,elevateOnSelect:t.elevateEdgesOnSelect,zIndexMode:t.zIndexMode}),...o||oB}},[C.source,C.target,C.sourceHandle,C.targetHandle,C.selected,C.zIndex]),n9),Y=(0,x.useMemo)(()=>C.markerStart?`url('#${nE(C.markerStart,m)}')`:void 0,[C.markerStart,m]),K=(0,x.useMemo)(()=>C.markerEnd?`url('#${nE(C.markerEnd,m)}')`:void 0,[C.markerEnd,m]);if(C.hidden||null===T||null===$||null===H||null===V)return null;let W=i?e=>{i(e,{...C})}:void 0,Z=a?e=>{a(e,{...C})}:void 0,q=s?e=>{s(e,{...C})}:void 0,U=l?e=>{l(e,{...C})}:void 0,G=d?e=>{d(e,{...C})}:void 0;return(0,v.jsx)("svg",{style:{zIndex:B},children:(0,v.jsxs)("g",{className:w(["react-flow__edge",`react-flow__edge-${N}`,C.className,b,{selected:C.selected,animated:C.animated,inactive:!P&&!o,updating:I,selectable:P}]),onClick:t=>{let{addSelectedEdges:n,unselectNodesAndEdges:r,multiSelectionActive:i}=R.getState();P&&(R.setState({nodesSelectionActive:!1}),C.selected&&i?(r({nodes:[],edges:[C]}),A.current?.blur()):n([e])),o&&o(t,C)},onDoubleClick:W,onContextMenu:Z,onMouseEnter:q,onMouseMove:U,onMouseLeave:G,onKeyDown:j?t=>{if(!E&&tC.includes(t.key)&&P){let{unselectNodesAndEdges:n,addSelectedEdges:r}=R.getState();"Escape"===t.key?(A.current?.blur(),n({edges:[C]})):r([e])}}:void 0,tabIndex:j?0:void 0,role:C.ariaRole??(j?"group":"img"),"aria-roledescription":"edge","data-id":e,"data-testid":`rf__edge-${e}`,"aria-label":null===C.ariaLabel?void 0:C.ariaLabel||`Edge from ${C.source} to ${C.target}`,"aria-describedby":j?`${rd}-${m}`:void 0,ref:A,...C.domAttributes,children:[!D&&(0,v.jsx)(M,{id:e,source:C.source,target:C.target,type:C.type,selected:C.selected,animated:C.animated,selectable:P,deletable:C.deletable??!0,label:C.label,labelStyle:C.labelStyle,labelShowBg:C.labelShowBg,labelBgStyle:C.labelBgStyle,labelBgPadding:C.labelBgPadding,labelBgBorderRadius:C.labelBgBorderRadius,sourceX:T,sourceY:$,targetX:H,targetY:V,sourcePosition:F,targetPosition:X,data:C.data,style:C.style,sourceHandleId:C.sourceHandle,targetHandleId:C.targetHandle,markerStart:Y,markerEnd:K,pathOptions:"pathOptions"in C?C.pathOptions:void 0,interactionWidth:C.interactionWidth}),O&&(0,v.jsx)(oH,{edge:C,isReconnectable:O,reconnectRadius:c,onReconnect:h,onReconnectStart:f,onReconnectEnd:p,sourceX:T,sourceY:$,targetX:H,targetY:V,sourcePosition:F,targetPosition:X,setUpdateHover:z,setReconnecting:L})]})})});let oF=e=>({edgesFocusable:e.edgesFocusable,edgesReconnectable:e.edgesReconnectable,elementsSelectable:e.elementsSelectable,connectionMode:e.connectionMode,onError:e.onError});function oX({defaultMarkerColor:e,onlyRenderVisibleElements:t,rfId:n,edgeTypes:r,noPanClassName:o,onReconnect:i,onEdgeContextMenu:a,onEdgeMouseEnter:s,onEdgeMouseMove:l,onEdgeMouseLeave:d,onEdgeClick:u,reconnectRadius:c,onEdgeDoubleClick:h,onReconnectStart:f,onReconnectEnd:p,disableKeyboardA11y:g}){let{edgesFocusable:m,edgesReconnectable:y,elementsSelectable:w,onError:b}=ro(oF,n9),_=ro((0,x.useCallback)(e=>{if(!t)return e.edges.map(e=>e.id);let n=[];if(e.width&&e.height)for(let t of e.edges){let r=e.nodeLookup.get(t.source),o=e.nodeLookup.get(t.target);r&&o&&function({sourceNode:e,targetNode:t,width:n,height:r,transform:o}){let i=tF(tW(e),tW(t));return i.x===i.x2&&(i.x2+=1),i.y===i.y2&&(i.y2+=1),tq({x:-o[0]/o[2],y:-o[1]/o[2],width:n/o[2],height:r/o[2]},tY(i))>0}({sourceNode:r,targetNode:o,width:e.width,height:e.height,transform:e.transform})&&n.push(t.id)}return n},[t]),n9);return(0,v.jsxs)("div",{className:"react-flow__edges",children:[(0,v.jsx)(om,{defaultColor:e,rfId:n}),_.map(e=>(0,v.jsx)(oV,{id:e,edgesFocusable:m,edgesReconnectable:y,elementsSelectable:w,noPanClassName:o,onReconnect:i,onContextMenu:a,onMouseEnter:s,onMouseMove:l,onMouseLeave:d,onClick:u,reconnectRadius:c,onDoubleClick:h,onReconnectStart:f,onReconnectEnd:p,rfId:n,onError:b,edgeTypes:r,disableKeyboardA11y:g},e))]})}oX.displayName="EdgeRenderer";let oY=(0,x.memo)(oX),oK=e=>`translate(${e.transform[0]}px,${e.transform[1]}px) scale(${e.transform[2]})`;function oW({children:e}){let t=ro(oK);return(0,v.jsx)("div",{className:"react-flow__viewport xyflow__viewport react-flow__container",style:{transform:t},children:e})}let oZ=e=>e.panZoom?.syncViewport;function oq(e){return e.connection.inProgress?{...e.connection,to:t0(e.connection.to,e.transform)}:{...e.connection}}let oU=e=>({nodesConnectable:e.nodesConnectable,isValid:e.connection.isValid,inProgress:e.connection.inProgress,width:e.width,height:e.height});function oG({containerStyle:e,style:t,type:n,component:r}){let{nodesConnectable:o,width:i,height:a,isValid:s,inProgress:l}=ro(oU,n9);return i&&o&&l?(0,v.jsx)("svg",{style:e,width:i,height:a,className:"react-flow__connectionline react-flow__container",children:(0,v.jsx)("g",{className:w(["react-flow__connection",tj(s)]),children:(0,v.jsx)(oQ,{style:t,type:n,CustomComponent:r,isValid:s})})}):null}let oQ=({style:e,type:t=f.Bezier,CustomComponent:n,isValid:r})=>{let{inProgress:o,from:i,fromNode:a,fromHandle:s,fromPosition:l,to:d,toNode:u,toHandle:c,toPosition:h,pointer:p}=ro(oq,n9);if(!o)return;if(n)return(0,v.jsx)(n,{connectionLineType:t,connectionLineStyle:e,fromNode:a,fromHandle:s,fromX:i.x,fromY:i.y,toX:d.x,toY:d.y,fromPosition:l,toPosition:h,connectionStatus:tj(r),toNode:u,toHandle:c,pointer:p});let g="",m={sourceX:i.x,sourceY:i.y,sourcePosition:l,targetX:d.x,targetY:d.y,targetPosition:h};switch(t){case f.Bezier:[g]=nu(m);break;case f.SimpleBezier:[g]=ob(m);break;case f.Step:[g]=nv({...m,borderRadius:0});break;case f.SmoothStep:[g]=nv(m);break;default:[g]=np(m)}return(0,v.jsx)("path",{d:g,fill:"none",className:"react-flow__connection-path",style:e})};oQ.displayName="ConnectionLine";let oJ={};function o0(e=oJ){(0,x.useRef)(e),ri(),(0,x.useEffect)(()=>{},[e])}function o1({nodeTypes:e,edgeTypes:t,onInit:n,onNodeClick:r,onEdgeClick:o,onNodeDoubleClick:i,onEdgeDoubleClick:a,onNodeMouseEnter:s,onNodeMouseMove:l,onNodeMouseLeave:d,onNodeContextMenu:u,onSelectionContextMenu:c,onSelectionStart:h,onSelectionEnd:f,connectionLineType:p,connectionLineStyle:g,connectionLineComponent:m,connectionLineContainerStyle:y,selectionKeyCode:w,selectionOnDrag:b,selectionMode:_,multiSelectionKeyCode:E,panActivationKeyCode:k,zoomActivationKeyCode:C,deleteKeyCode:S,onlyRenderVisibleElements:N,elementsSelectable:M,defaultViewport:j,translateExtent:O,minZoom:P,maxZoom:A,preventScrolling:I,defaultMarkerColor:z,zoomOnScroll:D,zoomOnPinch:L,panOnScroll:R,panOnScrollSpeed:B,panOnScrollMode:T,zoomOnDoubleClick:$,panOnDrag:H,onPaneClick:V,onPaneMouseEnter:F,onPaneMouseMove:X,onPaneMouseLeave:Y,onPaneScroll:K,onPaneContextMenu:W,paneClickDistance:Z,nodeClickDistance:q,onEdgeContextMenu:U,onEdgeMouseEnter:G,onEdgeMouseMove:Q,onEdgeMouseLeave:J,reconnectRadius:ee,onReconnect:et,onReconnectStart:en,onReconnectEnd:er,noDragClassName:eo,noWheelClassName:ei,noPanClassName:ea,disableKeyboardA11y:es,nodeExtent:el,rfId:ed,viewport:eu,onViewportChange:ec}){let eh,ef,ep,eg;return o0(e),o0(t),ri(),(0,x.useRef)(!1),(0,x.useEffect)(()=>{},[]),eh=rY(),ef=(0,x.useRef)(!1),(0,x.useEffect)(()=>{!ef.current&&eh.viewportInitialized&&n&&(setTimeout(()=>n(eh),1),ef.current=!0)},[n,eh.viewportInitialized]),ep=ro(oZ),eg=ri(),(0,x.useEffect)(()=>{eu&&(ep?.(eu),eg.setState({transform:[eu.x,eu.y,eu.zoom]}))},[eu,ep]),(0,v.jsx)(os,{onPaneClick:V,onPaneMouseEnter:F,onPaneMouseMove:X,onPaneMouseLeave:Y,onPaneContextMenu:W,onPaneScroll:K,paneClickDistance:Z,deleteKeyCode:S,selectionKeyCode:w,selectionOnDrag:b,selectionMode:_,onSelectionStart:h,onSelectionEnd:f,multiSelectionKeyCode:E,panActivationKeyCode:k,zoomActivationKeyCode:C,elementsSelectable:M,zoomOnScroll:D,zoomOnPinch:L,zoomOnDoubleClick:$,panOnScroll:R,panOnScrollSpeed:B,panOnScrollMode:T,panOnDrag:H,defaultViewport:j,translateExtent:O,minZoom:P,maxZoom:A,onSelectionContextMenu:c,preventScrolling:I,noDragClassName:eo,noWheelClassName:ei,noPanClassName:ea,disableKeyboardA11y:es,onViewportChange:ec,isControlledViewport:!!eu,children:(0,v.jsxs)(oW,{children:[(0,v.jsx)(oY,{edgeTypes:t,onEdgeClick:o,onEdgeDoubleClick:a,onReconnect:et,onReconnectStart:en,onReconnectEnd:er,onlyRenderVisibleElements:N,onEdgeContextMenu:U,onEdgeMouseEnter:G,onEdgeMouseMove:Q,onEdgeMouseLeave:J,reconnectRadius:ee,defaultMarkerColor:z,noPanClassName:ea,disableKeyboardA11y:es,rfId:ed}),(0,v.jsx)(oG,{style:g,type:p,component:m,containerStyle:y}),(0,v.jsx)("div",{className:"react-flow__edgelabel-renderer"}),(0,v.jsx)(oh,{nodeTypes:e,onNodeClick:r,onNodeDoubleClick:i,onNodeMouseEnter:s,onNodeMouseMove:l,onNodeMouseLeave:d,onNodeContextMenu:u,nodeClickDistance:q,onlyRenderVisibleElements:N,noPanClassName:ea,noDragClassName:eo,disableKeyboardA11y:es,nodeExtent:el,rfId:ed}),(0,v.jsx)("div",{className:"react-flow__viewport-portal"})]})})}o1.displayName="GraphView";let o2=(0,x.memo)(o1),o3=({nodes:e,edges:t,defaultNodes:n,defaultEdges:r,width:o,height:i,fitView:a,fitViewOptions:s,minZoom:l=.5,maxZoom:d=2,nodeOrigin:c,nodeExtent:h,zIndexMode:f="basic"}={})=>{let p=new Map,g=new Map,m=new Map,y=new Map,v=r??t??[],x=n??e??[],w=c??[0,0],b=h??tk;nz(m,y,v);let{nodesInitialized:_}=nM(x,p,g,{nodeOrigin:w,nodeExtent:b,zIndexMode:f}),E=[0,0,1];if(a&&o&&i){let{x:e,y:t,zoom:n}=t3(tI(p,{filter:e=>!!((e.width||e.initialWidth)&&(e.height||e.initialHeight))}),o,i,l,d,s?.padding??.1);E=[e,t,n]}return{rfId:"1",width:o??0,height:i??0,transform:E,nodes:x,nodesInitialized:_,nodeLookup:p,parentLookup:g,edges:v,edgeLookup:y,connectionLookup:m,onNodesChange:null,onEdgesChange:null,hasDefaultNodes:void 0!==n,hasDefaultEdges:void 0!==r,panZoom:null,minZoom:l,maxZoom:d,translateExtent:tk,nodeExtent:b,nodesSelectionActive:!1,userSelectionActive:!1,userSelectionRect:null,connectionMode:u.Strict,domNode:null,paneDragging:!1,noPanClassName:"nopan",nodeOrigin:w,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:a??!1,fitViewOptions:s,fitViewResolver:null,connection:{...tN},connectionClickStartHandle:null,connectOnClick:!0,ariaLiveMessage:"",autoPanOnConnect:!0,autoPanOnNodeDrag:!0,autoPanOnNodeFocus:!0,autoPanSpeed:15,connectionRadius:20,onError:tQ,isValidConnection:void 0,onSelectionChangeHandlers:[],lib:"react",debug:!1,ariaLabelConfig:tS,zIndexMode:f,onNodesChangeMiddlewareMap:new Map,onEdgesChangeMiddlewareMap:new Map}};function o5({initialNodes:e,initialEdges:t,defaultNodes:n,defaultEdges:r,initialWidth:o,initialHeight:i,initialMinZoom:a,initialMaxZoom:s,initialFitViewOptions:l,fitView:d,nodeOrigin:u,nodeExtent:c,zIndexMode:h,children:f}){let[p]=(0,x.useState)(()=>(({nodes:e,edges:t,defaultNodes:n,defaultEdges:r,width:o,height:i,fitView:a,fitViewOptions:s,minZoom:l,maxZoom:d,nodeOrigin:u,nodeExtent:c,zIndexMode:h})=>{let f,p;return f=(f,p)=>{async function m(){let{nodeLookup:e,panZoom:t,fitViewOptions:n,fitViewResolver:r,width:o,height:i,minZoom:a,maxZoom:s}=p();t&&(await tD({nodes:e,width:o,height:i,panZoom:t,minZoom:a,maxZoom:s},n),r?.resolve(!0),f({fitViewResolver:null}))}return{...o3({nodes:e,edges:t,width:o,height:i,fitView:a,fitViewOptions:s,minZoom:l,maxZoom:d,nodeOrigin:u,nodeExtent:c,defaultNodes:n,defaultEdges:r,zIndexMode:h}),setNodes:e=>{let{nodeLookup:t,parentLookup:n,nodeOrigin:r,elevateNodesOnSelect:o,fitViewQueued:i,zIndexMode:a,nodesSelectionActive:s}=p(),{nodesInitialized:l,hasSelectedNodes:d}=nM(e,t,n,{nodeOrigin:r,nodeExtent:c,elevateNodesOnSelect:o,checkEquality:!0,zIndexMode:a}),u=s&&d;i&&l?(m(),f({nodes:e,nodesInitialized:l,fitViewQueued:!1,fitViewOptions:void 0,nodesSelectionActive:u})):f({nodes:e,nodesInitialized:l,nodesSelectionActive:u})},setEdges:e=>{let{connectionLookup:t,edgeLookup:n}=p();nz(t,n,e),f({edges:e})},setDefaultNodesAndEdges:(e,t)=>{if(e){let{setNodes:t}=p();t(e),f({hasDefaultNodes:!0})}if(t){let{setEdges:e}=p();e(t),f({hasDefaultEdges:!0})}},updateNodeInternals:e=>{let{triggerNodeChanges:t,nodeLookup:n,parentLookup:r,domNode:o,nodeOrigin:i,nodeExtent:a,debug:s,fitViewQueued:l,zIndexMode:d}=p(),{changes:u,updatedInternals:c}=function(e,t,n,r,o,i,a){let s=r?.querySelector(".xyflow__viewport"),l=!1;if(!s)return{changes:[],updatedInternals:l};let d=[],u=window.getComputedStyle(s),{m22:c}=new window.DOMMatrixReadOnly(u.transform),h=[];for(let r of e.values()){let e=t.get(r.id);if(!e)continue;if(e.hidden){t.set(e.id,{...e,internals:{...e.internals,handleBounds:void 0}}),l=!0;continue}let s=nt(r.nodeElement),u=e.measured.width!==s.width||e.measured.height!==s.height;if(s.width&&s.height&&(u||!e.internals.handleBounds||r.force)){let f=r.nodeElement.getBoundingClientRect(),p=t4(e.extent)?e.extent:i,{positionAbsolute:g}=e.internals;e.parentId&&"parent"===e.extent?g=t$(g,s,t.get(e.parentId)):p&&(g=tT(g,p,s));let m={...e,measured:s,internals:{...e.internals,positionAbsolute:g,handleBounds:{source:na("source",r.nodeElement,f,c,e.id),target:na("target",r.nodeElement,f,c,e.id)}}};t.set(e.id,m),e.parentId&&nj(m,t,n,{nodeOrigin:o,zIndexMode:a}),l=!0,u&&(d.push({id:e.id,type:"dimensions",dimensions:s}),e.expandParent&&e.parentId&&h.push({id:e.id,parentId:e.parentId,rect:tK(m,o)}))}}if(h.length>0){let e=nP(h,t,n,o);d.push(...e)}return{changes:d,updatedInternals:l}}(e,n,r,o,i,a,d);c&&(!function(e,t,n){let r=nS(nk,n);for(let n of e.values())if(n.parentId)nj(n,e,t,r);else{let e=tT(tA(n,r.nodeOrigin),t4(n.extent)?n.extent:r.nodeExtent,t6(n));n.internals.positionAbsolute=e}}(n,r,{nodeOrigin:i,nodeExtent:a,zIndexMode:d}),l?(m(),f({fitViewQueued:!1,fitViewOptions:void 0})):f({}),u?.length>0&&(s&&console.log("React Flow: trigger node changes",u),t?.(u)))},updateNodePositions:(e,t=!1)=>{let n=[],r=[],{nodeLookup:o,triggerNodeChanges:i,connection:a,updateConnection:s,onNodesChangeMiddlewareMap:l}=p();for(let[i,l]of e){let e=o.get(i),d=!!(e?.expandParent&&e?.parentId&&l?.position),u={id:i,type:"position",position:d?{x:Math.max(0,l.position.x),y:Math.max(0,l.position.y)}:l.position,dragging:t};if(e&&a.inProgress&&a.fromNode.id===e.id){let t=nb(e,a.fromHandle,g.Left,!0);s({...a,from:t})}d&&e.parentId&&n.push({id:i,parentId:e.parentId,rect:{...l.internals.positionAbsolute,width:l.measured.width??0,height:l.measured.height??0}}),r.push(u)}if(n.length>0){let{parentLookup:e,nodeOrigin:t}=p(),i=nP(n,o,e,t);r.push(...i)}for(let e of l.values())r=e(r);i(r)},triggerNodeChanges:e=>{let{onNodesChange:t,setNodes:n,nodes:r,hasDefaultNodes:o,debug:i}=p();e?.length&&(o&&n(rz(e,r)),i&&console.log("React Flow: trigger node changes",e),t?.(e))},triggerEdgeChanges:e=>{let{onEdgesChange:t,setEdges:n,edges:r,hasDefaultEdges:o,debug:i}=p();e?.length&&(o&&n(rz(e,r)),i&&console.log("React Flow: trigger edge changes",e),t?.(e))},addSelectedNodes:e=>{let{multiSelectionActive:t,edgeLookup:n,nodeLookup:r,triggerNodeChanges:o,triggerEdgeChanges:i}=p();t?o(e.map(e=>rD(e,!0))):(o(rL(r,new Set([...e]),!0)),i(rL(n)))},addSelectedEdges:e=>{let{multiSelectionActive:t,edgeLookup:n,nodeLookup:r,triggerNodeChanges:o,triggerEdgeChanges:i}=p();t?i(e.map(e=>rD(e,!0))):(i(rL(n,new Set([...e]))),o(rL(r,new Set,!0)))},unselectNodesAndEdges:({nodes:e,edges:t}={})=>{let{edges:n,nodes:r,nodeLookup:o,triggerNodeChanges:i,triggerEdgeChanges:a}=p(),s=[];for(let t of e||r){if(!t.selected)continue;let e=o.get(t.id);e&&(e.selected=!1),s.push(rD(t.id,!1))}let l=[];for(let e of t||n)e.selected&&l.push(rD(e.id,!1));i(s),a(l)},setMinZoom:e=>{let{panZoom:t,maxZoom:n}=p();t?.setScaleExtent([e,n]),f({minZoom:e})},setMaxZoom:e=>{let{panZoom:t,minZoom:n}=p();t?.setScaleExtent([n,e]),f({maxZoom:e})},setTranslateExtent:e=>{p().panZoom?.setTranslateExtent(e),f({translateExtent:e})},resetSelectedElements:()=>{let{edges:e,nodes:t,triggerNodeChanges:n,triggerEdgeChanges:r,elementsSelectable:o}=p();if(!o)return;let i=t.reduce((e,t)=>t.selected?[...e,rD(t.id,!1)]:e,[]),a=e.reduce((e,t)=>t.selected?[...e,rD(t.id,!1)]:e,[]);n(i),r(a)},setNodeExtent:e=>{let{nodes:t,nodeLookup:n,parentLookup:r,nodeOrigin:o,elevateNodesOnSelect:i,nodeExtent:a,zIndexMode:s}=p();(e[0][0]!==a[0][0]||e[0][1]!==a[0][1]||e[1][0]!==a[1][0]||e[1][1]!==a[1][1])&&(nM(t,n,r,{nodeOrigin:o,nodeExtent:e,elevateNodesOnSelect:i,checkEquality:!1,zIndexMode:s}),f({nodeExtent:e}))},panBy:e=>{let{transform:t,width:n,height:r,panZoom:o,translateExtent:i}=p();return nA({delta:e,panZoom:o,transform:t,translateExtent:i,width:n,height:r})},setCenter:async(e,t,n)=>{let{width:r,height:o,maxZoom:i,panZoom:a}=p();if(!a)return Promise.resolve(!1);let s=void 0!==n?.zoom?n.zoom:i;return await a.setViewport({x:r/2-e*s,y:o/2-t*s,zoom:s},{duration:n?.duration,ease:n?.ease,interpolate:n?.interpolate}),Promise.resolve(!0)},cancelConnection:()=>{f({connection:{...tN}})},updateConnection:e=>{f({connection:e})},reset:()=>f({...o3()})}},p=Object.is,f?n8(f,p):n8})({nodes:e,edges:t,defaultNodes:n,defaultEdges:r,width:o,height:i,fitView:d,minZoom:a,maxZoom:s,fitViewOptions:l,nodeOrigin:u,nodeExtent:c,zIndexMode:h}));return(0,v.jsx)(rn,{value:p,children:(0,v.jsx)(rF,{children:f})})}function o4({children:e,nodes:t,edges:n,defaultNodes:r,defaultEdges:o,width:i,height:a,fitView:s,fitViewOptions:l,minZoom:d,maxZoom:u,nodeOrigin:c,nodeExtent:h,zIndexMode:f}){return(0,x.useContext)(rt)?(0,v.jsx)(v.Fragment,{children:e}):(0,v.jsx)(o5,{initialNodes:t,initialEdges:n,defaultNodes:r,defaultEdges:o,initialWidth:i,initialHeight:a,fitView:s,initialFitViewOptions:l,initialMinZoom:d,initialMaxZoom:u,nodeOrigin:c,nodeExtent:h,zIndexMode:f,children:e})}let o6={width:"100%",height:"100%",overflow:"hidden",position:"relative",zIndex:0};var o7=r$(function({nodes:e,edges:t,defaultNodes:n,defaultEdges:r,className:o,nodeTypes:i,edgeTypes:a,onNodeClick:s,onEdgeClick:l,onInit:d,onMove:u,onMoveStart:p,onMoveEnd:g,onConnect:m,onConnectStart:y,onConnectEnd:b,onClickConnectStart:_,onClickConnectEnd:E,onNodeMouseEnter:k,onNodeMouseMove:C,onNodeMouseLeave:S,onNodeContextMenu:N,onNodeDoubleClick:M,onNodeDragStart:j,onNodeDrag:O,onNodeDragStop:P,onNodesDelete:A,onEdgesDelete:I,onDelete:z,onSelectionChange:D,onSelectionDragStart:L,onSelectionDrag:R,onSelectionDragStop:B,onSelectionContextMenu:T,onSelectionStart:$,onSelectionEnd:H,onBeforeDelete:V,connectionMode:F,connectionLineType:X=f.Bezier,connectionLineStyle:Y,connectionLineComponent:K,connectionLineContainerStyle:W,deleteKeyCode:Z="Backspace",selectionKeyCode:q="Shift",selectionOnDrag:U=!1,selectionMode:G=h.Full,panActivationKeyCode:Q="Space",multiSelectionKeyCode:J=t5()?"Meta":"Control",zoomActivationKeyCode:ee=t5()?"Meta":"Control",snapToGrid:et,snapGrid:en,onlyRenderVisibleElements:er=!1,selectNodesOnDrag:eo,nodesDraggable:ei,autoPanOnNodeFocus:ea,nodesConnectable:es,nodesFocusable:el,nodeOrigin:ed=rE,edgesFocusable:eu,edgesReconnectable:ec,elementsSelectable:eh=!0,defaultViewport:ef=rk,minZoom:ep=.5,maxZoom:eg=2,translateExtent:em=tk,preventScrolling:ey=!0,nodeExtent:ev,defaultMarkerColor:ex="#b1b1b7",zoomOnScroll:ew=!0,zoomOnPinch:eb=!0,panOnScroll:e_=!1,panOnScrollSpeed:eE=.5,panOnScrollMode:ek=c.Free,zoomOnDoubleClick:eC=!0,panOnDrag:eS=!0,onPaneClick:eN,onPaneMouseEnter:eM,onPaneMouseMove:ej,onPaneMouseLeave:eO,onPaneScroll:eP,onPaneContextMenu:eA,paneClickDistance:eI=1,nodeClickDistance:ez=0,children:eD,onReconnect:eL,onReconnectStart:eR,onReconnectEnd:eB,onEdgeContextMenu:eT,onEdgeDoubleClick:e$,onEdgeMouseEnter:eH,onEdgeMouseMove:eV,onEdgeMouseLeave:eF,reconnectRadius:eX=10,onNodesChange:eY,onEdgesChange:eK,noDragClassName:eW="nodrag",noWheelClassName:eZ="nowheel",noPanClassName:eq="nopan",fitView:eU,fitViewOptions:eG,connectOnClick:eQ,attributionPosition:eJ,proOptions:e0,defaultEdgeOptions:e1,elevateNodesOnSelect:e2=!0,elevateEdgesOnSelect:e3=!1,disableKeyboardA11y:e5=!1,autoPanOnConnect:e4,autoPanOnNodeDrag:e6,autoPanSpeed:e7,connectionRadius:e8,isValidConnection:e9,onError:te,style:tt,id:tn,nodeDragThreshold:tr,connectionDragThreshold:to,viewport:ti,onViewportChange:ta,width:ts,height:tl,colorMode:td="light",debug:tu,onScroll:tc,ariaLabelConfig:th,zIndexMode:tf="basic",...tp},tg){let tm=tn||"1",ty=function(e){let[t,n]=(0,x.useState)("system"===e?null:e);return(0,x.useEffect)(()=>{if("system"!==e)return void n(e);let t=rj(),r=()=>n(t?.matches?"dark":"light");return r(),t?.addEventListener("change",r),()=>{t?.removeEventListener("change",r)}},[e]),null!==t?t:rj()?.matches?"dark":"light"}(td),tv=(0,x.useCallback)(e=>{e.currentTarget.scrollTo({top:0,left:0,behavior:"instant"}),tc?.(e)},[tc]);return(0,v.jsx)("div",{"data-testid":"rf__wrapper",...tp,onScroll:tv,style:{...tt,...o6},ref:tg,className:w(["react-flow",o,ty]),id:tn,role:"application",children:(0,v.jsxs)(o4,{nodes:e,edges:t,width:ts,height:tl,fitView:eU,fitViewOptions:eG,minZoom:ep,maxZoom:eg,nodeOrigin:ed,nodeExtent:ev,zIndexMode:tf,children:[(0,v.jsx)(rM,{nodes:e,edges:t,defaultNodes:n,defaultEdges:r,onConnect:m,onConnectStart:y,onConnectEnd:b,onClickConnectStart:_,onClickConnectEnd:E,nodesDraggable:ei,autoPanOnNodeFocus:ea,nodesConnectable:es,nodesFocusable:el,edgesFocusable:eu,edgesReconnectable:ec,elementsSelectable:eh,elevateNodesOnSelect:e2,elevateEdgesOnSelect:e3,minZoom:ep,maxZoom:eg,nodeExtent:ev,onNodesChange:eY,onEdgesChange:eK,snapToGrid:et,snapGrid:en,connectionMode:F,translateExtent:em,connectOnClick:eQ,defaultEdgeOptions:e1,fitView:eU,fitViewOptions:eG,onNodesDelete:A,onEdgesDelete:I,onDelete:z,onNodeDragStart:j,onNodeDrag:O,onNodeDragStop:P,onSelectionDrag:R,onSelectionDragStart:L,onSelectionDragStop:B,onMove:u,onMoveStart:p,onMoveEnd:g,noPanClassName:eq,nodeOrigin:ed,rfId:tm,autoPanOnConnect:e4,autoPanOnNodeDrag:e6,autoPanSpeed:e7,onError:te,connectionRadius:e8,isValidConnection:e9,selectNodesOnDrag:eo,nodeDragThreshold:tr,connectionDragThreshold:to,onBeforeDelete:V,debug:tu,ariaLabelConfig:th,zIndexMode:tf}),(0,v.jsx)(o2,{onInit:d,onNodeClick:s,onEdgeClick:l,onNodeMouseEnter:k,onNodeMouseMove:C,onNodeMouseLeave:S,onNodeContextMenu:N,onNodeDoubleClick:M,nodeTypes:i,edgeTypes:a,connectionLineType:X,connectionLineStyle:Y,connectionLineComponent:K,connectionLineContainerStyle:W,selectionKeyCode:q,selectionOnDrag:U,selectionMode:G,deleteKeyCode:Z,multiSelectionKeyCode:J,panActivationKeyCode:Q,zoomActivationKeyCode:ee,onlyRenderVisibleElements:er,defaultViewport:ef,translateExtent:em,minZoom:ep,maxZoom:eg,preventScrolling:ey,zoomOnScroll:ew,zoomOnPinch:eb,zoomOnDoubleClick:eC,panOnScroll:e_,panOnScrollSpeed:eE,panOnScrollMode:ek,panOnDrag:eS,onPaneClick:eN,onPaneMouseEnter:eM,onPaneMouseMove:ej,onPaneMouseLeave:eO,onPaneScroll:eP,onPaneContextMenu:eA,paneClickDistance:eI,nodeClickDistance:ez,onSelectionContextMenu:T,onSelectionStart:$,onSelectionEnd:H,onReconnect:eL,onReconnectStart:eR,onReconnectEnd:eB,onEdgeContextMenu:eT,onEdgeDoubleClick:e$,onEdgeMouseEnter:eH,onEdgeMouseMove:eV,onEdgeMouseLeave:eF,reconnectRadius:eX,defaultMarkerColor:ex,noDragClassName:eW,noWheelClassName:eZ,noPanClassName:eq,rfId:tm,disableKeyboardA11y:e5,nodeExtent:ev,viewport:ti,onViewportChange:ta}),(0,v.jsx)(rb,{onSelectionChange:D}),eD,(0,v.jsx)(rg,{proOptions:e0,position:eJ}),(0,v.jsx)(rf,{rfId:tm,disableKeyboardA11y:e5})]})})});let o8=e=>e.domNode?.querySelector(".react-flow__edgelabel-renderer");function o9({children:e}){let t=ro(o8);return t?(0,re.createPortal)(e,t):null}function ie({dimensions:e,lineWidth:t,variant:n,className:r}){return(0,v.jsx)("path",{strokeWidth:t,d:`M${e[0]/2} 0 V${e[1]} M0 ${e[1]/2} H${e[0]}`,className:w(["react-flow__background-pattern",n,r])})}function it({radius:e,className:t}){return(0,v.jsx)("circle",{cx:e,cy:e,r:e,className:w(["react-flow__background-pattern","dots",t])})}(l=y||(y={})).Lines="lines",l.Dots="dots",l.Cross="cross";let ir={[y.Dots]:1,[y.Lines]:1,[y.Cross]:6},io=e=>({transform:e.transform,patternId:`pattern-${e.rfId}`});function ii({id:e,variant:t=y.Dots,gap:n=20,size:r,lineWidth:o=1,offset:i=0,color:a,bgColor:s,style:l,className:d,patternClassName:u}){let c=(0,x.useRef)(null),{transform:h,patternId:f}=ro(io,n9),p=r||ir[t],g=t===y.Dots,m=t===y.Cross,b=Array.isArray(n)?n:[n,n],_=[b[0]*h[2]||1,b[1]*h[2]||1],E=p*h[2],k=Array.isArray(i)?i:[i,i],C=m?[E,E]:_,S=[k[0]*h[2]||1+C[0]/2,k[1]*h[2]||1+C[1]/2],N=`${f}${e||""}`;return(0,v.jsxs)("svg",{className:w(["react-flow__background",d]),style:{...l,...rZ,"--xy-background-color-props":s,"--xy-background-pattern-color-props":a},ref:c,"data-testid":"rf__background",children:[(0,v.jsx)("pattern",{id:N,x:h[0]%_[0],y:h[1]%_[1],width:_[0],height:_[1],patternUnits:"userSpaceOnUse",patternTransform:`translate(-${S[0]},-${S[1]})`,children:g?(0,v.jsx)(it,{radius:E/2,className:u}):(0,v.jsx)(ie,{dimensions:C,lineWidth:o,variant:t,className:u})}),(0,v.jsx)("rect",{x:"0",y:"0",width:"100%",height:"100%",fill:`url(#${N})`})]})}ii.displayName="Background";let ia=(0,x.memo)(ii);function is(){return(0,v.jsx)("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 32 32",children:(0,v.jsx)("path",{d:"M32 18.133H18.133V32h-4.266V18.133H0v-4.266h13.867V0h4.266v13.867H32z"})})}function il(){return(0,v.jsx)("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 32 5",children:(0,v.jsx)("path",{d:"M0 0h32v4.2H0z"})})}function id(){return(0,v.jsx)("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 32 30",children:(0,v.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 iu(){return(0,v.jsx)("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 25 32",children:(0,v.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 ic(){return(0,v.jsx)("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 25 32",children:(0,v.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 ih({children:e,className:t,...n}){return(0,v.jsx)("button",{type:"button",className:w(["react-flow__controls-button",t]),...n,children:e})}let ip=e=>({isInteractive:e.nodesDraggable||e.nodesConnectable||e.elementsSelectable,minZoomReached:e.transform[2]<=e.minZoom,maxZoomReached:e.transform[2]>=e.maxZoom,ariaLabelConfig:e.ariaLabelConfig});function ig({style:e,showZoom:t=!0,showFitView:n=!0,showInteractive:r=!0,fitViewOptions:o,onZoomIn:i,onZoomOut:a,onFitView:s,onInteractiveChange:l,className:d,children:u,position:c="bottom-left",orientation:h="vertical","aria-label":f}){let p=ri(),{isInteractive:g,minZoomReached:m,maxZoomReached:y,ariaLabelConfig:x}=ro(ip,n9),{zoomIn:b,zoomOut:_,fitView:E}=rY();return(0,v.jsxs)(rp,{className:w(["react-flow__controls","horizontal"===h?"horizontal":"vertical",d]),position:c,style:e,"data-testid":"rf__controls","aria-label":f??x["controls.ariaLabel"],children:[t&&(0,v.jsxs)(v.Fragment,{children:[(0,v.jsx)(ih,{onClick:()=>{b(),i?.()},className:"react-flow__controls-zoomin",title:x["controls.zoomIn.ariaLabel"],"aria-label":x["controls.zoomIn.ariaLabel"],disabled:y,children:(0,v.jsx)(is,{})}),(0,v.jsx)(ih,{onClick:()=>{_(),a?.()},className:"react-flow__controls-zoomout",title:x["controls.zoomOut.ariaLabel"],"aria-label":x["controls.zoomOut.ariaLabel"],disabled:m,children:(0,v.jsx)(il,{})})]}),n&&(0,v.jsx)(ih,{className:"react-flow__controls-fitview",onClick:()=>{E(o),s?.()},title:x["controls.fitView.ariaLabel"],"aria-label":x["controls.fitView.ariaLabel"],children:(0,v.jsx)(id,{})}),r&&(0,v.jsx)(ih,{className:"react-flow__controls-interactive",onClick:()=>{p.setState({nodesDraggable:!g,nodesConnectable:!g,elementsSelectable:!g}),l?.(!g)},title:x["controls.interactive.ariaLabel"],"aria-label":x["controls.interactive.ariaLabel"],children:g?(0,v.jsx)(ic,{}):(0,v.jsx)(iu,{})}),u]})}ig.displayName="Controls";let im=(0,x.memo)(ig),iy=(0,x.memo)(function({id:e,x:t,y:n,width:r,height:o,style:i,color:a,strokeColor:s,strokeWidth:l,className:d,borderRadius:u,shapeRendering:c,selected:h,onClick:f}){let{background:p,backgroundColor:g}=i||{};return(0,v.jsx)("rect",{className:w(["react-flow__minimap-node",{selected:h},d]),x:t,y:n,rx:u,ry:u,width:r,height:o,style:{fill:a||p||g,stroke:s,strokeWidth:l},shapeRendering:c,onClick:f?t=>f(t,e):void 0})}),iv=e=>e.nodes.map(e=>e.id),ix=e=>e instanceof Function?e:()=>e,iw=(0,x.memo)(function({id:e,nodeColorFunc:t,nodeStrokeColorFunc:n,nodeClassNameFunc:r,nodeBorderRadius:o,nodeStrokeWidth:i,shapeRendering:a,NodeComponent:s,onClick:l}){let{node:d,x:u,y:c,width:h,height:f}=ro(t=>{let n=t.nodeLookup.get(e);if(!n)return{node:void 0,x:0,y:0,width:0,height:0};let r=n.internals.userNode,{x:o,y:i}=n.internals.positionAbsolute,{width:a,height:s}=t6(r);return{node:r,x:o,y:i,width:a,height:s}},n9);return d&&!d.hidden&&t7(d)?(0,v.jsx)(s,{x:u,y:c,width:h,height:f,style:d.style,selected:!!d.selected,className:r(d),color:t(d),borderRadius:o,strokeColor:n(d),strokeWidth:i,shapeRendering:a,onClick:l,id:d.id}):null});var ib=(0,x.memo)(function({nodeStrokeColor:e,nodeColor:t,nodeClassName:n="",nodeBorderRadius:r=5,nodeStrokeWidth:o,nodeComponent:i=iy,onClick:a}){let s=ro(iv,n9),l=ix(t),d=ix(e),u=ix(n),c="u"<typeof window||window.chrome?"crispEdges":"geometricPrecision";return(0,v.jsx)(v.Fragment,{children:s.map(e=>(0,v.jsx)(iw,{id:e,nodeColorFunc:l,nodeStrokeColorFunc:d,nodeClassNameFunc:u,nodeBorderRadius:r,nodeStrokeWidth:o,NodeComponent:i,onClick:a,shapeRendering:c},e))})});let i_=e=>!e.hidden,iE=e=>{let 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?tZ(tI(e.nodeLookup,{filter:i_}),t):t,rfId:e.rfId,panZoom:e.panZoom,translateExtent:e.translateExtent,flowWidth:e.width,flowHeight:e.height,ariaLabelConfig:e.ariaLabelConfig}};function ik({style:e,className:t,nodeStrokeColor:n,nodeColor:r,nodeClassName:o="",nodeBorderRadius:i=5,nodeStrokeWidth:a,nodeComponent:s,bgColor:l,maskColor:d,maskStrokeColor:u,maskStrokeWidth:c,position:h="bottom-right",onClick:f,onNodeClick:p,pannable:g=!1,zoomable:m=!1,ariaLabel:y,inversePan:b,zoomStep:_=1,offsetScale:E=5}){let k=ri(),C=(0,x.useRef)(null),{boundingRect:S,viewBB:N,rfId:M,panZoom:j,translateExtent:O,flowWidth:P,flowHeight:A,ariaLabelConfig:I}=ro(iE,n9),z=e?.width??200,D=e?.height??150,L=Math.max(S.width/z,S.height/D),R=L*z,B=L*D,T=E*L,$=S.x-(R-S.width)/2-T,H=S.y-(B-S.height)/2-T,V=R+2*T,F=B+2*T,X=`react-flow__minimap-desc-${M}`,Y=(0,x.useRef)(0),K=(0,x.useRef)();Y.current=L,(0,x.useEffect)(()=>{if(C.current&&j)return K.current=function({domNode:e,panZoom:t,getTransform:n,getViewScale:r}){let o=eh(e);return{update:function({translateExtent:e,width:i,height:a,zoomStep:s=1,pannable:l=!0,zoomable:d=!0,inversePan:u=!1}){let c=[0,0],h=t_().on("start",e=>{("mousedown"===e.sourceEvent.type||"touchstart"===e.sourceEvent.type)&&(c=[e.sourceEvent.clientX??e.sourceEvent.touches[0].clientX,e.sourceEvent.clientY??e.sourceEvent.touches[0].clientY])}).on("zoom",l?o=>{let s=n();if("mousemove"!==o.sourceEvent.type&&"touchmove"!==o.sourceEvent.type||!t)return;let l=[o.sourceEvent.clientX??o.sourceEvent.touches[0].clientX,o.sourceEvent.clientY??o.sourceEvent.touches[0].clientY],d=[l[0]-c[0],l[1]-c[1]];c=l;let h=r()*Math.max(s[2],Math.log(s[2]))*(u?-1:1),f={x:s[0]-d[0]*h,y:s[1]-d[1]*h};t.setViewportConstrained({x:f.x,y:f.y,zoom:s[2]},[[0,0],[i,a]],e)}:null).on("zoom.wheel",d?e=>{if("wheel"!==e.sourceEvent.type||!t)return;let r=n(),o=e.sourceEvent.ctrlKey&&t5()?10:1,i=-e.sourceEvent.deltaY*(1===e.sourceEvent.deltaMode?.05:e.sourceEvent.deltaMode?1:.002)*s,a=r[2]*Math.pow(2,i*o);t.scaleTo(a)}:null);o.call(h,{})},destroy:function(){o.on("zoom",null)},pointer:ef}}({domNode:C.current,panZoom:j,getTransform:()=>k.getState().transform,getViewScale:()=>Y.current}),()=>{K.current?.destroy()}},[j]),(0,x.useEffect)(()=>{K.current?.update({translateExtent:O,width:P,height:A,inversePan:b,pannable:g,zoomStep:_,zoomable:m})},[g,m,b,_,O,P,A]);let W=f?e=>{let[t,n]=K.current?.pointer(e)||[0,0];f(e,{x:t,y:n})}:void 0,Z=p?(0,x.useCallback)((e,t)=>{p(e,k.getState().nodeLookup.get(t).internals.userNode)},[]):void 0,q=y??I["minimap.ariaLabel"];return(0,v.jsx)(rp,{position:h,style:{...e,"--xy-minimap-background-color-props":"string"==typeof l?l:void 0,"--xy-minimap-mask-background-color-props":"string"==typeof d?d:void 0,"--xy-minimap-mask-stroke-color-props":"string"==typeof u?u:void 0,"--xy-minimap-mask-stroke-width-props":"number"==typeof c?c*L:void 0,"--xy-minimap-node-background-color-props":"string"==typeof r?r:void 0,"--xy-minimap-node-stroke-color-props":"string"==typeof n?n:void 0,"--xy-minimap-node-stroke-width-props":"number"==typeof a?a:void 0},className:w(["react-flow__minimap",t]),"data-testid":"rf__minimap",children:(0,v.jsxs)("svg",{width:z,height:D,viewBox:`${$} ${H} ${V} ${F}`,className:"react-flow__minimap-svg",role:"img","aria-labelledby":X,ref:C,onClick:W,children:[q&&(0,v.jsx)("title",{id:X,children:q}),(0,v.jsx)(ib,{onClick:Z,nodeColor:r,nodeStrokeColor:n,nodeBorderRadius:i,nodeClassName:o,nodeStrokeWidth:a,nodeComponent:s}),(0,v.jsx)("path",{className:"react-flow__minimap-mask",d:`M${$-T},${H-T}h${V+2*T}v${F+2*T}h${-V-2*T}z
|
|
2
|
+
M${N.x},${N.y}h${N.width}v${N.height}h${-N.width}z`,fillRule:"evenodd",pointerEvents:"none"})]})})}ik.displayName="MiniMap",(0,x.memo)(ik);let iC={[m.Line]:"right",[m.Handle]:"bottom-right"};(0,x.memo)(function({nodeId:e,position:t,variant:n=m.Handle,className:r,style:o,children:i,color:a,minWidth:s=10,minHeight:l=10,maxWidth:d=Number.MAX_VALUE,maxHeight:u=Number.MAX_VALUE,keepAspectRatio:c=!1,resizeDirection:h,autoScale:f=!0,shouldResize:p,onResizeStart:g,onResize:y,onResizeEnd:b}){let _,E=r7(),k="string"==typeof e?e:E,C=ri(),S=(0,x.useRef)(null),N=n===m.Handle,M=ro((0,x.useCallback)((_=N&&f,e=>_?`${Math.max(1/e.transform[2],1)}`:void 0),[N,f]),n9),j=(0,x.useRef)(null),O=t??iC[n];(0,x.useEffect)(()=>{if(S.current&&k)return j.current||(j.current=function({domNode:e,nodeId:t,getStoreItems:n,onChange:r,onEnd:o}){let i=eh(e),a={controlDirection:nq("bottom-right"),boundaries:{minWidth:0,minHeight:0,maxWidth:Number.MAX_VALUE,maxHeight:Number.MAX_VALUE},resizeDirection:void 0,keepAspectRatio:!1};return{update:function({controlPosition:e,boundaries:s,keepAspectRatio:l,resizeDirection:d,onResizeStart:u,onResize:c,onResizeEnd:h,shouldResize:f}){let p,g,m,y,v={...nJ},x={...n0};a={boundaries:s,resizeDirection:d,keepAspectRatio:l,controlDirection:nq(e)};let w=null,b=[],_=!1,E=eS().on("start",e=>{let{nodeLookup:r,transform:o,snapGrid:i,snapToGrid:a,nodeOrigin:s,paneDomNode:l}=n();if(!(p=r.get(t)))return;w=l?.getBoundingClientRect()??null;let{xSnapped:d,ySnapped:c}=ne(e.sourceEvent,{transform:o,snapGrid:i,snapToGrid:a,containerBounds:w});if(x={...v={width:p.measured.width??0,height:p.measured.height??0,x:p.position.x??0,y:p.position.y??0},pointerX:d,pointerY:c,aspectRatio:v.width/v.height},g=void 0,p.parentId&&("parent"===p.extent||p.expandParent)){var h;m=(g=r.get(p.parentId))&&"parent"===p.extent?[[0,0],[(h=g).measured.width,h.measured.height]]:void 0}for(let[e,n]of(b=[],y=void 0,r))if(n.parentId===t&&(b.push({id:e,position:{...n.position},extent:n.extent}),"parent"===n.extent||n.expandParent)){let e=function(e,t,n){let r=t.position.x+e.position.x,o=t.position.y+e.position.y,i=e.measured.width??0,a=e.measured.height??0,s=n[0]*i,l=n[1]*a;return[[r-s,o-l],[r+i-s,o+a-l]]}(n,p,n.origin??s);y=y?[[Math.min(e[0][0],y[0][0]),Math.min(e[0][1],y[0][1])],[Math.max(e[1][0],y[1][0]),Math.max(e[1][1],y[1][1])]]:e}u?.(e,{...v})}).on("drag",e=>{let{transform:t,snapGrid:o,snapToGrid:i,nodeOrigin:s}=n(),l=ne(e.sourceEvent,{transform:t,snapGrid:o,snapToGrid:i,containerBounds:w}),d=[];if(!p)return;let{x:u,y:h,width:E,height:k}=v,C={},S=p.origin??s,{width:N,height:M,x:j,y:O}=function(e,t,n,r,o,i,a,s){var l,d,u,c;let{affectsX:h,affectsY:f}=t,{isHorizontal:p,isVertical:g}=t,m=p&&g,{xSnapped:y,ySnapped:v}=n,{minWidth:x,maxWidth:w,minHeight:b,maxHeight:_}=r,{x:E,y:k,width:C,height:S,aspectRatio:N}=e,M=Math.floor(p?y-e.pointerX:0),j=Math.floor(g?v-e.pointerY:0),O=C+(h?-M:M),P=S+(f?-j:j),A=-i[0]*C,I=-i[1]*S,z=nQ(O,x,w),D=nQ(P,b,_);if(a){let e=0,t=0;h&&M<0?e=nU(E+M+A,a[0][0]):!h&&M>0&&(e=nG(E+O+A,a[1][0])),f&&j<0?t=nU(k+j+I,a[0][1]):!f&&j>0&&(t=nG(k+P+I,a[1][1])),z=Math.max(z,e),D=Math.max(D,t)}if(s){let e=0,t=0;h&&M>0?e=nG(E+M,s[0][0]):!h&&M<0&&(e=nU(E+O,s[1][0])),f&&j>0?t=nG(k+j,s[0][1]):!f&&j<0&&(t=nU(k+P,s[1][1])),z=Math.max(z,e),D=Math.max(D,t)}if(o){if(p){(z=Math.max(z,nQ(O/N,b,_)*N),a)&&(z=Math.max(z,(h||f)&&(!h||f||!m)?nU(k+I+(h?M:-M)/N,a[0][1])*N:nG(k+I+O/N,a[1][1])*N));s&&(z=Math.max(z,(h||f)&&(!h||f||!m)?nG(k+(h?M:-M)/N,s[0][1])*N:nU(k+O/N,s[1][1])*N))}if(g){(D=Math.max(D,nQ(P*N,x,w)/N),a)&&(D=Math.max(D,(h||f)&&(!f||h||!m)?nU(E+(f?j:-j)*N+A,a[0][0])/N:nG(E+P*N+A,a[1][0])/N));s&&(D=Math.max(D,(h||f)&&(!f||h||!m)?nG(E+(f?j:-j)*N,s[0][0])/N:nU(E+P*N,s[1][0])/N))}}j+=j<0?D:-D,M+=M<0?z:-z,o&&(m?O>P*N?j=((l=h,d=f,l?!d:d)?-M:M)/N:M=((u=h,c=f,u?!c:c)?-j:j)*N:p?(j=M/N,f=h):(M=j*N,h=f));let L=h?E+M:E,R=f?k+j:k;return{width:C+(h?-M:M),height:S+(f?-j:j),x:i[0]*M*(h?-1:1)+L,y:i[1]*j*(f?-1:1)+R}}(x,a.controlDirection,l,a.boundaries,a.keepAspectRatio,S,m,y),P=N!==E,A=M!==k,I=j!==u&&P,z=O!==h&&A;if(!I&&!z&&!P&&!A)return;if((I||z||1===S[0]||1===S[1])&&(C.x=I?j:v.x,C.y=z?O:v.y,v.x=C.x,v.y=C.y,b.length>0)){let e=j-u,t=O-h;for(let n of b)n.position={x:n.position.x-e+S[0]*(N-E),y:n.position.y-t+S[1]*(M-k)},d.push(n)}if((P||A)&&(C.width=P&&(!a.resizeDirection||"horizontal"===a.resizeDirection)?N:v.width,C.height=A&&(!a.resizeDirection||"vertical"===a.resizeDirection)?M:v.height,v.width=C.width,v.height=C.height),g&&p.expandParent){let e=S[0]*(C.width??0);C.x&&C.x<e&&(v.x=e,x.x=x.x-(C.x-e));let t=S[1]*(C.height??0);C.y&&C.y<t&&(v.y=t,x.y=x.y-(C.y-t))}let D=function({width:e,prevWidth:t,height:n,prevHeight:r,affectsX:o,affectsY:i}){let a=e-t,s=n-r,l=[a>0?1:a<0?-1:0,s>0?1:s<0?-1:0];return a&&o&&(l[0]=-1*l[0]),s&&i&&(l[1]=-1*l[1]),l}({width:v.width,prevWidth:E,height:v.height,prevHeight:k,affectsX:a.controlDirection.affectsX,affectsY:a.controlDirection.affectsY}),L={...v,direction:D};!1!==f?.(e,L)&&(_=!0,c?.(e,L),r(C,d))}).on("end",e=>{_&&(h?.(e,{...v}),o?.({...v}),_=!1)});i.call(E)},destroy:function(){i.on(".drag",null)}}}({domNode:S.current,nodeId:k,getStoreItems:()=>{let{nodeLookup:e,transform:t,snapGrid:n,snapToGrid:r,nodeOrigin:o,domNode:i}=C.getState();return{nodeLookup:e,transform:t,snapGrid:n,snapToGrid:r,nodeOrigin:o,paneDomNode:i}},onChange:(e,t)=>{let{triggerNodeChanges:n,nodeLookup:r,parentLookup:o,nodeOrigin:i}=C.getState(),a=[],s={x:e.x,y:e.y},l=r.get(k);if(l&&l.expandParent&&l.parentId){let t=l.origin??i,n=e.width??l.measured.width??0,d=e.height??l.measured.height??0,u=nP([{id:l.id,parentId:l.parentId,rect:{width:n,height:d,...t8({x:e.x??l.position.x,y:e.y??l.position.y},{width:n,height:d},l.parentId,r,t)}}],r,o,i);a.push(...u),s.x=e.x?Math.max(t[0]*n,e.x):void 0,s.y=e.y?Math.max(t[1]*d,e.y):void 0}if(void 0!==s.x&&void 0!==s.y){let e={id:k,type:"position",position:{...s}};a.push(e)}if(void 0!==e.width&&void 0!==e.height){let t={id:k,type:"dimensions",resizing:!0,setAttributes:!h||("horizontal"===h?"width":"height"),dimensions:{width:e.width,height:e.height}};a.push(t)}for(let e of t){let t={...e,type:"position"};a.push(t)}n(a)},onEnd:({width:e,height:t})=>{C.getState().triggerNodeChanges([{id:k,type:"dimensions",resizing:!1,dimensions:{width:e,height:t}}])}})),j.current.update({controlPosition:O,boundaries:{minWidth:s,minHeight:l,maxWidth:d,maxHeight:u},keepAspectRatio:c,resizeDirection:h,onResizeStart:g,onResize:y,onResizeEnd:b,shouldResize:p}),()=>{j.current?.destroy()}},[O,s,l,d,u,c,g,y,b,p]);let P=O.split("-");return(0,v.jsx)("div",{className:w(["react-flow__resize-control","nodrag",...P,n,r]),ref:S,style:{...o,scale:M,...a&&{[N?"backgroundColor":"borderColor"]:a}},children:i})});var iS=e.i(302773),iN=Object.defineProperty,iM={},ij={Graph:()=>iI,alg:()=>iV,json:()=>iT,version:()=>iB};for(var iO in ij)iN(iM,iO,{get:ij[iO],enumerable:!0});var iP=Object.defineProperty,iA=(e,t)=>{for(var n in t)iP(e,n,{get:t[n],enumerable:!0})},iI=class{constructor(e){this._isDirected=!0,this._isMultigraph=!1,this._isCompound=!1,this._nodes={},this._in={},this._preds={},this._out={},this._sucs={},this._edgeObjs={},this._edgeLabels={},this._nodeCount=0,this._edgeCount=0,this._defaultNodeLabelFn=()=>{},this._defaultEdgeLabelFn=()=>{},e&&(this._isDirected=!("directed"in e)||e.directed,this._isMultigraph="multigraph"in e&&e.multigraph,this._isCompound="compound"in e&&e.compound),this._isCompound&&(this._parent={},this._children={},this._children["\0"]={})}isDirected(){return this._isDirected}isMultigraph(){return this._isMultigraph}isCompound(){return this._isCompound}setGraph(e){return this._label=e,this}graph(){return this._label}setDefaultNodeLabel(e){return"function"!=typeof e?this._defaultNodeLabelFn=()=>e:this._defaultNodeLabelFn=e,this}nodeCount(){return this._nodeCount}nodes(){return Object.keys(this._nodes)}sources(){return this.nodes().filter(e=>0===Object.keys(this._in[e]).length)}sinks(){return this.nodes().filter(e=>0===Object.keys(this._out[e]).length)}setNodes(e,t){return e.forEach(e=>{void 0!==t?this.setNode(e,t):this.setNode(e)}),this}setNode(e,t){return e in this._nodes?arguments.length>1&&(this._nodes[e]=t):(this._nodes[e]=arguments.length>1?t:this._defaultNodeLabelFn(e),this._isCompound&&(this._parent[e]="\0",this._children[e]={},this._children["\0"][e]=!0),this._in[e]={},this._preds[e]={},this._out[e]={},this._sucs[e]={},++this._nodeCount),this}node(e){return this._nodes[e]}hasNode(e){return e in this._nodes}removeNode(e){if(e in this._nodes){let t=e=>this.removeEdge(this._edgeObjs[e]);delete this._nodes[e],this._isCompound&&(this._removeFromParentsChildList(e),delete this._parent[e],this.children(e).forEach(e=>{this.setParent(e)}),delete this._children[e]),Object.keys(this._in[e]).forEach(t),delete this._in[e],delete this._preds[e],Object.keys(this._out[e]).forEach(t),delete this._out[e],delete this._sucs[e],--this._nodeCount}return this}setParent(e,t){if(!this._isCompound)throw Error("Cannot set parent in a non-compound graph");if(void 0===t)t="\0";else{t+="";for(let n=t;void 0!==n;n=this.parent(n))if(n===e)throw Error("Setting "+t+" as parent of "+e+" would create a cycle");this.setNode(t)}return this.setNode(e),this._removeFromParentsChildList(e),this._parent[e]=t,this._children[t][e]=!0,this}parent(e){if(this._isCompound){let t=this._parent[e];if("\0"!==t)return t}}children(e="\0"){if(this._isCompound){let t=this._children[e];if(t)return Object.keys(t)}else{if("\0"===e)return this.nodes();this.hasNode(e)}return[]}predecessors(e){let t=this._preds[e];if(t)return Object.keys(t)}successors(e){let t=this._sucs[e];if(t)return Object.keys(t)}neighbors(e){let t=this.predecessors(e);if(t){let n=new Set(t);for(let t of this.successors(e))n.add(t);return Array.from(n.values())}}isLeaf(e){return 0===(this.isDirected()?this.successors(e):this.neighbors(e)).length}filterNodes(e){let t=new this.constructor({directed:this._isDirected,multigraph:this._isMultigraph,compound:this._isCompound});t.setGraph(this.graph()),Object.entries(this._nodes).forEach(([n,r])=>{e(n)&&t.setNode(n,r)}),Object.values(this._edgeObjs).forEach(e=>{t.hasNode(e.v)&&t.hasNode(e.w)&&t.setEdge(e,this.edge(e))});let n={},r=e=>{let o=this.parent(e);return!o||t.hasNode(o)?(n[e]=null!=o?o:void 0,null!=o?o:void 0):o in n?n[o]:r(o)};return this._isCompound&&t.nodes().forEach(e=>t.setParent(e,r(e))),t}setDefaultEdgeLabel(e){return"function"!=typeof e?this._defaultEdgeLabelFn=()=>e:this._defaultEdgeLabelFn=e,this}edgeCount(){return this._edgeCount}edges(){return Object.values(this._edgeObjs)}setPath(e,t){return e.reduce((e,n)=>(void 0!==t?this.setEdge(e,n,t):this.setEdge(e,n),n)),this}setEdge(e,t,n,r){let o,i,a,s,l=!1;"object"==typeof e&&null!==e&&"v"in e?(o=e.v,i=e.w,a=e.name,2==arguments.length&&(s=t,l=!0)):(o=e,i=t,a=r,arguments.length>2&&(s=n,l=!0)),o=""+o,i=""+i,void 0!==a&&(a=""+a);let d=iL(this._isDirected,o,i,a);if(d in this._edgeLabels)return l&&(this._edgeLabels[d]=s),this;if(void 0!==a&&!this._isMultigraph)throw Error("Cannot set a named edge when isMultigraph = false");this.setNode(o),this.setNode(i),this._edgeLabels[d]=l?s:this._defaultEdgeLabelFn(o,i,a);let u=function(e,t,n,r){let o=""+t,i=""+n;if(!e&&o>i){let e=o;o=i,i=e}let a={v:o,w:i};return r&&(a.name=r),a}(this._isDirected,o,i,a);return o=u.v,i=u.w,Object.freeze(u),this._edgeObjs[d]=u,iz(this._preds[i],o),iz(this._sucs[o],i),this._in[i][d]=u,this._out[o][d]=u,this._edgeCount++,this}edge(e,t,n){let r=1==arguments.length?iR(this._isDirected,e):iL(this._isDirected,e,t,n);return this._edgeLabels[r]}edgeAsObj(e,t,n){let r=1==arguments.length?this.edge(e):this.edge(e,t,n);return"object"!=typeof r?{label:r}:r}hasEdge(e,t,n){return(1==arguments.length?iR(this._isDirected,e):iL(this._isDirected,e,t,n))in this._edgeLabels}removeEdge(e,t,n){let r=1==arguments.length?iR(this._isDirected,e):iL(this._isDirected,e,t,n),o=this._edgeObjs[r];if(o){let e=o.v,t=o.w;delete this._edgeLabels[r],delete this._edgeObjs[r],iD(this._preds[t],e),iD(this._sucs[e],t),delete this._in[t][r],delete this._out[e][r],this._edgeCount--}return this}inEdges(e,t){return this.isDirected()?this.filterEdges(this._in[e],e,t):this.nodeEdges(e,t)}outEdges(e,t){return this.isDirected()?this.filterEdges(this._out[e],e,t):this.nodeEdges(e,t)}nodeEdges(e,t){if(e in this._nodes)return this.filterEdges({...this._in[e],...this._out[e]},e,t)}_removeFromParentsChildList(e){delete this._children[this._parent[e]][e]}filterEdges(e,t,n){if(!e)return;let r=Object.values(e);return n?r.filter(e=>e.v===t&&e.w===n||e.v===n&&e.w===t):r}};function iz(e,t){e[t]?e[t]++:e[t]=1}function iD(e,t){void 0===e[t]||--e[t]||delete e[t]}function iL(e,t,n,r){let o=""+t,i=""+n;if(!e&&o>i){let e=o;o=i,i=e}return o+"\x01"+i+"\x01"+(void 0===r?"\0":r)}function iR(e,t){return iL(e,t.v,t.w,t.name)}var iB="4.0.1",iT={};function i$(e){var t,n;let r={options:{directed:e.isDirected(),multigraph:e.isMultigraph(),compound:e.isCompound()},nodes:(t=e).nodes().map(e=>{let n=t.node(e),r=t.parent(e),o={v:e};return void 0!==n&&(o.value=n),void 0!==r&&(o.parent=r),o}),edges:(n=e).edges().map(e=>{let t=n.edge(e),r={v:e.v,w:e.w};return void 0!==e.name&&(r.name=e.name),void 0!==t&&(r.value=t),r})},o=e.graph();return void 0!==o&&(r.value=structuredClone(o)),r}function iH(e){let t=new iI(e.options);return void 0!==e.value&&t.setGraph(e.value),e.nodes.forEach(e=>{t.setNode(e.v,e.value),e.parent&&t.setParent(e.v,e.parent)}),e.edges.forEach(e=>{t.setEdge({v:e.v,w:e.w,name:e.name},e.value)}),t}iA(iT,{read:()=>iH,write:()=>i$});var iV={};iA(iV,{CycleException:()=>i0,bellmanFord:()=>iX,components:()=>iY,dijkstra:()=>iZ,dijkstraAll:()=>iq,findCycles:()=>iG,floydWarshall:()=>iJ,isAcyclic:()=>i2,postorder:()=>i5,preorder:()=>i4,prim:()=>i6,shortestPaths:()=>i7,tarjan:()=>iU,topsort:()=>i1});var iF=()=>1;function iX(e,t,n,r){return function(e,t,n,r){let o={},i,a=0,s=e.nodes(),l=function(e){let t=n(e);o[e.v].distance+t<o[e.w].distance&&(o[e.w]={distance:o[e.v].distance+t,predecessor:e.v},i=!0)},d=function(){s.forEach(function(e){r(e).forEach(function(t){let n=t.v===e?t.v:t.w,r=n===t.v?t.w:t.v;l({v:n,w:r})})})};s.forEach(function(e){o[e]={distance:e===t?0:1/0,predecessor:""}});let u=s.length;for(let e=1;e<u&&(i=!1,a++,d(),i);e++);if(a===u-1&&(i=!1,d(),i))throw Error("The graph contains a negative weight cycle");return o}(e,String(t),n||iF,r||function(t){return e.outEdges(t)})}function iY(e){let t={},n=[],r;return e.nodes().forEach(function(o){r=[],function n(o){o in t||(t[o]=!0,r.push(o),e.successors(o).forEach(n),e.predecessors(o).forEach(n))}(o),r.length&&n.push(r)}),n}var iK=class{constructor(){this._arr=[],this._keyIndices={}}size(){return this._arr.length}keys(){return this._arr.map(e=>e.key)}has(e){return e in this._keyIndices}priority(e){let t=this._keyIndices[e];if(void 0!==t)return this._arr[t].priority}min(){if(0===this.size())throw Error("Queue underflow");return this._arr[0].key}add(e,t){let n=this._keyIndices,r=String(e);if(!(r in n)){let e=this._arr,o=e.length;return n[r]=o,e.push({key:r,priority:t}),this._decrease(o),!0}return!1}removeMin(){this._swap(0,this._arr.length-1);let e=this._arr.pop();return delete this._keyIndices[e.key],this._heapify(0),e.key}decrease(e,t){let n=this._keyIndices[e];if(void 0===n)throw Error(`Key not found: ${e}`);let r=this._arr[n].priority;if(t>r)throw Error(`New priority is greater than current priority. Key: ${e} Old: ${r} New: ${t}`);this._arr[n].priority=t,this._decrease(n)}_heapify(e){let t=this._arr,n=2*e,r=n+1,o=e;n<t.length&&(o=t[n].priority<t[o].priority?n:o,r<t.length&&(o=t[r].priority<t[o].priority?r:o),o!==e&&(this._swap(e,o),this._heapify(o)))}_decrease(e){let t=this._arr,n=t[e].priority,r;for(;0!==e&&!(t[r=e>>1].priority<n);)this._swap(e,r),e=r}_swap(e,t){let n=this._arr,r=this._keyIndices,o=n[e],i=n[t];n[e]=i,n[t]=o,r[i.key]=e,r[o.key]=t}},iW=()=>1;function iZ(e,t,n,r){return function(e,t,n,r){let o={},i=new iK,a,s,l=function(e){let t=e.v!==a?e.v:e.w,r=o[t],l=n(e),d=s.distance+l;if(l<0)throw Error("dijkstra does not allow negative edge weights. Bad edge: "+e+" Weight: "+l);d<r.distance&&(r.distance=d,r.predecessor=a,i.decrease(t,d))};for(e.nodes().forEach(function(e){let n=e===t?0:1/0;o[e]={distance:n,predecessor:""},i.add(e,n)});i.size()>0&&(s=o[a=i.removeMin()]).distance!==1/0;)r(a).forEach(l);return o}(e,String(t),n||iW,r||function(t){return e.outEdges(t)})}function iq(e,t,n){return e.nodes().reduce(function(r,o){return r[o]=iZ(e,o,t,n),r},{})}function iU(e){let t=0,n=[],r={},o=[];return e.nodes().forEach(function(i){i in r||function i(a){let s=r[a]={onStack:!0,lowlink:t,index:t++};if(n.push(a),e.successors(a).forEach(function(e){e in r?r[e].onStack&&(s.lowlink=Math.min(s.lowlink,r[e].index)):(i(e),s.lowlink=Math.min(s.lowlink,r[e].lowlink))}),s.lowlink===s.index){let e=[],t;do r[t=n.pop()].onStack=!1,e.push(t);while(a!==t)o.push(e)}}(i)}),o}function iG(e){return iU(e).filter(function(t){return t.length>1||1===t.length&&e.hasEdge(t[0],t[0])})}var iQ=()=>1;function iJ(e,t,n){var r,o,i;let a,s;return r=e,o=t||iQ,i=n||function(t){return e.outEdges(t)},a={},(s=r.nodes()).forEach(function(e){a[e]={},a[e][e]={distance:0,predecessor:""},s.forEach(function(t){e!==t&&(a[e][t]={distance:1/0,predecessor:""})}),i(e).forEach(function(t){let n=t.v===e?t.w:t.v,r=o(t);a[e][n]={distance:r,predecessor:e}})}),s.forEach(function(e){let t=a[e];s.forEach(function(n){let r=a[n];s.forEach(function(n){let o=r[e],i=t[n],a=r[n],s=o.distance+i.distance;s<a.distance&&(a.distance=s,a.predecessor=i.predecessor)})})}),a}var i0=class extends Error{constructor(...e){super(...e)}};function i1(e){let t={},n={},r=[];if(e.sinks().forEach(function o(i){if(i in n)throw new i0;i in t||(n[i]=!0,t[i]=!0,e.predecessors(i).forEach(o),delete n[i],r.push(i))}),Object.keys(t).length!==e.nodeCount())throw new i0;return r}function i2(e){try{i1(e)}catch(e){if(e instanceof i0)return!1;throw e}return!0}function i3(e,t,n){var r,o,i;let a,s;return r=t,o=function(e,t){return e.push(t),e},i=[],Array.isArray(r)||(r=[r]),a=t=>{var n;return null!=(n=e.isDirected()?e.successors(t):e.neighbors(t))?n:[]},s={},r.forEach(function(t){if(!e.hasNode(t))throw Error("Graph does not have node: "+t);i=function e(t,n,r,o,i,a,s){return n in o||(o[n]=!0,r||(s=a(s,n)),i(n).forEach(function(n){s=e(t,n,r,o,i,a,s)}),r&&(s=a(s,n))),s}(e,t,"post"===n,s,a,o,i)}),i}function i5(e,t){return i3(e,t,"post")}function i4(e,t){return i3(e,t,"pre")}function i6(e,t){let n=new iI,r={},o=new iK,i;function a(e){let n=e.v===i?e.w:e.v,a=o.priority(n);if(void 0!==a){let s=t(e);s<a&&(r[n]=i,o.decrease(n,s))}}if(0===e.nodeCount())return n;e.nodes().forEach(function(e){o.add(e,1/0),n.setNode(e)}),o.decrease(e.nodes()[0],0);let s=!1;for(;o.size()>0;){if((i=o.removeMin())in r)n.setEdge(i,r[i]);else{if(s)throw Error("Input graph is not connected: "+e);s=!0}e.nodeEdges(i).forEach(a)}return n}function i7(e,t,n,r){return function(e,t,n,r){if(void 0===n)return iZ(e,t,n,r);let o=!1,i=e.nodes();for(let a=0;a<i.length;a++){let s=r(i[a]);for(let e=0;e<s.length;e++){let t=s[e],r=t.v===i[a]?t.v:t.w,l=r===t.v?t.w:t.v;0>n({v:r,w:l})&&(o=!0)}if(o)return iX(e,t,n,r)}return iZ(e,t,n,r)}(e,t,n,null!=r?r:t=>{let n=e.outEdges(t);return null!=n?n:[]})}function i8(e,t,n,r){let o=r;for(;e.hasNode(o);)o=r+""+ ++as;return n.dummy=t,e.setNode(o,n),o}function i9(e){let t=new iI({multigraph:e.isMultigraph()}).setGraph(e.graph());return e.nodes().forEach(n=>{e.children(n).length||t.setNode(n,e.node(n))}),e.edges().forEach(n=>{t.setEdge(n,e.edge(n))}),t}function ae(e,t){let n,r,o=e.x,i=e.y,a=t.x-o,s=t.y-i,l=e.width/2,d=e.height/2;if(!a&&!s)throw Error("Not possible to find intersection inside of the rectangle");return Math.abs(s)*l>Math.abs(a)*d?(s<0&&(d=-d),n=d*a/s,r=d):(a<0&&(l=-l),n=l,r=l*s/a),{x:o+n,y:i+r}}function at(e){let t=al(ao(e)+1).map(()=>[]);return e.nodes().forEach(n=>{let r=e.node(n),o=r.rank;void 0!==o&&(t[o]||(t[o]=[]),t[o][r.order]=n)}),t}function an(e,t,n,r){let o={width:0,height:0};return arguments.length>=4&&(o.rank=n,o.order=r),i8(e,"border",o,t)}function ar(e,t){return t.length>65535?e(...(function(e,t=65535){let n=[];for(let r=0;r<e.length;r+=t){let o=e.slice(r,r+t);n.push(o)}return n})(t).map(t=>e(...t))):e(...t)}function ao(e){return ar(Math.max,e.nodes().map(t=>{let n=e.node(t).rank;return void 0===n?5e-324:n}))}function ai(e,t){let n=Date.now();try{return t()}finally{console.log(e+" time: "+(Date.now()-n)+"ms")}}function aa(e,t){return t()}var as=0;function al(e,t,n=1){null==t&&(t=e,e=0);let r=e=>e<t;n<0&&(r=e=>t<e);let o=[];for(let t=e;r(t);t+=n)o.push(t);return o}function ad(e,t){let n={};for(let r of t)void 0!==e[r]&&(n[r]=e[r]);return n}function au(e,t){let n;return n="string"==typeof t?e=>e[t]:t,Object.entries(e).reduce((e,[t,r])=>(e[t]=n(r,t),e),{})}var ac=class{constructor(){((e,t,n)=>{let r;return(r="symbol"!=typeof t?t+"":t)in e?iN(e,r,{enumerable:!0,configurable:!0,writable:!0,value:n}):e[r]=n})(this,"_sentinel");let e={};e._next=e._prev=e,this._sentinel=e}dequeue(){let e=this._sentinel,t=e._prev;if(t!==e)return ah(t),t}enqueue(e){let t=this._sentinel;e._prev&&e._next&&ah(e),e._next=t._next,t._next._prev=e,t._next=e,e._prev=t}toString(){let e=[],t=this._sentinel,n=t._prev;for(;n!==t;)e.push(JSON.stringify(n,af)),n=n._prev;return"["+e.join(", ")+"]"}};function ah(e){e._prev._next=e._next,e._next._prev=e._prev,delete e._next,delete e._prev}function af(e,t){if("_next"!==e&&"_prev"!==e)return t}var ap=()=>1;function ag(e,t,n,r,o){let i=[],a=o?i:void 0;return(e.inEdges(r.v)||[]).forEach(r=>{let a=e.edge(r),s=e.node(r.v);o&&i.push({v:r.v,w:r.w}),s.out-=a,am(t,n,s)}),(e.outEdges(r.v)||[]).forEach(r=>{let o=e.edge(r),i=r.w,a=e.node(i);a.in-=o,am(t,n,a)}),e.removeNode(r.v),a}function am(e,t,n){var r,o,i;n.out?n.in?null==(i=e[n.out-n.in+t])||i.enqueue(n):null==(o=e[e.length-1])||o.enqueue(n):null==(r=e[0])||r.enqueue(n)}function ay(e){let t={};e.sources().forEach(function n(r){let o=e.node(r);if(Object.hasOwn(t,r))return o.rank;t[r]=!0;let i=e.outEdges(r),a=ar(Math.min,i?i.map(t=>null==t?1/0:n(t.w)-e.edge(t).minlen):[]);return a===1/0&&(a=0),o.rank=a})}function av(e,t){return e.node(t.w).rank-e.node(t.v).rank-e.edge(t).minlen}var ax=function(e){var t,n,r,o;let i,a,s=new iI({directed:!1}),l=e.nodes();if(0===l.length)throw Error("Graph must have at least one node");let d=l[0],u=e.nodeCount();for(s.setNode(d,{});t=s,n=e,t.nodes().forEach(function e(r){let o=n.nodeEdges(r);o&&o.forEach(o=>{let i=o.v,a=r===i?o.w:i;t.hasNode(a)||av(n,o)||(t.setNode(a,{}),t.setEdge(r,a,{}),e(a))})}),t.nodeCount()<u&&(r=s,i=(o=e).edges().reduce((e,t)=>{let n=1/0;return r.hasNode(t.v)!==r.hasNode(t.w)&&(n=av(o,t)),n<e[0]?[n,t]:e},[1/0,null])[1]);)a=s.hasNode(i.v)?av(e,i):-av(e,i),function(e,t,n){e.nodes().forEach(e=>t.node(e).rank+=n)}(s,e,a);return s},{preorder:aw,postorder:ab}=iV;function a_(e){var t;let n,r,o;t=e,o=new iI().setGraph(t.graph()),t.nodes().forEach(e=>o.setNode(e,t.node(e))),t.edges().forEach(e=>{let n=o.edge(e.v,e.w)||{weight:0,minlen:1},r=t.edge(e);o.setEdge(e.v,e.w,{weight:n.weight+r.weight,minlen:Math.max(n.minlen,r.minlen)})}),ay(e=o);let i=ax(e);for(aC(i),aE(i,e);n=aS(i);)r=aN(i,e,n),aM(i,e,n,r)}function aE(e,t){let n=ab(e,e.nodes());(n=n.slice(0,n.length-1)).forEach(n=>{var r,o,i;let a;return r=e,o=t,i=n,a=r.node(i).parent,void(r.edge(i,a).cutvalue=ak(r,o,i))})}function ak(e,t,n){let r=e.node(n).parent,o=!0,i=t.edge(n,r),a=0;i||(o=!1,i=t.edge(r,n)),a=i.weight;let s=t.nodeEdges(n);return s&&s.forEach(i=>{let s=i.v===n,l=s?i.w:i.v;if(l!==r){var d,u,c;let r=s===o,h=t.edge(i).weight;if(a+=r?h:-h,d=e,u=n,c=l,d.hasEdge(u,c)){let t=e.edge(n,l).cutvalue;a+=r?-t:t}}}),a}function aC(e,t){arguments.length<2&&(t=e.nodes()[0]),function e(t,n,r,o,i){let a=r,s=t.node(o);n[o]=!0;let l=t.neighbors(o);return l&&l.forEach(i=>{Object.hasOwn(n,i)||(r=e(t,n,r,i,o))}),s.low=a,s.lim=r++,i?s.parent=i:delete s.parent,r}(e,{},1,t)}function aS(e){return e.edges().find(t=>e.edge(t).cutvalue<0)}function aN(e,t,n){let r=n.v,o=n.w;t.hasEdge(r,o)||(r=n.w,o=n.v);let i=e.node(r),a=e.node(o),s=i,l=!1;return i.lim>a.lim&&(s=a,l=!0),t.edges().filter(t=>l===aj(e,e.node(t.v),s)&&l!==aj(e,e.node(t.w),s)).reduce((e,n)=>av(t,n)<av(t,e)?n:e)}function aM(e,t,n,r){let o=n.v,i=n.w;e.removeEdge(o,i),e.setEdge(r.v,r.w,{}),aC(e),aE(e,t),function(e,t){let n=e.nodes().find(t=>!e.node(t).parent);if(!n)return;let r=aw(e,[n]);(r=r.slice(1)).forEach(n=>{let r=e.node(n).parent,o=t.edge(n,r),i=!1;o||(o=t.edge(r,n),i=!0),t.node(n).rank=t.node(r).rank+(i?o.minlen:-o.minlen)})}(e,t)}function aj(e,t,n){return n.low<=t.lim&&t.lim<=n.lim}a_.initLowLimValues=aC,a_.initCutValues=aE,a_.calcCutValue=ak,a_.leaveEdge=aS,a_.enterEdge=aN,a_.exchangeEdges=aM;function aO(e,t,n,r,o,i){let a=o[t][i-1],s=i8(e,"border",{width:0,height:0,rank:i,borderType:t},n);o[t][i]=s,e.setParent(s,r),a&&e.setEdge(a,s,{weight:1})}function aP(e){e.nodes().forEach(t=>aA(e.node(t))),e.edges().forEach(t=>aA(e.edge(t)))}function aA(e){let t=e.width;e.width=e.height,e.height=t}function aI(e){e.y=-e.y}function az(e){let t=e.x;e.x=e.y,e.y=t}function aD(e,t,n){let r;for(;t.length&&(r=t[t.length-1]).i<=n;)t.pop(),e.push(r.vs),n++;return n}function aL(e,t,n){let r=new Map,o=(e,t)=>{r.has(e)||r.set(e,[]),r.get(e).push(t)};for(let t of e.nodes()){let n=e.node(t);if("number"==typeof n.rank&&o(n.rank,t),"number"==typeof n.minRank&&"number"==typeof n.maxRank)for(let e=n.minRank;e<=n.maxRank;e++)e!==n.rank&&o(e,t)}return t.map(function(t){var o;let i,a;return o=r.get(t)||[],i=function(e){let t;for(;e.hasNode(t="_root"+ ++as););return t}(e),a=new iI({compound:!0}).setGraph({root:i}).setDefaultNodeLabel(t=>e.node(t)),o.forEach(r=>{let o=e.node(r),s=e.parent(r);if(o.rank===t||o.minRank<=t&&t<=o.maxRank){a.setNode(r),a.setParent(r,s||i);let l=e[n](r);l&&l.forEach(t=>{let n=t.v===r?t.w:t.v,o=a.edge(n,r),i=void 0!==o?o.weight:0;a.setEdge(n,r,{weight:e.edge(t).weight+i})}),Object.hasOwn(o,"minRank")&&a.setNode(r,{borderLeft:o.borderLeft[t],borderRight:o.borderRight[t]})}}),a})}function aR(e,t){Object.values(t).forEach(t=>t.forEach((t,n)=>e.node(t).order=n))}function aB(e,t,n){if(t>n){let e=t;t=n,n=e}let r=e[t];r||(e[t]=r={}),r[n]=!0}var aT=["nodesep","edgesep","ranksep","marginx","marginy"],a$={ranksep:50,edgesep:20,nodesep:50,rankdir:"TB",rankalign:"center"},aH=["acyclicer","ranker","rankdir","align","rankalign"],aV=["width","height","rank"],aF={width:0,height:0},aX=["minlen","weight","width","height","labeloffset"],aY={minlen:1,weight:1,width:0,height:0,labeloffset:10,labelpos:"r"},aK=["labelpos"];function aW(e,t){return au(ad(e,t),Number)}function aZ(e){let t={};return e&&Object.entries(e).forEach(([e,n])=>{"string"==typeof e&&(e=e.toLowerCase()),t[e]=n}),t}var aq=function(e,t={}){let n=t.debugTiming?ai:aa;return n("layout",()=>{let r=n(" buildLayoutGraph",()=>{var t;let n,r;return t=e,n=new iI({multigraph:!0,compound:!0}),r=aZ(t.graph()),n.setGraph(Object.assign({},a$,aW(r,aT),ad(r,aH))),t.nodes().forEach(e=>{let r=aW(aZ(t.node(e)),aV);Object.keys(aF).forEach(e=>{void 0===r[e]&&(r[e]=aF[e])}),n.setNode(e,r);let o=t.parent(e);void 0!==o&&n.setParent(e,o)}),t.edges().forEach(e=>{let r=aZ(t.edge(e));n.setEdge(e,Object.assign({},aY,aW(r,aX),ad(r,aK)))}),n});return n(" runLayout",()=>{var e,o,i;return e=r,o=n,i=t,void(o(" makeSpaceForEdgeLabels",()=>{var t;let n;return n=(t=e).graph(),void(n.ranksep/=2,t.edges().forEach(e=>{let r=t.edge(e);r.minlen*=2,"c"!==r.labelpos.toLowerCase()&&("TB"===n.rankdir||"BT"===n.rankdir?r.width+=r.labeloffset:r.height+=r.labeloffset)}))}),o(" removeSelfEdges",()=>{var t;(t=e).edges().forEach(e=>{if(e.v===e.w){let n=t.node(e.v);n.selfEdges||(n.selfEdges=[]),n.selfEdges.push({e:e,label:t.edge(e)}),t.removeEdge(e)}})}),o(" acyclic",()=>{var t,n;let r,o,i;("greedy"===e.graph().acyclicer?function(e,t){var n,r;let o,i,a,s,l;if(1>=e.nodeCount())return[];let d=(n=e,r=t||ap,o=new iI,i=0,a=0,n.nodes().forEach(e=>{o.setNode(e,{v:e,in:0,out:0})}),n.edges().forEach(e=>{let t=o.edge(e.v,e.w)||0,n=r(e);o.setEdge(e.v,e.w,t+n);let s=o.node(e.v),l=o.node(e.w);a=Math.max(a,s.out+=n),i=Math.max(i,l.in+=n)}),s=(function(e){let t=[];for(let n=0;n<e;n++)t.push(n);return t})(a+i+3).map(()=>new ac),l=i+1,o.nodes().forEach(e=>{am(s,l,o.node(e))}),{graph:o,buckets:s,zeroIdx:l});return(function(e,t,n){var r;let o=[],i=t[t.length-1],a=t[0],s;for(;e.nodeCount();){for(;s=a.dequeue();)ag(e,t,n,s);for(;s=i.dequeue();)ag(e,t,n,s);if(e.nodeCount()){for(let i=t.length-2;i>0;--i)if(s=null==(r=t[i])?void 0:r.dequeue()){o=o.concat(ag(e,t,n,s,!0)||[]);break}}}return o})(d.graph,d.buckets,d.zeroIdx).flatMap(t=>e.outEdges(t.v,t.w)||[])}(e,(t=e,e=>t.edge(e).weight)):(r=[],o={},i={},(n=e).nodes().forEach(function e(t){Object.hasOwn(i,t)||(i[t]=!0,o[t]=!0,n.outEdges(t).forEach(t=>{Object.hasOwn(o,t.w)?r.push(t):e(t.w)}),delete o[t])}),r)).forEach(t=>{let n=e.edge(t);e.removeEdge(t),n.forwardName=t.name,n.reversed=!0,e.setEdge(t.w,t.v,n,"rev"+ ++as)})}),o(" nestingGraph.run",()=>{var t,n;let r,o,i,a,s,l;return r=i8(e,"root",{},"_root"),a=2*(i=ar(Math.max,Object.values((l={},(t=e).children("\0").forEach(e=>(function e(n,r){let o=t.children(n);o&&o.length&&o.forEach(t=>e(t,r+1)),l[n]=r})(e,1)),o=l)))-1)+1,e.graph().nestingRoot=r,e.edges().forEach(t=>e.edge(t).minlen*=a),s=(n=e).edges().reduce((e,t)=>e+n.edge(t).weight,0)+1,void(e.children("\0").forEach(t=>(function e(t,n,r,o,i,a,s){var l;let d=t.children(s);if(!d.length){s!==n&&t.setEdge(n,s,{weight:0,minlen:r});return}let u=an(t,"_bt"),c=an(t,"_bb"),h=t.node(s);t.setParent(u,s),h.borderTop=u,t.setParent(c,s),h.borderBottom=c,d.forEach(l=>{var d;e(t,n,r,o,i,a,l);let h=t.node(l),f=h.borderTop?h.borderTop:l,p=h.borderBottom?h.borderBottom:l,g=h.borderTop?o:2*o,m=f!==p?1:i-(null!=(d=a[s])?d:0)+1;t.setEdge(u,f,{weight:g,minlen:m,nestingEdge:!0}),t.setEdge(p,c,{weight:g,minlen:m,nestingEdge:!0})}),t.parent(s)||t.setEdge(n,u,{weight:0,minlen:i+(null!=(l=a[s])?l:0)})})(e,r,a,s,i,o,t)),e.graph().nodeRankFactor=a)}),o(" rank",()=>(function(e){let t=e.graph().ranker;if("function"==typeof t)return t(e);switch(t){case"network-simplex":default:a_(e);break;case"tight-tree":var n;ay(n=e),ax(n);break;case"longest-path":ay(e);case"none":}})(i9(e))),o(" injectEdgeLabelProxies",()=>{var t;(t=e).edges().forEach(e=>{let n=t.edge(e);if(n.width&&n.height){let n=t.node(e.v),r={rank:(t.node(e.w).rank-n.rank)/2+n.rank,e:e};i8(t,"edge-proxy",r,"_ep")}})}),o(" removeEmptyRanks",()=>{let t,n,r,o;return t=ar(Math.min,e.nodes().map(t=>e.node(t).rank).filter(e=>void 0!==e)),n=[],e.nodes().forEach(r=>{let o=e.node(r).rank-t;n[o]||(n[o]=[]),n[o].push(r)}),r=0,o=e.graph().nodeRankFactor,void Array.from(n).forEach((t,n)=>{void 0===t&&n%o!=0?--r:void 0!==t&&r&&t.forEach(t=>e.node(t).rank+=r)})}),o(" nestingGraph.cleanup",()=>{let t;return t=e.graph(),void(e.removeNode(t.nestingRoot),delete t.nestingRoot,e.edges().forEach(t=>{e.edge(t).nestingEdge&&e.removeEdge(t)}))}),o(" normalizeRanks",()=>{let t;return t=ar(Math.min,e.nodes().map(t=>{let n=e.node(t).rank;return void 0===n?Number.MAX_VALUE:n})),void e.nodes().forEach(n=>{let r=e.node(n);Object.hasOwn(r,"rank")&&(r.rank-=t)})}),o(" assignRankMinMax",()=>{var t;let n;return n=0,void((t=e).nodes().forEach(e=>{let r=t.node(e);r.borderTop&&(r.minRank=t.node(r.borderTop).rank,r.maxRank=t.node(r.borderBottom).rank,n=Math.max(n,r.maxRank))}),t.graph().maxRank=n)}),o(" removeEdgeLabelProxies",()=>{var t;(t=e).nodes().forEach(e=>{let n=t.node(e);"edge-proxy"===n.dummy&&(t.edge(n.e).labelRank=n.rank,t.removeNode(e))})}),o(" normalize.run",()=>{e.graph().dummyChains=[],e.edges().forEach(t=>(function(e,t){let n,r,o,i=t.v,a=e.node(i).rank,s=t.w,l=e.node(s).rank,d=t.name,u=e.edge(t),c=u.labelRank;if(l!==a+1){for(e.removeEdge(t),o=0,++a;a<l;++o,++a)u.points=[],n=i8(e,"edge",r={width:0,height:0,edgeLabel:u,edgeObj:t,rank:a},"_d"),a===c&&(r.width=u.width,r.height=u.height,r.dummy="edge-label",r.labelpos=u.labelpos),e.setEdge(i,n,{weight:u.weight},d),0===o&&e.graph().dummyChains.push(n),i=n;e.setEdge(i,s,{weight:u.weight},d)}})(e,t))}),o(" parentDummyChains",()=>{var t,n;let r,o,i;return i=(r={},o=0,(n=t=e).children("\0").forEach(function e(t){let i=o;n.children(t).forEach(e),r[t]={low:i,lim:o++}}),r),void t.graph().dummyChains.forEach(e=>{let n=t.node(e),r=n.edgeObj,o=function(e,t,n,r){let o=[],i=[],a=Math.min(t[n].low,t[r].low),s=Math.max(t[n].lim,t[r].lim),l;l=n;do o.push(l=e.parent(l));while(l&&(t[l].low>a||s>t[l].lim))let d=l,u=r;for(;(u=e.parent(u))!==d;)i.push(u);return{path:o.concat(i.reverse()),lca:d}}(t,i,r.v,r.w),a=o.path,s=o.lca,l=0,d=a[0],u=!0;for(;e!==r.w;){if(n=t.node(e),u){for(;(d=a[l])!==s&&t.node(d).maxRank<n.rank;)l++;d===s&&(u=!1)}if(!u){for(;l<a.length-1&&t.node(a[l+1]).minRank<=n.rank;)l++;d=a[l]}void 0!==d&&t.setParent(e,d),e=t.successors(e)[0]}})}),o(" addBorderSegments",()=>{var t;(t=e).children("\0").forEach(function e(n){let r=t.children(n),o=t.node(n);if(r.length&&r.forEach(e),Object.hasOwn(o,"minRank")){o.borderLeft=[],o.borderRight=[];for(let e=o.minRank,r=o.maxRank+1;e<r;++e)aO(t,"borderLeft","_bl",n,o,e),aO(t,"borderRight","_br",n,o,e)}})}),o(" order",()=>(function e(t,n={}){let r,o,i;if("function"==typeof n.customOrder)return void n.customOrder(t,e);let a=ao(t),s=aL(t,al(1,a+1),"inEdges"),l=aL(t,al(a-1,-1,-1),"outEdges"),d=(r={},i=al(ar(Math.max,(o=t.nodes().filter(e=>!t.children(e).length)).map(e=>t.node(e).rank))+1).map(()=>[]),o.sort((e,n)=>t.node(e).rank-t.node(n).rank).forEach(function e(n){if(r[n])return;r[n]=!0,i[t.node(n).rank].push(n);let o=t.successors(n);o&&o.forEach(e)}),i);if(aR(t,d),n.disableOptimalOrderHeuristic)return;let u=1/0,c,h=n.constraints||[];for(let e=0,n=0;n<4;++e,++n){(function(e,t,n){let r=new iI;e.forEach(function(e){var o;let i,a;n.forEach(e=>r.setEdge(e.left,e.right));let s=e.graph().root,l=function e(t,n,r,o){var i;let a,s,l,d,u,c,h,f,p,g,m=t.children(n),y=t.node(n),v=y?y.borderLeft:void 0,x=y?y.borderRight:void 0,w={};v&&(m=m.filter(e=>e!==v&&e!==x));let b=function(e,t=[]){return t.map(t=>{let n=e.inEdges(t);if(!n||!n.length)return{v:t};{let r=n.reduce((t,n)=>{let r=e.edge(n),o=e.node(n.v);return{sum:t.sum+r.weight*o.order,weight:t.weight+r.weight}},{sum:0,weight:0});return{v:t,barycenter:r.sum/r.weight,weight:r.weight}}})}(t,m);b.forEach(n=>{if(t.children(n.v).length){var i,a;let s=e(t,n.v,r,o);w[n.v]=s,Object.hasOwn(s,"barycenter")&&(i=n,a=s,void 0!==i.barycenter?(i.barycenter=(i.barycenter*i.weight+a.barycenter*a.weight)/(i.weight+a.weight),i.weight+=a.weight):(i.barycenter=a.barycenter,i.weight=a.weight))}});let _=(a={},b.forEach((e,t)=>{let n={indegree:0,in:[],out:[],vs:[e.v],i:t};void 0!==e.barycenter&&(n.barycenter=e.barycenter,n.weight=e.weight),a[e.v]=n}),r.edges().forEach(e=>{let t=a[e.v],n=a[e.w];void 0!==t&&void 0!==n&&(n.indegree++,t.out.push(n))}),function(e){let t=[];for(;e.length;){let n=e.pop();t.push(n),n.in.reverse().forEach(function(e){return t=>{t.merged||(void 0===t.barycenter||void 0===e.barycenter||t.barycenter>=e.barycenter)&&function(e,t){let n=0,r=0;e.weight&&(n+=e.barycenter*e.weight,r+=e.weight),t.weight&&(n+=t.barycenter*t.weight,r+=t.weight),e.vs=t.vs.concat(e.vs),e.barycenter=n/r,e.weight=r,e.i=Math.min(t.i,e.i),t.merged=!0}(e,t)}}(n)),n.out.forEach(function(t){return n=>{n.in.push(t),0==--n.indegree&&e.push(n)}}(n))}return t.filter(e=>!e.merged).map(e=>ad(e,["vs","i","barycenter","weight"]))}(Object.values(a).filter(e=>!e.indegree)));!function(e,t){e.forEach(e=>{e.vs=e.vs.flatMap(e=>t[e]?t[e].vs:e)})}(_,w);let E=(d=(i=e=>Object.hasOwn(e,"barycenter"),s={lhs:[],rhs:[]},_.forEach(e=>{i(e)?s.lhs.push(e):s.rhs.push(e)}),l=s).lhs,u=l.rhs.sort((e,t)=>t.i-e.i),c=[],h=0,f=0,p=0,d.sort(function(e){return(t,n)=>t.barycenter<n.barycenter?-1:t.barycenter>n.barycenter?1:e?n.i-t.i:t.i-n.i}(!!o)),p=aD(c,u,p),d.forEach(e=>{p+=e.vs.length,c.push(e.vs),h+=e.barycenter*e.weight,f+=e.weight,p=aD(c,u,p)}),g={vs:c.flat(1)},f&&(g.barycenter=h/f,g.weight=f),g);if(v&&x){E.vs=[v,E.vs,x].flat(1);let e=t.predecessors(v);if(e&&e.length){let n=t.node(e[0]),r=t.predecessors(x),o=t.node(r[0]);Object.hasOwn(E,"barycenter")||(E.barycenter=0,E.weight=0),E.barycenter=(E.barycenter*E.weight+n.order+o.order)/(E.weight+2),E.weight+=2}}return E}(e,s,r,t);l.vs.forEach((t,n)=>e.node(t).order=n),o=l.vs,i={},o.forEach(t=>{let n=e.parent(t),o,s;for(;n;){if((o=e.parent(n))?(s=i[o],i[o]=n):(s=a,a=n),s&&s!==n)return void r.setEdge(s,n);n=o}})})})(e%2?s:l,e%4>=2,h),d=at(t);let r=function(e,t){let n=0;for(let r=1;r<t.length;++r)n+=function(e,t,n){var r;let o=(r=n.map((e,t)=>t),n.reduce((e,t,n)=>(e[t]=r[n],e),{})),i=t.flatMap(t=>{let n=e.outEdges(t);return n?n.map(t=>({pos:o[t.w],weight:e.edge(t).weight})).sort((e,t)=>e.pos-t.pos):[]}),a=1;for(;a<n.length;)a<<=1;let s=2*a-1;a-=1;let l=Array(s).fill(0),d=0;return i.forEach(e=>{let t=e.pos+a;l[t]+=e.weight;let n=0;for(;t>0;)t%2&&(n+=l[t+1]),t=t-1>>1,l[t]+=e.weight;d+=e.weight*n}),d}(e,t[r-1],t[r]);return n}(t,d);r<u?(n=0,c=Object.assign({},d),u=r):r===u&&(c=structuredClone(d))}aR(t,c)})(e,i)),o(" insertSelfEdges",()=>{var t;at(t=e).forEach(e=>{let n=0;e.forEach((e,r)=>{let o=t.node(e);o.order=r+n,(o.selfEdges||[]).forEach(e=>{i8(t,"selfedge",{width:e.label.width,height:e.label.height,rank:o.rank,order:r+ ++n,e:e.e,label:e.label},"_se")}),delete o.selfEdges})})}),o(" adjustCoordinateSystem",()=>{var t;let n;("lr"===(n=null==(t=e.graph().rankdir)?void 0:t.toLowerCase())||"rl"===n)&&aP(e)}),o(" position",()=>{var t,n,r,o;let i,a,s,l,d,u,c,h,f,p,g,m,y,v,x;g=at(o=t=i9(t=e)),y=(m=o.graph()).ranksep,v=m.rankalign,x=0,g.forEach(e=>{let t=e.reduce((e,t)=>{var n;let r=null!=(n=o.node(t).height)?n:0;return e>r?e:r},0);e.forEach(e=>{let n=o.node(e);"top"===v?n.y=x+n.height/2:"bottom"===v?n.y=x+t-n.height/2:n.y=x+t/2}),x+=t+y}),Object.entries((a=at(n=t),s=Object.assign((i={},a.length&&a.reduce(function(e,t){let r=0,o=0,a=e.length,s=t[t.length-1];return t.forEach((e,l)=>{let d=function(e,t){if(e.node(t).dummy){let n=e.predecessors(t);if(n)return n.find(t=>e.node(t).dummy)}}(n,e),u=d?n.node(d).order:a;(d||e===s)&&(t.slice(o,l+1).forEach(e=>{let t=n.predecessors(e);t&&t.forEach(t=>{let o=n.node(t),a=o.order;(a<r||u<a)&&!(o.dummy&&n.node(e).dummy)&&aB(i,t,e)})}),o=l+1,r=u)}),t}),i),function(e,t){let n={};function r(t,r,o,i,a){al(r,o).forEach(r=>{let o=t[r];if(void 0!==o&&e.node(o).dummy){let t=e.predecessors(o);t&&t.forEach(t=>{if(void 0===t)return;let r=e.node(t);r.dummy&&(r.order<i||r.order>a)&&aB(n,t,o)})}})}return t.length&&t.reduce(function(t,n){let o=-1,i=-1,a=0;return n.forEach((s,l)=>{if("border"===e.node(s).dummy){let t=e.predecessors(s);if(t&&t.length){let s=t[0];if(void 0===s)return;i=e.node(s).order,r(n,a,l,o,i),a=l,o=i}}r(n,a,n.length,i,t.length)}),n}),n}(n,a)),l={},["u","d"].forEach(e=>{d="u"===e?a:Object.values(a).reverse(),["l","r"].forEach(t=>{var r,o;let i,a,u;"r"===t&&(d=d.map(e=>Object.values(e).reverse()));let c=(r=d,o=t=>("u"===e?n.predecessors(t):n.successors(t))||[],i={},a={},u={},r.forEach(e=>{e.forEach((e,t)=>{i[e]=e,a[e]=e,u[e]=t})}),r.forEach(e=>{let t=-1;e.forEach(e=>{let n=o(e);if(n&&n.length){let r=n.sort((e,t)=>{let n=u[e],r=u[t];return(void 0!==n?n:0)-(void 0!==r?r:0)}),o=(r.length-1)/2;for(let n=Math.floor(o),l=Math.ceil(o);n<=l;++n){let o=r[n];if(void 0===o)continue;let l=u[o];if(void 0!==l&&a[e]===e&&t<l&&!function(e,t,n){if(t>n){let e=t;t=n,n=e}let r=e[t];return void 0!==r&&Object.hasOwn(r,n)}(s,e,o)){let n=i[o];void 0!==n&&(a[o]=e,a[e]=i[e]=n,t=l)}}}})}),{root:i,align:a}),h=function(e,t,n,r,o=!1){var i,a,s,l,d,u,c;let h,f,p,g={},m=(i=e,a=t,s=n,l=o,h=new iI,p=(d=(f=i.graph()).nodesep,u=f.edgesep,c=l,(e,t,n)=>{let r=e.node(t),o=e.node(n),i,a;if(i=0+r.width/2,Object.hasOwn(r,"labelpos"))switch(r.labelpos.toLowerCase()){case"l":a=-r.width/2;break;case"r":a=r.width/2}if(a&&(i+=c?a:-a),a=void 0,i+=(r.dummy?u:d)/2,i+=(o.dummy?u:d)/2,i+=o.width/2,Object.hasOwn(o,"labelpos"))switch(o.labelpos.toLowerCase()){case"l":a=o.width/2;break;case"r":a=-o.width/2}return a&&(i+=c?a:-a),i}),a.forEach(e=>{let t;e.forEach(e=>{let n=s[e];if(void 0!==n){if(h.setNode(n),void 0!==t){let r=s[t];if(void 0!==r){let o=h.edge(r,n);h.setEdge(r,n,Math.max(p(i,e,t),o||0))}}t=e}})}),h),y=o?"borderLeft":"borderRight";function v(e,t){let n=m.nodes().slice(),r={},o=n.pop();for(;o;){if(r[o])e(o);else for(let e of(r[o]=!0,n.push(o),t(o)))n.push(e);o=n.pop()}}return v(function(e){let t=m.inEdges(e);t?g[e]=t.reduce((e,t)=>{var n;let r=null!=(n=g[t.v])?n:0,o=m.edge(t);return Math.max(e,r+(void 0!==o?o:0))},0):g[e]=0},function(e){return m.predecessors(e)||[]}),v(function(t){let n=m.outEdges(t),r=1/0;n&&(r=n.reduce((e,t)=>{let n=g[t.w],r=m.edge(t);return Math.min(e,(void 0!==n?n:0)-(void 0!==r?r:0))},1/0));let o=e.node(t);r!==1/0&&o.borderType!==y&&(g[t]=Math.max(void 0!==g[t]?g[t]:0,r))},function(e){return m.successors(e)||[]}),Object.keys(r).forEach(e=>{var t;let r=n[e];void 0!==r&&(g[e]=null!=(t=g[r])?t:0)}),g}(n,d,c.root,c.align,"r"===t);"r"===t&&(h=au(h,e=>-e)),l[e+t]=h})}),u=Object.values(l).reduce((e,t)=>{let r=-1/0,o=1/0;Object.entries(t).forEach(([e,t])=>{var i,a;let s=(i=n,a=e,i.node(a).width/2);r=Math.max(t+s,r),o=Math.min(t-s,o)});let i=r-o;return i<e[0]&&(e=[i,t]),e},[1/0,null])[1],h=ar(Math.min,c=Object.values(u)),f=ar(Math.max,c),["u","d"].forEach(e=>{["l","r"].forEach(t=>{let n=e+t,r=l[n];if(!r||r===u)return;let o=Object.values(r),i=h-ar(Math.min,o);"l"!==t&&(i=f-ar(Math.max,o)),i&&(l[n]=au(r,e=>e+i))})}),r=n.graph().align,(p=l.ul)?au(p,(e,t)=>{var n,o;if(r){let e=l[r.toLowerCase()];if(e&&void 0!==e[t])return e[t]}let i=Object.values(l).map(e=>{let n=e[t];return void 0!==n?n:0}).sort((e,t)=>e-t);return((null!=(n=i[1])?n:0)+(null!=(o=i[2])?o:0))/2}):{})).forEach(([e,n])=>t.node(e).x=n)}),o(" positionSelfEdges",()=>{var t;(t=e).nodes().forEach(e=>{let n=t.node(e);if("selfedge"===n.dummy){let r=t.node(n.e.v),o=r.x+r.width/2,i=r.y,a=n.x-o,s=r.height/2;t.setEdge(n.e,n.label),t.removeNode(e),n.label.points=[{x:o+2*a/3,y:i-s},{x:o+5*a/6,y:i-s},{x:o+a,y:i},{x:o+5*a/6,y:i+s},{x:o+2*a/3,y:i+s}],n.label.x=n.x,n.label.y=n.y}})}),o(" removeBorderNodes",()=>{var t;(t=e).nodes().forEach(e=>{if(t.children(e).length){let n=t.node(e),r=t.node(n.borderTop),o=t.node(n.borderBottom),i=t.node(n.borderLeft[n.borderLeft.length-1]),a=t.node(n.borderRight[n.borderRight.length-1]);n.width=Math.abs(a.x-i.x),n.height=Math.abs(o.y-r.y),n.x=i.x+n.width/2,n.y=r.y+n.height/2}}),t.nodes().forEach(e=>{"border"===t.node(e).dummy&&t.removeNode(e)})}),o(" normalize.undo",()=>{e.graph().dummyChains.forEach(t=>{let n=e.node(t),r=n.edgeLabel,o;for(e.setEdge(n.edgeObj,r);n.dummy;)o=e.successors(t)[0],e.removeNode(t),r.points.push({x:n.x,y:n.y}),"edge-label"===n.dummy&&(r.x=n.x,r.y=n.y,r.width=n.width,r.height=n.height),t=o,n=e.node(t)})}),o(" fixupEdgeLabelCoords",()=>{var t;(t=e).edges().forEach(e=>{let n=t.edge(e);if(Object.hasOwn(n,"x"))switch(("l"===n.labelpos||"r"===n.labelpos)&&(n.width-=n.labeloffset),n.labelpos){case"l":n.x-=n.width/2+n.labeloffset;break;case"r":n.x+=n.width/2+n.labeloffset}})}),o(" undoCoordinateSystem",()=>{var t,n,r;let o;("bt"===(o=null==(t=e.graph().rankdir)?void 0:t.toLowerCase())||"rl"===o)&&((n=e).nodes().forEach(e=>aI(n.node(e))),n.edges().forEach(e=>{var t;let r=n.edge(e);null==(t=r.points)||t.forEach(aI),Object.hasOwn(r,"y")&&aI(r)})),("lr"===o||"rl"===o)&&((r=e).nodes().forEach(e=>az(r.node(e))),r.edges().forEach(e=>{var t;let n=r.edge(e);null==(t=n.points)||t.forEach(az),Object.hasOwn(n,"x")&&az(n)}),aP(e))}),o(" translateGraph",()=>(function(e){let t=1/0,n=0,r=1/0,o=0,i=e.graph(),a=i.marginx||0,s=i.marginy||0;function l(e){let i=e.x,a=e.y,s=e.width,l=e.height;t=Math.min(t,i-s/2),n=Math.max(n,i+s/2),r=Math.min(r,a-l/2),o=Math.max(o,a+l/2)}e.nodes().forEach(t=>l(e.node(t))),e.edges().forEach(t=>{let n=e.edge(t);Object.hasOwn(n,"x")&&l(n)}),t-=a,r-=s,e.nodes().forEach(n=>{let o=e.node(n);o.x-=t,o.y-=r}),e.edges().forEach(n=>{let o=e.edge(n);o.points.forEach(e=>{e.x-=t,e.y-=r}),Object.hasOwn(o,"x")&&(o.x-=t),Object.hasOwn(o,"y")&&(o.y-=r)}),i.width=n-t+a,i.height=o-r+s})(e)),o(" assignNodeIntersects",()=>{var t;(t=e).edges().forEach(e=>{let n=t.edge(e),r=t.node(e.v),o=t.node(e.w),i,a;n.points?(i=n.points[0],a=n.points[n.points.length-1]):(n.points=[],i=o,a=r),n.points.unshift(ae(r,i)),n.points.push(ae(o,a))})}),o(" reversePoints",()=>{var t;(t=e).edges().forEach(e=>{let n=t.edge(e);n.reversed&&n.points.reverse()})}),o(" acyclic.undo",()=>{e.edges().forEach(t=>{let n=e.edge(t);if(n.reversed){e.removeEdge(t);let r=n.forwardName;delete n.reversed,delete n.forwardName,e.setEdge(t.w,t.v,n,r)}})}))}),n(" updateInputGraph",()=>{var t,n;return t=e,n=r,void(t.nodes().forEach(e=>{let r=t.node(e),o=n.node(e);r&&(r.x=o.x,r.y=o.y,r.order=o.order,r.rank=o.rank,n.children(e).length&&(r.width=o.width,r.height=o.height))}),t.edges().forEach(e=>{let r=t.edge(e),o=n.edge(e);r.points=o.points,Object.hasOwn(o,"x")&&(r.x=o.x,r.y=o.y)}),t.graph().width=n.graph().width,t.graph().height=n.graph().height)}),r})};let aU={agent:function({data:e}){return(0,v.jsx)("div",{className:"rounded-md border bg-card px-2 py-1 text-[8px] truncate w-full",children:e.label})}},aG=(0,x.memo)(function({template:e}){if(0===e.nodes.length)return(0,v.jsx)("div",{className:"h-24 flex items-center justify-center text-xs text-muted-foreground bg-muted/30 rounded",children:"Empty workflow"});let{nodes:t,edges:n}=function(e){let t=new iM.Graph;t.setDefaultEdgeLabel(()=>({})),t.setGraph({rankdir:"LR",nodesep:20,ranksep:40});let n=e.nodes.map(e=>({id:e.id,type:"agent",position:e.position,data:e.data})),r=e.edges.map(e=>({id:e.id,source:e.source,target:e.target,type:"smoothstep"}));for(let e of n)t.setNode(e.id,{width:80,height:24});for(let e of r)t.setEdge(e.source,e.target);return aq(t),{nodes:n.map(e=>{let n=t.node(e.id);return{...e,position:{x:n.x-40,y:n.y-12}}}),edges:r}}(e);return(0,v.jsx)("div",{className:"h-24 w-full pointer-events-none",children:(0,v.jsx)(o7,{nodes:t,edges:n,nodeTypes:aU,fitView:!0,proOptions:{hideAttribution:!0},nodesDraggable:!1,nodesConnectable:!1,elementsSelectable:!1,panOnDrag:!1,zoomOnScroll:!1,zoomOnPinch:!1,panOnScroll:!1,children:(0,v.jsx)(ia,{variant:y.Dots,gap:10,size:.5})})})});var aQ=e.i(562918),aJ=e.i(611176),a0=e.i(972846);let a1={agent:"bg-gray-100 text-gray-700 border-gray-200",scheduler:"bg-blue-100 text-blue-700 border-blue-200",task_creator:"bg-green-100 text-green-700 border-green-200",bot:"bg-yellow-100 text-yellow-700 border-yellow-200"},a2={agent:(0,x.memo)(function({id:e,data:t,selected:n}){let r=a1[t.role]||"bg-gray-100 text-gray-700 border-gray-200",{setNodes:o}=rY(),[i,a]=(0,x.useState)(!1),s=(0,x.useCallback)(t=>{t.stopPropagation(),o(t=>t.filter(t=>t.id!==e))},[e,o]),l=(0,x.useCallback)(()=>{a(e=>!e)},[]);return(0,v.jsxs)("div",{onClick:l,className:`rounded-lg border-2 bg-card p-3 shadow-sm min-w-[160px] transition-colors duration-150 group relative ${n?"border-primary ring-2 ring-primary/20":"border-border"}`,children:[(0,v.jsx)(r9,{type:"target",position:g.Top,className:"!w-3 !h-3 !bg-muted-foreground/40 !border-2 !border-background hover:!bg-primary"}),(0,v.jsx)("button",{type:"button",onClick:s,className:"absolute -top-2 -right-2 flex items-center justify-center size-5 rounded-full bg-destructive text-destructive-foreground opacity-0 group-hover:opacity-100 hover:bg-destructive/80 transition-opacity z-10 md:opacity-0 md:group-hover:opacity-100",style:{opacity:i?1:void 0},children:(0,v.jsx)(a0.X,{className:"size-3"})}),(0,v.jsxs)("div",{className:"flex items-center gap-2.5",children:[(0,v.jsx)(aJ.AgentIcon,{avatarUrl:t.avatarUrl,name:t.label,className:"size-8 rounded-md"}),(0,v.jsxs)("div",{className:"flex-1 min-w-0",children:[(0,v.jsx)("div",{className:"font-medium text-sm truncate",children:t.label}),(0,v.jsxs)("div",{className:"flex items-center gap-1.5 mt-0.5",children:[(0,v.jsx)(aQ.Badge,{variant:"outline",className:`text-[10px] px-1.5 py-0 ${r}`,children:t.role}),t.modelId&&(0,v.jsx)("span",{className:"text-[10px] text-muted-foreground truncate",children:t.modelId})]})]})]}),(0,v.jsx)(r9,{type:"source",position:g.Bottom,className:"!w-3 !h-3 !bg-muted-foreground/40 !border-2 !border-background hover:!bg-primary"})]})})},a3={smoothstep:function({id:e,sourceX:t,sourceY:n,targetX:r,targetY:o,sourcePosition:i,targetPosition:a,style:s={},markerEnd:l}){let{setEdges:d}=rY(),[u,c]=(0,x.useState)(!1),[h,f,p]=nv({sourceX:t,sourceY:n,targetX:r,targetY:o,sourcePosition:i,targetPosition:a});return(0,v.jsxs)(v.Fragment,{children:[(0,v.jsxs)("g",{onMouseEnter:()=>c(!0),onMouseLeave:()=>c(!1),children:[(0,v.jsx)("path",{d:h,fill:"none",strokeWidth:20,stroke:"transparent"}),(0,v.jsx)(ox,{id:e,path:h,markerEnd:l,style:{...s,strokeWidth:u?3:2,stroke:u?"hsl(var(--primary))":s.stroke}})]}),u&&(0,v.jsx)(o9,{children:(0,v.jsx)("button",{type:"button",className:"nodrag nopan absolute flex items-center justify-center size-5 rounded-full bg-destructive text-destructive-foreground hover:bg-destructive/80 pointer-events-auto",style:{transform:`translate(-50%, -50%) translate(${f}px,${p}px)`},onClick:()=>d(t=>t.filter(t=>t.id!==e)),children:(0,v.jsx)(a0.X,{className:"size-3"})})})]})}};function a5({nodes:e,edges:t,onNodesChange:n,onEdgesChange:r,onConnect:o,onNodeAdd:i}){let a=(0,x.useRef)(null),{screenToFlowPosition:s}=rY(),l=(0,x.useCallback)(e=>{e.preventDefault(),e.dataTransfer.dropEffect="move"},[]),d=(0,x.useCallback)(e=>{e.preventDefault();let t=e.dataTransfer.getData("application/json");if(!t)return;let n=JSON.parse(t),r=s({x:e.clientX,y:e.clientY});i?.({id:`node-${Date.now()}`,type:"agent",position:r,data:{label:n.name,agentConfigId:n.id,role:n.role,avatarUrl:n.avatarUrl,modelId:n.modelId}})},[s,i]);return(0,v.jsx)("div",{ref:a,className:"flex-1 h-full",children:(0,v.jsxs)(o7,{nodes:e,edges:t,onNodesChange:n,onEdgesChange:r,onConnect:o,onDragOver:l,onDrop:d,nodeTypes:a2,edgeTypes:a3,fitView:!0,snapToGrid:!0,snapGrid:[15,15],deleteKeyCode:["Backspace","Delete"],defaultEdgeOptions:{type:"smoothstep",animated:!1,style:{strokeWidth:2}},children:[(0,v.jsx)(ia,{variant:y.Dots,gap:15,size:1}),(0,v.jsx)(im,{})]})})}var a4=e.i(588591);let a6=(0,e.i(433721).default)("eye",[["path",{d:"M2.062 12.348a1 1 0 0 1 0-.696 10.75 10.75 0 0 1 19.876 0 1 1 0 0 1 0 .696 10.75 10.75 0 0 1-19.876 0",key:"1nclc0"}],["circle",{cx:"12",cy:"12",r:"3",key:"1v7zrd"}]]);var a7=e.i(953700);let a8={agent:"Agent",scheduler:"Scheduler",task_creator:"Task Creator",bot:"Bot"};function a9({agents:e,onNodeAdd:t}){let n=function(e){let t={};for(let n of e){if(!n.enabled)continue;let e=n.role||"agent";t[e]||(t[e]=[]),t[e].push(n)}return t}(e),[r,o]=(0,x.useState)(!1),[i,a]=(0,x.useState)(),s=(e,t)=>{e.dataTransfer.setData("application/json",JSON.stringify(t)),e.dataTransfer.effectAllowed="move"},l=e.filter(e=>e.enabled);return(0,v.jsxs)(v.Fragment,{children:[(0,v.jsxs)("div",{className:"hidden md:block w-56 border-r bg-muted/30 p-3 overflow-y-auto",children:[(0,v.jsx)("h3",{className:"text-xs font-semibold uppercase text-muted-foreground mb-3",children:"Agents"}),Object.entries(n).map(([e,t])=>(0,v.jsxs)("div",{className:"mb-3",children:[(0,v.jsx)("div",{className:"text-[10px] font-medium uppercase text-muted-foreground/60 mb-1.5",children:a8[e]||e}),t.map(e=>(0,v.jsxs)("div",{draggable:!0,onDragStart:t=>s(t,e),className:"group flex items-center gap-2 p-2 rounded-md bg-card border cursor-grab active:cursor-grabbing hover:bg-accent/50 transition-colors mb-1",children:[(0,v.jsxs)("div",{className:"min-w-0 flex-1",children:[(0,v.jsx)("div",{className:"text-xs font-medium truncate",children:e.name}),(0,v.jsx)("div",{className:"text-[10px] text-muted-foreground truncate",children:e.modelId||e.runtimeKind||e.role})]}),(0,v.jsx)("button",{type:"button",onClick:t=>{t.stopPropagation(),a(e.id),o(!0)},className:"shrink-0 flex items-center justify-center size-5 rounded opacity-0 group-hover:opacity-100 hover:bg-accent transition-opacity",children:(0,v.jsx)(a6,{className:"size-3 text-muted-foreground"})})]},e.id))]},e)),0===l.length&&(0,v.jsx)("p",{className:"text-xs text-muted-foreground text-center py-4",children:"No agents configured."})]}),(0,v.jsxs)("div",{className:"md:hidden flex items-center gap-2 px-3 py-2 border-b bg-muted/30 overflow-x-auto shrink-0",children:[l.map(e=>(0,v.jsxs)("div",{className:"flex items-center gap-1.5 px-2 py-1.5 rounded-md bg-card border shrink-0 cursor-grab active:cursor-grabbing",draggable:!0,onDragStart:t=>s(t,e),children:[(0,v.jsx)("span",{className:"text-xs font-medium whitespace-nowrap",children:e.name}),t&&(0,v.jsx)("button",{type:"button",onClick:()=>{t&&t({id:`node-${Date.now()}`,type:"agent",position:{x:100+200*Math.random(),y:100+200*Math.random()},data:{label:e.name,agentConfigId:e.id,role:e.role,avatarUrl:e.avatarUrl,modelId:e.modelId}})},className:"flex items-center justify-center size-4 rounded hover:bg-accent",children:(0,v.jsx)(a7.Plus,{className:"size-3"})})]},e.id)),0===l.length&&(0,v.jsx)("p",{className:"text-xs text-muted-foreground",children:"No agents configured."})]}),(0,v.jsx)(a4.AgentDialog,{open:r,onOpenChange:e=>{o(e),e||a(void 0)},initialAgentId:i})]})}var se=e.i(260218),st=e.i(193251),sn=e.i(267624),sr=e.i(111343),so=e.i(137340),si=e.i(159619);function sa({onSave:e,onAutoLayout:t,onDelete:n,onDuplicate:r,onExport:o,isDirty:i,isSaving:a}){return(0,v.jsxs)("div",{className:"flex items-center gap-2 border-t bg-card px-4 py-2",children:[(0,v.jsxs)(se.Button,{variant:"outline",size:"sm",onClick:t,title:"Auto Layout",children:[(0,v.jsx)(sn.LayoutGrid,{className:"h-4 w-4 mr-1"})," Auto Layout"]}),(0,v.jsx)("div",{className:"flex-1"}),r&&(0,v.jsx)(se.Button,{variant:"ghost",size:"sm",onClick:r,title:"Duplicate",children:(0,v.jsx)(si.Copy,{className:"h-4 w-4"})}),(0,v.jsx)(se.Button,{variant:"ghost",size:"sm",onClick:o,title:"Export JSON",children:(0,v.jsx)(st.Download,{className:"h-4 w-4"})}),n&&(0,v.jsx)(se.Button,{variant:"ghost",size:"sm",onClick:n,title:"Delete",className:"text-destructive hover:text-destructive",children:(0,v.jsx)(so.Trash2,{className:"h-4 w-4"})}),(0,v.jsxs)(se.Button,{size:"sm",onClick:e,disabled:!i||a,children:[(0,v.jsx)(sr.Save,{className:"h-4 w-4 mr-1"})," ",a?"Saving...":"Save"]})]})}var ss=e.i(681622),sl=e.i(767467),sd=e.i(437122);function su({template:e,onBack:t}){let{updateWorkflow:n,createWorkflow:r}=(0,iS.useWorkflowStore)(),[o,i]=(0,x.useState)([]);(0,x.useEffect)(()=>{fetch("/api/agents/presets",{headers:(0,sd.authHeaders)()}).then(e=>e.ok?e.json():[]).then(e=>i(e)).catch(()=>{})},[]);let[a,s]=(0,x.useState)(e?.name??"New Workflow"),[l,d]=(0,x.useState)(e?.description??""),[u,c]=(0,x.useState)(()=>e?.nodes.map(e=>({id:e.id,type:"agent",position:e.position,data:e.data}))??[]),[h,f]=(0,x.useState)(()=>e?.edges.map(e=>({id:e.id,source:e.source,target:e.target,type:"smoothstep"}))??[]),[p,g]=(0,x.useState)(!1),[m,y]=(0,x.useState)(!1),w=e?.id,b=(0,x.useCallback)(()=>g(!0),[]),_=(0,x.useCallback)(e=>{c(t=>rz(e,t)),b()},[b]),E=(0,x.useCallback)(e=>{f(t=>rz(e,t)),b()},[b]),k=(0,x.useCallback)(e=>{f(t=>nf({...e,type:"smoothstep"},t)),b()},[b]),C=(0,x.useCallback)(e=>{c(t=>[...t,e]),b()},[b]),S=(0,x.useCallback)(()=>{c(e=>(function(e,t){let n=new iM.Graph;for(let t of(n.setDefaultEdgeLabel(()=>({})),n.setGraph({rankdir:"TB",nodesep:80,ranksep:100}),e))n.setNode(t.id,{width:180,height:80});for(let e of t)n.setEdge(e.source,e.target);return aq(n),e.map(e=>{let t=n.node(e.id);return{...e,position:{x:t.x-90,y:t.y-40}}})})(e,h)),b()},[h,b]),N=(0,x.useCallback)(async()=>{y(!0);try{let e=u.map(e=>({id:e.id,type:"agent",position:e.position,data:e.data})),t=h.map(e=>({id:e.id,source:e.source,target:e.target}));w?await n(w,{name:a,description:l||void 0,nodes:e,edges:t}):await r({name:a,description:l||void 0,nodes:e,edges:t}),g(!1)}finally{y(!1)}},[w,a,l,u,h,n,r]),M=(0,x.useCallback)(()=>{let e={};for(let t of u){let n=t.data.agentConfigId;if(n&&!e[n]){let t=o.find(e=>e.id===n);if(t){let{apiKey:r,...o}=t;e[n]=o}}}let t=new Blob([JSON.stringify({name:a,description:l,nodes:u.map(e=>({id:e.id,type:e.type,position:e.position,data:e.data})),edges:h.map(e=>({id:e.id,source:e.source,target:e.target})),agents:e},null,2)],{type:"application/json"}),n=URL.createObjectURL(t),r=document.createElement("a");r.href=n,r.download=`${a.replace(/\s+/g,"-").toLowerCase()}.json`,r.click(),URL.revokeObjectURL(n)},[a,l,u,h,o]);return(0,v.jsxs)("div",{className:"flex flex-col h-full",children:[(0,v.jsxs)("div",{className:"hidden md:flex items-center gap-3 border-b px-4 py-2",children:[(0,v.jsx)("button",{onClick:t,className:"p-1 rounded-md text-muted-foreground hover:text-foreground hover:bg-accent",children:(0,v.jsx)(sl.ArrowLeft,{className:"size-4"})}),(0,v.jsx)(ss.Input,{value:a,onChange:e=>{s(e.target.value),b()},className:"h-8 text-sm font-medium border-0 shadow-none focus-visible:ring-0 px-1",placeholder:"Workflow name"})]}),(0,v.jsxs)("div",{className:"flex flex-col md:flex-row flex-1 min-h-0",children:[(0,v.jsx)(a9,{agents:o,onNodeAdd:C}),(0,v.jsx)(a5,{nodes:u,edges:h,onNodesChange:_,onEdgesChange:E,onConnect:k,onNodeAdd:C})]}),(0,v.jsx)(sa,{onSave:N,onAutoLayout:S,onExport:M,isDirty:p,isSaving:m})]})}function sc({template:e,onBack:t}){return(0,v.jsx)(o5,{children:(0,v.jsx)(su,{template:e,onBack:t})})}var sh=e.i(212603),sf=e.i(962562),sp=e.i(129981),sg=e.i(989484),sm=e.i(209988);let sy=[{id:"code-writing",name:"代码编写",description:"Planner → Executor → Reviewer → Commit 四阶段代码编写流程",data:{name:"代码编写工作流",description:"Planner 分解任务 → Executor 编写代码 → Reviewer 审查代码 → Commit 自动提交",nodes:[{id:"node-planner",type:"agent",position:{x:300,y:285},data:{label:"Planner",agentConfigId:"tpl-planner",role:"planner",modelId:""}},{id:"node-executor",type:"agent",position:{x:600,y:390},data:{label:"Executor",agentConfigId:"tpl-executor",role:"executor",modelId:""}},{id:"node-reviewer",type:"agent",position:{x:510,y:585},data:{label:"Reviewer",agentConfigId:"tpl-reviewer",role:"reviewer",modelId:""}},{id:"node-commit",type:"agent",position:{x:885,y:705},data:{label:"Commit",agentConfigId:"tpl-commit",role:"commit",modelId:""}}],edges:[{id:"edge-planner-executor",source:"node-planner",target:"node-executor"},{id:"edge-executor-reviewer",source:"node-executor",target:"node-reviewer"},{id:"edge-reviewer-commit",source:"node-reviewer",target:"node-commit"}],agents:{"tpl-planner":{id:"tpl-planner",templateId:"a1b2c3d4-e5f6-4a7b-8c9d-0e1f2a3b4c5d",name:"Planner",role:"planner",description:"策划者,负责分解任务和制定计划",modelProvider:"anthropic-messages",modelId:"",apiBase:"",workingDir:"",mcps:{mcpServers:{fetch:{command:"uvx",args:["mcp-server-fetch"],env:{PYTHONIOENCODING:"utf-8"}}}},skills:[],systemPrompt:"你是策划者 Agent。负责将复杂任务分解为可执行的子任务,制定详细的实施计划,识别潜在风险和依赖关系。",temperature:.5,maxTokens:8192,enabled:!0,runtimeKind:"claude-code",avatarUrl:"",tools:["CreateCurrentChannelIssue","ViewCurrentChannelIssue","AddCurrentChannelComment"]},"tpl-executor":{id:"tpl-executor",templateId:"b2c3d4e5-f6a7-4b8c-9d0e-1f2a3b4c5d6e",name:"Executor",role:"executor",description:"执行者,负责代码编写和修改",modelProvider:"anthropic-messages",modelId:"",apiBase:"",workingDir:"",mcps:{},skills:[],systemPrompt:"你是执行者 Agent。根据计划编写高质量的代码,遵循项目编码规范,编写必要的测试。完成后提交审核。",temperature:.2,maxTokens:16384,enabled:!0,runtimeKind:"claude-code",avatarUrl:"",tools:["CreateCurrentChannelIssue","ViewCurrentChannelIssue","AddCurrentChannelComment"]},"tpl-reviewer":{id:"tpl-reviewer",templateId:"c3d4e5f6-a7b8-4c9d-0e1f-2a3b4c5d6e7f",name:"Reviewer",role:"reviewer",description:"审核者,负责代码审查和质量把关",modelProvider:"anthropic-messages",modelId:"",apiBase:"",workingDir:"",mcps:{},skills:[],systemPrompt:"你是审核者 Agent。负责审查代码质量、安全性和可维护性。提供具体的改进建议,确保代码符合最佳实践。",temperature:.2,maxTokens:8192,enabled:!0,runtimeKind:"claude-code",avatarUrl:"",tools:["CreateCurrentChannelIssue","ViewCurrentChannelIssue","AddCurrentChannelComment"]},"tpl-commit":{id:"tpl-commit",templateId:"d4e5f6a7-b8c9-4d0e-1f2a-3b4c5d6e7f80",name:"Commit",role:"commit",description:"提交消息生成器,根据 diff 智能生成 commit message",runtimeKind:"claude-code",modelProvider:"anthropic-messages",modelId:"",apiBase:"",workingDir:"",mcps:{},skills:[],tools:[],systemPrompt:'你是一个 Git 提交 Agent。你的任务是完成 git commit 操作。步骤:1. 运行 git status 和 git diff --staged 查看暂存区变更;如果没有暂存文件,先运行 git add 添加所有变更文件。2. 运行 git diff --cached 查看将要提交的内容。3. 根据 diff 内容生成 conventional commit 消息(格式:type: description,类型包括 feat, fix, docs, style, refactor, perf, test, chore, build, ci)。4. 使用 git commit -m "消息" 执行提交。只做 commit,不要 push。',temperature:.3,maxTokens:4096,enabled:!0}}}}];function sv({open:e,onOpenChange:t,onImport:n}){let[r,o]=(0,x.useState)(null),i=async e=>{o(e.id);try{await n(e.data),t(!1)}finally{o(null)}};return(0,v.jsx)(sm.Dialog,{open:e,onOpenChange:t,children:(0,v.jsxs)(sm.DialogContent,{className:"sm:max-w-lg",children:[(0,v.jsxs)(sm.DialogHeader,{children:[(0,v.jsx)(sm.DialogTitle,{children:"工作流模板"}),(0,v.jsx)(sm.DialogDescription,{children:"选择一个模板快速创建工作流"})]}),(0,v.jsx)("div",{className:"space-y-3 mt-2",children:sy.map(e=>{let t=Object.keys(e.data.agents).length;return(0,v.jsx)(sh.Card,{className:"overflow-hidden",children:(0,v.jsx)(sh.CardContent,{className:"p-4",children:(0,v.jsxs)("div",{className:"flex items-start justify-between gap-3",children:[(0,v.jsxs)("div",{className:"flex-1 min-w-0",children:[(0,v.jsxs)("div",{className:"flex items-center gap-2 mb-1",children:[(0,v.jsx)("span",{className:"font-medium text-sm",children:e.name}),(0,v.jsxs)(aQ.Badge,{variant:"secondary",className:"text-xs",children:[t," 个 Agent"]})]}),(0,v.jsx)("p",{className:"text-xs text-muted-foreground mb-2",children:e.description}),(0,v.jsx)("div",{className:"flex flex-wrap gap-1",children:e.data.nodes.map(e=>(0,v.jsx)(aQ.Badge,{variant:"outline",className:"text-xs",children:e.data.label},e.id))})]}),(0,v.jsxs)(se.Button,{size:"sm",variant:"outline",className:"shrink-0",disabled:null!==r,onClick:()=>i(e),children:[r===e.id?(0,v.jsx)("span",{className:"h-3.5 w-3.5 animate-spin rounded-full border-2 border-current border-t-transparent"}):(0,v.jsx)(st.Download,{className:"h-3.5 w-3.5 mr-1"}),"导入"]})]})})},e.id)})})]})})}function sx(){let{workflows:e,loadWorkflows:t,deleteWorkflow:n,duplicateWorkflow:r}=(0,iS.useWorkflowStore)(),[o,i]=(0,x.useState)(null),[a,s]=(0,x.useState)(!1),[l,d]=(0,x.useState)(!1);(0,x.useEffect)(()=>{t()},[t]);let u=(0,x.useCallback)(async e=>{await n(e.id)},[n]),c=(0,x.useCallback)(async e=>{await r(e.id)},[r]),h=(0,x.useCallback)(async()=>{let e=document.createElement("input");e.type="file",e.accept=".json",e.onchange=async e=>{let n=e.target.files?.[0];if(n)try{let e=await n.text(),{name:r,description:o,nodes:i,edges:a,agents:s}=JSON.parse(e);if(!i||!a)return;let l={};if(s)for(let[e,t]of Object.entries(s)){let{id:n,enabled:r,...o}=t,i=await fetch("/api/agents/presets",{method:"POST",headers:{...(0,sd.authHeaders)(),"Content-Type":"application/json"},body:JSON.stringify(o)});if(i.ok){let t=await i.json();l[e]=t.id}}let d=i.map(e=>({...e,data:{...e.data,agentConfigId:l[e.data.agentConfigId]??e.data.agentConfigId}}));await fetch("/api/workflows",{method:"POST",headers:{...(0,sd.authHeaders)(),"Content-Type":"application/json"},body:JSON.stringify({name:r??"Imported Workflow",description:o,nodes:d,edges:a})}),t()}catch{}},e.click()},[t]),f=(0,x.useCallback)(async e=>{let{name:n,description:r,nodes:o,edges:i,agents:a}=e,s={},l=await fetch("/api/agents/presets",{headers:(0,sd.authHeaders)()}),d=l.ok?await l.json():[],u=new Map;for(let e of d)e.templateId&&u.set(e.templateId,e.id);if(a)for(let[e,t]of Object.entries(a)){if(t.templateId&&u.has(t.templateId)){s[e]=u.get(t.templateId);continue}let{id:n,enabled:r,...o}=t,i=await fetch("/api/agents/presets",{method:"POST",headers:{...(0,sd.authHeaders)(),"Content-Type":"application/json"},body:JSON.stringify(o)});if(i.ok){let t=await i.json();s[e]=t.id}}let c=o.map(e=>({...e,data:{...e.data,agentConfigId:s[e.data.agentConfigId]??e.data.agentConfigId}}));await fetch("/api/workflows",{method:"POST",headers:{...(0,sd.authHeaders)(),"Content-Type":"application/json"},body:JSON.stringify({name:n,description:r,nodes:c,edges:i})}),t()},[t]);return o||a?(0,v.jsx)(sc,{template:o,onBack:()=>{i(null),s(!1),t()}}):(0,v.jsxs)("div",{className:"p-6 h-full overflow-y-auto",children:[(0,v.jsxs)("div",{className:"hidden md:flex items-center justify-between mb-6",children:[(0,v.jsxs)("div",{children:[(0,v.jsx)("h2",{className:"text-lg font-semibold",children:"工作流"}),(0,v.jsx)("p",{className:"text-sm text-muted-foreground",children:"管理 Workflow 模板"})]}),(0,v.jsxs)("div",{className:"flex gap-2",children:[(0,v.jsxs)(se.Button,{variant:"outline",onClick:()=>d(!0),children:[(0,v.jsx)(sg.FileText,{className:"h-4 w-4 mr-1"})," 模版"]}),(0,v.jsxs)(se.Button,{variant:"outline",onClick:h,children:[(0,v.jsx)(sp.Upload,{className:"h-4 w-4 mr-1"})," 导入"]}),(0,v.jsxs)(se.Button,{onClick:()=>s(!0),children:[(0,v.jsx)(a7.Plus,{className:"h-4 w-4 mr-1"})," 新建工作流"]})]})]}),0===e.length?(0,v.jsxs)("div",{className:"flex flex-col items-center justify-center py-16 text-muted-foreground",children:[(0,v.jsx)("p",{className:"text-sm mb-2",children:"暂无工作流模板"}),(0,v.jsxs)(se.Button,{variant:"outline",onClick:()=>s(!0),children:[(0,v.jsx)(a7.Plus,{className:"h-4 w-4 mr-1"})," 创建第一个工作流"]})]}):(0,v.jsx)("div",{className:"grid grid-cols-1 md:grid-cols-2 lg:grid-cols-3 gap-4",children:e.map(e=>(0,v.jsxs)(sh.Card,{className:"overflow-hidden hover:shadow-md transition-shadow",children:[(0,v.jsx)(o5,{children:(0,v.jsx)(aG,{template:e})}),(0,v.jsxs)(sh.CardHeader,{className:"pb-2",children:[(0,v.jsx)(sh.CardTitle,{className:"text-sm",children:e.name}),e.description&&(0,v.jsx)(sh.CardDescription,{className:"text-xs",children:e.description})]}),(0,v.jsx)(sh.CardContent,{className:"pt-0",children:(0,v.jsxs)("div",{className:"flex items-center justify-between",children:[(0,v.jsxs)("span",{className:"text-xs text-muted-foreground",children:[e.nodes.length," 个节点"]}),(0,v.jsxs)("div",{className:"flex gap-1",children:[(0,v.jsx)(se.Button,{variant:"ghost",size:"icon",className:"h-7 w-7",onClick:()=>i(e),children:(0,v.jsx)(sf.Pencil,{className:"h-3.5 w-3.5"})}),(0,v.jsx)(se.Button,{variant:"ghost",size:"icon",className:"h-7 w-7",onClick:()=>c(e),children:(0,v.jsx)(si.Copy,{className:"h-3.5 w-3.5"})}),(0,v.jsx)(se.Button,{variant:"ghost",size:"icon",className:"h-7 w-7 text-destructive hover:text-destructive",onClick:()=>u(e),children:(0,v.jsx)(so.Trash2,{className:"h-3.5 w-3.5"})})]})]})})]},e.id))}),(0,v.jsx)(sv,{open:l,onOpenChange:d,onImport:f})]})}e.s(["default",0,function(){return(0,v.jsx)(sx,{})}],322432)}]);
|