@next-bricks/diagram 0.54.8 → 0.55.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (33) hide show
  1. package/dist/bricks.json +1 -1
  2. package/dist/chunks/8552.b1182b74.js +2 -0
  3. package/dist/chunks/8552.b1182b74.js.map +1 -0
  4. package/dist/chunks/9711.6546e794.js +2 -0
  5. package/dist/chunks/9711.6546e794.js.map +1 -0
  6. package/dist/chunks/editable-label.dac00113.js +3 -0
  7. package/dist/chunks/{editable-label.a7b497ee.js.map → editable-label.dac00113.js.map} +1 -1
  8. package/dist/chunks/eo-draw-canvas.8d6f455b.js +2 -0
  9. package/dist/chunks/eo-draw-canvas.8d6f455b.js.map +1 -0
  10. package/dist/chunks/{main.2a59de7e.js → main.3da92bd7.js} +2 -2
  11. package/dist/chunks/{main.2a59de7e.js.map → main.3da92bd7.js.map} +1 -1
  12. package/dist/examples.json +3 -3
  13. package/dist/index.415b685f.js +2 -0
  14. package/dist/{index.a0bd8d53.js.map → index.415b685f.js.map} +1 -1
  15. package/dist/manifest.json +40 -40
  16. package/dist/types.json +104 -0
  17. package/dist-types/draw-canvas/CellComponent.d.ts +4 -2
  18. package/dist-types/draw-canvas/EditingLineComponent.d.ts +2 -1
  19. package/dist-types/draw-canvas/HoverStateContext.d.ts +2 -2
  20. package/dist-types/draw-canvas/LineConnectorComponent.d.ts +2 -1
  21. package/dist-types/draw-canvas/LineEditorComponent.d.ts +4 -2
  22. package/dist-types/draw-canvas/interfaces.d.ts +4 -0
  23. package/dist-types/draw-canvas/processors/handleMouseDown.d.ts +3 -2
  24. package/package.json +2 -2
  25. package/dist/chunks/8552.0c89d62a.js +0 -2
  26. package/dist/chunks/8552.0c89d62a.js.map +0 -1
  27. package/dist/chunks/9711.d48f441d.js +0 -2
  28. package/dist/chunks/9711.d48f441d.js.map +0 -1
  29. package/dist/chunks/editable-label.a7b497ee.js +0 -3
  30. package/dist/chunks/eo-draw-canvas.2f912dba.js +0 -2
  31. package/dist/chunks/eo-draw-canvas.2f912dba.js.map +0 -1
  32. package/dist/index.a0bd8d53.js +0 -2
  33. /package/dist/chunks/{editable-label.a7b497ee.js.LICENSE.txt → editable-label.dac00113.js.LICENSE.txt} +0 -0
package/dist/bricks.json CHANGED
@@ -16,5 +16,5 @@
16
16
  "basic.lock-body-scroll"
17
17
  ]
18
18
  },
19
- "filePath": "bricks/diagram/dist/index.a0bd8d53.js"
19
+ "filePath": "bricks/diagram/dist/index.415b685f.js"
20
20
  }
@@ -0,0 +1,2 @@
1
+ "use strict";(globalThis.webpackChunk_next_bricks_diagram=globalThis.webpackChunk_next_bricks_diagram||[]).push([[8552],{6787:(e,t,n)=>{n.d(t,{m:()=>D});var o=n(8769),r=n.n(o),i=n(3373),l=n.n(i),a=n(531),c=n(1030),s=n(9126),d=n(3033),u=n(8653),v=n(7531),f=n(2716),h=n(3848);function m(e){let{edge:t,position:n,offset:o,label:i,text:a,onRendered:c,onClick:s}=e;if(!i&&!a)return null;const d=!(!n||!o);return r().createElement("foreignObject",{className:l()("line-label-container",{ready:d}),x:d?n[0]+o[0]:0,y:d?n[1]+o[1]:0,onClick:s},i?r().createElement("div",{className:"line-label label"},r().createElement(p,{edge:t,label:i,onRendered:c})):r().createElement(g,{text:a,onRendered:c}))}function g(e){let{text:t,onRendered:n}=e;const i=(0,o.useCallback)((e=>{null==n||n(e)}),[n]);return r().createElement("div",{className:"line-label text",ref:i,style:t.style},t.content)}function p(e){let{edge:t,label:n,onRendered:i}=e;const l=(0,o.useMemo)((()=>(0,f.checkIfOfComputed)(n)?n.useBrick:null),[n]),a=(0,o.useMemo)((()=>({edge:t})),[t]);(0,o.useEffect)((()=>{l||setTimeout((()=>{null==i||i(null)}))}),[i,l]),(0,o.useEffect)((()=>()=>{null==i||i(null)}),[]);const c=(0,o.useCallback)((e=>{e&&setTimeout((()=>{null==i||i(e.parentElement)}))}),[i]),s=(0,o.useCallback)((()=>{setTimeout((()=>{null==i||i(null)}))}),[i]);return l?r().createElement(h.ReactUseBrick,{refCallback:c,ignoredCallback:s,useBrick:l,data:a}):null}var y=n(9386);function w(e){var t,n,i,a,f,h,g;let{edge:p,lineConfMap:w,editableLineMap:x,readOnly:E,active:k,activeRelated:b,onSwitchActiveTarget:C}=e;const M=(0,o.useRef)(null),I=w.get(p),{points:S}=null!==(t=x.get(p))&&void 0!==t?t:{},L=(0,o.useMemo)((()=>(0,u.S)(S,"curve"===I.type?I.curveType:"curveLinear",0,1)),[I,S]),z=(0,o.useMemo)((()=>(0,c.uniqueId)("line-mask-")),[]),[P,R]=(0,o.useState)(null),[N,A]=(0,o.useState)(null),[T,H]=(0,o.useState)(null),D=(0,o.useCallback)((()=>{const e=M.current,{label:t,text:n}=I;if(e&&S&&(t||n)){var o,r;const i=null!==(o=t?t.placement:n.placement)&&void 0!==o?o:"center",l=e.getTotalLength(),a=l/2,c=e.getPointAtLength("start"===i?Math.min(0,a):"end"===i?Math.max(l-0,a):a);let s="center",d=0;if("start"===i||"end"===i){let e,t;"start"===i?(e=S[0],t=S[1]):(e=S[S.length-1],t=S[S.length-2]),d=Math.atan2(t.y-e.y,t.x-e.x),s=Math.abs(e.x-t.x)>Math.abs(e.y-t.y)?e.x>t.x?"left":"right":e.y>t.y?"top":"bottom"}const u=null!==(r=t?t.offset:n.offset)&&void 0!==r?r:0;R([c.x,c.y,s,d,u]);const v=e.getBBox();H({x:v.x-1e3,y:v.y-1e3,width:v.width+2e3,height:v.height+2e3})}}),[I,S]),[W,Z]=(0,o.useState)(null),$=(0,o.useCallback)((e=>{if(M.current=e,e){var t,n,o;Z(null!==(t=null===(n=e.getTotalLength)||void 0===n?void 0:n.call(e))&&void 0!==t?t:100);const r=null===(o=e.getBBox)||void 0===o?void 0:o.call(e);p.view={...p.view,x:null==r?void 0:r.x,y:null==r?void 0:r.y,width:null==r?void 0:r.width,height:null==r?void 0:r.height}}D()}),[D,p]),[B,j]=(0,o.useState)(null);(0,o.useEffect)((()=>{if(!B)return void A(null);const e=new s.A((()=>{const{offsetWidth:e,offsetHeight:t}=B;A(0!==e&&0!==t?[e,t]:null)}));return e.observe(B),()=>{e.disconnect()}}),[B]);const O=(0,o.useCallback)((e=>{j(e)}),[]);(0,o.useEffect)((()=>{D()}),[D,S]);const U=(0,o.useCallback)((()=>{null==C||C((0,y.P)(p))}),[p,C]),V=(0,o.useCallback)((e=>{var t,n;!E&&I.callLabelOnDoubleClick&&(e.preventDefault(),e.stopPropagation(),null==B||null===(t=B.firstElementChild)||void 0===t||null===(n=t[I.callLabelOnDoubleClick])||void 0===n||n.call(t))}),[B,I,E]),[G,X]=(0,o.useMemo)((()=>function(e,t){if(!e||!t)return[null,null];const[n,o,r,i,l]=e,[a,c]=t,s=n-a/2-3,d=o-c/2-3;let u=0,v=0;const f=a/2+3,h=c/2+3;switch(r){case"top":u=l*Math.cos(i)-h/Math.tan(i),v=l*Math.sin(i)-h;break;case"bottom":u=l*Math.cos(i)+h/Math.tan(i),v=l*Math.sin(i)+h;break;case"left":u=l*Math.cos(i)-f,v=l*Math.sin(i)-f*Math.tan(i);break;case"right":u=l*Math.cos(i)+f,v=l*Math.sin(i)+f*Math.tan(i)}return[{left:s+u,top:d+v,width:a+6,height:c+6},[u,v]]}(P,N)),[P,N]),Y=(0,o.useMemo)((()=>{if(!G||!T)return null;const e=T.x+T.width,t=T.y+T.height,n=G.left+G.width,o=G.top+G.height;return[[G.left,o],[n,o],[n,G.top],[G.left,G.top],[G.left,T.y],[e,T.y],[e,t],[T.x,t],[T.x,T.y],[G.left,T.y]].map((e=>e.join(","))).join(" ")}),[T,G]);if(!L||!S)return null;let F,Q,J,K,_;const q=(0,v.I)(I);if(k){var ee,te,ne;const e=null===(ee=I.overrides)||void 0===ee?void 0:ee.active;J=null!==(te=null==e?void 0:e.strokeColor)&&void 0!==te?te:I.strokeColor,K=null!==(ne=null==e?void 0:e.strokeWidth)&&void 0!==ne?ne:I.strokeWidth,_=null==e?void 0:e.motion;for(const e of q){var oe,re;"start"===e.placement?F=null!==(oe=I.$activeMarkerStartUrl)&&void 0!==oe?oe:I.$markerStartUrl:Q=null!==(re=I.$activeMarkerEndUrl)&&void 0!==re?re:I.$markerEndUrl}}else if(b){var ie,le,ae;const e=null===(ie=I.overrides)||void 0===ie?void 0:ie.activeRelated;J=null!==(le=null==e?void 0:e.strokeColor)&&void 0!==le?le:I.strokeColor,K=null!==(ae=null==e?void 0:e.strokeWidth)&&void 0!==ae?ae:I.strokeWidth,_=null==e?void 0:e.motion;for(const e of q){var ce,se;"start"===e.placement?F=null!==(ce=I.$activeRelatedMarkerStartUrl)&&void 0!==ce?ce:I.$markerStartUrl:Q=null!==(se=I.$activeRelatedMarkerEndUrl)&&void 0!==se?se:I.$markerEndUrl}}else{J=I.strokeColor,K=I.strokeWidth;for(const e of q)"start"===e.placement?F=I.$markerStartUrl:Q=I.$markerEndUrl}let de,ue;if("dot"===(null===(n=_)||void 0===n?void 0:n.shape)){const e=null==_.size?2*K:_.size/2;de=`M 0,${-e} A ${e},${e} 0,1,1 0,${e} A ${e},${e} 0,1,1 0,${-e} z`}else if("triangle"===(null===(i=_)||void 0===i?void 0:i.shape)){const e=null==_.size?2*K:_.size/2,t=e/Math.sqrt(3);de=`M ${-t},${e} v ${2*-e} L ${2*t},0 z`}var ve,fe;W&&(ue=W/(null!==(ve=null===(fe=_)||void 0===fe?void 0:fe.speed)&&void 0!==ve?ve:d.Jo)+"s");const he=[null===(a=I.overrides)||void 0===a||null===(a=a.active)||void 0===a||null===(a=a.motion)||void 0===a?void 0:a.shape,null===(f=I.overrides)||void 0===f||null===(f=f.activeRelated)||void 0===f||null===(f=f.motion)||void 0===f?void 0:f.shape].some((e=>"dot"===e||"triangle"===e)),me=Y?`url(#${z})`:void 0;return r().createElement(r().Fragment,null,Y&&r().createElement("defs",null,r().createElement("clipPath",{id:z},r().createElement("polygon",{points:Y}))),r().createElement("g",{className:"line-group",onDoubleClick:V},r().createElement("path",{d:L,fill:"none",stroke:"transparent",strokeWidth:I.interactStrokeWidth,clipPath:me}),r().createElement("path",{ref:$,className:l()("line",{dashed:I.dashed,dotted:I.dotted,[(I.dashed?"dashed":I.dotted?"dotted":"solid")+"-animation"]:I.animate.useAnimate}),clipPath:me,style:{"--time":`${null!==(h=I.animate.duration)&&void 0!==h?h:d.Be}s`,"--solid-length":W},d:L,fill:"none",stroke:J,strokeWidth:K,markerStart:F,markerEnd:Q}),!(null!==(g=I.overrides)&&void 0!==g&&g.active)&&r().createElement("path",{className:"line-active-bg",d:L,fill:"none",clipPath:me}),he&&ue&&r().createElement("path",{className:l()("motion",{visible:!!de}),d:de,fill:J},r().createElement("animateMotion",{dur:ue,repeatCount:"indefinite",rotate:"auto",path:L}))),r().createElement(m,{edge:p,position:P,offset:X,label:I.label,text:I.text,onClick:U,onRendered:O}))}function x(e){let{node:t,degraded:n,degradedNodeLabel:i,defaultNodeBricks:l,onResize:a}=e;const d=function(e){const[t,n]=(0,o.useState)(e);return(0,o.useEffect)((()=>{n((t=>(0,c.isEqual)(t,e)?t:e))}),[e]),t}({node:{id:t.id,data:t.data}}),u=t.useBrick,v=(0,o.useRef)(null),m=(0,o.useMemo)((()=>{var e;return n?null:null!=u?u:null==l||null===(e=l.find((e=>(0,f.checkIfByTransform)(e,d))))||void 0===e?void 0:e.useBrick}),[n,u,l,d]),g=(0,o.useMemo)((()=>n?String(f.__secret_internals.legacyDoTransform(d,null!=i?i:"<% DATA.node.id %>")):""),[n,i,d]),p=(0,o.useCallback)((e=>{const n=v.current;n&&(n.disconnect(),v.current=null),e?setTimeout((()=>{const n=new s.A((()=>{a(t.id,[e.offsetWidth,e.offsetHeight])}));n.observe(e),v.current=n})):a(t.id,null)}),[t.id,a]),y=(0,o.useCallback)((e=>{if(e){const n=e.getBBox();a(t.id,[n.width,n.height])}else a(t.id,null)}),[t.id,a]);return m?r().createElement("foreignObject",{width:9999,height:9999,className:"node"},m&&r().createElement(h.ReactUseBrick,{useBrick:m,data:d,refCallback:p})):n?r().createElement("g",{className:"degraded",ref:y},r().createElement("circle",{cx:8,cy:8,r:8}),r().createElement("text",{x:8,y:32},g)):null}const E=["center","top","bottom","left","right"];function k(e,t){const n={};for(const i of null!==(o=null==t||null===(r=t.split(/\s+/g))||void 0===r?void 0:r.flatMap((e=>"all"===e?E:e)))&&void 0!==o?o:[]){var o,r;let t;const l=e.x+e.width/2,a=e.y+e.height/2;switch(i){case"center":t=[l,a];break;case"top":t=[l,e.y];break;case"right":t=[e.x+e.width,a];break;case"bottom":t=[l,e.y+e.height];break;case"left":t=[e.x,a];break;default:throw new Error(`Unknown snap position: "${i}"`)}n[i]=t}return n}var b=n(8185),C=n(4197);const M=["left","center","right"],I=["top","center","bottom"];function S(e,t){var n;let{action:o,cell:r,scale:i,layout:l,layoutOptions:c,activeTarget:s,cells:u,onCellsMoving:v,onCellsMoved:f,onCellResizing:h,onCellResized:m,onSwitchActiveTarget:g,updateCurActiveEditableEdge:p}=t;e.stopPropagation();const w=(0,C.Q)(r,s);if(e.shiftKey){const e=s?"multi"===(null==s?void 0:s.type)?s.targets:[s]:[];let t=[];w?t=e.filter((e=>!(0,b.c)(e,r))):(t=[...e,r],"edge"===r.type&&(null==p||p(r))),null==g||g(t.length>0?{type:"multi",targets:t}:null)}else"resize"!==o&&w||(null==g||g((0,y.P)(r)),"edge"===r.type&&(null==p||p(r)));if((0,a.WW)(r))return;const x=[],E="multi"===(null==s?void 0:s.type)&&"move"===o?u.filter((e=>(0,C.Q)(e,s))):[r];E.forEach((e=>{x.push(e),"move"===o&&(0,a.t2)(e)&&x.push(...u.filter((t=>(0,a.N)(t)&&t.containerId===e.id&&!E.includes(t))))}));const S="force"===l||"dagre"===l,L=x.filter((e=>(0,a.N)(e)&&!S||(0,a.mH)(e)));if(0===L.length)return;const z=function(e){var t,n,o;const r=e?!0===e?{grid:!0,object:!0}:e:null,i=null!=r&&r.grid?!0===r.grid?{}:r.grid:null,l=null!=r&&r.object?!0===r.object?{}:r.object:null;return{grid:i?{size:null!==(t=i.size)&&void 0!==t?t:d.gx}:null,object:l?{distance:null!==(n=l.distance)&&void 0!==n?n:d.ld,positions:null!==(o=l.positions)&&void 0!==o?o:d.o5}:null}}(null==c?void 0:c.snap),P=null===(n=z.object)||void 0===n?void 0:n.positions,R=[e.clientX,e.clientY],N=L.map((e=>({cell:e,position:"move"===o?[e.view.x,e.view.y]:[e.view.width,e.view.height],snapPositions:"move"!==o||(0,a.WW)(e)?null:k(e.view,P)}))),A=N[0].position;let T=N.map((e=>{let{position:t}=e;return t})),H=[];if("move"===o&&z.object){const e=u.filter((e=>!(0,a.WW)(e)&&!x.includes(e)));H=e.map((e=>({cell:e,snapPositions:k(e.view,P)})))}let D=!1;const W=(e,t)=>{const n=function(e){return[(e.clientX-R[0])/i,(e.clientY-R[1])/i]}(e);let l,c,s,d,u;if(!z.grid&&!z.object||e.altKey)l=N.map((e=>{let{position:t}=e;return[t[0]+n[0],t[1]+n[1]]})),D||(D=n[0]**2+n[1]**2>=9);else{let e=1/0,t=1/0;const o=[...n];if(z.object){const r=z.object.distance;let i,l,a,v,f=0,h=0;for(const{cell:c,snapPositions:s}of H)for(const{cell:m,snapPositions:g}of N)for(const[p,y]of Object.entries(g)){const g=M.includes(p),w=I.includes(p),[x,E]=s[p],[k,b]=y;if(g){const t=Math.abs(k+n[0]-x);t<r&&t<e&&(e=t,o[0]=x-k,d=m,a=c,i=[x,E],f=b)}if(w){const e=Math.abs(b+n[1]-E);e<r&&e<t&&(t=e,o[1]=E-b,u=m,v=c,l=[x,E],h=k)}}if(a&&a===v){const e=a.view.height/2,t=a.view.width/2;c=[[i[0],i[1]-e],[i[0],i[1]+e]],s=[[l[0]-t,l[1]],[l[0]+t,l[1]]]}else i&&(c=[i,[i[0],f+o[1]]]),l&&(s=[l,[h+o[0],l[1]]])}if(z.grid){const r=z.grid.size,i=[Math.round((A[0]+n[0])/r)*r,Math.round((A[1]+n[1])/r)*r],l=[i[0]-A[0],i[1]-A[1]],a=Math.abs(l[0]-n[0]),v=Math.abs(l[1]-n[1]);a<e&&(e=a,o[0]=l[0],c=void 0,d=void 0),v<t&&(t=v,o[1]=l[1],s=void 0,u=void 0)}l=N.map((e=>{let{position:t}=e;return[Math.round(t[0]+o[0]),Math.round(t[1]+o[1])]})),(l[0][0]!==T[0][0]||l[0][1]!==T[0][1])&&(T=l,D=!0)}if(D)if("move"===o){var g;const e=N.map(((e,n)=>{let{cell:o}=e;return{type:o.type,id:o.id,x:l[n][0],y:l[n][1],width:o.view.width,height:o.view.height,decorator:(0,a.mH)(o)?o.decorator:void 0,guideLines:t?void 0:[...d===o?[c]:[],...u===o?[s]:[]]}}));null===(g=t?f:v)||void 0===g||g(e)}else{var p;null===(p=t?m:h)||void 0===p||p({type:r.type,id:r.id,width:l[0][0],height:l[0][1]})}},Z=e=>{W(e)},$=e=>{W(e,!0),D=!1,document.removeEventListener("mousemove",Z),document.removeEventListener("mouseup",$)};document.addEventListener("mousemove",Z),document.addEventListener("mouseup",$)}function L(e){let{cell:t,transform:n,readOnly:i,layoutOptions:l,activeTarget:a,cells:c,onCellResizing:s,onCellResized:d,onSwitchActiveTarget:u}=e;const v=r().useRef(null);return(0,o.useEffect)((()=>{const e=v.current;if(!e||i)return;const o=e=>{S(e,{action:"resize",cell:t,scale:n.k,layoutOptions:l,activeTarget:a,cells:c,onCellResizing:s,onCellResized:d,onSwitchActiveTarget:u})};return e.addEventListener("mousedown",o),()=>{e.removeEventListener("mousedown",o)}}),[a,t,c,l,d,s,u,i,n.k]),r().createElement("g",{className:"decorator-area"},r().createElement("rect",{width:t.view.width,height:t.view.height,className:"area"}),!i&&r().createElement("g",{ref:v,className:"resize-handle",transform:`translate(${t.view.width-20} ${t.view.height-20})`},r().createElement("rect",{width:20,height:20}),r().createElement("path",{d:"M10 18L18 10 M15 18L18 15"})))}function z(e){var t;let{cell:n,readOnly:i,onDecoratorTextEditing:a,onDecoratorTextChange:c}=e;const s=null!==(t=n.view.text)&&void 0!==t?t:"",[d,u]=(0,o.useState)(s),[v,f]=(0,o.useState)(!1),h=(0,o.useRef)(!1),[m,g]=(0,o.useState)(!1),p=(0,o.useRef)(null),y=(0,o.useCallback)((e=>{i||(e.preventDefault(),e.stopPropagation(),f(!0))}),[i]);(0,o.useEffect)((()=>{const e=p.current;e&&e.textContent!==d&&(e.textContent=d)}),[d]),(0,o.useEffect)((()=>{var e;const t=null===(e=p.current)||void 0===e?void 0:e.parentElement;t&&(n.view.width=t.clientWidth,n.view.height=t.clientHeight)}),[d,n.id]),(0,o.useEffect)((()=>{v&&p.current&&(p.current.focus(),P(p.current)),null==a||a({id:n.id,editing:v})}),[n.id,v,a]),(0,o.useEffect)((()=>{h.current?null==a||a({id:n.id,editing:v}):h.current=!0}),[n.id,v,a]);const w=(0,o.useCallback)((e=>{i||u(e.target.textContent)}),[i]),x=(0,o.useCallback)((()=>{i||(f(!1),g(!0))}),[i]);return(0,o.useEffect)((()=>{m&&(null==c||c({id:n.id,view:{...n.view,text:d}}),g(!1))}),[n,d,c,m]),r().createElement("foreignObject",{className:"decorator-text"},r().createElement("div",{className:l()("text-container",{editing:v}),onDoubleClick:y},r().createElement("div",{className:"text",contentEditable:v,ref:p,onInput:w,onBlur:x})))}function P(e){const t=document.createRange();t.selectNodeContents(e);const n=window.getSelection();n.removeAllRanges(),n.addRange(t)}var R=n(9068);function N(e){let{cell:t,transform:n,readOnly:i,layout:s,view:d,activeTarget:u,cells:v,onCellResizing:f,onCellResized:h,onSwitchActiveTarget:m,onDecoratorTextEditing:g,onDecoratorTextChange:p}=e;const y=(0,c.get)(t.view,"text",""),w=(0,c.get)(t.view,"direction","top"),x=(0,o.useRef)(null),E=r().useRef(null),[k,b]=(0,o.useState)(!1),[C,M]=(0,o.useState)(y),[I,L]=(0,o.useState)(!1),[z,N]=(0,o.useState)(),[A,T]=(0,o.useState)({x:0,y:0,width:t.view.width,height:t.view.height}),H=(0,o.useCallback)((e=>{i||(e.preventDefault(),e.stopPropagation(),b(!0))}),[i]),D=(0,o.useCallback)((e=>{i||M(e.target.textContent)}),[i]),W=(0,o.useCallback)((()=>{i||(b(!1),L(!0),N((0,R.uuidV4)()))}),[i]);return(0,o.useEffect)((()=>{M(y)}),[y]),(0,o.useEffect)((()=>{const e=x.current;e&&e.textContent!==C&&(e.textContent=C)}),[C]),(0,o.useEffect)((()=>{var e;const t=null===(e=x.current)||void 0===e?void 0:e.parentElement;if(t){const{clientWidth:e,clientHeight:n}=t;if(["left","right"].includes(w)){const t={width:e,height:d.height,x:"left"===w?-e:d.width,y:0};T(t)}else{const e={width:d.width,height:n,x:0,y:"top"===w?-n:d.height};T(e)}}}),[d,C,w,z]),(0,o.useEffect)((()=>{k&&x.current&&(x.current.focus(),P(x.current)),null==g||g({id:t.id,editing:k})}),[t.id,k,g]),(0,o.useEffect)((()=>{I&&(null==p||p({id:t.id,view:{...d,text:C}}),L(!1))}),[t,d,C,p,I]),(0,o.useEffect)((()=>{const e=E.current;if(!e||i)return;const o=e=>{S(e,{action:"resize",cell:t,scale:n.k,activeTarget:u,cells:v,onCellResizing:f,onCellResized:h,onSwitchActiveTarget:m})};return e.addEventListener("mousedown",o),()=>{e.removeEventListener("mousedown",o)}}),[u,t,v,h,f,m,i,n.k]),r().createElement("g",{className:"decorator-container"},r().createElement("foreignObject",A,r().createElement("div",{className:l()("text-container",{editing:k,[["left","right"].includes(w)?"vertical":"horizontal"]:!0}),onDoubleClick:H},r().createElement("div",{className:"text",contentEditable:k,ref:x,onInput:D,onBlur:W}))),r().createElement("rect",{width:d.width,height:d.height,className:"container"}),!i&&!(0,a.OD)(s)&&r().createElement("g",{ref:E,className:"resize-handle",transform:`translate(${d.width-20} ${d.height-20})`},r().createElement("rect",{width:20,height:20}),r().createElement("path",{d:"M10 18L18 10 M15 18L18 15"})))}function A(e){let t,{cell:n,view:o,transform:i,readOnly:l,layout:a,layoutOptions:c,activeTarget:s,cells:d,onCellResizing:u,onCellResized:v,onSwitchActiveTarget:f,onDecoratorTextEditing:h,onDecoratorTextChange:m}=e;switch(n.decorator){case"container":t=N;break;case"area":t=L;break;case"text":t=z;break;default:return console.error(`Unknown decorator: ${n.decorator}`),null}return r().createElement(t,{cell:n,view:o,transform:i,readOnly:l,layout:a,layoutOptions:c,activeTarget:s,cells:d,onCellResizing:u,onCellResized:v,onSwitchActiveTarget:f,onDecoratorTextEditing:h,onDecoratorTextChange:m})}function T(e){let t=1/0,n=1/0,o=-1/0,r=-1/0;return e.forEach((e=>{const{x:i,y:l,width:a,height:c}=e.view;i<t&&(t=i),l<n&&(n=l),i+a>o&&(o=i+a),l+c>r&&(r=l+c)})),[t,o,n,r].some((e=>isFinite(e)))?{x:t-20,y:n-20,width:o-t+40,height:r-n+40}:{}}var H=n(9978);function D(e){let{layout:t,layoutOptions:n,cell:i,cells:s,degraded:d,degradedNodeLabel:u,defaultNodeBricks:v,lineConfMap:f,editableLineMap:h,activeTarget:m,dragNodeToContainerActive:g,readOnly:p,transform:E,hoverCell:k,unrelatedCells:M,allowEdgeToArea:I,curActiveEditableEdge:L,updateCurActiveEditableEdge:z,onCellsMoving:P,onCellsMoved:R,onCellResizing:N,onCellResized:D,onSwitchActiveTarget:W,onCellContextMenu:Z,onCellClick:$,onDecoratorTextEditing:B,onDecoratorTextChange:j,onNodeBrickResize:O,onCellMouseEnter:U,onCellMouseLeave:V}=e;const{lineEditorState:G,smartConnectLineState:X,setSmartConnectLineState:Y,onConnect:F,setLineEditorState:Q,onChangeEdgeView:J}=(0,H.s)(),K=(0,o.useRef)(null),_=(0,o.useMemo)((()=>M.some((e=>(0,b.c)(e,i)))),[i,M]),q=(0,o.useMemo)((()=>{if((0,a.t2)(i)&&(0,a.OD)(t)){const e=s.filter((e=>(0,a.N)(e)&&e.containerId===i.id)),t={...i.view,...T(e)};return i.view=t,t}return(0,a.WW)(i)?void 0:(0,c.get)(i,"view",{x:0,y:0,width:0,height:0})}),[t,i,s]);(0,o.useEffect)((()=>{const e=K.current;if(!e)return;const o=e=>{p||(0,a.t2)(i)&&(0,a.OD)(t)?e.stopPropagation():S(e,{layout:t,layoutOptions:n,action:"move",cell:i,scale:E.k,activeTarget:m,cells:s,onCellsMoving:P,onCellsMoved:R,onSwitchActiveTarget:W,updateCurActiveEditableEdge:z})};return e.addEventListener("mousedown",o),()=>{e.removeEventListener("mousedown",o)}}),[t,n,i,m,s,R,P,W,p,E.k]),(0,o.useEffect)((()=>{const e=K.current;if(!e||!(0,a.bo)(i,I)||!(X||G&&"control"!==G.type))return;const t=e=>{if(e.preventDefault(),e.stopPropagation(),X)X.source!==i&&(null==F||F(X.source,i,X.exitPosition,void 0)),Y(null);else if(L&&G){const{type:e}=G,{source:t,target:n}=h.get(L),{view:o}=L,r="entry"===e;(r?n:t)===i&&(r?null==J||J(t,n,{...o,entryPosition:null}):null==J||J(t,n,{...o,exitPosition:null})),Q(null)}};return e.addEventListener("mouseup",t),()=>{e.removeEventListener("mouseup",t)}}),[L,h,I,i,G,J,F,Q,Y,X,z]);const ee=(0,o.useCallback)((e=>{p&&"decorator"===i.type||(e.preventDefault(),W((0,y.P)(i)),Z({cell:i,clientX:e.clientX,clientY:e.clientY}))}),[i,Z,W,p]),te=(0,o.useCallback)((e=>{$&&"decorator"!==i.type&&$({cell:i,clientX:e.clientX,clientY:e.clientY})}),[i,$]),ne=(0,o.useCallback)((()=>{null==U||U(i)}),[i,U]),oe=(0,o.useCallback)((()=>{null==V||V(i)}),[i,V]),re=(0,C.Q)(i,m);return r().createElement("g",{className:l()("cell",{active:re,faded:_,"read-only":p,"container-active":g}),ref:K,transform:"edge"===i.type||null==i.view.x?void 0:`translate(${q.x} ${q.y})`,onContextMenu:ee,onClick:te,onMouseEnter:ne,onMouseLeave:oe},(0,a.N)(i)?r().createElement(x,{node:i,degraded:d,degradedNodeLabel:u,defaultNodeBricks:v,onResize:O}):(0,a.WW)(i)?r().createElement(w,{edge:i,active:p?k===i:(0,b.c)(m,i),activeRelated:!!(p?k:m)&&!_,lineConfMap:f,editableLineMap:h,readOnly:p,onSwitchActiveTarget:W}):(0,a.mH)(i)?r().createElement(A,{cell:i,view:q,transform:E,readOnly:p,layout:t,layoutOptions:n,activeTarget:m,cells:s,onCellResizing:N,onCellResized:D,onSwitchActiveTarget:W,onDecoratorTextEditing:B,onDecoratorTextChange:j}):null)}},3639:(e,t,n)=>{n.d(t,{w:()=>a});var o=n(8769),r=n.n(o),i=n(3373),l=n.n(i);function a(e){let{connectLineState:t,transform:n,markerEnd:i,onConnect:a}=e;const[c,s]=(0,o.useState)(null);return(0,o.useEffect)((()=>{t&&s(t.from)}),[t]),(0,o.useEffect)((()=>{if(t){const e=e=>[(e.clientX-n.x-t.offset[0])/n.k,(e.clientY-n.y-t.offset[1])/n.k],o=t=>{s(e(t))},r=e=>{e.stopPropagation()},i=n=>{n.stopPropagation(),l(),a(t,e(n))},l=()=>{document.removeEventListener("mousemove",o),document.removeEventListener("mousedown",r,{capture:!0}),document.removeEventListener("click",i,{capture:!0}),s(null)};return document.addEventListener("mousemove",o),document.addEventListener("mousedown",r,{capture:!0}),document.addEventListener("click",i,{capture:!0}),l}}),[t,a,n]),r().createElement("path",{className:l()("connect-line",{connecting:!!t&&c&&(c[0]-t.from[0])**2+(c[1]-t.from[1])**2>25}),d:t&&c?`M${t.from.join(" ")}L${c.join(" ")}`:"",fill:"none",stroke:"gray",strokeWidth:1,markerEnd:`url(#${i})`})}},1825:(e,t,n)=>{n.d(t,{W:()=>f});var o=n(8769),r=n.n(o),i=n(3373),l=n.n(i),a=n(8653),c=n(9978),s=n(1030),d=n(967);function u(e,t,n,o){const{control:r}=t,{points:i}=n.get(e),l=[],[a,c]=o,s=i[0],u=i[i.length-1];0===r.index&&l.push("ns"===r.direction?{x:s.x,y:c}:{x:a,y:s.y});for(let e=1;e<i.length-1;e++){const t=i[e];l.push(e===r.index||e===r.index+1?"ns"===r.direction?{x:t.x,y:c}:{x:a,y:t.y}:t)}return r.index===i.length-2&&l.push("ns"===r.direction?{x:u.x,y:c}:{x:a,y:u.y}),(0,d.P)(s,l,u)}var v=n(7531);function f(e){let{cells:t,editableLineMap:n,transform:i,options:f,activeEditableEdge:h}=e;const[m,g]=(0,o.useState)(null),{hoverState:p,lineEditorState:y,setLineEditorState:w,onChangeEdgeView:x}=(0,c.s)(),E=(0,o.useRef)(!1);(0,o.useEffect)((()=>{y||setTimeout((()=>{E.current=!1}),0)}),[y]),(0,o.useEffect)((()=>{if(!h||!y)return;E.current=!1;const{type:e,offset:o,from:r}=y,l=l=>{const a={x:(l.clientX-i.x-o[0])/i.k,y:(l.clientY-i.y-o[1])/i.k};let c=1/0;if("control"===e&&!l.altKey){const{control:e}=y,o=n.get(h).points,r="ns"===e.direction?"y":"x",i=e[r],l=o.filter(((t,n)=>0===n||n===o.length-1||n!==e.index&&n!==e.index+1)),s=5;for(const e of t){if("edge"!==e.type||e===h)continue;const t=n.get(e);t&&l.push(...t.points.slice(1,-1))}for(const e of l){const t=Math.abs(e[r]-a[r]);t<=s&&t<c&&(a[r]=e[r],c=t,E.current||i===a[r]||(E.current=!0))}}if(c===1/0&&!E.current){const e=(l.clientX-r[0])/i.k,t=(l.clientY-r[1])/i.k;E.current=e**2+t**2>=9}return[a.x,a.y]},a=e=>{const t=l(e);E.current&&g(t)};function c(e){if(e.preventDefault(),s(),"control"===(null==y?void 0:y.type)){const t=l(e);if(E.current){const{source:e,target:o}=n.get(h),{view:r}=h;null==x||x(e,o,{...r,vertices:u(h,y,n,t)})}}}function s(){document.removeEventListener("mousemove",a),document.removeEventListener("mouseup",c),g(null),w(null)}return document.addEventListener("mousemove",a),document.addEventListener("mouseup",c),s}),[h,n,y,i,w,x,t]),(0,o.useEffect)((()=>{if(!h)return;const e=e=>{E.current&&(e.stopPropagation(),e.preventDefault())};return document.body.addEventListener("click",e),()=>{document.body.removeEventListener("click",e)}}),[h]);const k=(0,o.useMemo)((()=>{var e;const t=function(e,t,n,o,r){if(!e||!t||!(o||"control"!==t.type&&void 0!==(null==r?void 0:r.activePointIndex)))return null;const{type:i}=t,{source:l,target:a}=n.get(e),{view:c}=e,{exitPosition:v,entryPosition:f,vertices:h}=null!=c?c:{},m=(0,s.pick)(c,["type","curveType"]);if("control"===i){const r=u(e,t,n,o);return(0,d.V)(l.view,a.view,{...m,exitPosition:v,entryPosition:f,vertices:r})}if(void 0!==(null==r?void 0:r.activePointIndex)){const e=r.relativePoints[r.activePointIndex];return(0,d.V)(l.view,a.view,{...m,..."entry"===i?{exitPosition:v,entryPosition:e}:{exitPosition:e,entryPosition:f},vertices:h})}const[g,p]=o;return"entry"===i?(0,d.V)(l.view,{x:g,y:p,width:0,height:0},{...m,exitPosition:v,vertices:h}):(0,d.V)({x:g,y:p,width:0,height:0},a.view,{...m,entryPosition:f,vertices:h})}(h,y,n,m,p);return(0,a.S)(t,"curve"===(null==h||null===(e=h.view)||void 0===e?void 0:e.type)?h.view.curveType:"curveLinear",0,1)}),[m,p,h,y,n]);let b,C;const M=(0,v.I)(f);for(const e of M)"start"===e.placement?b=f.$editingStartMarkerUrl:C=f.$editingEndMarkerUrl;return r().createElement("path",{className:l()("editing-line",{editing:!(!y||!m)}),d:k,fill:"none",stroke:f.editingStrokeColor,markerStart:b,markerEnd:C})}},9978:(e,t,n)=>{n.d(t,{H:()=>i,s:()=>l});var o=n(8769),r=n.n(o);const i=r().createContext({rootRef:{current:null},smartConnectLineState:null,unsetHoverStateTimeoutRef:{current:null},hoverState:null,activeEditableEdges:[],lineEditorState:null,setLineEditorState:()=>{},setHoverState:()=>{},setSmartConnectLineState:()=>{}});function l(){return r().useContext(i)}},2722:(e,t,n)=>{n.d(t,{T:()=>v});var o=n(8769),r=n.n(o),i=n(9978),l=n(4197),a=n(3033);const c="data:image/svg+xml;base64,PCFET0NUWVBFIHN2ZyBQVUJMSUMgIi0vL1czQy8vRFREIFNWRyAxLjEvL0VOIiAiaHR0cDovL3d3dy53My5vcmcvR3JhcGhpY3MvU1ZHLzEuMS9EVEQvc3ZnMTEuZHRkIj48c3ZnIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIHdpZHRoPSI1cHgiIGhlaWdodD0iNXB4IiB2ZXJzaW9uPSIxLjEiPjxwYXRoIGQ9Im0gMCAwIEwgNSA1IE0gMCA1IEwgNSAwIiBzdHJva2Utd2lkdGg9IjIiIHN0eWxlPSJzdHJva2Utb3BhY2l0eTowLjQiIHN0cm9rZT0iI2ZmZmZmZiIvPjxwYXRoIGQ9Im0gMCAwIEwgNSA1IE0gMCA1IEwgNSAwIiBzdHJva2U9IiMyOWI2ZjIiLz48L3N2Zz4=",s=5,d=8,u=s/2;function v(e){let{activeTarget:t,editableLineMap:n,scale:c,activeEditableEdge:s,disabled:u}=e;const{unsetHoverStateTimeoutRef:v,hoverState:h,setHoverState:m,smartConnectLineState:g,lineEditorState:p}=(0,i.s)(),y=(0,o.useCallback)((()=>{null!==v.current&&(clearTimeout(v.current),v.current=null)}),[v]),w=(0,o.useCallback)((()=>{y(),m((e=>void 0===(null==e?void 0:e.activePointIndex)?e:{...h,activePointIndex:void 0}))}),[h,m,y]),x=(0,o.useCallback)((()=>{v.current=setTimeout((()=>{m(null)}))}),[m,v]);let E,k;const b=!u&&h&&(!!g||(s&&p&&(({source:E,target:k}=n.get(s)),1)?"entry"===p.type?h.cell===k:"exit"===p.type&&h.cell===E:!(0,l.Q)(h.cell,t)&&!function(e){return e&&("edge"===e.type||"multi"===e.type&&e.targets.some((e=>"edge"===e.type)))}(t))),C=a.XK,M=C/2;return r().createElement("g",{onMouseEnter:w,onMouseLeave:x},b&&r().createElement(r().Fragment,null,r().createElement("rect",{x:h.cell.view.x-M,y:h.cell.view.y-M,width:h.cell.view.width+C,height:h.cell.view.height+C,fill:"none",stroke:"transparent",strokeWidth:2*d/c,pointerEvents:"stroke"}),void 0!==h.activePointIndex&&r().createElement("circle",{cx:h.points[h.activePointIndex].x,cy:h.points[h.activePointIndex].y,r:d/c,fill:"lightgreen",fillOpacity:.5,pointerEvents:"none"}),h.points.map(((e,t)=>r().createElement(f,{key:t,editableLineMap:n,index:t,point:e,scale:c,activeEditableEdge:s,unsetActivePointIndex:w,unsetTimeout:y})))))}function f(e){let{editableLineMap:t,index:n,point:l,scale:a,activeEditableEdge:v,unsetTimeout:f,unsetActivePointIndex:h}=e;const{rootRef:m,smartConnectLineState:g,hoverState:p,setHoverState:y,setSmartConnectLineState:w,onConnect:x,lineEditorState:E,setLineEditorState:k,onChangeEdgeView:b}=(0,i.s)(),C=(0,o.useRef)(null);return(0,o.useEffect)((()=>{const e=C.current,t=o=>{"mousemove"===o.type&&(null==e||e.removeEventListener(o.type,t)),f(),y((e=>e&&e.activePointIndex!==n?{...p,activePointIndex:n}:e))};return null==e||e.addEventListener("mouseenter",t),null==e||e.addEventListener("mousemove",t),()=>{null==e||e.removeEventListener("mouseenter",t),null==e||e.removeEventListener("mousemove",t)}}),[p,n,y,f]),(0,o.useEffect)((()=>{if(E)return;const e=e=>{e.preventDefault(),e.stopPropagation();const t=m.current.getBoundingClientRect(),o=p.points[n];w({source:p.cell,from:[o.x,o.y],offset:[t.left,t.top],exitPosition:p.relativePoints[n]})},t=C.current;return null==t||t.addEventListener("mousedown",e),()=>{null==t||t.removeEventListener("mousedown",e)}}),[p,n,E,m,w]),(0,o.useEffect)((()=>{const e=e=>{if(e.preventDefault(),e.stopPropagation(),g)g.source!==(null==p?void 0:p.cell)&&(null==x||x(g.source,p.cell,g.exitPosition,p.relativePoints[p.activePointIndex])),w(null);else if(v&&E){const e=p.relativePoints[p.activePointIndex],{type:n}=E,{source:o,target:r}=t.get(v),{view:i}=v;"entry"===n?null==b||b(o,r,{...i,entryPosition:e}):null==b||b(o,r,{...i,exitPosition:e}),k(null)}},n=C.current;return null==n||n.addEventListener("mouseup",e),()=>{null==n||n.removeEventListener("mouseup",e)}}),[g,p,x,w,v,E,t,b,k]),r().createElement("g",{ref:C,onMouseLeave:h},r().createElement("circle",{cx:l.x,cy:l.y,r:d,fill:"transparent"}),r().createElement("image",{x:l.x-u/a,y:l.y-u/a,width:s/a,height:s/a,xlinkHref:c,preserveAspectRatio:"none"}))}},2202:(e,t,n)=>{n.d(t,{F:()=>v});var o=n(9575),r=n(8769),i=n.n(r),l=n(9978),a=n(531);const c="data:image/svg+xml;base64,PCFET0NUWVBFIHN2ZyBQVUJMSUMgIi0vL1czQy8vRFREIFNWRyAxLjEvL0VOIiAiaHR0cDovL3d3dy53My5vcmcvR3JhcGhpY3MvU1ZHLzEuMS9EVEQvc3ZnMTEuZHRkIj48c3ZnIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIHdpZHRoPSIyMnB4IiBoZWlnaHQ9IjIycHgiIHZlcnNpb249IjEuMSI+PGNpcmNsZSBjeD0iMTEiIGN5PSIxMSIgcj0iNyIgc3Ryb2tlPSIjZmZmIiBmaWxsPSIjMjliNmYyIi8+PGNpcmNsZSBjeD0iMTEiIGN5PSIxMSIgcj0iMyIgc3Ryb2tlPSIjZmZmIiBmaWxsPSJ0cmFuc3BhcmVudCIvPjwvc3ZnPg==",s="data:image/svg+xml;base64,PCFET0NUWVBFIHN2ZyBQVUJMSUMgIi0vL1czQy8vRFREIFNWRyAxLjEvL0VOIiAiaHR0cDovL3d3dy53My5vcmcvR3JhcGhpY3MvU1ZHLzEuMS9EVEQvc3ZnMTEuZHRkIj48c3ZnIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIHdpZHRoPSIyMnB4IiBoZWlnaHQ9IjIycHgiIHZlcnNpb249IjEuMSI+PGNpcmNsZSBjeD0iMTEiIGN5PSIxMSIgcj0iNyIgc3Ryb2tlPSIjZmZmIiBmaWxsPSIjMDFiZDIyIi8+PHBhdGggZD0ibSA4IDggTCAxNCAxNE0gOCAxNCBMIDE0IDgiIHN0cm9rZT0iI2ZmZiIvPjwvc3ZnPg==",d="data:image/svg+xml;base64,PCFET0NUWVBFIHN2ZyBQVUJMSUMgIi0vL1czQy8vRFREIFNWRyAxLjEvL0VOIiAiaHR0cDovL3d3dy53My5vcmcvR3JhcGhpY3MvU1ZHLzEuMS9EVEQvc3ZnMTEuZHRkIj48c3ZnIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIHdpZHRoPSIxOHB4IiBoZWlnaHQ9IjE4cHgiIHZlcnNpb249IjEuMSI+PGNpcmNsZSBjeD0iOSIgY3k9IjkiIHI9IjUiIHN0cm9rZT0iI2ZmZiIgZmlsbD0iIzI5YjZmMiIvPjwvc3ZnPg==",u=22;function v(e){let{scale:t,editableLineMap:n,activeEditableEdge:v,updateCurActiveEditableEdge:f}=e;const{rootRef:h,setLineEditorState:m}=(0,l.s)(),g=(0,r.useRef)(null),p=(0,r.useRef)(null),y=(0,r.useRef)([]);(0,r.useEffect)((()=>{const e=g.current,t=p.current;if(!e||!t||!v)return;const n=e=>t=>{t.stopPropagation(),t.preventDefault();const n=h.current.getBoundingClientRect();m({offset:[n.left,n.top],from:[t.clientX,t.clientY],type:e}),null==f||f(v)},o=n("exit"),r=n("entry");return e.addEventListener("mousedown",o),t.addEventListener("mousedown",r),()=>{e.removeEventListener("mousedown",o),t.removeEventListener("mousedown",r)}}),[v,h,m,f]);const w=(0,r.useMemo)((()=>{var e;return v&&!(0,a.jw)(null===(e=v.view)||void 0===e?void 0:e.type)?function(e){const t=[];let n=e[0],o=1;for(;o<e.length;){const r=e[o],i=n.y===r.y,l=n.x===r.x;if(!i||!l){const e=i?"ns":"ew";t.push({direction:e,index:o-1,x:(n.x+r.x)/2,y:(n.y+r.y)/2})}n=r,o++}return t}(n.get(v).points):[]}),[v,n]);(0,r.useEffect)((()=>{if(!v)return;const e=y.current,t=w.map((e=>(e=>t=>{t.stopPropagation(),t.preventDefault(),null==f||f(v);const n=h.current.getBoundingClientRect();m({offset:[n.left,n.top],from:[t.clientX,t.clientY],type:"control",control:e})})(e)));return e.forEach(((e,n)=>{null==e||e.addEventListener("mousedown",t[n])})),()=>{e.forEach(((e,n)=>{null==e||e.removeEventListener("mousedown",t[n])}))}}),[v,w,h,m,f]);const x=(0,r.useRef)(null);if((0,r.useEffect)((()=>{const e=x.current,t=e=>{e.stopPropagation(),e.preventDefault()};return null==e||e.addEventListener("click",t),()=>{null==e||e.removeEventListener("click",t)}}),[]),!v)return null;const{view:E}=v,k=n.get(v).points,{exitPosition:b,entryPosition:C}=null!=E?E:{},M={width:u/t,height:u/t,preserveAspectRatio:"none",cursor:"pointer",pointerEvents:"fill"},I=k[0],S=k[k.length-1],L=u/t/2;return i().createElement("g",{ref:x},i().createElement("image",(0,o.A)({ref:g},M,{x:I.x-L,y:I.y-L,xlinkHref:b?s:c})),w.map(((e,t)=>i().createElement("image",(0,o.A)({key:t,ref:e=>{y.current[t]=e}},M,{x:e.x-L,y:e.y-L,xlinkHref:d,cursor:"ns"===e.direction?"row-resize":"col-resize"})))),i().createElement("image",(0,o.A)({ref:p},M,{x:S.x-L,y:S.y-L,xlinkHref:C?s:c})))}},1103:(e,t,n)=>{n.d(t,{X:()=>u});var o=n(8769),r=n.n(o),i=n(3373),l=n.n(i),a=n(8653),c=n(9978),s=n(967),d=n(7531);function u(e){let{transform:t,lineSettings:n,options:i}=e;const[u,v]=(0,o.useState)(null),{hoverState:f,smartConnectLineState:h,setSmartConnectLineState:m}=(0,c.s)();(0,o.useEffect)((()=>{if(h)return document.addEventListener("mousemove",e),document.addEventListener("mouseup",n),o;function e(e){v([(e.clientX-t.x-h.offset[0])/t.k,(e.clientY-t.y-h.offset[1])/t.k])}function n(e){e.preventDefault(),o()}function o(){document.removeEventListener("mousemove",e),document.removeEventListener("mouseup",n),v(null),m(null)}}),[m,h,t]);const g=(0,o.useMemo)((()=>{const e=function(e,t,n,o){if(!e||!t&&void 0===(null==n?void 0:n.activePointIndex))return null;const r=e.source.view;if(void 0!==(null==n?void 0:n.activePointIndex))return(0,s.V)(r,n.cell.view,{...o,exitPosition:e.exitPosition,entryPosition:n.relativePoints[n.activePointIndex]});const[i,l]=t;return(0,s.V)(r,{x:i,y:l,width:0,height:0},{...o,exitPosition:e.exitPosition})}(h,u,f,n);return(0,a.S)(e,"curve"===(null==n?void 0:n.type)?n.curveType:"curveLinear",0,1)}),[u,f,h,n]);let p,y;const w=(0,d.I)(i);for(const e of w)"start"===e.placement?p=i.$markerStartUrl:y=i.$markerEndUrl;return r().createElement("path",{className:l()("connect-line",{connecting:!(!h||!u)}),d:g,fill:"none",stroke:i.strokeColor,strokeWidth:i.strokeWidth,markerStart:p,markerEnd:y})}},3033:(e,t,n)=>{n.d(t,{Be:()=>p,CV:()=>o,D9:()=>a,Dm:()=>l,HP:()=>i,Ie:()=>h,Jo:()=>C,N8:()=>c,Ub:()=>g,VO:()=>f,XK:()=>b,XV:()=>m,Yt:()=>u,gx:()=>w,ld:()=>x,mF:()=>v,o5:()=>E,p6:()=>k,pC:()=>y,sS:()=>d,w1:()=>s,xc:()=>r});const o=Symbol.for("size-initialized"),r=Symbol.for("layout-initialized"),i=20,l=36,a=50,c=180,s=120,d=.5,u=2,v="gray",f=1,h=15,m=!1,g=!0,p=1,y=500,w=10,x=5,E="all",k=5,b=0,C=50},531:(e,t,n)=>{function o(e){return"node"===e.type}function r(e){return"decorator"===e.type}function i(e){return"node"===e.type}function l(e){return"edge"===e.type}function a(e){return"node"===e.type||"edge"===e.type}function c(e){return"node"===e.type||"decorator"===e.type&&"area"===e.decorator}function s(e,t){return"node"===e.type||!!t&&"decorator"===e.type&&"area"===e.decorator}function d(e){return"decorator"===e.type&&"text"===e.decorator}function u(e){return"decorator"===e.type&&"container"===e.decorator}function v(e){return!["manual",void 0].includes(e)}function f(e){return!("polyline"===e||"curve"===e)}n.d(t,{Hs:()=>d,N:()=>o,OD:()=>v,WW:()=>l,bo:()=>s,jw:()=>f,mH:()=>r,nv:()=>a,o6:()=>c,t2:()=>u,vC:()=>i})},9386:(e,t,n)=>{n.d(t,{P:()=>r});var o=n(1030);function r(e){return"edge"===e.type?(0,o.pick)(e,["type","source","target","data"]):(0,o.pick)(e,["type","id","data"])}},227:(e,t,n)=>{n.d(t,{Y:()=>r});var o=n(4197);function r(e,t,n,r){const i=[];if(t){const n=new Set;for(const o of e)"edge"===o.type&&o.source===t.source.id&&n.add(o.target);for(const t of e)switch(t.type){case"node":n.has(t.id)&&i.push(t);break;case"decorator":r&&"text"!=t.decorator&&!n.has(t.id)||i.push(t);break;default:i.push(t)}}else switch(null==n?void 0:n.type){case"multi":{const t=new Map,r=new Set,l=new Set;for(const e of n.targets)"node"===e.type&&(r.add(e.id),l.add(e.id));for(const a of e)"node"===a.type?t.set(a.id,a):"edge"===a.type?r.has(a.source)?l.add(a.target):r.has(a.target)?l.add(a.source):(0,o.Q)(a,n)||i.push(a):(0,o.Q)(a,n)||i.push(a);for(const[e,n]of t)l.has(e)||i.push(n);break}case"node":{const t=new Map,o=new Set([n.id]);for(const r of e)"node"===r.type?t.set(r.id,r):"edge"===r.type?r.source===n.id?o.add(r.target):r.target===n.id?o.add(r.source):i.push(r):i.push(r);for(const[e,n]of t)o.has(e)||i.push(n);break}case"edge":for(const t of e)("edge"===t.type?(0,o.Q)(t,n):"node"===t.type&&(t.id===n.source||t.id===n.target))||i.push(t)}return i}},2733:(e,t,n)=>{n.d(t,{a:()=>r});var o=n(4197);function r(e,t){let{cells:n,activeTarget:r}=t;const i=n.filter((e=>(0,o.Q)(e,r)));if(0!==i.length)switch(e.key||e.keyCode||e.which){case"Backspace":case 8:case"Delete":case 46:return e.preventDefault(),e.stopPropagation(),{action:"delete-cells",cells:i}}}},2219:(e,t,n)=>{function o(e,t){let{transform:n,offset:o,onLassoing:r,onLassoed:i}=t;if(e.ctrlKey||e.button)return;e.stopPropagation();const l=[e.clientX,e.clientY],a=(e.clientX-o[0]-n.x)/n.k,c=(e.clientY-o[1]-n.y)/n.k;let s=!1;const d=(e,t)=>{const o=function(e){return[(e.clientX-l[0])/n.k,(e.clientY-l[1])/n.k]}(e);if(s||(s=o[0]**2+o[1]**2>=9),s){let[e,n]=o,l=a,s=c;e<0&&(l=a+e,e=-e),n<0&&(s=c+n,n=-n),(t?i:r)({x:l,y:s,width:e,height:n})}},u=e=>{d(e)},v=e=>{d(e,!0),s=!1,document.removeEventListener("mousemove",u),document.removeEventListener("mouseup",v)};document.addEventListener("mousemove",u),document.addEventListener("mouseup",v)}n.d(t,{F:()=>o})},1991:(e,t,n)=>{n.d(t,{_:()=>r});var o=n(531);function r(e,t,n){const r=t.filter((e=>(0,o.N)(e))),i=e.filter((e=>(0,o.t2)(e))).map((e=>e.id)),l=e.filter((e=>{const t=r.find((t=>t.id===e.id)),n=(null==t?void 0:t.containerId)&&i.includes(t.containerId);return(0,o.N)(e)&&!n}));l.forEach((e=>{const n=e.x,r=e.x+e.width,i=e.y,l=e.y+e.height,a=t.filter((e=>(0,o.t2)(e)));for(const t of a){const o=t.view.x,a=t.view.x+t.view.width,c=t.view.y,s=t.view.y+t.view.height;if(n>=o&&r<=a&&i>=c&&l<=s){e.containerCell=t;break}}}));let a=[];return a=l.filter((e=>{var t;const n=r.find((t=>t.id===e.id));return(null==n?void 0:n.containerId)!==(null===(t=e.containerCell)||void 0===t?void 0:t.id)})),a.length>0&&(null==n||n(a)),a}},3783:(e,t,n)=>{n.d(t,{C:()=>r});var o=n(531);function r(e,t){let{defaultNodeSize:n}=t;return(null!=e?e:[]).map((e=>{var t,r;return!(0,o.vC)(e)||void 0!==(null===(t=e.view)||void 0===t?void 0:t.width)&&void 0!==(null===(r=e.view)||void 0===r?void 0:r.height)?e:{...e,view:{width:n[0],height:n[1],...e.view}}}))}},8185:(e,t,n)=>{function o(e,t){return e?!!t&&e.type===t.type&&("multi"===e.type?e.targets.length===t.targets.length&&e.targets.every((e=>t.targets.some((t=>o(e,t))))):"node"===e.type||"decorator"===e.type?e.id===t.id:e.source===t.source&&e.target===t.target):!t}n.d(t,{c:()=>o})},4197:(e,t,n)=>{n.d(t,{Q:()=>r});var o=n(8185);function r(e,t){return!!t&&("multi"===t.type?t.targets:[t]).some((t=>(0,o.c)(t,e)))}},908:(e,t,n)=>{n.d(t,{r:()=>r});var o=n(531);function r(e,t){let{canvasWidth:n,canvasHeight:r,scaleRange:i}=t,l=1/0,a=1/0,c=-1/0,s=-1/0,d=!0;for(const t of e)if(!(0,o.WW)(t)){d=!1;const{view:e}=t,n=e.x+e.width,o=e.y+e.height;e.x<l&&(l=e.x),n>c&&(c=n),e.y<a&&(a=e.y),o>s&&(s=o)}const u=c-l,v=s-a,f=i&&!d&&(u>n||v>r)?Math.max(Math.min(n/u,r/v,i[1]),i[0]):1;return{x:d?0:(n-u*f)/2-l*f,y:d?0:(r-v*f)/2-a*f,k:f}}},2098:(e,t,n)=>{n.d(t,{L:()=>u});var o=n(1030),r=n(3033),i=n(531),l=n(3783),a=n(908),c=n(6170),s=n(9127),d=n(8185);function u(e){let{cells:t,layout:n,previousCells:u,defaultNodeSize:v,canvasWidth:f,canvasHeight:h,scaleRange:m,transform:g,reason:p,parent:y,allowEdgeToArea:w}=e;const x="force"!==n&&"dagre"!==n,E=(0,l.C)(t,{defaultNodeSize:v}),k=[];let b=!1;const C=new Map;let M=!1;for(const e of u)(0,i.mH)(e)?M=!0:(0,i.N)(e)&&(M=!0,e[r.CV]&&C.set(e.id,e));const I=new Map;for(const e of E)if((0,i.N)(e)){I.set(e.id,e);const t=C.get(e.id);t&&(e.view.width=t.view.width,e.view.height=t.view.height,e[r.CV]=!0)}let S=!1;if("add-related-nodes"===p&&y){const e=new Set;for(const t of E)(0,i.WW)(t)&&t.source===y&&t.target!==y&&e.add(t.target);const t=I.get(y);if(void 0!==(null==t?void 0:t.view.x)&&void 0!==t.view.y){if(S=!0,x)for(const t of E)((0,i.N)(t)&&void 0===t.view.x||(0,i.N)(t)&&void 0===t.view.y)&&e.add(t.id);const n=[...e].map((e=>I.get(e))).filter(Boolean);let o;for(const e of n)void 0!==e.view.x&&void 0!==e.view.y?(!o||e.view.x>o.view.x)&&e.view.y>t.view.y&&(o=e):k.push(e);if(k.length>0&&x){let e,n;if(o)e=o.view.x+o.view.width+r.Dm,n=o.view.y;else{const o=k.reduce(((e,t)=>e+t.view.width+r.Dm),-r.Dm);e=t.view.x-o/2+t.view.width/2,n=t.view.y+t.view.height+r.D9}for(const t of k)t.view.x=e,t.view.y=n,e+=t.view.width+r.Dm}}}if(!S){const e=[];let t=!1;for(const n of E)(0,i.N)(n)?void 0===n.view.x||void 0===n.view.y?k.push(n):e.push(n):(0,i.mH)(n)&&(t=!0);if(x){let n;M||(g=(0,a.r)((0,o.without)(E,...k),{canvasWidth:f,canvasHeight:h,scaleRange:m})),0===e.length||1===e.length&&!t&&k.length>0?(k.push(...e),({getNodeView:n}=(0,s.C)({cells:E,allowEdgeToArea:w})),b=0===u.length||u.length===E.length&&u.every(((e,t)=>(0,d.c)(e,E[t])))):({getNodeView:n}=(0,c.k)({cells:E,fixedPosition:!0,allowEdgeToArea:w,center:[(f/2-g.x)/g.k,(h/2-g.y)/g.k]}));for(const e of E)if((0,i.N)(e)){const t=n(e.id);e.view.x=t.x,e.view.y=t.y}}}return{cells:E,updated:k,shouldReCenter:b}}},5748:(e,t,n)=>{n.d(t,{d:()=>l});var o=n(531),r=n(3033);function i(e,t,n){const o=e.findLastIndex(n)+1;return[...e.slice(0,o),t,...e.slice(o)]}const l=(a={cells:(e,t)=>{switch(t.type){case"drop-node":return i(e,t.payload,(e=>!("decorator"===e.type&&"text"===e.decorator)));case"drop-decorator":return"text"===t.payload.decorator?[...e,t.payload]:i(e,t.payload,(e=>"decorator"===e.type&&"area"===e.decorator));case"add-nodes":{const n=e.findLastIndex((e=>!("decorator"===e.type&&"text"===e.decorator)))+1;return[...e.slice(0,n),...t.payload,...e.slice(n)]}case"add-edge":{const n=e.findIndex((e=>"edge"===e.type&&e.source===t.payload.source&&e.target===t.payload.target));return-1===n?i(e,t.payload,(e=>"edge"===e.type||"decorator"===e.type&&"area"===e.decorator)):[...e.slice(0,n),t.payload,...e.slice(n+1)]}case"change-edge-view":{const n=e.findIndex((e=>"edge"===e.type&&e.source===t.payload.source&&e.target===t.payload.target));return-1===n?e:[...e.slice(0,n),{...e[n],view:{...e[n].view,...t.payload.view}},...e.slice(n+1)]}case"move-cells":{let n=!1;const o=e.map((e=>{const o=t.payload.find((t=>e.type===t.type&&e.id===t.id));return o?(n=!0,{...e,view:{...e.view,x:o.x,y:o.y}}):e}));return n?o:e}case"resize-cell":{const{type:n,id:o,width:r,height:i}=t.payload,l=e.findIndex((e=>e.type===n&&e.id===o));if(-1!==l){const t=e[l];return[...e.slice(0,l),{...t,view:{...t.view,width:r,height:i}},...e.slice(l+1)]}return e}case"update-cells":return t.payload;case"update-node-size":return e.map((e=>(0,o.N)(e)&&e.id===t.payload.id?{...e,[r.CV]:!0,view:t.payload.size?{...e.view,width:t.payload.size[0],height:t.payload.size[1]}:e.view}:e))}return e},layoutKey:(e,t)=>"update-node-size"===t.type?t.layoutKey:e},(e,t)=>Object.fromEntries(Object.entries(a).map((n=>{let[o,r]=n;return[o,r(e[o],t)]}))));var a},7099:(e,t,n)=>{n.d(t,{Y:()=>h});var o=n(8769),r=n.n(o),i=n(1895),l=n(6768),a=n(6313),c=n(5694),s=n(3848),d=n(9575);const u=e=>o.createElement("svg",(0,d.A)({xmlns:"http://www.w3.org/2000/svg",width:24,height:24,viewBox:"0 0 24 24"},e),o.createElement("path",{d:"M12 0a.5.5 0 0 1 .5.5v2.013a9.5 9.5 0 0 1 8.987 8.988L23.5 11.5a.5.5 0 0 1 0 1h-2.013a9.5 9.5 0 0 1-8.987 8.987V23.5a.5.5 0 0 1-1 0v-2.013A9.5 9.5 0 0 1 2.514 12.5H.5a.5.5 0 0 1 0-1h2.013A9.5 9.5 0 0 1 11.5 2.514V.5A.5.5 0 0 1 12 0M3.514 11.5H7.5a.5.5 0 0 1 0 1H3.514a8.5 8.5 0 0 0 7.987 7.986L11.5 16.5a.5.5 0 0 1 1 0v3.986a8.5 8.5 0 0 0 7.986-7.986H16.5a.5.5 0 0 1 0-1h3.986A8.5 8.5 0 0 0 12.5 3.515V7.5a.5.5 0 0 1-1 0V3.514a8.5 8.5 0 0 0-7.986 7.987zm8.486-1a1.5 1.5 0 1 1 0 3 1.5 1.5 0 0 1 0-3"})),v=e=>o.createElement("svg",(0,d.A)({xmlns:"http://www.w3.org/2000/svg",width:128,height:128,className:"icon",viewBox:"0 0 1024 1024"},e),o.createElement("path",{d:"M512 76.8A435.2 435.2 0 1 0 947.2 512 435.71 435.71 0 0 0 512 76.8m0 819.2a384 384 0 1 1 384-384 384 384 0 0 1-384 384"}),o.createElement("path",{d:"M744.448 486.4h-204.8V281.6a25.6 25.6 0 1 0-51.2 0v204.8h-204.8a25.6 25.6 0 0 0 0 51.2h204.8v204.8a25.6 25.6 0 0 0 51.2 0V537.6h204.8a25.6 25.6 0 0 0 0-51.2"})),f=e=>o.createElement("svg",(0,d.A)({xmlns:"http://www.w3.org/2000/svg",width:128,height:128,className:"icon",viewBox:"0 0 1024 1024"},e),o.createElement("path",{d:"M512 76.8A435.2 435.2 0 1 0 947.2 512 435.71 435.71 0 0 0 512 76.8m0 819.2a384 384 0 1 1 384-384 384 384 0 0 1-384 384"}),o.createElement("path",{d:"M744.448 486.4H280.064a25.6 25.6 0 1 0 0 51.2h464.384a25.6 25.6 0 0 0 0-51.2"}));function h(e){let{shadowRoot:t,scale:n,scaleRange:d,onZoomChange:h,onReCenter:m}=e;const g=(0,s.useCurrentTheme)(),p=(0,o.useMemo)((()=>(0,c.VC)()),[]),y=(0,o.useRef)(null),w=100*d[0],x=100*d[1],E=100*n,k=(0,o.useMemo)((()=>({formatter:e=>`${e}%`,placement:"left",getPopupContainer:()=>y.current})),[]),b=(0,o.useCallback)((()=>{h(Math.min(E+5,x))}),[x,h,E]),C=(0,o.useCallback)((()=>{h(Math.max(E-5,w))}),[w,h,E]);return r().createElement(i.Ay,{theme:{algorithm:"dark-v2"===g?l.A.darkAlgorithm:l.A.defaultAlgorithm}},r().createElement(c.N7,{container:t,autoClear:!0,cache:p,hashPriority:"high"},r().createElement("div",{className:"zoom-bar",ref:y},r().createElement("div",{className:"center-button",onClick:m,role:"button"},r().createElement(u,null)),r().createElement("div",{className:"zoom-slider"},r().createElement("div",{className:"zoom-button",role:"button",onClick:b},r().createElement(v,null)),r().createElement(a.A,{min:w,max:x,value:E,step:5,vertical:!0,included:!1,tooltip:k,onChange:h}),r().createElement("div",{className:"zoom-button",role:"button",onClick:C},r().createElement(f,null))))))}},9127:(e,t,n)=>{n.d(t,{C:()=>c});var o=n(1030),r=n(7586),i=n.n(r),l=n(8802),a=n(531);function c(e){let{cells:t,layoutOptions:n,allowEdgeToArea:r}=e;const{nodePadding:c,...s}={nodePadding:0,rankdir:"TB",ranksep:50,edgesep:10,nodesep:50,...(0,o.pick)(n,["nodePadding","rankdir","ranksep","edgesep","nodesep","align"])},d=(0,l.D)(c);if(!t.some(a.N))return{getNodeView:()=>null,nodePaddings:d};const u=new(i().graphlib.Graph);u.setGraph(s),u.setDefaultEdgeLabel((function(){return{}}));for(const e of t)r&&(0,a.o6)(e)||(0,a.N)(e)?u.setNode(e.id,{id:e.id,width:e.view.width+d[1]+d[3],height:e.view.height+d[0]+d[2]}):(0,a.WW)(e)&&u.setEdge(e.source,e.target);return i().layout(u),{getNodeView:e=>u.node(e),nodePaddings:d}}},6170:(e,t,n)=>{n.d(t,{k:()=>v});var o=n(1030),r=n(6149),i=n(4842),l=n(1945),a=n(9418),c=n(3854),s=n(7931),d=n(531),u=n(8802);function v(e){let{cells:t,layoutOptions:n,center:v,fixedPosition:f,allowEdgeToArea:h}=e;const{nodePadding:m,collide:g}={nodePadding:0,...(0,o.pick)(n,["nodePadding"]),collide:!1!==(null==n?void 0:n.collide)&&{radiusDiff:18,strength:1,iterations:1,...!0===(null==n?void 0:n.collide)?null:null==n?void 0:n.collide}},p=(0,u.D)(m),y=[],w=[],x=new Map;for(const e of t)if(h&&(0,d.o6)(e)||(0,d.N)(e)){const t={id:e.id,width:e.view.width+p[1]+p[3],height:e.view.height+p[0]+p[2],...f?{fx:e.view.x,fy:e.view.y}:null};y.push(t),x.set(t.id,t)}else(0,d.WW)(e)&&w.push({source:e.source,target:e.target});const E=(0,r.A)(w).id((e=>e.id)),k=(0,i.A)(y).force("link",E).force("x",(0,l.A)(null==v?void 0:v[0])).force("y",(0,a.A)(null==v?void 0:v[1])).force("charge",(0,c.A)());return g&&k.force("collide",(0,s.A)().radius((e=>Math.sqrt(e.width**2+e.height**2)/2+g.radiusDiff)).strength(g.strength).iterations(g.iterations)),k.stop(),function(e){e.tick(Math.ceil(Math.log(e.alphaMin())/Math.log(1-e.alphaDecay())))}(k),{getNodeView:e=>x.get(e),nodePaddings:p}}},967:(e,t,n)=>{n.d(t,{V:()=>u,P:()=>v});var o=n(1030),r=n(8875),i=n(4059);function l(e,t){return{x:e.x+e.width/2,y:e.y+e.height/2,width:e.width+t,height:e.height+t}}var a=n(3033),c=n(3188),s=n(531);const d=["right","top","left","bottom"];function u(e,t,n,u){var p,y,w,x,E,k;const{type:b,vertices:C,exitPosition:M,entryPosition:I}=null!=n?n:{};if((0,s.jw)(b))return(0,c.h)(l(e,M?a.XK:a.p6),l(t,I?a.XK:a.p6),u,n);if(null!=C&&C.length){const n=C[0],o=C[C.length-1];let r,i,l,a;if(M)r=h(e,M);else{let i;if(C.length>1?i=C[1]:I&&(i=h(t,I)),i)r=m(n,e,n.y===i.y);else{const n=o.y<t.y||o.y>t.y+t.height?"ns":"ew";({point:r,direction:l}=g(e,t,C,n))}}if(I)i=h(t,I);else{let r;if(C.length>1?r=C[C.length-2]:M&&(r=h(e,M)),r)i=m(o,t,o.y===r.y);else{const o=n.x<e.x||n.x>e.x+e.width?"ew":"ns";({point:i,direction:a}=g(t,e,C.slice().reverse(),o))}}const{x:c,y:s}=r,{x:d,y:u}=i,f=[r,...C,i],p=[...C];return n&&n.x!==c&&n.y!==s&&p.unshift("ns"===l?{x:c,y:n.y}:"ew"===l?{x:n.x,y:s}:n.x===f[2].x?{x:c,y:n.y}:{x:n.x,y:s}),o&&o.x!==d&&o.y!==u&&p.push("ns"===a?{x:d,y:o.y}:"ew"===a?{x:o.x,y:u}:o.x===f[f.length-3].x?{x:d,y:o.y}:{x:o.x,y:u}),[r,...v(r,p,i),i]}const S=null!=M?M:f(t,e),L=null!=I?I:f(e,t),{x:z,y:P}=h(e,S),{x:R,y:N}=h(t,L),A=(0,r.X)(),T=null!==(p=null===(y=A.find((e=>e.x===S.x&&e.y===S.y)))||void 0===y?void 0:y.d)&&void 0!==p?p:d,H=null!==(w=null===(x=A.find((e=>e.x===L.x&&e.y===L.y)))||void 0===x?void 0:x.d)&&void 0!==w?w:d,D=[...T],W=[...H];z<R?((0,o.pull)(D,"left"),(0,o.pull)(W,"right")):((0,o.pull)(D,"right"),(0,o.pull)(W,"left")),P<N?((0,o.pull)(D,"top"),(0,o.pull)(W,"bottom")):((0,o.pull)(D,"bottom"),(0,o.pull)(W,"top"));const Z=null!==(E=D[0])&&void 0!==E?E:T[0],$=null!==(k=W[0])&&void 0!==k?k:H[0],B="left"===Z||"right"===Z?S.y:S.x,j="left"===$||"right"===$?L.y:L.x;return(0,i.o)(l(e,a.XK),l(t,a.XK),Z,$,B,j)}function v(e,t,n){const o=[];let r,i=e,l=0;for(;l<t.length;){const e=t[l],a=e.x!==i.x,c=e.y!==i.y;if(a||c){const c=a?"ew":"ns";if(c!==r){const a=l===t.length-1?n:t[l+1],s=a.x!==e.x,d=a.y!==e.y;(s||d)&&c!==(s?"ew":"ns")&&(r=c,o.push(e),i=e)}}l++}return o}function f(e,t){return t.y+t.height<e.y?{x:.5,y:1}:t.y>e.y+e.height?{x:.5,y:0}:t.x<e.x?{x:1,y:.5}:{x:0,y:.5}}function h(e,t){const n=a.XK/2;return{x:e.x-n+t.x*(e.width+a.XK),y:e.y-n+t.y*(e.height+a.XK)}}function m(e,t,n){let o,r,i,l,c;if(n?(o="y",r="x",i="height",l="width"):(o="x",r="y",i="width",l="height"),t[r]+t[l]<e[r]&&(c={[o]:.5,[r]:1}),t[r]>e[r]&&(c={[o]:.5,[r]:0}),c)return h(t,c);const s=t[o]<e[o]?1:0;return{[o]:t[o]-a.XK/2+s*(t[i]+a.XK),[r]:e[r]}}function g(e,t,n,o){let r,i,l,a,c,s,d,u;"ns"===o?(l="x",a="y",c="width",s="height",d="ns",u="ew"):(l="y",a="x",c="height",s="width",d="ew",u="ns");const v=n[0];if(v[l]>=e[l]&&v[l]<=e[l]+e[c])if(v[a]>e[a]+e[s])r={[l]:v[l],[a]:e[a]+e[s]},i=d;else if(v[a]<e[a])r={[l]:v[l],[a]:e[a]},i=d;else{var f;const o=null!==(f=n[1])&&void 0!==f?f:t;r={[l]:v[l],[a]:o[a]<v[a]?v[a]:e[a]+e[s]},i=d}else v[a]<e[a]?(r={[l]:e[l]+e[c]/2,[a]:e[a]},i=d):v[a]>e[a]+e[s]?(r={[l]:e[l]+e[c]/2,[a]:e[a]+e[s]},i=d):v[l]<e[l]?(r={[l]:e[l],[a]:v[a]},i=u):(r={[l]:e[l]+e[c],[a]:v[a]},i=u);return{point:r,direction:i}}},8875:(e,t,n)=>{n.d(t,{G:()=>l,X:()=>i});const o=[{x:0,y:0,d:["top","left"]},{x:.5,y:0,d:["top"]},{x:1,y:0,d:["top","right"]},{x:0,y:.5,d:["left"]},{x:1,y:.5,d:["right"]},{x:0,y:1,d:["bottom","left"]},{x:.5,y:1,d:["bottom"]},{x:1,y:1,d:["bottom","right"]}],r=o.map((e=>({x:e.x,y:e.y})));function i(){return o}function l(){return r}},1819:(e,t,n)=>{n.d(t,{J:()=>i});var o=n(8769),r=n(8185);function i(e){let{rootRef:t,activeTarget:n,doNotResetActiveTargetForSelector:i,doNotResetActiveTargetOutsideCanvas:l,onActiveTargetChange:a}=e;const c=null!=n?n:null,[s,d]=(0,o.useState)(c);(0,o.useEffect)((()=>{d((e=>(0,r.c)(e,c)?e:c))}),[c]);const u=(0,o.useRef)(!1);return(0,o.useEffect)((()=>{u.current?a(s):u.current=!0}),[s,a]),(0,o.useEffect)((()=>{if(!s)return;const e=e=>{const n=e.composedPath(),o=n.indexOf(t.current);(l?0!==o:!(o<=0)||i&&n.some((e=>e instanceof Element&&e.matches(i))))||d(null)};return document.addEventListener("click",e),()=>{document.removeEventListener("click",e)}}),[s,l,i,t]),s}},5915:(e,t,n)=>{n.d(t,{A:()=>a});var o=n(8769),r=n(531);function i(e,t){return e.find((e=>(0,r.o6)(e)&&e.id===t))}var l=n(967);function a(e){let{cells:t,lineConfMap:n}=e;return(0,o.useMemo)((()=>{const e=new WeakMap;for(const a of t)if((0,r.WW)(a)){var o;const c=n.get(a),s=i(t,a.source),d=i(t,a.target),u=(0,r.jw)(null===(o=a.view)||void 0===o?void 0:o.type)&&t.some((e=>{var t;return(0,r.WW)(e)&&e.source===a.target&&e.target===a.source&&(0,r.jw)(null===(t=e.view)||void 0===t?void 0:t.type)}))?c.parallelGap:0,v=s&&d&&null!=s.view.x&&null!=d.view.x?(0,l.V)(s.view,d.view,a.view,u):null;v&&e.set(a,{edge:a,points:v,source:s,target:d,parallelGap:u})}return e}),[t,n])}},1484:(e,t,n)=>{n.d(t,{g:()=>f});var o=n(8769),r=n(7566),i=n(9047),l=n(3033),a=n(531),c=n(908),s=n(6170),d=n(9127);const u=new Map([["center",.5],["left",0],["right",1],["top",0],["bottom",1]]);function v(e,t){if("string"==typeof e){const n=u.get(e);if(void 0!==n)return n;const o=e.match(/^(-?\d+(?:\.\d+)?)%$/);if(o)return Number(o[1])/100;console.error("Unexpected align origin %s:",t,e)}else{if("number"==typeof e)return e;console.error("Unexpected align origin %s, expected %s, received %s:",t,"string | number",typeof e,e)}return.5}function f(e){let{layout:t,layoutOptions:n,rootRef:u,cells:f,zoomable:h,zoomer:m,scaleRange:g,layoutKey:p,allowEdgeToArea:y,autoCenterWhenCellsChange:w,dispatch:x}=e;const[E,k]=(0,o.useState)("force"!==t&&"dagre"!==t),b=(0,o.useRef)(p),C=(0,o.useCallback)((()=>++b.current),[]),[M,I]=function(e){let{rootRef:t,cells:n,layoutInitialized:s,zoomable:d,zoomer:u,scaleRange:v,autoCenterWhenCellsChange:f}=e;const[h,m]=(0,o.useState)(!1);return(0,o.useEffect)((()=>{n.some((e=>(0,a.N)(e)||(0,a.mH)(e)))&&!f||m(!1)}),[n,f]),(0,o.useEffect)((()=>{const e=t.current;if(!e||!s||h||!n.some((e=>(0,a.N)(e)||(0,a.mH)(e)))||n.some((e=>(0,a.N)(e)&&!e[l.CV])))return;const{k:o,x:f,y:g}=(0,c.r)(n,{canvasWidth:e.clientWidth,canvasHeight:e.clientHeight,scaleRange:d?v:void 0});u.transform((0,r.A)(e),new i.uV(o,f,g)),m(!0)}),[n,h,s,t,v,d,u]),[h,m]}({rootRef:u,layoutInitialized:E,cells:f,zoomable:h,zoomer:m,scaleRange:g,autoCenterWhenCellsChange:w}),S=(0,o.useRef)(null);return(0,o.useEffect)((()=>{if(f.some((e=>(0,a.N)(e)&&!e[l.CV]))||0===f.length)return;if("force"!==t&&"dagre"!==t)return void k(!0);if(b.current!==p||(e=S.current,o=f.filter(a.nv),(null==e?void 0:e.length)===o.length&&e.every(((e,t)=>e===o[t]))))return;var e,o;let r,i;({getNodeView:r,nodePaddings:i}="force"===t?(0,s.k)({cells:f,layoutOptions:n,allowEdgeToArea:y}):(0,d.C)({cells:f,layoutOptions:n,allowEdgeToArea:y}));const c=function(e){const t=null!=e?e:[.5,.5];return[v(t[0],"x"),v(t[1],"y")]}(null==n?void 0:n.alignOrigin),u=f.map((e=>{if(y&&(0,a.o6)(e)||(0,a.N)(e)){const t=r(e.id);return{...e,view:{...e.view,x:t.x-t.width*c[0]+i[3],y:t.y-t.height*c[1]+i[0]},[l.xc]:!0}}return e}));S.current=u.filter(a.nv),x({type:"update-cells",payload:u}),k(!0)}),[f,x,t,p,n]),{centered:M,setCentered:I,getNextLayoutKey:C}}},7531:(e,t,n)=>{n.d(t,{I:()=>d,d:()=>c});var o=n(8769),r=n(2716),i=n(1030),l=n(531),a=n(3033);function c(e){let{cells:t,defaultEdgeLines:n,markerPrefix:c,lineConnector:f}=e;return(0,o.useMemo)((()=>{const e=[{strokeColor:a.mF,markerType:"arrow"}];let o=null;if(f){o={...v(),editingStrokeColor:"var(--palette-blue-5)",...(0,i.omitBy)(!0===f?{}:f,i.isUndefined)};const t=d(o);for(const n of t){const{placement:t,type:r}=n,i=null!=r?r:"arrow",l=u({strokeColor:o.strokeColor,markerType:i},e),a=u({strokeColor:o.editingStrokeColor,markerType:i},e);"start"===t?(o.$markerStartUrl=`url(#${c}${l})`,o.$editingStartMarkerUrl=`url(#${c}${a})`):(o.$markerEndUrl=`url(#${c}${l})`,o.$editingEndMarkerUrl=`url(#${c}${a})`)}}const h=new WeakMap;for(const o of t)if((0,l.WW)(o)){var m,g;const t=null!==(m=Array.isArray(n)?s(n.find((e=>(0,r.checkIfByTransform)(e,{edge:o}))),o):null===(g=r.__secret_internals.legacyDoTransform({edge:o},n))||void 0===g?void 0:g.find((e=>(0,r.checkIfOfComputed)(e))))&&void 0!==m?m:{},l={...v(),...(0,i.omitBy)(t,i.isUndefined),...(0,i.omitBy)(o.view,i.isUndefined)};void 0===l.parallelGap&&(l.parallelGap=l.interactStrokeWidth);const a=d(l);for(const t of a){var p,y;const{placement:n,type:o}=t,r=null!=o?o:"arrow",i=u({strokeColor:l.strokeColor,markerType:r},e);"start"===n?l.$markerStartUrl=`url(#${c}${i})`:l.$markerEndUrl=`url(#${c}${i})`;const a=null===(p=l.overrides)||void 0===p||null===(p=p.active)||void 0===p?void 0:p.strokeColor;if(a&&a!==l.strokeColor){const t=u({strokeColor:a,markerType:r},e);"start"===n?l.$activeMarkerStartUrl=`url(#${c}${t})`:l.$activeMarkerEndUrl=`url(#${c}${t})`}const s=null===(y=l.overrides)||void 0===y||null===(y=y.activeRelated)||void 0===y?void 0:y.strokeColor;if(s&&s!==l.strokeColor){const t=u({strokeColor:s,markerType:r},e);"start"===n?l.$activeRelatedMarkerStartUrl=`url(#${c}${t})`:l.$activeRelatedMarkerEndUrl=`url(#${c}${t})`}}h.set(o,l)}return{lineConfMap:h,lineConnectorConf:o,markers:e}}),[t,n,f,c])}function s(e,t){var n;if(null!=e&&null!==(n=e.label)&&void 0!==n&&n.useBrick){const{label:{useBrick:n,...o},...i}=e,l=r.__secret_internals.legacyDoTransform({edge:t},{...i,label:o});return{...l,label:{...l.label,useBrick:n}}}return r.__secret_internals.legacyDoTransform({edge:t},e)}function d(e){let t=[];return e.markers?t=e.markers:(e.showStartArrow&&t.push({type:"arrow",placement:"start"}),e.showEndArrow&&t.push({type:"arrow",placement:"end"})),t}function u(e,t){let n=(0,i.findIndex)(t,e);return-1===n&&(n=t.push(e)-1),n}function v(){return{type:"straight",dashed:!1,strokeColor:a.mF,strokeWidth:a.VO,interactStrokeWidth:a.Ie,showStartArrow:a.XV,showEndArrow:a.Ub,animate:{useAnimate:!1,duration:a.Be}}}},8197:(e,t,n)=>{n.d(t,{H:()=>l});var o=n(8769),r=n(531),i=n(3033);function l(e){let{cells:t,layout:n,centered:l}=e;return(0,o.useMemo)((()=>l&&t.every((e=>!(0,r.N)(e)||e[i.CV]&&("force"!==n&&"dagre"!==n||e[i.xc])))),[t,l,n])}},8091:(e,t,n)=>{n.d(t,{f:()=>v});var o,r,i,l=n(8769),a=n(7566),c=n(9047),s=n(3033);const d=/mac/i.test(null!==(o=null!==(r=null===(i=navigator.userAgentData)||void 0===i?void 0:i.platform)&&void 0!==r?r:navigator.platform)&&void 0!==o?o:navigator.userAgent);function u(e){return-e.deltaY*(1===e.deltaMode?.05:e.deltaMode?1:.002)*(e.ctrlKey&&d?10:1)}function v(e){let{rootRef:t,zoomable:n,scrollable:o,pannable:r,draggable:i,ctrlDraggable:d,scaleRange:v,onSwitchActiveTarget:f}=e;const[h,m]=(0,l.useState)(!1),[g,p]=(0,l.useState)({k:1,x:0,y:0}),y=(0,l.useMemo)((()=>null!=v?v:[s.sS,s.Yt]),[v]),w=(0,l.useMemo)((()=>(0,c.s_)().wheelDelta(u)),[]);return(0,l.useEffect)((()=>{let e=!1;w.scaleExtent(n?y:[1,1]).on("start",(()=>{e=!1,m(!0)})).on("zoom",(t=>{e=!0,p(t.transform)})).on("end",(()=>{m(!1),e||null==f||f(null)})).filter((e=>("wheel"===e.type||(d?i||e.ctrlKey:!e.ctrlKey))&&!e.button))}),[f,y,n,w,d,i]),(0,l.useEffect)((()=>{if(d){const e=e=>{e.ctrlKey&&e.preventDefault()};return document.addEventListener("contextmenu",e,!0),()=>{document.removeEventListener("contextmenu",e,!0)}}}),[d]),(0,l.useEffect)((()=>{const e=t.current;if(!e)return;const l=(0,a.A)(e),c=()=>{l.on(".zoom",null).on(".zoom.custom",null).on("wheel",null)};if(n||o||r)return(n||o)&&l.on("wheel.zoom.custom",(e=>{e.ctrlKey||(e.stopImmediatePropagation(),o&&(e.preventDefault(),w.translateBy(l,e.wheelDeltaX/5,e.wheelDeltaY/5)))})),l.call(w).on("wheel",(e=>{e.preventDefault()})).on("dblclick.zoom",null),(i||d)&&r||l.on("mousedown.zoom",null),r||l.on("touchstart.zoom",null).on("touchmove.zoom",null).on("touchend.zoom",null),c;c()}),[d,i,r,t,o,n,w]),{grabbing:h,transform:g,zoomer:w,scaleRange:y}}},6237:(e,t,n)=>{n.d(t,{A:()=>a});var o=n(6758),r=n.n(o),i=n(935),l=n.n(i)()(r());l.push([e.id,'.zoom-bar{position:absolute;bottom:20px;right:20px;width:40px;scale:0.8}.zoom-slider,\n.center-button{width:100%;display:flex;align-items:center;border:1px solid var(--antd-background-color-base);border-radius:var(--larger-border-radius);box-shadow:var(--connected-overlay-shadow);background-color:var(--color-fill-bg-container-4)}.zoom-slider{height:140px;padding:8px 0;flex-direction:column}[role="button"]{cursor:pointer}.center-button{justify-content:center;margin-bottom:8px;height:40px}.center-button:hover{border-color:var(--antd-btn-default-hover-border-color)}.center-button path{fill:var(--antd-link-hover-color)}.center-button:hover path{fill:var(--palette-blue-7)}.zoom-button{font-size:16px;line-height:0}.zoom-button svg{width:1em;height:1em;fill:var(--antd-link-hover-color)}.zoom-slider .ant-slider-vertical{padding-left:5px;padding-right:5px}.zoom-slider .ant-slider-vertical .ant-slider-rail{width:2px}.zoom-slider .ant-slider-vertical .ant-slider-handle{width:6px;height:6px;left:3px}.zoom-slider .ant-slider .ant-slider-handle:hover::before,\n.zoom-slider .ant-slider .ant-slider-handle:focus::before,\n.zoom-slider .ant-slider .ant-slider-handle::before{width:10px;height:10px;left:-2px}.zoom-slider .ant-slider .ant-slider-handle:hover::after,\n.zoom-slider .ant-slider .ant-slider-handle:focus::after,\n.zoom-slider .ant-slider .ant-slider-handle::after{width:6px;height:6px;top:0;left:0}',""]);const a=l.toString()},3012:(e,t,n)=>{n.d(t,{A:()=>a});var o=n(6758),r=n.n(o),i=n(935),l=n.n(i)()(r());l.push([e.id,"*{box-sizing:border-box}:host{display:block;position:relative;overflow:hidden;--animation-dasharray:48;--stroke-dashedoffset:96;--stroke-dottedoffset:24;--dasharray:4;--dotted:1}:host,\n.root{width:100%;height:100%}:host([hidden]){display:none}.root{opacity:0}.root.ready{opacity:1}.root:focus{outline:none}@keyframes solidAnimation{to{stroke-dashoffset:0}}@keyframes dashedAnimation{0%{stroke-dashoffset:var(--stroke-dashedoffset)}to{stroke-dashoffset:0}}@keyframes dottedAnimation{0%{stroke-dashoffset:var(--stroke-dottedoffset)}to{stroke-dashoffset:0}}.solid-animation{stroke-dasharray:var(--solid-length);stroke-dashoffset:var(--solid-length);animation:solidAnimation var(--time) linear infinite}.dashed-animation{animation:dashedAnimation var(--time) linear infinite}.dotted-animation{animation:dottedAnimation var(--time) linear infinite}.decorator-area .area,\n.decorator-container .container{fill:rgba(73,126,255,0.1);stroke:none;stroke-width:0}.node,\n.decorator-text{overflow:visible}.cell.active .decorator-area .area,\n.cell.active .decorator-container .container,\n.cell:not(.read-only) .decorator-container .container:hover,\n.allowEdgeToArea .decorator-area .area:hover,\n.cell.active .line-active-bg{stroke:var(--palette-blue-5);stroke-dasharray:var(--dasharray);stroke-width:1}.container-active .decorator-container .container{stroke:var(--palette-blue-5);stroke-width:1}.cell:not(.read-only){-webkit-user-select:none;user-select:none}.resize-handle{cursor:nwse-resize;opacity:0}.resize-handle rect{fill:transparent;stroke:none}.resize-handle path{fill:none;stroke:var(--palette-gray-5);stroke-width:1.5}.cell.active .decorator-area .resize-handle,\n.decorator-area:hover .resize-handle,\n.decorator-container:hover .resize-handle{opacity:1}.connect-line{pointer-events:none}.connect-line:not(.connecting){display:none}.editing-line{pointer-events:none;stroke-dasharray:var(--dasharray);stroke-width:1}.editing-line:not(.editing){display:none}.line.dashed{stroke-dasharray:var(--dasharray)}.line.dotted{stroke-dasharray:var(--dotted)}.cell.active .decorator-text .text-container{outline:1px dashed var(--palette-blue-5)}.decorator-text .text-container{width:max-content;padding:0.5em}.decorator-text .text:focus{outline:none}.cell.faded{opacity:0.3}.cell.container-active{opacity:1}.cell .node{pointer-events:none}.cell .node > *{position:fixed;pointer-events:auto}.degraded{pointer-events:bounding-box}.degraded circle{fill:rgb(119,141,195)}.degraded text{text-anchor:middle;fill:var(--antd-text-color)}.cell.active .degraded circle,\n.cell.active .degraded text,\n.degraded:hover circle,\n.degraded:hover text{fill:var(--color-brand)}.decorator-container{--defaultSize:24px}.decorator-container .text-container{display:flex;align-items:center;justify-content:center;padding:0.5em;text-align:center;font-size:16px;background-color:rgba(73,126,255,0.6);overflow:hidden}.decorator-container .horizontal{height:max-content;width:100%}.decorator-container .horizontal .text{min-height:var(--defaultSize)}.decorator-container .vertical{width:max-content;height:100%;writing-mode:vertical-lr;-webkit-text-orientation:upright;text-orientation:upright;letter-spacing:4px}.decorator-container .vertical .text{min-width:var(--defaultSize)}.line-label-container{overflow:visible;opacity:0}.line-label-container.ready{opacity:1}.line-label{position:absolute;display:block;transform:translate(-50%,-50%);white-space:pre-line;width:max-content;text-align:center}.line-label.text{font-size:11px;color:var(--color-secondary-text);font-weight:400;line-height:1.63636364}.motion:not(.visible){opacity:0}",""]);const a=l.toString()}}]);
2
+ //# sourceMappingURL=8552.b1182b74.js.map