@specific.dev/cli 0.1.41 → 0.1.42

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (39) hide show
  1. package/dist/admin/404/index.html +1 -1
  2. package/dist/admin/404.html +1 -1
  3. package/dist/admin/__next.__PAGE__.txt +2 -2
  4. package/dist/admin/__next._full.txt +3 -3
  5. package/dist/admin/__next._head.txt +1 -1
  6. package/dist/admin/__next._index.txt +2 -2
  7. package/dist/admin/__next._tree.txt +2 -2
  8. package/dist/admin/_next/static/chunks/1a608619ba3183f8.js +5 -0
  9. package/dist/admin/_next/static/chunks/237926899f121e8a.js +2 -0
  10. package/dist/admin/_next/static/chunks/2ca8ab35893ba132.css +3 -0
  11. package/dist/admin/_next/static/chunks/42730c0491633b9d.js +5 -0
  12. package/dist/admin/_not-found/__next._full.txt +2 -2
  13. package/dist/admin/_not-found/__next._head.txt +1 -1
  14. package/dist/admin/_not-found/__next._index.txt +2 -2
  15. package/dist/admin/_not-found/__next._not-found.__PAGE__.txt +1 -1
  16. package/dist/admin/_not-found/__next._not-found.txt +1 -1
  17. package/dist/admin/_not-found/__next._tree.txt +2 -2
  18. package/dist/admin/_not-found/index.html +1 -1
  19. package/dist/admin/_not-found/index.txt +2 -2
  20. package/dist/admin/databases/__next._full.txt +3 -3
  21. package/dist/admin/databases/__next._head.txt +1 -1
  22. package/dist/admin/databases/__next._index.txt +2 -2
  23. package/dist/admin/databases/__next._tree.txt +2 -2
  24. package/dist/admin/databases/__next.databases.__PAGE__.txt +2 -2
  25. package/dist/admin/databases/__next.databases.txt +1 -1
  26. package/dist/admin/databases/index.html +1 -1
  27. package/dist/admin/databases/index.txt +3 -3
  28. package/dist/admin/index.html +1 -1
  29. package/dist/admin/index.txt +3 -3
  30. package/dist/cli.js +6715 -6666
  31. package/dist/docs/integrations/nextjs.md +2 -10
  32. package/package.json +2 -2
  33. package/dist/admin/_next/static/chunks/0476153b08658d87.js +0 -5
  34. package/dist/admin/_next/static/chunks/1de437acc5206b1f.js +0 -5
  35. package/dist/admin/_next/static/chunks/5ff94899b8b7a03a.css +0 -3
  36. package/dist/admin/_next/static/chunks/6aae09c9429b9f24.js +0 -2
  37. /package/dist/admin/_next/static/{9wAYbYI1Gg_jzlXqEZ1W5 → w-7TGbUFVs5LhUxmBNTTr}/_buildManifest.js +0 -0
  38. /package/dist/admin/_next/static/{9wAYbYI1Gg_jzlXqEZ1W5 → w-7TGbUFVs5LhUxmBNTTr}/_clientMiddlewareManifest.json +0 -0
  39. /package/dist/admin/_next/static/{9wAYbYI1Gg_jzlXqEZ1W5 → w-7TGbUFVs5LhUxmBNTTr}/_ssgManifest.js +0 -0
@@ -1,2 +0,0 @@
1
- (globalThis.TURBOPACK||(globalThis.TURBOPACK=[])).push(["object"==typeof document?document.currentScript:void 0,55838,(e,t,n)=>{"use strict";var r=e.r(71645),o="function"==typeof Object.is?Object.is:function(e,t){return e===t&&(0!==e||1/e==1/t)||e!=e&&t!=t},i=r.useState,a=r.useEffect,s=r.useLayoutEffect,l=r.useDebugValue;function u(e){var t=e.getSnapshot;e=e.value;try{var n=t();return!o(e,n)}catch(e){return!0}}var c="u"<typeof window||void 0===window.document||void 0===window.document.createElement?function(e,t){return t()}:function(e,t){var n=t(),r=i({inst:{value:n,getSnapshot:t}}),o=r[0].inst,c=r[1];return s(function(){o.value=n,o.getSnapshot=t,u(o)&&c({inst:o})},[e,n,t]),a(function(){return u(o)&&c({inst:o}),e(function(){u(o)&&c({inst:o})})},[e]),l(n),n};n.useSyncExternalStore=void 0!==r.useSyncExternalStore?r.useSyncExternalStore:c},2239,(e,t,n)=>{"use strict";t.exports=e.r(55838)},52822,(e,t,n)=>{"use strict";var r=e.r(71645),o=e.r(2239),i="function"==typeof Object.is?Object.is:function(e,t){return e===t&&(0!==e||1/e==1/t)||e!=e&&t!=t},a=o.useSyncExternalStore,s=r.useRef,l=r.useEffect,u=r.useMemo,c=r.useDebugValue;n.useSyncExternalStoreWithSelector=function(e,t,n,r,o){var d=s(null);if(null===d.current){var h={hasValue:!1,value:null};d.current=h}else h=d.current;var f=a(e,(d=u(function(){function e(e){if(!l){if(l=!0,a=e,e=r(e),void 0!==o&&h.hasValue){var t=h.value;if(o(t,e))return s=t}return s=e}if(t=s,i(a,e))return t;var n=r(e);return void 0!==o&&o(t,n)?(a=e,t):(a=e,s=n)}var a,s,l=!1,u=void 0===n?null:n;return[function(){return e(t())},null===u?void 0:function(){return e(u())}]},[t,n,r,o]))[0],d[1]);return l(function(){h.hasValue=!0,h.value=f},[f]),c(f),f}},30224,(e,t,n)=>{"use strict";t.exports=e.r(52822)},75621,(e,t,n)=>{"use strict";function r(e,t){e[t]?e[t]++:e[t]=1}function o(e,t){--e[t]||delete e[t]}function i(e,t,n,r){var o=""+t,i=""+n;if(!e&&o>i){var a=o;o=i,i=a}return o+"\x01"+i+"\x01"+(void 0===r?"\0":r)}function a(e,t){return i(e,t.v,t.w,t.name)}t.exports=class{_isDirected=!0;_isMultigraph=!1;_isCompound=!1;_label;_defaultNodeLabelFn=()=>void 0;_defaultEdgeLabelFn=()=>void 0;_nodes={};_in={};_preds={};_out={};_sucs={};_edgeObjs={};_edgeLabels={};_nodeCount=0;_edgeCount=0;_parent;_children;constructor(e){e&&(this._isDirected=!Object.hasOwn(e,"directed")||e.directed,this._isMultigraph=!!Object.hasOwn(e,"multigraph")&&e.multigraph,this._isCompound=!!Object.hasOwn(e,"compound")&&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 this._defaultNodeLabelFn=e,"function"!=typeof e&&(this._defaultNodeLabelFn=()=>e),this}nodeCount(){return this._nodeCount}nodes(){return Object.keys(this._nodes)}sources(){var e=this;return this.nodes().filter(t=>0===Object.keys(e._in[t]).length)}sinks(){var e=this;return this.nodes().filter(t=>0===Object.keys(e._out[t]).length)}setNodes(e,t){var n=arguments,r=this;return e.forEach(function(e){n.length>1?r.setNode(e,t):r.setNode(e)}),this}setNode(e,t){return Object.hasOwn(this._nodes,e)?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 Object.hasOwn(this._nodes,e)}removeNode(e){var t=this;if(Object.hasOwn(this._nodes,e)){var n=e=>t.removeEdge(t._edgeObjs[e]);delete this._nodes[e],this._isCompound&&(this._removeFromParentsChildList(e),delete this._parent[e],this.children(e).forEach(function(e){t.setParent(e)}),delete this._children[e]),Object.keys(this._in[e]).forEach(n),delete this._in[e],delete this._preds[e],Object.keys(this._out[e]).forEach(n),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(var 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}_removeFromParentsChildList(e){delete this._children[this._parent[e]][e]}parent(e){if(this._isCompound){var t=this._parent[e];if("\0"!==t)return t}}children(e="\0"){if(this._isCompound){var t=this._children[e];if(t)return Object.keys(t)}else if("\0"===e)return this.nodes();else if(this.hasNode(e))return[]}predecessors(e){var t=this._preds[e];if(t)return Object.keys(t)}successors(e){var t=this._sucs[e];if(t)return Object.keys(t)}neighbors(e){var t=this.predecessors(e);if(t){let r=new Set(t);for(var n of this.successors(e))r.add(n);return Array.from(r.values())}}isLeaf(e){return 0===(this.isDirected()?this.successors(e):this.neighbors(e)).length}filterNodes(e){var t=new this.constructor({directed:this._isDirected,multigraph:this._isMultigraph,compound:this._isCompound});t.setGraph(this.graph());var n=this;Object.entries(this._nodes).forEach(function([n,r]){e(n)&&t.setNode(n,r)}),Object.values(this._edgeObjs).forEach(function(e){t.hasNode(e.v)&&t.hasNode(e.w)&&t.setEdge(e,n.edge(e))});var r={};return this._isCompound&&t.nodes().forEach(e=>t.setParent(e,function e(o){var i=n.parent(o);return void 0===i||t.hasNode(i)?(r[o]=i,i):i in r?r[i]:e(i)}(e))),t}setDefaultEdgeLabel(e){return this._defaultEdgeLabelFn=e,"function"!=typeof e&&(this._defaultEdgeLabelFn=()=>e),this}edgeCount(){return this._edgeCount}edges(){return Object.values(this._edgeObjs)}setPath(e,t){var n=this,r=arguments;return e.reduce(function(e,o){return r.length>1?n.setEdge(e,o,t):n.setEdge(e,o),o}),this}setEdge(){var e,t,n,o,a=!1,s=arguments[0];"object"==typeof s&&null!==s&&"v"in s?(e=s.v,t=s.w,n=s.name,2==arguments.length&&(o=arguments[1],a=!0)):(e=s,t=arguments[1],n=arguments[3],arguments.length>2&&(o=arguments[2],a=!0)),e=""+e,t=""+t,void 0!==n&&(n=""+n);var l=i(this._isDirected,e,t,n);if(Object.hasOwn(this._edgeLabels,l))return a&&(this._edgeLabels[l]=o),this;if(void 0!==n&&!this._isMultigraph)throw Error("Cannot set a named edge when isMultigraph = false");this.setNode(e),this.setNode(t),this._edgeLabels[l]=a?o:this._defaultEdgeLabelFn(e,t,n);var u=function(e,t,n,r){var o=""+t,i=""+n;if(!e&&o>i){var a=o;o=i,i=a}var s={v:o,w:i};return r&&(s.name=r),s}(this._isDirected,e,t,n);return e=u.v,t=u.w,Object.freeze(u),this._edgeObjs[l]=u,r(this._preds[t],e),r(this._sucs[e],t),this._in[t][l]=u,this._out[e][l]=u,this._edgeCount++,this}edge(e,t,n){var r=1==arguments.length?a(this._isDirected,arguments[0]):i(this._isDirected,e,t,n);return this._edgeLabels[r]}edgeAsObj(){let e=this.edge(...arguments);return"object"!=typeof e?{label:e}:e}hasEdge(e,t,n){var r=1==arguments.length?a(this._isDirected,arguments[0]):i(this._isDirected,e,t,n);return Object.hasOwn(this._edgeLabels,r)}removeEdge(e,t,n){var r=1==arguments.length?a(this._isDirected,arguments[0]):i(this._isDirected,e,t,n),s=this._edgeObjs[r];return s&&(e=s.v,t=s.w,delete this._edgeLabels[r],delete this._edgeObjs[r],o(this._preds[t],e),o(this._sucs[e],t),delete this._in[t][r],delete this._out[e][r],this._edgeCount--),this}inEdges(e,t){var n=this._in[e];if(n){var r=Object.values(n);return t?r.filter(e=>e.v===t):r}}outEdges(e,t){var n=this._out[e];if(n){var r=Object.values(n);return t?r.filter(e=>e.w===t):r}}nodeEdges(e,t){var n=this.inEdges(e,t);if(n)return n.concat(this.outEdges(e,t))}}},95446,(e,t,n)=>{t.exports="2.2.4"},96950,(e,t,n)=>{t.exports={Graph:e.r(75621),version:e.r(95446)}},71636,(e,t,n)=>{var r=e.r(75621);t.exports={write:function(e){var t,n,r={options:{directed:e.isDirected(),multigraph:e.isMultigraph(),compound:e.isCompound()},nodes:(t=e).nodes().map(function(e){var 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(function(e){var 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})};return void 0!==e.graph()&&(r.value=structuredClone(e.graph())),r},read:function(e){var t=new r(e.options).setGraph(e.value);return e.nodes.forEach(function(e){t.setNode(e.v,e.value),e.parent&&t.setParent(e.v,e.parent)}),e.edges.forEach(function(e){t.setEdge({v:e.v,w:e.w,name:e.name},e.value)}),t}}},16131,(e,t,n)=>{t.exports=function(e){var t,n={},r=[];return e.nodes().forEach(function(o){t=[],function r(o){Object.hasOwn(n,o)||(n[o]=!0,t.push(o),e.successors(o).forEach(r),e.predecessors(o).forEach(r))}(o),t.length&&r.push(t)}),r}},88532,(e,t,n)=>{t.exports=class{_arr=[];_keyIndices={};size(){return this._arr.length}keys(){return this._arr.map(function(e){return e.key})}has(e){return Object.hasOwn(this._keyIndices,e)}priority(e){var 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){var n=this._keyIndices;if(!Object.hasOwn(n,e=String(e))){var r=this._arr,o=r.length;return n[e]=o,r.push({key:e,priority:t}),this._decrease(o),!0}return!1}removeMin(){this._swap(0,this._arr.length-1);var e=this._arr.pop();return delete this._keyIndices[e.key],this._heapify(0),e.key}decrease(e,t){var n=this._keyIndices[e];if(t>this._arr[n].priority)throw Error("New priority is greater than current priority. Key: "+e+" Old: "+this._arr[n].priority+" New: "+t);this._arr[n].priority=t,this._decrease(n)}_heapify(e){var 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){for(var t,n=this._arr,r=n[e].priority;0!==e&&!(n[t=e>>1].priority<r);)this._swap(e,t),e=t}_swap(e,t){var 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}}},28998,(e,t,n)=>{var r=e.r(88532);t.exports=function(e,t,n,i){return function(e,t,n,o){var i,a,s={},l=new r,u=function(e){var t=e.v!==i?e.v:e.w,r=s[t],o=n(e),u=a.distance+o;if(o<0)throw Error("dijkstra does not allow negative edge weights. Bad edge: "+e+" Weight: "+o);u<r.distance&&(r.distance=u,r.predecessor=i,l.decrease(t,u))};for(e.nodes().forEach(function(e){var n=e===t?0:1/0;s[e]={distance:n},l.add(e,n)});l.size()>0&&(a=s[i=l.removeMin()]).distance!==1/0;)o(i).forEach(u);return s}(e,String(t),n||o,i||function(t){return e.outEdges(t)})};var o=()=>1},30492,(e,t,n)=>{var r=e.r(28998);t.exports=function(e,t,n){return e.nodes().reduce(function(o,i){return o[i]=r(e,i,t,n),o},{})}},92771,(e,t,n)=>{t.exports=function(e){var t=0,n=[],r={},o=[];return e.nodes().forEach(function(i){Object.hasOwn(r,i)||function i(a){var s=r[a]={onStack:!0,lowlink:t,index:t++};if(n.push(a),e.successors(a).forEach(function(e){Object.hasOwn(r,e)?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){var l,u=[];do r[l=n.pop()].onStack=!1,u.push(l);while(a!==l)o.push(u)}}(i)}),o}},48327,(e,t,n)=>{var r=e.r(92771);t.exports=function(e){return r(e).filter(function(t){return t.length>1||1===t.length&&e.hasEdge(t[0],t[0])})}},2975,(e,t,n)=>{t.exports=function(e,t,n){var o,i,a,s,l;return o=e,i=t||r,a=n||function(t){return e.outEdges(t)},s={},(l=o.nodes()).forEach(function(e){s[e]={},s[e][e]={distance:0},l.forEach(function(t){e!==t&&(s[e][t]={distance:1/0})}),a(e).forEach(function(t){var n=t.v===e?t.w:t.v,r=i(t);s[e][n]={distance:r,predecessor:e}})}),l.forEach(function(e){var t=s[e];l.forEach(function(n){var r=s[n];l.forEach(function(n){var o=r[e],i=t[n],a=r[n],s=o.distance+i.distance;s<a.distance&&(a.distance=s,a.predecessor=i.predecessor)})})}),s};var r=()=>1},48251,(e,t,n)=>{function r(e){var t={},n={},r=[];if(e.sinks().forEach(function i(a){if(Object.hasOwn(n,a))throw new o;Object.hasOwn(t,a)||(n[a]=!0,t[a]=!0,e.predecessors(a).forEach(i),delete n[a],r.push(a))}),Object.keys(t).length!==e.nodeCount())throw new o;return r}class o extends Error{constructor(){super(...arguments)}}t.exports=r,r.CycleException=o},622,(e,t,n)=>{var r=e.r(48251);t.exports=function(e){try{r(e)}catch(e){if(e instanceof r.CycleException)return!1;throw e}return!0}},82493,(e,t,n)=>{function r(e,t,n,r){for(var o=[[e,!1]];o.length>0;){var a=o.pop();a[1]?r.push(a[0]):Object.hasOwn(n,a[0])||(n[a[0]]=!0,o.push([a[0],!0]),i(t(a[0]),e=>o.push([e,!1])))}}function o(e,t,n,r){for(var o=[e];o.length>0;){var a=o.pop();Object.hasOwn(n,a)||(n[a]=!0,r.push(a),i(t(a),e=>o.push(e)))}}function i(e,t){for(var n=e.length;n--;)t(e[n],n,e);return e}t.exports=function(e,t,n){Array.isArray(t)||(t=[t]);var i=e.isDirected()?t=>e.successors(t):t=>e.neighbors(t),a="post"===n?r:o,s=[],l={};return t.forEach(t=>{if(!e.hasNode(t))throw Error("Graph does not have node: "+t);a(t,i,l,s)}),s}},88994,(e,t,n)=>{var r=e.r(82493);t.exports=function(e,t){return r(e,t,"post")}},60947,(e,t,n)=>{var r=e.r(82493);t.exports=function(e,t){return r(e,t,"pre")}},58646,(e,t,n)=>{var r=e.r(75621),o=e.r(88532);t.exports=function(e,t){var n,i=new r,a={},s=new o;function l(e){var r=e.v===n?e.w:e.v,o=s.priority(r);if(void 0!==o){var i=t(e);i<o&&(a[r]=n,s.decrease(r,i))}}if(0===e.nodeCount())return i;e.nodes().forEach(function(e){s.add(e,1/0),i.setNode(e)}),s.decrease(e.nodes()[0],0);for(var u=!1;s.size()>0;){if(Object.hasOwn(a,n=s.removeMin()))i.setEdge(n,a[n]);else if(u)throw Error("Input graph is not connected: "+e);else u=!0;e.nodeEdges(n).forEach(l)}return i}},69527,(e,t,n)=>{t.exports={components:e.r(16131),dijkstra:e.r(28998),dijkstraAll:e.r(30492),findCycles:e.r(48327),floydWarshall:e.r(2975),isAcyclic:e.r(622),postorder:e.r(88994),preorder:e.r(60947),prim:e.r(58646),tarjan:e.r(92771),topsort:e.r(48251)}},92353,(e,t,n)=>{var r=e.r(96950);t.exports={Graph:r.Graph,json:e.r(71636),alg:e.r(69527),version:r.version}},16370,(e,t,n)=>{function r(e){e._prev._next=e._next,e._next._prev=e._prev,delete e._next,delete e._prev}function o(e,t){if("_next"!==e&&"_prev"!==e)return t}t.exports=class{constructor(){let e={};e._next=e._prev=e,this._sentinel=e}dequeue(){let e=this._sentinel,t=e._prev;if(t!==e)return r(t),t}enqueue(e){let t=this._sentinel;e._prev&&e._next&&r(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,o)),n=n._prev;return"["+e.join(", ")+"]"}}},50395,(e,t,n)=>{let r=e.r(92353).Graph,o=e.r(16370);t.exports=function(e,t){var n,l;let u,c,d,h,f;if(1>=e.nodeCount())return[];let p=(n=e,l=t||i,u=new r,c=0,d=0,n.nodes().forEach(e=>{u.setNode(e,{v:e,in:0,out:0})}),n.edges().forEach(e=>{let t=u.edge(e.v,e.w)||0,n=l(e);u.setEdge(e.v,e.w,t+n),d=Math.max(d,u.node(e.v).out+=n),c=Math.max(c,u.node(e.w).in+=n)}),h=(function(e){let t=[];for(let n=0;n<e;n++)t.push(n);return t})(d+c+3).map(()=>new o),f=c+1,u.nodes().forEach(e=>{s(h,f,u.node(e))}),{graph:u,buckets:h,zeroIdx:f});return(function(e,t,n){let r,o=[],i=t[t.length-1],s=t[0];for(;e.nodeCount();){for(;r=s.dequeue();)a(e,t,n,r);for(;r=i.dequeue();)a(e,t,n,r);if(e.nodeCount()){for(let i=t.length-2;i>0;--i)if(r=t[i].dequeue()){o=o.concat(a(e,t,n,r,!0));break}}}return o})(p.graph,p.buckets,p.zeroIdx).flatMap(t=>e.outEdges(t.v,t.w))};let i=()=>1;function a(e,t,n,r,o){let i=o?[]:void 0;return e.inEdges(r.v).forEach(r=>{let a=e.edge(r),l=e.node(r.v);o&&i.push({v:r.v,w:r.w}),l.out-=a,s(t,n,l)}),e.outEdges(r.v).forEach(r=>{let o=e.edge(r),i=r.w,a=e.node(i);a.in-=o,s(t,n,a)}),e.removeNode(r.v),i}function s(e,t,n){n.out?n.in?e[n.out-n.in+t].enqueue(n):e[e.length-1].enqueue(n):e[0].enqueue(n)}},98298,(e,t,n)=>{"use strict";let r=e.r(92353).Graph;function o(e,t,n,r){for(var o=r;e.hasNode(o);)o=l(r);return n.dummy=t,e.setNode(o,n),o}t.exports={addBorderNode:function(e,t,n,r){let i={width:0,height:0};return arguments.length>=4&&(i.rank=n,i.order=r),o(e,"border",i,t)},addDummyNode:o,applyWithChunking:i,asNonCompoundGraph:function(e){let t=new r({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},buildLayerMatrix:function(e){let t=u(a(e)+1).map(()=>[]);return e.nodes().forEach(n=>{let r=e.node(n),o=r.rank;void 0!==o&&(t[o][r.order]=n)}),t},intersectRect:function(e,t){let n,r,o=e.x,i=e.y,a=t.x-o,s=t.y-i,l=e.width/2,u=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)*u?(s<0&&(u=-u),n=u*a/s,r=u):(a<0&&(l=-l),n=l,r=l*s/a),{x:o+n,y:i+r}},mapValues:function(e,t){let n=t;return"string"==typeof t&&(n=e=>e[t]),Object.entries(e).reduce((e,[t,r])=>(e[t]=n(r,t),e),{})},maxRank:a,normalizeRanks:function(e){let t=i(Math.min,e.nodes().map(t=>{let n=e.node(t).rank;return void 0===n?Number.MAX_VALUE:n}));e.nodes().forEach(n=>{let r=e.node(n);Object.hasOwn(r,"rank")&&(r.rank-=t)})},notime:function(e,t){return t()},partition:function(e,t){let n={lhs:[],rhs:[]};return e.forEach(e=>{t(e)?n.lhs.push(e):n.rhs.push(e)}),n},pick:function(e,t){let n={};for(let r of t)void 0!==e[r]&&(n[r]=e[r]);return n},predecessorWeights:function(e){let t=e.nodes().map(t=>{let n={};return e.inEdges(t).forEach(t=>{n[t.v]=(n[t.v]||0)+e.edge(t).weight}),n});return c(e.nodes(),t)},range:u,removeEmptyRanks:function(e){let t=i(Math.min,e.nodes().map(t=>e.node(t).rank)),n=[];e.nodes().forEach(r=>{let o=e.node(r).rank-t;n[o]||(n[o]=[]),n[o].push(r)});let r=0,o=e.graph().nodeRankFactor;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)})},simplify:function(e){let t=new r().setGraph(e.graph());return e.nodes().forEach(n=>t.setNode(n,e.node(n))),e.edges().forEach(n=>{let r=t.edge(n.v,n.w)||{weight:0,minlen:1},o=e.edge(n);t.setEdge(n.v,n.w,{weight:r.weight+o.weight,minlen:Math.max(r.minlen,o.minlen)})}),t},successorWeights:function(e){let t=e.nodes().map(t=>{let n={};return e.outEdges(t).forEach(t=>{n[t.w]=(n[t.w]||0)+e.edge(t).weight}),n});return c(e.nodes(),t)},time:function(e,t){let n=Date.now();try{return t()}finally{console.log(e+" time: "+(Date.now()-n)+"ms")}},uniqueId:l,zipObject:c};function i(e,t){if(!(t.length>65535))return e.apply(null,t);{let n=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);return e.apply(null,n.map(t=>e.apply(null,t)))}}function a(e){return i(Math.max,e.nodes().map(t=>{let n=e.node(t).rank;return void 0===n?5e-324:n}))}let s=0;function l(e){return e+""+ ++s}function u(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 c(e,t){return e.reduce((e,n,r)=>(e[n]=t[r],e),{})}},96218,(e,t,n)=>{"use strict";let r=e.r(50395),o=e.r(98298).uniqueId;t.exports={run:function(e){var t,n;let i,a,s;("greedy"===e.graph().acyclicer?r(e,(t=e,e=>t.edge(e).weight)):(i=[],a={},s={},(n=e).nodes().forEach(function e(t){Object.hasOwn(s,t)||(s[t]=!0,a[t]=!0,n.outEdges(t).forEach(t=>{Object.hasOwn(a,t.w)?i.push(t):e(t.w)}),delete a[t])}),i)).forEach(t=>{let n=e.edge(t);e.removeEdge(t),n.forwardName=t.name,n.reversed=!0,e.setEdge(t.w,t.v,n,o("rev"))})},undo:function(e){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)}})}}},60908,(e,t,n)=>{"use strict";let r=e.r(98298);t.exports={run:function(e){e.graph().dummyChains=[],e.edges().forEach(t=>(function(e,t){let n,o,i,a=t.v,s=e.node(a).rank,l=t.w,u=e.node(l).rank,c=t.name,d=e.edge(t),h=d.labelRank;if(u!==s+1){for(e.removeEdge(t),i=0,++s;s<u;++i,++s)d.points=[],o={width:0,height:0,edgeLabel:d,edgeObj:t,rank:s},n=r.addDummyNode(e,"edge",o,"_d"),s===h&&(o.width=d.width,o.height=d.height,o.dummy="edge-label",o.labelpos=d.labelpos),e.setEdge(a,n,{weight:d.weight},c),0===i&&e.graph().dummyChains.push(n),a=n;e.setEdge(a,l,{weight:d.weight},c)}})(e,t))},undo:function(e){e.graph().dummyChains.forEach(t=>{let n,r=e.node(t),o=r.edgeLabel;for(e.setEdge(r.edgeObj,o);r.dummy;)n=e.successors(t)[0],e.removeNode(t),o.points.push({x:r.x,y:r.y}),"edge-label"===r.dummy&&(o.x=r.x,o.y=r.y,o.width=r.width,o.height=r.height),t=n,r=e.node(t)})}}},570,(e,t,n)=>{"use strict";let{applyWithChunking:r}=e.r(98298);t.exports={longestPath:function(e){var t={};e.sources().forEach(function n(o){var i=e.node(o);if(Object.hasOwn(t,o))return i.rank;t[o]=!0;var a=r(Math.min,e.outEdges(o).map(t=>null==t?1/0:n(t.w)-e.edge(t).minlen));return a===1/0&&(a=0),i.rank=a})},slack:function(e,t){return e.node(t.w).rank-e.node(t.v).rank-e.edge(t).minlen}}},48438,(e,t,n)=>{"use strict";var r=e.r(92353).Graph,o=e.r(570).slack;t.exports=function(e){var t,n,i,a,s=new r({directed:!1}),l=e.nodes()[0],u=e.nodeCount();for(s.setNode(l,{});t=s,n=e,t.nodes().forEach(function e(r){n.nodeEdges(r).forEach(i=>{var a=i.v,s=r===a?i.w:a;t.hasNode(s)||o(n,i)||(t.setNode(s,{}),t.setEdge(r,s,{}),e(s))})}),t.nodeCount()<u;)i=function(e,t){return t.edges().reduce((n,r)=>{let i=1/0;return(e.hasNode(r.v)!==e.hasNode(r.w)&&(i=o(t,r)),i<n[0])?[i,r]:n},[1/0,null])[1]}(s,e),a=s.hasNode(i.v)?o(e,i):-o(e,i),function(e,t,n){e.nodes().forEach(e=>t.node(e).rank+=n)}(s,e,a);return s}},6654,(e,t,n)=>{"use strict";var r=e.r(48438),o=e.r(570).slack,i=e.r(570).longestPath,a=e.r(92353).alg.preorder,s=e.r(92353).alg.postorder,l=e.r(98298).simplify;function u(e){i(e=l(e));var t,n,o=r(e);for(h(o),c(o,e);t=f(o);)n=p(o,e,t),g(o,e,t,n)}function c(e,t){var n=s(e,e.nodes());(n=n.slice(0,n.length-1)).forEach(n=>{var r,o,i,a;return r=e,o=t,i=n,a=r.node(i).parent,void(r.edge(i,a).cutvalue=d(r,o,i))})}function d(e,t,n){var r=e.node(n).parent,o=!0,i=t.edge(n,r),a=0;return i||(o=!1,i=t.edge(r,n)),a=i.weight,t.nodeEdges(n).forEach(i=>{var s=i.v===n,l=s?i.w:i.v;if(l!==r){var u,c,d,h=s===o,f=t.edge(i).weight;if(a+=h?f:-f,u=e,c=n,d=l,u.hasEdge(c,d)){var p=e.edge(n,l).cutvalue;a+=h?-p:p}}}),a}function h(e,t){arguments.length<2&&(t=e.nodes()[0]),function e(t,n,r,o,i){var a=r,s=t.node(o);return n[o]=!0,t.neighbors(o).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 f(e){return e.edges().find(t=>e.edge(t).cutvalue<0)}function p(e,t,n){var r=n.v,i=n.w;t.hasEdge(r,i)||(r=n.w,i=n.v);var a=e.node(r),s=e.node(i),l=a,u=!1;return a.lim>s.lim&&(l=s,u=!0),t.edges().filter(t=>u===m(e,e.node(t.v),l)&&u!==m(e,e.node(t.w),l)).reduce((e,n)=>o(t,n)<o(t,e)?n:e)}function g(e,t,n,r){var o,i,s,l,u=n.v,d=n.w;e.removeEdge(u,d),e.setEdge(r.v,r.w,{}),h(e),c(e,t),o=e,i=t,s=o.nodes().find(e=>!i.node(e).parent),(l=(l=a(o,s)).slice(1)).forEach(e=>{var t=o.node(e).parent,n=i.edge(e,t),r=!1;n||(n=i.edge(t,e),r=!0),i.node(e).rank=i.node(t).rank+(r?n.minlen:-n.minlen)})}function m(e,t,n){return n.low<=t.lim&&t.lim<=n.lim}t.exports=u,u.initLowLimValues=h,u.initCutValues=c,u.calcCutValue=d,u.leaveEdge=f,u.enterEdge=p,u.exchangeEdges=g},93534,(e,t,n)=>{"use strict";var r=e.r(570).longestPath,o=e.r(48438),i=e.r(6654);t.exports=function(e){var t,n=e.graph().ranker;if(n instanceof Function)return n(e);switch(e.graph().ranker){case"network-simplex":default:i(e);break;case"tight-tree":r(t=e),o(t);break;case"longest-path":a(e);case"none":}};var a=r},84179,(e,t,n)=>{t.exports=function(e){var t;let n,r,o=(n={},r=0,(t=e).children().forEach(function e(o){let i=r;t.children(o).forEach(e),n[o]={low:i,lim:r++}}),n);e.graph().dummyChains.forEach(t=>{let n=e.node(t),r=n.edgeObj,i=function(e,t,n,r){let o,i,a=[],s=[],l=Math.min(t[n].low,t[r].low),u=Math.max(t[n].lim,t[r].lim);o=n;do a.push(o=e.parent(o));while(o&&(t[o].low>l||u>t[o].lim))for(i=o,o=r;(o=e.parent(o))!==i;)s.push(o);return{path:a.concat(s.reverse()),lca:i}}(e,o,r.v,r.w),a=i.path,s=i.lca,l=0,u=a[0],c=!0;for(;t!==r.w;){if(n=e.node(t),c){for(;(u=a[l])!==s&&e.node(u).maxRank<n.rank;)l++;u===s&&(c=!1)}if(!c){for(;l<a.length-1&&e.node(u=a[l+1]).minRank<=n.rank;)l++;u=a[l]}e.setParent(t,u),t=e.successors(t)[0]}})}},45128,(e,t,n)=>{let r=e.r(98298);t.exports={run:function(e){var t,n,o;let i=r.addDummyNode(e,"root",{},"_root"),a=(n={},(t=e).children().forEach(e=>(function e(r,o){var i=t.children(r);i&&i.length&&i.forEach(t=>e(t,o+1)),n[r]=o})(e,1)),n),s=Object.values(a),l=r.applyWithChunking(Math.max,s)-1,u=2*l+1;e.graph().nestingRoot=i,e.edges().forEach(t=>e.edge(t).minlen*=u);let c=(o=e).edges().reduce((e,t)=>e+o.edge(t).weight,0)+1;e.children().forEach(t=>(function e(t,n,o,i,a,s,l){let u=t.children(l);if(!u.length){l!==n&&t.setEdge(n,l,{weight:0,minlen:o});return}let c=r.addBorderNode(t,"_bt"),d=r.addBorderNode(t,"_bb"),h=t.node(l);t.setParent(c,l),h.borderTop=c,t.setParent(d,l),h.borderBottom=d,u.forEach(r=>{e(t,n,o,i,a,s,r);let u=t.node(r),h=u.borderTop?u.borderTop:r,f=u.borderBottom?u.borderBottom:r,p=u.borderTop?i:2*i,g=h!==f?1:a-s[l]+1;t.setEdge(c,h,{weight:p,minlen:g,nestingEdge:!0}),t.setEdge(f,d,{weight:p,minlen:g,nestingEdge:!0})}),t.parent(l)||t.setEdge(n,c,{weight:0,minlen:a+s[l]})})(e,i,u,c,l,a,t)),e.graph().nodeRankFactor=u},cleanup:function(e){var t=e.graph();e.removeNode(t.nestingRoot),delete t.nestingRoot,e.edges().forEach(t=>{e.edge(t).nestingEdge&&e.removeEdge(t)})}}},36561,(e,t,n)=>{let r=e.r(98298);function o(e,t,n,o,i,a){let s=i[t][a-1],l=r.addDummyNode(e,"border",{width:0,height:0,rank:a,borderType:t},n);i[t][a]=l,e.setParent(l,o),s&&e.setEdge(s,l,{weight:1})}t.exports=function(e){e.children().forEach(function t(n){let r=e.children(n),i=e.node(n);if(r.length&&r.forEach(t),Object.hasOwn(i,"minRank")){i.borderLeft=[],i.borderRight=[];for(let t=i.minRank,r=i.maxRank+1;t<r;++t)o(e,"borderLeft","_bl",n,i,t),o(e,"borderRight","_br",n,i,t)}})}},14872,(e,t,n)=>{"use strict";function r(e){e.nodes().forEach(t=>o(e.node(t))),e.edges().forEach(t=>o(e.edge(t)))}function o(e){let t=e.width;e.width=e.height,e.height=t}function i(e){e.y=-e.y}function a(e){let t=e.x;e.x=e.y,e.y=t}t.exports={adjust:function(e){let t=e.graph().rankdir.toLowerCase();("lr"===t||"rl"===t)&&r(e)},undo:function(e){var t,n;let o=e.graph().rankdir.toLowerCase();("bt"===o||"rl"===o)&&((t=e).nodes().forEach(e=>i(t.node(e))),t.edges().forEach(e=>{let n=t.edge(e);n.points.forEach(i),Object.hasOwn(n,"y")&&i(n)})),("lr"===o||"rl"===o)&&((n=e).nodes().forEach(e=>a(n.node(e))),n.edges().forEach(e=>{let t=n.edge(e);t.points.forEach(a),Object.hasOwn(t,"x")&&a(t)}),r(e))}}},55396,(e,t,n)=>{"use strict";let r=e.r(98298);t.exports=function(e){let t={},n=e.nodes().filter(t=>!e.children(t).length),o=n.map(t=>e.node(t).rank),i=r.applyWithChunking(Math.max,o),a=r.range(i+1).map(()=>[]);return n.sort((t,n)=>e.node(t).rank-e.node(n).rank).forEach(function n(r){t[r]||(t[r]=!0,a[e.node(r).rank].push(r),e.successors(r).forEach(n))}),a}},5762,(e,t,n)=>{"use strict";let r=e.r(98298).zipObject;t.exports=function(e,t){let n=0;for(let o=1;o<t.length;++o)n+=function(e,t,n){let o=r(n,n.map((e,t)=>t)),i=t.flatMap(t=>e.outEdges(t).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),u=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;u+=e.weight*n}),u}(e,t[o-1],t[o]);return n}},93763,(e,t,n)=>{t.exports=function(e,t=[]){return t.map(t=>{let n=e.inEdges(t);if(!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}}})}},54053,(e,t,n)=>{"use strict";let r=e.r(98298);t.exports=function(e,t){let n={};return e.forEach((e,t)=>{let r=n[e.v]={indegree:0,in:[],out:[],vs:[e.v],i:t};void 0!==e.barycenter&&(r.barycenter=e.barycenter,r.weight=e.weight)}),t.edges().forEach(e=>{let t=n[e.v],r=n[e.w];void 0!==t&&void 0!==r&&(r.indegree++,t.out.push(n[e.w]))}),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=>r.pick(e,["vs","i","barycenter","weight"]))}(Object.values(n).filter(e=>!e.indegree))}},99139,(e,t,n)=>{let r=e.r(98298);function o(e,t,n){let r;for(;t.length&&(r=t[t.length-1]).i<=n;)t.pop(),e.push(r.vs),n++;return n}t.exports=function(e,t){var n;let i=r.partition(e,e=>Object.hasOwn(e,"barycenter")),a=i.lhs,s=i.rhs.sort((e,t)=>t.i-e.i),l=[],u=0,c=0,d=0;a.sort((n=!!t,(e,t)=>e.barycenter<t.barycenter?-1:e.barycenter>t.barycenter?1:n?t.i-e.i:e.i-t.i)),d=o(l,s,d),a.forEach(e=>{d+=e.vs.length,l.push(e.vs),u+=e.barycenter*e.weight,c+=e.weight,d=o(l,s,d)});let h={vs:l.flat(!0)};return c&&(h.barycenter=u/c,h.weight=c),h}},68818,(e,t,n)=>{let r=e.r(93763),o=e.r(54053),i=e.r(99139);t.exports=function e(t,n,a,s){var l,u;let c=t.children(n),d=t.node(n),h=d?d.borderLeft:void 0,f=d?d.borderRight:void 0,p={};h&&(c=c.filter(e=>e!==h&&e!==f));let g=r(t,c);g.forEach(n=>{if(t.children(n.v).length){var r,o;let i=e(t,n.v,a,s);p[n.v]=i,Object.hasOwn(i,"barycenter")&&(r=n,o=i,void 0!==r.barycenter?(r.barycenter=(r.barycenter*r.weight+o.barycenter*o.weight)/(r.weight+o.weight),r.weight+=o.weight):(r.barycenter=o.barycenter,r.weight=o.weight))}});let m=o(g,a);l=m,u=p,l.forEach(e=>{e.vs=e.vs.flatMap(e=>u[e]?u[e].vs:e)});let y=i(m,s);if(h&&(y.vs=[h,y.vs,f].flat(!0),t.predecessors(h).length)){let e=t.node(t.predecessors(h)[0]),n=t.node(t.predecessors(f)[0]);Object.hasOwn(y,"barycenter")||(y.barycenter=0,y.weight=0),y.barycenter=(y.barycenter*y.weight+e.order+n.order)/(y.weight+2),y.weight+=2}return y}},62782,(e,t,n)=>{let r=e.r(92353).Graph,o=e.r(98298);t.exports=function(e,t,n,i){i||(i=e.nodes());let a=function(e){for(var t;e.hasNode(t=o.uniqueId("_root")););return t}(e),s=new r({compound:!0}).setGraph({root:a}).setDefaultNodeLabel(t=>e.node(t));return i.forEach(r=>{let o=e.node(r),i=e.parent(r);(o.rank===t||o.minRank<=t&&t<=o.maxRank)&&(s.setNode(r),s.setParent(r,i||a),e[n](r).forEach(t=>{let n=t.v===r?t.w:t.v,o=s.edge(n,r),i=void 0!==o?o.weight:0;s.setEdge(n,r,{weight:e.edge(t).weight+i})}),Object.hasOwn(o,"minRank")&&s.setNode(r,{borderLeft:o.borderLeft[t],borderRight:o.borderRight[t]}))}),s}},35403,(e,t,n)=>{t.exports=function(e,t,n){let r={},o;n.forEach(n=>{let i=e.parent(n),a,s;for(;i;){if((a=e.parent(i))?(s=r[a],r[a]=i):(s=o,o=i),s&&s!==i)return void t.setEdge(s,i);i=a}})}},5461,(e,t,n)=>{"use strict";let r=e.r(55396),o=e.r(5762),i=e.r(68818),a=e.r(62782),s=e.r(35403),l=e.r(92353).Graph,u=e.r(98298);function c(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){return a(e,t,n,r.get(t)||[])})}function d(e,t){Object.values(t).forEach(t=>t.forEach((t,n)=>e.node(t).order=n))}t.exports=function e(t,n){if(n&&"function"==typeof n.customOrder)return void n.customOrder(t,e);let a=u.maxRank(t),h=c(t,u.range(1,a+1),"inEdges"),f=c(t,u.range(a-1,-1,-1),"outEdges"),p=r(t);if(d(t,p),n&&n.disableOptimalOrderHeuristic)return;let g=1/0,m;for(let e=0,n=0;n<4;++e,++n){(function(e,t){let n=new l;e.forEach(function(e){let r=e.graph().root,o=i(e,r,n,t);o.vs.forEach((t,n)=>e.node(t).order=n),s(e,n,o.vs)})})(e%2?h:f,e%4>=2),p=u.buildLayerMatrix(t);let r=o(t,p);r<g&&(n=0,m=Object.assign({},p),g=r)}d(t,m)}},90741,(e,t,n)=>{"use strict";let r=e.r(92353).Graph,o=e.r(98298);function i(e,t){let n={};return t.length&&t.reduce(function(t,r){let o=0,i=0,a=t.length,l=r[r.length-1];return r.forEach((t,u)=>{let c=function(e,t){if(e.node(t).dummy)return e.predecessors(t).find(t=>e.node(t).dummy)}(e,t),d=c?e.node(c).order:a;(c||t===l)&&(r.slice(i,u+1).forEach(t=>{e.predecessors(t).forEach(r=>{let i=e.node(r),a=i.order;(a<o||d<a)&&!(i.dummy&&e.node(t).dummy)&&s(n,r,t)})}),i=u+1,o=d)}),r}),n}function a(e,t){let n={};function r(t,r,i,a,l){let u;o.range(r,i).forEach(r=>{u=t[r],e.node(u).dummy&&e.predecessors(u).forEach(t=>{let r=e.node(t);r.dummy&&(r.order<a||r.order>l)&&s(n,t,u)})})}return t.length&&t.reduce(function(t,n){let o=-1,i,a=0;return n.forEach((s,l)=>{if("border"===e.node(s).dummy){let t=e.predecessors(s);t.length&&(i=e.node(t[0]).order,r(n,a,l,o,i),a=l,o=i)}r(n,a,n.length,i,t.length)}),n}),n}function s(e,t,n){if(t>n){let e=t;t=n,n=e}let r=e[t];r||(e[t]=r={}),r[n]=!0}function l(e,t,n){if(t>n){let e=t;t=n,n=e}return!!e[t]&&Object.hasOwn(e[t],n)}function u(e,t,n,r){let o={},i={},a={};return t.forEach(e=>{e.forEach((e,t)=>{o[e]=e,i[e]=e,a[e]=t})}),t.forEach(e=>{let t=-1;e.forEach(e=>{let s=r(e);if(s.length){let r=((s=s.sort((e,t)=>a[e]-a[t])).length-1)/2;for(let u=Math.floor(r),c=Math.ceil(r);u<=c;++u){let r=s[u];i[e]===e&&t<a[r]&&!l(n,e,r)&&(i[r]=e,i[e]=o[e]=o[r],t=a[r])}}})}),{root:o,align:i}}function c(e,t,n,o,i){var a,s,l,u,c,d,h;let f,p,g,m={},y=(a=e,s=t,l=n,u=i,f=new r,g=(c=(p=a.graph()).nodesep,d=p.edgesep,h=u,(e,t,n)=>{let r,o,i=e.node(t),a=e.node(n);if(r=0+i.width/2,Object.hasOwn(i,"labelpos"))switch(i.labelpos.toLowerCase()){case"l":o=-i.width/2;break;case"r":o=i.width/2}if(o&&(r+=h?o:-o),o=0,r+=(i.dummy?d:c)/2,r+=(a.dummy?d:c)/2,r+=a.width/2,Object.hasOwn(a,"labelpos"))switch(a.labelpos.toLowerCase()){case"l":o=a.width/2;break;case"r":o=-a.width/2}return o&&(r+=h?o:-o),o=0,r}),s.forEach(e=>{let t;e.forEach(e=>{let n=l[e];if(f.setNode(n),t){var r=l[t],o=f.edge(r,n);f.setEdge(r,n,Math.max(g(a,e,t),o||0))}t=e})}),f),v=i?"borderLeft":"borderRight";function x(e,t){let n=y.nodes(),r=n.pop(),o={};for(;r;)o[r]?e(r):(o[r]=!0,n.push(r),n=n.concat(t(r))),r=n.pop()}return x(function(e){m[e]=y.inEdges(e).reduce((e,t)=>Math.max(e,m[t.v]+y.edge(t)),0)},y.predecessors.bind(y)),x(function(t){let n=y.outEdges(t).reduce((e,t)=>Math.min(e,m[t.w]-y.edge(t)),1/0),r=e.node(t);n!==1/0&&r.borderType!==v&&(m[t]=Math.max(m[t],n))},y.successors.bind(y)),Object.keys(o).forEach(e=>m[e]=m[n[e]]),m}function d(e,t){return Object.values(t).reduce((t,n)=>{let r=-1/0,o=1/0;Object.entries(n).forEach(([t,n])=>{var i,a;let s=(i=e,a=t,i.node(a).width/2);r=Math.max(n+s,r),o=Math.min(n-s,o)});let i=r-o;return i<t[0]&&(t=[i,n]),t},[1/0,null])[1]}function h(e,t){let n=Object.values(t),r=o.applyWithChunking(Math.min,n),i=o.applyWithChunking(Math.max,n);["u","d"].forEach(n=>{["l","r"].forEach(a=>{let s=n+a,l=e[s];if(l===t)return;let u=Object.values(l),c=r-o.applyWithChunking(Math.min,u);"l"!==a&&(c=i-o.applyWithChunking(Math.max,u)),c&&(e[s]=o.mapValues(l,e=>e+c))})})}function f(e,t){return o.mapValues(e.ul,(n,r)=>{if(t)return e[t.toLowerCase()][r];{let t=Object.values(e).map(e=>e[r]).sort((e,t)=>e-t);return(t[1]+t[2])/2}})}t.exports={positionX:function(e){let t,n=o.buildLayerMatrix(e),r=Object.assign(i(e,n),a(e,n)),s={};["u","d"].forEach(i=>{t="u"===i?n:Object.values(n).reverse(),["l","r"].forEach(n=>{"r"===n&&(t=t.map(e=>Object.values(e).reverse()));let a=("u"===i?e.predecessors:e.successors).bind(e),l=u(e,t,r,a),d=c(e,t,l.root,l.align,"r"===n);"r"===n&&(d=o.mapValues(d,e=>-e)),s[i+n]=d})});let l=d(e,s);return h(s,l),f(s,e.graph().align)},findType1Conflicts:i,findType2Conflicts:a,addConflict:s,hasConflict:l,verticalAlignment:u,horizontalCompaction:c,alignCoordinates:h,findSmallestWidthAlignment:d,balance:f}},14314,(e,t,n)=>{"use strict";let r=e.r(98298),o=e.r(90741).positionX;t.exports=function(e){var t;let n,i,a;t=e=r.asNonCompoundGraph(e),n=r.buildLayerMatrix(t),i=t.graph().ranksep,a=0,n.forEach(e=>{let n=e.reduce((e,n)=>{let r=t.node(n).height;return e>r?e:r},0);e.forEach(e=>t.node(e).y=a+n/2),a+=n+i}),Object.entries(o(e)).forEach(([t,n])=>e.node(t).x=n)}},52654,(e,t,n)=>{"use strict";let r=e.r(96218),o=e.r(60908),i=e.r(93534),a=e.r(98298).normalizeRanks,s=e.r(84179),l=e.r(98298).removeEmptyRanks,u=e.r(45128),c=e.r(36561),d=e.r(14872),h=e.r(5461),f=e.r(14314),p=e.r(98298),g=e.r(92353).Graph;t.exports=function(e,t){let n=t&&t.debugTiming?p.time:p.notime;n("layout",()=>{let M=n(" buildLayoutGraph",()=>{var t;let n,r;return t=e,n=new g({multigraph:!0,compound:!0}),r=S(t.graph()),n.setGraph(Object.assign({},y,k(r,m),p.pick(r,v))),t.nodes().forEach(e=>{let r=k(S(t.node(e)),x);Object.keys(w).forEach(e=>{void 0===r[e]&&(r[e]=w[e])}),n.setNode(e,r),n.setParent(e,t.parent(e))}),t.edges().forEach(e=>{let r=S(t.edge(e));n.setEdge(e,Object.assign({},E,k(r,b),p.pick(r,_)))}),n});n(" runLayout",()=>{var e,g,m;return e=M,g=n,m=t,void(g(" 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)}))}),g(" removeSelfEdges",()=>{var t;(t=e).edges().forEach(e=>{if(e.v===e.w){var n=t.node(e.v);n.selfEdges||(n.selfEdges=[]),n.selfEdges.push({e:e,label:t.edge(e)}),t.removeEdge(e)}})}),g(" acyclic",()=>r.run(e)),g(" nestingGraph.run",()=>u.run(e)),g(" rank",()=>i(p.asNonCompoundGraph(e))),g(" 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};p.addDummyNode(t,"edge-proxy",r,"_ep")}})}),g(" removeEmptyRanks",()=>l(e)),g(" nestingGraph.cleanup",()=>u.cleanup(e)),g(" normalizeRanks",()=>a(e)),g(" 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)}),g(" 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))})}),g(" normalize.run",()=>o.run(e)),g(" parentDummyChains",()=>s(e)),g(" addBorderSegments",()=>c(e)),g(" order",()=>h(e,m)),g(" insertSelfEdges",()=>{var t;return t=e,void p.buildLayerMatrix(t).forEach(e=>{var n=0;e.forEach((e,r)=>{var o=t.node(e);o.order=r+n,(o.selfEdges||[]).forEach(e=>{p.addDummyNode(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})})}),g(" adjustCoordinateSystem",()=>d.adjust(e)),g(" position",()=>f(e)),g(" positionSelfEdges",()=>{var t;(t=e).nodes().forEach(e=>{var n=t.node(e);if("selfedge"===n.dummy){var 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}})}),g(" 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)})}),g(" normalize.undo",()=>o.undo(e)),g(" 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}})}),g(" undoCoordinateSystem",()=>d.undo(e)),g(" 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)),g(" assignNodeIntersects",()=>{var t;(t=e).edges().forEach(e=>{let n,r,o=t.edge(e),i=t.node(e.v),a=t.node(e.w);o.points?(n=o.points[0],r=o.points[o.points.length-1]):(o.points=[],n=a,r=i),o.points.unshift(p.intersectRect(i,n)),o.points.push(p.intersectRect(a,r))})}),g(" reversePoints",()=>{var t;(t=e).edges().forEach(e=>{let n=t.edge(e);n.reversed&&n.points.reverse()})}),g(" acyclic.undo",()=>r.undo(e)))}),n(" updateInputGraph",()=>{var t,n;return t=e,n=M,void(t.nodes().forEach(e=>{let r=t.node(e),o=n.node(e);r&&(r.x=o.x,r.y=o.y,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)})})};let m=["nodesep","edgesep","ranksep","marginx","marginy"],y={ranksep:50,edgesep:20,nodesep:50,rankdir:"tb"},v=["acyclicer","ranker","rankdir","align"],x=["width","height","rank"],w={width:0,height:0},b=["minlen","weight","width","height","labeloffset"],E={minlen:1,weight:1,width:0,height:0,labeloffset:10,labelpos:"r"},_=["labelpos"];function k(e,t){return p.mapValues(p.pick(e,t),Number)}function S(e){var t={};return e&&Object.entries(e).forEach(([e,n])=>{"string"==typeof e&&(e=e.toLowerCase()),t[e]=n}),t}},13515,(e,t,n)=>{let r=e.r(98298),o=e.r(92353).Graph;t.exports={debugOrdering:function(e){let t=r.buildLayerMatrix(e),n=new o({compound:!0,multigraph:!0}).setGraph({});return e.nodes().forEach(t=>{n.setNode(t,{label:t}),n.setParent(t,"layer"+e.node(t).rank)}),e.edges().forEach(e=>n.setEdge(e.v,e.w,{},e.name)),t.forEach((e,t)=>{n.setNode("layer"+t,{rank:"same"}),e.reduce((e,t)=>(n.setEdge(e,t,{style:"invis"}),t))}),n}}},22596,(e,t,n)=>{t.exports="1.1.8"},65825,(e,t,n)=>{t.exports={graphlib:e.r(92353),layout:e.r(52654),debug:e.r(13515),util:{time:e.r(98298).time,notime:e.r(98298).notime},version:e.r(22596)}},68613,e=>{"use strict";var t,n,r,o,i,a,s,l,u,c,d,h,f,p,g,m,y,v=e.i(43476),x=e.i(71645);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(47167);var b={value:()=>{}};function E(){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 _(r)}function _(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 S(){}function M(e){return null==e?S:function(){return this.querySelector(e)}}function N(){return[]}function C(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)}}_.prototype=E.prototype={constructor:_,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)},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 z=Array.prototype.filter;function $(){return Array.from(this.children)}function I(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,u=i.length;s<u;++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 D(e,t,n,r,o,i,a){var s,l,u,c=new Map,d=t.length,h=i.length,f=Array(d);for(s=0;s<d;++s)(l=t[s])&&(f[s]=u=a.call(l,l.__data__,s,t)+"",c.has(u)?o[s]=l:c.set(u,l));for(s=0;s<h;++s)u=a.call(e,i[s],s,i)+"",(l=c.get(u))?(r[s]=l,l.__data__=i[s],c.delete(u)):n[s]=new L(e,i[s]);for(s=0;s<d;++s)(l=t[s])&&c.get(f[s])===l&&(o[s]=l)}function B(e){return e.__data__}function T(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 W(e){return e.trim().split(/^|\s+/)}function q(e){return e.classList||new K(e)}function K(e){this._node=e,this._names=W(e.getAttribute("class")||"")}function Z(e,t){for(var n=q(e),r=-1,o=t.length;++r<o;)n.add(t[r])}function G(e,t){for(var n=q(e),r=-1,o=t.length;++r<o;)n.remove(t[r])}function U(){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)}K.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 eu=[null];function ec(e,t){this._groups=e,this._parents=t}function ed(){return new ec([[document.documentElement]],eu)}function eh(e){return"string"==typeof e?new ec([[document.querySelector(e)]],[document.documentElement]):new ec([[e]],eu)}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]}ec.prototype=ed.prototype={constructor:ec,select:function(e){"function"!=typeof e&&(e=M(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,u=r[o]=Array(l),c=0;c<l;++c)(i=s[c])&&(a=e.call(i,i.__data__,c,s))&&("__data__"in i&&(a.__data__=i.__data__),u[c]=a);return new ec(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=C(e);for(var n=this._groups,r=n.length,o=[],i=[],a=0;a<r;++a)for(var s,l=n[a],u=l.length,c=0;c<u;++c)(s=l[c])&&(o.push(e.call(s,s.__data__,c,l)),i.push(s));return new ec(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?$:(t="function"==typeof e?e:O(e),function(){return z.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]=[],u=0;u<s;++u)(i=a[u])&&e.call(i,i.__data__,u,a)&&l.push(i);return new ec(r,this._parents)},data:function(e,t){if(!arguments.length)return Array.from(this,B);var n=t?D: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),u=0;u<i;++u){var c=r[u],d=o[u],h=d.length,f="object"==typeof(y=e.call(c,c&&c.__data__,u,r))&&"length"in y?y:Array.from(y),p=f.length,g=s[u]=Array(p),m=a[u]=Array(p);n(c,d,g,m,l[u]=Array(h),f,t);for(var y,v,x,w,b=0,E=0;b<p;++b)if(x=g[b]){for(b>=E&&(E=b+1);!(w=m[E])&&++E<p;);x._next=w||null}}return(a=new ec(a,r))._enter=s,a._exit=l,a},enter:function(){return new ec(this._enter||this._groups.map(I),this._parents)},exit:function(){return new ec(this._exit||this._groups.map(I),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 u,c=n[l],d=r[l],h=c.length,f=s[l]=Array(h),p=0;p<h;++p)(u=c[p]||d[p])&&(f[p]=u);for(;l<o;++l)s[l]=n[l];return new ec(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=T);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,u=o[i]=Array(l),c=0;c<l;++c)(a=s[c])&&(u[c]=a);u.sort(t)}return new ec(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=W(e+"");if(arguments.length<2){for(var r=q(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)?Z:G)(this,e)}}:t?function(e){return function(){Z(this,e)}}:function(e){return function(){G(this,e)}})(n,t))},text:function(e){return arguments.length?this.each(null==e?U:("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:M(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,u=0,c=s.length;u<c;++u)for(r=0,l=s[u];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:u,dispatch:c}){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:u,enumerable:!0,configurable:!0},_:{value:c}})}function eE(e){return!e.ctrlKey&&!e.button}function e_(){return this.parentNode}function ek(e,t){return null==t?{x:e.x,y:e.y}:t}function eS(){return navigator.maxTouchPoints||"ontouchstart"in this}function eM(){var e,t,n,r,o=eE,i=e_,a=ek,s=eS,l={},u=E("start","drag","end"),c=0,d=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>d}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,d,f,p=u.copy(),g=ef(i||n,t);if(null!=(f=a.call(e,new eb("beforestart",{sourceEvent:n,target:h,identifier:o,active:c,x:g[0],y:g[1],dx:0,dy:0,dispatch:p}),r)))return s=f.x-g[0]||0,d=f.y-g[1]||0,function n(i,a,u){var m,y=g;switch(i){case"start":l[o]=n,m=c++;break;case"end":delete l[o],--c;case"drag":g=ef(u||a,t),m=c}p.call(i,e,new eb(i,{sourceEvent:a,subject:f,target:h,identifier:o,active:m,x:g[0]+s,y:g[1]+d,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=u.on.apply(u,arguments);return e===u?h:e},h.clickDistance=function(e){return arguments.length?(d=(e*=1)*e,h):Math.sqrt(d)},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 eC=function e(t,n,r){function o(e,o){var i,a,s=e[0],l=e[1],u=e[2],c=o[0],d=o[1],h=o[2],f=c-s,p=d-l,g=f*f+p*p;if(g<1e-12)a=Math.log(h/u)/t,i=function(e){return[s+e*f,l+e*p,u*Math.exp(t*e*a)]};else{var m=Math.sqrt(g),y=(h*h-u*u+r*g)/(2*u*n*m),v=(h*h-u*u-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,c=eN(x),d=u/(n*m)*(c*(((r=Math.exp(2*(r=t*i+x)))-1)/(r+1))-((o=Math.exp(o=x))-1/o)/2);return[s+d*f,l+d*p,u*c/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,ez=0,e$=0,eI=0,eL=0,eR="object"==typeof performance&&performance.now?performance:Date,eD="object"==typeof window&&window.requestAnimationFrame?window.requestAnimationFrame.bind(window):function(e){setTimeout(e,17)};function eB(){return eI||(eD(eT),eI=eR.now()+eL)}function eT(){eI=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(){eI=(e$=eR.now())+eL,eP=eA=0;try{eB(),++eP;for(var e,t=ej;t;)(e=eI-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)}(),eI=0}}function eX(){var e=eR.now(),t=e-e$;t>1e3&&(eL-=t,e$=e)}function eY(e){!eP&&(eA&&(eA=clearTimeout(eA)),e-eI>24?(e<1/0&&(eA=setTimeout(eF,e-eR.now()-eL)),ez&&(ez=clearInterval(ez))):(ez||(e$=eR.now(),ez=setInterval(eX,1e3)),eP=1,eD(eF)))}function eW(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?eB():+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 eq=E("start","end","cancel","interrupt"),eK=[];function eZ(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 u,c,d,h;if(1!==n.state)return s();for(u in o)if((h=o[u]).name===n.name){if(3===h.state)return eW(i);4===h.state?(h.state=6,h.timer.stop(),h.on.call("interrupt",e,e.__data__,h.index,h.group),delete o[u]):+u<t&&(h.state=6,h.timer.stop(),h.on.call("cancel",e,e.__data__,h.index,h.group),delete o[u])}if(eW(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(u=0,n.state=3,r=Array(d=n.tween.length),c=-1;u<d;++u)(h=n.tween[u].value.call(e,e.__data__,n.index,n.group))&&(r[++c]=h);r.length=c+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:eq,tween:eK,time:i.time,delay:i.delay,duration:i.duration,ease:i.ease,timer:null,state:0})}function eG(e,t){var n=eQ(e,t);if(n.state>0)throw Error("too late; already scheduled");return n}function eU(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}}function e0(e,t){return e*=1,t*=1,function(n){return e*(1-n)+t*n}}var e1=180/Math.PI,e2={translateX:0,translateY:0,rotate:0,skewX:0,scaleX:1,scaleY:1};function e5(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 e3(e,t,n,r){function o(e){return e.length?e.pop()+" ":""}return function(i,a){var s,l,u,c,d=[],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:e0(e,o)},{i:l-2,x:e0(r,i)})}else(o||i)&&a.push("translate("+o+t+i+n)}(i.translateX,i.translateY,a.translateX,a.translateY,d,h),s=i.rotate,l=a.rotate,s!==l?(s-l>180?l+=360:l-s>180&&(s+=360),h.push({i:d.push(o(d)+"rotate(",null,r)-2,x:e0(s,l)})):l&&d.push(o(d)+"rotate("+l+r),u=i.skewX,c=a.skewX,u!==c?h.push({i:d.push(o(d)+"skewX(",null,r)-2,x:e0(u,c)}):c&&d.push(o(d)+"skewX("+c+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:e0(e,n)},{i:s-2,x:e0(t,r)})}else(1!==n||1!==r)&&i.push(o(i)+"scale("+n+","+r+")")}(i.scaleX,i.scaleY,a.scaleX,a.scaleY,d,h),i=a=null,function(e){for(var t,n=-1,r=h.length;++n<r;)d[(t=h[n]).i]=t.x(e);return d.join("")}}}var e4=e3(function(e){let t=new("function"==typeof DOMMatrix?DOMMatrix:WebKitCSSMatrix)(e+"");return t.isIdentity?e2:e5(t.a,t.b,t.c,t.d,t.e,t.f)},"px, ","px)","deg)"),e6=e3(function(e){return null==e?e2:(u||(u=document.createElementNS("http://www.w3.org/2000/svg","g")),u.setAttribute("transform",e),e=u.transform.baseVal.consolidate())?e5((e=e.matrix).a,e.b,e.c,e.d,e.e,e.f):e2},", ",")",")");function e8(e,t,n){var r=e._id;return e.each(function(){var e=eU(this,r);(e.value||(e.value={}))[t]=n.apply(this,arguments)}),function(e){return eQ(e,r).value[t]}}function e9(e,t,n){e.prototype=t.prototype=n,n.constructor=e}function e7(e,t){var n=Object.create(e.prototype);for(var r in t)n[r]=t[r];return n}function te(){}var tt="\\s*([+-]?\\d+)\\s*",tn="\\s*([+-]?(?:\\d*\\.)?\\d+(?:[eE][+-]?\\d+)?)\\s*",tr="\\s*([+-]?(?:\\d*\\.)?\\d+(?:[eE][+-]?\\d+)?)%\\s*",to=/^#([0-9a-f]{3,8})$/,ti=RegExp(`^rgb\\(${tt},${tt},${tt}\\)$`),ta=RegExp(`^rgb\\(${tr},${tr},${tr}\\)$`),ts=RegExp(`^rgba\\(${tt},${tt},${tt},${tn}\\)$`),tl=RegExp(`^rgba\\(${tr},${tr},${tr},${tn}\\)$`),tu=RegExp(`^hsl\\(${tn},${tr},${tr}\\)$`),tc=RegExp(`^hsla\\(${tn},${tr},${tr},${tn}\\)$`),td={aliceblue:0xf0f8ff,antiquewhite:0xfaebd7,aqua:65535,aquamarine:8388564,azure:0xf0ffff,beige:0xf5f5dc,bisque:0xffe4c4,black:0,blanchedalmond:0xffebcd,blue:255,blueviolet:9055202,brown:0xa52a2a,burlywood:0xdeb887,cadetblue:6266528,chartreuse:8388352,chocolate:0xd2691e,coral:0xff7f50,cornflowerblue:6591981,cornsilk:0xfff8dc,crimson:0xdc143c,cyan:65535,darkblue:139,darkcyan:35723,darkgoldenrod:0xb8860b,darkgray:0xa9a9a9,darkgreen:25600,darkgrey:0xa9a9a9,darkkhaki:0xbdb76b,darkmagenta:9109643,darkolivegreen:5597999,darkorange:0xff8c00,darkorchid:0x9932cc,darkred:9109504,darksalmon:0xe9967a,darkseagreen:9419919,darkslateblue:4734347,darkslategray:3100495,darkslategrey:3100495,darkturquoise:52945,darkviolet:9699539,deeppink:0xff1493,deepskyblue:49151,dimgray:6908265,dimgrey:6908265,dodgerblue:2003199,firebrick:0xb22222,floralwhite:0xfffaf0,forestgreen:2263842,fuchsia:0xff00ff,gainsboro:0xdcdcdc,ghostwhite:0xf8f8ff,gold:0xffd700,goldenrod:0xdaa520,gray:8421504,green:32768,greenyellow:0xadff2f,grey:8421504,honeydew:0xf0fff0,hotpink:0xff69b4,indianred:0xcd5c5c,indigo:4915330,ivory:0xfffff0,khaki:0xf0e68c,lavender:0xe6e6fa,lavenderblush:0xfff0f5,lawngreen:8190976,lemonchiffon:0xfffacd,lightblue:0xadd8e6,lightcoral:0xf08080,lightcyan:0xe0ffff,lightgoldenrodyellow:0xfafad2,lightgray:0xd3d3d3,lightgreen:9498256,lightgrey:0xd3d3d3,lightpink:0xffb6c1,lightsalmon:0xffa07a,lightseagreen:2142890,lightskyblue:8900346,lightslategray:7833753,lightslategrey:7833753,lightsteelblue:0xb0c4de,lightyellow:0xffffe0,lime:65280,limegreen:3329330,linen:0xfaf0e6,magenta:0xff00ff,maroon:8388608,mediumaquamarine:6737322,mediumblue:205,mediumorchid:0xba55d3,mediumpurple:9662683,mediumseagreen:3978097,mediumslateblue:8087790,mediumspringgreen:64154,mediumturquoise:4772300,mediumvioletred:0xc71585,midnightblue:1644912,mintcream:0xf5fffa,mistyrose:0xffe4e1,moccasin:0xffe4b5,navajowhite:0xffdead,navy:128,oldlace:0xfdf5e6,olive:8421376,olivedrab:7048739,orange:0xffa500,orangered:0xff4500,orchid:0xda70d6,palegoldenrod:0xeee8aa,palegreen:0x98fb98,paleturquoise:0xafeeee,palevioletred:0xdb7093,papayawhip:0xffefd5,peachpuff:0xffdab9,peru:0xcd853f,pink:0xffc0cb,plum:0xdda0dd,powderblue:0xb0e0e6,purple:8388736,rebeccapurple:6697881,red:0xff0000,rosybrown:0xbc8f8f,royalblue:4286945,saddlebrown:9127187,salmon:0xfa8072,sandybrown:0xf4a460,seagreen:3050327,seashell:0xfff5ee,sienna:0xa0522d,silver:0xc0c0c0,skyblue:8900331,slateblue:6970061,slategray:7372944,slategrey:7372944,snow:0xfffafa,springgreen:65407,steelblue:4620980,tan:0xd2b48c,teal:32896,thistle:0xd8bfd8,tomato:0xff6347,turquoise:4251856,violet:0xee82ee,wheat:0xf5deb3,white:0xffffff,whitesmoke:0xf5f5f5,yellow:0xffff00,yellowgreen:0x9acd32};function th(){return this.rgb().formatHex()}function tf(){return this.rgb().formatRgb()}function tp(e){var t,n;return e=(e+"").trim().toLowerCase(),(t=to.exec(e))?(n=t[1].length,t=parseInt(t[1],16),6===n?tg(t):3===n?new tv(t>>8&15|t>>4&240,t>>4&15|240&t,(15&t)<<4|15&t,1):8===n?tm(t>>24&255,t>>16&255,t>>8&255,(255&t)/255):4===n?tm(t>>12&15|t>>8&240,t>>8&15|t>>4&240,t>>4&15|240&t,((15&t)<<4|15&t)/255):null):(t=ti.exec(e))?new tv(t[1],t[2],t[3],1):(t=ta.exec(e))?new tv(255*t[1]/100,255*t[2]/100,255*t[3]/100,1):(t=ts.exec(e))?tm(t[1],t[2],t[3],t[4]):(t=tl.exec(e))?tm(255*t[1]/100,255*t[2]/100,255*t[3]/100,t[4]):(t=tu.exec(e))?tk(t[1],t[2]/100,t[3]/100,1):(t=tc.exec(e))?tk(t[1],t[2]/100,t[3]/100,t[4]):td.hasOwnProperty(e)?tg(td[e]):"transparent"===e?new tv(NaN,NaN,NaN,0):null}function tg(e){return new tv(e>>16&255,e>>8&255,255&e,1)}function tm(e,t,n,r){return r<=0&&(e=t=n=NaN),new tv(e,t,n,r)}function ty(e,t,n,r){var o;return 1==arguments.length?((o=e)instanceof te||(o=tp(o)),o)?new tv((o=o.rgb()).r,o.g,o.b,o.opacity):new tv:new tv(e,t,n,null==r?1:r)}function tv(e,t,n,r){this.r=+e,this.g=+t,this.b=+n,this.opacity=+r}function tx(){return`#${t_(this.r)}${t_(this.g)}${t_(this.b)}`}function tw(){let e=tb(this.opacity);return`${1===e?"rgb(":"rgba("}${tE(this.r)}, ${tE(this.g)}, ${tE(this.b)}${1===e?")":`, ${e})`}`}function tb(e){return isNaN(e)?1:Math.max(0,Math.min(1,e))}function tE(e){return Math.max(0,Math.min(255,Math.round(e)||0))}function t_(e){return((e=tE(e))<16?"0":"")+e.toString(16)}function tk(e,t,n,r){return r<=0?e=t=n=NaN:n<=0||n>=1?e=t=NaN:t<=0&&(e=NaN),new tM(e,t,n,r)}function tS(e){if(e instanceof tM)return new tM(e.h,e.s,e.l,e.opacity);if(e instanceof te||(e=tp(e)),!e)return new tM;if(e instanceof tM)return e;var t=(e=e.rgb()).r/255,n=e.g/255,r=e.b/255,o=Math.min(t,n,r),i=Math.max(t,n,r),a=NaN,s=i-o,l=(i+o)/2;return s?(a=t===i?(n-r)/s+(n<r)*6:n===i?(r-t)/s+2:(t-n)/s+4,s/=l<.5?i+o:2-i-o,a*=60):s=l>0&&l<1?0:a,new tM(a,s,l,e.opacity)}function tM(e,t,n,r){this.h=+e,this.s=+t,this.l=+n,this.opacity=+r}function tN(e){return(e=(e||0)%360)<0?e+360:e}function tC(e){return Math.max(0,Math.min(1,e||0))}function tj(e,t,n){return(e<60?t+(n-t)*e/60:e<180?n:e<240?t+(n-t)*(240-e)/60:t)*255}function tO(e,t,n,r,o){var i=e*e,a=i*e;return((1-3*e+3*i-a)*t+(4-6*i+3*a)*n+(1+3*e+3*i-3*a)*r+a*o)/6}e9(te,tp,{copy(e){return Object.assign(new this.constructor,this,e)},displayable(){return this.rgb().displayable()},hex:th,formatHex:th,formatHex8:function(){return this.rgb().formatHex8()},formatHsl:function(){return tS(this).formatHsl()},formatRgb:tf,toString:tf}),e9(tv,ty,e7(te,{brighter(e){return e=null==e?1.4285714285714286:Math.pow(1.4285714285714286,e),new tv(this.r*e,this.g*e,this.b*e,this.opacity)},darker(e){return e=null==e?.7:Math.pow(.7,e),new tv(this.r*e,this.g*e,this.b*e,this.opacity)},rgb(){return this},clamp(){return new tv(tE(this.r),tE(this.g),tE(this.b),tb(this.opacity))},displayable(){return -.5<=this.r&&this.r<255.5&&-.5<=this.g&&this.g<255.5&&-.5<=this.b&&this.b<255.5&&0<=this.opacity&&this.opacity<=1},hex:tx,formatHex:tx,formatHex8:function(){return`#${t_(this.r)}${t_(this.g)}${t_(this.b)}${t_((isNaN(this.opacity)?1:this.opacity)*255)}`},formatRgb:tw,toString:tw})),e9(tM,function(e,t,n,r){return 1==arguments.length?tS(e):new tM(e,t,n,null==r?1:r)},e7(te,{brighter(e){return e=null==e?1.4285714285714286:Math.pow(1.4285714285714286,e),new tM(this.h,this.s,this.l*e,this.opacity)},darker(e){return e=null==e?.7:Math.pow(.7,e),new tM(this.h,this.s,this.l*e,this.opacity)},rgb(){var e=this.h%360+(this.h<0)*360,t=isNaN(e)||isNaN(this.s)?0:this.s,n=this.l,r=n+(n<.5?n:1-n)*t,o=2*n-r;return new tv(tj(e>=240?e-240:e+120,o,r),tj(e,o,r),tj(e<120?e+240:e-120,o,r),this.opacity)},clamp(){return new tM(tN(this.h),tC(this.s),tC(this.l),tb(this.opacity))},displayable(){return(0<=this.s&&this.s<=1||isNaN(this.s))&&0<=this.l&&this.l<=1&&0<=this.opacity&&this.opacity<=1},formatHsl(){let e=tb(this.opacity);return`${1===e?"hsl(":"hsla("}${tN(this.h)}, ${100*tC(this.s)}%, ${100*tC(this.l)}%${1===e?")":`, ${e})`}`}}));let tP=e=>()=>e;function tA(e,t){var n=t-e;return n?function(t){return e+t*n}:tP(isNaN(e)?t:e)}let tz=function e(t){var n,r=1==(n=+t)?tA:function(e,t){var r,o,i;return t-e?(r=e,o=t,r=Math.pow(r,i=n),o=Math.pow(o,i)-r,i=1/i,function(e){return Math.pow(r+e*o,i)}):tP(isNaN(e)?t:e)};function o(e,t){var n=r((e=ty(e)).r,(t=ty(t)).r),o=r(e.g,t.g),i=r(e.b,t.b),a=tA(e.opacity,t.opacity);return function(t){return e.r=n(t),e.g=o(t),e.b=i(t),e.opacity=a(t),e+""}}return o.gamma=e,o}(1);function t$(e){return function(t){var n,r,o=t.length,i=Array(o),a=Array(o),s=Array(o);for(n=0;n<o;++n)r=ty(t[n]),i[n]=r.r||0,a[n]=r.g||0,s[n]=r.b||0;return i=e(i),a=e(a),s=e(s),r.opacity=1,function(e){return r.r=i(e),r.g=a(e),r.b=s(e),r+""}}}t$(function(e){var t=e.length-1;return function(n){var r=n<=0?n=0:n>=1?(n=1,t-1):Math.floor(n*t),o=e[r],i=e[r+1],a=r>0?e[r-1]:2*o-i,s=r<t-1?e[r+2]:2*i-o;return tO((n-r/t)*t,a,o,i,s)}}),t$(function(e){var t=e.length;return function(n){var r=Math.floor(((n%=1)<0?++n:n)*t),o=e[(r+t-1)%t],i=e[r%t],a=e[(r+1)%t],s=e[(r+2)%t];return tO((n-r/t)*t,o,i,a,s)}});var tI=/[-+]?(?:\d+\.?\d*|\.?\d+)(?:[eE][-+]?\d+)?/g,tL=RegExp(tI.source,"g");function tR(e,t){var n,r,o,i,a,s=tI.lastIndex=tL.lastIndex=0,l=-1,u=[],c=[];for(e+="",t+="";(o=tI.exec(e))&&(i=tL.exec(t));)(a=i.index)>s&&(a=t.slice(s,a),u[l]?u[l]+=a:u[++l]=a),(o=o[0])===(i=i[0])?u[l]?u[l]+=i:u[++l]=i:(u[++l]=null,c.push({i:l,x:e0(o,i)})),s=tL.lastIndex;return s<t.length&&(a=t.slice(s),u[l]?u[l]+=a:u[++l]=a),u.length<2?c[0]?(n=c[0].x,function(e){return n(e)+""}):(r=t,function(){return r}):(t=c.length,function(e){for(var n,r=0;r<t;++r)u[(n=c[r]).i]=n.x(e);return u.join("")})}function tD(e,t){var n;return("number"==typeof t?e0:t instanceof tp?tz:(n=tp(t))?(t=n,tz):tR)(e,t)}var tB=ed.prototype.constructor;function tT(e){return function(){this.style.removeProperty(e)}}var tH=0;function tV(e,t,n,r){this._groups=e,this._parents=t,this._name=n,this._id=r}var tF=ed.prototype;tV.prototype=(function(e){return ed().transition(e)}).prototype={constructor:tV,select:function(e){var t=this._name,n=this._id;"function"!=typeof e&&(e=M(e));for(var r=this._groups,o=r.length,i=Array(o),a=0;a<o;++a)for(var s,l,u=r[a],c=u.length,d=i[a]=Array(c),h=0;h<c;++h)(s=u[h])&&(l=e.call(s,s.__data__,h,u))&&("__data__"in s&&(l.__data__=s.__data__),d[h]=l,eZ(d[h],t,n,h,d,eQ(s,n)));return new tV(i,this._parents,t,n)},selectAll:function(e){var t=this._name,n=this._id;"function"!=typeof e&&(e=C(e));for(var r=this._groups,o=r.length,i=[],a=[],s=0;s<o;++s)for(var l,u=r[s],c=u.length,d=0;d<c;++d)if(l=u[d]){for(var h,f=e.call(l,l.__data__,d,u),p=eQ(l,n),g=0,m=f.length;g<m;++g)(h=f[g])&&eZ(h,t,n,g,f,p);i.push(f),a.push(l)}return new tV(i,a,t,n)},selectChild:tF.selectChild,selectChildren:tF.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]=[],u=0;u<s;++u)(i=a[u])&&e.call(i,i.__data__,u,a)&&l.push(i);return new tV(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,u=t[s],c=n[s],d=u.length,h=a[s]=Array(d),f=0;f<d;++f)(l=u[f]||c[f])&&(h[f]=l);for(;s<r;++s)a[s]=t[s];return new tV(a,this._parents,this._name,this._id)},selection:function(){return new tB(this._groups,this._parents)},transition:function(){for(var e=this._name,t=this._id,n=++tH,r=this._groups,o=r.length,i=0;i<o;++i)for(var a,s=r[i],l=s.length,u=0;u<l;++u)if(a=s[u]){var c=eQ(a,t);eZ(a,e,n,u,s,{time:c.time+c.delay+c.duration,delay:0,duration:c.duration,ease:c.ease})}return new tV(r,this._parents,e,n)},call:tF.call,nodes:tF.nodes,node:tF.node,size:tF.size,empty:tF.empty,each:tF.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})?eG:eU,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:tD;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,e8(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,u,c,d,h,f,p,g,m,y,v,x,w,b,E,_,k="transform"==(e+="")?e4:tD;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,tT(e)):"function"==typeof t?this.styleTween(e,(s=e,l=e8(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===u&&n===c?d:(c=n,d=k(u=e,t))})).each((h=this._id,x="end."+(v="style."+(f=e)),function(){var e=eU(this,h),t=e.on,n=null==e.value[v]?y||(y=tT(f)):void 0;(t!==p||m!==n)&&(g=(p=t).copy()).on(x,m=n),e.on=g})):this.styleTween(e,(w=e,_=t+"",function(){var e=Y(this,w);return e===_?null:e===b?E:E=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=e8(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=eU(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=eU(this,e),a=i.tween;if(a!==r){o=(r=a).slice();for(var s={name:t,value:n},l=0,u=o.length;l<u;++l)if(o[l].name===t){o[l]=s;break}l===u&&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(){eG(this,e).delay=+t.apply(this,arguments)}}:function(e,t){return t*=1,function(){eG(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(){eU(this,e).duration=+t.apply(this,arguments)}}:function(e,t){return t*=1,function(){eU(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(){eU(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();eU(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=eU(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]:tF[Symbol.iterator]};var tX={time:null,delay:0,duration:250,ease:function(e){return((e*=2)<=1?e*e*e:(e-=2)*e*e+2)/2}};ed.prototype.interrupt=function(e){return this.each(function(){eJ(this,e)})},ed.prototype.transition=function(e){var t,n;e instanceof tV?(t=e._id,e=e._name):(t=++tH,(n=tX).time=eB(),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,u=0;u<l;++u)(a=s[u])&&eZ(a,e,t,u,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 tV(r,this._parents,e,t)};let tY=e=>()=>e;function tW(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 tq(e,t,n){this.k=e,this.x=t,this.y=n}tq.prototype={constructor:tq,scale:function(e){return 1===e?this:new tq(this.k*e,this.x,this.y)},translate:function(e,t){return 0===e&0===t?this:new tq(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 tK=new tq(1,0,0);function tZ(e){for(;!e.__zoom;)if(!(e=e.parentNode))return tK;return e.__zoom}function tG(e){e.stopImmediatePropagation()}function tU(e){e.preventDefault(),e.stopImmediatePropagation()}function tQ(e){return(!e.ctrlKey||"wheel"===e.type)&&!e.button}function tJ(){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 t0(){return this.__zoom||tK}function t1(e){return-e.deltaY*(1===e.deltaMode?.05:e.deltaMode?1:.002)*(e.ctrlKey?10:1)}function t2(){return navigator.maxTouchPoints||"ontouchstart"in this}function t5(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 t3(){var e,t,n,r=tQ,o=tJ,i=t5,a=t1,s=t2,l=[0,1/0],u=[[-1/0,-1/0],[1/0,1/0]],c=250,d=eC,h=E("start","zoom","end"),f=0,p=10;function g(e){e.property("__zoom",t0).on("wheel.zoom",_,{passive:!1}).on("mousedown.zoom",k).on("dblclick.zoom",S).filter(s).on("touchstart.zoom",M).on("touchmove.zoom",N).on("touchend.zoom touchcancel.zoom",C).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 tq(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 tq(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]),u=this.__zoom,c="function"==typeof t?t.apply(this,e):t,h=d(u.invert(s).concat(l/u.k),c.invert(s).concat(l/c.k));return function(e){if(1===e)e=c;else{var t=h(e),n=l/t[2];e=new tq(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,...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)))),c=ef(e);if(n.wheel)(n.mouse[0][0]!==c[0]||n.mouse[0][1]!==c[1])&&(n.mouse[1]=o.invert(n.mouse[0]=c)),clearTimeout(n.wheel);else{if(o.k===s)return;n.mouse=[c,o.invert(c)],eJ(this),n.start()}tU(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,u))}}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(tU(e),!a.moved){var t=e.clientX-c,n=e.clientY-d;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,u))},!0).on("mouseup.zoom",function(e){s.on("mousemove.zoom mouseup.zoom",null),ex(e.view,a.moved),tU(e),a.event(e).end()},!0),l=ef(e,o),c=e.clientX,d=e.clientY;ev(e.view),tG(e),a.mouse=[l,this.__zoom.invert(l)],eJ(this),a.start()}}function S(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),d=i(y(m(n,l),a,s),o.apply(this,t),u);tU(e),c>0?eh(this).transition().duration(c).call(x,d,a,e):eh(this).call(g.transform,d,a,e)}}function M(n,...o){if(r.apply(this,arguments)){var i,a,s,l,u=n.touches,c=u.length,d=w(this,o,n.changedTouches.length===c).event(n);for(tG(n),a=0;a<c;++a)l=[l=ef(s=u[a],this),this.__zoom.invert(l),s.identifier],d.touch0?d.touch1||d.touch0[2]===l[2]||(d.touch1=l,d.taps=0):(d.touch0=l,i=!0,d.taps=1+!!e);e&&(e=clearTimeout(e)),i&&(d.taps<2&&(t=l[0],e=setTimeout(function(){e=null},500)),eJ(this),d.start())}}function N(e,...t){if(this.__zooming){var n,r,o,a,s=w(this,t).event(e),l=e.changedTouches,c=l.length;for(tU(e),n=0;n<c;++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 d=s.touch0[0],h=s.touch0[1],f=s.touch1[0],p=s.touch1[1],g=(g=f[0]-d[0])*g+(g=f[1]-d[1])*g,v=(v=p[0]-h[0])*v+(v=p[1]-h[1])*v;r=m(r,Math.sqrt(g/v)),o=[(d[0]+f[0])/2,(d[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,u))}}function C(e,...r){if(this.__zooming){var o,i,a=w(this,r).event(e),s=e.changedTouches,l=s.length;for(tG(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 u=eh(this).on("dblclick.zoom");u&&u.apply(this,arguments)}}}return g.transform=function(e,t,n,r){var o=e.selection?e.selection():e;o.property("__zoom",t0),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,u)},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),u)},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(tK.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,u)},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 tW(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:tY(+e),g):a},g.filter=function(e){return arguments.length?(r="function"==typeof e?e:tY(!!e),g):r},g.touchable=function(e){return arguments.length?(s="function"==typeof e?e:tY(!!e),g):s},g.extent=function(e){return arguments.length?(o="function"==typeof e?e:tY([[+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?(u[0][0]=+e[0][0],u[1][0]=+e[1][0],u[0][1]=+e[0][1],u[1][1]=+e[1][1],g):[[u[0][0],u[0][1]],[u[1][0],u[1][1]]]},g.constrain=function(e){return arguments.length?(i=e,g):i},g.duration=function(e){return arguments.length?(c=+e,g):c},g.interpolate=function(e){return arguments.length?(d=e,g):d},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}function t4(e,t){var n,r,o=typeof t;return null==t||"boolean"===o?tP(t):("number"===o?e0:"string"===o?(r=tp(t))?(t=r,tz):tR:t instanceof tp?tz:t instanceof Date?function(e,t){var n=new Date;return e*=1,t*=1,function(r){return n.setTime(e*(1-r)+t*r),n}}:!ArrayBuffer.isView(n=t)||n instanceof DataView?Array.isArray(t)?function(e,t){var n,r=t?t.length:0,o=e?Math.min(r,e.length):0,i=Array(o),a=Array(r);for(n=0;n<o;++n)i[n]=t4(e[n],t[n]);for(;n<r;++n)a[n]=t[n];return function(e){for(n=0;n<o;++n)a[n]=i[n](e);return a}}:"function"!=typeof t.valueOf&&"function"!=typeof t.toString||isNaN(t)?function(e,t){var n,r={},o={};for(n in(null===e||"object"!=typeof e)&&(e={}),(null===t||"object"!=typeof t)&&(t={}),t)n in e?r[n]=t4(e[n],t[n]):o[n]=t[n];return function(e){for(n in r)o[n]=r[n](e);return o}}:e0:function(e,t){t||(t=[]);var n,r=e?Math.min(t.length,e.length):0,o=t.slice();return function(i){for(n=0;n<r;++n)o[n]=e[n]*(1-i)+t[n]*i;return o}})(e,t)}tZ.prototype=tq.prototype;let t6=[[-1/0,-1/0],[1/0,1/0]],t8=["Enter"," ","Escape"],t9={"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=c||(c={})).Strict="strict",t.Loose="loose",(n=d||(d={})).Free="free",n.Vertical="vertical",n.Horizontal="horizontal",(r=h||(h={})).Partial="partial",r.Full="full";let t7={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 ne={[g.Left]:g.Right,[g.Right]:g.Left,[g.Top]:g.Bottom,[g.Bottom]:g.Top};function nt(e){return null===e?null:e?"valid":"invalid"}let nn=e=>"id"in e&&"source"in e&&"target"in e,nr=e=>"id"in e&&"internals"in e&&!("source"in e)&&!("target"in e),no=(e,t=[0,0])=>{let{width:n,height:r}=nA(e),o=e.origin??t,i=n*o[0],a=r*o[1];return{x:e.position.x-i,y:e.position.y-a}},ni=(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=ng(n,nx(e)),r=!0)}),r?ny(n):{x:0,y:0,width:0,height:0}},na=(e,t,[n,r,o]=[0,0,1],i=!1,a=!1)=>{let s={...nM(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,u=e.height??t.height??t.initialHeight??null,c=nb(s,nv(t)),d=(o??0)*(u??0),h=i&&c>0;(!t.internals.handleBounds||h||c>=d||t.dragging)&&l.push(t)}return l};async function ns({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 u=nj(ni((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(u,{duration:a?.duration,ease:a?.ease,interpolate:a?.interpolate}),Promise.resolve(!0)}function nl({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:u}=s?s.internals.positionAbsolute:{x:0,y:0},c=a.origin??r,d=a.extent||o;if("parent"!==a.extent||a.expandParent)s&&nP(a.extent)&&(d=[[a.extent[0][0]+l,a.extent[0][1]+u],[a.extent[1][0]+l,a.extent[1][1]+u]]);else if(s){let e=s.measured.width,t=s.measured.height;e&&t&&(d=[[l,u],[l+e,u+t]])}else i?.("005","Only child nodes can use a parent extent.");let h=nP(d)?nd(t,d,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)*c[0],y:h.y-u+(a.measured.height??0)*c[1]},positionAbsolute:h}}async function nu({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)),u=r.filter(e=>!1!==e.deletable),c=(i=new Set,s.forEach(e=>{i.add(e.id)}),u.filter(e=>i.has(e.source)||i.has(e.target)));for(let e of u)l.has(e.id)&&!c.find(t=>t.id===e.id)&&c.push(e);if(!o)return{edges:c,nodes:s};let d=await o({nodes:s,edges:c});return"boolean"==typeof d?d?{edges:c,nodes:s}:{edges:[],nodes:[]}:d}let nc=(e,t=0,n=1)=>Math.min(Math.max(e,t),n),nd=(e={x:0,y:0},t,n)=>({x:nc(e.x,t[0][0],t[1][0]-(n?.width??0)),y:nc(e.y,t[0][1],t[1][1]-(n?.height??0))});function nh(e,t,n){let{width:r,height:o}=nA(n),{x:i,y:a}=n.internals.positionAbsolute;return nd(e,[[i,a],[i+r,a+o]],t)}let nf=(e,t,n)=>e<t?nc(Math.abs(e-t),1,t)/t:e>n?-nc(Math.abs(e-n),1,t)/t:0,np=(e,t,n=15,r=40)=>[nf(e.x,r,t.width-r)*n,nf(e.y,r,t.height-r)*n],ng=(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)}),nm=({x:e,y:t,width:n,height:r})=>({x:e,y:t,x2:e+n,y2:t+r}),ny=({x:e,y:t,x2:n,y2:r})=>({x:e,y:t,width:n-e,height:r-t}),nv=(e,t=[0,0])=>{let{x:n,y:r}=nr(e)?e.internals.positionAbsolute:no(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}},nx=(e,t=[0,0])=>{let{x:n,y:r}=nr(e)?e.internals.positionAbsolute:no(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)}},nw=(e,t)=>ny(ng(nm(e),nm(t))),nb=(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))),nE=e=>n_(e.width)&&n_(e.height)&&n_(e.x)&&n_(e.y),n_=e=>!isNaN(e)&&isFinite(e),nk=(e,t)=>{},nS=(e,t=[1,1])=>({x:t[0]*Math.round(e.x/t[0]),y:t[1]*Math.round(e.y/t[1])}),nM=({x:e,y:t},[n,r,o],i=!1,a=[1,1])=>{let s={x:(e-n)/o,y:(t-r)/o};return i?nS(s,a):s},nN=({x:e,y:t},[n,r,o])=>({x:e*o+n,y:t*o+r});function nC(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 nj=(e,t,n,r,o,i)=>{let a=function(e,t,n){if("string"==typeof e||"number"==typeof e){let r=nC(e,n),o=nC(e,t);return{top:r,right:o,bottom:r,left:o,x:2*o,y:2*r}}if("object"==typeof e){let r=nC(e.top??e.y??0,n),o=nC(e.bottom??e.y??0,n),i=nC(e.left??e.x??0,t),a=nC(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=nc(Math.min((t-a.x)/e.width,(n-a.y)/e.height),r,o),l=e.x+e.width/2,u=e.y+e.height/2,c=t/2-l*s,d=n/2-u*s,h=function(e,t,n,r,o,i){let{x:a,y:s}=nN(e,[t,n,r]),{x:l,y:u}=nN({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-u)}}(e,c,d,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:c-f.left+f.right,y:d-f.top+f.bottom,zoom:s}},nO=()=>"u">typeof navigator&&navigator?.userAgent?.indexOf("Mac")>=0;function nP(e){return null!=e&&"parent"!==e}function nA(e){return{width:e.measured?.width??e.width??e.initialWidth??0,height:e.measured?.height??e.height??e.initialHeight??0}}function nz(e){return(e.measured?.width??e.width??e.initialWidth)!==void 0&&(e.measured?.height??e.height??e.initialHeight)!==void 0}function n$(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 nI(e,t){if(e.size!==t.size)return!1;for(let n of e)if(!t.has(n))return!1;return!0}function nL(e,{snapGrid:t=[0,0],snapToGrid:n=!1,transform:r,containerBounds:o}){let{x:i,y:a}=nH(e),s=nM({x:i-(o?.left??0),y:a-(o?.top??0)},r),{x:l,y:u}=n?nS(s,t):s;return{xSnapped:l,ySnapped:u,...s}}let nR=e=>({width:e.offsetWidth,height:e.offsetHeight}),nD=e=>e?.getRootNode?.()||window?.document,nB=["INPUT","SELECT","TEXTAREA"];function nT(e){let t=e.composedPath?.()?.[0]||e.target;return t?.nodeType===1&&(nB.includes(t.nodeName)||t.hasAttribute("contenteditable")||!!t.closest(".nokey"))}let nH=(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)}},nV=(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,...nR(t)}}):null};function nF({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,u=.125*t+.375*i+.375*s+.125*r,c=Math.abs(l-e),d=Math.abs(u-t);return[l,u,c,d]}function nX(e,t){return e>=0?.5*e:25*t*Math.sqrt(-e)}function nY({pos:e,x1:t,y1:n,x2:r,y2:o,c:i}){switch(e){case g.Left:return[t-nX(t-r,i),n];case g.Right:return[t+nX(r-t,i),n];case g.Top:return[t,n-nX(n-o,i)];case g.Bottom:return[t,n+nX(o-n,i)]}}function nW({sourceX:e,sourceY:t,sourcePosition:n=g.Bottom,targetX:r,targetY:o,targetPosition:i=g.Top,curvature:a=.25}){let[s,l]=nY({pos:n,x1:e,y1:t,x2:r,y2:o,c:a}),[u,c]=nY({pos:i,x1:r,y1:o,x2:e,y2:t,c:a}),[d,h,f,p]=nF({sourceX:e,sourceY:t,targetX:r,targetY:o,sourceControlX:s,sourceControlY:l,targetControlX:u,targetControlY:c});return[`M${e},${t} C${s},${l} ${u},${c} ${r},${o}`,d,h,f,p]}function nq({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 nK=({source:e,sourceHandle:t,target:n,targetHandle:r})=>`xy-edge__${e}${t||""}-${n}${r||""}`;function nZ({sourceX:e,sourceY:t,targetX:n,targetY:r}){let[o,i,a,s]=nq({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}},nU=({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},nQ=(e,t)=>Math.sqrt(Math.pow(t.x-e.x,2)+Math.pow(t.y-e.y,2));function nJ({sourceX:e,sourceY:t,sourcePosition:n=g.Bottom,targetX:r,targetY:o,targetPosition:i=g.Top,borderRadius:a=5,centerX:s,centerY:l,offset:u=20,stepPosition:c=.5}){let[d,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,u=nG[t],c=nG[r],d={x:e.x+u.x*i,y:e.y+u.y*i},h={x:n.x+c.x*i,y:n.y+c.y*i},f=nU({source:d,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]=nq({sourceX:e.x,sourceY:e.y,targetX:n.x,targetY:n.y});if(u[p]*c[p]==-1){"x"===p?(s=o.x??d.x+(h.x-d.x)*a,l=o.y??(d.y+h.y)/2):(s=o.x??(d.x+h.x)/2,l=o.y??d.y+(h.y-d.y)*a);let e=[{x:s,y:d.y},{x:s,y:h.y}],t=[{x:d.x,y:l},{x:h.x,y:l}];y=u[p]===m?"x"===p?e:t:"x"===p?t:e}else{let o=[{x:d.x,y:h.y}],a=[{x:h.x,y:d.y}];if(y="x"===p?u.x===m?a:o:u.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);u[p]===m?v[p]=(d[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=u[p]===c[e],n=d[e]>h[e],r=d[e]<h[e];(1===u[p]&&(!t&&n||t&&r)||1!==u[p]&&(!t&&r||t&&n))&&(y="x"===p?o:a)}let f={x:d.x+v.x,y:d.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)}return[[e,{x:d.x+v.x,y:d.y+v.y},...y,{x:h.x+x.x,y:h.y+x.y},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:u,stepPosition:c});return[d.reduce((e,t,n)=>e+(n>0&&n<d.length-1?function(e,t,n,r){let o=Math.min(nQ(e,t)/2,nQ(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}`}(d[n-1],t,d[n+1],a):`${0===n?"M":"L"}${t.x} ${t.y}`),""),h,f,p,m]}function n0(e){return e&&!!(e.internals.handleBounds||e.handles?.length)&&!!(e.measured.width||e.width||e.initialWidth)}function n1(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 n2(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??nA(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 n5(e,t){return e&&(t?e.find(e=>e.id===t):e[0])||null}function n3(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 n4={nodeOrigin:[0,0],nodeExtent:t6,elevateNodesOnSelect:!0,zIndexMode:"basic",defaults:{}},n6={...n4,checkEquality:!0};function n8(e,t){let n={...e};for(let e in t)void 0!==t[e]&&(n[e]=t[e]);return n}function n9(e){return"manual"===e}function n7(e,t,n,r={}){let o=n8(n6,r),i={i:0},a=new Map(t),s=o?.elevateNodesOnSelect&&!n9(o.zIndexMode)?1e3:0,l=e.length>0;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=nd(no(u,o.nodeOrigin),nP(u.extent)?u.extent:o.nodeExtent,nA(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:rt(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&&re(e,t,n,r,i)}return l}function re(e,t,n,r,o){let{elevateNodesOnSelect:i,nodeOrigin:a,nodeExtent:s,zIndexMode:l}=n8(n4,r),u=e.parentId,c=t.get(u);if(!c)return void console.warn(`Parent node ${u} 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&&!c.parentId&&void 0===c.internals.rootParentIndex&&"auto"===l&&(c.internals.rootParentIndex=++o.i,c.internals.z=c.internals.z+10*o.i),o&&void 0!==c.internals.rootParentIndex&&(o.i=c.internals.rootParentIndex);let{x:d,y:h,z:f}=function(e,t,n,r,o,i){let{x:a,y:s}=t.internals.positionAbsolute,l=nA(e),u=no(e,n),c=nP(e.extent)?nd(u,e.extent,l):u,d=nd({x:a+c.x,y:s+c.y},r,l);"parent"===e.extent&&(d=nh(d,l,t));let h=rt(e,o,i),f=t.internals.z??0;return{x:d.x,y:d.y,z:f>=h?f+1:h}}(e,c,a,s,i&&!n9(l)?1e3:0,l),{positionAbsolute:p}=e.internals,g=d!==p.x||h!==p.y;(g||f!==e.internals.z)&&t.set(e.id,{...e,internals:{...e.internals,positionAbsolute:g?{x:d,y:h}:p,z:f}})}function rt(e,t,n){let r=n_(e.zIndex)?e.zIndex:0;return n9(n)?r:r+(e.selected?t:0)}function rn(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=nw(i.get(n.parentId)?.expandedRect??nv(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=nA(i),u=i.origin??r,c=t.x<s.x?Math.round(Math.abs(s.x-t.x)):0,d=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)*u[0],g=(f-l.height)*u[1];(c>0||d>0||p||g)&&(o.push({id:a,type:"position",position:{x:i.position.x-c+p,y:i.position.y-d+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+c,y:t.position.y+d}})})),(l.width<t.width||l.height<t.height||c||d)&&o.push({id:a,type:"dimensions",setAttributes:!0,dimensions:{width:h+(c?u[0]*c-p:0),height:f+(d?u[1]*d-g:0)}})}),o}async function rr({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 ro(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 ri(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}`;ro("source",s,`${o}-${a}--${n}-${i}`,e,n,i),ro("target",s,l,e,o,a),t.set(r.id,r)}}function ra(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 rs({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 rl(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,...n2(a,l,l.position,!0)}:l}function ru(e,t){return e?e:t?.classList.contains("target")?"target":t?.classList.contains("source")?"source":null}let rc=()=>!0;function rd(e,{handle:t,connectionMode:n,fromNodeId:r,fromHandleId:o,fromType:i,doc:a,lib:s,flowId:l,isValidConnection:u=rc,nodeLookup:d}){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}=nH(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=ru(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===c.Strict?h&&"source"===e||!h&&"target"===e:t!==r||i!==o)&&u(l),v.toHandle=rl(t,e,i,d,n,!0)}return v}let rh=function(e,{connectionMode:t,connectionRadius:n,handleId:r,nodeId:o,edgeUpdaterType:i,isTarget:a,domNode:s,nodeLookup:l,lib:u,autoPanOnConnect:c,flowId:d,panBy:h,cancelConnection:f,onConnectStart:p,onConnect:m,onConnectEnd:y,isValidConnection:v=rc,onReconnectEnd:x,updateConnection:w,getTransform:b,getFromHandle:E,autoPanSpeed:_,dragThreshold:k=1,handleDomNode:S}){let M,N=nD(e.target),C=0,{x:j,y:O}=nH(e),P=ru(i,S),A=s?.getBoundingClientRect(),z=!1;if(!A||!P)return;let $=rl(o,P,r,l,t);if(!$)return;let I=nH(e,A),L=!1,R=null,D=!1,B=null,T={...$,nodeId:o,type:P,position:$.position},H=l.get(o),V={inProgress:!0,isValid:null,from:n2(H,T,g.Left,!0),fromHandle:T,fromPosition:T.position,fromNode:H,to:I,toHandle:null,toPosition:ne[T.position],toNode:null,pointer:I};function F(){z=!0,w(V),p?.(e,{nodeId:o,handleId:r,handleType:P})}function X(e){var i,s;let f;if(!z){let{x:t,y:n}=nH(e),r=t-j,o=n-O;if(!(r*r+o*o>k*k))return;F()}if(!E()||!T)return void Y(e);let p=b();M=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())nb(o,nv(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}=n2(a,n,n.position,!0),u=Math.sqrt(Math.pow(s-e.x,2)+Math.pow(l-e.y,2));u>t||(u<i?(o=[{...n,x:s,y:l}],i=u):u===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]}(nM(I=nH(e,A),p,!1,[1,1]),n,l,T),L||(!function e(){if(!c||!A)return;let[t,n]=np(I,A,_);h({x:t,y:n}),C=requestAnimationFrame(e)}(),L=!0);let m=rd(e,{handle:M,connectionMode:t,fromNodeId:o,fromHandleId:r,fromType:a?"target":"source",isValidConnection:v,doc:N,lib:u,flowId:d,nodeLookup:l});B=m.handleDomNode,R=m.connection,i=!!M,s=m.isValid,f=null,s?f=!0:i&&!s&&(f=!1),D=f;let y=l.get(o),x=y?n2(y,T,g.Left,!0):V.from,S={...V,from:x,isValid:D,to:m.toHandle&&D?nN({x:m.toHandle.x,y:m.toHandle.y},p):I,toHandle:m.toHandle,toPosition:D&&m.toHandle?m.toHandle.position:ne[T.position],toNode:m.toHandle?l.get(m.toHandle.nodeId):null,pointer:I};w(S),V=S}function Y(e){if(!("touches"in e)||!(e.touches.length>0)){if(z){(M||B)&&R&&D&&m?.(R);let{inProgress:t,...n}=V,r={...n,toPosition:V.toHandle?V.toPosition:null};y?.(e,r),i&&x?.(e,r)}f(),cancelAnimationFrame(C),L=!1,D=!1,R=null,B=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)},rf=e=>({x:e.x,y:e.y,zoom:e.k}),rp=({x:e,y:t,zoom:n})=>tK.translate(e,t).scale(n),rg=(e,t)=>e.target.closest(`.${t}`),rm=(e,t)=>2===t&&Array.isArray(e)&&e.includes(2),ry=e=>((e*=2)<=1?e*e*e:(e-=2)*e*e+2)/2,rv=(e,t=0,n=ry,r=()=>{})=>{let o="number"==typeof t&&t>0;return o||r(),o?e.transition().duration(t).ease(n).on("end",r):e},rx=e=>{let t=e.ctrlKey&&nO()?10:1;return-e.deltaY*(1===e.deltaMode?.05:e.deltaMode?1:.002)*t};function rw(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 rb(e,t){return Math.max(0,t-e)}function rE(e,t){return Math.max(0,e-t)}function r_(e,t,n){return Math.max(0,t-e,e-n)}(s=m||(m={})).Line="line",s.Handle="handle";let rk={width:0,height:0,x:0,y:0},rS={...rk,pointerX:0,pointerY:0,aspectRatio:1};var rM=e.i(30224);let rN={get url(){return`file://${e.P("node_modules/zustand/esm/vanilla.mjs")}`}},rC=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:()=>{(rN.env?rN.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:rj}=x.default,{useSyncExternalStoreWithSelector:rO}=rM.default,rP=e=>e;function rA(e,t=rP,n){let r=rO(e.subscribe,e.getState,e.getServerState||e.getInitialState,t,n);return rj(r),r}let rz=(e,t)=>{let n=e?rC(e):rC,r=(e,r=t)=>rA(n,e,r);return Object.assign(r,n),r};function r$(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}e.i(74080);let rI=(0,x.createContext)(null),rL=rI.Provider,rR="[React Flow]: Seems like you have not used zustand provider as an ancestor. Help: https://reactflow.dev/error#001";function rD(e,t){let n=(0,x.useContext)(rI);if(null===n)throw Error(rR);return rA(n,e,t)}function rB(){let e=(0,x.useContext)(rI);if(null===e)throw Error(rR);return(0,x.useMemo)(()=>({getState:e.getState,setState:e.setState,subscribe:e.subscribe}),[e])}let rT={display:"none"},rH={position:"absolute",width:1,height:1,margin:-1,border:0,padding:0,overflow:"hidden",clip:"rect(0px, 0px, 0px, 0px)",clipPath:"inset(100%)"},rV="react-flow__node-desc",rF="react-flow__edge-desc",rX=e=>e.ariaLiveMessage,rY=e=>e.ariaLabelConfig;function rW({rfId:e}){let t=rD(rX);return(0,v.jsx)("div",{id:`react-flow__aria-live-${e}`,"aria-live":"assertive","aria-atomic":"true",style:rH,children:t})}function rq({rfId:e,disableKeyboardA11y:t}){let n=rD(rY);return(0,v.jsxs)(v.Fragment,{children:[(0,v.jsx)("div",{id:`${rV}-${e}`,style:rT,children:t?n["node.a11yDescription.default"]:n["node.a11yDescription.keyboardDisabled"]}),(0,v.jsx)("div",{id:`${rF}-${e}`,style:rT,children:n["edge.a11yDescription.default"]}),!t&&(0,v.jsx)(rW,{rfId:e})]})}let rK=(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 rZ({proOptions:e,position:t="bottom-right"}){return e?.hideAttribution?null:(0,v.jsx)(rK,{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"})})}rK.displayName="Panel";let rG=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}},rU=e=>e.id;function rQ(e,t){return r$(e.selectedNodes.map(rU),t.selectedNodes.map(rU))&&r$(e.selectedEdges.map(rU),t.selectedEdges.map(rU))}function rJ({onSelectionChange:e}){let t=rB(),{selectedNodes:n,selectedEdges:r}=rD(rG,rQ);return(0,x.useEffect)(()=>{let o={nodes:n,edges:r};e?.(o),t.getState().onSelectionChangeHandlers.forEach(e=>e(o))},[n,r,e]),null}let r0=e=>!!e.onSelectionChangeHandlers;function r1({onSelectionChange:e}){let t=rD(r0);return e||t?(0,v.jsx)(rJ,{onSelectionChange:e}):null}let r2=[0,0],r5={x:0,y:0,zoom:1},r3=["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"],r4=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}),r6={translateExtent:t6,nodeOrigin:r2,minZoom:.5,maxZoom:2,elementsSelectable:!0,noPanClassName:"nopan",rfId:"1"};function r8(e){let{setNodes:t,setEdges:n,setMinZoom:r,setMaxZoom:o,setTranslateExtent:i,setNodeExtent:a,reset:s,setDefaultNodesAndEdges:l}=rD(r4,r$),u=rB();(0,x.useEffect)(()=>(l(e.defaultNodes,e.defaultEdges),()=>{c.current=r6,s()}),[]);let c=(0,x.useRef)(r6);return(0,x.useEffect)(()=>{for(let s of r3){let l=e[s];if(l!==c.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)u.setState({ariaLabelConfig:{...t9,...l||{}}});else"fitView"===s?u.setState({fitViewQueued:l}):"fitViewOptions"===s?u.setState({fitViewOptions:l}):u.setState({[s]:l})}c.current=e},r3.map(t=>e[t])),null}function r9(){return"u"<typeof window||!window.matchMedia?null:window.matchMedia("(prefers-color-scheme: dark)")}let r7="u">typeof document?document:null;function oe(e=null,t={target:r7,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??r7,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)&&nT(e))return!1;let n=on(e.code,s);if(i.current.add(e[n]),ot(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)}},u=e=>{let t=on(e.code,s);ot(a,i.current,!0)?(r(!1),i.current.clear()):i.current.delete(e[t]),"Meta"===e.key&&i.current.clear(),o.current=!1},c=()=>{i.current.clear(),r(!1)};return n?.addEventListener("keydown",e),n?.addEventListener("keyup",u),window.addEventListener("blur",c),window.addEventListener("contextmenu",c),()=>{n?.removeEventListener("keydown",e),n?.removeEventListener("keyup",u),window.removeEventListener("blur",c),window.removeEventListener("contextmenu",c)}}},[e,r]),n}function ot(e,t,n){return e.filter(e=>n||e.length===t.size).some(e=>e.every(e=>t.has(e)))}function on(e,t){return t.includes(e)?"code":"key"}function or(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 oo(e,t){return{id:e,type:"select",selected:t}}function oi(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(oo(i.id,e)))}return r}function oa({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 os(e){return{id:e.id,type:"remove"}}let ol=e=>"id"in e&&"position"in e&&!("source"in e)&&!("target"in e);function ou(e){return(0,x.forwardRef)(e)}let oc="u">typeof window?x.useLayoutEffect:x.useEffect;function od(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 oc(()=>{let t=r.get();t.length&&(e(t),r.reset())},[t]),r}let oh=(0,x.createContext)(null);function of({children:e}){let t=rB(),n=od((0,x.useCallback)(e=>{let{nodes:n=[],setNodes:r,hasDefaultNodes:o,onNodesChange:i,nodeLookup:a,fitViewQueued:s,onNodesChangeMiddlewareMap:l}=t.getState(),u=n;for(let t of e)u="function"==typeof t?t(u):t;let c=oa({items:u,lookup:a});for(let e of l.values())c=e(c);o&&r(u),c.length>0?i?.(c):s&&window.requestAnimationFrame(()=>{let{fitViewQueued:e,nodes:n,setNodes:r}=t.getState();e&&r(n)})},[])),r=od((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(oa({items:s,lookup:a}))},[])),o=(0,x.useMemo)(()=>({nodeQueue:n,edgeQueue:r}),[]);return(0,v.jsx)(oh.Provider,{value:o,children:e})}let op=e=>!!e.panZoom;function og(){let e,t=(e=rB(),(0,x.useMemo)(()=>({zoomIn:t=>{let{panZoom:n}=e.getState();return n?n.scaleBy(1.2,{duration:t?.duration}):Promise.resolve(!1)},zoomOut:t=>{let{panZoom:n}=e.getState();return n?n.scaleBy(1/1.2,{duration:t?.duration}):Promise.resolve(!1)},zoomTo:(t,n)=>{let{panZoom:r}=e.getState();return r?r.scaleTo(t,{duration:n?.duration}):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=nj(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(),u={x:t.x-s,y:t.y-l},c=n.snapGrid??o;return nM(u,r,n.snapToGrid??i,c)},flowToScreenPosition:t=>{let{transform:n,domNode:r}=e.getState();if(!r)return t;let{x:o,y:i}=r.getBoundingClientRect(),a=nN(t,n);return{x:a.x+o,y:a.y+i}}}),[])),n=rB(),r=function(){let e=(0,x.useContext)(oh);if(!e)throw Error("useBatchContext must be used within a BatchProvider");return e}(),o=rD(op),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=ol(e)?e:t.get(e.id),i=o.parentId?n$(o.position,o.measured,o.parentId,t,r):o.position;return nv({...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&&ol(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&&nn(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:u,onBeforeDelete:c}=n.getState(),{nodes:d,edges:h}=await nu({nodesToRemove:e,edgesToRemove:t,nodes:r,edges:o,onBeforeDelete:c}),f=h.length>0,p=d.length>0;if(f){let e=h.map(os);a?.(h),l(e)}if(p){let e=d.map(os);i?.(d),s(e)}return(p||f)&&u?.({nodes:d,edges:h}),{deletedNodes:d,deletedEdges:h}},getIntersectingNodes:(e,t=!0,r)=>{let o=nE(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=nv(s?r:i),u=nb(l,a);return t&&u>0||u>=l.width*l.height||u>=a.width*a.height}):[]},isNodeIntersecting:(e,t,n=!0)=>{let r=nE(e)?e:i(e);if(!r)return!1;let o=nb(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}:ny(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):nr(n)?n:t.nodeLookup.get(n.id)),ng(e,o?nx(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 om=e=>e.selected,oy="u">typeof window?window:void 0,ov={position:"absolute",width:"100%",height:"100%",top:0,left:0},ox=e=>({userSelectionActive:e.userSelectionActive,lib:e.lib,connectionInProgress:e.connection.inProgress});function ow({onPaneContextMenu:e,zoomOnScroll:t=!0,zoomOnPinch:n=!0,panOnScroll:r=!1,panOnScrollSpeed:o=.5,panOnScrollMode:i=d.Free,zoomOnDoubleClick:a=!0,panOnDrag:s=!0,defaultViewport:l,translateExtent:u,minZoom:c,maxZoom:h,zoomActivationKeyCode:f,preventScrolling:p=!0,children:g,noWheelClassName:m,noPanClassName:y,onViewportChange:w,isControlledViewport:b,paneClickDistance:E,selectionOnDrag:_}){let k,S=rB(),M=(0,x.useRef)(null),{userSelectionActive:N,lib:C,connectionInProgress:j}=rD(ox,r$),O=oe(f),P=(0,x.useRef)();k=rB(),(0,x.useEffect)(()=>{let e=()=>{if(!M.current||!(M.current.checkVisibility?.()??!0))return!1;let e=nR(M.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(M.current){e(),window.addEventListener("resize",e);let t=new ResizeObserver(()=>e());return t.observe(M.current),()=>{window.removeEventListener("resize",e),t&&M.current&&t.unobserve(M.current)}}},[]);let A=(0,x.useCallback)(e=>{w?.({x:e[0],y:e[1],zoom:e[2]}),b||S.setState({transform:e})},[w,b]);return(0,x.useEffect)(()=>{if(M.current){P.current=function({domNode:e,minZoom:t,maxZoom:n,translateExtent:r,viewport:o,onPanZoom:i,onPanZoomStart:a,onPanZoomEnd:s,onDraggingChange:l}){let u={isZoomingOrPanning:!1,usedRightMouseButton:!1,prevViewport:{x:0,y:0,zoom:0},mouseButton:0,timerId:void 0,panScrollTimeout:void 0,isPanScrolling:!1},c=e.getBoundingClientRect(),h=t3().scaleExtent([t,n]).translateExtent(r),f=eh(e).call(h);v({x:o.x,y:o.y,zoom:nc(o.zoom,t,n)},[[0,0],[c.width,c.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"?t4:eC).transform(rv(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=rp(e),o=h?.constrain()(r,t,n);return o&&await m(o),new Promise(e=>e(o))}return h.wheelDelta(rx),{update:function({noWheelClassName:e,noPanClassName:t,onPaneContextMenu:n,userSelectionActive:r,panOnScroll:o,panOnDrag:c,panOnScrollMode:m,panOnScrollSpeed:v,preventScrolling:x,zoomOnPinch:w,zoomOnScroll:b,zoomOnDoubleClick:E,zoomActivationKeyPressed:_,lib:k,onTransformChange:S,connectionInProgress:M,paneClickDistance:N,selectionOnDrag:C}){r&&!u.isZoomingOrPanning&&y();let j=o&&!_&&!r;h.clickDistance(C?1/0:!n_(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:u}){return c=>{if(rg(c,t))return c.ctrlKey&&c.preventDefault(),!1;c.preventDefault(),c.stopImmediatePropagation();let h=n.property("__zoom").k||1;if(c.ctrlKey&&a){let e=ef(c),t=h*Math.pow(2,rx(c));r.scaleTo(n,t,e,c);return}let f=1===c.deltaMode?20:1,p=o===d.Vertical?0:c.deltaX*f,g=o===d.Horizontal?0:c.deltaY*f;!nO()&&c.shiftKey&&o!==d.Vertical&&(p=c.deltaY*f,g=0),r.translateBy(n,-(p/h)*i,-(g/h)*i,{internal:!0});let m=rf(n.property("__zoom"));clearTimeout(e.panScrollTimeout),e.isPanScrolling?(l?.(c,m),e.panScrollTimeout=setTimeout(()=>{u?.(c,m),e.isPanScrolling=!1},150)):(e.isPanScrolling=!0,s?.(c,m))}}({zoomPanValues:u,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=rg(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=rf(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:u,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&&rm(t,e.mouseButton??0)),i.sourceEvent?.sync||r([i.transform.x,i.transform.y,i.transform.k]),o&&!i.sourceEvent?.internal&&o?.(i.sourceEvent,rf(i.transform))}}({zoomPanValues:u,panOnDrag:c,onPaneContextMenu:!!n,onPanZoom:i,onTransformChange:S});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&&rm(t,e.mouseButton??0)&&!e.usedRightMouseButton&&a.sourceEvent&&i(a.sourceEvent),e.usedRightMouseButton=!1,r(!1),o)){let t=rf(a.transform);e.prevViewport=t,clearTimeout(e.timerId),e.timerId=setTimeout(()=>{o?.(a.sourceEvent,t)},150*!!n)}}}({zoomPanValues:u,panOnDrag:c,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:u,connectionInProgress:c}){return d=>{let h=e||t,f=n&&d.ctrlKey,p="wheel"===d.type;if(1===d.button&&"mousedown"===d.type&&(rg(d,`${u}-flow__node`)||rg(d,`${u}-flow__edge`)))return!0;if(!r&&!h&&!o&&!i&&!n||a||c&&!p||rg(d,s)&&p||rg(d,l)&&(!p||o&&p&&!e)||!n&&d.ctrlKey&&p)return!1;if(!n&&"touchstart"===d.type&&d.touches?.length>1)return d.preventDefault(),!1;if(!h&&!o&&!f&&p||!r&&("mousedown"===d.type||"touchstart"===d.type)||Array.isArray(r)&&!r.includes(d.button)&&"mousedown"===d.type)return!1;let g=Array.isArray(r)&&r.includes(d.button)||!d.button||d.button<=1;return(!d.ctrlKey||p)&&g}}({zoomActivationKeyPressed:_,panOnDrag:c,zoomOnScroll:b,panOnScroll:o,zoomOnDoubleClick:E,zoomOnPinch:w,userSelectionActive:r,noPanClassName:t,noWheelClassName:e,lib:k,connectionInProgress:M});h.filter(P),E?f.on("dblclick.zoom",g):f.on("dblclick.zoom",null)},destroy:y,setViewport:async function e(e,t){let n=rp(e);return await m(n,t),new Promise(e=>e(n))},setViewportConstrained:v,getViewport:function(){let e=f?tZ(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"?t4:eC).scaleTo(rv(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"?t4:eC).scaleBy(rv(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=rp(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=!n_(e)||e<0?0:e;h?.clickDistance(t)}}}({domNode:M.current,minZoom:c,maxZoom:h,translateExtent:u,viewport:l,onDraggingChange:e=>S.setState({paneDragging:e}),onPanZoomStart:(e,t)=>{let{onViewportChangeStart:n,onMoveStart:r}=S.getState();r?.(e,t),n?.(t)},onPanZoom:(e,t)=>{let{onViewportChange:n,onMove:r}=S.getState();r?.(e,t),n?.(t)},onPanZoomEnd:(e,t)=>{let{onViewportChangeEnd:n,onMoveEnd:r}=S.getState();r?.(e,t),n?.(t)}});let{x:e,y:t,zoom:n}=P.current.getViewport();return S.setState({panZoom:P.current,transform:[e,t,n],domNode:M.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:C,onTransformChange:A,connectionInProgress:j,selectionOnDrag:_,paneClickDistance:E})},[e,t,n,r,o,i,a,s,O,p,y,N,m,C,A,j,_,E]),(0,v.jsx)("div",{className:"react-flow__renderer",ref:M,style:ov,children:g})}let ob=e=>({userSelectionActive:e.userSelectionActive,userSelectionRect:e.userSelectionRect});function oE(){let{userSelectionActive:e,userSelectionRect:t}=rD(ob,r$);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 o_=(e,t)=>n=>{n.target===t.current&&e?.(n)},ok=e=>({userSelectionActive:e.userSelectionActive,elementsSelectable:e.elementsSelectable,connectionInProgress:e.connection.inProgress,dragging:e.paneDragging});function oS({isSelecting:e,selectionKeyPressed:t,selectionMode:n=h.Full,panOnDrag:r,paneClickDistance:o,selectionOnDrag:i,onSelectionStart:a,onSelectionEnd:s,onPaneClick:l,onPaneContextMenu:u,onPaneScroll:c,onPaneMouseEnter:d,onPaneMouseMove:f,onPaneMouseLeave:p,children:g}){let m=rB(),{userSelectionActive:y,elementsSelectable:b,dragging:E,connectionInProgress:_}=rD(ok,r$),k=b&&(e||y),S=(0,x.useRef)(null),M=(0,x.useRef)(),N=(0,x.useRef)(new Set),C=(0,x.useRef)(new Set),j=(0,x.useRef)(!1),O=e=>{if(j.current||_){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:E,selection:e}]),onClick:k?void 0:o_(O,S),onContextMenu:o_(e=>{Array.isArray(r)&&r?.includes(2)?e.preventDefault():u?.(e)},S),onWheel:o_(c?e=>c(e):void 0,S),onPointerEnter:k?void 0:d,onPointerMove:k?e=>{let{userSelectionRect:r,transform:i,nodeLookup:s,edgeLookup:l,connectionLookup:u,triggerNodeChanges:c,triggerEdgeChanges:d,defaultEdgeOptions:f,resetSelectedElements:p}=m.getState();if(!M.current||!r)return;let{x:g,y:y}=nH(e.nativeEvent,M.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,E=C.current;N.current=new Set(na(s,w,i,n===h.Partial,!0).map(e=>e.id)),C.current=new Set;let _=f?.selectable??!0;for(let e of N.current){let t=u.get(e);if(t)for(let{edgeId:e}of t.values()){let t=l.get(e);t&&(t.selectable??_)&&C.current.add(e)}}nI(b,N.current)||c(oi(s,N.current,!0)),nI(E,C.current)||d(oi(l,C.current)),m.setState({userSelectionRect:w,userSelectionActive:!0,nodesSelectionActive:!1})}:f,onPointerUp:k?e=>{0===e.button&&(e.target?.releasePointerCapture?.(e.pointerId),!y&&e.target===S.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(M.current=r?.getBoundingClientRect(),!M.current)return;let o=n.target===S.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}=nH(n.nativeEvent,M.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:S,style:ov,children:[g,(0,v.jsx)(oE,{})]})}function oM({id:e,store:t,unselect:n=!1,nodeRef:r}){let o,{addSelectedNodes:i,unselectNodesAndEdges:a,multiSelectionActive:s,nodeLookup:l,onError:u}=t.getState(),c=l.get(e);c?(t.setState({nodesSelectionActive:!1}),c.selected?(n||c.selected&&s)&&(a({nodes:[c],edges:[]}),requestAnimationFrame(()=>r?.current?.blur())):i([e])):u?.("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 oN({nodeRef:e,disabled:t=!1,noDragClassName:n,handleSelector:r,nodeId:o,isSelectable:i,nodeClickDistance:a}){let s=rB(),[l,u]=(0,x.useState)(!1),c=(0,x.useRef)();return(0,x.useEffect)(()=>{c.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,u={x:0,y:0},c=null,d=!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 E({x:e,y:n}){let{nodeLookup:o,nodeExtent:a,snapGrid:l,snapToGrid:u,nodeOrigin:c,onNodeDrag:d,onSelectionDrag:h,onError:f,updateNodePositions:m}=t();i={x:e,y:n};let y=!1,v=s.size>1,x=v&&a?nm(ni(s)):null,b=v&&u?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=nS(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};u&&(i=b?{x:Math.round(i.x+b.x),y:Math.round(i.y+b.y)}:nS(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:d,positionAbsolute:h}=nl({nodeId:t,nextPosition:i,nodeLookup:o,nodeExtent:s||a,nodeOrigin:c,onError:f});y=y||r.position.x!==d.x||r.position.y!==d.y,r.position=d,r.internals.positionAbsolute=h}if(p=p||y,y&&(m(s,!0),g&&(r||d||!w&&h))){let[e,t]=rs({nodeId:w,dragItems:s,nodeLookup:o});r?.(g,s,e,t),d?.(g,e,t),w||h?.(g,t)}}async function _(){if(!c)return;let{transform:e,panBy:n,autoPanSpeed:r,autoPanOnNodeDrag:o}=t();if(!o){l=!1,cancelAnimationFrame(a);return}let[s,d]=np(u,c,r);(0!==s||0!==d)&&(i.x=(i.x??0)-s/e[2],i.y=(i.y??0)-d/e[2],await n({x:s,y:d})&&E(i)),a=requestAnimationFrame(_)}function k(r){let{nodeLookup:o,multiSelectionActive:a,nodesDraggable:l,transform:u,snapGrid:h,snapToGrid:f,selectNodesOnDrag:p,onNodeDragStart:g,onSelectionDragStart:m,unselectNodesAndEdges:y}=t();d=!0,p&&x||a||!w||o.get(w)?.selected||y(),x&&p&&w&&e?.(w);let v=nL(r.sourceEvent,{transform:u,snapGrid:h,snapToGrid:f,containerBounds:c});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]=rs({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 S=eM().clickDistance(b).on("start",e=>{let{domNode:n,nodeDragThreshold:r,transform:o,snapGrid:a,snapToGrid:s}=t();c=n?.getBoundingClientRect()||null,f=!1,p=!1,g=e.sourceEvent,0===r&&k(e),i=nL(e.sourceEvent,{transform:o,snapGrid:a,snapToGrid:s,containerBounds:c}),u=nH(e.sourceEvent,c)}).on("drag",e=>{let{autoPanOnNodeDrag:n,transform:r,snapGrid:o,snapToGrid:a,nodeDragThreshold:h,nodeLookup:p}=t(),m=nL(e.sourceEvent,{transform:r,snapGrid:o,snapToGrid:a,containerBounds:c});if(g=e.sourceEvent,("touchmove"===e.sourceEvent.type&&e.sourceEvent.touches.length>1||w&&!p.has(w))&&(f=!0),!f){if(!l&&n&&d&&(l=!0,_()),!d){let t=nH(e.sourceEvent,c),n=t.x-u.x,r=t.y-u.y;Math.sqrt(n*n+r*r)>h&&k(e)}(i.x!==m.xSnapped||i.y!==m.ySnapped)&&s&&d&&(u=nH(e.sourceEvent,c),E(m))}}).on("end",e=>{if(d&&!f&&(l=!1,d=!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]=rs({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||!ra(t,`.${m}`,v))&&(!y||ra(t,y,v))});h.call(S)},destroy:function(){h?.on(".drag",null)}}}({getStoreItems:()=>s.getState(),onNodeMouseDown:t=>{oM({id:t,store:s,nodeRef:e})},onDragStart:()=>{u(!0)},onDragStop:()=>{u(!1)}})},[]),(0,x.useEffect)(()=>{if(t)c.current?.destroy();else if(e.current)return c.current?.update({noDragClassName:n,handleSelector:r,domNode:e.current,isSelectable:i,nodeId:o,nodeClickDistance:a}),()=>{c.current?.destroy()}},[n,r,t,i,e,o]),l}function oC(){let e=rB();return(0,x.useCallback)(t=>{let{nodeExtent:n,snapToGrid:r,snapGrid:o,nodesDraggable:i,onError:a,updateNodePositions:s,nodeLookup:l,nodeOrigin:u}=e.getState(),c=new Map,d=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(!d(e))continue;let t={x:e.internals.positionAbsolute.x+p,y:e.internals.positionAbsolute.y+g};r&&(t=nS(t,o));let{position:i,positionAbsolute:s}=nl({nodeId:e.id,nextPosition:t,nodeLookup:l,nodeExtent:n,nodeOrigin:u,onError:a});e.position=i,e.internals.positionAbsolute=s,c.set(e.id,e)}s(c)},[])}let oj=(0,x.createContext)(null),oO=oj.Provider;oj.Consumer;let oP=()=>(0,x.useContext)(oj),oA=e=>({connectOnClick:e.connectOnClick,noPanClassName:e.noPanClassName,rfId:e.rfId}),oz=(0,x.memo)(ou(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:u,onMouseDown:d,onTouchStart:h,...f},p){let m=a||null,y="target"===e,x=rB(),b=oP(),{connectOnClick:E,noPanClassName:_,rfId:k}=rD(oA,r$),{connectingFrom:S,connectingTo:M,clickConnecting:N,isPossibleEndHandle:C,connectionInProcess:j,clickConnectionInProcess:O,valid:P}=rD(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===c.Strict?i?.type!==e:b!==i?.nodeId||m!==i?.id,connectionInProcess:!!i,clickConnectionInProcess:!!n,valid:l&&s}},r$);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(((e,t,n={})=>{let r,o;if(!e.source||!e.target)return nk("006","Can't create edge. An edge needs a source and a target."),t;let i=n.getEdgeId||nK;return(o=r=nn(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))})(o,e))}n?.(o),s?.(o)},z=e=>{if(!b)return;let t="clientX"in e.nativeEvent;if(o&&(t&&0===e.button||!t)){let t=x.getState();rh(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:t.onConnectEnd,updateConnection:t.updateConnection,onConnect:A,isValidConnection:n||t.isValidConnection,getTransform:()=>x.getState().transform,getFromHandle:()=>x.getState().connection.fromHandle,autoPanSpeed:t.autoPanSpeed,dragThreshold:t.connectionDragThreshold})}t?d?.(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",_,u,{source:!y,target:y,connectable:r,connectablestart:o,connectableend:i,clickconnecting:N,connectingfrom:S,connectingto:M,valid:P,connectionindicator:r&&(!j||C)&&(j||O?i:o)}]),onMouseDown:z,onTouchStart:z,onClick:E?t=>{let{onClickConnectStart:r,onClickConnectEnd:i,connectionClickStartHandle:a,connectionMode:s,isValidConnection:l,lib:u,rfId:c,nodeLookup:d,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=nD(t.target),p=n||l,{connection:g,isValid:y}=rd(t.nativeEvent,{handle:{nodeId:b,id:m,type:e},connectionMode:s,fromNodeId:a.nodeId,fromHandleId:a.id||null,fromType:a.type,isValidConnection:p,flowId:c,doc:f,lib:u,nodeLookup:d});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})})),o$={ArrowUp:{x:0,y:-1},ArrowDown:{x:0,y:1},ArrowLeft:{x:-1,y:0},ArrowRight:{x:1,y:0}},oI={input:function({data:e,isConnectable:t,sourcePosition:n=g.Bottom}){return(0,v.jsxs)(v.Fragment,{children:[e?.label,(0,v.jsx)(oz,{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)(oz,{type:"target",position:n,isConnectable:t}),e?.label,(0,v.jsx)(oz,{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)(oz,{type:"target",position:n,isConnectable:t}),e?.label]})},group:function(){return null}},oL=e=>{let{width:t,height:n,x:r,y:o}=ni(e.nodeLookup,{filter:e=>!!e.selected});return{width:n_(t)?t:null,height:n_(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=rB(),{width:o,height:i,transformString:a,userSelectionActive:s}=rD(oL,r$),l=oC(),u=(0,x.useRef)(null);if((0,x.useEffect)(()=>{n||u.current?.focus({preventScroll:!0})},[n]),oN({nodeRef:u}),s||!o||!i)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:u,className:"react-flow__nodesselection-rect",onContextMenu:c,tabIndex:n?void 0:-1,onKeyDown:n?void 0:e=>{Object.prototype.hasOwnProperty.call(o$,e.key)&&(e.preventDefault(),l({direction:o$[e.key],factor:e.shiftKey?4:1}))},style:{width:o,height:i}})})}let oD="u">typeof window?window:void 0,oB=e=>({nodesSelectionActive:e.nodesSelectionActive,userSelectionActive:e.userSelectionActive});function oT({children:e,onPaneClick:t,onPaneMouseEnter:n,onPaneMouseMove:r,onPaneMouseLeave:o,onPaneContextMenu:i,onPaneScroll:a,paneClickDistance:s,deleteKeyCode:l,selectionKeyCode:u,selectionOnDrag:c,selectionMode:d,onSelectionStart:h,onSelectionEnd:f,multiSelectionKeyCode:p,panActivationKeyCode:g,zoomActivationKeyCode:m,elementsSelectable:y,zoomOnScroll:w,zoomOnPinch:b,panOnScroll:E,panOnScrollSpeed:_,panOnScrollMode:k,zoomOnDoubleClick:S,panOnDrag:M,defaultViewport:N,translateExtent:C,minZoom:j,maxZoom:O,preventScrolling:P,onSelectionContextMenu:A,noWheelClassName:z,noPanClassName:$,disableKeyboardA11y:I,onViewportChange:L,isControlledViewport:R}){let{nodesSelectionActive:D,userSelectionActive:B}=rD(oB,r$),T=oe(u,{target:oD}),H=oe(g,{target:oD}),V=H||M,F=H||E,X=c&&!0!==V,Y=T||B||X;return!function({deleteKeyCode:e,multiSelectionKeyCode:t}){let n=rB(),{deleteElements:r}=og(),o=oe(e,{actInsideInputWithModifier:!1}),i=oe(t,{target:oy});(0,x.useEffect)(()=>{if(o){let{edges:e,nodes:t}=n.getState();r({nodes:t.filter(om),edges:e.filter(om)}),n.setState({nodesSelectionActive:!1})}},[o]),(0,x.useEffect)(()=>{n.setState({multiSelectionActive:i})},[i])}({deleteKeyCode:l,multiSelectionKeyCode:p}),(0,v.jsx)(ow,{onPaneContextMenu:i,elementsSelectable:y,zoomOnScroll:w,zoomOnPinch:b,panOnScroll:F,panOnScrollSpeed:_,panOnScrollMode:k,zoomOnDoubleClick:S,panOnDrag:!T&&V,defaultViewport:N,translateExtent:C,minZoom:j,maxZoom:O,zoomActivationKeyCode:m,preventScrolling:P,noWheelClassName:z,noPanClassName:$,onViewportChange:L,isControlledViewport:R,paneClickDistance:s,selectionOnDrag:X,children:(0,v.jsxs)(oS,{onSelectionStart:h,onSelectionEnd:f,onPaneClick:t,onPaneMouseEnter:n,onPaneMouseMove:r,onPaneMouseLeave:o,onPaneContextMenu:i,onPaneScroll:a,panOnDrag:V,isSelecting:!!Y,selectionMode:d,selectionKeyPressed:T,paneClickDistance:s,selectionOnDrag:X,children:[e,D&&(0,v.jsx)(oR,{onSelectionContextMenu:A,noPanClassName:$,disableKeyboardA11y:I})]})})}oT.displayName="FlowRenderer";let oH=(0,x.memo)(oT),oV=e=>e.updateNodeInternals;var oF=(0,x.memo)(function({id:e,onClick:t,onMouseEnter:n,onMouseMove:r,onMouseLeave:o,onContextMenu:i,onDoubleClick:a,nodesDraggable:s,elementsSelectable:l,nodesConnectable:u,nodesFocusable:c,resizeObserver:d,noDragClassName:h,noPanClassName:f,disableKeyboardA11y:p,rfId:g,nodeTypes:m,nodeClickDistance:y,onError:b}){let E,{node:_,internals:k,isParent:S}=rD(t=>{let n=t.nodeLookup.get(e),r=t.parentLookup.has(e);return{node:n,internals:n.internals,isParent:r}},r$),M=_.type||"default",N=m?.[M]||oI[M];void 0===N&&(b?.("003",(E=M,`Node type "${E}" not found. Using fallback type "default".`)),M="default",N=m?.default||oI.default);let C=!!(_.draggable||s&&void 0===_.draggable),j=!!(_.selectable||l&&void 0===_.selectable),O=!!(_.connectable||u&&void 0===_.connectable),P=!!(_.focusable||c&&void 0===_.focusable),A=rB(),z=nz(_),$=function({node:e,nodeType:t,hasDimensions:n,resizeObserver:r}){let o=rB(),i=(0,x.useRef)(null),a=(0,x.useRef)(null),s=(0,x.useRef)(e.sourcePosition),l=(0,x.useRef)(e.targetPosition),u=(0,x.useRef)(t),c=n&&!!e.internals.handleBounds;return(0,x.useEffect)(()=>{!i.current||e.hidden||c&&a.current===i.current||(a.current&&r?.unobserve(a.current),r?.observe(i.current),a.current=i.current)},[c,e.hidden]),(0,x.useEffect)(()=>()=>{a.current&&(r?.unobserve(a.current),a.current=null)},[]),(0,x.useEffect)(()=>{if(i.current){let n=u.current!==t,r=s.current!==e.sourcePosition,a=l.current!==e.targetPosition;(n||r||a)&&(u.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:_,nodeType:M,hasDimensions:z,resizeObserver:d}),I=oN({nodeRef:$,disabled:_.hidden||!C,noDragClassName:h,handleSelector:_.dragHandle,nodeId:e,isSelectable:j,nodeClickDistance:y}),L=oC();if(_.hidden)return null;let R=nA(_),D=void 0===_.internals.handleBounds?{width:_.width??_.initialWidth??_.style?.width,height:_.height??_.initialHeight??_.style?.height}:{width:_.width??_.style?.width,height:_.height??_.style?.height},B=j||C||t||n||r||o,T=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-${M}`,{[f]:C},_.className,{selected:_.selected,selectable:j,parent:S,draggable:C,dragging:I}]),ref:$,style:{zIndex:k.z,transform:`translate(${k.positionAbsolute.x}px,${k.positionAbsolute.y}px)`,pointerEvents:B?"all":"none",visibility:z?"visible":"hidden",..._.style,...D},"data-id":e,"data-testid":`rf__node-${e}`,onMouseEnter:T,onMouseMove:H,onMouseLeave:V,onContextMenu:F,onClick:n=>{let{selectNodesOnDrag:r,nodeDragThreshold:o}=A.getState();j&&(!r||!C||o>0)&&oM({id:e,store:A,nodeRef:$}),t&&t(n,{...k.userNode})},onDoubleClick:X,onKeyDown:P?t=>{if(!nT(t.nativeEvent)&&!p){if(t8.includes(t.key)&&j)oM({id:e,store:A,unselect:"Escape"===t.key,nodeRef:$});else if(C&&_.selected&&Object.prototype.hasOwnProperty.call(o$,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:o$[t.key],factor:t.shiftKey?4:1})}}}:void 0,tabIndex:P?0:void 0,onFocus:P?()=>{if(p||!$.current?.matches(":focus-visible"))return;let{transform:t,width:n,height:r,autoPanOnNodeFocus:o,setCenter:i}=A.getState();!o||na(new Map([[e,_]]),{x:0,y:0,width:n,height:r},t,!0).length>0||i(_.position.x+R.width/2,_.position.y+R.height/2,{zoom:t[2]})}:void 0,role:_.ariaRole??(P?"group":void 0),"aria-roledescription":"node","aria-describedby":p?void 0:`${rV}-${g}`,"aria-label":_.ariaLabel,..._.domAttributes,children:(0,v.jsx)(oO,{value:e,children:(0,v.jsx)(N,{id:e,data:_.data,type:M,positionAbsoluteX:k.positionAbsolute.x,positionAbsoluteY:k.positionAbsolute.y,selected:_.selected??!1,selectable:j,draggable:C,deletable:_.deletable??!0,isConnectable:O,sourcePosition:_.sourcePosition,targetPosition:_.targetPosition,dragging:I,dragHandle:_.dragHandle,zIndex:k.z,parentId:_.parentId,...R})})})});let oX=e=>({nodesDraggable:e.nodesDraggable,nodesConnectable:e.nodesConnectable,nodesFocusable:e.nodesFocusable,elementsSelectable:e.elementsSelectable,onError:e.onError});function oY(e){var t;let{nodesDraggable:n,nodesConnectable:r,nodesFocusable:o,elementsSelectable:i,onError:a}=rD(oX,r$),s=(t=e.onlyRenderVisibleElements,rD((0,x.useCallback)(e=>t?na(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]),r$)),l=function(){let e=rD(oV),[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:ov,children:s.map(t=>(0,v.jsx)(oF,{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))})}oY.displayName="NodeRenderer";let oW=(0,x.memo)(oY),oq={[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"})}},oK=({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,u=(l=rB(),(0,x.useMemo)(()=>{let e;return Object.prototype.hasOwnProperty.call(oq,t)?oq[t]:(l.getState().onError?.("009",(e=t,`Marker type "${e}" doesn't exist.`)),null)},[t]));return u?(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)(u,{color:n,strokeWidth:a})}):null},oZ=({defaultColor:e,rfId:t})=>{let n=rD(e=>e.edges),r=rD(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=n3(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)(oK,{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};oZ.displayName="MarkerDefinitions";var oG=(0,x.memo)(oZ);function oU({x:e,y:t,label:n,labelStyle:r,labelShowBg:o=!0,labelBgStyle:i,labelBgPadding:a=[2,4],labelBgBorderRadius:s=2,children:l,className:u,...c}){let[d,h]=(0,x.useState)({x:1,y:0,width:0,height:0}),f=w(["react-flow__edge-textwrapper",u]),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-d.width/2} ${t-d.height/2})`,className:f,visibility:d.width?"visible":"hidden",...c,children:[o&&(0,v.jsx)("rect",{width:d.width+2*a[0],x:-a[0],y:-a[1],height:d.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:d.height/2,dy:"0.3em",ref:p,style:r,children:n}),l]}):null}oU.displayName="EdgeText";let oQ=(0,x.memo)(oU);function oJ({path:e,labelX:t,labelY:n,label:r,labelStyle:o,labelShowBg:i,labelBgStyle:a,labelBgPadding:s,labelBgBorderRadius:l,interactionWidth:u=20,...c}){return(0,v.jsxs)(v.Fragment,{children:[(0,v.jsx)("path",{...c,d:e,fill:"none",className:w(["react-flow__edge-path",c.className])}),u?(0,v.jsx)("path",{d:e,fill:"none",strokeOpacity:0,strokeWidth:u,className:"react-flow__edge-interaction"}):null,r&&n_(t)&&n_(n)?(0,v.jsx)(oQ,{x:t,y:n,label:r,labelStyle:o,labelShowBg:i,labelBgStyle:a,labelBgPadding:s,labelBgBorderRadius:l}):null]})}function o0({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 o1({sourceX:e,sourceY:t,sourcePosition:n=g.Bottom,targetX:r,targetY:o,targetPosition:i=g.Top}){let[a,s]=o0({pos:n,x1:e,y1:t,x2:r,y2:o}),[l,u]=o0({pos:i,x1:r,y1:o,x2:e,y2:t}),[c,d,h,f]=nF({sourceX:e,sourceY:t,targetX:r,targetY:o,sourceControlX:a,sourceControlY:s,targetControlX:l,targetControlY:u});return[`M${e},${t} C${a},${s} ${l},${u} ${r},${o}`,c,d,h,f]}function o2(e){return(0,x.memo)(({id:t,sourceX:n,sourceY:r,targetX:o,targetY:i,sourcePosition:a,targetPosition:s,label:l,labelStyle:u,labelShowBg:c,labelBgStyle:d,labelBgPadding:h,labelBgBorderRadius:f,style:p,markerEnd:g,markerStart:m,interactionWidth:y})=>{let[x,w,b]=o1({sourceX:n,sourceY:r,sourcePosition:a,targetX:o,targetY:i,targetPosition:s}),E=e.isInternal?void 0:t;return(0,v.jsx)(oJ,{id:E,path:x,labelX:w,labelY:b,label:l,labelStyle:u,labelShowBg:c,labelBgStyle:d,labelBgPadding:h,labelBgBorderRadius:f,style:p,markerEnd:g,markerStart:m,interactionWidth:y})})}let o5=o2({isInternal:!1}),o3=o2({isInternal:!0});function o4(e){return(0,x.memo)(({id:t,sourceX:n,sourceY:r,targetX:o,targetY:i,label:a,labelStyle:s,labelShowBg:l,labelBgStyle:u,labelBgPadding:c,labelBgBorderRadius:d,style:h,sourcePosition:f=g.Bottom,targetPosition:p=g.Top,markerEnd:m,markerStart:y,pathOptions:x,interactionWidth:w})=>{let[b,E,_]=nJ({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)(oJ,{id:k,path:b,labelX:E,labelY:_,label:a,labelStyle:s,labelShowBg:l,labelBgStyle:u,labelBgPadding:c,labelBgBorderRadius:d,style:h,markerEnd:m,markerStart:y,interactionWidth:w})})}o5.displayName="SimpleBezierEdge",o3.displayName="SimpleBezierEdgeInternal";let o6=o4({isInternal:!1}),o8=o4({isInternal:!0});function o9(e){return(0,x.memo)(({id:t,...n})=>{let r=e.isInternal?void 0:t;return(0,v.jsx)(o6,{...n,id:r,pathOptions:(0,x.useMemo)(()=>({borderRadius:0,offset:n.pathOptions?.offset}),[n.pathOptions?.offset])})})}o6.displayName="SmoothStepEdge",o8.displayName="SmoothStepEdgeInternal";let o7=o9({isInternal:!1}),ie=o9({isInternal:!0});function it(e){return(0,x.memo)(({id:t,sourceX:n,sourceY:r,targetX:o,targetY:i,label:a,labelStyle:s,labelShowBg:l,labelBgStyle:u,labelBgPadding:c,labelBgBorderRadius:d,style:h,markerEnd:f,markerStart:p,interactionWidth:g})=>{let[m,y,x]=nZ({sourceX:n,sourceY:r,targetX:o,targetY:i}),w=e.isInternal?void 0:t;return(0,v.jsx)(oJ,{id:w,path:m,labelX:y,labelY:x,label:a,labelStyle:s,labelShowBg:l,labelBgStyle:u,labelBgPadding:c,labelBgBorderRadius:d,style:h,markerEnd:f,markerStart:p,interactionWidth:g})})}o7.displayName="StepEdge",ie.displayName="StepEdgeInternal";let ir=it({isInternal:!1}),io=it({isInternal:!0});function ii(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:u,labelShowBg:c,labelBgStyle:d,labelBgPadding:h,labelBgBorderRadius:f,style:p,markerEnd:m,markerStart:y,pathOptions:x,interactionWidth:w})=>{let[b,E,_]=nW({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)(oJ,{id:k,path:b,labelX:E,labelY:_,label:l,labelStyle:u,labelShowBg:c,labelBgStyle:d,labelBgPadding:h,labelBgBorderRadius:f,style:p,markerEnd:m,markerStart:y,interactionWidth:w})})}ir.displayName="StraightEdge",io.displayName="StraightEdgeInternal";let ia=ii({isInternal:!1}),is=ii({isInternal:!0});ia.displayName="BezierEdge",is.displayName="BezierEdgeInternal";let il={default:is,straight:io,step:ie,smoothstep:o8,simplebezier:o3},iu={sourceX:null,sourceY:null,targetX:null,targetY:null,sourcePosition:null,targetPosition:null},ic="react-flow__edgeupdater";function id({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([ic,`${ic}-${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 ih({isReconnectable:e,reconnectRadius:t,edge:n,sourceX:r,sourceY:o,targetX:i,targetY:a,sourcePosition:s,targetPosition:l,onReconnect:u,onReconnectStart:c,onReconnectEnd:d,setReconnecting:h,setUpdateHover:f}){let p=rB(),g=(e,t)=>{if(0!==e.button)return;let{autoPanOnConnect:r,domNode:o,isValidConnection:i,connectionMode:a,connectionRadius:s,lib:l,onConnectStart:f,onConnectEnd:g,cancelConnection:m,nodeLookup:y,rfId:v,panBy:x,updateConnection:w}=p.getState(),b="target"===t.type;rh(e.nativeEvent,{autoPanOnConnect:r,connectionMode:a,connectionRadius:s,domNode:o,handleId:t.id,nodeId:t.nodeId,nodeLookup:y,isTarget:b,edgeUpdaterType:t.type,lib:l,flowId:v,cancelConnection:m,panBy:x,isValidConnection:i,onConnect:e=>u?.(n,e),onConnectStart:(r,o)=>{h(!0),c?.(e,n,t.type),f?.(r,o)},onConnectEnd:g,onReconnectEnd:(e,r)=>{h(!1),d?.(e,n,t.type,r)},updateConnection:w,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)(id,{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)(id,{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 ip=(0,x.memo)(function({id:e,edgesFocusable:t,edgesReconnectable:n,elementsSelectable:r,onClick:o,onDoubleClick:i,onContextMenu:a,onMouseEnter:s,onMouseMove:l,onMouseLeave:u,reconnectRadius:d,onReconnect:h,onReconnectStart:f,onReconnectEnd:p,rfId:m,edgeTypes:y,noPanClassName:b,onError:E,disableKeyboardA11y:_}){let k,S=rD(t=>t.edgeLookup.get(e)),M=rD(e=>e.defaultEdgeOptions),N=(S=M?{...M,...S}:S).type||"default",C=y?.[N]||il[N];void 0===C&&(E?.("011",(k=N,`Edge type "${k}" not found. Using fallback type "default".`)),N="default",C=y?.default||il.default);let j=!!(S.focusable||t&&void 0===S.focusable),O=void 0!==h&&(S.reconnectable||n&&void 0===S.reconnectable),P=!!(S.selectable||r&&void 0===S.selectable),A=(0,x.useRef)(null),[z,$]=(0,x.useState)(!1),[I,L]=(0,x.useState)(!1),R=rB(),{zIndex:D,sourceX:B,sourceY:T,targetX:H,targetY:V,sourcePosition:F,targetPosition:X}=rD((0,x.useCallback)(t=>{let n=t.nodeLookup.get(S.source),r=t.nodeLookup.get(S.target);if(!n||!r)return{zIndex:S.zIndex,...iu};let o=function(e){let{sourceNode:t,targetNode:n}=e;if(!n0(t)||!n0(n))return null;let r=t.internals.handleBounds||n1(t.handles),o=n.internals.handleBounds||n1(n.handles),i=n5(r?.source??[],e.sourceHandle),a=n5(e.connectionMode===c.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,u=n2(t,i,s),d=n2(n,a,l);return{sourceX:u.x,sourceY:u.y,targetX:d.x,targetY:d.y,sourcePosition:s,targetPosition:l}}({id:e,sourceNode:n,targetNode:r,sourceHandle:S.sourceHandle||null,targetHandle:S.targetHandle||null,connectionMode:t.connectionMode,onError:E});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:S.selected,zIndex:S.zIndex,sourceNode:n,targetNode:r,elevateOnSelect:t.elevateEdgesOnSelect,zIndexMode:t.zIndexMode}),...o||iu}},[S.source,S.target,S.sourceHandle,S.targetHandle,S.selected,S.zIndex]),r$),Y=(0,x.useMemo)(()=>S.markerStart?`url('#${n3(S.markerStart,m)}')`:void 0,[S.markerStart,m]),W=(0,x.useMemo)(()=>S.markerEnd?`url('#${n3(S.markerEnd,m)}')`:void 0,[S.markerEnd,m]);if(S.hidden||null===B||null===T||null===H||null===V)return null;let q=i?e=>{i(e,{...S})}:void 0,K=a?e=>{a(e,{...S})}:void 0,Z=s?e=>{s(e,{...S})}:void 0,G=l?e=>{l(e,{...S})}:void 0,U=u?e=>{u(e,{...S})}:void 0;return(0,v.jsx)("svg",{style:{zIndex:D},children:(0,v.jsxs)("g",{className:w(["react-flow__edge",`react-flow__edge-${N}`,S.className,b,{selected:S.selected,animated:S.animated,inactive:!P&&!o,updating:z,selectable:P}]),onClick:t=>{let{addSelectedEdges:n,unselectNodesAndEdges:r,multiSelectionActive:i}=R.getState();P&&(R.setState({nodesSelectionActive:!1}),S.selected&&i?(r({nodes:[],edges:[S]}),A.current?.blur()):n([e])),o&&o(t,S)},onDoubleClick:q,onContextMenu:K,onMouseEnter:Z,onMouseMove:G,onMouseLeave:U,onKeyDown:j?t=>{if(!_&&t8.includes(t.key)&&P){let{unselectNodesAndEdges:n,addSelectedEdges:r}=R.getState();"Escape"===t.key?(A.current?.blur(),n({edges:[S]})):r([e])}}:void 0,tabIndex:j?0:void 0,role:S.ariaRole??(j?"group":"img"),"aria-roledescription":"edge","data-id":e,"data-testid":`rf__edge-${e}`,"aria-label":null===S.ariaLabel?void 0:S.ariaLabel||`Edge from ${S.source} to ${S.target}`,"aria-describedby":j?`${rF}-${m}`:void 0,ref:A,...S.domAttributes,children:[!I&&(0,v.jsx)(C,{id:e,source:S.source,target:S.target,type:S.type,selected:S.selected,animated:S.animated,selectable:P,deletable:S.deletable??!0,label:S.label,labelStyle:S.labelStyle,labelShowBg:S.labelShowBg,labelBgStyle:S.labelBgStyle,labelBgPadding:S.labelBgPadding,labelBgBorderRadius:S.labelBgBorderRadius,sourceX:B,sourceY:T,targetX:H,targetY:V,sourcePosition:F,targetPosition:X,data:S.data,style:S.style,sourceHandleId:S.sourceHandle,targetHandleId:S.targetHandle,markerStart:Y,markerEnd:W,pathOptions:"pathOptions"in S?S.pathOptions:void 0,interactionWidth:S.interactionWidth}),O&&(0,v.jsx)(ih,{edge:S,isReconnectable:O,reconnectRadius:d,onReconnect:h,onReconnectStart:f,onReconnectEnd:p,sourceX:B,sourceY:T,targetX:H,targetY:V,sourcePosition:F,targetPosition:X,setUpdateHover:$,setReconnecting:L})]})})});let ig=e=>({edgesFocusable:e.edgesFocusable,edgesReconnectable:e.edgesReconnectable,elementsSelectable:e.elementsSelectable,connectionMode:e.connectionMode,onError:e.onError});function im({defaultMarkerColor:e,onlyRenderVisibleElements:t,rfId:n,edgeTypes:r,noPanClassName:o,onReconnect:i,onEdgeContextMenu:a,onEdgeMouseEnter:s,onEdgeMouseMove:l,onEdgeMouseLeave:u,onEdgeClick:c,reconnectRadius:d,onEdgeDoubleClick:h,onReconnectStart:f,onReconnectEnd:p,disableKeyboardA11y:g}){let{edgesFocusable:m,edgesReconnectable:y,elementsSelectable:w,onError:b}=rD(ig,r$),E=rD((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=ng(nx(e),nx(t));return i.x===i.x2&&(i.x2+=1),i.y===i.y2&&(i.y2+=1),nb({x:-o[0]/o[2],y:-o[1]/o[2],width:n/o[2],height:r/o[2]},ny(i))>0}({sourceNode:r,targetNode:o,width:e.width,height:e.height,transform:e.transform})&&n.push(t.id)}return n},[t]),r$);return(0,v.jsxs)("div",{className:"react-flow__edges",children:[(0,v.jsx)(oG,{defaultColor:e,rfId:n}),E.map(e=>(0,v.jsx)(ip,{id:e,edgesFocusable:m,edgesReconnectable:y,elementsSelectable:w,noPanClassName:o,onReconnect:i,onContextMenu:a,onMouseEnter:s,onMouseMove:l,onMouseLeave:u,onClick:c,reconnectRadius:d,onDoubleClick:h,onReconnectStart:f,onReconnectEnd:p,rfId:n,onError:b,edgeTypes:r,disableKeyboardA11y:g},e))]})}im.displayName="EdgeRenderer";let iy=(0,x.memo)(im),iv=e=>`translate(${e.transform[0]}px,${e.transform[1]}px) scale(${e.transform[2]})`;function ix({children:e}){let t=rD(iv);return(0,v.jsx)("div",{className:"react-flow__viewport xyflow__viewport react-flow__container",style:{transform:t},children:e})}let iw=e=>e.panZoom?.syncViewport;function ib(e){return e.connection.inProgress?{...e.connection,to:nM(e.connection.to,e.transform)}:{...e.connection}}let iE=e=>({nodesConnectable:e.nodesConnectable,isValid:e.connection.isValid,inProgress:e.connection.inProgress,width:e.width,height:e.height});function i_({containerStyle:e,style:t,type:n,component:r}){let{nodesConnectable:o,width:i,height:a,isValid:s,inProgress:l}=rD(iE,r$);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",nt(s)]),children:(0,v.jsx)(ik,{style:t,type:n,CustomComponent:r,isValid:s})})}):null}let ik=({style:e,type:t=f.Bezier,CustomComponent:n,isValid:r})=>{let{inProgress:o,from:i,fromNode:a,fromHandle:s,fromPosition:l,to:u,toNode:c,toHandle:d,toPosition:h,pointer:p}=rD(ib,r$);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:u.x,toY:u.y,fromPosition:l,toPosition:h,connectionStatus:nt(r),toNode:c,toHandle:d,pointer:p});let g="",m={sourceX:i.x,sourceY:i.y,sourcePosition:l,targetX:u.x,targetY:u.y,targetPosition:h};switch(t){case f.Bezier:[g]=nW(m);break;case f.SimpleBezier:[g]=o1(m);break;case f.Step:[g]=nJ({...m,borderRadius:0});break;case f.SmoothStep:[g]=nJ(m);break;default:[g]=nZ(m)}return(0,v.jsx)("path",{d:g,fill:"none",className:"react-flow__connection-path",style:e})};ik.displayName="ConnectionLine";let iS={};function iM(e=iS){(0,x.useRef)(e),rB(),(0,x.useEffect)(()=>{},[e])}function iN({nodeTypes:e,edgeTypes:t,onInit:n,onNodeClick:r,onEdgeClick:o,onNodeDoubleClick:i,onEdgeDoubleClick:a,onNodeMouseEnter:s,onNodeMouseMove:l,onNodeMouseLeave:u,onNodeContextMenu:c,onSelectionContextMenu:d,onSelectionStart:h,onSelectionEnd:f,connectionLineType:p,connectionLineStyle:g,connectionLineComponent:m,connectionLineContainerStyle:y,selectionKeyCode:w,selectionOnDrag:b,selectionMode:E,multiSelectionKeyCode:_,panActivationKeyCode:k,zoomActivationKeyCode:S,deleteKeyCode:M,onlyRenderVisibleElements:N,elementsSelectable:C,defaultViewport:j,translateExtent:O,minZoom:P,maxZoom:A,preventScrolling:z,defaultMarkerColor:$,zoomOnScroll:I,zoomOnPinch:L,panOnScroll:R,panOnScrollSpeed:D,panOnScrollMode:B,zoomOnDoubleClick:T,panOnDrag:H,onPaneClick:V,onPaneMouseEnter:F,onPaneMouseMove:X,onPaneMouseLeave:Y,onPaneScroll:W,onPaneContextMenu:q,paneClickDistance:K,nodeClickDistance:Z,onEdgeContextMenu:G,onEdgeMouseEnter:U,onEdgeMouseMove:Q,onEdgeMouseLeave:J,reconnectRadius:ee,onReconnect:et,onReconnectStart:en,onReconnectEnd:er,noDragClassName:eo,noWheelClassName:ei,noPanClassName:ea,disableKeyboardA11y:es,nodeExtent:el,rfId:eu,viewport:ec,onViewportChange:ed}){let eh,ef,ep,eg;return iM(e),iM(t),rB(),(0,x.useRef)(!1),(0,x.useEffect)(()=>{},[]),eh=og(),ef=(0,x.useRef)(!1),(0,x.useEffect)(()=>{!ef.current&&eh.viewportInitialized&&n&&(setTimeout(()=>n(eh),1),ef.current=!0)},[n,eh.viewportInitialized]),ep=rD(iw),eg=rB(),(0,x.useEffect)(()=>{ec&&(ep?.(ec),eg.setState({transform:[ec.x,ec.y,ec.zoom]}))},[ec,ep]),(0,v.jsx)(oH,{onPaneClick:V,onPaneMouseEnter:F,onPaneMouseMove:X,onPaneMouseLeave:Y,onPaneContextMenu:q,onPaneScroll:W,paneClickDistance:K,deleteKeyCode:M,selectionKeyCode:w,selectionOnDrag:b,selectionMode:E,onSelectionStart:h,onSelectionEnd:f,multiSelectionKeyCode:_,panActivationKeyCode:k,zoomActivationKeyCode:S,elementsSelectable:C,zoomOnScroll:I,zoomOnPinch:L,zoomOnDoubleClick:T,panOnScroll:R,panOnScrollSpeed:D,panOnScrollMode:B,panOnDrag:H,defaultViewport:j,translateExtent:O,minZoom:P,maxZoom:A,onSelectionContextMenu:d,preventScrolling:z,noDragClassName:eo,noWheelClassName:ei,noPanClassName:ea,disableKeyboardA11y:es,onViewportChange:ed,isControlledViewport:!!ec,children:(0,v.jsxs)(ix,{children:[(0,v.jsx)(iy,{edgeTypes:t,onEdgeClick:o,onEdgeDoubleClick:a,onReconnect:et,onReconnectStart:en,onReconnectEnd:er,onlyRenderVisibleElements:N,onEdgeContextMenu:G,onEdgeMouseEnter:U,onEdgeMouseMove:Q,onEdgeMouseLeave:J,reconnectRadius:ee,defaultMarkerColor:$,noPanClassName:ea,disableKeyboardA11y:es,rfId:eu}),(0,v.jsx)(i_,{style:g,type:p,component:m,containerStyle:y}),(0,v.jsx)("div",{className:"react-flow__edgelabel-renderer"}),(0,v.jsx)(oW,{nodeTypes:e,onNodeClick:r,onNodeDoubleClick:i,onNodeMouseEnter:s,onNodeMouseMove:l,onNodeMouseLeave:u,onNodeContextMenu:c,nodeClickDistance:Z,onlyRenderVisibleElements:N,noPanClassName:ea,noDragClassName:eo,disableKeyboardA11y:es,nodeExtent:el,rfId:eu}),(0,v.jsx)("div",{className:"react-flow__viewport-portal"})]})})}iN.displayName="GraphView";let iC=(0,x.memo)(iN),ij=({nodes:e,edges:t,defaultNodes:n,defaultEdges:r,width:o,height:i,fitView:a,fitViewOptions:s,minZoom:l=.5,maxZoom:u=2,nodeOrigin:d,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=d??[0,0],b=h??t6;ri(m,y,v);let E=n7(x,p,g,{nodeOrigin:w,nodeExtent:b,zIndexMode:f}),_=[0,0,1];if(a&&o&&i){let{x:e,y:t,zoom:n}=nj(ni(p,{filter:e=>!!((e.width||e.initialWidth)&&(e.height||e.initialHeight))}),o,i,l,u,s?.padding??.1);_=[e,t,n]}return{rfId:"1",width:o??0,height:i??0,transform:_,nodes:x,nodesInitialized:E,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:u,translateExtent:t6,nodeExtent:b,nodesSelectionActive:!1,userSelectionActive:!1,userSelectionRect:null,connectionMode:c.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:{...t7},connectionClickStartHandle:null,connectOnClick:!0,ariaLiveMessage:"",autoPanOnConnect:!0,autoPanOnNodeDrag:!0,autoPanOnNodeFocus:!0,autoPanSpeed:15,connectionRadius:20,onError:nk,isValidConnection:void 0,onSelectionChangeHandlers:[],lib:"react",debug:!1,ariaLabelConfig:t9,zIndexMode:f,onNodesChangeMiddlewareMap:new Map,onEdgesChangeMiddlewareMap:new Map}};function iO({initialNodes:e,initialEdges:t,defaultNodes:n,defaultEdges:r,initialWidth:o,initialHeight:i,initialMinZoom:a,initialMaxZoom:s,initialFitViewOptions:l,fitView:u,nodeOrigin:c,nodeExtent:d,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:u,nodeOrigin:c,nodeExtent:d,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 ns({nodes:e,width:o,height:i,panZoom:t,minZoom:a,maxZoom:s},n),r?.resolve(!0),f({fitViewResolver:null}))}return{...ij({nodes:e,edges:t,width:o,height:i,fitView:a,fitViewOptions:s,minZoom:l,maxZoom:u,nodeOrigin:c,nodeExtent:d,defaultNodes:n,defaultEdges:r,zIndexMode:h}),setNodes:e=>{let{nodeLookup:t,parentLookup:n,nodeOrigin:r,elevateNodesOnSelect:o,fitViewQueued:i,zIndexMode:a}=p(),s=n7(e,t,n,{nodeOrigin:r,nodeExtent:d,elevateNodesOnSelect:o,checkEquality:!0,zIndexMode:a});i&&s?(m(),f({nodes:e,nodesInitialized:s,fitViewQueued:!1,fitViewOptions:void 0})):f({nodes:e,nodesInitialized:s})},setEdges:e=>{let{connectionLookup:t,edgeLookup:n}=p();ri(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:u}=p(),{changes:c,updatedInternals:d}=function(e,t,n,r,o,i,a){let s=r?.querySelector(".xyflow__viewport"),l=!1;if(!s)return{changes:[],updatedInternals:l};let u=[],c=window.getComputedStyle(s),{m22:d}=new window.DOMMatrixReadOnly(c.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=nR(r.nodeElement),c=e.measured.width!==s.width||e.measured.height!==s.height;if(s.width&&s.height&&(c||!e.internals.handleBounds||r.force)){let f=r.nodeElement.getBoundingClientRect(),p=nP(e.extent)?e.extent:i,{positionAbsolute:g}=e.internals;e.parentId&&"parent"===e.extent?g=nh(g,s,t.get(e.parentId)):p&&(g=nd(g,p,s));let m={...e,measured:s,internals:{...e.internals,positionAbsolute:g,handleBounds:{source:nV("source",r.nodeElement,f,d,e.id),target:nV("target",r.nodeElement,f,d,e.id)}}};t.set(e.id,m),e.parentId&&re(m,t,n,{nodeOrigin:o,zIndexMode:a}),l=!0,c&&(u.push({id:e.id,type:"dimensions",dimensions:s}),e.expandParent&&e.parentId&&h.push({id:e.id,parentId:e.parentId,rect:nv(m,o)}))}}if(h.length>0){let e=rn(h,t,n,o);u.push(...e)}return{changes:u,updatedInternals:l}}(e,n,r,o,i,a,u);d&&(!function(e,t,n){let r=n8(n4,n);for(let n of e.values())if(n.parentId)re(n,e,t,r);else{let e=nd(no(n,r.nodeOrigin),nP(n.extent)?n.extent:r.nodeExtent,nA(n));n.internals.positionAbsolute=e}}(n,r,{nodeOrigin:i,nodeExtent:a,zIndexMode:u}),l?(m(),f({fitViewQueued:!1,fitViewOptions:void 0})):f({}),c?.length>0&&(s&&console.log("React Flow: trigger node changes",c),t?.(c)))},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),u=!!(e?.expandParent&&e?.parentId&&l?.position),c={id:i,type:"position",position:u?{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=n2(e,a.fromHandle,g.Left,!0);s({...a,from:t})}u&&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(c)}if(n.length>0){let{parentLookup:e,nodeOrigin:t}=p(),i=rn(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(or(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(or(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=>oo(e,!0))):(o(oi(r,new Set([...e]),!0)),i(oi(n)))},addSelectedEdges:e=>{let{multiSelectionActive:t,edgeLookup:n,nodeLookup:r,triggerNodeChanges:o,triggerEdgeChanges:i}=p();t?i(e.map(e=>oo(e,!0))):(i(oi(n,new Set([...e]))),o(oi(r,new Set,!0)))},unselectNodesAndEdges:({nodes:e,edges:t}={})=>{let{edges:n,nodes:r,nodeLookup:o,triggerNodeChanges:i,triggerEdgeChanges:a}=p(),s=(e||r).map(e=>{let t=o.get(e.id);return t&&(t.selected=!1),oo(e.id,!1)}),l=(t||n).map(e=>oo(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,oo(t.id,!1)]:e,[]),a=e.reduce((e,t)=>t.selected?[...e,oo(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])&&(n7(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 rr({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:{...t7}})},updateConnection:e=>{f({connection:e})},reset:()=>f({...ij()})}},p=Object.is,f?rz(f,p):rz})({nodes:e,edges:t,defaultNodes:n,defaultEdges:r,width:o,height:i,fitView:u,minZoom:a,maxZoom:s,fitViewOptions:l,nodeOrigin:c,nodeExtent:d,zIndexMode:h}));return(0,v.jsx)(rL,{value:p,children:(0,v.jsx)(of,{children:f})})}function iP({children:e,nodes:t,edges:n,defaultNodes:r,defaultEdges:o,width:i,height:a,fitView:s,fitViewOptions:l,minZoom:u,maxZoom:c,nodeOrigin:d,nodeExtent:h,zIndexMode:f}){return(0,x.useContext)(rI)?(0,v.jsx)(v.Fragment,{children:e}):(0,v.jsx)(iO,{initialNodes:t,initialEdges:n,defaultNodes:r,defaultEdges:o,initialWidth:i,initialHeight:a,fitView:s,initialFitViewOptions:l,initialMinZoom:u,initialMaxZoom:c,nodeOrigin:d,nodeExtent:h,zIndexMode:f,children:e})}let iA={width:"100%",height:"100%",overflow:"hidden",position:"relative",zIndex:0};var iz=ou(function({nodes:e,edges:t,defaultNodes:n,defaultEdges:r,className:o,nodeTypes:i,edgeTypes:a,onNodeClick:s,onEdgeClick:l,onInit:u,onMove:c,onMoveStart:p,onMoveEnd:g,onConnect:m,onConnectStart:y,onConnectEnd:b,onClickConnectStart:E,onClickConnectEnd:_,onNodeMouseEnter:k,onNodeMouseMove:S,onNodeMouseLeave:M,onNodeContextMenu:N,onNodeDoubleClick:C,onNodeDragStart:j,onNodeDrag:O,onNodeDragStop:P,onNodesDelete:A,onEdgesDelete:z,onDelete:$,onSelectionChange:I,onSelectionDragStart:L,onSelectionDrag:R,onSelectionDragStop:D,onSelectionContextMenu:B,onSelectionStart:T,onSelectionEnd:H,onBeforeDelete:V,connectionMode:F,connectionLineType:X=f.Bezier,connectionLineStyle:Y,connectionLineComponent:W,connectionLineContainerStyle:q,deleteKeyCode:K="Backspace",selectionKeyCode:Z="Shift",selectionOnDrag:G=!1,selectionMode:U=h.Full,panActivationKeyCode:Q="Space",multiSelectionKeyCode:J=nO()?"Meta":"Control",zoomActivationKeyCode:ee=nO()?"Meta":"Control",snapToGrid:et,snapGrid:en,onlyRenderVisibleElements:er=!1,selectNodesOnDrag:eo,nodesDraggable:ei,autoPanOnNodeFocus:ea,nodesConnectable:es,nodesFocusable:el,nodeOrigin:eu=r2,edgesFocusable:ec,edgesReconnectable:ed,elementsSelectable:eh=!0,defaultViewport:ef=r5,minZoom:ep=.5,maxZoom:eg=2,translateExtent:em=t6,preventScrolling:ey=!0,nodeExtent:ev,defaultMarkerColor:ex="#b1b1b7",zoomOnScroll:ew=!0,zoomOnPinch:eb=!0,panOnScroll:eE=!1,panOnScrollSpeed:e_=.5,panOnScrollMode:ek=d.Free,zoomOnDoubleClick:eS=!0,panOnDrag:eM=!0,onPaneClick:eN,onPaneMouseEnter:eC,onPaneMouseMove:ej,onPaneMouseLeave:eO,onPaneScroll:eP,onPaneContextMenu:eA,paneClickDistance:ez=1,nodeClickDistance:e$=0,children:eI,onReconnect:eL,onReconnectStart:eR,onReconnectEnd:eD,onEdgeContextMenu:eB,onEdgeDoubleClick:eT,onEdgeMouseEnter:eH,onEdgeMouseMove:eV,onEdgeMouseLeave:eF,reconnectRadius:eX=10,onNodesChange:eY,onEdgesChange:eW,noDragClassName:eq="nodrag",noWheelClassName:eK="nowheel",noPanClassName:eZ="nopan",fitView:eG,fitViewOptions:eU,connectOnClick:eQ,attributionPosition:eJ,proOptions:e0,defaultEdgeOptions:e1,elevateNodesOnSelect:e2=!0,elevateEdgesOnSelect:e5=!1,disableKeyboardA11y:e3=!1,autoPanOnConnect:e4,autoPanOnNodeDrag:e6,autoPanSpeed:e8,connectionRadius:e9,isValidConnection:e7,onError:te,style:tt,id:tn,nodeDragThreshold:tr,connectionDragThreshold:to,viewport:ti,onViewportChange:ta,width:ts,height:tl,colorMode:tu="light",debug:tc,onScroll:td,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=r9(),r=()=>n(t?.matches?"dark":"light");return r(),t?.addEventListener("change",r),()=>{t?.removeEventListener("change",r)}},[e]),null!==t?t:r9()?.matches?"dark":"light"}(tu),tv=(0,x.useCallback)(e=>{e.currentTarget.scrollTo({top:0,left:0,behavior:"instant"}),td?.(e)},[td]);return(0,v.jsx)("div",{"data-testid":"rf__wrapper",...tp,onScroll:tv,style:{...tt,...iA},ref:tg,className:w(["react-flow",o,ty]),id:tn,role:"application",children:(0,v.jsxs)(iP,{nodes:e,edges:t,width:ts,height:tl,fitView:eG,fitViewOptions:eU,minZoom:ep,maxZoom:eg,nodeOrigin:eu,nodeExtent:ev,zIndexMode:tf,children:[(0,v.jsx)(iC,{onInit:u,onNodeClick:s,onEdgeClick:l,onNodeMouseEnter:k,onNodeMouseMove:S,onNodeMouseLeave:M,onNodeContextMenu:N,onNodeDoubleClick:C,nodeTypes:i,edgeTypes:a,connectionLineType:X,connectionLineStyle:Y,connectionLineComponent:W,connectionLineContainerStyle:q,selectionKeyCode:Z,selectionOnDrag:G,selectionMode:U,deleteKeyCode:K,multiSelectionKeyCode:J,panActivationKeyCode:Q,zoomActivationKeyCode:ee,onlyRenderVisibleElements:er,defaultViewport:ef,translateExtent:em,minZoom:ep,maxZoom:eg,preventScrolling:ey,zoomOnScroll:ew,zoomOnPinch:eb,zoomOnDoubleClick:eS,panOnScroll:eE,panOnScrollSpeed:e_,panOnScrollMode:ek,panOnDrag:eM,onPaneClick:eN,onPaneMouseEnter:eC,onPaneMouseMove:ej,onPaneMouseLeave:eO,onPaneScroll:eP,onPaneContextMenu:eA,paneClickDistance:ez,nodeClickDistance:e$,onSelectionContextMenu:B,onSelectionStart:T,onSelectionEnd:H,onReconnect:eL,onReconnectStart:eR,onReconnectEnd:eD,onEdgeContextMenu:eB,onEdgeDoubleClick:eT,onEdgeMouseEnter:eH,onEdgeMouseMove:eV,onEdgeMouseLeave:eF,reconnectRadius:eX,defaultMarkerColor:ex,noDragClassName:eq,noWheelClassName:eK,noPanClassName:eZ,rfId:tm,disableKeyboardA11y:e3,nodeExtent:ev,viewport:ti,onViewportChange:ta}),(0,v.jsx)(r8,{nodes:e,edges:t,defaultNodes:n,defaultEdges:r,onConnect:m,onConnectStart:y,onConnectEnd:b,onClickConnectStart:E,onClickConnectEnd:_,nodesDraggable:ei,autoPanOnNodeFocus:ea,nodesConnectable:es,nodesFocusable:el,edgesFocusable:ec,edgesReconnectable:ed,elementsSelectable:eh,elevateNodesOnSelect:e2,elevateEdgesOnSelect:e5,minZoom:ep,maxZoom:eg,nodeExtent:ev,onNodesChange:eY,onEdgesChange:eW,snapToGrid:et,snapGrid:en,connectionMode:F,translateExtent:em,connectOnClick:eQ,defaultEdgeOptions:e1,fitView:eG,fitViewOptions:eU,onNodesDelete:A,onEdgesDelete:z,onDelete:$,onNodeDragStart:j,onNodeDrag:O,onNodeDragStop:P,onSelectionDrag:R,onSelectionDragStart:L,onSelectionDragStop:D,onMove:c,onMoveStart:p,onMoveEnd:g,noPanClassName:eZ,nodeOrigin:eu,rfId:tm,autoPanOnConnect:e4,autoPanOnNodeDrag:e6,autoPanSpeed:e8,onError:te,connectionRadius:e9,isValidConnection:e7,selectNodesOnDrag:eo,nodeDragThreshold:tr,connectionDragThreshold:to,onBeforeDelete:V,debug:tc,ariaLabelConfig:th,zIndexMode:tf}),(0,v.jsx)(r1,{onSelectionChange:I}),eI,(0,v.jsx)(rZ,{proOptions:e0,position:eJ}),(0,v.jsx)(rq,{rfId:tm,disableKeyboardA11y:e3})]})})});function i$({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 iI({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 iL={[y.Dots]:1,[y.Lines]:1,[y.Cross]:6},iR=e=>({transform:e.transform,patternId:`pattern-${e.rfId}`});function iD({id:e,variant:t=y.Dots,gap:n=20,size:r,lineWidth:o=1,offset:i=0,color:a,bgColor:s,style:l,className:u,patternClassName:c}){let d=(0,x.useRef)(null),{transform:h,patternId:f}=rD(iR,r$),p=r||iL[t],g=t===y.Dots,m=t===y.Cross,b=Array.isArray(n)?n:[n,n],E=[b[0]*h[2]||1,b[1]*h[2]||1],_=p*h[2],k=Array.isArray(i)?i:[i,i],S=m?[_,_]:E,M=[k[0]*h[2]||1+S[0]/2,k[1]*h[2]||1+S[1]/2],N=`${f}${e||""}`;return(0,v.jsxs)("svg",{className:w(["react-flow__background",u]),style:{...l,...ov,"--xy-background-color-props":s,"--xy-background-pattern-color-props":a},ref:d,"data-testid":"rf__background",children:[(0,v.jsx)("pattern",{id:N,x:h[0]%E[0],y:h[1]%E[1],width:E[0],height:E[1],patternUnits:"userSpaceOnUse",patternTransform:`translate(-${M[0]},-${M[1]})`,children:g?(0,v.jsx)(iI,{radius:_/2,className:c}):(0,v.jsx)(i$,{dimensions:S,lineWidth:o,variant:t,className:c})}),(0,v.jsx)("rect",{x:"0",y:"0",width:"100%",height:"100%",fill:`url(#${N})`})]})}iD.displayName="Background";let iB=(0,x.memo)(iD);function iT(){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 iH(){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 iV(){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 iF(){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 iX(){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 iY({children:e,className:t,...n}){return(0,v.jsx)("button",{type:"button",className:w(["react-flow__controls-button",t]),...n,children:e})}let iW=e=>({isInteractive:e.nodesDraggable||e.nodesConnectable||e.elementsSelectable,minZoomReached:e.transform[2]<=e.minZoom,maxZoomReached:e.transform[2]>=e.maxZoom,ariaLabelConfig:e.ariaLabelConfig});function iq({style:e,showZoom:t=!0,showFitView:n=!0,showInteractive:r=!0,fitViewOptions:o,onZoomIn:i,onZoomOut:a,onFitView:s,onInteractiveChange:l,className:u,children:c,position:d="bottom-left",orientation:h="vertical","aria-label":f}){let p=rB(),{isInteractive:g,minZoomReached:m,maxZoomReached:y,ariaLabelConfig:x}=rD(iW,r$),{zoomIn:b,zoomOut:E,fitView:_}=og();return(0,v.jsxs)(rK,{className:w(["react-flow__controls","horizontal"===h?"horizontal":"vertical",u]),position:d,style:e,"data-testid":"rf__controls","aria-label":f??x["controls.ariaLabel"],children:[t&&(0,v.jsxs)(v.Fragment,{children:[(0,v.jsx)(iY,{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)(iT,{})}),(0,v.jsx)(iY,{onClick:()=>{E(),a?.()},className:"react-flow__controls-zoomout",title:x["controls.zoomOut.ariaLabel"],"aria-label":x["controls.zoomOut.ariaLabel"],disabled:m,children:(0,v.jsx)(iH,{})})]}),n&&(0,v.jsx)(iY,{className:"react-flow__controls-fitview",onClick:()=>{_(o),s?.()},title:x["controls.fitView.ariaLabel"],"aria-label":x["controls.fitView.ariaLabel"],children:(0,v.jsx)(iV,{})}),r&&(0,v.jsx)(iY,{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)(iX,{}):(0,v.jsx)(iF,{})}),c]})}iq.displayName="Controls";let iK=(0,x.memo)(iq),iZ=(0,x.memo)(function({id:e,x:t,y:n,width:r,height:o,style:i,color:a,strokeColor:s,strokeWidth:l,className:u,borderRadius:c,shapeRendering:d,selected:h,onClick:f}){let{background:p,backgroundColor:g}=i||{};return(0,v.jsx)("rect",{className:w(["react-flow__minimap-node",{selected:h},u]),x:t,y:n,rx:c,ry:c,width:r,height:o,style:{fill:a||p||g,stroke:s,strokeWidth:l},shapeRendering:d,onClick:f?t=>f(t,e):void 0})}),iG=e=>e.nodes.map(e=>e.id),iU=e=>e instanceof Function?e:()=>e,iQ=(0,x.memo)(function({id:e,nodeColorFunc:t,nodeStrokeColorFunc:n,nodeClassNameFunc:r,nodeBorderRadius:o,nodeStrokeWidth:i,shapeRendering:a,NodeComponent:s,onClick:l}){let{node:u,x:c,y:d,width:h,height:f}=rD(t=>{let{internals:n}=t.nodeLookup.get(e),r=n.userNode,{x:o,y:i}=n.positionAbsolute,{width:a,height:s}=nA(r);return{node:r,x:o,y:i,width:a,height:s}},r$);return u&&!u.hidden&&nz(u)?(0,v.jsx)(s,{x:c,y:d,width:h,height:f,style:u.style,selected:!!u.selected,className:r(u),color:t(u),borderRadius:o,strokeColor:n(u),strokeWidth:i,shapeRendering:a,onClick:l,id:u.id}):null});var iJ=(0,x.memo)(function({nodeStrokeColor:e,nodeColor:t,nodeClassName:n="",nodeBorderRadius:r=5,nodeStrokeWidth:o,nodeComponent:i=iZ,onClick:a}){let s=rD(iG,r$),l=iU(t),u=iU(e),c=iU(n),d="u"<typeof window||window.chrome?"crispEdges":"geometricPrecision";return(0,v.jsx)(v.Fragment,{children:s.map(e=>(0,v.jsx)(iQ,{id:e,nodeColorFunc:l,nodeStrokeColorFunc:u,nodeClassNameFunc:c,nodeBorderRadius:r,nodeStrokeWidth:o,NodeComponent:i,onClick:a,shapeRendering:d},e))})});let i0=e=>!e.hidden,i1=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?nw(ni(e.nodeLookup,{filter:i0}),t):t,rfId:e.rfId,panZoom:e.panZoom,translateExtent:e.translateExtent,flowWidth:e.width,flowHeight:e.height,ariaLabelConfig:e.ariaLabelConfig}};function i2({style:e,className:t,nodeStrokeColor:n,nodeColor:r,nodeClassName:o="",nodeBorderRadius:i=5,nodeStrokeWidth:a,nodeComponent:s,bgColor:l,maskColor:u,maskStrokeColor:c,maskStrokeWidth:d,position:h="bottom-right",onClick:f,onNodeClick:p,pannable:g=!1,zoomable:m=!1,ariaLabel:y,inversePan:b,zoomStep:E=1,offsetScale:_=5}){let k=rB(),S=(0,x.useRef)(null),{boundingRect:M,viewBB:N,rfId:C,panZoom:j,translateExtent:O,flowWidth:P,flowHeight:A,ariaLabelConfig:z}=rD(i1,r$),$=e?.width??200,I=e?.height??150,L=Math.max(M.width/$,M.height/I),R=L*$,D=L*I,B=_*L,T=M.x-(R-M.width)/2-B,H=M.y-(D-M.height)/2-B,V=R+2*B,F=D+2*B,X=`react-flow__minimap-desc-${C}`,Y=(0,x.useRef)(0),W=(0,x.useRef)();Y.current=L,(0,x.useEffect)(()=>{if(S.current&&j)return W.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:u=!0,inversePan:c=!1}){let d=[0,0],h=t3().on("start",e=>{("mousedown"===e.sourceEvent.type||"touchstart"===e.sourceEvent.type)&&(d=[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],u=[l[0]-d[0],l[1]-d[1]];d=l;let h=r()*Math.max(s[2],Math.log(s[2]))*(c?-1:1),f={x:s[0]-u[0]*h,y:s[1]-u[1]*h};t.setViewportConstrained({x:f.x,y:f.y,zoom:s[2]},[[0,0],[i,a]],e)}:null).on("zoom.wheel",u?e=>{if("wheel"!==e.sourceEvent.type||!t)return;let r=n(),o=e.sourceEvent.ctrlKey&&nO()?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:S.current,panZoom:j,getTransform:()=>k.getState().transform,getViewScale:()=>Y.current}),()=>{W.current?.destroy()}},[j]),(0,x.useEffect)(()=>{W.current?.update({translateExtent:O,width:P,height:A,inversePan:b,pannable:g,zoomStep:E,zoomable:m})},[g,m,b,E,O,P,A]);let q=f?e=>{let[t,n]=W.current?.pointer(e)||[0,0];f(e,{x:t,y:n})}:void 0,K=p?(0,x.useCallback)((e,t)=>{p(e,k.getState().nodeLookup.get(t).internals.userNode)},[]):void 0,Z=y??z["minimap.ariaLabel"];return(0,v.jsx)(rK,{position:h,style:{...e,"--xy-minimap-background-color-props":"string"==typeof l?l:void 0,"--xy-minimap-mask-background-color-props":"string"==typeof u?u:void 0,"--xy-minimap-mask-stroke-color-props":"string"==typeof c?c:void 0,"--xy-minimap-mask-stroke-width-props":"number"==typeof d?d*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:$,height:I,viewBox:`${T} ${H} ${V} ${F}`,className:"react-flow__minimap-svg",role:"img","aria-labelledby":X,ref:S,onClick:q,children:[Z&&(0,v.jsx)("title",{id:X,children:Z}),(0,v.jsx)(iJ,{onClick:K,nodeColor:r,nodeStrokeColor:n,nodeBorderRadius:i,nodeClassName:o,nodeStrokeWidth:a,nodeComponent:s}),(0,v.jsx)("path",{className:"react-flow__minimap-mask",d:`M${T-B},${H-B}h${V+2*B}v${F+2*B}h${-V-2*B}z
2
- M${N.x},${N.y}h${N.width}v${N.height}h${-N.width}z`,fillRule:"evenodd",pointerEvents:"none"})]})})}i2.displayName="MiniMap",(0,x.memo)(i2);let i5={[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:u=Number.MAX_VALUE,maxHeight:c=Number.MAX_VALUE,keepAspectRatio:d=!1,resizeDirection:h,autoScale:f=!0,shouldResize:p,onResizeStart:g,onResize:y,onResizeEnd:b}){let E,_=oP(),k="string"==typeof e?e:_,S=rB(),M=(0,x.useRef)(null),N=n===m.Handle,C=rD((0,x.useCallback)((E=N&&f,e=>E?`${Math.max(1/e.transform[2],1)}`:void 0),[N,f]),r$),j=(0,x.useRef)(null),O=t??i5[n];(0,x.useEffect)(()=>{if(M.current&&k)return j.current||(j.current=function({domNode:e,nodeId:t,getStoreItems:n,onChange:r,onEnd:o}){let i=eh(e),a={controlDirection:rw("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:u,onResizeStart:c,onResize:d,onResizeEnd:h,shouldResize:f}){let p,g,m,y,v={...rk},x={...rS};a={boundaries:s,resizeDirection:u,keepAspectRatio:l,controlDirection:rw(e)};let w=null,b=[],E=!1,_=eM().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:u,ySnapped:d}=nL(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:u,pointerY:d,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}c?.(e,{...v})}).on("drag",e=>{let{transform:t,snapGrid:o,snapToGrid:i,nodeOrigin:s}=n(),l=nL(e.sourceEvent,{transform:t,snapGrid:o,snapToGrid:i,containerBounds:w}),u=[];if(!p)return;let{x:c,y:h,width:_,height:k}=v,S={},M=p.origin??s,{width:N,height:C,x:j,y:O}=function(e,t,n,r,o,i,a,s){var l,u,c,d;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:E}=r,{x:_,y:k,width:S,height:M,aspectRatio:N}=e,C=Math.floor(p?y-e.pointerX:0),j=Math.floor(g?v-e.pointerY:0),O=S+(h?-C:C),P=M+(f?-j:j),A=-i[0]*S,z=-i[1]*M,$=r_(O,x,w),I=r_(P,b,E);if(a){let e=0,t=0;h&&C<0?e=rb(_+C+A,a[0][0]):!h&&C>0&&(e=rE(_+O+A,a[1][0])),f&&j<0?t=rb(k+j+z,a[0][1]):!f&&j>0&&(t=rE(k+P+z,a[1][1])),$=Math.max($,e),I=Math.max(I,t)}if(s){let e=0,t=0;h&&C>0?e=rE(_+C,s[0][0]):!h&&C<0&&(e=rb(_+O,s[1][0])),f&&j>0?t=rE(k+j,s[0][1]):!f&&j<0&&(t=rb(k+P,s[1][1])),$=Math.max($,e),I=Math.max(I,t)}if(o){if(p){($=Math.max($,r_(O/N,b,E)*N),a)&&($=Math.max($,(h||f)&&(!h||f||!m)?rb(k+z+(h?C:-C)/N,a[0][1])*N:rE(k+z+O/N,a[1][1])*N));s&&($=Math.max($,(h||f)&&(!h||f||!m)?rE(k+(h?C:-C)/N,s[0][1])*N:rb(k+O/N,s[1][1])*N))}if(g){(I=Math.max(I,r_(P*N,x,w)/N),a)&&(I=Math.max(I,(h||f)&&(!f||h||!m)?rb(_+(f?j:-j)*N+A,a[0][0])/N:rE(_+P*N+A,a[1][0])/N));s&&(I=Math.max(I,(h||f)&&(!f||h||!m)?rE(_+(f?j:-j)*N,s[0][0])/N:rb(_+P*N,s[1][0])/N))}}j+=j<0?I:-I,C+=C<0?$:-$,o&&(m?O>P*N?j=((l=h,u=f,l?!u:u)?-C:C)/N:C=((c=h,d=f,c?!d:d)?-j:j)*N:p?(j=C/N,f=h):(C=j*N,h=f));let L=h?_+C:_,R=f?k+j:k;return{width:S+(h?-C:C),height:M+(f?-j:j),x:i[0]*C*(h?-1:1)+L,y:i[1]*j*(f?-1:1)+R}}(x,a.controlDirection,l,a.boundaries,a.keepAspectRatio,M,m,y),P=N!==_,A=C!==k,z=j!==c&&P,$=O!==h&&A;if(!z&&!$&&!P&&!A)return;if((z||$||1===M[0]||1===M[1])&&(S.x=z?j:v.x,S.y=$?O:v.y,v.x=S.x,v.y=S.y,b.length>0)){let e=j-c,t=O-h;for(let n of b)n.position={x:n.position.x-e+M[0]*(N-_),y:n.position.y-t+M[1]*(C-k)},u.push(n)}if((P||A)&&(S.width=P&&(!a.resizeDirection||"horizontal"===a.resizeDirection)?N:v.width,S.height=A&&(!a.resizeDirection||"vertical"===a.resizeDirection)?C:v.height,v.width=S.width,v.height=S.height),g&&p.expandParent){let e=M[0]*(S.width??0);S.x&&S.x<e&&(v.x=e,x.x=x.x-(S.x-e));let t=M[1]*(S.height??0);S.y&&S.y<t&&(v.y=t,x.y=x.y-(S.y-t))}let I=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:_,height:v.height,prevHeight:k,affectsX:a.controlDirection.affectsX,affectsY:a.controlDirection.affectsY}),L={...v,direction:I};!1!==f?.(e,L)&&(E=!0,d?.(e,L),r(S,u))}).on("end",e=>{E&&(h?.(e,{...v}),o?.({...v}),E=!1)});i.call(_)},destroy:function(){i.on(".drag",null)}}}({domNode:M.current,nodeId:k,getStoreItems:()=>{let{nodeLookup:e,transform:t,snapGrid:n,snapToGrid:r,nodeOrigin:o,domNode:i}=S.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}=S.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,u=e.height??l.measured.height??0,c=rn([{id:l.id,parentId:l.parentId,rect:{width:n,height:u,...n$({x:e.x??l.position.x,y:e.y??l.position.y},{width:n,height:u},l.parentId,r,t)}}],r,o,i);a.push(...c),s.x=e.x?Math.max(t[0]*n,e.x):void 0,s.y=e.y?Math.max(t[1]*u,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})=>{S.getState().triggerNodeChanges([{id:k,type:"dimensions",resizing:!1,dimensions:{width:e,height:t}}])}})),j.current.update({controlPosition:O,boundaries:{minWidth:s,minHeight:l,maxWidth:u,maxHeight:c},keepAspectRatio:d,resizeDirection:h,onResizeStart:g,onResize:y,onResizeEnd:b,shouldResize:p}),()=>{j.current?.destroy()}},[O,s,l,u,c,d,g,y,b,p]);let P=O.split("-");return(0,v.jsx)("div",{className:w(["react-flow__resize-control","nodrag",...P,n,r]),ref:M,style:{...o,scale:C,...a&&{[N?"backgroundColor":"borderColor"]:a}},children:i})});var i3=e.i(65825),i4=e.i(75254);let i6=(0,i4.default)("server",[["rect",{width:"20",height:"8",x:"2",y:"2",rx:"2",ry:"2",key:"ngkwjq"}],["rect",{width:"20",height:"8",x:"2",y:"14",rx:"2",ry:"2",key:"iecqi9"}],["line",{x1:"6",x2:"6.01",y1:"6",y2:"6",key:"16zg32"}],["line",{x1:"6",x2:"6.01",y1:"18",y2:"18",key:"nzw8ys"}]]),i8=(0,i4.default)("globe",[["circle",{cx:"12",cy:"12",r:"10",key:"1mglay"}],["path",{d:"M12 2a14.5 14.5 0 0 0 0 20 14.5 14.5 0 0 0 0-20",key:"13o1zl"}],["path",{d:"M2 12h20",key:"9i4pu4"}]]);var i9=e.i(70583);function i7({className:e,...t}){return(0,v.jsx)("div",{"data-slot":"card",className:(0,i9.cn)("bg-card text-card-foreground flex flex-col gap-6 rounded-xl border py-6",e),...t})}function ae({className:e,...t}){return(0,v.jsx)("div",{"data-slot":"card-content",className:(0,i9.cn)("px-6",e),...t})}var at=e.i(91918);let an=(0,e.i(25913).cva)("inline-flex items-center justify-center rounded-full border px-2 py-0.5 text-xs font-medium w-fit whitespace-nowrap shrink-0 [&>svg]:size-3 gap-1 [&>svg]:pointer-events-none focus-visible:border-ring focus-visible:ring-ring/50 focus-visible:ring-[3px] aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive transition-[color,box-shadow] overflow-hidden",{variants:{variant:{default:"border-transparent bg-primary text-primary-foreground [a&]:hover:bg-primary/90",secondary:"border-transparent bg-secondary text-secondary-foreground [a&]:hover:bg-secondary/90",destructive:"border-transparent bg-destructive text-white [a&]:hover:bg-destructive/90 focus-visible:ring-destructive/20 dark:focus-visible:ring-destructive/40 dark:bg-destructive/60",outline:"text-foreground [a&]:hover:bg-accent [a&]:hover:text-accent-foreground"}},defaultVariants:{variant:"default"}});function ar({className:e,variant:t,asChild:n=!1,...r}){let o=n?at.Slot:"span";return(0,v.jsx)(o,{"data-slot":"badge",className:(0,i9.cn)(an({variant:t}),e),...r})}let ao=(0,i4.default)("zap",[["path",{d:"M4 14a1 1 0 0 1-.78-1.63l9.9-10.2a.5.5 0 0 1 .86.46l-1.92 6.02A1 1 0 0 0 13 10h7a1 1 0 0 1 .78 1.63l-9.9 10.2a.5.5 0 0 1-.86-.46l1.92-6.02A1 1 0 0 0 11 14z",key:"1xq2db"}]]),ai={service:function({data:e}){return(0,v.jsxs)(i7,{className:"min-w-[140px] border-gray-200 bg-white py-0 gap-0 overflow-hidden",children:[(0,v.jsx)(oz,{type:"target",position:g.Left,id:"left",className:e.hasIncoming?"!bg-[#2366EC] !w-2 !h-2":"!opacity-0 !w-1 !h-1"}),(0,v.jsx)(oz,{type:"source",position:g.Right,id:"right-source",className:e.hasOutgoing?"!bg-[#2366EC] !w-2 !h-2":"!opacity-0 !w-1 !h-1"}),(0,v.jsx)(ae,{className:"p-2.5",children:(0,v.jsxs)("div",{className:"flex items-center gap-2",children:[(0,v.jsx)(i6,{className:"w-4 h-4 text-gray-500 shrink-0"}),(0,v.jsx)("span",{className:"font-medium text-sm text-foreground truncate",children:e.name}),(0,v.jsx)(ar,{variant:"secondary",className:"text-[10px] px-1.5 py-0 ml-auto",children:"Service"})]})}),e.exposed&&(0,v.jsxs)("div",{className:"border-t border-gray-100 bg-gray-50 px-2.5 py-1 text-[10px] text-gray-500 flex items-center gap-1",children:[(0,v.jsx)(i8,{className:"w-3 h-3"}),(0,v.jsx)("span",{children:"Public"})]})]})},postgres:function({data:e}){return(0,v.jsxs)(i7,{className:"min-w-[140px] border-gray-200 bg-white py-0 gap-0 overflow-hidden",children:[(0,v.jsx)(oz,{type:"target",position:g.Left,id:"left",className:e.hasIncoming?"!bg-[#2366EC] !w-2 !h-2":"!opacity-0 !w-1 !h-1"}),(0,v.jsx)(ae,{className:"p-2.5",children:(0,v.jsxs)("div",{className:"flex items-center gap-2",children:[(0,v.jsxs)("svg",{className:"w-4 h-4 text-gray-500 shrink-0",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",children:[(0,v.jsx)("ellipse",{cx:"12",cy:"5",rx:"9",ry:"3"}),(0,v.jsx)("path",{d:"M21 12c0 1.66-4 3-9 3s-9-1.34-9-3"}),(0,v.jsx)("path",{d:"M3 5v14c0 1.66 4 3 9 3s9-1.34 9-3V5"})]}),(0,v.jsx)("span",{className:"font-medium text-sm text-foreground truncate",children:e.name}),(0,v.jsx)(ar,{variant:"secondary",className:"text-[10px] px-1.5 py-0 ml-auto",children:"Postgres"})]})}),e.syncEnabled&&(0,v.jsxs)("div",{className:"border-t border-gray-100 bg-gray-50 px-2.5 py-1 text-[10px] text-gray-500 flex items-center gap-1",children:[(0,v.jsx)(ao,{className:"w-3 h-3"}),(0,v.jsx)("span",{children:"Sync"})]}),(0,v.jsx)(oz,{type:"source",position:g.Right,className:e.hasOutgoing?"!bg-[#2366EC] !w-2 !h-2":"!opacity-0 !w-1 !h-1"})]})},redis:function({data:e}){return(0,v.jsxs)(i7,{className:"min-w-[140px] border-gray-200 bg-white py-0",children:[(0,v.jsx)(oz,{type:"target",position:g.Left,id:"left",className:e.hasIncoming?"!bg-[#2366EC] !w-2 !h-2":"!opacity-0 !w-1 !h-1"}),(0,v.jsx)(ae,{className:"p-2.5",children:(0,v.jsxs)("div",{className:"flex items-center gap-2",children:[(0,v.jsx)("svg",{className:"w-4 h-4 text-gray-500 shrink-0",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",children:(0,v.jsx)("path",{d:"M13 2L3 14h9l-1 8 10-12h-9l1-8z"})}),(0,v.jsx)("span",{className:"font-medium text-sm text-foreground truncate",children:e.name}),(0,v.jsx)(ar,{variant:"secondary",className:"text-[10px] px-1.5 py-0 ml-auto",children:"Redis"})]})}),(0,v.jsx)(oz,{type:"source",position:g.Right,className:e.hasOutgoing?"!bg-[#2366EC] !w-2 !h-2":"!opacity-0 !w-1 !h-1"})]})},storage:function({data:e}){return(0,v.jsxs)(i7,{className:"min-w-[140px] border-gray-200 bg-white py-0",children:[(0,v.jsx)(oz,{type:"target",position:g.Left,id:"left",className:e.hasIncoming?"!bg-[#2366EC] !w-2 !h-2":"!opacity-0 !w-1 !h-1"}),(0,v.jsx)(ae,{className:"p-2.5",children:(0,v.jsxs)("div",{className:"flex items-center gap-2",children:[(0,v.jsx)("svg",{className:"w-4 h-4 text-gray-500 shrink-0",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",children:(0,v.jsx)("path",{d:"M22 19a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2V5a2 2 0 0 1 2-2h5l2 3h9a2 2 0 0 1 2 2z"})}),(0,v.jsx)("span",{className:"font-medium text-sm text-foreground truncate",children:e.name}),(0,v.jsx)(ar,{variant:"secondary",className:"text-[10px] px-1.5 py-0 ml-auto",children:"Storage"})]})}),(0,v.jsx)(oz,{type:"source",position:g.Right,className:e.hasOutgoing?"!bg-[#2366EC] !w-2 !h-2":"!opacity-0 !w-1 !h-1"})]})}};function aa({services:e,resources:t}){let{nodes:n,edges:r}=(0,x.useMemo)(()=>{let n,r=[],o=[],i=new Set,a=new Set;return e.forEach(e=>{if(e.env)for(let t of Object.values(e.env))"object"==typeof t&&null!==t&&(("postgres"===t.type||"redis"===t.type||"storage"===t.type)&&(a.add(`service-${e.name}`),i.add(`resource-${t.name}`)),"service"===t.type&&t.serviceName!==e.name&&(a.add(`service-${e.name}`),i.add(`service-${t.serviceName}`)))}),t.forEach(e=>{let t=`resource-${e.name}`;r.push({id:t,type:e.type,position:{x:0,y:0},data:{name:e.name,port:e.port,syncEnabled:e.syncEnabled,hasIncoming:i.has(t),hasOutgoing:a.has(t)},draggable:!1,selectable:!1})}),e.forEach(e=>{let t=`service-${e.name}`;if(r.push({id:t,type:"service",position:{x:0,y:0},data:{name:e.name,port:e.port,exposed:e.exposed,hasIncoming:i.has(t),hasOutgoing:a.has(t)},draggable:!1,selectable:!1}),e.env){let n=new Set,r=new Set;for(let t of Object.values(e.env))"object"==typeof t&&null!==t&&(("postgres"===t.type||"redis"===t.type||"storage"===t.type)&&n.add(`${t.type}-${t.name}`),"service"===t.type&&r.add(t.serviceName));n.forEach(n=>{let[,r]=n.split("-");o.push({id:`edge-${e.name}-${r}`,source:t,sourceHandle:"right-source",target:`resource-${r}`,targetHandle:"left",animated:!0,style:{stroke:"#2366EC",strokeWidth:2}})}),r.forEach(n=>{n!==e.name&&o.push({id:`edge-svc-${e.name}-${n}`,source:t,sourceHandle:"right-source",target:`service-${n}`,targetHandle:"left",animated:!0,style:{stroke:"#2366EC",strokeWidth:2}})})}}),(n=new i3.default.graphlib.Graph().setDefaultEdgeLabel(()=>({}))).setGraph({rankdir:"LR",nodesep:50,ranksep:100,marginx:30,marginy:30}),r.forEach(e=>{n.setNode(e.id,{width:160,height:60})}),o.forEach(e=>{n.setEdge(e.source,e.target)}),i3.default.layout(n),{nodes:r.map(e=>{let t=n.node(e.id);return{...e,position:{x:t.x-80,y:t.y-30}}}),edges:o}},[e,t]);return(0,v.jsx)("div",{className:"w-full h-full overflow-hidden bg-gray-50",children:(0,v.jsxs)(iz,{nodes:n,edges:r,nodeTypes:ai,fitView:!0,fitViewOptions:{padding:.5},proOptions:{hideAttribution:!0},nodesDraggable:!1,nodesConnectable:!1,elementsSelectable:!1,panOnDrag:!0,zoomOnScroll:!0,children:[(0,v.jsx)(iB,{variant:y.Dots,color:"#d1d5db",gap:12,size:1}),(0,v.jsx)(iK,{showInteractive:!1,className:"!bg-card !border-border [&>button]:!bg-card [&>button]:!border-border [&>button]:!text-foreground [&>button:hover]:!bg-muted"})]})})}var as=e.i(94519),al=e.i(84220),au=e.i(35014);function ac(){let[e,t]=(0,x.useState)(null),[n,r]=(0,x.useState)(null),[o,i]=(0,x.useState)(!1),a=(0,x.useMemo)(()=>(0,au.getInstanceKey)(),[]);(0,x.useEffect)(()=>{async function e(){try{let e=await fetch("/api/state");if(!e.ok)throw Error("Failed to fetch state");let n=await e.json();t(n),i(!0),r(null)}catch(e){r(e instanceof Error?e.message:"Unknown error"),i(!1)}}e();let n=setInterval(e,2e3);return()=>clearInterval(n)},[]);let s=e&&(e.services.length>0||e.resources.length>0),l=e?.resources.some(e=>"postgres"===e.type)??!1;return(0,v.jsxs)(al.SidebarProvider,{children:[(0,v.jsx)(as.AppSidebar,{connected:o,currentPage:"architecture",hasDatabases:l,instanceKey:a}),(0,v.jsx)(al.SidebarInset,{className:"flex flex-col h-screen border-l border-border",children:(0,v.jsx)("main",{className:"flex-1 overflow-hidden bg-gray-50",children:n?(0,v.jsx)("div",{className:"p-6",children:(0,v.jsx)("div",{className:"p-6 rounded-lg bg-destructive/10 border border-destructive/20",children:(0,v.jsxs)("p",{className:"text-destructive",children:["Error: ",n]})})}):e?s?(0,v.jsx)(aa,{services:e.services,resources:e.resources}):(0,v.jsx)("div",{className:"p-6",children:(0,v.jsxs)("div",{className:"p-6 rounded-lg bg-card border border-border text-center",children:[(0,v.jsx)("p",{className:"text-muted-foreground",children:"No services or resources configured."}),(0,v.jsx)("p",{className:"text-sm text-muted-foreground mt-1",children:"Add services and databases to your specific.hcl to see them here."})]})}):(0,v.jsx)("div",{className:"p-6",children:(0,v.jsx)("div",{className:"p-6 rounded-lg bg-card border border-border",children:(0,v.jsx)("p",{className:"text-muted-foreground",children:"Connecting to dev server..."})})})})})]})}e.s(["default",()=>ac],68613)}]);