@next-bricks/diagram 0.32.4 → 0.32.5

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.
@@ -0,0 +1,2 @@
1
+ "use strict";(self.webpackChunk_next_bricks_diagram=self.webpackChunk_next_bricks_diagram||[]).push([[6974],{3739:(e,t,r)=>{r.d(t,{c:()=>o});var n=r(8769),a=r.n(n);function o(e){var t,{id:r,type:n,strokeColor:o}=e;switch(n){case"0..1":t=l;break;case"0..N":t=d;break;default:t=i}return a().createElement(t,{id:r,strokeColor:o})}function i(e){var{id:t,strokeColor:r}=e;return a().createElement("marker",{id:t,viewBox:"0 0 6 6",refX:5,refY:3,markerWidth:6,markerHeight:6,orient:"auto-start-reverse",strokeLinejoin:"round"},a().createElement("path",{d:"M 0.5 0.5 L 5.5 3 L 0.5 5.5 z",stroke:r,strokeWidth:1,fill:r}))}function l(e){var{id:t,strokeColor:r}=e;return a().createElement("marker",{id:t,viewBox:"0 0 21 11",refX:.5,refY:5.5,markerWidth:21,markerHeight:11,orient:"auto-start-reverse"},a().createElement("path",{d:"M 5.5 5.5 m 5 0 a 5 5 0 1 0 -10 0 a 5 5 0 1 0 10 0 M 15.5 0.5 V 10.5 M 10.5 5.5 H 20.5",stroke:r,strokeWidth:1,fill:"none"}))}function d(e){var{id:t,strokeColor:r}=e;return a().createElement("marker",{id:t,viewBox:"0 0 21 11",refX:.5,refY:5.5,markerWidth:21,markerHeight:11,orient:"auto-start-reverse"},a().createElement("path",{d:"M 5.5 5.5 m 5 0 a 5 5 0 1 0 -10 0 a 5 5 0 1 0 10 0 M 20.5 0.5 L 10.5 5.5 L 20.5 10.5 M 10.5 5.5 H 20.5",stroke:r,strokeWidth:1,fill:"none"}))}},3188:(e,t,r)=>{r.d(t,{h:()=>a});var n=r(733);function a(e,t,r){if(e===t||(0,n.w)(e,t,0,0))return null;var a,i,l=0,d=0;if(r){var c=t.x-e.x,s=t.y-e.y,u=Math.atan2(s,c);l=r/2*Math.cos(u+Math.PI/2),d=r/2*Math.sin(u+Math.PI/2)}var h=[[e.x+l,e.y+d],[t.x+l,t.y+d]],v=o(e,h),f=o(t,h);return a=v.length>0?v[0]:[e.x,e.y],i=f.length>0?f[0]:[t.x,t.y],[{x:a[0],y:a[1]},{x:i[0],y:i[1]}]}function o(e,t){for(var r=[[e.x-e.width/2,e.y-e.height/2],[e.x+e.width/2,e.y-e.height/2],[e.x+e.width/2,e.y+e.height/2],[e.x-e.width/2,e.y+e.height/2]],n=[],a=0;a<4;a++)n.push([r[a],r[(a+1)%4]]);var o=[];for(var l of n){var d=i(t[0],t[1],l[0],l[1]);d&&o.push(d)}return o}function i(e,t,r,n){var[a,o]=e,[i,l]=t,[d,c]=r,[s,u]=n;if(a===i&&o===l||d===s&&c===u)return null;var h=(u-c)*(i-a)-(s-d)*(l-o);if(0===h)return null;var v=((s-d)*(o-c)-(u-c)*(a-d))/h,f=((i-a)*(o-c)-(l-o)*(a-d))/h;return v<0||v>1||f<0||f>1?null:[a+v*(i-a),o+v*(l-o)]}},733:(e,t,r)=>{function n(e,t,r,n){var o=r?a(e,r):e,i=n?a(t,n):t,l=Math.min(o.x-o.width/2,i.x-i.width/2),d=Math.max(o.x+o.width/2,i.x+i.width/2),c=Math.min(o.y-o.height/2,i.y-i.height/2),s=Math.max(o.y+o.height/2,i.y+i.height/2);return d-l<o.width+i.width&&s-c<o.height+i.height}function a(e,t){return{x:e.x-e.width/2-t,y:e.y-e.height/2-t,width:e.width+2*t,height:e.height+2*t}}r.d(t,{w:()=>n})},8802:(e,t,r)=>{function n(e){if(Array.isArray(e)){var t=e[0],r=e.length>1?e[1]:t;return[t,r,e.length>2?e[2]:t,e.length>3?e[3]:r]}return new Array(4).fill(e)}r.d(t,{D:()=>n})},2830:(e,t,r)=>{r.d(t,{m:()=>A});var n=r(8769),a=r.n(n),o=r(3373),i=r.n(o),l=r(531),d=r(3188);function c(e,t){return e.find((e=>(0,l.N)(e)&&e.id===t))}var s=r(3033);function u(e){var t,r,o,{edge:u,cells:v,lineConfMap:f}=e,m=(0,n.useRef)(null),g=(0,n.useMemo)((()=>c(v,u.source)),[v,u.source]),p=(0,n.useMemo)((()=>c(v,u.target)),[v,u.target]),w=(0,n.useMemo)((()=>f.get(u)),[u,f]),y=(0,n.useMemo)((()=>v.some((e=>(0,l.WW)(e)&&e.source===u.target&&e.target===u.source))?w.parallelGap:0),[v,u,w.parallelGap]),x=(0,n.useMemo)((()=>g&&p&&null!=g.view.x&&null!=p.view.x?(0,d.h)(h(g.view,5),h(p.view,5),y):null),[y,g,p]);if(!x)return null;var k="M".concat(x[0].x," ").concat(x[0].y,"L").concat(x[1].x," ").concat(x[1].y);return a().createElement(a().Fragment,null,a().createElement("path",{d:k,fill:"none",stroke:"transparent",strokeWidth:w.interactStrokeWidth}),a().createElement("path",{ref:m,className:i()("line",{dashed:w.dashed,["".concat(w.dashed?"dashed":"solid","-animation")]:w.animate.useAnimate}),style:{"--time":"".concat(null!==(t=w.animate.duration)&&void 0!==t?t:s.Be,"s"),"--solid-length":null===(r=m.current)||void 0===r||null===(o=r.getTotalLength)||void 0===o?void 0:o.call(r)},d:k,fill:"none",stroke:w.strokeColor,strokeWidth:w.strokeWidth,markerStart:w.showStartArrow?w.markerArrow:"",markerEnd:w.showEndArrow?w.markerArrow:""}),a().createElement("path",{className:"line-active-bg",d:k,fill:"none"}))}function h(e,t){return{x:e.x+e.width/2,y:e.y+e.height/2,width:e.width+t,height:e.height+t}}var v=r(6263),f=r(5530),m=r(1030),g=r(9126);function p(e){var{node:t,degraded:r,degradedNodeLabel:o,defaultNodeBricks:i,onResize:l}=e,d=function(e){var[t,r]=(0,n.useState)(e);return(0,n.useEffect)((()=>{r((t=>(0,m.isEqual)(t,e)?t:e))}),[e]),t}({node:{id:t.id,data:t.data}}),c=t.useBrick,s=(0,n.useRef)(null),u=(0,n.useMemo)((()=>{var e;return r?null:null!=c?c:null==i||null===(e=i.find((e=>(0,f.checkIfByTransform)(e,d))))||void 0===e?void 0:e.useBrick}),[r,c,i,d]),h=(0,n.useMemo)((()=>r?String(f.__secret_internals.legacyDoTransform(d,null!=o?o:"<% DATA.node.id %>")):""),[r,o,d]),p=(0,n.useCallback)((e=>{var r=s.current;r&&(r.disconnect(),s.current=null),e?setTimeout((()=>{var r=new g.A((()=>{l(t.id,[e.offsetWidth,e.offsetHeight])}));r.observe(e),s.current=r})):l(t.id,null)}),[t.id,l]),w=(0,n.useCallback)((e=>{if(e){var r=e.getBBox();l(t.id,[r.width,r.height])}else l(t.id,null)}),[t.id,l]);return u?a().createElement("foreignObject",{width:9999,height:9999,className:"node"},u&&a().createElement(v.ReactUseBrick,{useBrick:u,data:d,refCallback:p})):r?a().createElement("g",{className:"degraded",ref:w},a().createElement("circle",{cx:8,cy:8,r:8}),a().createElement("text",{x:8,y:32},h)):null}function w(e){return"edge"===e.type?(0,m.pick)(e,["type","source","target","data"]):(0,m.pick)(e,["type","id","data"])}function y(e,t){var{action:r,cell:n,scale:a,layout:o,onCellMoving:i,onCellMoved:d,onCellResizing:c,onCellResized:s,onSwitchActiveTarget:u}=t;if(e.stopPropagation(),null==u||u(w(n)),!(0,l.WW)(n)&&("force"!==o&&"dagre"!==o||!(0,l.N)(n))){var h=[e.clientX,e.clientY],v="move"===r?[n.view.x,n.view.y]:[n.view.width,n.view.height],f=!1,m=(e,t)=>{var o,l,u=function(e){return[(e.clientX-h[0])/a,(e.clientY-h[1])/a]}(e);f||(f=u[0]**2+u[1]**2>=9),f&&("move"===r?null===(o=t?d:i)||void 0===o||o({type:n.type,id:n.id,x:v[0]+u[0],y:v[1]+u[1]}):null===(l=t?s:c)||void 0===l||l({type:n.type,id:n.id,width:v[0]+u[0],height:v[1]+u[1]}))},g=e=>{m(e)},p=e=>{m(e,!0),f=!1,document.removeEventListener("mousemove",g),document.removeEventListener("mouseup",p)};document.addEventListener("mousemove",g),document.addEventListener("mouseup",p)}}function x(e){var{cell:t,transform:r,readOnly:o,onCellResizing:i,onCellResized:l,onSwitchActiveTarget:d}=e,c=a().useRef(null);return(0,n.useEffect)((()=>{var e=c.current;if(e&&!o){var n=e=>{y(e,{action:"resize",cell:t,scale:r.k,onCellResizing:i,onCellResized:l,onSwitchActiveTarget:d})};return e.addEventListener("mousedown",n),()=>{e.removeEventListener("mousedown",n)}}}),[t,l,i,d,o,r.k]),a().createElement("g",{className:"decorator-area"},a().createElement("rect",{width:t.view.width,height:t.view.height,className:"area"}),!o&&a().createElement("g",{ref:c,className:"resize-handle",transform:"translate(".concat(t.view.width-20," ").concat(t.view.height-20,")")},a().createElement("rect",{width:20,height:20}),a().createElement("path",{d:"M10 18L18 10 M15 18L18 15"})))}var k=r(9740);function b(e){var t,{cell:r,readOnly:o,onDecoratorTextEditing:l,onDecoratorTextChange:d}=e,c=null!==(t=r.view.text)&&void 0!==t?t:"",[s,u]=(0,n.useState)(c),[h,v]=(0,n.useState)(!1),f=(0,n.useRef)(!1),[m,g]=(0,n.useState)(!1),p=(0,n.useRef)(null),w=(0,n.useCallback)((e=>{o||(e.preventDefault(),e.stopPropagation(),v(!0))}),[o]);(0,n.useEffect)((()=>{var e=p.current;e&&e.textContent!==s&&(e.textContent=s)}),[s]),(0,n.useEffect)((()=>{h&&p.current&&(p.current.focus(),function(e){var t=document.createRange();t.selectNodeContents(e);var r=window.getSelection();r.removeAllRanges(),r.addRange(t)}(p.current)),null==l||l({id:r.id,editing:h})}),[r.id,h,l]),(0,n.useEffect)((()=>{f.current?null==l||l({id:r.id,editing:h}):f.current=!0}),[r.id,h,l]);var y=(0,n.useCallback)((e=>{o||u(e.target.textContent)}),[o]),x=(0,n.useCallback)((()=>{o||(v(!1),g(!0))}),[o]);return(0,n.useEffect)((()=>{m&&(null==d||d({id:r.id,view:(0,k.A)((0,k.A)({},r.view),{},{text:s})}),g(!1))}),[r,s,d,m]),a().createElement("foreignObject",{className:"decorator-text"},a().createElement("div",{className:i()("text-container",{editing:h}),onDoubleClick:w},a().createElement("div",{className:"text",contentEditable:h,ref:p,onInput:y,onBlur:x})))}function C(e){var t,{cell:r,transform:n,readOnly:o,onCellResizing:i,onCellResized:l,onSwitchActiveTarget:d,onDecoratorTextEditing:c,onDecoratorTextChange:s}=e;switch(r.decorator){case"area":t=x;break;case"text":t=b;break;default:return console.error("Unknown decorator: ".concat(r.decorator)),null}return a().createElement(t,{cell:r,transform:n,readOnly:o,onCellResizing:i,onCellResized:l,onSwitchActiveTarget:d,onDecoratorTextEditing:c,onDecoratorTextChange:s})}var E=r(8185);function A(e){var{layout:t,cell:r,cells:o,degraded:d,degradedNodeLabel:c,defaultNodeBricks:s,lineConfMap:h,active:v,readOnly:f,transform:m,unrelatedCells:g,onCellMoving:x,onCellMoved:k,onCellResizing:b,onCellResized:A,onSwitchActiveTarget:z,onCellContextMenu:M,onCellClick:N,onDecoratorTextEditing:R,onDecoratorTextChange:S,onNodeBrickResize:W,onCellMouseEnter:L,onCellMouseLeave:T}=e,D=(0,n.useRef)(null),B=(0,n.useMemo)((()=>g.some((e=>(0,E.c)(e,r)))),[r,g]);(0,n.useEffect)((()=>{var e=D.current;if(e&&!f){var n=e=>{y(e,{layout:t,action:"move",cell:r,scale:m.k,onCellMoving:x,onCellMoved:k,onSwitchActiveTarget:z})};return e.addEventListener("mousedown",n),()=>{e.removeEventListener("mousedown",n)}}}),[t,r,k,x,z,f,m.k]);var P=(0,n.useCallback)((e=>{f&&"decorator"===r.type||(e.preventDefault(),z(w(r)),M({cell:r,clientX:e.clientX,clientY:e.clientY}))}),[r,M,z,f]),V=(0,n.useCallback)((e=>{N&&"decorator"!==r.type&&N({cell:r,clientX:e.clientX,clientY:e.clientY})}),[r,N]),H=(0,n.useCallback)((()=>{null==L||L(r)}),[r,L]),O=(0,n.useCallback)((()=>{null==T||T(r)}),[r,T]);return a().createElement("g",{className:i()("cell",{active:v,faded:B,"read-only":f}),ref:D,transform:"edge"===r.type||null==r.view.x?void 0:"translate(".concat(r.view.x," ").concat(r.view.y,")"),onContextMenu:P,onClick:V,onMouseEnter:H,onMouseLeave:O},(0,l.N)(r)?a().createElement(p,{node:r,degraded:d,degradedNodeLabel:c,defaultNodeBricks:s,onResize:W}):(0,l.WW)(r)?a().createElement(u,{edge:r,cells:o,lineConfMap:h}):(0,l.mH)(r)?a().createElement(C,{cell:r,transform:m,readOnly:f,onCellResizing:b,onCellResized:A,onSwitchActiveTarget:z,onDecoratorTextEditing:R,onDecoratorTextChange:S}):null)}},3033:(e,t,r)=>{r.d(t,{Be:()=>g,CV:()=>n,HP:()=>o,Ie:()=>v,N8:()=>l,Ub:()=>m,VO:()=>h,XV:()=>f,Yt:()=>s,mF:()=>u,pC:()=>p,sS:()=>c,sz:()=>i,w1:()=>d,xc:()=>a});var n=Symbol.for("size-initialized"),a=Symbol.for("layout-initialized"),o=20,i=36,l=100,d=60,c=.5,s=2,u="gray",h=1,v=15,f=!1,m=!0,g=1,p=500},531:(e,t,r)=>{function n(e){return"node"===e.type}function a(e){return"decorator"===e.type}function o(e){return"node"===e.type}function i(e){return"edge"===e.type}function l(e){return"node"===e.type||"edge"===e.type}r.d(t,{N:()=>n,WW:()=>i,mH:()=>a,nv:()=>l,vC:()=>o})},227:(e,t,r)=>{r.d(t,{Y:()=>a});var n=r(8185);function a(e,t,r){var a=[];if(t){var o=new Set;for(var i of e)"edge"===i.type&&i.source===t.source.id&&o.add(i.target);for(var l of e)"node"===l.type?o.has(l.id)&&a.push(l):a.push(l)}else switch(null==r?void 0:r.type){case"node":var d=new Map,c=new Set([r.id]);for(var s of e)"node"===s.type?d.set(s.id,s):"edge"===s.type?s.source===r.id?c.add(s.target):s.target===r.id?c.add(s.source):a.push(s):a.push(s);for(var[u,h]of d)c.has(u)||a.push(h);break;case"edge":for(var v of e)("edge"===v.type?(0,n.c)(v,r):"node"===v.type&&(v.id===r.source||v.id===r.target))||a.push(v)}return a}},3783:(e,t,r)=>{r.d(t,{C:()=>o});var n=r(9740),a=r(531);function o(e,t){var{defaultNodeSize:r}=t;return(null!=e?e:[]).map((e=>{var t,o;return!(0,a.vC)(e)||void 0!==(null===(t=e.view)||void 0===t?void 0:t.width)&&void 0!==(null===(o=e.view)||void 0===o?void 0:o.height)?e:(0,n.A)((0,n.A)({},e),{},{view:(0,n.A)({width:r[0],height:r[1]},e.view)})}))}},8185:(e,t,r)=>{function n(e,t){return e?!!t&&e.type===t.type&&("node"===e.type||"decorator"===e.type?e.id===t.id:e.source===t.source&&e.target===t.target):!t}r.d(t,{c:()=>n})},908:(e,t,r)=>{r.d(t,{r:()=>a});var n=r(531);function a(e,t){var{canvasWidth:r,canvasHeight:a,scaleRange:o}=t,i=1/0,l=1/0,d=-1/0,c=-1/0,s=!0;for(var u of e)if(!(0,n.WW)(u)){s=!1;var{view:h}=u,v=h.x+h.width,f=h.y+h.height;h.x<i&&(i=h.x),v>d&&(d=v),h.y<l&&(l=h.y),f>c&&(c=f)}var m=d-i,g=c-l,p=o&&!s&&(m>r||g>a)?Math.max(Math.min(r/m,a/g,o[1]),o[0]):1;return{x:s?0:(r-m*p)/2-i*p,y:s?0:(a-g*p)/2-l*p,k:p}}},5748:(e,t,r)=>{r.d(t,{d:()=>d});var n=r(9740),a=r(531),o=r(3033);function i(e,t,r){var n=e.findLastIndex(r)+1;return[...e.slice(0,n),t,...e.slice(n)]}var l,d=(l={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":var r=e.findLastIndex((e=>!("decorator"===e.type&&"text"===e.decorator)))+1;return[...e.slice(0,r),...t.payload,...e.slice(r)];case"add-edge":return i(e,t.payload,(e=>"edge"===e.type||"decorator"===e.type&&"area"===e.decorator));case"move-cell":var{type:l,id:d,x:c,y:s}=t.payload,u=e.findIndex((e=>e.type===l&&e.id===d));if(-1!==u){var h=e[u];return[...e.slice(0,u),(0,n.A)((0,n.A)({},h),{},{view:(0,n.A)((0,n.A)({},h.view),{},{x:c,y:s})}),...e.slice(u+1)]}return e;case"resize-cell":var{type:v,id:f,width:m,height:g}=t.payload,p=e.findIndex((e=>e.type===v&&e.id===f));if(-1!==p){var w=e[p];return[...e.slice(0,p),(0,n.A)((0,n.A)({},w),{},{view:(0,n.A)((0,n.A)({},w.view),{},{width:m,height:g})}),...e.slice(p+1)]}return e;case"update-cells":return t.payload;case"update-node-size":return e.map((e=>(0,a.N)(e)&&e.id===t.payload.id?(0,n.A)((0,n.A)({},e),{},{[o.CV]:!0,view:t.payload.size?(0,n.A)((0,n.A)({},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(l).map((r=>{var[n,a]=r;return[n,a(e[n],t)]}))))},7099:(e,t,r)=>{r.d(t,{Y:()=>f});var n=r(8769),a=r.n(n),o=r(2657),i=r(6768),l=r(198),d=r(8621),c=r(6263),s=r(9575);const u=e=>n.createElement("svg",(0,s.A)({xmlns:"http://www.w3.org/2000/svg",width:24,height:24,viewBox:"0 0 24 24"},e),n.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"})),h=e=>n.createElement("svg",(0,s.A)({xmlns:"http://www.w3.org/2000/svg",width:128,height:128,className:"icon",viewBox:"0 0 1024 1024"},e),n.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"}),n.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"})),v=e=>n.createElement("svg",(0,s.A)({xmlns:"http://www.w3.org/2000/svg",width:128,height:128,className:"icon",viewBox:"0 0 1024 1024"},e),n.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"}),n.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 f(e){var{shadowRoot:t,scale:r,scaleRange:s,onZoomChange:f,onReCenter:m}=e,g=(0,c.useCurrentTheme)(),p=(0,n.useMemo)((()=>(0,d.VC)()),[]),w=(0,n.useRef)(null),y=100*s[0],x=100*s[1],k=100*r,b=(0,n.useMemo)((()=>({formatter:e=>"".concat(e,"%"),placement:"left",getPopupContainer:()=>w.current})),[]),C=(0,n.useCallback)((()=>{f(Math.min(k+5,x))}),[x,f,k]),E=(0,n.useCallback)((()=>{f(Math.max(k-5,y))}),[y,f,k]);return a().createElement(o.Ay,{theme:{algorithm:"dark-v2"===g?i.A.darkAlgorithm:i.A.defaultAlgorithm}},a().createElement(d.N7,{container:t,autoClear:!0,cache:p,hashPriority:"high"},a().createElement("div",{className:"zoom-bar",ref:w},a().createElement("div",{className:"center-button",onClick:m,role:"button"},a().createElement(u,null)),a().createElement("div",{className:"zoom-slider"},a().createElement("div",{className:"zoom-button",role:"button",onClick:C},a().createElement(h,null)),a().createElement(l.A,{min:y,max:x,value:k,step:5,vertical:!0,included:!1,tooltip:b,onChange:f}),a().createElement("div",{className:"zoom-button",role:"button",onClick:E},a().createElement(v,null))))))}},9127:(e,t,r)=>{r.d(t,{C:()=>u});var n=r(9740),a=r(4223),o=r(1030),i=r(7586),l=r.n(i),d=r(8802),c=r(531),s=["nodePadding"];function u(e){var{cells:t,layoutOptions:r}=e,i=(0,n.A)({nodePadding:0,rankdir:"TB",ranksep:50,edgesep:10,nodesep:50},(0,o.pick)(r,["nodePadding","rankdir","ranksep","edgesep","nodesep","align"])),{nodePadding:u}=i,h=(0,a.A)(i,s),v=(0,d.D)(u);if(!t.some(c.N))return{getNodeView:()=>null,nodePaddings:v};var f=new(l().graphlib.Graph);for(var m of(f.setGraph(h),f.setDefaultEdgeLabel((function(){return{}})),t))(0,c.N)(m)?f.setNode(m.id,{id:m.id,width:m.view.width+v[1]+v[3],height:m.view.height+v[0]+v[2]}):(0,c.WW)(m)&&f.setEdge(m.source,m.target);return l().layout(f),{getNodeView:e=>f.node(e),nodePaddings:v}}},6170:(e,t,r)=>{r.d(t,{k:()=>v});var n=r(9740),a=r(1030),o=r(6149),i=r(4842),l=r(1945),d=r(9418),c=r(3854),s=r(7931),u=r(531),h=r(8802);function v(e){var{cells:t,layoutOptions:r,center:v,fixedPosition:f}=e,{nodePadding:m,collide:g}=(0,n.A)((0,n.A)({nodePadding:0},(0,a.pick)(r,["nodePadding"])),{},{collide:!1!==(null==r?void 0:r.collide)&&(0,n.A)({radiusDiff:18,strength:1,iterations:1},!0===(null==r?void 0:r.collide)?null:null==r?void 0:r.collide)}),p=(0,h.D)(m),w=[],y=[],x=new Map;for(var k of t)if((0,u.N)(k)){var b=(0,n.A)({id:k.id,width:k.view.width+p[1]+p[3],height:k.view.height+p[0]+p[2]},f?{fx:k.view.x,fy:k.view.y}:null);w.push(b),x.set(b.id,b)}else(0,u.WW)(k)&&y.push({source:k.source,target:k.target});var C=(0,o.A)(y).id((e=>e.id)),E=(0,i.A)(w).force("link",C).force("x",(0,l.A)(null==v?void 0:v[0])).force("y",(0,d.A)(null==v?void 0:v[1])).force("charge",(0,c.A)());return g&&E.force("collide",(0,s.A)().radius((e=>Math.sqrt(e.width**2+e.height**2)/2+g.radiusDiff)).strength(g.strength).iterations(g.iterations)),E.stop(),function(e){e.tick(Math.ceil(Math.log(e.alphaMin())/Math.log(1-e.alphaDecay())))}(E),{getNodeView:e=>x.get(e),nodePaddings:p}}},1819:(e,t,r)=>{r.d(t,{J:()=>o});var n=r(8769),a=r(8185);function o(e){var{cellsRef:t,activeTarget:r,onActiveTargetChange:o}=e,i=null!=r?r:null,[l,d]=(0,n.useState)(i);(0,n.useEffect)((()=>{d((e=>(0,a.c)(e,i)?e:i))}),[i]);var c=(0,n.useRef)(!1);return(0,n.useEffect)((()=>{c.current?o(l):c.current=!0}),[l,o]),(0,n.useEffect)((()=>{if(l){var e=e=>{e.composedPath().indexOf(t.current)<=0&&d(null)};return document.addEventListener("click",e),()=>{document.removeEventListener("click",e)}}}),[l,t]),l}},2361:(e,t,r)=>{r.d(t,{g:()=>h});var n=r(9740),a=r(8769),o=r(7566),i=r(1517),l=r(3033),d=r(531),c=r(908),s=r(6170),u=r(9127);function h(e){var{layout:t,layoutOptions:r,rootRef:h,cells:v,zoomable:f,zoomer:m,scaleRange:g,layoutKey:p,dispatch:w}=e,[y,x]=(0,a.useState)("force"!==t&&"dagre"!==t),k=(0,a.useRef)(p),b=(0,a.useCallback)((()=>++k.current),[]),[C,E]=function(e){var{rootRef:t,cells:r,layoutInitialized:n,zoomable:s,zoomer:u,scaleRange:h}=e,[v,f]=(0,a.useState)(!1);return(0,a.useEffect)((()=>{var e=t.current;if(e&&n&&!v&&r.some((e=>(0,d.N)(e)||(0,d.mH)(e)))&&!r.some((e=>(0,d.N)(e)&&!e[l.CV]))){var{k:a,x:m,y:g}=(0,c.r)(r,{canvasWidth:e.clientWidth,canvasHeight:e.clientHeight,scaleRange:s?h:void 0});u.transform((0,o.A)(e),new i.uV(a,m,g)),f(!0)}}),[r,v,n,t,h,s,u]),(0,a.useEffect)((()=>{r.some((e=>(0,d.N)(e)||(0,d.mH)(e)))||f(!1)}),[r]),[v,f]}({rootRef:h,layoutInitialized:y,cells:v,zoomable:f,zoomer:m,scaleRange:g}),A=(0,a.useRef)(null);return(0,a.useEffect)((()=>{if(!v.some((e=>(0,d.N)(e)&&!e[l.CV])))if("force"===t||"dagre"===t){if(k.current===p&&(e=A.current,a=v.filter(d.nv),(null==e?void 0:e.length)!==a.length||!e.every(((e,t)=>e===a[t])))){var e,a,o,i;({getNodeView:o,nodePaddings:i}="force"===t?(0,s.k)({cells:v,layoutOptions:r}):(0,u.C)({cells:v,layoutOptions:r}));var c=v.map((e=>{if((0,d.N)(e)){var t=o(e.id);return(0,n.A)((0,n.A)({},e),{},{view:(0,n.A)((0,n.A)({},e.view),{},{x:t.x-t.width/2+i[3],y:t.y-t.height/2+i[0]}),[l.xc]:!0})}return e}));A.current=c.filter(d.nv),w({type:"update-cells",payload:c}),E(!1),x(!0)}}else x(!0)}),[v,w,t,p,r,E]),{centered:C,setCentered:E,getNextLayoutKey:b}}},7531:(e,t,r)=>{r.d(t,{d:()=>c});var n=r(9740),a=r(8769),o=r(5530),i=r(1030),l=r(531),d=r(3033);function c(e){var{cells:t,defaultEdgeLines:r,markerPrefix:c}=e;return(0,a.useMemo)((()=>{var e=[{strokeColor:d.mF}],a=new WeakMap,s=function(t){if((0,l.WW)(t)){var s,u=null!==(s=o.__secret_internals.legacyDoTransform({edge:t},null==r?void 0:r.find((e=>(0,o.checkIfByTransform)(e,{edge:t})))))&&void 0!==s?s:{},h=(0,n.A)({dashed:!1,strokeColor:d.mF,strokeWidth:d.VO,interactStrokeWidth:d.Ie,showStartArrow:d.XV,showEndArrow:d.Ub,animate:{useAnimate:!1,duration:d.Be}},(0,i.omitBy)(u,i.isUndefined));void 0===h.parallelGap&&(h.parallelGap=h.interactStrokeWidth);var v=function(e,t){var r=(0,i.findIndex)(t,e);return-1===r&&(r=t.push(e)-1),r}({strokeColor:h.strokeColor},e);h.markerArrow="url(#".concat(c).concat(v,")"),a.set(t,h)}};for(var u of t)s(u);return[a,e]}),[t,r,c])}},8197:(e,t,r)=>{r.d(t,{H:()=>i});var n=r(8769),a=r(531),o=r(3033);function i(e){var{cells:t,layout:r,centered:i}=e;return(0,n.useMemo)((()=>i&&t.every((e=>!(0,a.N)(e)||e[o.CV]&&("force"!==r&&"dagre"!==r||e[o.xc])))),[t,i,r])}},8091:(e,t,r)=>{r.d(t,{f:()=>l});var n=r(8769),a=r(7566),o=r(1517),i=r(3033);function l(e){var{rootRef:t,zoomable:r,scrollable:l,pannable:d,scaleRange:c,onSwitchActiveTarget:s}=e,[u,h]=(0,n.useState)(!1),[v,f]=(0,n.useState)({k:1,x:0,y:0}),m=(0,n.useMemo)((()=>null!=c?c:[i.sS,i.Yt]),[c]),g=(0,n.useMemo)((()=>(0,o.s_)()),[]);return(0,n.useEffect)((()=>{var e=!1;g.scaleExtent(r?m:[1,1]).on("start",(()=>{e=!1,h(!0)})).on("zoom",(t=>{e=!0,f(t.transform)})).on("end",(()=>{h(!1),e||null==s||s(null)}))}),[s,m,r,g]),(0,n.useEffect)((()=>{var e=t.current;if(e){var n=(0,a.A)(e),o=()=>{n.on(".zoom",null).on(".zoom.custom",null).on("wheel",null)};if(r||l||d)return(r||l)&&n.on("wheel.zoom.custom",(e=>{e.ctrlKey||(e.stopImmediatePropagation(),l&&(e.preventDefault(),g.translateBy(n,e.wheelDeltaX/5,e.wheelDeltaY/5)))})),n.call(g).on("wheel",(e=>e.preventDefault())).on("dblclick.zoom",null).on("mousedown.zoom",null),d||n.on("touchstart.zoom",null).on("touchmove.zoom",null).on("touchend.zoom",null),o;o()}}),[d,t,l,r,g]),{grabbing:u,transform:v,zoomer:g,scaleRange:m}}},8618:(e,t,r)=>{r.d(t,{A:()=>l});var n=r(6758),a=r.n(n),o=r(935),i=r.n(o)()(a());i.push([e.id,'.zoom-bar{position:absolute;bottom:20px;right:20px;width:40px}.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-inline:5px}.zoom-slider .ant-slider-vertical .ant-slider-rail{width:2px}.zoom-slider .ant-slider-vertical .ant-slider-handle{width:6px;height:6px;inset-inline-start: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;inset-inline-start:-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;inset-block-start:0;inset-inline-start:0}',""]);const l=i.toString()},3012:(e,t,r)=>{r.d(t,{A:()=>l});var n=r(6758),a=r.n(n),o=r(935),i=r.n(o)()(a());i.push([e.id,"*{box-sizing:border-box}:host{display:block;position:relative;overflow:hidden;--animation-dasharray:48;--stroke-dashoffset:96;--dasharray:4}:host,\n.root{width:100%;height:100%}:host([hidden]){display:none}.root{opacity:0}.root.ready{opacity:1}.root:focus{outline:none}@keyframes dashedAnimation{0%{stroke-dashoffset:var(--stroke-dashoffset)}to{stroke-dashoffset:0}}@keyframes solidAnimation{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}.decorator-area .area{fill:rgba(119,141,195,0.1);stroke:none;stroke-width:0}.node,\n.decorator-text{overflow:visible}.cell.active .decorator-area .area,\n.cell.active .line-active-bg{stroke:var(--palette-blue-5);stroke-dasharray:var(--dasharray);stroke-width:1}.cell:not(.read-only){-webkit-user-select:none;-moz-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{opacity:1}.connect-line{pointer-events:none}.connect-line:not(.connecting){display:none}.line.dashed{stroke-dasharray:var(--dasharray)}.cell.active .decorator-text .text-container{outline:1px dashed var(--palette-blue-5)}.decorator-text .text-container{width:-webkit-max-content;width:-moz-max-content;width:max-content;padding:0.5em}.decorator-text .text:focus{outline:none}.cell.faded{opacity:0.3}.cell .node{pointer-events:none}.cell .node > *{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)}",""]);const l=i.toString()}}]);
2
+ //# sourceMappingURL=6974.e97f2976.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"chunks/6974.e97f2976.js","mappings":"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","sources":["webpack:///./src/diagram/MarkerComponent.tsx","webpack:///./src/diagram/lines/getDirectLinePoints.ts","webpack:///./src/diagram/processors/doTwoNodesOverlap.ts","webpack:///./src/diagram/processors/extractPartialRectTuple.ts","webpack:///./src/draw-canvas/processors/findNode.ts","webpack:///./src/draw-canvas/EdgeComponent.tsx","webpack:///./src/draw-canvas/NodeComponent.tsx","webpack:///./src/draw-canvas/processors/cellToTarget.ts","webpack:///./src/draw-canvas/processors/handleMouseDown.ts","webpack:///./src/draw-canvas/decorators/DecoratorArea.tsx","webpack:///./src/draw-canvas/decorators/DecoratorText.tsx","webpack:///./src/draw-canvas/decorators/index.tsx","webpack:///./src/draw-canvas/CellComponent.tsx","webpack:///./src/draw-canvas/constants.ts","webpack:///./src/draw-canvas/processors/asserts.ts","webpack:///./src/draw-canvas/processors/getUnrelatedCells.ts","webpack:///./src/draw-canvas/processors/initializeCells.ts","webpack:///./src/draw-canvas/processors/sameTarget.ts","webpack:///./src/draw-canvas/processors/transformToCenter.ts","webpack:///./src/draw-canvas/reducers/cells.ts","webpack:///./src/draw-canvas/reducers/index.ts","webpack:///./src/draw-canvas/reducers/layoutKey.ts","webpack:///./src/shared/canvas/icons/center.svg","webpack:///./src/shared/canvas/icons/zoom-in.svg","webpack:///./src/shared/canvas/icons/zoom-out.svg","webpack:///./src/shared/canvas/ZoomBarComponent.tsx","webpack:///./src/shared/canvas/dagreLayout.ts","webpack:///./src/shared/canvas/forceLayout.ts","webpack:///./src/shared/canvas/useActiveTarget.ts","webpack:///./src/shared/canvas/useLayout.ts","webpack:///./src/shared/canvas/useAutoCenter.ts","webpack:///./src/shared/canvas/useLineMarkers.ts","webpack:///./src/shared/canvas/useReady.ts","webpack:///./src/shared/canvas/useZoom.ts","webpack:///./src/shared/canvas/ZoomBarComponent.shadow.css","webpack:///./src/shared/canvas/styles.shadow.css"],"sourcesContent":["import React from \"react\";\nimport type { LineMarkerType } from \"./interfaces\";\n\nexport interface MarkerComponentProps extends BaseMarkerComponentProps {\n type: LineMarkerType;\n}\n\nexport interface BaseMarkerComponentProps {\n id: string;\n strokeColor?: string;\n}\n\nexport function MarkerComponent({\n id,\n type,\n strokeColor,\n}: MarkerComponentProps): JSX.Element {\n let Component: (props: BaseMarkerComponentProps) => JSX.Element;\n\n switch (type) {\n case \"0..1\":\n Component = EntityRelationZeroOrOneMarker;\n break;\n case \"0..N\":\n Component = EntityRelationZeroOrManyMarker;\n break;\n default:\n Component = ArrowMarker;\n }\n\n return <Component id={id} strokeColor={strokeColor} />;\n}\n\nfunction ArrowMarker({\n id,\n strokeColor,\n}: BaseMarkerComponentProps): JSX.Element {\n return (\n <marker\n id={id}\n viewBox=\"0 0 6 6\"\n refX={5}\n refY={3}\n markerWidth={6}\n markerHeight={6}\n orient=\"auto-start-reverse\"\n strokeLinejoin=\"round\"\n >\n <path\n d=\"M 0.5 0.5 L 5.5 3 L 0.5 5.5 z\"\n stroke={strokeColor}\n strokeWidth={1}\n fill={strokeColor}\n />\n </marker>\n );\n}\n\nfunction EntityRelationZeroOrOneMarker({\n id,\n strokeColor,\n}: BaseMarkerComponentProps): JSX.Element {\n return (\n <marker\n id={id}\n viewBox=\"0 0 21 11\"\n refX={0.5}\n refY={5.5}\n markerWidth={21}\n markerHeight={11}\n orient=\"auto-start-reverse\"\n >\n <path\n d=\"M 5.5 5.5 m 5 0 a 5 5 0 1 0 -10 0 a 5 5 0 1 0 10 0 M 15.5 0.5 V 10.5 M 10.5 5.5 H 20.5\"\n stroke={strokeColor}\n strokeWidth={1}\n fill=\"none\"\n />\n </marker>\n );\n}\n\nfunction EntityRelationZeroOrManyMarker({\n id,\n strokeColor,\n}: BaseMarkerComponentProps): JSX.Element {\n return (\n <marker\n id={id}\n viewBox=\"0 0 21 11\"\n refX={0.5}\n refY={5.5}\n markerWidth={21}\n markerHeight={11}\n orient=\"auto-start-reverse\"\n >\n <path\n d=\"M 5.5 5.5 m 5 0 a 5 5 0 1 0 -10 0 a 5 5 0 1 0 10 0 M 20.5 0.5 L 10.5 5.5 L 20.5 10.5 M 10.5 5.5 H 20.5\"\n stroke={strokeColor}\n strokeWidth={1}\n fill=\"none\"\n />\n </marker>\n );\n}\n","import type { NodePosition, NodeRect, PositionTuple } from \"../interfaces\";\nimport { doTwoNodesOverlap } from \"../processors/doTwoNodesOverlap\";\n\ntype LineTuple = [start: PositionTuple, end: PositionTuple];\n\nexport function getDirectLinePoints(\n source: NodeRect,\n target: NodeRect,\n parallelGap?: number\n): NodePosition[] | null {\n // Ignore if two nodes are the same.\n // Ignore if two nodes overlap.\n if (source === target || doTwoNodesOverlap(source, target, 0, 0)) {\n return null;\n }\n\n let p0: PositionTuple;\n let p1: PositionTuple;\n\n let xDiff = 0;\n let yDiff = 0;\n\n if (parallelGap) {\n const dx = target.x - source.x;\n const dy = target.y - source.y;\n const angle = Math.atan2(dy, dx);\n xDiff = (parallelGap / 2) * Math.cos(angle + Math.PI / 2);\n yDiff = (parallelGap / 2) * Math.sin(angle + Math.PI / 2);\n }\n\n const line: LineTuple = [\n [source.x + xDiff, source.y + yDiff],\n [target.x + xDiff, target.y + yDiff],\n ];\n const sourceIntersections = getIntersections(source, line);\n const targetIntersections = getIntersections(target, line);\n\n // Todo: handle when more than one intersection\n if (sourceIntersections.length > 0) {\n p0 = sourceIntersections[0];\n } else {\n p0 = [source.x, source.y];\n }\n if (targetIntersections.length > 0) {\n p1 = targetIntersections[0];\n } else {\n p1 = [target.x, target.y];\n }\n\n return [\n { x: p0[0], y: p0[1] },\n { x: p1[0], y: p1[1] },\n ];\n}\n\nfunction getIntersections(rect: NodeRect, line: LineTuple) {\n const vertices: PositionTuple[] = [\n [rect.x - rect.width / 2, rect.y - rect.height / 2],\n [rect.x + rect.width / 2, rect.y - rect.height / 2],\n [rect.x + rect.width / 2, rect.y + rect.height / 2],\n [rect.x - rect.width / 2, rect.y + rect.height / 2],\n ];\n const possibleLines: [start: PositionTuple, end: PositionTuple][] = [];\n for (let i = 0; i < 4; i++) {\n possibleLines.push([vertices[i], vertices[(i + 1) % 4]]);\n }\n const intersections: PositionTuple[] = [];\n for (const item of possibleLines) {\n const intersection = intersect(line[0], line[1], item[0], item[1]);\n if (intersection) {\n intersections.push(intersection);\n }\n }\n return intersections;\n}\n\n// https://paulbourke.net/geometry/pointlineplane/javascript.txt\nfunction intersect(\n [x1, y1]: PositionTuple,\n [x2, y2]: PositionTuple,\n [x3, y3]: PositionTuple,\n [x4, y4]: PositionTuple\n): null | PositionTuple {\n // Check if none of the lines are of length 0\n if ((x1 === x2 && y1 === y2) || (x3 === x4 && y3 === y4)) {\n return null;\n }\n\n const denominator = (y4 - y3) * (x2 - x1) - (x4 - x3) * (y2 - y1);\n\n // Lines are parallel\n if (denominator === 0) {\n return null;\n }\n\n const ua = ((x4 - x3) * (y1 - y3) - (y4 - y3) * (x1 - x3)) / denominator;\n const ub = ((x2 - x1) * (y1 - y3) - (y2 - y1) * (x1 - x3)) / denominator;\n\n // is the intersection along the segments\n if (ua < 0 || ua > 1 || ub < 0 || ub > 1) {\n return null;\n }\n\n // Return a object with the x and y coordinates of the intersection\n const x = x1 + ua * (x2 - x1);\n const y = y1 + ua * (y2 - y1);\n\n return [x, y];\n}\n","import type { NodeRect } from \"../interfaces\";\n\nexport function doTwoNodesOverlap(\n a: NodeRect,\n b: NodeRect,\n paddingA: number,\n paddingB: number\n): boolean {\n const A = paddingA ? getNodesWithPadding(a, paddingA) : a;\n const B = paddingB ? getNodesWithPadding(b, paddingB) : b;\n const left = Math.min(A.x - A.width / 2, B.x - B.width / 2);\n const right = Math.max(A.x + A.width / 2, B.x + B.width / 2);\n const top = Math.min(A.y - A.height / 2, B.y - B.height / 2);\n const bottom = Math.max(A.y + A.height / 2, B.y + B.height / 2);\n return right - left < A.width + B.width && bottom - top < A.height + B.height;\n}\n\nfunction getNodesWithPadding(node: NodeRect, padding: number) {\n return {\n x: node.x - node.width / 2 - padding,\n y: node.y - node.height / 2 - padding,\n width: node.width + padding * 2,\n height: node.height + padding * 2,\n };\n}\n","import type { FullRectTuple, PartialRectTuple } from \"../interfaces\";\n\nexport function extractPartialRectTuple(\n value: PartialRectTuple\n): FullRectTuple {\n if (Array.isArray(value)) {\n const v0 = value[0];\n const v1 = value.length > 1 ? value[1]! : v0;\n const v2 = value.length > 2 ? value[2]! : v0;\n const v3 = value.length > 3 ? value[3]! : v1;\n return [v0, v1, v2, v3];\n }\n return new Array(4).fill(value) as FullRectTuple;\n}\n","import type { Cell, NodeCell, NodeId } from \"../interfaces\";\nimport { isNodeCell } from \"./asserts\";\n\nexport function findNode(cells: Cell[], id: NodeId): NodeCell | undefined {\n return cells.find((cell) => isNodeCell(cell) && cell.id === id) as\n | NodeCell\n | undefined;\n}\n","import React, { useMemo, useRef } from \"react\";\nimport classNames from \"classnames\";\nimport type {\n Cell,\n ComputedEdgeLineConf,\n EdgeCell,\n NodeView,\n} from \"./interfaces\";\nimport { getDirectLinePoints } from \"../diagram/lines/getDirectLinePoints\";\nimport type { NodeRect } from \"../diagram/interfaces\";\nimport { findNode } from \"./processors/findNode\";\nimport { isEdgeCell } from \"./processors/asserts\";\nimport { DEFAULT_LINE_INTERACT_ANIMATE_DURATION } from \"./constants\";\n\nexport interface EdgeComponentProps {\n edge: EdgeCell;\n cells: Cell[];\n lineConfMap: WeakMap<EdgeCell, ComputedEdgeLineConf>;\n}\n\nexport function EdgeComponent({\n edge,\n cells,\n lineConfMap,\n}: EdgeComponentProps): JSX.Element | null {\n const pathRef = useRef<SVGPathElement>(null);\n const sourceNode = useMemo(\n () => findNode(cells, edge.source),\n [cells, edge.source]\n );\n const targetNode = useMemo(\n () => findNode(cells, edge.target),\n [cells, edge.target]\n );\n const lineConf = useMemo(() => lineConfMap.get(edge)!, [edge, lineConfMap]);\n\n const parallelGap = useMemo(() => {\n const hasOppositeEdge = cells.some(\n (cell) =>\n isEdgeCell(cell) &&\n cell.source === edge.target &&\n cell.target === edge.source\n );\n return hasOppositeEdge ? lineConf.parallelGap : 0;\n }, [cells, edge, lineConf.parallelGap]);\n\n const padding = 5;\n\n const line = useMemo(\n () =>\n sourceNode &&\n targetNode &&\n sourceNode.view.x != null &&\n targetNode.view.x != null\n ? getDirectLinePoints(\n nodeViewToNodeRect(sourceNode.view, padding),\n nodeViewToNodeRect(targetNode.view, padding),\n parallelGap\n )\n : null,\n [parallelGap, sourceNode, targetNode]\n );\n\n if (!line) {\n // This happens when source or target is not found,\n // or when source or target has not been positioned yet.\n return null;\n }\n const d = `M${line[0].x} ${line[0].y}L${line[1].x} ${line[1].y}`;\n return (\n <>\n <path\n // This `path` is made for expanding interaction area of graph lines.\n d={d}\n fill=\"none\"\n stroke=\"transparent\"\n strokeWidth={lineConf.interactStrokeWidth}\n />\n <path\n ref={pathRef}\n className={classNames(\"line\", {\n dashed: lineConf.dashed,\n [`${lineConf.dashed ? \"dashed\" : \"solid\"}-animation`]:\n lineConf.animate.useAnimate,\n })}\n style={\n {\n \"--time\": `${lineConf.animate.duration ?? DEFAULT_LINE_INTERACT_ANIMATE_DURATION}s`,\n \"--solid-length\": pathRef.current?.getTotalLength?.(),\n } as React.CSSProperties\n }\n d={d}\n fill=\"none\"\n stroke={lineConf.strokeColor}\n strokeWidth={lineConf.strokeWidth}\n markerStart={lineConf.showStartArrow ? lineConf.markerArrow : \"\"}\n markerEnd={lineConf.showEndArrow ? lineConf.markerArrow : \"\"}\n />\n <path className=\"line-active-bg\" d={d} fill=\"none\" />\n </>\n );\n}\n\nfunction nodeViewToNodeRect(view: NodeView, padding: number): NodeRect {\n return {\n x: view.x + view.width / 2,\n y: view.y + view.height / 2,\n width: view.width + padding,\n height: view.height + padding,\n };\n}\n","import React, {\n useCallback,\n useEffect,\n useMemo,\n useRef,\n useState,\n} from \"react\";\nimport { ReactUseBrick } from \"@next-core/react-runtime\";\nimport { __secret_internals, checkIfByTransform } from \"@next-core/runtime\";\nimport { isEqual } from \"lodash\";\nimport ResizeObserver from \"resize-observer-polyfill\";\nimport type { NodeBrickCell, NodeBrickConf, NodeCell } from \"./interfaces\";\nimport type { SizeTuple } from \"../diagram/interfaces\";\n\nexport interface NodeComponentProps {\n node: NodeCell;\n degraded: boolean;\n degradedNodeLabel?: string;\n defaultNodeBricks?: NodeBrickConf[];\n onResize(id: string, size: SizeTuple | null): void;\n}\n\nexport function NodeComponent({\n node,\n degraded,\n degradedNodeLabel,\n defaultNodeBricks,\n onResize,\n}: NodeComponentProps): JSX.Element | null {\n const memoizedData = useDeepMemo({ node: { id: node.id, data: node.data } });\n const specifiedUseBrick = (node as NodeBrickCell).useBrick;\n const observerRef = useRef<ResizeObserver | null>(null);\n\n const useBrick = useMemo(() => {\n return degraded\n ? null\n : specifiedUseBrick ??\n defaultNodeBricks?.find((item) =>\n checkIfByTransform(item, memoizedData)\n )?.useBrick;\n }, [degraded, specifiedUseBrick, defaultNodeBricks, memoizedData]);\n\n const label = useMemo<string>(\n () =>\n degraded\n ? String(\n __secret_internals.legacyDoTransform(\n memoizedData,\n degradedNodeLabel ?? \"<% DATA.node.id %>\"\n )\n )\n : \"\",\n [degraded, degradedNodeLabel, memoizedData]\n );\n\n const refCallback = useCallback(\n (element: HTMLElement | null) => {\n const prevObserver = observerRef.current;\n if (prevObserver) {\n prevObserver.disconnect();\n observerRef.current = null;\n }\n if (element) {\n // Todo: correctly wait for `useBrick` in v3 to be rendered (after layout)\n // Wait a macro task to let `useBrick` to be rendered.\n setTimeout(() => {\n const observer = new ResizeObserver(() => {\n onResize(node.id, [element.offsetWidth, element.offsetHeight]);\n });\n observer.observe(element);\n observerRef.current = observer;\n });\n } else {\n onResize(node.id, null);\n }\n },\n [node.id, onResize]\n );\n\n const degradedRefCallBack = useCallback(\n (g: SVGGElement | null) => {\n if (g) {\n // istanbul ignore next\n const size =\n process.env.NODE_ENV === \"test\"\n ? { width: 60, height: 60 }\n : g.getBBox();\n onResize(node.id, [size.width, size.height]);\n } else {\n onResize(node.id, null);\n }\n },\n [node.id, onResize]\n );\n\n return useBrick ? (\n <foreignObject\n // Make a large size to avoid the brick inside to be clipped by the foreignObject.\n width={9999}\n height={9999}\n className=\"node\"\n >\n {useBrick && (\n <ReactUseBrick\n useBrick={useBrick}\n data={memoizedData}\n refCallback={refCallback}\n />\n )}\n </foreignObject>\n ) : degraded ? (\n <g className=\"degraded\" ref={degradedRefCallBack}>\n <circle cx={8} cy={8} r={8} />\n <text x={8} y={32}>\n {label}\n </text>\n </g>\n ) : null;\n}\n\nfunction useDeepMemo<T>(value: T): T {\n const [memoizedValue, setMemoizedValue] = useState(value);\n\n useEffect(() => {\n setMemoizedValue((prev) => (isEqual(prev, value) ? prev : value));\n }, [value]);\n\n return memoizedValue;\n}\n","import { pick } from \"lodash\";\nimport type { ActiveTarget, Cell } from \"../interfaces\";\n\nexport function cellToTarget(cell: Cell): ActiveTarget {\n return cell.type === \"edge\"\n ? pick(cell, [\"type\", \"source\", \"target\", \"data\"])\n : pick(cell, [\"type\", \"id\", \"data\"]);\n}\n","import type { PositionTuple } from \"../../diagram/interfaces\";\nimport type { ActiveTarget, Cell, LayoutType } from \"../interfaces\";\nimport type {\n MoveCellPayload,\n ResizeCellPayload,\n} from \"../reducers/interfaces\";\nimport { isEdgeCell, isNodeCell } from \"./asserts\";\nimport { cellToTarget } from \"./cellToTarget\";\n\nexport function handleMouseDown(\n event: MouseEvent,\n {\n action,\n cell,\n scale,\n layout,\n onCellMoving,\n onCellMoved,\n onCellResizing,\n onCellResized,\n onSwitchActiveTarget,\n }: {\n action: \"move\" | \"resize\";\n cell: Cell;\n scale: number;\n layout?: LayoutType;\n onCellMoving?(info: MoveCellPayload): void;\n onCellMoved?(info: MoveCellPayload): void;\n onCellResizing?(info: ResizeCellPayload): void;\n onCellResized?(info: ResizeCellPayload): void;\n onSwitchActiveTarget?(activeTarget: ActiveTarget | null): void;\n }\n) {\n event.stopPropagation();\n // Drag node\n onSwitchActiveTarget?.(cellToTarget(cell));\n\n if (\n isEdgeCell(cell) ||\n ((layout === \"force\" || layout === \"dagre\") && isNodeCell(cell))\n ) {\n return;\n }\n\n const from: PositionTuple = [event.clientX, event.clientY];\n const original =\n action === \"move\"\n ? [cell.view.x, cell.view.y]\n : [cell.view.width, cell.view.height];\n\n function getMovement(e: MouseEvent): PositionTuple {\n return [(e.clientX - from[0]) / scale, (e.clientY - from[1]) / scale];\n }\n\n let moved = false;\n\n const handleMove = (e: MouseEvent, finished?: boolean) => {\n // Respect the scale\n const movement = getMovement(e);\n if (!moved) {\n moved = movement[0] ** 2 + movement[1] ** 2 >= 9;\n }\n // const [x, y] = getNewPosition(movement);\n // adjustCellPosition(x, y);\n if (moved) {\n if (action === \"move\") {\n (finished ? onCellMoved : onCellMoving)?.({\n type: cell.type,\n id: cell.id,\n x: original[0] + movement[0],\n y: original[1] + movement[1],\n });\n } else {\n (finished ? onCellResized : onCellResizing)?.({\n type: cell.type,\n id: cell.id,\n width: original[0] + movement[0],\n height: original[1] + movement[1],\n });\n }\n }\n };\n\n const onMouseMove = (e: MouseEvent) => {\n handleMove(e);\n };\n const onMouseUp = (e: MouseEvent) => {\n handleMove(e, true);\n moved = false;\n document.removeEventListener(\"mousemove\", onMouseMove);\n document.removeEventListener(\"mouseup\", onMouseUp);\n };\n document.addEventListener(\"mousemove\", onMouseMove);\n document.addEventListener(\"mouseup\", onMouseUp);\n}\n","import React, { useEffect } from \"react\";\nimport type { BasicDecoratorProps } from \"../interfaces\";\nimport { handleMouseDown } from \"../processors/handleMouseDown\";\n\nexport function DecoratorArea({\n cell,\n transform,\n readOnly,\n onCellResizing,\n onCellResized,\n onSwitchActiveTarget,\n}: BasicDecoratorProps): JSX.Element {\n const resizeHandleRef = React.useRef<SVGGElement>(null);\n\n useEffect(() => {\n const resizeHandle = resizeHandleRef.current;\n if (!resizeHandle || readOnly) {\n return;\n }\n const onMouseDown = (event: MouseEvent) => {\n handleMouseDown(event, {\n action: \"resize\",\n cell,\n scale: transform.k,\n onCellResizing,\n onCellResized,\n onSwitchActiveTarget,\n });\n };\n resizeHandle.addEventListener(\"mousedown\", onMouseDown);\n return () => {\n resizeHandle.removeEventListener(\"mousedown\", onMouseDown);\n };\n }, [\n cell,\n onCellResized,\n onCellResizing,\n onSwitchActiveTarget,\n readOnly,\n transform.k,\n ]);\n\n return (\n <g className=\"decorator-area\">\n <rect\n width={cell.view.width}\n height={cell.view.height}\n className=\"area\"\n />\n {!readOnly && (\n <g\n ref={resizeHandleRef}\n className=\"resize-handle\"\n transform={`translate(${cell.view.width - 20} ${cell.view.height - 20})`}\n >\n <rect width={20} height={20} />\n <path d=\"M10 18L18 10 M15 18L18 15\" />\n </g>\n )}\n </g>\n );\n}\n","import React, { useCallback, useEffect, useRef, useState } from \"react\";\nimport type { BasicDecoratorProps } from \"../interfaces\";\nimport classNames from \"classnames\";\n\nexport type DecoratorTextProps = Pick<\n BasicDecoratorProps,\n \"cell\" | \"readOnly\" | \"onDecoratorTextEditing\" | \"onDecoratorTextChange\"\n>;\n\nexport function DecoratorText({\n cell,\n readOnly,\n onDecoratorTextEditing,\n onDecoratorTextChange,\n}: DecoratorTextProps): JSX.Element {\n const label = cell.view.text ?? \"\";\n const [currentLabel, setCurrentLabel] = useState<string>(label);\n const [editingLabel, setEditingLabel] = useState(false);\n const editingLabelInitialized = useRef(false);\n const [shouldEmitLabelChange, setShouldEmitLabelChange] = useState(false);\n const ref = useRef<HTMLDivElement>(null);\n\n const handleEnableEdit = useCallback(\n (e: React.MouseEvent) => {\n if (readOnly) {\n return;\n }\n e.preventDefault();\n e.stopPropagation();\n setEditingLabel(true);\n },\n [readOnly]\n );\n\n useEffect(() => {\n const element = ref.current;\n if (element && element.textContent !== currentLabel) {\n element.textContent = currentLabel;\n }\n }, [currentLabel]);\n\n useEffect(() => {\n if (editingLabel && ref.current) {\n ref.current.focus();\n selectAllText(ref.current);\n }\n onDecoratorTextEditing?.({ id: cell.id, editing: editingLabel });\n }, [cell.id, editingLabel, onDecoratorTextEditing]);\n\n useEffect(() => {\n if (editingLabelInitialized.current) {\n onDecoratorTextEditing?.({ id: cell.id, editing: editingLabel });\n } else {\n editingLabelInitialized.current = true;\n }\n }, [cell.id, editingLabel, onDecoratorTextEditing]);\n\n const handleInput = useCallback(\n (event: React.FormEvent<HTMLDivElement>) => {\n if (readOnly) {\n return;\n }\n setCurrentLabel((event.target as HTMLDivElement).textContent!);\n },\n [readOnly]\n );\n\n const handleBlur = useCallback(() => {\n if (readOnly) {\n return;\n }\n setEditingLabel(false);\n setShouldEmitLabelChange(true);\n }, [readOnly]);\n\n useEffect(() => {\n if (shouldEmitLabelChange) {\n onDecoratorTextChange?.({\n id: cell.id,\n view: { ...cell.view, text: currentLabel },\n });\n setShouldEmitLabelChange(false);\n }\n }, [cell, currentLabel, onDecoratorTextChange, shouldEmitLabelChange]);\n\n return (\n <foreignObject className=\"decorator-text\">\n <div\n className={classNames(\"text-container\", { editing: editingLabel })}\n onDoubleClick={handleEnableEdit}\n >\n <div\n className=\"text\"\n contentEditable={editingLabel}\n ref={ref}\n onInput={handleInput}\n onBlur={handleBlur}\n />\n </div>\n </foreignObject>\n );\n}\n\nfunction selectAllText(element: HTMLElement) {\n const range = document.createRange();\n range.selectNodeContents(element);\n const selection = window.getSelection()!;\n selection.removeAllRanges();\n selection.addRange(range);\n}\n","import React from \"react\";\nimport type { BasicDecoratorProps } from \"../interfaces\";\nimport { DecoratorArea } from \"./DecoratorArea\";\nimport { DecoratorText } from \"./DecoratorText\";\n\nexport function DecoratorComponent({\n cell,\n transform,\n readOnly,\n onCellResizing,\n onCellResized,\n onSwitchActiveTarget,\n onDecoratorTextEditing,\n onDecoratorTextChange,\n}: BasicDecoratorProps): JSX.Element | null {\n let SpecifiedComponent: (props: BasicDecoratorProps) => JSX.Element | null;\n\n switch (cell.decorator) {\n case \"area\":\n SpecifiedComponent = DecoratorArea;\n break;\n case \"text\":\n SpecifiedComponent = DecoratorText;\n break;\n // istanbul ignore next\n default:\n // eslint-disable-next-line no-console\n console.error(`Unknown decorator: ${cell.decorator}`);\n return null;\n }\n\n return (\n <SpecifiedComponent\n cell={cell}\n transform={transform}\n readOnly={readOnly}\n onCellResizing={onCellResizing}\n onCellResized={onCellResized}\n onSwitchActiveTarget={onSwitchActiveTarget}\n onDecoratorTextEditing={onDecoratorTextEditing}\n onDecoratorTextChange={onDecoratorTextChange}\n />\n );\n}\n","import React, { useCallback, useEffect, useMemo, useRef } from \"react\";\nimport classNames from \"classnames\";\nimport type {\n ActiveTarget,\n Cell,\n CellContextMenuDetail,\n ComputedEdgeLineConf,\n DecoratorTextChangeDetail,\n EdgeCell,\n LayoutType,\n NodeBrickConf,\n} from \"./interfaces\";\nimport { isDecoratorCell, isEdgeCell, isNodeCell } from \"./processors/asserts\";\nimport { EdgeComponent } from \"./EdgeComponent\";\nimport { NodeComponent } from \"./NodeComponent\";\nimport { handleMouseDown } from \"./processors/handleMouseDown\";\nimport type { MoveCellPayload, ResizeCellPayload } from \"./reducers/interfaces\";\nimport { DecoratorComponent } from \"./decorators\";\nimport { cellToTarget } from \"./processors/cellToTarget\";\nimport type { SizeTuple, TransformLiteral } from \"../diagram/interfaces\";\nimport { sameTarget } from \"./processors/sameTarget\";\n\nexport interface CellComponentProps {\n layout: LayoutType;\n cell: Cell;\n cells: Cell[];\n degraded: boolean;\n degradedNodeLabel?: string;\n defaultNodeBricks?: NodeBrickConf[];\n transform: TransformLiteral;\n lineConfMap: WeakMap<EdgeCell, ComputedEdgeLineConf>;\n active: boolean;\n readOnly?: boolean;\n unrelatedCells: Cell[];\n onCellMoving?(info: MoveCellPayload): void;\n onCellMoved?(info: MoveCellPayload): void;\n onCellResizing?(info: ResizeCellPayload): void;\n onCellResized?(info: ResizeCellPayload): void;\n onSwitchActiveTarget(target: ActiveTarget | null): void;\n onCellContextMenu(detail: CellContextMenuDetail): void;\n onCellClick?(detail: CellContextMenuDetail): void;\n onDecoratorTextEditing?(detail: { id: string; editing: boolean }): void;\n onDecoratorTextChange?(detail: DecoratorTextChangeDetail): void;\n onNodeBrickResize(id: string, size: SizeTuple | null): void;\n onCellMouseEnter?(cell: Cell): void;\n onCellMouseLeave?(cell: Cell): void;\n}\n\nexport function CellComponent({\n layout,\n cell,\n cells,\n degraded,\n degradedNodeLabel,\n defaultNodeBricks,\n lineConfMap,\n active,\n readOnly,\n transform,\n unrelatedCells,\n onCellMoving,\n onCellMoved,\n onCellResizing,\n onCellResized,\n onSwitchActiveTarget,\n onCellContextMenu,\n onCellClick,\n onDecoratorTextEditing,\n onDecoratorTextChange,\n onNodeBrickResize,\n onCellMouseEnter,\n onCellMouseLeave,\n}: CellComponentProps): JSX.Element | null {\n const gRef = useRef<SVGGElement>(null);\n\n const unrelated = useMemo(\n () => unrelatedCells.some((item) => sameTarget(item, cell)),\n [cell, unrelatedCells]\n );\n\n useEffect(() => {\n const g = gRef.current;\n if (!g || readOnly) {\n return;\n }\n const onMouseDown = (event: MouseEvent) => {\n handleMouseDown(event, {\n layout,\n action: \"move\",\n cell,\n scale: transform.k,\n onCellMoving,\n onCellMoved,\n onSwitchActiveTarget,\n });\n };\n g.addEventListener(\"mousedown\", onMouseDown);\n return () => {\n g.removeEventListener(\"mousedown\", onMouseDown);\n };\n }, [\n layout,\n cell,\n onCellMoved,\n onCellMoving,\n onSwitchActiveTarget,\n readOnly,\n transform.k,\n ]);\n\n const handleContextMenu = useCallback(\n (event: React.MouseEvent<SVGGElement>) => {\n if (readOnly && cell.type === \"decorator\") {\n return;\n }\n event.preventDefault();\n onSwitchActiveTarget(cellToTarget(cell));\n onCellContextMenu({\n cell,\n clientX: event.clientX,\n clientY: event.clientY,\n });\n },\n [cell, onCellContextMenu, onSwitchActiveTarget, readOnly]\n );\n\n const handleCellClick = useCallback(\n (event: React.MouseEvent<SVGGElement>) => {\n if (!onCellClick || cell.type === \"decorator\") {\n return;\n }\n onCellClick({\n cell,\n clientX: event.clientX,\n clientY: event.clientY,\n });\n },\n [cell, onCellClick]\n );\n\n const handleMouseEnter = useCallback(() => {\n onCellMouseEnter?.(cell);\n }, [cell, onCellMouseEnter]);\n\n const handleMouseLeave = useCallback(() => {\n onCellMouseLeave?.(cell);\n }, [cell, onCellMouseLeave]);\n\n return (\n <g\n className={classNames(\"cell\", {\n active,\n faded: unrelated,\n \"read-only\": readOnly,\n })}\n ref={gRef}\n transform={\n cell.type === \"edge\" || cell.view.x == null\n ? undefined\n : `translate(${cell.view.x} ${cell.view.y})`\n }\n onContextMenu={handleContextMenu}\n onClick={handleCellClick}\n onMouseEnter={handleMouseEnter}\n onMouseLeave={handleMouseLeave}\n >\n {isNodeCell(cell) ? (\n <NodeComponent\n node={cell}\n degraded={degraded}\n degradedNodeLabel={degradedNodeLabel}\n defaultNodeBricks={defaultNodeBricks}\n onResize={onNodeBrickResize}\n />\n ) : isEdgeCell(cell) ? (\n <EdgeComponent edge={cell} cells={cells} lineConfMap={lineConfMap} />\n ) : isDecoratorCell(cell) ? (\n <DecoratorComponent\n cell={cell}\n transform={transform}\n readOnly={readOnly}\n onCellResizing={onCellResizing}\n onCellResized={onCellResized}\n onSwitchActiveTarget={onSwitchActiveTarget}\n onDecoratorTextEditing={onDecoratorTextEditing}\n onDecoratorTextChange={onDecoratorTextChange}\n />\n ) : null}\n </g>\n );\n}\n","export const SYMBOL_FOR_SIZE_INITIALIZED = Symbol.for(\"size-initialized\");\nexport const SYMBOL_FOR_LAYOUT_INITIALIZED = Symbol.for(\"layout-initialized\");\nexport const DEFAULT_NODE_SIZE = 20;\nexport const DEFAULT_NODE_GAP = 36;\nexport const DEFAULT_AREA_WIDTH = 100;\nexport const DEFAULT_AREA_HEIGHT = 60;\nexport const DEFAULT_SCALE_RANGE_MIN = 0.5;\nexport const DEFAULT_SCALE_RANGE_MAX = 2;\nexport const DEFAULT_LINE_STROKE_COLOR = \"gray\";\nexport const DEFAULT_LINE_STROKE_WIDTH = 1;\nexport const DEFAULT_LINE_INTERACT_STROKE_WIDTH = 15;\nexport const DEFAULT_LINE_INTERACT_SHOW_START_ARROW = false;\nexport const DEFAULT_LINE_INTERACT_SHOW_END_ARROW = true;\nexport const DEFAULT_LINE_INTERACT_ANIMATE_DURATION = 1;\nexport const DEFAULT_DEGRADED_THRESHOLD = 500;\n","import type {\n Cell,\n DecoratorCell,\n EdgeCell,\n InitialCell,\n InitialNodeCell,\n NodeCell,\n} from \"../interfaces\";\n\nexport function isNodeCell(cell: Cell): cell is NodeCell {\n return cell.type === \"node\";\n}\n\nexport function isDecoratorCell(cell: Cell): cell is DecoratorCell {\n return cell.type === \"decorator\";\n}\n\nexport function isInitialNodeCell(cell: InitialCell): cell is InitialNodeCell {\n return cell.type === \"node\";\n}\n\nexport function isEdgeCell(cell: Cell): cell is EdgeCell {\n return cell.type === \"edge\";\n}\n\nexport function isNodeOrEdgeCell(cell: Cell): cell is NodeCell | EdgeCell {\n return cell.type === \"node\" || cell.type === \"edge\";\n}\n","import type { ActiveTarget, Cell, ConnectLineState } from \"../interfaces\";\nimport { sameTarget } from \"./sameTarget\";\n\nexport function getUnrelatedCells(\n cells: Cell[],\n connectLineState: ConnectLineState | null,\n activeTarget: ActiveTarget | null\n): Cell[] {\n const unrelated: Cell[] = [];\n\n if (connectLineState) {\n const existedTargets = new Set<string>();\n for (const cell of cells) {\n if (cell.type === \"edge\" && cell.source === connectLineState.source.id) {\n existedTargets.add(cell.target);\n }\n }\n for (const cell of cells) {\n switch (cell.type) {\n case \"node\":\n if (existedTargets.has(cell.id)) {\n unrelated.push(cell);\n }\n break;\n default:\n unrelated.push(cell);\n }\n }\n } else {\n switch (activeTarget?.type) {\n case \"node\": {\n const nodesMap = new Map<string, Cell>();\n const relatedNodeIds = new Set<string>([activeTarget.id]);\n for (const cell of cells) {\n if (cell.type === \"node\") {\n nodesMap.set(cell.id, cell);\n } else if (cell.type === \"edge\") {\n if (cell.source === activeTarget.id) {\n relatedNodeIds.add(cell.target);\n } else if (cell.target === activeTarget.id) {\n relatedNodeIds.add(cell.source);\n } else {\n unrelated.push(cell);\n }\n } else {\n unrelated.push(cell);\n }\n }\n for (const [id, cell] of nodesMap) {\n if (!relatedNodeIds.has(id)) {\n unrelated.push(cell);\n }\n }\n break;\n }\n\n case \"edge\":\n for (const cell of cells) {\n if (\n !(cell.type === \"edge\"\n ? sameTarget(cell, activeTarget)\n : cell.type === \"node\" &&\n (cell.id === activeTarget.source ||\n cell.id === activeTarget.target))\n ) {\n unrelated.push(cell);\n }\n }\n break;\n }\n }\n\n return unrelated;\n}\n","import type { SizeTuple } from \"../../diagram/interfaces\";\nimport type { Cell, InitialCell, NodeCell } from \"../interfaces\";\nimport { isInitialNodeCell } from \"./asserts\";\n\nexport function initializeCells(\n initialCells: InitialCell[] | undefined,\n {\n defaultNodeSize,\n }: {\n defaultNodeSize: SizeTuple;\n }\n): Cell[] {\n const originalCells = initialCells ?? [];\n const finalCells: Cell[] = originalCells.map<Cell>((cell) => {\n if (\n !isInitialNodeCell(cell) ||\n (cell.view?.width !== undefined && cell.view?.height !== undefined)\n ) {\n return cell as NodeCell;\n }\n return {\n ...cell,\n view: {\n width: defaultNodeSize[0],\n height: defaultNodeSize[1],\n ...cell.view,\n },\n } as NodeCell;\n });\n return finalCells;\n}\n","import type {\n ActiveTarget,\n ActiveTargetOfEdge,\n ActiveTargetOfNode,\n} from \"../interfaces\";\n\nexport function sameTarget(\n a: ActiveTarget | null | undefined,\n b: ActiveTarget | null | undefined\n): boolean {\n return a\n ? !!b &&\n a.type === b.type &&\n (a.type === \"node\" || a.type === \"decorator\"\n ? a.id === (b as ActiveTargetOfNode).id\n : a.source === (b as ActiveTargetOfEdge).source &&\n a.target === (b as ActiveTargetOfEdge).target)\n : !b;\n}\n","import type { TransformLiteral } from \"../../diagram/interfaces\";\nimport type { Cell } from \"../interfaces\";\nimport { isEdgeCell } from \"./asserts\";\n\nexport interface TransformToCenterOptions {\n canvasWidth: number;\n canvasHeight: number;\n scaleRange?: [min: number, max: number];\n}\n\nexport function transformToCenter(\n cells: Cell[],\n { canvasWidth, canvasHeight, scaleRange }: TransformToCenterOptions\n): TransformLiteral {\n let left = Infinity;\n let top = Infinity;\n let right = -Infinity;\n let bottom = -Infinity;\n let empty = true;\n for (const cell of cells) {\n if (!isEdgeCell(cell)) {\n empty = false;\n const { view } = cell;\n const r = view.x + view.width;\n const b = view.y + view.height;\n if (view.x < left) {\n left = view.x;\n }\n if (r > right) {\n right = r;\n }\n if (view.y < top) {\n top = view.y;\n }\n if (b > bottom) {\n bottom = b;\n }\n }\n }\n\n const width = right - left;\n const height = bottom - top;\n\n const scale =\n scaleRange && !empty && (width > canvasWidth || height > canvasHeight)\n ? Math.max(\n Math.min(canvasWidth / width, canvasHeight / height, scaleRange[1]),\n scaleRange[0]\n )\n : 1;\n\n const x = empty ? 0 : (canvasWidth - width * scale) / 2 - left * scale;\n const y = empty ? 0 : (canvasHeight - height * scale) / 2 - top * scale;\n\n return { x, y, k: scale };\n}\n","import type { Reducer } from \"react\";\nimport type { DrawCanvasAction } from \"./interfaces\";\nimport type { Cell, NodeCell } from \"../interfaces\";\nimport { isNodeCell } from \"../processors/asserts\";\nimport { SYMBOL_FOR_SIZE_INITIALIZED } from \"../constants\";\n\nexport const cells: Reducer<Cell[], DrawCanvasAction> = (state, action) => {\n switch (action.type) {\n case \"drop-node\":\n return insertCellAfter(\n state,\n action.payload,\n (cell) => !(cell.type === \"decorator\" && cell.decorator === \"text\")\n );\n case \"drop-decorator\": {\n if (action.payload.decorator === \"text\") {\n return [...state, action.payload];\n }\n return insertCellAfter(\n state,\n action.payload,\n (cell) => cell.type === \"decorator\" && cell.decorator === \"area\"\n );\n }\n case \"add-nodes\": {\n const index =\n state.findLastIndex(\n (cell) => !(cell.type === \"decorator\" && cell.decorator === \"text\")\n ) + 1;\n return [\n ...state.slice(0, index),\n ...action.payload,\n ...state.slice(index),\n ];\n }\n case \"add-edge\":\n // Add the edge to just next to the previous last edge or area decorator.\n // If not found, append to the start.\n return insertCellAfter(\n state,\n action.payload,\n (cell) =>\n cell.type === \"edge\" ||\n (cell.type === \"decorator\" && cell.decorator === \"area\")\n );\n case \"move-cell\": {\n const { type, id, x, y } = action.payload;\n const index = state.findIndex(\n (cell) => cell.type === type && cell.id === id\n );\n if (index !== -1) {\n const node = state[index] as NodeCell;\n return [\n ...state.slice(0, index),\n { ...node, view: { ...node.view, x, y } },\n ...state.slice(index + 1),\n ];\n }\n return state;\n }\n case \"resize-cell\": {\n const { type, id, width, height } = action.payload;\n const index = state.findIndex(\n (cell) => cell.type === type && cell.id === id\n );\n if (index !== -1) {\n const node = state[index] as NodeCell;\n return [\n ...state.slice(0, index),\n { ...node, view: { ...node.view, width, height } },\n ...state.slice(index + 1),\n ];\n }\n return state;\n }\n case \"update-cells\":\n return action.payload;\n case \"update-node-size\":\n return state.map((cell) =>\n isNodeCell(cell) && cell.id === action.payload.id\n ? {\n ...cell,\n [SYMBOL_FOR_SIZE_INITIALIZED]: true,\n view: action.payload.size\n ? {\n ...cell.view,\n width: action.payload.size[0],\n height: action.payload.size[1],\n }\n : cell.view,\n }\n : cell\n );\n }\n return state;\n};\n\nfunction insertCellAfter(\n cells: Cell[],\n newCell: Cell,\n after: (cell: Cell) => boolean\n) {\n const index = cells.findLastIndex(after) + 1;\n return [...cells.slice(0, index), newCell, ...cells.slice(index)];\n}\n","import { Reducer } from \"react\";\nimport type { DrawCanvasAction, DrawCanvasState } from \"./interfaces\";\nimport { cells } from \"./cells\";\nimport { layoutKey } from \"./layoutKey\";\n\ntype ReducersMapObject<S, A> = {\n [K in keyof S]: Reducer<S[K], A>;\n};\n\nfunction combineReducers<S, A>(\n reducers: ReducersMapObject<S, A>\n): Reducer<S, A> {\n return ((state, action) =>\n Object.fromEntries(\n Object.entries<Reducer<any, A>>(reducers).map(([key, value]) => [\n key,\n value(state[key as keyof S], action),\n ])\n )) as Reducer<S, A>;\n}\n\nexport const rootReducer = combineReducers<DrawCanvasState, DrawCanvasAction>({\n cells,\n layoutKey,\n});\n","import type { Reducer } from \"react\";\nimport type { DrawCanvasAction } from \"./interfaces\";\n\nexport const layoutKey: Reducer<number, DrawCanvasAction> = (state, action) => {\n switch (action.type) {\n case \"update-node-size\":\n return action.layoutKey;\n default:\n return state;\n }\n};\n","import * as React from \"react\";\nconst SvgCenter = props => <svg xmlns=\"http://www.w3.org/2000/svg\" width={24} height={24} viewBox=\"0 0 24 24\" {...props}><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\" /></svg>;\nexport default SvgCenter;","import * as React from \"react\";\nconst SvgZoomIn = props => <svg xmlns=\"http://www.w3.org/2000/svg\" width={128} height={128} className=\"icon\" viewBox=\"0 0 1024 1024\" {...props}><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\" /><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\" /></svg>;\nexport default SvgZoomIn;","import * as React from \"react\";\nconst SvgZoomOut = props => <svg xmlns=\"http://www.w3.org/2000/svg\" width={128} height={128} className=\"icon\" viewBox=\"0 0 1024 1024\" {...props}><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\" /><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\" /></svg>;\nexport default SvgZoomOut;","import React, { useCallback, useMemo, useRef } from \"react\";\nimport { ConfigProvider, Slider, theme } from \"antd\";\nimport { StyleProvider, createCache } from \"@ant-design/cssinjs\";\nimport { useCurrentTheme } from \"@next-core/react-runtime\";\nimport type { RangeTuple } from \"../../diagram/interfaces\";\nimport CenterSVG from \"./icons/center.svg\";\nimport ZoomInSVG from \"./icons/zoom-in.svg\";\nimport ZoomOutSVG from \"./icons/zoom-out.svg\";\n\nexport interface ZoomBarComponentProps {\n shadowRoot: ShadowRoot;\n scale: number;\n scaleRange: RangeTuple;\n onZoomChange(value: number): void;\n onReCenter(): void;\n}\n\nexport function ZoomBarComponent({\n shadowRoot,\n scale,\n scaleRange,\n onZoomChange,\n onReCenter,\n}: ZoomBarComponentProps): JSX.Element | null {\n const currentTheme = useCurrentTheme();\n const cache = useMemo(() => createCache(), []);\n const zoomBarRef = useRef<HTMLDivElement | null>(null);\n const min = scaleRange[0] * 100;\n const max = scaleRange[1] * 100;\n const value = scale * 100;\n const step = 5;\n\n const tooltip = useMemo(() => {\n return {\n formatter: (value: number | undefined) => `${value}%`,\n placement: \"left\" as const,\n getPopupContainer: () => zoomBarRef.current!,\n };\n }, []);\n\n const onZoomIn = useCallback(() => {\n onZoomChange(Math.min(value + step, max));\n }, [max, onZoomChange, value]);\n\n const onZoomOut = useCallback(() => {\n onZoomChange(Math.max(value - step, min));\n }, [min, onZoomChange, value]);\n\n return (\n <ConfigProvider\n theme={{\n algorithm:\n currentTheme === \"dark-v2\"\n ? theme.darkAlgorithm\n : theme.defaultAlgorithm,\n }}\n >\n <StyleProvider\n container={shadowRoot}\n // Auto clear injected styles after unmount\n autoClear\n cache={cache}\n // Set hashPriority to \"high\" to disable `:where()` usage for compatibility\n hashPriority=\"high\"\n >\n <div className=\"zoom-bar\" ref={zoomBarRef}>\n <div className=\"center-button\" onClick={onReCenter} role=\"button\">\n <CenterSVG />\n </div>\n <div className=\"zoom-slider\">\n <div className=\"zoom-button\" role=\"button\" onClick={onZoomIn}>\n <ZoomInSVG />\n </div>\n <Slider\n min={min}\n max={max}\n value={value}\n step={step}\n vertical\n included={false}\n tooltip={tooltip}\n onChange={onZoomChange}\n />\n <div className=\"zoom-button\" role=\"button\" onClick={onZoomOut}>\n <ZoomOutSVG />\n </div>\n </div>\n </div>\n </StyleProvider>\n </ConfigProvider>\n );\n}\n","import { pick } from \"lodash\";\nimport dagre from \"@dagrejs/dagre\";\nimport { extractPartialRectTuple } from \"../../diagram/processors/extractPartialRectTuple\";\nimport type {\n Cell,\n ForceNode,\n LayoutOptionsDagre,\n NodeId,\n NodeView,\n} from \"../../draw-canvas/interfaces\";\nimport { isEdgeCell, isNodeCell } from \"../../draw-canvas/processors/asserts\";\nimport type { FullRectTuple } from \"../../diagram/interfaces\";\n\nexport interface DagreLayoutOptions {\n cells: Cell[];\n layoutOptions?: LayoutOptionsDagre;\n}\n\nexport function dagreLayout({ cells, layoutOptions }: DagreLayoutOptions): {\n getNodeView: (id: NodeId) => NodeView;\n nodePaddings: FullRectTuple;\n} {\n const { nodePadding, ...dagreGraphOptions } = {\n nodePadding: 0,\n rankdir: \"TB\",\n ranksep: 50,\n edgesep: 10,\n nodesep: 50,\n // align: undefined,\n ...pick(layoutOptions, [\n \"nodePadding\",\n \"rankdir\",\n \"ranksep\",\n \"edgesep\",\n \"nodesep\",\n \"align\",\n ]),\n };\n const nodePaddings = extractPartialRectTuple(nodePadding);\n\n if (!cells.some(isNodeCell)) {\n // Dagre cannot render empty nodes\n return {\n getNodeView: () => null!,\n nodePaddings,\n };\n }\n\n const graph = new dagre.graphlib.Graph<ForceNode>();\n graph.setGraph(dagreGraphOptions);\n // Default to assigning a new object as a label for each new edge.\n graph.setDefaultEdgeLabel(function () {\n return {};\n });\n for (const cell of cells) {\n if (isNodeCell(cell)) {\n graph.setNode(cell.id, {\n id: cell.id,\n width: cell.view.width + nodePaddings[1] + nodePaddings[3],\n height: cell.view.height + nodePaddings[0] + nodePaddings[2],\n });\n } else if (isEdgeCell(cell)) {\n graph.setEdge(cell.source, cell.target);\n }\n }\n dagre.layout(graph);\n\n return {\n getNodeView: (id: NodeId) => graph.node(id),\n nodePaddings,\n };\n}\n","import { pick } from \"lodash\";\nimport {\n forceCollide,\n forceLink,\n forceManyBody,\n forceSimulation,\n forceX,\n forceY,\n type Simulation,\n} from \"d3-force\";\nimport type {\n Cell,\n ForceCollideOptions,\n ForceLink,\n ForceNode,\n LayoutOptionsForce,\n NodeId,\n NodeView,\n} from \"../../draw-canvas/interfaces\";\nimport { isEdgeCell, isNodeCell } from \"../../draw-canvas/processors/asserts\";\nimport { extractPartialRectTuple } from \"../../diagram/processors/extractPartialRectTuple\";\nimport type { FullRectTuple, PositionTuple } from \"../../diagram/interfaces\";\n\nexport interface ForceLayoutOptions {\n cells: Cell[];\n layoutOptions?: LayoutOptionsForce;\n center?: PositionTuple;\n fixedPosition?: boolean;\n}\n\nexport function forceLayout({\n cells,\n layoutOptions,\n center,\n fixedPosition,\n}: ForceLayoutOptions): {\n getNodeView: (id: NodeId) => NodeView;\n nodePaddings: FullRectTuple;\n} {\n const { nodePadding, collide } = {\n nodePadding: 0,\n ...pick(layoutOptions, [\"nodePadding\"]),\n collide:\n layoutOptions?.collide !== false\n ? ({\n radiusDiff: 18,\n strength: 1,\n iterations: 1,\n ...(layoutOptions?.collide === true\n ? null\n : (layoutOptions?.collide as ForceCollideOptions)),\n } as Required<ForceCollideOptions>)\n : (false as const),\n };\n const nodePaddings = extractPartialRectTuple(nodePadding);\n const forceNodes: ForceNode[] = [];\n const forceLinks: ForceLink[] = [];\n const nodesMap = new Map<NodeId, ForceNode>();\n for (const cell of cells) {\n if (isNodeCell(cell)) {\n const node: ForceNode = {\n id: cell.id,\n width: cell.view.width + nodePaddings[1] + nodePaddings[3],\n height: cell.view.height + nodePaddings[0] + nodePaddings[2],\n ...(fixedPosition ? { fx: cell.view.x, fy: cell.view.y } : null),\n };\n forceNodes.push(node);\n nodesMap.set(node.id, node);\n } else if (isEdgeCell(cell)) {\n forceLinks.push({ source: cell.source, target: cell.target });\n }\n }\n\n const linkSimulation = forceLink<ForceNode, ForceLink>(forceLinks).id(\n (d) => d.id\n );\n const simulation = forceSimulation<ForceNode, ForceLink>(forceNodes)\n .force(\"link\", linkSimulation)\n .force(\"x\", forceX(center?.[0]))\n .force(\"y\", forceY(center?.[1]))\n .force(\"charge\", forceManyBody());\n\n if (collide) {\n simulation.force(\n \"collide\",\n forceCollide<ForceNode>()\n .radius(\n (d) =>\n Math.sqrt(d.width ** 2 + d.height ** 2) / 2 + collide.radiusDiff\n )\n .strength(collide.strength)\n .iterations(collide.iterations)\n );\n }\n\n simulation.stop();\n manuallyTickToTheEnd(simulation);\n\n return {\n getNodeView: (id: NodeId) => nodesMap.get(id) as NodeView,\n nodePaddings,\n };\n}\n\nfunction manuallyTickToTheEnd(\n simulation: Simulation<ForceNode, ForceLink>\n): void {\n // Manually tick to the end.\n simulation.tick(\n Math.ceil(\n Math.log(simulation.alphaMin()) / Math.log(1 - simulation.alphaDecay())\n )\n );\n}\n","import React, { useEffect, useRef, useState } from \"react\";\nimport type { ActiveTarget } from \"../../draw-canvas/interfaces\";\nimport { sameTarget } from \"../../draw-canvas/processors/sameTarget\";\n\nexport interface UseActiveTargetOptions {\n cellsRef: React.RefObject<SVGGElement>;\n activeTarget?: ActiveTarget | null;\n onActiveTargetChange(target: ActiveTarget | null): void;\n}\n\nexport type UseActiveTargetResult = ActiveTarget | null;\n\nexport function useActiveTarget({\n cellsRef,\n activeTarget: _activeTarget,\n onActiveTargetChange,\n}: UseActiveTargetOptions): UseActiveTargetResult {\n const newActiveTarget = _activeTarget ?? null;\n const [activeTarget, setActiveTarget] = useState<ActiveTarget | null>(\n newActiveTarget\n );\n\n useEffect(() => {\n setActiveTarget((previous) =>\n sameTarget(previous, newActiveTarget) ? previous : newActiveTarget\n );\n }, [newActiveTarget]);\n\n const activeTargetChangeInitialized = useRef(false);\n useEffect(() => {\n if (!activeTargetChangeInitialized.current) {\n activeTargetChangeInitialized.current = true;\n return;\n }\n onActiveTargetChange(activeTarget);\n }, [activeTarget, onActiveTargetChange]);\n\n useEffect(() => {\n if (!activeTarget) {\n return;\n }\n const resetActiveTarget = (e: MouseEvent) => {\n const path = e.composedPath();\n const cellsContainerIndex = path.indexOf(cellsRef.current!);\n // Reset active target to null when clicking outside of the cells container,\n // Or inside the cells container but not on any cell.\n if (cellsContainerIndex <= 0) {\n setActiveTarget(null);\n }\n };\n document.addEventListener(\"click\", resetActiveTarget);\n return () => {\n document.removeEventListener(\"click\", resetActiveTarget);\n };\n }, [activeTarget, cellsRef]);\n\n return activeTarget;\n}\n","import { useCallback, useEffect, useRef, useState } from \"react\";\nimport type { ZoomBehavior } from \"d3-zoom\";\nimport type {\n Cell,\n LayoutOptions,\n LayoutOptionsForce,\n LayoutOptionsDagre,\n LayoutType,\n NodeId,\n NodeView,\n} from \"../../draw-canvas/interfaces\";\nimport type { FullRectTuple, RangeTuple } from \"../../diagram/interfaces\";\nimport { useAutoCenter } from \"./useAutoCenter\";\nimport {\n isNodeCell,\n isNodeOrEdgeCell,\n} from \"../../draw-canvas/processors/asserts\";\nimport {\n SYMBOL_FOR_LAYOUT_INITIALIZED,\n SYMBOL_FOR_SIZE_INITIALIZED,\n} from \"../../draw-canvas/constants\";\nimport type { DrawCanvasAction } from \"../../draw-canvas/reducers/interfaces\";\nimport { forceLayout } from \"./forceLayout\";\nimport { dagreLayout } from \"./dagreLayout\";\n\nexport interface UseLayoutOptions {\n layout: LayoutType;\n layoutOptions?: LayoutOptions;\n rootRef: React.RefObject<SVGSVGElement>;\n cells: Cell[];\n zoomable?: boolean;\n zoomer: ZoomBehavior<SVGSVGElement, unknown>;\n scaleRange: RangeTuple;\n layoutKey: number;\n dispatch: (value: DrawCanvasAction) => void;\n}\n\nexport function useLayout({\n layout,\n layoutOptions,\n rootRef,\n cells,\n zoomable,\n zoomer,\n scaleRange,\n layoutKey,\n dispatch,\n}: UseLayoutOptions) {\n const [layoutInitialized, setLayoutInitialized] = useState(\n layout !== \"force\" && layout !== \"dagre\"\n );\n\n const layoutKeyRef = useRef(layoutKey);\n\n const getNextLayoutKey = useCallback(() => {\n return ++layoutKeyRef.current;\n }, []);\n\n const [centered, setCentered] = useAutoCenter({\n rootRef,\n layoutInitialized,\n cells,\n zoomable,\n zoomer,\n scaleRange,\n });\n\n const previousLayoutRef = useRef<Cell[] | null>(null);\n\n useEffect(() => {\n // Wait for all nodes to be size-initialized before layout.\n if (\n cells.some(\n (cell) => isNodeCell(cell) && !cell[SYMBOL_FOR_SIZE_INITIALIZED]\n )\n ) {\n return;\n }\n\n if (layout !== \"force\" && layout !== \"dagre\") {\n setLayoutInitialized(true);\n return;\n }\n\n // DO NOT re-layout if layout key mismatched.\n // DO NOT re-layout if nodes and edges not changed.\n if (\n layoutKeyRef.current !== layoutKey ||\n isSameArray(previousLayoutRef.current, cells.filter(isNodeOrEdgeCell))\n ) {\n // Layout key mismatch happens when this effect is performed after\n // update-node-size dispatched but not yet applied.\n // If didn't ignore mismatched layout, it will cause the update-cells\n // action overwrites those update-node-size actions.\n return;\n }\n\n let getNodeView: (id: NodeId) => NodeView;\n let nodePaddings: FullRectTuple;\n\n if (layout === \"force\") {\n ({ getNodeView, nodePaddings } = forceLayout({\n cells,\n layoutOptions: layoutOptions as LayoutOptionsForce,\n }));\n } else {\n ({ getNodeView, nodePaddings } = dagreLayout({\n cells,\n layoutOptions: layoutOptions as LayoutOptionsDagre,\n }));\n }\n\n const newCells: Cell[] = cells.map((cell) => {\n if (isNodeCell(cell)) {\n const nodeView = getNodeView(cell.id);\n return {\n ...cell,\n view: {\n ...cell.view,\n x: nodeView.x! - nodeView.width / 2 + nodePaddings[3],\n y: nodeView.y! - nodeView.height / 2 + nodePaddings[0],\n },\n [SYMBOL_FOR_LAYOUT_INITIALIZED]: true,\n };\n }\n return cell;\n });\n previousLayoutRef.current = newCells.filter(isNodeOrEdgeCell);\n\n dispatch({ type: \"update-cells\", payload: newCells });\n setCentered(false);\n setLayoutInitialized(true);\n }, [cells, dispatch, layout, layoutKey, layoutOptions, setCentered]);\n\n return { centered, setCentered, getNextLayoutKey };\n}\n\nfunction isSameArray<T = unknown>(a: T[] | null, b: T[]): boolean {\n return a?.length === b.length && a.every((v, i) => v === b[i]);\n}\n","import React, { useEffect, useState } from \"react\";\nimport { select } from \"d3-selection\";\nimport { ZoomTransform, type ZoomBehavior } from \"d3-zoom\";\nimport type { RangeTuple } from \"../../diagram/interfaces\";\nimport { SYMBOL_FOR_SIZE_INITIALIZED } from \"../../draw-canvas/constants\";\nimport type { Cell } from \"../../draw-canvas/interfaces\";\nimport {\n isDecoratorCell,\n isNodeCell,\n} from \"../../draw-canvas/processors/asserts\";\nimport { transformToCenter } from \"../../draw-canvas/processors/transformToCenter\";\n\nexport interface UseAutoCenterOptions {\n rootRef: React.RefObject<SVGSVGElement>;\n cells: Cell[];\n layoutInitialized: boolean;\n zoomable?: boolean;\n zoomer: ZoomBehavior<SVGSVGElement, unknown>;\n scaleRange: RangeTuple;\n}\n\nexport type UseAutoCenterResult = [\n centered: boolean,\n setCentered: React.Dispatch<React.SetStateAction<boolean>>,\n];\n\nexport function useAutoCenter({\n rootRef,\n cells,\n layoutInitialized,\n zoomable,\n zoomer,\n scaleRange,\n}: UseAutoCenterOptions): UseAutoCenterResult {\n const [centered, setCentered] = useState(false);\n\n useEffect(() => {\n const root = rootRef.current;\n if (\n !root ||\n !layoutInitialized ||\n centered ||\n !cells.some((cell) => isNodeCell(cell) || isDecoratorCell(cell)) ||\n cells.some(\n (cell) => isNodeCell(cell) && !cell[SYMBOL_FOR_SIZE_INITIALIZED]\n )\n ) {\n return;\n }\n const { k, x, y } = transformToCenter(cells, {\n canvasWidth: root.clientWidth,\n canvasHeight: root.clientHeight,\n scaleRange: zoomable ? scaleRange : undefined,\n });\n // istanbul ignore next\n if (process.env.NODE_ENV !== \"test\") {\n // jsdom doesn't support svg baseVal yet.\n // https://github.com/jsdom/jsdom/issues/2531\n zoomer.transform(select(root), new ZoomTransform(k, x, y));\n }\n setCentered(true);\n }, [\n cells,\n centered,\n layoutInitialized,\n rootRef,\n scaleRange,\n zoomable,\n zoomer,\n ]);\n\n useEffect(() => {\n // Reset auto centering when nodes and decorators are all removed.\n if (!cells.some((cell) => isNodeCell(cell) || isDecoratorCell(cell))) {\n setCentered(false);\n }\n }, [cells]);\n\n return [centered, setCentered];\n}\n","import { useMemo } from \"react\";\nimport { __secret_internals, checkIfByTransform } from \"@next-core/runtime\";\nimport { findIndex, isUndefined, omitBy } from \"lodash\";\nimport type {\n Cell,\n ComputedEdgeLineConf,\n EdgeCell,\n EdgeLineConf,\n LineMarker,\n} from \"../../draw-canvas/interfaces\";\nimport { isEdgeCell } from \"../../draw-canvas/processors/asserts\";\nimport {\n DEFAULT_LINE_STROKE_COLOR,\n DEFAULT_LINE_STROKE_WIDTH,\n DEFAULT_LINE_INTERACT_STROKE_WIDTH,\n DEFAULT_LINE_INTERACT_SHOW_START_ARROW,\n DEFAULT_LINE_INTERACT_SHOW_END_ARROW,\n DEFAULT_LINE_INTERACT_ANIMATE_DURATION,\n} from \"../../draw-canvas/constants\";\n\nexport interface UseLineMarkersOptions {\n cells: Cell[];\n defaultEdgeLines: EdgeLineConf[] | undefined;\n markerPrefix: string;\n}\n\nexport function useLineMarkers({\n cells,\n defaultEdgeLines,\n markerPrefix,\n}: UseLineMarkersOptions): [\n lineConfMap: WeakMap<EdgeCell, ComputedEdgeLineConf>,\n markers: LineMarker[],\n] {\n return useMemo(() => {\n // Always put the default stroke marker at the first position,\n // since the connecting line will use it.\n const markers: LineMarker[] = [{ strokeColor: DEFAULT_LINE_STROKE_COLOR }];\n const map = new WeakMap<EdgeCell, ComputedEdgeLineConf>();\n for (const cell of cells) {\n if (isEdgeCell(cell)) {\n const computedLineConf =\n __secret_internals.legacyDoTransform(\n { edge: cell },\n defaultEdgeLines?.find((item) =>\n checkIfByTransform(item, { edge: cell })\n )\n ) ?? {};\n const lineConf = {\n dashed: false,\n strokeColor: DEFAULT_LINE_STROKE_COLOR,\n strokeWidth: DEFAULT_LINE_STROKE_WIDTH,\n interactStrokeWidth: DEFAULT_LINE_INTERACT_STROKE_WIDTH,\n showStartArrow: DEFAULT_LINE_INTERACT_SHOW_START_ARROW,\n showEndArrow: DEFAULT_LINE_INTERACT_SHOW_END_ARROW,\n animate: {\n useAnimate: false,\n duration: DEFAULT_LINE_INTERACT_ANIMATE_DURATION,\n },\n ...omitBy(computedLineConf, isUndefined),\n } as ComputedEdgeLineConf;\n if (lineConf.parallelGap === undefined) {\n lineConf.parallelGap = lineConf.interactStrokeWidth;\n }\n const markerEndIndex = addMarker(\n { strokeColor: lineConf.strokeColor },\n markers\n );\n lineConf.markerArrow = `url(#${markerPrefix}${markerEndIndex})`;\n map.set(cell, lineConf);\n }\n }\n return [map, markers];\n }, [cells, defaultEdgeLines, markerPrefix]);\n}\n\nfunction addMarker(marker: LineMarker, markers: LineMarker[]): number {\n let markerIndex = findIndex(markers, marker);\n if (markerIndex === -1) {\n markerIndex = markers.push(marker) - 1;\n }\n return markerIndex;\n}\n","import { useMemo } from \"react\";\nimport type { Cell, LayoutType } from \"../../draw-canvas/interfaces\";\nimport { isNodeCell } from \"../../draw-canvas/processors/asserts\";\nimport {\n SYMBOL_FOR_LAYOUT_INITIALIZED,\n SYMBOL_FOR_SIZE_INITIALIZED,\n} from \"../../draw-canvas/constants\";\n\nexport interface UseReadyOptions {\n cells: Cell[];\n layout: LayoutType;\n centered: boolean;\n}\n\nexport function useReady({ cells, layout, centered }: UseReadyOptions) {\n const ready = useMemo(\n () =>\n centered &&\n cells.every(\n (cell) =>\n !isNodeCell(cell) ||\n (cell[SYMBOL_FOR_SIZE_INITIALIZED] &&\n ((layout !== \"force\" && layout !== \"dagre\") ||\n cell[SYMBOL_FOR_LAYOUT_INITIALIZED]))\n ),\n [cells, centered, layout]\n );\n return ready;\n}\n","import React, { useEffect, useMemo, useState } from \"react\";\nimport { select } from \"d3-selection\";\nimport { zoom, type ZoomBehavior } from \"d3-zoom\";\nimport type { RangeTuple, TransformLiteral } from \"../../diagram/interfaces\";\nimport {\n DEFAULT_SCALE_RANGE_MIN,\n DEFAULT_SCALE_RANGE_MAX,\n} from \"../../draw-canvas/constants\";\nimport type { ActiveTarget } from \"../../draw-canvas/interfaces\";\n\nexport interface UseZoomOptions {\n rootRef: React.RefObject<SVGSVGElement>;\n zoomable?: boolean;\n scrollable?: boolean;\n pannable?: boolean;\n scaleRange?: RangeTuple;\n onSwitchActiveTarget?(target: ActiveTarget | null): void;\n}\n\nexport interface UseZoomResult {\n grabbing: boolean;\n transform: TransformLiteral;\n scaleRange: RangeTuple;\n zoomer: ZoomBehavior<SVGSVGElement, unknown>;\n}\n\nexport function useZoom({\n rootRef,\n zoomable,\n scrollable,\n pannable,\n scaleRange: _scaleRange,\n onSwitchActiveTarget,\n}: UseZoomOptions): UseZoomResult {\n const [grabbing, setGrabbing] = useState(false);\n const [transform, setTransform] = useState<TransformLiteral>({\n k: 1,\n x: 0,\n y: 0,\n });\n\n const scaleRange = useMemo(\n () =>\n _scaleRange ??\n ([DEFAULT_SCALE_RANGE_MIN, DEFAULT_SCALE_RANGE_MAX] as RangeTuple),\n [_scaleRange]\n );\n\n const zoomer = useMemo(() => zoom<SVGSVGElement, unknown>(), []);\n\n // istanbul ignore next: d3-zoom currently hard to test\n useEffect(() => {\n let moved = false;\n zoomer\n .scaleExtent(zoomable ? scaleRange : [1, 1])\n .on(\"start\", () => {\n moved = false;\n setGrabbing(true);\n })\n .on(\"zoom\", (e: { transform: TransformLiteral }) => {\n moved = true;\n setTransform(e.transform);\n })\n .on(\"end\", () => {\n setGrabbing(false);\n if (!moved) {\n onSwitchActiveTarget?.(null);\n }\n });\n }, [onSwitchActiveTarget, scaleRange, zoomable, zoomer]);\n\n // istanbul ignore next: d3-zoom currently hard to test\n useEffect(() => {\n const root = rootRef.current;\n if (!root) {\n return;\n }\n\n const rootSelection = select(root);\n\n const unsetZoom = () => {\n rootSelection\n .on(\".zoom\", null)\n .on(\".zoom.custom\", null)\n .on(\"wheel\", null);\n };\n\n if (!(zoomable || scrollable || pannable)) {\n unsetZoom();\n return;\n }\n\n if (zoomable || scrollable) {\n // Do not override default d3 zoom handler.\n // Only handles *panning*\n rootSelection.on(\n \"wheel.zoom.custom\",\n (e: WheelEvent & { wheelDeltaX: number; wheelDeltaY: number }) => {\n // Mac OS trackpad pinch event is emitted as a wheel.zoom and d3.event.ctrlKey set to true\n if (!e.ctrlKey) {\n // Stop immediate propagation for default d3 zoom handler\n e.stopImmediatePropagation();\n if (scrollable) {\n e.preventDefault();\n zoomer.translateBy(\n rootSelection,\n e.wheelDeltaX / 5,\n e.wheelDeltaY / 5\n );\n }\n }\n // zoomer.scaleBy(rootSelection, Math.pow(2, defaultWheelDelta(e)))\n }\n );\n }\n\n rootSelection\n .call(zoomer)\n .on(\"wheel\", (e: WheelEvent) => e.preventDefault())\n .on(\"dblclick.zoom\", null)\n .on(\"mousedown.zoom\", null);\n\n if (!pannable) {\n rootSelection\n .on(\"touchstart.zoom\", null)\n .on(\"touchmove.zoom\", null)\n .on(\"touchend.zoom\", null);\n }\n\n return unsetZoom;\n }, [pannable, rootRef, scrollable, zoomable, zoomer]);\n\n return { grabbing, transform, zoomer, scaleRange };\n}\n","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `.zoom-bar{position:absolute;bottom:20px;right:20px;width:40px}.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-inline:5px}.zoom-slider .ant-slider-vertical .ant-slider-rail{width:2px}.zoom-slider .ant-slider-vertical .ant-slider-handle{width:6px;height:6px;inset-inline-start: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;inset-inline-start:-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;inset-block-start:0;inset-inline-start:0}`, \"\"]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___.toString();\n","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `*{box-sizing:border-box}:host{display:block;position:relative;overflow:hidden;--animation-dasharray:48;--stroke-dashoffset:96;--dasharray:4}:host,\n.root{width:100%;height:100%}:host([hidden]){display:none}.root{opacity:0}.root.ready{opacity:1}.root:focus{outline:none}@keyframes dashedAnimation{0%{stroke-dashoffset:var(--stroke-dashoffset)}to{stroke-dashoffset:0}}@keyframes solidAnimation{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}.decorator-area .area{fill:rgba(119,141,195,0.1);stroke:none;stroke-width:0}.node,\n.decorator-text{overflow:visible}.cell.active .decorator-area .area,\n.cell.active .line-active-bg{stroke:var(--palette-blue-5);stroke-dasharray:var(--dasharray);stroke-width:1}.cell:not(.read-only){-webkit-user-select:none;-moz-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{opacity:1}.connect-line{pointer-events:none}.connect-line:not(.connecting){display:none}.line.dashed{stroke-dasharray:var(--dasharray)}.cell.active .decorator-text .text-container{outline:1px dashed var(--palette-blue-5)}.decorator-text .text-container{width:-webkit-max-content;width:-moz-max-content;width:max-content;padding:0.5em}.decorator-text .text:focus{outline:none}.cell.faded{opacity:0.3}.cell .node{pointer-events:none}.cell .node > *{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)}`, \"\"]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___.toString();\n"],"names":["MarkerComponent","_ref","Component","id","type","strokeColor","EntityRelationZeroOrOneMarker","EntityRelationZeroOrManyMarker","ArrowMarker","React","_ref2","viewBox","refX","refY","markerWidth","markerHeight","orient","strokeLinejoin","d","stroke","strokeWidth","fill","_ref3","_ref4","getDirectLinePoints","source","target","parallelGap","doTwoNodesOverlap","p0","p1","xDiff","yDiff","dx","x","dy","y","angle","Math","atan2","cos","PI","sin","line","sourceIntersections","getIntersections","targetIntersections","length","rect","vertices","width","height","possibleLines","i","push","intersections","item","intersection","intersect","x1","y1","x2","y2","x3","y3","x4","y4","denominator","ua","ub","a","b","paddingA","paddingB","A","getNodesWithPadding","B","left","min","right","max","top","bottom","node","padding","extractPartialRectTuple","value","Array","isArray","v0","v1","findNode","cells","find","cell","isNodeCell","EdgeComponent","_lineConf$animate$dur","_pathRef$current","_pathRef$current$getT","edge","lineConfMap","pathRef","useRef","sourceNode","useMemo","targetNode","lineConf","get","some","isEdgeCell","view","nodeViewToNodeRect","concat","interactStrokeWidth","ref","className","classNames","dashed","animate","useAnimate","style","duration","DEFAULT_LINE_INTERACT_ANIMATE_DURATION","current","getTotalLength","call","markerStart","showStartArrow","markerArrow","markerEnd","showEndArrow","NodeComponent","degraded","degradedNodeLabel","defaultNodeBricks","onResize","memoizedData","memoizedValue","setMemoizedValue","useState","useEffect","prev","isEqual","useDeepMemo","data","specifiedUseBrick","useBrick","observerRef","_defaultNodeBricks$fi","checkIfByTransform","label","String","__secret_internals","legacyDoTransform","refCallback","useCallback","element","prevObserver","disconnect","setTimeout","observer","ResizeObserver","offsetWidth","offsetHeight","observe","degradedRefCallBack","g","size","getBBox","ReactUseBrick","cx","cy","r","cellToTarget","pick","handleMouseDown","event","action","scale","layout","onCellMoving","onCellMoved","onCellResizing","onCellResized","onSwitchActiveTarget","stopPropagation","from","clientX","clientY","original","moved","handleMove","e","finished","movement","getMovement","onMouseMove","onMouseUp","document","removeEventListener","addEventListener","DecoratorArea","transform","readOnly","resizeHandleRef","resizeHandle","onMouseDown","k","DecoratorText","_cell$view$text","onDecoratorTextEditing","onDecoratorTextChange","text","currentLabel","setCurrentLabel","editingLabel","setEditingLabel","editingLabelInitialized","shouldEmitLabelChange","setShouldEmitLabelChange","handleEnableEdit","preventDefault","textContent","focus","range","createRange","selectNodeContents","selection","window","getSelection","removeAllRanges","addRange","selectAllText","editing","handleInput","handleBlur","_objectSpread","onDoubleClick","contentEditable","onInput","onBlur","DecoratorComponent","SpecifiedComponent","decorator","console","error","CellComponent","active","unrelatedCells","onCellContextMenu","onCellClick","onNodeBrickResize","onCellMouseEnter","onCellMouseLeave","gRef","unrelated","sameTarget","handleContextMenu","handleCellClick","handleMouseEnter","handleMouseLeave","faded","undefined","onContextMenu","onClick","onMouseEnter","onMouseLeave","isDecoratorCell","SYMBOL_FOR_SIZE_INITIALIZED","Symbol","for","SYMBOL_FOR_LAYOUT_INITIALIZED","DEFAULT_NODE_SIZE","DEFAULT_NODE_GAP","DEFAULT_AREA_WIDTH","DEFAULT_AREA_HEIGHT","DEFAULT_SCALE_RANGE_MIN","DEFAULT_SCALE_RANGE_MAX","DEFAULT_LINE_STROKE_COLOR","DEFAULT_LINE_STROKE_WIDTH","DEFAULT_LINE_INTERACT_STROKE_WIDTH","DEFAULT_LINE_INTERACT_SHOW_START_ARROW","DEFAULT_LINE_INTERACT_SHOW_END_ARROW","DEFAULT_DEGRADED_THRESHOLD","isInitialNodeCell","isNodeOrEdgeCell","getUnrelatedCells","connectLineState","activeTarget","existedTargets","Set","add","has","nodesMap","Map","relatedNodeIds","set","initializeCells","initialCells","defaultNodeSize","map","_cell$view","_cell$view2","transformToCenter","canvasWidth","canvasHeight","scaleRange","Infinity","empty","insertCellAfter","newCell","after","index","findLastIndex","slice","reducers","rootReducer","state","payload","findIndex","layoutKey","Object","fromEntries","entries","key","props","_extends","xmlns","ZoomBarComponent","shadowRoot","onZoomChange","onReCenter","currentTheme","useCurrentTheme","cache","createCache","zoomBarRef","tooltip","formatter","placement","getPopupContainer","onZoomIn","onZoomOut","ConfigProvider","theme","algorithm","darkAlgorithm","defaultAlgorithm","StyleProvider","container","autoClear","hashPriority","role","CenterSVG","ZoomInSVG","Slider","step","vertical","included","onChange","ZoomOutSVG","dagreLayout","layoutOptions","_nodePadding$rankdir$","nodePadding","rankdir","ranksep","edgesep","nodesep","dagreGraphOptions","_objectWithoutProperties","_excluded","nodePaddings","getNodeView","graph","dagre","Graph","setGraph","setDefaultEdgeLabel","setNode","setEdge","forceLayout","center","fixedPosition","collide","radiusDiff","strength","iterations","forceNodes","forceLinks","fx","fy","linkSimulation","forceLink","simulation","forceSimulation","force","forceX","forceY","forceManyBody","forceCollide","radius","sqrt","stop","tick","ceil","log","alphaMin","alphaDecay","manuallyTickToTheEnd","useActiveTarget","cellsRef","_activeTarget","onActiveTargetChange","newActiveTarget","setActiveTarget","previous","activeTargetChangeInitialized","resetActiveTarget","composedPath","indexOf","useLayout","rootRef","zoomable","zoomer","dispatch","layoutInitialized","setLayoutInitialized","layoutKeyRef","getNextLayoutKey","centered","setCentered","root","clientWidth","clientHeight","select","ZoomTransform","useAutoCenter","previousLayoutRef","filter","every","v","newCells","nodeView","useLineMarkers","defaultEdgeLines","markerPrefix","markers","WeakMap","_loop","_secret_internals$le","computedLineConf","omitBy","isUndefined","markerEndIndex","marker","markerIndex","addMarker","useReady","useZoom","scrollable","pannable","_scaleRange","grabbing","setGrabbing","setTransform","zoom","scaleExtent","on","rootSelection","unsetZoom","ctrlKey","stopImmediatePropagation","translateBy","wheelDeltaX","wheelDeltaY","___CSS_LOADER_EXPORT___","module","toString"],"sourceRoot":""}
@@ -0,0 +1,2 @@
1
+ "use strict";(self.webpackChunk_next_bricks_diagram=self.webpackChunk_next_bricks_diagram||[]).push([[9823],{6094:(e,t,a)=>{a.r(t),a.d(t,{EoDisplayCanvas:()=>Ne});var n,s,i,l,r,o,c,d,u,h,g,f,p,b,m,y,v,k,w,C,A,N,M,T,E,R,W,z,S,L,x,B,O,j,P,U,_,K,D,I,H,Y,q=a(4635),F=a(918),J=a(1369),Z=a(8449),G=a(4521),Q=a(8769),V=a.n(Q),X=a(9929),$=a(9938),ee=(a(330),a(1030)),te=a(3373),ae=a.n(te),ne=a(7566),se=a(3739),ie=a(8185),le=a(2830),re=a(3783),oe=a(3033),ce=a(8091),de=a(1819),ue=a(5748),he=a(227),ge=a(531),fe=a(7099),pe=a(2361),be=a(8197),me=a(7531),ye=a(3012),ve=a(8618);function ke(e,t,a){return a(Ae(e,t))}function we(e,t,a){return e.set(Ae(e,t),a),a}function Ce(e,t){return e.get(Ae(e,t))}function Ae(e,t,a){if("function"==typeof e?e===t:e.has(t))return arguments.length<3?t:a;throw new TypeError("Private element is not present on this object")}var Ne,{defineElement:Me,property:Te,event:Ee}=(0,X.createDecorators)(),Re=new WeakMap,We=new WeakMap,ze=new WeakMap,Se=new WeakMap,Le=new WeakMap,xe=new WeakMap,Be=new WeakMap,Oe=new WeakMap,je=new WeakMap,Pe=new WeakMap,Ue=new WeakMap,_e=new WeakMap,Ke=new WeakMap,De=new WeakMap,Ie=new WeakMap,He=new WeakSet,Ye=new WeakMap,qe=new WeakMap,Fe=new WeakMap,Je=new WeakMap,Ze=new WeakMap,Ge=new WeakMap;class Qe extends $.ReactNextElement{constructor(){super(...arguments),(0,q.A)(this,He),(0,F.A)(this,Re,s(this)),(0,F.A)(this,We,(i(this),l(this))),(0,F.A)(this,ze,(r(this),o(this))),(0,F.A)(this,Se,(c(this),d(this,[oe.HP,oe.HP]))),(0,F.A)(this,Le,(u(this),h(this))),(0,F.A)(this,xe,(g(this),f(this))),(0,F.A)(this,Be,(p(this),b(this))),(0,F.A)(this,Oe,(m(this),y(this))),(0,F.A)(this,je,(v(this),k(this))),(0,F.A)(this,Pe,(w(this),C(this))),(0,F.A)(this,Ue,(A(this),N(this,!0))),(0,F.A)(this,_e,(M(this),T(this,!0))),(0,F.A)(this,Ke,(E(this),R(this,!0))),(0,F.A)(this,De,(W(this),z(this))),(0,F.A)(this,Ie,(S(this),L(this))),(0,F.A)(this,Ye,(O(this),e=>{ke(He,this,x).emit(e)})),(0,F.A)(this,qe,(e=>{(0,ie.c)(e,this.activeTarget)||(this.activeTarget=e)})),(0,F.A)(this,Fe,j(this)),(0,F.A)(this,Je,(_(this),e=>{ke(He,this,P).emit(e)})),(0,F.A)(this,Ze,K(this)),(0,F.A)(this,Ge,(H(this),e=>{ke(He,this,D).emit(e)}))}get cells(){return Ce(Re,this)}set cells(e){we(Re,this,e)}get layout(){return Ce(We,this)}set layout(e){we(We,this,e)}get layoutOptions(){return Ce(ze,this)}set layoutOptions(e){we(ze,this,e)}get defaultNodeSize(){return Ce(Se,this)}set defaultNodeSize(e){we(Se,this,e)}get defaultNodeBricks(){return Ce(Le,this)}set defaultNodeBricks(e){we(Le,this,e)}get degradedThreshold(){return Ce(xe,this)}set degradedThreshold(e){we(xe,this,e)}get degradedNodeLabel(){return Ce(Be,this)}set degradedNodeLabel(e){we(Be,this,e)}get defaultEdgeLines(){return Ce(Oe,this)}set defaultEdgeLines(e){we(Oe,this,e)}get activeTarget(){return Ce(je,this)}set activeTarget(e){we(je,this,e)}get fadeUnrelatedCells(){return Ce(Pe,this)}set fadeUnrelatedCells(e){we(Pe,this,e)}get zoomable(){return Ce(Ue,this)}set zoomable(e){we(Ue,this,e)}get scrollable(){return Ce(_e,this)}set scrollable(e){we(_e,this,e)}get pannable(){return Ce(Ke,this)}set pannable(e){we(Ke,this,e)}get scaleRange(){return Ce(De,this)}set scaleRange(e){we(De,this,e)}render(){return V().createElement(Ve,{shadowRoot:this.shadowRoot,cells:this.cells,layout:this.layout,layoutOptions:this.layoutOptions,defaultNodeSize:this.defaultNodeSize,defaultNodeBricks:this.defaultNodeBricks,defaultEdgeLines:this.defaultEdgeLines,degradedThreshold:this.degradedThreshold,degradedNodeLabel:this.degradedNodeLabel,activeTarget:this.activeTarget,fadeUnrelatedCells:this.fadeUnrelatedCells,zoomable:this.zoomable,scrollable:this.scrollable,pannable:this.pannable,scaleRange:this.scaleRange,onActiveTargetChange:Ce(Ye,this),onSwitchActiveTarget:Ce(qe,this),onCellContextMenu:Ce(Je,this),onCellClick:Ce(Ge,this)})}}function Ve(e){var{shadowRoot:t,cells:a,layout:n,layoutOptions:s,defaultNodeSize:i,defaultNodeBricks:l,defaultEdgeLines:r,degradedThreshold:o,degradedNodeLabel:c,activeTarget:d,fadeUnrelatedCells:u,zoomable:h,scrollable:g,pannable:f,scaleRange:p,onActiveTargetChange:b,onSwitchActiveTarget:m,onCellContextMenu:y,onCellClick:v}=e,[{cells:k,layoutKey:w},C]=(0,Q.useReducer)(ue.d,a,(e=>({cells:(0,re.C)(e,{defaultNodeSize:i}),layoutKey:1}))),A=(0,Q.useMemo)((()=>k.filter(ge.N).length>=(null!=o?o:oe.pC)),[k,o]),N=(0,Q.useRef)(null),M=(0,Q.useRef)(null),{grabbing:T,transform:E,zoomer:R,scaleRange:W}=(0,ce.f)({rootRef:N,zoomable:h,scrollable:g,pannable:f,scaleRange:p,onSwitchActiveTarget:m}),{centered:z,setCentered:S,getNextLayoutKey:L}=(0,pe.g)({layout:n,layoutOptions:s,rootRef:N,cells:k,zoomable:h,zoomer:R,scaleRange:W,layoutKey:w,dispatch:C}),x=(0,de.J)({cellsRef:M,activeTarget:d,onActiveTargetChange:b}),B=(0,Q.useMemo)((()=>"".concat((0,ee.uniqueId)("diagram-"),"-")),[]),O="".concat(B,"line-arrow-"),j=(0,Q.useCallback)(((e,t)=>{C({type:"update-node-size",payload:{id:e,size:t},layoutKey:L()})}),[L]),[P,U]=(0,Q.useState)(null),_=(0,Q.useCallback)((e=>{U(e)}),[]),K=(0,Q.useCallback)((e=>{U((t=>t===e?null:t))}),[]),[D,I]=(0,Q.useState)([]);(0,Q.useEffect)((()=>{var e=u?(0,he.Y)(k,null,P):[];I((t=>0===t.length&&0===e.length?t:e))}),[k,u,P]);var H=(0,Q.useCallback)((e=>{R.scaleTo((0,ne.A)(N.current),e/100)}),[R]),Y=(0,Q.useCallback)((()=>{S(!1)}),[S]),[q,F]=(0,me.d)({cells:k,defaultEdgeLines:r,markerPrefix:O}),J=(0,be.H)({cells:k,layout:n,centered:z});return V().createElement(V().Fragment,null,V().createElement("svg",{width:"100%",height:"100%",ref:N,className:ae()("root",{grabbing:T,pannable:f,ready:J}),tabIndex:-1},V().createElement("defs",null,F.map(((e,t)=>V().createElement(se.c,{key:t,id:"".concat(O).concat(t),type:"arrow",strokeColor:e.strokeColor})))),V().createElement("g",{transform:"translate(".concat(E.x," ").concat(E.y,") scale(").concat(E.k,")")},V().createElement("g",{className:"cells",ref:M},k.map((e=>V().createElement(le.m,{key:"".concat(e.type,":").concat((0,ge.WW)(e)?"".concat(e.source,"~").concat(e.target):e.id),layout:void 0,cell:e,cells:k,degraded:A,degradedNodeLabel:c,defaultNodeBricks:l,lineConfMap:q,transform:E,active:(0,ie.c)(x,e),readOnly:!0,unrelatedCells:D,onSwitchActiveTarget:m,onCellContextMenu:y,onCellClick:v,onNodeBrickResize:j,onCellMouseEnter:u&&(0,ge.N)(e)?_:void 0,onCellMouseLeave:u&&(0,ge.N)(e)?K:void 0})))))),V().createElement(fe.Y,{shadowRoot:t,scale:E.k,scaleRange:W,onZoomChange:H,onReCenter:Y}))}Y=Qe,({e:[s,i,l,r,o,c,d,u,h,g,f,p,b,m,y,v,k,w,C,A,N,M,T,E,R,W,z,S,L,x,B,O,j,P,U,_,K,D,I,H],c:[Ne,n]}=function(e,t,a,n,s,i){var l,r,o,c,d,u,h,g=Symbol.metadata||Symbol.for("Symbol.metadata"),f=Object.defineProperty,p=Object.create,b=[p(null),p(null)],m=t.length;function y(t,a,n){return function(s,i){a&&(i=s,s=e);for(var l=0;l<t.length;l++)i=t[l].apply(s,n?[i]:[]);return n?i:s}}function v(e,t,a,n){if("function"!=typeof e&&(n||void 0!==e))throw new TypeError(t+" must "+(a||"be")+" a function"+(n?"":" or undefined"));return e}function k(e,t,a,n,s,i,o,c,d,u,h){function g(e){if(!h(e))throw new TypeError("Attempted to access private element on non-instance")}var p=[].concat(t[0]),m=t[3],k=!o,w=1===s,C=3===s,A=4===s,N=2===s;function M(t,a,n){return function(s,i){return a&&(i=s,s=e),n&&n(s),T[t].call(s,i)}}if(!k){var T={},E=[],R=C?"get":A||w?"set":"value";if(d?(u||w?T={get:(0,Z.A)((function(){return m(this)}),n,"get"),set:function(e){t[4](this,e)}}:T[R]=m,u||(0,Z.A)(T[R],n,N?"":R)):u||(T=Object.getOwnPropertyDescriptor(e,n)),!u&&!d){if((r=b[+c][n])&&7!=(r^s))throw new Error("Decorating two elements with the same name ("+T[R].name+") is not supported yet");b[+c][n]=s<3?1:s}}for(var W=e,z=p.length-1;z>=0;z-=a?2:1){var S=p[z],L=a?p[z-1]:void 0,x={},B={kind:["field","accessor","method","getter","setter","class"][s],name:n,metadata:l,addInitializer:function(e,t){if(e.v)throw new Error("attempted to call addInitializer after decoration was finished");v(t,"An initializer","be",!0),i.push(t)}.bind(null,x)};if(k)r=S.call(L,W,B),x.v=1,v(r,"class decorators","return")&&(W=r);else if(B.static=c,B.private=d,r=B.access={has:d?h.bind():function(e){return n in e}},A||(r.get=d?N?function(e){return g(e),T.value}:M("get",0,g):function(e){return e[n]}),N||C||(r.set=d?M("set",0,g):function(e,t){e[n]=t}),W=S.call(L,w?{get:T.get,set:T.set}:T[R],B),x.v=1,w){if("object"==typeof W&&W)(r=v(W.get,"accessor.get"))&&(T.get=r),(r=v(W.set,"accessor.set"))&&(T.set=r),(r=v(W.init,"accessor.init"))&&E.unshift(r);else if(void 0!==W)throw new TypeError("accessor decorators must return an object with get, set, or init properties or undefined")}else v(W,(u?"field":"method")+" decorators","return")&&(u?E.unshift(W):T[R]=W)}return s<2&&o.push(y(E,c,1),y(i,c,0)),u||k||(d?w?o.splice(-1,0,M("get",c),M("set",c)):o.push(N?T[R]:v.call.bind(T[R])):f(e,n,T)),W}function w(e){return f(e,g,{configurable:!0,enumerable:!0,value:l})}return void 0!==i&&(l=i[g]),l=p(null==l?null:l),d=[],u=function(e){e&&d.push(y(e))},(h=function(t,n){for(var i=0;i<a.length;i++){var l=a[i],r=l[1],u=7&r;if((8&r)==t&&!u==n){var h=l[2],g=!!l[3],f=16&r;k(t?e:e.prototype,l,f,g?"#"+h:(0,J.A)(h),u,u<2?[]:t?c=c||[]:o=o||[],d,!!t,g,n,t&&g?function(t){return(0,G.A)(t)===e}:s)}}})(8,0),h(0,0),h(8,1),h(0,1),u(o),u(c),r=d,m||w(e),{e:r,get c(){var a=[];return m&&[w(e=k(e,[t],0,e.name,5,a)),y(a,1)]}}}(Y,[Me("eo-display-canvas",{styleTexts:[ye.A,ve.A]})],[[Te({attribute:!1}),1,"cells"],[Te({type:String}),1,"layout"],[Te({attribute:!1}),1,"layoutOptions"],[Te({attribute:!1}),1,"defaultNodeSize"],[Te({attribute:!1}),1,"defaultNodeBricks"],[Te({type:Number}),1,"degradedThreshold"],[Te({attribute:!1}),1,"degradedNodeLabel"],[Te({attribute:!1}),1,"defaultEdgeLines"],[Te({attribute:!1}),1,"activeTarget"],[Te({type:Boolean}),1,"fadeUnrelatedCells"],[Te({type:Boolean}),1,"zoomable"],[Te({type:Boolean}),1,"scrollable"],[Te({type:Boolean}),1,"pannable"],[Te({attribute:!1}),1,"scaleRange"],[Ee({type:"activeTarget.change"}),1,"activeTargetChangeEvent",e=>Ce(Ie,e),(e,t)=>we(Ie,e,t)],[Ee({type:"cell.contextmenu"}),1,"cellContextMenu",e=>Ce(Fe,e),(e,t)=>we(Fe,e,t)],[Ee({type:"cell.click"}),1,"cellClick",e=>Ce(Ze,e),(e,t)=>we(Ze,e,t)]],0,(e=>Ge.has((0,G.A)(e))),$.ReactNextElement)),n()}}]);
2
+ //# sourceMappingURL=eo-display-canvas.8feea548.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"chunks/eo-display-canvas.8feea548.js","mappings":"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","sources":["webpack:///./src/display-canvas/index.tsx"],"sourcesContent":["import React, {\n useCallback,\n useEffect,\n useMemo,\n useReducer,\n useRef,\n useState,\n} from \"react\";\nimport { createDecorators, type EventEmitter } from \"@next-core/element\";\nimport { ReactNextElement } from \"@next-core/react-element\";\nimport \"@next-core/theme\";\nimport { uniqueId } from \"lodash\";\nimport classNames from \"classnames\";\nimport { select } from \"d3-selection\";\nimport type { RangeTuple, SizeTuple } from \"../diagram/interfaces\";\nimport type {\n ActiveTarget,\n InitialCell,\n NodeBrickConf,\n CellContextMenuDetail,\n EdgeLineConf,\n Cell,\n LayoutType,\n LayoutOptions,\n} from \"../draw-canvas/interfaces\";\nimport { MarkerComponent } from \"../diagram/MarkerComponent\";\nimport { sameTarget } from \"../draw-canvas/processors/sameTarget\";\nimport { CellComponent } from \"../draw-canvas/CellComponent\";\nimport { initializeCells } from \"../draw-canvas/processors/initializeCells\";\nimport {\n DEFAULT_DEGRADED_THRESHOLD,\n DEFAULT_NODE_SIZE,\n} from \"../draw-canvas/constants\";\nimport { useZoom } from \"../shared/canvas/useZoom\";\nimport { useActiveTarget } from \"../shared/canvas/useActiveTarget\";\nimport { rootReducer } from \"../draw-canvas/reducers\";\nimport { getUnrelatedCells } from \"../draw-canvas/processors/getUnrelatedCells\";\nimport { isEdgeCell, isNodeCell } from \"../draw-canvas/processors/asserts\";\nimport { ZoomBarComponent } from \"../shared/canvas/ZoomBarComponent\";\nimport { useLayout } from \"../shared/canvas/useLayout\";\nimport { useReady } from \"../shared/canvas/useReady\";\nimport { useLineMarkers } from \"../shared/canvas/useLineMarkers\";\nimport styleText from \"../shared/canvas/styles.shadow.css\";\nimport zoomBarStyleText from \"../shared/canvas/ZoomBarComponent.shadow.css\";\n\nconst { defineElement, property, event } = createDecorators();\n\nexport interface EoDisplayCanvasProps {\n cells: InitialCell[] | undefined;\n layout: LayoutType;\n layoutOptions?: LayoutOptions;\n defaultNodeSize: SizeTuple;\n defaultNodeBricks?: NodeBrickConf[];\n defaultEdgeLines?: EdgeLineConf[];\n degradedThreshold?: number;\n degradedNodeLabel?: string;\n activeTarget?: ActiveTarget | null;\n fadeUnrelatedCells?: boolean;\n zoomable?: boolean;\n scrollable?: boolean;\n pannable?: boolean;\n scaleRange?: RangeTuple;\n}\n\n/**\n * 用于展示查看的画布。\n */\nexport\n@defineElement(\"eo-display-canvas\", {\n styleTexts: [styleText, zoomBarStyleText],\n})\nclass EoDisplayCanvas extends ReactNextElement implements EoDisplayCanvasProps {\n /**\n * 仅当初始化时使用,渲染后重新设置 `cells` 将无效。\n */\n @property({ attribute: false })\n accessor cells: InitialCell[] | undefined;\n\n @property({ type: String })\n accessor layout: LayoutType;\n\n @property({ attribute: false })\n accessor layoutOptions: LayoutOptions | undefined;\n\n @property({ attribute: false })\n accessor defaultNodeSize: SizeTuple = [DEFAULT_NODE_SIZE, DEFAULT_NODE_SIZE];\n\n @property({ attribute: false })\n accessor defaultNodeBricks: NodeBrickConf[] | undefined;\n\n /**\n * 当节点数量达到或超过 `degradedThreshold` 时,节点将被降级展示。\n *\n * @default 500\n */\n @property({ type: Number })\n accessor degradedThreshold: number | undefined;\n\n // Set `attribute` to `false` event if it accepts string value.\n // Because when passing like \"<% DATA.node.data.name %>\", it will be\n // evaluated as object temporarily.\n /**\n * 设置节点将降级展示时显示的名称。\n *\n * @default \"<% DATA.node.id %>\"\n */\n @property({ attribute: false })\n accessor degradedNodeLabel: string | undefined;\n\n /**\n * 使用条件判断设置默认的边对应的连线。在 `if` 表达式中 `DATA` 为 `{ edge }`,例如:\n *\n * ```yaml\n * defaultEdgeLines:\n * - if: <% DATA.edge.data?.virtual %>\n * dashed: true\n * ```\n */\n @property({ attribute: false })\n accessor defaultEdgeLines: EdgeLineConf[] | undefined;\n\n @property({ attribute: false })\n accessor activeTarget: ActiveTarget | null | undefined;\n\n /**\n * 当鼠标悬浮到某节点上时,隐藏其他跟该节点无关的元素。\n */\n @property({ type: Boolean })\n accessor fadeUnrelatedCells: boolean | undefined;\n\n @property({ type: Boolean })\n accessor zoomable: boolean | undefined = true;\n\n @property({ type: Boolean })\n accessor scrollable: boolean | undefined = true;\n\n @property({ type: Boolean })\n accessor pannable: boolean | undefined = true;\n\n @property({ attribute: false })\n accessor scaleRange: RangeTuple | undefined;\n\n @event({ type: \"activeTarget.change\" })\n accessor #activeTargetChangeEvent!: EventEmitter<ActiveTarget | null>;\n\n #handleActiveTargetChange = (target: ActiveTarget | null) => {\n this.#activeTargetChangeEvent.emit(target);\n };\n\n #handleSwitchActiveTarget = (target: ActiveTarget | null) => {\n if (!sameTarget(target, this.activeTarget)) {\n this.activeTarget = target;\n }\n };\n\n @event({ type: \"cell.contextmenu\" })\n accessor #cellContextMenu!: EventEmitter<CellContextMenuDetail>;\n\n #handleCellContextMenu = (detail: CellContextMenuDetail) => {\n this.#cellContextMenu.emit(detail);\n };\n\n @event({ type: \"cell.click\" })\n accessor #cellClick!: EventEmitter<CellContextMenuDetail>;\n\n #handleCellClick = (detail: CellContextMenuDetail) => {\n this.#cellClick.emit(detail);\n };\n\n render() {\n return (\n <EoDisplayCanvasComponent\n shadowRoot={this.shadowRoot!}\n cells={this.cells}\n layout={this.layout}\n layoutOptions={this.layoutOptions}\n defaultNodeSize={this.defaultNodeSize}\n defaultNodeBricks={this.defaultNodeBricks}\n defaultEdgeLines={this.defaultEdgeLines}\n degradedThreshold={this.degradedThreshold}\n degradedNodeLabel={this.degradedNodeLabel}\n activeTarget={this.activeTarget}\n fadeUnrelatedCells={this.fadeUnrelatedCells}\n zoomable={this.zoomable}\n scrollable={this.scrollable}\n pannable={this.pannable}\n scaleRange={this.scaleRange}\n onActiveTargetChange={this.#handleActiveTargetChange}\n onSwitchActiveTarget={this.#handleSwitchActiveTarget}\n onCellContextMenu={this.#handleCellContextMenu}\n onCellClick={this.#handleCellClick}\n />\n );\n }\n}\n\nexport interface EoDisplayCanvasComponentProps extends EoDisplayCanvasProps {\n shadowRoot: ShadowRoot;\n onActiveTargetChange(target: ActiveTarget | null): void;\n onSwitchActiveTarget(target: ActiveTarget | null): void;\n onCellContextMenu(detail: CellContextMenuDetail): void;\n onCellClick(detail: CellContextMenuDetail): void;\n}\n\nfunction EoDisplayCanvasComponent({\n shadowRoot,\n cells: initialCells,\n layout,\n layoutOptions,\n defaultNodeSize,\n defaultNodeBricks,\n defaultEdgeLines,\n degradedThreshold,\n degradedNodeLabel,\n activeTarget: _activeTarget,\n fadeUnrelatedCells,\n zoomable,\n scrollable,\n pannable,\n scaleRange: _scaleRange,\n onActiveTargetChange,\n onSwitchActiveTarget,\n onCellContextMenu,\n onCellClick,\n}: EoDisplayCanvasComponentProps) {\n const [{ cells, layoutKey }, dispatch] = useReducer(\n rootReducer,\n initialCells,\n (initialCells) => ({\n cells: initializeCells(initialCells, { defaultNodeSize }),\n layoutKey: 1,\n })\n );\n\n // When nodes are greater or equal to threshold, the diagram will be degraded.\n // Thus all nodes will be displayed as simple svg elements instead of bricks.\n const degraded = useMemo(\n () =>\n cells.filter(isNodeCell).length >=\n (degradedThreshold ?? DEFAULT_DEGRADED_THRESHOLD),\n [cells, degradedThreshold]\n );\n\n const rootRef = useRef<SVGSVGElement>(null);\n const cellsRef = useRef<SVGGElement>(null);\n\n const { grabbing, transform, zoomer, scaleRange } = useZoom({\n rootRef,\n zoomable,\n scrollable,\n pannable,\n scaleRange: _scaleRange,\n onSwitchActiveTarget,\n });\n\n const { centered, setCentered, getNextLayoutKey } = useLayout({\n layout,\n layoutOptions,\n rootRef,\n cells,\n zoomable,\n zoomer,\n scaleRange,\n layoutKey,\n dispatch,\n });\n\n const activeTarget = useActiveTarget({\n cellsRef,\n activeTarget: _activeTarget,\n onActiveTargetChange,\n });\n\n const defPrefix = useMemo(() => `${uniqueId(\"diagram-\")}-`, []);\n const markerPrefix = `${defPrefix}line-arrow-`;\n\n const handleNodeBrickResize = useCallback(\n (id: string, size: SizeTuple | null) => {\n dispatch({\n type: \"update-node-size\",\n payload: { id, size },\n layoutKey: getNextLayoutKey(),\n });\n },\n [getNextLayoutKey]\n );\n\n const [hoverCell, setHoverCell] = useState<Cell | null>(null);\n const handleCellMouseEnter = useCallback((cell: Cell) => {\n setHoverCell(cell);\n }, []);\n const handleCellMouseLeave = useCallback((cell: Cell) => {\n setHoverCell((prev) => (prev === cell ? null : prev));\n }, []);\n\n const [unrelatedCells, setUnrelatedCells] = useState<Cell[]>([]);\n useEffect(() => {\n const nextUnrelated = fadeUnrelatedCells\n ? getUnrelatedCells(cells, null, hoverCell)\n : [];\n // Do not update the state when prev and next are both empty.\n setUnrelatedCells((prev) =>\n prev.length === 0 && nextUnrelated.length === 0 ? prev : nextUnrelated\n );\n }, [cells, fadeUnrelatedCells, hoverCell]);\n\n const handleZoomSlide = useCallback(\n (value: number) => {\n // istanbul ignore next\n if (process.env.NODE_ENV !== \"test\") {\n zoomer.scaleTo(select(rootRef.current!), value / 100);\n }\n },\n [zoomer]\n );\n\n const reCenter = useCallback(() => {\n setCentered(false);\n }, [setCentered]);\n\n const [lineConfMap, markers] = useLineMarkers({\n cells,\n defaultEdgeLines,\n markerPrefix,\n });\n\n const ready = useReady({ cells, layout, centered });\n\n return (\n <>\n <svg\n width=\"100%\"\n height=\"100%\"\n ref={rootRef}\n className={classNames(\"root\", { grabbing, pannable, ready })}\n tabIndex={-1}\n >\n <defs>\n {markers.map((marker, index) => (\n <MarkerComponent\n key={index}\n id={`${markerPrefix}${index}`}\n type=\"arrow\"\n strokeColor={marker.strokeColor}\n />\n ))}\n </defs>\n <g\n transform={`translate(${transform.x} ${transform.y}) scale(${transform.k})`}\n >\n <g className=\"cells\" ref={cellsRef}>\n {cells.map((cell) => (\n <CellComponent\n key={`${cell.type}:${isEdgeCell(cell) ? `${cell.source}~${cell.target}` : cell.id}`}\n layout={undefined}\n cell={cell}\n cells={cells}\n degraded={degraded}\n degradedNodeLabel={degradedNodeLabel}\n defaultNodeBricks={defaultNodeBricks}\n lineConfMap={lineConfMap}\n transform={transform}\n active={sameTarget(activeTarget, cell)}\n readOnly\n unrelatedCells={unrelatedCells}\n onSwitchActiveTarget={onSwitchActiveTarget}\n onCellContextMenu={onCellContextMenu}\n onCellClick={onCellClick}\n onNodeBrickResize={handleNodeBrickResize}\n onCellMouseEnter={\n fadeUnrelatedCells && isNodeCell(cell)\n ? handleCellMouseEnter\n : undefined\n }\n onCellMouseLeave={\n fadeUnrelatedCells && isNodeCell(cell)\n ? handleCellMouseLeave\n : undefined\n }\n />\n ))}\n </g>\n </g>\n </svg>\n <ZoomBarComponent\n shadowRoot={shadowRoot}\n scale={transform.k}\n scaleRange={scaleRange}\n onZoomChange={handleZoomSlide}\n onReCenter={reCenter}\n />\n </>\n );\n}\n"],"names":["_EoDisplayCanvas","defineElement","property","event","createDecorators","_A","WeakMap","_B","_C","_D","_E","_F","_G","_H","_I","_J","_K","_L","_M","_N","_O","_EoDisplayCanvas_brand","WeakSet","_handleActiveTargetChange","_handleSwitchActiveTarget","_P","_handleCellContextMenu","_Q","_handleCellClick","EoDisplayCanvas","ReactNextElement","constructor","arguments","_classPrivateMethodInitSpec","_classPrivateFieldInitSpec","_init_cells","_init_extra_cells","_init_layout","_init_extra_layout","_init_layoutOptions","_init_extra_layoutOptions","_init_defaultNodeSize","DEFAULT_NODE_SIZE","_init_extra_defaultNodeSize","_init_defaultNodeBricks","_init_extra_defaultNodeBricks","_init_degradedThreshold","_init_extra_degradedThreshold","_init_degradedNodeLabel","_init_extra_degradedNodeLabel","_init_defaultEdgeLines","_init_extra_defaultEdgeLines","_init_activeTarget","_init_extra_activeTarget","_init_fadeUnrelatedCells","_init_extra_fadeUnrelatedCells","_init_zoomable","_init_extra_zoomable","_init_scrollable","_init_extra_scrollable","_init_pannable","_init_extra_pannable","_init_scaleRange","_init_extra_scaleRange","_init_activeTargetChangeEvent","_init_extra_activeTargetChangeEvent","target","_classPrivateGetter","this","_get_activeTargetChangeEvent","emit","sameTarget","activeTarget","_init_cellContextMenu","_init_extra_cellContextMenu","detail","_get_cellContextMenu","_init_cellClick","_init_extra_cellClick","_get_cellClick","cells","_classPrivateFieldGet","v","_classPrivateFieldSet","layout","layoutOptions","defaultNodeSize","defaultNodeBricks","degradedThreshold","degradedNodeLabel","defaultEdgeLines","fadeUnrelatedCells","zoomable","scrollable","pannable","scaleRange","render","React","EoDisplayCanvasComponent","shadowRoot","onActiveTargetChange","onSwitchActiveTarget","onCellContextMenu","onCellClick","_ref","initialCells","_activeTarget","_scaleRange","layoutKey","dispatch","useReducer","rootReducer","initializeCells","degraded","useMemo","filter","isNodeCell","length","DEFAULT_DEGRADED_THRESHOLD","rootRef","useRef","cellsRef","grabbing","transform","zoomer","useZoom","centered","setCentered","getNextLayoutKey","useLayout","useActiveTarget","defPrefix","concat","uniqueId","markerPrefix","handleNodeBrickResize","useCallback","id","size","type","payload","hoverCell","setHoverCell","useState","handleCellMouseEnter","cell","handleCellMouseLeave","prev","unrelatedCells","setUnrelatedCells","useEffect","nextUnrelated","getUnrelatedCells","handleZoomSlide","value","scaleTo","select","current","reCenter","lineConfMap","markers","useLineMarkers","ready","useReady","width","height","ref","className","classNames","tabIndex","map","marker","index","MarkerComponent","key","strokeColor","x","y","k","CellComponent","isEdgeCell","source","undefined","active","readOnly","onNodeBrickResize","onCellMouseEnter","onCellMouseLeave","ZoomBarComponent","scale","onZoomChange","onReCenter","_EoDisplayCanvas2","e","_set_activeTargetChangeEvent","_set_cellContextMenu","_set_cellClick","c","_initClass","_applyDecs","styleTexts","styleText","zoomBarStyleText","attribute","String","Number","Boolean","o","_","has","_checkInRHS"],"sourceRoot":""}
@@ -0,0 +1,2 @@
1
+ "use strict";(self.webpackChunk_next_bricks_diagram=self.webpackChunk_next_bricks_diagram||[]).push([[8939],{3639:(e,t,a)=>{a.d(t,{w:()=>l});var n=a(8769),r=a.n(n),i=a(3373),o=a.n(i);function l(e){var{connectLineState:t,transform:a,markerEnd:i,onConnect:l}=e,[s,d]=(0,n.useState)(null);return(0,n.useEffect)((()=>{t&&d(t.from)}),[t]),(0,n.useEffect)((()=>{if(t){var e=e=>{d([(e.clientX-a.x-t.offset[0])/a.k,(e.clientY-a.y-t.offset[1])/a.k])},n=e=>{e.stopPropagation()},r=e=>{e.stopPropagation(),i(),l(t,[(e.clientX-a.x-t.offset[0])/a.k,(e.clientY-a.y-t.offset[1])/a.k])},i=()=>{document.removeEventListener("mousemove",e),document.removeEventListener("mousedown",n,{capture:!0}),document.removeEventListener("click",r,{capture:!0}),d(null)};return document.addEventListener("mousemove",e),document.addEventListener("mousedown",n,{capture:!0}),document.addEventListener("click",r,{capture:!0}),i}}),[t,l,a]),r().createElement("path",{className:o()("connect-line",{connecting:!!t&&s&&(s[0]-t.from[0])**2+(s[1]-t.from[1])**2>25}),d:t&&s?"M".concat(t.from.join(" "),"L").concat(s.join(" ")):"",fill:"none",stroke:"gray",strokeWidth:1,markerEnd:"url(#".concat(i,")")})}},9068:(e,t,a)=>{a.r(t),a.d(t,{EoDrawCanvas:()=>nt,EoDrawCanvasComponent:()=>dt});var n,r,i,o,l,s,d,c,u,h,v,f,g,p,w,m,y,k,C,x,b,A,N,E,z,M,W,R,T,S,L,B,D,P,H,j,O,I,U,_,K,V,Y,F,X,q,J,Z,G,Q,$,ee,te,ae,ne,re,ie,oe,le,se,de,ce,ue,he,ve,fe,ge,pe=a(4223),we=a(9740),me=a(6330),ye=a(4635),ke=a(918),Ce=a(1369),xe=a(8449),be=a(4521),Ae=a(8769),Ne=a.n(Ae),Ee=a(9929),ze=a(9938),Me=a(8438),We=(a(330),a(1030)),Re=a(3373),Te=a.n(Re),Se=a(7566),Le=a(5748),Be=a(3739),De=a(531),Pe=a(8185),He=a(5114),je=a(2830),Oe=a(3639),Ie=a(3783),Ue=a(2098),_e=a(227),Ke=a(3033),Ve=a(8091),Ye=a(1819),Fe=a(7099),Xe=a(2361),qe=a(8197),Je=a(7531),Ze=a(3012),Ge=a(8618),Qe=["shouldReCenter"];function $e(e,t,a){return a(at(e,t))}function et(e,t,a){return e.set(at(e,t),a),a}function tt(e,t){return e.get(at(e,t))}function at(e,t,a){if("function"==typeof e?e===t:e.has(t))return arguments.length<3?t:a;throw new TypeError("Private element is not present on this object")}var nt,rt=(0,Me.unwrapProvider)("basic.lock-body-scroll"),{defineElement:it,property:ot,method:lt,event:st}=(0,Ee.createDecorators)(),dt=Ne().forwardRef(Yt),ct=new WeakMap,ut=new WeakMap,ht=new WeakMap,vt=new WeakMap,ft=new WeakMap,gt=new WeakMap,pt=new WeakMap,wt=new WeakMap,mt=new WeakMap,yt=new WeakMap,kt=new WeakMap,Ct=new WeakMap,xt=new WeakMap,bt=new WeakMap,At=new WeakMap,Nt=new WeakSet,Et=new WeakMap,zt=new WeakMap,Mt=new WeakMap,Wt=new WeakMap,Rt=new WeakMap,Tt=new WeakMap,St=new WeakMap,Lt=new WeakMap,Bt=new WeakMap,Dt=new WeakMap,Pt=new WeakMap,Ht=new WeakMap,jt=new WeakMap,Ot=new WeakMap,It=new WeakMap,Ut=new WeakMap,_t=new WeakMap;class Kt extends ze.ReactNextElement{constructor(){super(...arguments),(0,ye.A)(this,Nt),(0,ke.A)(this,ct,(n(this),i(this))),(0,ke.A)(this,ut,(o(this),l(this))),(0,ke.A)(this,ht,(s(this),d(this))),(0,ke.A)(this,vt,(c(this),u(this,[Ke.HP,Ke.HP]))),(0,ke.A)(this,ft,(h(this),v(this))),(0,ke.A)(this,gt,(f(this),g(this))),(0,ke.A)(this,pt,(p(this),w(this))),(0,ke.A)(this,wt,(m(this),y(this))),(0,ke.A)(this,mt,(k(this),C(this))),(0,ke.A)(this,yt,(x(this),b(this))),(0,ke.A)(this,kt,(A(this),N(this,!0))),(0,ke.A)(this,Ct,(E(this),z(this,!0))),(0,ke.A)(this,xt,(M(this),W(this,!0))),(0,ke.A)(this,bt,(R(this),T(this))),(0,ke.A)(this,At,(S(this),L(this))),(0,ke.A)(this,Et,(P(this),e=>{$e(Nt,this,B).emit(e)})),(0,ke.A)(this,zt,(e=>{(0,Pe.c)(e,this.activeTarget)||(this.activeTarget=e)})),(0,ke.A)(this,Mt,H(this)),(0,ke.A)(this,Wt,(I(this),U(this))),(0,ke.A)(this,Rt,(V(this),e=>{$e(Nt,this,_).emit(e),"node"===e.type&&$e(Nt,this,j).emit(e)})),(0,ke.A)(this,Tt,Y(this)),(0,ke.A)(this,St,(q(this),e=>{$e(Nt,this,F).emit(e)})),(0,ke.A)(this,Lt,J(this)),(0,ke.A)(this,Bt,(Q(this),$(this))),(0,ke.A)(this,Dt,(ae(this),e=>{$e(Nt,this,ee).emit(e),"node"===e.type&&$e(Nt,this,Z).emit(e)})),(0,ke.A)(this,Pt,ne(this)),(0,ke.A)(this,Ht,(oe(this),e=>{$e(Nt,this,re).emit(e)})),(0,ke.A)(this,jt,le(this)),(0,ke.A)(this,Ot,(ce(this),e=>{$e(Nt,this,se).emit(e)})),(0,ke.A)(this,It,ue(this)),(0,ke.A)(this,Ut,(fe(this),e=>{$e(Nt,this,he).emit(e)})),(0,ke.A)(this,_t,(0,Ae.createRef)())}get cells(){return tt(ct,this)}set cells(e){et(ct,this,e)}get layout(){return tt(ut,this)}set layout(e){et(ut,this,e)}get layoutOptions(){return tt(ht,this)}set layoutOptions(e){et(ht,this,e)}get defaultNodeSize(){return tt(vt,this)}set defaultNodeSize(e){et(vt,this,e)}get defaultNodeBricks(){return tt(ft,this)}set defaultNodeBricks(e){et(ft,this,e)}get degradedThreshold(){return tt(gt,this)}set degradedThreshold(e){et(gt,this,e)}get degradedNodeLabel(){return tt(pt,this)}set degradedNodeLabel(e){et(pt,this,e)}get defaultEdgeLines(){return tt(wt,this)}set defaultEdgeLines(e){et(wt,this,e)}get activeTarget(){return tt(mt,this)}set activeTarget(e){et(mt,this,e)}get fadeUnrelatedCells(){return tt(yt,this)}set fadeUnrelatedCells(e){et(yt,this,e)}get zoomable(){return tt(kt,this)}set zoomable(e){et(kt,this,e)}get scrollable(){return tt(Ct,this)}set scrollable(e){et(Ct,this,e)}get pannable(){return tt(xt,this)}set pannable(e){et(xt,this,e)}get scaleRange(){return tt(bt,this)}set scaleRange(e){et(bt,this,e)}dropNode(e){var t=this;return(0,me.A)((function*(){var a,n,{id:r,position:i,size:o,data:l,useBrick:s}=e;if(null===(a=(n=document).elementsFromPoint)||void 0===a||null===(a=a.call(n,i[0],i[1]))||void 0===a?void 0:a.includes(t)){var d,c,u,h=t.getBoundingClientRect(),v=tt(_t,t).current.getTransform(),f={type:"node",id:r,view:(0,we.A)((0,we.A)({},"force"===t.layout||"dagre"===t.layout?null:{x:(i[0]-h.left-v.x)/v.k,y:(i[1]-h.top-v.y)/v.k}),{},{width:null!==(d=null==o?void 0:o[0])&&void 0!==d?d:t.defaultNodeSize[0],height:null!==(c=null==o?void 0:o[1])&&void 0!==c?c:t.defaultNodeSize[0]}),data:l,useBrick:s};return null===(u=tt(_t,t).current)||void 0===u||u.dropNode(f),f}return null}))()}dropDecorator(e){var t=this;return(0,me.A)((function*(){var a,n,{position:r,decorator:i,text:o}=e;if(null===(a=(n=document).elementsFromPoint)||void 0===a||null===(a=a.call(n,r[0],r[1]))||void 0===a?void 0:a.includes(t)){var l,s=t.getBoundingClientRect(),d=tt(_t,t).current.getTransform(),c={type:"decorator",decorator:i,id:"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g,(function(e){var t=16*Math.random()|0;return("x"==e?t:3&t|8).toString(16)})),view:{x:(r[0]-s.left-d.x)/d.k,y:(r[1]-s.top-d.y)/d.k,width:Ke.N8,height:Ke.w1,text:o}};return null===(l=tt(_t,t).current)||void 0===l||l.dropDecorator(c),c}return null}))()}addNodes(e){var t=this;return(0,me.A)((function*(){if(0===e.length)return[];var a=e.map((e=>{var a,n,{size:r,useBrick:i,id:o,data:l}=e;return{type:"node",id:o,data:l,view:{width:null!==(a=null==r?void 0:r[0])&&void 0!==a?a:t.defaultNodeSize[0],height:null!==(n=null==r?void 0:r[1])&&void 0!==n?n:t.defaultNodeSize[0]},useBrick:i}}));return tt(_t,t).current.addNodes(a,{defaultNodeSize:t.defaultNodeSize,canvasWidth:t.clientWidth,canvasHeight:t.clientHeight})}))()}addEdge(e){var t=this;return(0,me.A)((function*(){var a,{source:n,target:r,data:i}=e,o={type:"edge",source:n,target:r,data:i};return null===(a=tt(_t,t).current)||void 0===a||a.addEdge(o),o}))()}manuallyConnectNodes(e){return tt(_t,this).current.manuallyConnectNodes(e)}updateCells(e,t){var a=this;return(0,me.A)((function*(){yield at(Nt,a,Vt).call(a);var{updated:n}=tt(_t,a).current.updateCells(e,(0,we.A)((0,we.A)({},t),{},{defaultNodeSize:a.defaultNodeSize,canvasWidth:a.clientWidth,canvasHeight:a.clientHeight}));return{updated:n}}))()}disconnectedCallback(){super.disconnectedCallback(),rt(this,!1)}render(){return Ne().createElement(dt,{host:this,ref:tt(_t,this),layout:this.layout,layoutOptions:this.layoutOptions,cells:this.cells,defaultNodeSize:this.defaultNodeSize,defaultNodeBricks:this.defaultNodeBricks,defaultEdgeLines:this.defaultEdgeLines,degradedThreshold:this.degradedThreshold,degradedNodeLabel:this.degradedNodeLabel,activeTarget:this.activeTarget,fadeUnrelatedCells:this.fadeUnrelatedCells,zoomable:this.zoomable,scrollable:this.scrollable,pannable:this.pannable,scaleRange:this.scaleRange,onActiveTargetChange:tt(Et,this),onSwitchActiveTarget:tt(zt,this),onCellMove:tt(Rt,this),onCellResize:tt(St,this),onCellDelete:tt(Dt,this),onCellContextMenu:tt(Ht,this),onDecoratorTextChange:tt(Ot,this),onScaleChange:tt(Ut,this)})}}function Vt(){return new Promise((e=>{var t=()=>{tt(_t,this).current?e():setTimeout(t,10)};t()}))}function Yt(e,t){var{host:a,layout:n,layoutOptions:r,cells:i,defaultNodeSize:o,defaultNodeBricks:l,defaultEdgeLines:s,degradedThreshold:d,degradedNodeLabel:c,activeTarget:u,fadeUnrelatedCells:h,zoomable:v,scrollable:f,pannable:g,scaleRange:p,onActiveTargetChange:w,onSwitchActiveTarget:m,onCellMove:y,onCellResize:k,onCellDelete:C,onCellContextMenu:x,onDecoratorTextChange:b,onScaleChange:A}=e,[{cells:N,layoutKey:E},z]=(0,Ae.useReducer)(Le.d,i,(e=>({cells:(0,Ie.C)(e,{defaultNodeSize:o}),layoutKey:0}))),M=(0,Ae.useMemo)((()=>N.filter(De.N).length>=(null!=d?d:Ke.pC)),[N,d]),W=(0,Ae.useRef)(null),R=(0,Ae.useRef)(null),T=(0,Ae.useRef)(null),[S,L]=(0,Ae.useState)([]),{grabbing:B,transform:D,zoomer:P,scaleRange:H}=(0,Ve.f)({rootRef:W,zoomable:v,scrollable:f,pannable:g,scaleRange:p,onSwitchActiveTarget:m});(0,Ae.useEffect)((()=>{A(D.k)}),[A,D.k]);var[j,O]=(0,Ae.useState)(null),{centered:I,setCentered:U,getNextLayoutKey:_}=(0,Xe.g)({layout:n,layoutOptions:r,rootRef:W,cells:N,zoomable:v,zoomer:P,scaleRange:H,layoutKey:E,dispatch:z});(0,Ae.useImperativeHandle)(t,(()=>({dropNode(e){U(!0),z({type:"drop-node",payload:e})},dropDecorator(e){U(!0),z({type:"drop-decorator",payload:e})},addNodes(e,t){var{defaultNodeSize:a,canvasWidth:r,canvasHeight:i}=t,o=N.findLastIndex((e=>!("decorator"===e.type&&"text"===e.decorator)))+1,l=[...N.slice(0,o),...e,...N.slice(o)],{cells:s,updated:d,shouldReCenter:c}=(0,Ue.L)({cells:l,layout:n,previousCells:N,defaultNodeSize:a,canvasWidth:r,canvasHeight:i,scaleRange:H,transform:D});return c&&U(!1),z({type:"update-cells",payload:s}),d.filter((t=>e.includes(t)))},addEdge(e){z({type:"add-edge",payload:e})},updateCells(e,t){var a=(0,Ue.L)((0,we.A)((0,we.A)({},t),{},{layout:n,previousCells:N,cells:e,scaleRange:H,transform:D})),{shouldReCenter:r}=a,i=(0,pe.A)(a,Qe);return r&&U(!1),z({type:"update-cells",payload:i.cells}),i},getTransform:()=>D,manuallyConnectNodes(e){var t=N.find((t=>(0,De.N)(t)&&t.id===e));if(t){var a=W.current.getBoundingClientRect();return O({source:t,from:[t.view.x+t.view.width/2,t.view.y+t.view.height/2],offset:[a.left,a.top]}),new Promise(((e,t)=>{T.current={resolve:e,reject:t}}))}return Promise.reject(null)}})),[N,n,H,U,D]);var K=(0,Ae.useCallback)(((e,t)=>{for(var a,n=0;n<N.length;n++){var r=N[n];if((0,De.N)(r)&&r.id!==e.source.id&&r.view.x<t[0]&&r.view.x+r.view.width>t[0]&&r.view.y<t[1]&&r.view.y+r.view.height>t[1]){var i;null===(i=T.current)||void 0===i||i.resolve({source:e.source,target:r});break}}null===(a=T.current)||void 0===a||a.reject(null),O(null)}),[N]);(0,Ae.useEffect)((()=>{rt(a,!!j)}),[j,a]);var V=(0,Ye.J)({cellsRef:R,activeTarget:u,onActiveTargetChange:w}),[Y,F]=(0,Ae.useState)([]);(0,Ae.useEffect)((()=>{var e=h?(0,_e.Y)(N,j,V):[];F((t=>0===t.length&&0===e.length?t:e))}),[V,N,j,h]),(0,Ae.useEffect)((()=>{var e=W.current;if(e&&!(S.length>0)){var t=e=>{var t=(0,He.a)(e,{cells:N,activeTarget:V});"delete-cell"===(null==t?void 0:t.action)&&C(t.cell)};return e.addEventListener("keydown",t),()=>{e.removeEventListener("keydown",t)}}}),[V,N,S.length,C]);var X=(0,Ae.useMemo)((()=>"".concat((0,We.uniqueId)("diagram-"),"-")),[]),q="".concat(X,"line-arrow-"),J=(0,Ae.useCallback)((e=>{z({type:"move-cell",payload:e})}),[]),Z=(0,Ae.useCallback)((e=>{z({type:"move-cell",payload:e}),y(e)}),[y]),G=(0,Ae.useCallback)((e=>{z({type:"resize-cell",payload:e})}),[]),Q=(0,Ae.useCallback)((e=>{z({type:"resize-cell",payload:e}),k(e)}),[k]),$=(0,Ae.useCallback)((e=>{var{id:t,editing:a}=e;L(a?e=>e.includes(t)?e:[...e,t]:e=>e.filter((e=>e!==t)))}),[]),ee=(0,Ae.useCallback)(((e,t)=>{var a=_();z({type:"update-node-size",payload:{id:e,size:t},layoutKey:a})}),[_]),te=(0,Ae.useCallback)((e=>{P.scaleTo((0,Se.A)(W.current),e/100)}),[P]),ae=(0,Ae.useCallback)((()=>{U(!1)}),[U]),[ne,re]=(0,Je.d)({cells:N,defaultEdgeLines:s,markerPrefix:q}),ie=(0,qe.H)({cells:N,layout:n,centered:I});return Ne().createElement(Ne().Fragment,null,Ne().createElement("svg",{width:"100%",height:"100%",ref:W,className:Te()("root",{grabbing:B,pannable:g,ready:ie}),tabIndex:-1},Ne().createElement("defs",null,re.map(((e,t)=>Ne().createElement(Be.c,{key:t,id:"".concat(q).concat(t),type:"arrow",strokeColor:e.strokeColor})))),Ne().createElement("g",{transform:"translate(".concat(D.x," ").concat(D.y,") scale(").concat(D.k,")")},Ne().createElement("g",{className:"cells",ref:R},N.map((e=>Ne().createElement(je.m,{key:"".concat(e.type,":").concat("edge"===e.type?"".concat(e.source,"~").concat(e.target):e.id),layout:n,cell:e,cells:N,degraded:M,degradedNodeLabel:c,defaultNodeBricks:l,transform:D,lineConfMap:ne,active:(0,Pe.c)(V,e),unrelatedCells:Y,onCellMoving:J,onCellMoved:Z,onCellResizing:G,onCellResized:Q,onSwitchActiveTarget:m,onCellContextMenu:x,onDecoratorTextChange:b,onDecoratorTextEditing:$,onNodeBrickResize:ee})))),Ne().createElement(Oe.w,{connectLineState:j,transform:D,markerEnd:"".concat(q,"0"),onConnect:K}))),Ne().createElement(Fe.Y,{shadowRoot:a.shadowRoot,scale:D.k,scaleRange:H,onZoomChange:te,onReCenter:ae}))}ge=Kt,({e:[i,o,l,s,d,c,u,h,v,f,g,p,w,m,y,k,C,x,b,A,N,E,z,M,W,R,T,S,L,B,D,P,H,j,O,I,U,_,K,V,Y,F,X,q,J,Z,G,Q,$,ee,te,ae,ne,re,ie,oe,le,se,de,ce,ue,he,ve,fe,n],c:[nt,r]}=function(e,t,a,n,r,i){var o,l,s,d,c,u,h,v=Symbol.metadata||Symbol.for("Symbol.metadata"),f=Object.defineProperty,g=Object.create,p=[g(null),g(null)],w=t.length;function m(t,a,n){return function(r,i){a&&(i=r,r=e);for(var o=0;o<t.length;o++)i=t[o].apply(r,n?[i]:[]);return n?i:r}}function y(e,t,a,n){if("function"!=typeof e&&(n||void 0!==e))throw new TypeError(t+" must "+(a||"be")+" a function"+(n?"":" or undefined"));return e}function k(e,t,a,n,r,i,s,d,c,u,h){function v(e){if(!h(e))throw new TypeError("Attempted to access private element on non-instance")}var g=[].concat(t[0]),w=t[3],k=!s,C=1===r,x=3===r,b=4===r,A=2===r;function N(t,a,n){return function(r,i){return a&&(i=r,r=e),n&&n(r),E[t].call(r,i)}}if(!k){var E={},z=[],M=x?"get":b||C?"set":"value";if(c?(u||C?E={get:(0,xe.A)((function(){return w(this)}),n,"get"),set:function(e){t[4](this,e)}}:E[M]=w,u||(0,xe.A)(E[M],n,A?"":M)):u||(E=Object.getOwnPropertyDescriptor(e,n)),!u&&!c){if((l=p[+d][n])&&7!=(l^r))throw new Error("Decorating two elements with the same name ("+E[M].name+") is not supported yet");p[+d][n]=r<3?1:r}}for(var W=e,R=g.length-1;R>=0;R-=a?2:1){var T=g[R],S=a?g[R-1]:void 0,L={},B={kind:["field","accessor","method","getter","setter","class"][r],name:n,metadata:o,addInitializer:function(e,t){if(e.v)throw new Error("attempted to call addInitializer after decoration was finished");y(t,"An initializer","be",!0),i.push(t)}.bind(null,L)};if(k)l=T.call(S,W,B),L.v=1,y(l,"class decorators","return")&&(W=l);else if(B.static=d,B.private=c,l=B.access={has:c?h.bind():function(e){return n in e}},b||(l.get=c?A?function(e){return v(e),E.value}:N("get",0,v):function(e){return e[n]}),A||x||(l.set=c?N("set",0,v):function(e,t){e[n]=t}),W=T.call(S,C?{get:E.get,set:E.set}:E[M],B),L.v=1,C){if("object"==typeof W&&W)(l=y(W.get,"accessor.get"))&&(E.get=l),(l=y(W.set,"accessor.set"))&&(E.set=l),(l=y(W.init,"accessor.init"))&&z.unshift(l);else if(void 0!==W)throw new TypeError("accessor decorators must return an object with get, set, or init properties or undefined")}else y(W,(u?"field":"method")+" decorators","return")&&(u?z.unshift(W):E[M]=W)}return r<2&&s.push(m(z,d,1),m(i,d,0)),u||k||(c?C?s.splice(-1,0,N("get",d),N("set",d)):s.push(A?E[M]:y.call.bind(E[M])):f(e,n,E)),W}function C(e){return f(e,v,{configurable:!0,enumerable:!0,value:o})}return void 0!==i&&(o=i[v]),o=g(null==o?null:o),c=[],u=function(e){e&&c.push(m(e))},(h=function(t,n){for(var i=0;i<a.length;i++){var o=a[i],l=o[1],u=7&l;if((8&l)==t&&!u==n){var h=o[2],v=!!o[3],f=16&l;k(t?e:e.prototype,o,f,v?"#"+h:(0,Ce.A)(h),u,u<2?[]:t?d=d||[]:s=s||[],c,!!t,v,n,t&&v?function(t){return(0,be.A)(t)===e}:r)}}})(8,0),h(0,0),h(8,1),h(0,1),u(s),u(d),l=c,w||C(e),{e:l,get c(){var a=[];return w&&[C(e=k(e,[t],0,e.name,5,a)),m(a,1)]}}}(ge,[it("eo-draw-canvas",{styleTexts:[Ze.A,Ge.A]})],[[ot({attribute:!1}),1,"cells"],[ot({type:String}),1,"layout"],[ot({attribute:!1}),1,"layoutOptions"],[ot({attribute:!1}),1,"defaultNodeSize"],[ot({attribute:!1}),1,"defaultNodeBricks"],[ot({type:Number}),1,"degradedThreshold"],[ot({attribute:!1}),1,"degradedNodeLabel"],[ot({attribute:!1}),1,"defaultEdgeLines"],[ot({attribute:!1}),1,"activeTarget"],[ot({type:Boolean}),1,"fadeUnrelatedCells"],[ot({type:Boolean}),1,"zoomable"],[ot({type:Boolean}),1,"scrollable"],[ot({type:Boolean}),1,"pannable"],[ot({attribute:!1}),1,"scaleRange"],[st({type:"activeTarget.change"}),1,"activeTargetChangeEvent",e=>tt(At,e),(e,t)=>et(At,e,t)],[st({type:"node.move"}),1,"nodeMoveEvent",e=>tt(Mt,e),(e,t)=>et(Mt,e,t)],[st({type:"cell.move"}),1,"cellMoveEvent",e=>tt(Wt,e),(e,t)=>et(Wt,e,t)],[st({type:"cell.resize"}),1,"cellResizeEvent",e=>tt(Tt,e),(e,t)=>et(Tt,e,t)],[st({type:"node.delete"}),1,"nodeDelete",e=>tt(Lt,e),(e,t)=>et(Lt,e,t)],[st({type:"cell.delete"}),1,"cellDelete",e=>tt(Bt,e),(e,t)=>et(Bt,e,t)],[st({type:"cell.contextmenu"}),1,"cellContextMenu",e=>tt(Pt,e),(e,t)=>et(Pt,e,t)],[st({type:"decorator.text.change"}),1,"decoratorTextChange",e=>tt(jt,e),(e,t)=>et(jt,e,t)],[st({type:"scale.change"}),1,"scaleChange",e=>tt(It,e),(e,t)=>et(It,e,t)],[lt(),2,"dropNode"],[lt(),2,"dropDecorator"],[lt(),2,"addNodes"],[lt(),2,"addEdge"],[lt(),2,"manuallyConnectNodes"],[lt(),2,"updateCells"]],0,(e=>_t.has((0,be.A)(e))),ze.ReactNextElement)),r()},5114:(e,t,a)=>{a.d(t,{a:()=>r});var n=a(8185);function r(e,t){var{cells:a,activeTarget:r}=t,i=a.find((e=>(0,n.c)(e,r)));if(i)switch(e.key||e.keyCode||e.which){case"Backspace":case 8:case"Delete":case 46:return e.preventDefault(),e.stopPropagation(),{action:"delete-cell",cell:i}}}},2098:(e,t,a)=>{a.d(t,{L:()=>c});var n=a(1030),r=a(3033),i=a(531),o=a(3783),l=a(908),s=a(6170),d=a(9127);function c(e){var{cells:t,layout:a,previousCells:c,defaultNodeSize:u,canvasWidth:h,canvasHeight:v,scaleRange:f,transform:g,reason:p,parent:w}=e,m="force"!==a&&"dagre"!==a,y=(0,o.C)(t,{defaultNodeSize:u}),k=[],C=!1,x=new Map,b=!1;for(var A of c)(0,i.mH)(A)?b=!0:(0,i.N)(A)&&(b=!0,A[r.CV]&&x.set(A.id,A));var N=new Map;for(var E of y)if((0,i.N)(E)){N.set(E.id,E);var z=x.get(E.id);z&&(E.view.width=z.view.width,E.view.height=z.view.height,E[r.CV]=!0)}var M=!1;if("add-related-nodes"===p&&w){var W=new Set;for(var R of y)(0,i.WW)(R)&&R.source===w&&R.target!==w&&W.add(R.target);var T=N.get(w);if(void 0!==(null==T?void 0:T.view.x)&&void 0!==T.view.y){M=!0;var S=[...W].map((e=>N.get(e))).filter(Boolean),L=void 0;for(var B of S)void 0!==B.view.x&&void 0!==B.view.y?(!L||B.view.x>L.view.x)&&B.view.y>T.view.y&&(L=B):k.push(B);if(k.length>0&&m){var D,P;if(L)D=L.view.x+L.view.width+r.sz,P=L.view.y;else{var H=k.reduce(((e,t)=>e+t.view.width+r.sz),-r.sz);D=T.view.x-H/2+T.view.width/2,P=T.view.y+T.view.height+r.sz}for(var j of k)j.view.x=D,j.view.y=P,D+=j.view.width+r.sz}}}if(!M){var O,I=u[0],U=u[1],_=0,K=!1;for(var V of y)(0,i.N)(V)?(V.view.width>I&&(I=V.view.width),V.view.height>U&&(U=V.view.height),void 0===V.view.x||void 0===V.view.y?k.push(V):_++):(0,i.mH)(V)&&(K=!0);if(m)for(var Y of(b||(g=(0,l.r)((0,n.without)(y,...k),{canvasWidth:h,canvasHeight:v,scaleRange:f})),0===_||1===_&&!K?(({getNodeView:O}=(0,d.C)({cells:y})),C=!0):({getNodeView:O}=(0,s.k)({cells:y,fixedPosition:!0,center:[(h/2-g.x)/g.k,(v/2-g.y)/g.k]})),y))if((0,i.N)(Y)){var F=O(Y.id);Y.view.x=F.x,Y.view.y=F.y}}return{cells:y,updated:k,shouldReCenter:C}}},6330:(e,t,a)=>{function n(e,t,a,n,r,i,o){try{var l=e[i](o),s=l.value}catch(e){return void a(e)}l.done?t(s):Promise.resolve(s).then(n,r)}function r(e){return function(){var t=this,a=arguments;return new Promise((function(r,i){var o=e.apply(t,a);function l(e){n(o,r,i,l,s,"next",e)}function s(e){n(o,r,i,l,s,"throw",e)}l(void 0)}))}}a.d(t,{A:()=>r})}}]);
2
+ //# sourceMappingURL=eo-draw-canvas.d92e78e9.js.map