@next-bricks/diagram 0.14.0 → 0.15.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (28) hide show
  1. package/dist/bricks.json +3 -3
  2. package/dist/chunks/{9380.8d833db1.js → 8020.7d347956.js} +2 -2
  3. package/dist/chunks/8020.7d347956.js.map +1 -0
  4. package/dist/chunks/8272.fcc84aba.js +2 -0
  5. package/dist/chunks/{8600.b65b9474.js.map → 8272.fcc84aba.js.map} +1 -1
  6. package/dist/chunks/eo-diagram.2b8615e9.js +2 -0
  7. package/dist/chunks/{eo-diagram.963f5707.js.map → eo-diagram.2b8615e9.js.map} +1 -1
  8. package/dist/chunks/eo-draw-canvas.0418a178.js +2 -0
  9. package/dist/chunks/eo-draw-canvas.0418a178.js.map +1 -0
  10. package/dist/chunks/{main.391405db.js → main.9d26f349.js} +2 -2
  11. package/dist/chunks/{main.391405db.js.map → main.9d26f349.js.map} +1 -1
  12. package/dist/examples.json +5 -5
  13. package/dist/{index.8e738324.js → index.fa106669.js} +2 -2
  14. package/dist/{index.8e738324.js.map → index.fa106669.js.map} +1 -1
  15. package/dist/manifest.json +94 -77
  16. package/dist/types.json +405 -130
  17. package/dist-types/diagram/lines/getDirectLinePoints.d.ts +2 -2
  18. package/dist-types/draw-canvas/index.d.ts +19 -4
  19. package/dist-types/draw-canvas/interfaces.d.ts +16 -10
  20. package/dist-types/draw-canvas/processors/asserts.d.ts +4 -0
  21. package/dist-types/draw-canvas/reducers/interfaces.d.ts +5 -5
  22. package/docs/eo-draw-canvas.md +56 -18
  23. package/package.json +2 -2
  24. package/dist/chunks/8600.b65b9474.js +0 -2
  25. package/dist/chunks/9380.8d833db1.js.map +0 -1
  26. package/dist/chunks/eo-diagram.963f5707.js +0 -2
  27. package/dist/chunks/eo-draw-canvas.89c9e4a0.js +0 -2
  28. package/dist/chunks/eo-draw-canvas.89c9e4a0.js.map +0 -1
package/dist/bricks.json CHANGED
@@ -5,10 +5,10 @@
5
5
  "diagram.experimental-node"
6
6
  ],
7
7
  "elements": [
8
- "eo-draw-canvas",
9
- "eo-diagram"
8
+ "eo-diagram",
9
+ "eo-draw-canvas"
10
10
  ],
11
11
  "processors": [],
12
12
  "dependencies": {},
13
- "filePath": "bricks/diagram/dist/index.8e738324.js"
13
+ "filePath": "bricks/diagram/dist/index.fa106669.js"
14
14
  }
@@ -1,2 +1,2 @@
1
- "use strict";(self.webpackChunk_next_bricks_diagram=self.webpackChunk_next_bricks_diagram||[]).push([[9380],{3784:(e,t,n)=>{n.d(t,{E:()=>d});var a=n(5600),r=n.n(a),i=n(1252),o=n.n(i),l=n(8752);function d(e){var{connectLineState:t,connectLineTo:n,markerPrefix:a}=e;return r().createElement("svg",{width:"100%",height:"100%",className:o()("connect-line",{connecting:!!t&&(n[0]-t.from[0])**2+(n[1]-t.from[1])**2>25})},r().createElement("defs",null,r().createElement(l.y,{type:"arrow",id:"".concat(a,"connect-line"),strokeColor:null==t?void 0:t.options.strokeColor})),r().createElement("path",{d:t?"M".concat(t.from.join(" "),"L").concat(n.join(" ")):"",fill:"none",stroke:null==t?void 0:t.options.strokeColor,strokeWidth:null==t?void 0:t.options.strokeWidth,markerEnd:null!=t&&t.options.arrow?"url(#".concat(a,"connect-line)"):void 0}))}},2092:(e,t,n)=>{n.d(t,{k:()=>d});var a=n(4412),r=n(5600),i=n.n(r),o=n(1252),l=n.n(o);function d(e){var t,n,r,o,{line:{line:d,edge:c,d:s,markers:u},linePaths:f,lineMaskRects:v,maskPrefix:h,markerPrefix:p,activeLineMarkerPrefix:m,active:g,activeRelated:y,onLineClick:k,onLineDoubleClick:b}=e,x=v.has(d.$id)?"url(#".concat(h).concat(d.$id,")"):void 0,{strokeColor:w,strokeWidth:M,interactStrokeWidth:E}=(0,a.c)((0,a.c)({},d),g?null===(t=d.overrides)||void 0===t?void 0:t.active:y?null===(n=d.overrides)||void 0===n?void 0:n.activeRelated:null),L=g?"active":y?"active-related":"default";for(var R of u)R.variant===L&&("start"===R.placement?r="url(#".concat(p).concat(R.index,")"):o="url(#".concat(p).concat(R.index,")"));return i().createElement("g",{className:l()("line",{interactable:d.interactable,active:g,"active-related":y}),onClick:d.interactable?()=>{null==k||k({id:d.$id,edge:c})}:void 0,onDoubleClick:d.interactable?e=>{e.preventDefault(),e.stopPropagation(),null==b||b({id:d.$id,edge:c})}:void 0,style:{cursor:d.cursor}},d.interactable&&i().createElement("path",{d:s,fill:"none",stroke:"transparent",strokeWidth:E}),i().createElement("path",{ref:e=>f.set(d.$id,e),stroke:w,strokeWidth:M,d:s,fill:"none",markerStart:r,markerEnd:o,mask:x}),i().createElement("path",{stroke:"var(--palette-blue-3)",strokeWidth:M,d:s,fill:"none",className:"active-bg",markerStart:"url(#".concat(m,"start)"),markerEnd:"url(#".concat(m,"end)"),mask:x}))}},8276:(e,t,n)=>{n.d(t,{Ar:()=>l});var a=n(5600),r=n.n(a),i=n(6196),o=n(6960);function l(e){var{labels:t,onRendered:n}=e,[i,o]=(0,a.useState)(!1),[l,s]=(0,a.useState)([]),u=(0,a.useMemo)((()=>new Map),[]),f=(0,a.useCallback)(((e,t)=>{t&&u.set(e,t),s((t=>t.includes(e)?t:t.concat(e)))}),[u]),v=(0,a.useCallback)((e=>{s((t=>{var n=t.indexOf(e);return-1===n?t:t.slice(0,n).concat(t.slice(n+1))})),u.delete(e)}),[u]);return(0,a.useEffect)((()=>{o(!(null!=t&&t.some((e=>!l.includes(e.id)))))}),[t,l]),(0,a.useEffect)((()=>{null==n||n(i?u:null)}),[u,i]),r().createElement(r().Fragment,null,null==t?void 0:t.map((e=>{var{text:t,label:n,id:a,edge:i}=e;return n?r().createElement("div",{key:a,className:"line-label"},r().createElement(c,{id:a,edge:i,label:n,onRendered:f,onUnmount:v})):r().createElement(d,{key:a,id:a,text:t,onRendered:f})})))}function d(e){var{id:t,text:n,onRendered:i}=e,o=(0,a.useCallback)((e=>{null==i||i(t,e)}),[t,i]);return r().createElement("div",{className:"line-label",ref:o,style:n.style},n.content)}function c(e){var{id:t,edge:n,label:l,onRendered:d,onUnmount:c}=e,s=(0,a.useMemo)((()=>(0,o.checkIfByTransform)(l,{edge:n})?l.useBrick:null),[n,l]),u=(0,a.useMemo)((()=>({edge:n})),[n]);(0,a.useEffect)((()=>{s||setTimeout((()=>{null==d||d(t,null)}))}),[t,d,s]),(0,a.useEffect)((()=>()=>{null==c||c(t)}),[]);var f=(0,a.useCallback)((e=>{e&&setTimeout((()=>{null==d||d(t,e.parentElement)}))}),[t,d]),v=(0,a.useCallback)((()=>{setTimeout((()=>{null==d||d(t,null)}))}),[t,d]);return s?r().createElement(i.ReactUseBrick,{refCallback:f,ignoredCallback:v,useBrick:s,data:u}):null}},4092:(e,t,n)=>{n.d(t,{g:()=>i});var a=n(5600),r=n.n(a);function i(e){var{lineId:t,rects:n,maskPrefix:a,renderedLineLabels:i}=e,o=i.find((e=>e.lineId===t&&"center"===e.placement));if(!o)return null;var l,d,{lineRect:c}=o,s=(d=1e3,{left:(l=c).left-d,top:l.top-d,width:l.width+2e3,height:l.height+2e3});return r().createElement("mask",{id:"".concat(a).concat(t),x:s.left,y:s.top,width:s.width,height:s.height},r().createElement("rect",{x:s.left,y:s.top,width:s.width,height:s.height,fill:"white"}),n.map(((e,t)=>r().createElement("rect",{key:t,x:e.left,y:e.top,width:e.width,height:e.height,fill:"black"}))))}},8752:(e,t,n)=>{n.d(t,{y:()=>i});var a=n(5600),r=n.n(a);function i(e){var t,{id:n,type:a,strokeColor:i}=e;switch(a){case"0..1":t=l;break;case"0..N":t=d;break;default:t=o}return r().createElement(t,{id:n,strokeColor:i})}function o(e){var{id:t,strokeColor:n}=e;return r().createElement("marker",{id:t,viewBox:"0 0 6 6",refX:5,refY:3,markerWidth:6,markerHeight:6,orient:"auto-start-reverse",strokeLinejoin:"round"},r().createElement("path",{d:"M 0.5 0.5 L 5.5 3 L 0.5 5.5 z",stroke:n,strokeWidth:1,fill:n}))}function l(e){var{id:t,strokeColor:n}=e;return r().createElement("marker",{id:t,viewBox:"0 0 21 11",refX:.5,refY:5.5,markerWidth:21,markerHeight:11,orient:"auto-start-reverse"},r().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:n,strokeWidth:1,fill:"none"}))}function d(e){var{id:t,strokeColor:n}=e;return r().createElement("marker",{id:t,viewBox:"0 0 21 11",refX:.5,refY:5.5,markerWidth:21,markerHeight:11,orient:"auto-start-reverse"},r().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:n,strokeWidth:1,fill:"none"}))}},8996:(e,t,n)=>{n.d(t,{_:()=>l});var a=n(5600),r=n.n(a),i=n(6196),o=n(6960);function l(e){var{nodes:t,nodeBricks:n,onRendered:i}=e,[o,l]=(0,a.useState)(!1),[c,s]=(0,a.useState)([]),u=(0,a.useMemo)((()=>new Map),[]),f=(0,a.useCallback)(((e,t)=>{t&&u.set(e,t),s((t=>t.includes(e)?t:t.concat(e)))}),[u]),v=(0,a.useCallback)((e=>{s((t=>{var n=t.indexOf(e);return-1===n?t:t.slice(0,n).concat(t.slice(n+1))})),u.delete(e)}),[u]);return(0,a.useEffect)((()=>{l(!(null!=t&&t.some((e=>!c.includes(e.id)))))}),[t,c]),(0,a.useEffect)((()=>{null==i||i(o?u:null)}),[u,o]),r().createElement(r().Fragment,null,null==t?void 0:t.map((e=>r().createElement("div",{key:e.id,className:"node"},r().createElement(d,{nodeBricks:n,node:e,onRendered:f,onUnmount:v})))))}function d(e){var{node:t,nodeBricks:n,onRendered:l,onUnmount:d}=e,c=(0,a.useMemo)((()=>{var e;return null===(e=function(e,t){return null==t?void 0:t.find((t=>t.nodeType?[].concat(t.nodeType).includes(e.type):(0,o.checkIfByTransform)(t,{node:e})))}(t,n))||void 0===e?void 0:e.useBrick}),[t,n]),s=(0,a.useMemo)((()=>({node:t})),[t]);(0,a.useEffect)((()=>{c||setTimeout((()=>{null==l||l(t.id,null)}))}),[t.id,l,c]),(0,a.useEffect)((()=>()=>{null==d||d(t.id)}),[]);var u=(0,a.useCallback)((e=>{e&&setTimeout((()=>{null==l||l(t.id,e)}))}),[t.id,l]),f=(0,a.useCallback)((()=>{setTimeout((()=>{null==l||l(t.id,null)}))}),[t.id,l]);return c?r().createElement(i.ReactUseBrick,{refCallback:u,ignoredCallback:f,useBrick:c,data:s}):null}},6932:(e,t,n)=>{n.d(t,{Go:()=>o,Ij:()=>r,NN:()=>i,Oi:()=>d,WH:()=>l,es:()=>a});var a="var(--palette-gray-5)",r=1,i="curveBasis",o=20,l=.5,d=2},4580:(e,t,n)=>{n.d(t,{C:()=>w});var a=n(5600),r=n(4412),i=n(640),o=n(228),l=n.n(o),d=n(7568);function c(e,t,n){for(var a of e){var r,i,o=t.get(a.id);a.width=Math.max(null!==(r=null==o?void 0:o.offsetWidth)&&void 0!==r?r:0,10)+n[1]+n[3],a.height=Math.max(null!==(i=null==o?void 0:o.offsetHeight)&&void 0!==i?i:0,10)+n[0]+n[2]}}function s(e,t,n){for(var a of e){var r,i=a.x-a.width/2+n[3],o=a.y-a.height/2+n[0],l=null===(r=t.get(a.id))||void 0===r?void 0:r.parentElement;l&&(l.style.left="".concat(i,"px"),l.style.top="".concat(o,"px"),l.style.visibility="visible")}}function u(e){if(Array.isArray(e)){var t=e[0],n=e.length>1?e[1]:t;return[t,n,e.length>2?e[2]:t,e.length>3?e[3]:n]}return new Array(4).fill(e)}var f=["nodePadding"],v=n(1108),h=n(9472),p=n(7339),m=n(5336),g=n(9388),y=n(5064);function k(e,t){var n,{normalizedLinesMap:a,lineLabelsRefRepository:r}=t;return null!==(n=null==e?void 0:e.map((e=>{var t=a.get(e),n={};if(t)for(var i of["start","end"]){var o=r.get("".concat(t,"-").concat(i));o&&(n[i]=[o.offsetWidth,o.offsetHeight])}return{data:e,labelSize:n}})))&&void 0!==n?n:[]}function b(e,t){return new Array(t).fill(null).map(((t,n)=>({dummy:!0,id:"$dummy-".concat(e.source,"-").concat(e.target,"-").concat(n)})))}function x(e,t){return new Array(t+1).fill(null).map(((n,a)=>({dummy:!0,source:0===a?e.source:"$dummy-".concat(e.source,"-").concat(e.target,"-").concat(a-1),target:a===t?e.target:"$dummy-".concat(e.source,"-").concat(e.target,"-").concat(a)})))}function w(e){var{layout:t,nodes:n,edges:o,manualLayoutStatus:w,userViewReady:M,userViewNodesMap:E,nodeMovement:L,nodesRefRepository:R,lineLabelsRefRepository:C,normalizedLinesMap:P,nodesRenderId:I,lineLabelsRenderId:N,layoutOptions:S}=e,B="initial"===w?t:"manual",[T,W]=(0,a.useState)(null),[z,A]=(0,a.useState)({nodes:[],edges:[]});return(0,a.useEffect)((()=>{M&&W((e=>"dagre"===B?function(e,t,n,a){var o=(0,r.c)({nodePadding:0,rankdir:"TB",ranksep:50,edgesep:10,nodesep:50},(0,d.pick)(a,["nodePadding","rankdir","ranksep","edgesep","nodesep","align"])),{nodePadding:v}=o,h=(0,i.c)(o,f),p=u(v),m=new(l().graphlib.Graph);for(var g of(m.setGraph(h),m.setDefaultEdgeLabel((function(){return{}})),null!=t?t:[])){var y=null==e?void 0:e.getNode(g.id);m.setNode(g.id,(null==y?void 0:y.data)===g?y:{id:g.id,data:g})}for(var k of null!=n?n:[])m.setEdge(k.source,k.target,{data:k});return{layout:"dagre",getNode:e=>m.node(e),applyLayout(e){var{nodesRefRepository:t,lineLabelsRefRepository:n,normalizedLinesMap:a}=e,r=[];for(var i of m.nodes()){var o=m.node(i);o?r.push(o):console.error("Diagram node not found: %s",i)}if(0===r.length)return null;c(r,t,p);var d=m.edges().map((e=>m.edge(e)));for(var u of d){var f=a.get(u.data);if(f)for(var v of["center","start","end"]){var h=n.get("".concat(f,"-").concat(v));if(h){var g,{offsetWidth:y,offsetHeight:k}=h;"center"===v&&(u.labelpos="c",u.width=y,u.height=k),null!==(g=u.labelSize)&&void 0!==g||(u.labelSize={}),u.labelSize[v]=[y,k]}}}return l().layout(m),s(r,t,p),{nodes:r,edges:d}}}}(e,n,o,S):"force"===B?function(e,t,n,a,i){var{nodePadding:o,dummyNodesOnEdges:l,collide:f}=(0,r.c)((0,r.c)({nodePadding:0,dummyNodesOnEdges:0},(0,d.pick)(i,["nodePadding","dummyNodesOnEdges"])),{},{collide:!1!==(null==i?void 0:i.collide)&&(0,r.c)({dummyRadius:1,radiusDiff:5,strength:1,iterations:1},!0===(null==i?void 0:i.collide)?null:null==i?void 0:i.collide)}),w=u(o),M=[];for(var E of null!=t?t:[]){var L=null==e?void 0:e.getNode(E.id);if((null==L?void 0:L.data)===E)M.push(L);else{var R={id:E.id,data:E},C=null==a?void 0:a.get(E.id);C&&(R.fx=C.x,R.fy=C.y),M.push(R)}}return{layout:"force",getNode:function(e){return M.find((t=>t.data.id===e))},applyLayout(e){var{nodesRefRepository:t,lineLabelsRefRepository:a,normalizedLinesMap:i}=e;if(0===M.length)return null;c(M,t,w);var o=M.slice(),d=[];for(var u of null!=n?n:[])d.push((0,r.c)({},u)),l>0&&(o.push(...b(u,l)),d.push(...x(u,l)));var E=(0,v.c)(d).id((e=>e.id));l>0&&E.distance((e=>e.dummy?30/(l+1):30)).strength((e=>e.dummy?.5:1));var L=(0,h.c)(o).force("link",E).force("x",(0,p.c)()).force("y",(0,m.c)()).force("charge",(0,g.c)());f&&L.force("collide",(0,y.c)().radius((e=>e.dummy?f.dummyRadius:Math.sqrt(e.width**2+e.height**2)/2+f.radiusDiff)).strength(f.strength).iterations(f.iterations)),L.stop(),function(e){e.tick(Math.ceil(Math.log(e.alphaMin())/Math.log(1-e.alphaDecay())))}(L),s(M,t,w);var R=k(n,{normalizedLinesMap:i,lineLabelsRefRepository:a});return{nodes:M,edges:R}}}}(e,n,o,E,S):"manual"===B?function(e,t,n,a){var i,{nodePadding:o}=(0,r.c)({nodePadding:0},(0,d.pick)(a,["nodePadding"])),l=u(o),f=[];for(var v of null!=t?t:[]){var h=null==e?void 0:e.getNode(v.id);(null==h?void 0:h.data)===v?(f.push(h),h.x0=h.x,h.y0=h.y):f.push({id:v.id,data:v})}return{layout:"manual",getNode:function(e){return f.find((t=>t.data.id===e))},applyLayout(e){var t,a,{manualLayoutStatus:r,nodesRefRepository:o,lineLabelsRefRepository:d,normalizedLinesMap:u,nodeMovement:v}=e;if(0===f.length)return null;c(f,o,l),v&&(i=f.find((e=>e.id===v.id)),i&&(i.x=(null!==(t=i.x0)&&void 0!==t?t:0)+v.move[0],i.y=(null!==(a=i.y0)&&void 0!==a?a:0)+v.move[1])),"finished"===r&&i&&(i.x0=i.x,i.y0=i.y),s(f,o,l);var h=k(n,{normalizedLinesMap:u,lineLabelsRefRepository:d});return{nodes:f,edges:h}}}}(e,n,o,S):null))}),[o,n,B,S,M,E]),(0,a.useEffect)((()=>{if(R&&C&&B===(null==T?void 0:T.layout)){var e=null==T?void 0:T.applyLayout({manualLayoutStatus:w,nodesRefRepository:R,lineLabelsRefRepository:C,normalizedLinesMap:P,nodeMovement:L});e&&A(e)}}),[B,w,T,L,R,C,I,N,P]),z}},3888:(e,t,n)=>{n.d(t,{y:()=>s});var a=n(8944),r=n(5600),i=n(6960),o=n(6851),l=n(236),d=n(5996),c="GRAPH_USER_VIEW@EASYOPS";function s(e){var[t,n]=(0,r.useState)(!e),s=(0,r.useRef)(),[u,f]=(0,r.useState)(null),v=(0,r.useMemo)((()=>{return e=!1,t=[],function(){var n=(0,a.c)((function*(n){if(t.push(n),!e){var a;for(e=!0;a=t.shift();)try{yield a()}catch(e){console.error(e)}e=!1}}));return function(e){return n.apply(this,arguments)}}();var e,t}),[]);return(0,r.useEffect)((()=>{function t(){return(t=(0,a.c)((function*(){if(e){var{namespace:t,key:a}=e;if(!t||!a)return console.error("Namespace and key are required to save graph user view"),void n(!0);try{var r=(yield(0,o.c)(c,{fields:["nodes"],query:{namespace:{$eq:t},key:{$eq:a}},page:1,page_size:30})).list;if(r.length>0){var l,d=r[0],u=new Map(null===(l=d.nodes)||void 0===l?void 0:l.map((e=>[e.id,e])));s.current=d.instanceId,f(u)}else f(null)}catch(e){(0,i.handleHttpError)(e)}finally{n(!0)}}else n(!0)}))).apply(this,arguments)}!function(){t.apply(this,arguments)}()}),[e]),{userViewReady:t,userViewNodesMap:u,saveUserView:(0,r.useCallback)((t=>{var{namespace:n,key:r}=null!=e?e:{};n&&r&&v((0,a.c)((function*(){var e={namespace:n,key:r,nodes:t};try{if(s.current)yield(0,l.Y)(c,s.current,e,{interceptorParams:{ignoreLoadingBar:!0}});else{var a=yield(0,d.A)(c,e,{interceptorParams:{ignoreLoadingBar:!0}});s.current=a.instanceId}}catch(e){(0,i.handleHttpError)(e)}})))}),[e,v])}}},9900:(e,t,n)=>{function a(e,t){for(var{id:n,position:a,placement:r,angle:i,size:o}of e){var l=t.get(n);if(l&&(l.style.left="".concat(a[0],"px"),l.style.top="".concat(a[1],"px"),l.style.visibility="visible","center"!==r&&void 0!==i)){var[d,c]=null!=o?o:[0,0],s=Math.floor((i<0?2*Math.PI+i:i)/Math.PI*4),u="start"===r?s:(s+4)%8,f=Math.tan(i),v=i+("start"===r?1:-1)*Math.PI/2,h=2*Math.sin(v),p=2*Math.cos(v),m=void 0;switch(u){case 0:m="translate(0,".concat(d*f+h,"px)");break;case 1:m="translate(".concat(c/f-p,"px,0)");break;case 2:m="translate(calc(".concat(c/f+p,"px - 100%),0)");break;case 3:m="translate(-100%,".concat(-d*f-h,"px)");break;case 4:m="translate(-100%,calc(".concat(-d*f+h,"px - 100%))");break;case 5:m="translate(calc(".concat(-c/f-p,"px - 100%),-100%)");break;case 6:m="translate(".concat(-c/f+p,"px,-100%)");break;default:m="translate(0,calc(".concat(d*f-h,"px - 100%))")}l.style.transform=m}}}n.d(t,{c:()=>a})},3256:(e,t,n)=>{function a(e,t){var n=new Map;for(var{id:a,lineId:r,placement:i}of e)if(t&&"center"===i){var o=t.get(a);if(o){var{offsetWidth:l,offsetHeight:d}=o;0!==l&&0!==d&&n.set(r,[{left:o.offsetLeft-l/2-3,top:o.offsetTop-d/2-3,width:l+6,height:d+6}])}}return n}n.d(t,{E:()=>a})},3732:(e,t,n)=>{function a(e,t,n){return 0===e.length&&0===t.length?e:t.flatMap((e=>{var t,a,{line:{text:r,label:i,$id:o},edge:l,labelSize:d,angle:c}=e,s=n.get(o);if(!r&&!i||!s||!s.getAttribute("d"))return[];i?(t="label",a=[].concat(i)):(t="text",a=[].concat(r));var{x:u,y:f,width:v,height:h}=s.getBBox(),p=s.getTotalLength();return a.map((e=>{var n,a=null!==(n=e.placement)&&void 0!==n?n:"center",r=s.getPointAtLength("start"===a?Math.min(0,p/2):"end"===a?Math.max(p-0,p/2):p/2);return{[t]:e,edge:l,position:[r.x,r.y],lineRect:{left:u,top:f,width:v,height:h},id:"".concat(o,"-").concat(a),lineId:o,placement:a,angle:c,size:null==d?void 0:d[a]}}))}))}n.d(t,{c:()=>a})},108:(e,t,n)=>{n.d(t,{e:()=>g});var a=n(4412),r=n(640),i=n(3584),o=n(2128),l=n(5416),d=n(4348),c=n(2760),s=n(1260);function u(e,t,n,a){if(!Array.isArray(e))return"";var r;switch(t){case"curveLinear":r=i.c;break;case"curveBumpX":r=o.KQ;break;case"curveBumpY":r=o.yM;break;case"curveMonotoneX":r=l.O;break;case"curveMonotoneY":r=l.o;break;case"curveNatural":r=d.c;break;default:r=c.cp}var u=f(e[1],e[0],n),v=f(e[e.length-2],e[e.length-1],a);return(0,s.c)().x(((t,n)=>t.x-(0===n?u.x:n===e.length-1?v.x:0))).y(((t,n)=>t.y-(0===n?u.y:n===e.length-1?v.y:0))).curve(r)(e)}function f(e,t,n){if(!n)return{x:0,y:0};var{x:a,y:r}=e,{x:i,y:o}=t,l=n/Math.sqrt(Math.pow(i-a,2)+Math.pow(o-r,2));return{x:(i-a)*l,y:(o-r)*l}}function v(e,t,n,a){var r=n?h(e,n):e,i=a?h(t,a):t,o=Math.min(r.x-r.width/2,i.x-i.width/2),l=Math.max(r.x+r.width/2,i.x+i.width/2),d=Math.min(r.y-r.height/2,i.y-i.height/2),c=Math.max(r.y+r.height/2,i.y+i.height/2);return l-o<r.width+i.width&&c-d<r.height+i.height}function h(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}}function p(e,t,n){var{x:a,y:r,width:i,height:o}=e;switch(t){case"top":return{x:a-i/2+i*n,y:r-o/2};case"bottom":return{x:a-i/2+i*n,y:r+o/2};case"left":return{x:a-i/2,y:r-o/2+o*n};case"right":return{x:a+i/2,y:r-o/2+o*n}}}var m=["line","edge","markers"];function g(e,t,n){var i=new WeakMap,o=new Map,l=new Map;for(var d of t)o.set(d.id,d);for(var c of e){var{data:s}=c;i.set(s,c)}var f=!1;return n.map((t=>{var n,d,c,s,{line:h,edge:g,markers:b}=t,x=(0,r.c)(t,m),w=i.get(g);if(w){var M,E=null!==(n=null===(d=b.find((e=>"default"===e.variant&&"start"===e.placement)))||void 0===d?void 0:d.offset)&&void 0!==n?n:0,L=null!==(c=null===(s=b.find((e=>"default"===e.variant&&"end"===e.placement)))||void 0===s?void 0:s.offset)&&void 0!==c?c:0,{points:R}=w;if(!R){var C=o.get(g.source),P=o.get(g.target);if(C&&P&&C!==P){if("polyline"===h.type){if(!v(C,P,E,L)){var I,N;(()=>{if(!f){f=!0;var t=(e,t)=>{var n=l.get(e);n||l.set(e,n=new Set);var a=o.get(t);a&&n.add(a)};for(var{data:{source:n,target:a}}of e)n!==a&&(t(n,a),t(a,n))}})();var S=y(C,P,E),B=y(P,C,L),T=k(null!==(I=l.get(g.source))&&void 0!==I?I:[],C,S,E),W=k(null!==(N=l.get(g.target))&&void 0!==N?N:[],P,B,L);R=function(e,t,n,a,r,i){var o,l,d=p(e,n,r),c=p(t,a,i);switch(n){case"top":case"bottom":o={x:d.x,y:(d.y+c.y)/2},l={x:c.x,y:o.y};break;default:l={x:(o={x:(d.x+c.x)/2,y:d.y}).x,y:c.y}}return[d,o,l,c]}(C,P,S,B,(T.indexOf(P)+1)/(T.length+1),(W.indexOf(C)+1)/(W.length+1))}}else R=function(e,t){if(e===t||v(e,t,0,0))return null;var n,a,r,i,o=t.x-e.x,l=t.y-e.y,d=o>0?1:-1;if(0!==l){var c=Math.abs(o/l),s=l>0?1:-1;c<e.width/e.height?(n=e.x+c*e.height/2*d,a=e.y+e.height/2*s):(n=e.x+e.width/2*d,a=e.y+e.width/2/c*s),c<t.width/t.height?(r=t.x-c*t.height/2*d,i=t.y-t.height/2*s):(r=t.x-t.width/2*d,i=t.y-t.width/2/c*s)}else n=e.x+e.width/2*d,r=t.x-t.width/2*d,a=i=e.y;return[{x:n,y:a},{x:r,y:i}]}(C,P);if(R){var z=R[0],A=R[R.length-1];M=Math.atan2(A.y-z.y,A.x-z.x)}}}var _=u(R,h.curveType,E,L);return(0,a.c)((0,a.c)({},x),{},{markers:b,line:h,edge:g,d:_,angle:M,labelSize:w.labelSize})}})).filter(Boolean)}function y(e,t,n){var a=Math.atan2(e.height+2*n,e.width+2*n),{x:r,y:i}=e,{x:o,y:l}=t,d=Math.atan2(l-i,o-r),c=d<0?2*Math.PI+d:d;switch(Math.floor(c/Math.PI*2)){case 0:return c<a?"right":"bottom";case 1:return c<Math.PI-a?"bottom":"left";case 2:return c<Math.PI+a?"left":"top";default:return c<2*Math.PI-a?"top":"right"}}function k(e,t,n,a){return[...e].filter((e=>y(t,e,a)===n)).sort(((e,t)=>{var{x:a,y:r}=e,{x:i,y:o}=t;return"top"===n||"bottom"===n?a-i:r-o}))}},9140:(e,t,n)=>{n.d(t,{Y:()=>r});var a=n(7568);function r(e,t){var{renderedNodes:n,activeTarget:a}=t,r="node"===(null==a?void 0:a.type)?n.find((e=>e.id===a.nodeId)):void 0,o="edge"===(null==a?void 0:a.type)?a.edge:void 0;if(r||o){var l,d,c,s,u=e.key||e.keyCode||e.which;switch(u){case"Backspace":case 8:case"Delete":case 46:r?(l="delete-node",d=r):(l="delete-edge",c=o);break;default:if(!r)return;switch(u){case"ArrowLeft":case 37:d=i("x",n,r,-1),l="switch-active-node";break;case"ArrowUp":case 38:d=i("y",n,r,-1),l="switch-active-node";break;case"ArrowRight":case 39:d=i("x",n,r,1),l="switch-active-node";break;case"ArrowDown":case 40:d=i("y",n,r,1),l="switch-active-node"}}if(l)return e.preventDefault(),e.stopPropagation(),{action:l,node:null===(s=d)||void 0===s?void 0:s.data,edge:c}}}function i(e,t,n,r){var i,o="x"===e?"y":"x",l=t.filter((t=>t!==n&&(i=(t[e]-n[e])*r)>0&&i>Math.abs(n[o]-t[o])));return(0,a.minBy)(l,(t=>(n[o]-t[o])**2+(n[e]-t[e])**2))}},636:(e,t,n)=>{n.d(t,{w:()=>o});var a=n(4412),r=n(6960),i=n(6932);function o(e,t){var{nodes:n,nodesRefRepository:o,connectNodes:l,dragNodes:d,scale:c,setConnectLineState:s,setConnectLineTo:u,setManualLayoutStatus:f,setNodeMovement:v,onSwitchActiveTarget:h,onNodesConnect:p}=t;function m(e){if(o){var t,a=function(t){if(e(i))return{v:null==n?void 0:n.find((e=>e.id===t))}};for(var[r,i]of o)if(t=a(r))return t.v}}if(l||d){var g=m((t=>t.contains(e.target)));if(g&&function(e,t){return e.sourceType?[].concat(e.sourceType).includes(t.type):(0,r.checkIfByTransform)(e,{source:t})}(l||d,g)){e.stopPropagation();var y=[e.clientX,e.clientY];if(l){s({from:y,options:(0,a.c)({strokeColor:i.es,strokeWidth:i.Ij},r.__secret_internals.legacyDoTransform({source:g},l))}),u(y),null==h||h({type:"node",nodeId:g.id});var k=e=>{u([e.clientX,e.clientY])},b=e=>{document.removeEventListener("mousemove",k),document.removeEventListener("mouseup",b),s(null);var t=e.composedPath(),n=m((e=>t.includes(e)));n&&g!==n&&(null==p||p({source:g,target:n}))};return document.addEventListener("mousemove",k),void document.addEventListener("mouseup",b)}null==h||h({type:"node",nodeId:g.id});var x=!1,w=e=>{var t=[(e.clientX-y[0])/c,(e.clientY-y[1])/c];x||(x=t[0]**2+t[1]**2>=9)&&f("started"),x&&v({id:g.id,move:t})},M=()=>{x=!1,document.removeEventListener("mousemove",w),document.removeEventListener("mouseup",M),v(null),f("finished")};document.addEventListener("mousemove",w),document.addEventListener("mouseup",M)}}}},4378:(e,t,n)=>{n.d(t,{K:()=>c});var a=n(4412),r=n(640),i=n(7568),o=n(6960),l=n(6932),d=["label"];function c(e,t){var n=[],c=new WeakMap,u=[],f=function(e){var f,v,h=null!==(f=null==t?void 0:t.find((t=>function(e,t){return!!t&&(t.edgeType?[].concat(t.edgeType).includes(e.type):(0,o.checkIfByTransform)(t,{edge:e}))}(e,t))))&&void 0!==f?f:{},{label:p}=h,m=(0,r.c)(h,d),g=o.__secret_internals.legacyDoTransform({edge:e},m);if(!1===(null==g?void 0:g.draw))return 1;var y=(0,i.uniqueId)("line-"),k=(0,a.c)((0,a.c)({strokeColor:l.es,strokeWidth:l.Ij,curveType:"polyline"===(null==g?void 0:g.type)?"curveLinear":l.NN,interactStrokeWidth:l.Go,type:"auto"},g),{},{label:p,$id:y});c.set(e,y);var b=[],x=null!==(v=k.markers)&&void 0!==v?v:k.arrow?[{placement:"end",type:"arrow"}]:[];for(var w of x){var M,E,L,R,{placement:C,type:P}=w,I=null!=C?C:"end",N=void 0,S=void 0;switch(P){case"0..1":case"0..N":S=21,N=P;break;default:S=1,N="arrow"}var B=S*k.strokeWidth,T=s({type:N,strokeColor:k.strokeColor},u);b.push({index:T,placement:I,type:N,variant:"default",offset:B});var W=s({type:N,strokeColor:null!==(M=null===(E=k.overrides)||void 0===E||null===(E=E.active)||void 0===E?void 0:E.strokeColor)&&void 0!==M?M:k.strokeColor},u);b.push({index:W,placement:I,type:N,variant:"active",offset:B});var z=s({type:N,strokeColor:null!==(L=null===(R=k.overrides)||void 0===R||null===(R=R.activeRelated)||void 0===R?void 0:R.strokeColor)&&void 0!==L?L:k.strokeColor},u);b.push({index:z,placement:I,type:N,variant:"active-related",offset:B})}n.push({line:k,markers:b,edge:e})};for(var v of null!=e?e:[])f(v);return{normalizedLines:n,normalizedLinesMap:c,markers:u}}function s(e,t){var n=(0,i.findIndex)(t,e);return-1===n&&(n=t.push(e)-1),n}},4588:(e,t,n)=>{function a(e,t){return e?!!t&&e.type===t.type&&("node"===e.type?e.nodeId===t.nodeId:e.edge.source===t.edge.source&&e.edge.target===t.edge.target):!t}n.d(t,{M:()=>a})},3600:(e,t,n)=>{function a(e,t){var{canvasWidth:n,canvasHeight:a,scaleRange:r}=t,i=1/0,o=1/0,l=-1/0,d=-1/0;for(var c of e){var s=c.width/2,u=c.height/2,f=c.x-s,v=c.x+s,h=c.y-u,p=c.y+u;f<i&&(i=f),v>l&&(l=v),h<o&&(o=h),p>d&&(d=p)}var m=l-i,g=d-o,y=r&&(m>n||g>a)?Math.max(Math.min(n/m,a/g,r[1]),r[0]):1;return{x:(n-m*y)/2-i*y,y:(a-g*y)/2-o*y,k:y}}n.d(t,{c:()=>a})},6152:(e,t,n)=>{n.d(t,{c:()=>l});var a=n(8304),r=n.n(a),i=n(1849),o=n.n(i)()(r());o.push([e.id,":host{display:block;width:100%;height:100%;overflow:hidden}:host([hidden]){display:none}*{box-sizing:border-box}.diagram{width:100%;height:100%;position:relative;opacity:0}.diagram:focus{outline:none}.lines,\n.line-labels,\n.nodes{position:absolute;top:0;left:0}.line-labels{opacity:0}.ready{opacity:1}.diagram.ready.pannable{cursor:-webkit-grab;cursor:grab}.diagram.pannable.grabbing{cursor:-webkit-grabbing;cursor:grabbing}.nodes,\n.lines{transform-origin:0 0}.node,\n.line-label{position:absolute;visibility:hidden}.line-label{transform:translate(-50%,-50%);white-space:pre-line;width:-webkit-max-content;width:-moz-max-content;width:max-content;text-align:center;line-height:1}.lines{pointer-events:none}.line.interactable{pointer-events:auto;cursor:default}.connect-line{position:fixed;top:0;left:0;right:0;bottom:0;pointer-events:none}.connect-line:not(.connecting){display:none}.line:not(.active) .active-bg{display:none}",""]);const l=o.toString()}}]);
2
- //# sourceMappingURL=9380.8d833db1.js.map
1
+ "use strict";(self.webpackChunk_next_bricks_diagram=self.webpackChunk_next_bricks_diagram||[]).push([[8020],{3784:(e,t,n)=>{n.d(t,{E:()=>d});var a=n(5600),r=n.n(a),i=n(1252),o=n.n(i),l=n(8752);function d(e){var{connectLineState:t,connectLineTo:n,markerPrefix:a}=e;return r().createElement("svg",{width:"100%",height:"100%",className:o()("connect-line",{connecting:!!t&&(n[0]-t.from[0])**2+(n[1]-t.from[1])**2>25})},r().createElement("defs",null,r().createElement(l.y,{type:"arrow",id:"".concat(a,"connect-line"),strokeColor:null==t?void 0:t.options.strokeColor})),r().createElement("path",{d:t?"M".concat(t.from.join(" "),"L").concat(n.join(" ")):"",fill:"none",stroke:null==t?void 0:t.options.strokeColor,strokeWidth:null==t?void 0:t.options.strokeWidth,markerEnd:null!=t&&t.options.arrow?"url(#".concat(a,"connect-line)"):void 0}))}},2092:(e,t,n)=>{n.d(t,{k:()=>d});var a=n(4412),r=n(5600),i=n.n(r),o=n(1252),l=n.n(o);function d(e){var t,n,r,o,{line:{line:d,edge:c,d:s,markers:u},linePaths:f,lineMaskRects:v,maskPrefix:h,markerPrefix:p,activeLineMarkerPrefix:m,active:g,activeRelated:y,onLineClick:k,onLineDoubleClick:b}=e,x=v.has(d.$id)?"url(#".concat(h).concat(d.$id,")"):void 0,{strokeColor:w,strokeWidth:M,interactStrokeWidth:E}=(0,a.c)((0,a.c)({},d),g?null===(t=d.overrides)||void 0===t?void 0:t.active:y?null===(n=d.overrides)||void 0===n?void 0:n.activeRelated:null),L=g?"active":y?"active-related":"default";for(var R of u)R.variant===L&&("start"===R.placement?r="url(#".concat(p).concat(R.index,")"):o="url(#".concat(p).concat(R.index,")"));return i().createElement("g",{className:l()("line",{interactable:d.interactable,active:g,"active-related":y}),onClick:d.interactable?()=>{null==k||k({id:d.$id,edge:c})}:void 0,onDoubleClick:d.interactable?e=>{e.preventDefault(),e.stopPropagation(),null==b||b({id:d.$id,edge:c})}:void 0,style:{cursor:d.cursor}},d.interactable&&i().createElement("path",{d:s,fill:"none",stroke:"transparent",strokeWidth:E}),i().createElement("path",{ref:e=>f.set(d.$id,e),stroke:w,strokeWidth:M,d:s,fill:"none",markerStart:r,markerEnd:o,mask:x}),i().createElement("path",{stroke:"var(--palette-blue-3)",strokeWidth:M,d:s,fill:"none",className:"active-bg",markerStart:"url(#".concat(m,"start)"),markerEnd:"url(#".concat(m,"end)"),mask:x}))}},8276:(e,t,n)=>{n.d(t,{Ar:()=>l});var a=n(5600),r=n.n(a),i=n(6196),o=n(6960);function l(e){var{labels:t,onRendered:n}=e,[i,o]=(0,a.useState)(!1),[l,s]=(0,a.useState)([]),u=(0,a.useMemo)((()=>new Map),[]),f=(0,a.useCallback)(((e,t)=>{t&&u.set(e,t),s((t=>t.includes(e)?t:t.concat(e)))}),[u]),v=(0,a.useCallback)((e=>{s((t=>{var n=t.indexOf(e);return-1===n?t:t.slice(0,n).concat(t.slice(n+1))})),u.delete(e)}),[u]);return(0,a.useEffect)((()=>{o(!(null!=t&&t.some((e=>!l.includes(e.id)))))}),[t,l]),(0,a.useEffect)((()=>{null==n||n(i?u:null)}),[u,i]),r().createElement(r().Fragment,null,null==t?void 0:t.map((e=>{var{text:t,label:n,id:a,edge:i}=e;return n?r().createElement("div",{key:a,className:"line-label"},r().createElement(c,{id:a,edge:i,label:n,onRendered:f,onUnmount:v})):r().createElement(d,{key:a,id:a,text:t,onRendered:f})})))}function d(e){var{id:t,text:n,onRendered:i}=e,o=(0,a.useCallback)((e=>{null==i||i(t,e)}),[t,i]);return r().createElement("div",{className:"line-label",ref:o,style:n.style},n.content)}function c(e){var{id:t,edge:n,label:l,onRendered:d,onUnmount:c}=e,s=(0,a.useMemo)((()=>(0,o.checkIfByTransform)(l,{edge:n})?l.useBrick:null),[n,l]),u=(0,a.useMemo)((()=>({edge:n})),[n]);(0,a.useEffect)((()=>{s||setTimeout((()=>{null==d||d(t,null)}))}),[t,d,s]),(0,a.useEffect)((()=>()=>{null==c||c(t)}),[]);var f=(0,a.useCallback)((e=>{e&&setTimeout((()=>{null==d||d(t,e.parentElement)}))}),[t,d]),v=(0,a.useCallback)((()=>{setTimeout((()=>{null==d||d(t,null)}))}),[t,d]);return s?r().createElement(i.ReactUseBrick,{refCallback:f,ignoredCallback:v,useBrick:s,data:u}):null}},4092:(e,t,n)=>{n.d(t,{g:()=>i});var a=n(5600),r=n.n(a);function i(e){var{lineId:t,rects:n,maskPrefix:a,renderedLineLabels:i}=e,o=i.find((e=>e.lineId===t&&"center"===e.placement));if(!o)return null;var l,d,{lineRect:c}=o,s=(d=1e3,{left:(l=c).left-d,top:l.top-d,width:l.width+2e3,height:l.height+2e3});return r().createElement("mask",{id:"".concat(a).concat(t),x:s.left,y:s.top,width:s.width,height:s.height},r().createElement("rect",{x:s.left,y:s.top,width:s.width,height:s.height,fill:"white"}),n.map(((e,t)=>r().createElement("rect",{key:t,x:e.left,y:e.top,width:e.width,height:e.height,fill:"black"}))))}},8752:(e,t,n)=>{n.d(t,{y:()=>i});var a=n(5600),r=n.n(a);function i(e){var t,{id:n,type:a,strokeColor:i}=e;switch(a){case"0..1":t=l;break;case"0..N":t=d;break;default:t=o}return r().createElement(t,{id:n,strokeColor:i})}function o(e){var{id:t,strokeColor:n}=e;return r().createElement("marker",{id:t,viewBox:"0 0 6 6",refX:5,refY:3,markerWidth:6,markerHeight:6,orient:"auto-start-reverse",strokeLinejoin:"round"},r().createElement("path",{d:"M 0.5 0.5 L 5.5 3 L 0.5 5.5 z",stroke:n,strokeWidth:1,fill:n}))}function l(e){var{id:t,strokeColor:n}=e;return r().createElement("marker",{id:t,viewBox:"0 0 21 11",refX:.5,refY:5.5,markerWidth:21,markerHeight:11,orient:"auto-start-reverse"},r().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:n,strokeWidth:1,fill:"none"}))}function d(e){var{id:t,strokeColor:n}=e;return r().createElement("marker",{id:t,viewBox:"0 0 21 11",refX:.5,refY:5.5,markerWidth:21,markerHeight:11,orient:"auto-start-reverse"},r().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:n,strokeWidth:1,fill:"none"}))}},8996:(e,t,n)=>{n.d(t,{_:()=>l});var a=n(5600),r=n.n(a),i=n(6196),o=n(6960);function l(e){var{nodes:t,nodeBricks:n,onRendered:i}=e,[o,l]=(0,a.useState)(!1),[c,s]=(0,a.useState)([]),u=(0,a.useMemo)((()=>new Map),[]),f=(0,a.useCallback)(((e,t)=>{t&&u.set(e,t),s((t=>t.includes(e)?t:t.concat(e)))}),[u]),v=(0,a.useCallback)((e=>{s((t=>{var n=t.indexOf(e);return-1===n?t:t.slice(0,n).concat(t.slice(n+1))})),u.delete(e)}),[u]);return(0,a.useEffect)((()=>{l(!(null!=t&&t.some((e=>!c.includes(e.id)))))}),[t,c]),(0,a.useEffect)((()=>{null==i||i(o?u:null)}),[u,o]),r().createElement(r().Fragment,null,null==t?void 0:t.map((e=>r().createElement("div",{key:e.id,className:"node"},r().createElement(d,{nodeBricks:n,node:e,onRendered:f,onUnmount:v})))))}function d(e){var{node:t,nodeBricks:n,onRendered:l,onUnmount:d}=e,c=(0,a.useMemo)((()=>{var e;return null===(e=function(e,t){return null==t?void 0:t.find((t=>t.nodeType?[].concat(t.nodeType).includes(e.type):(0,o.checkIfByTransform)(t,{node:e})))}(t,n))||void 0===e?void 0:e.useBrick}),[t,n]),s=(0,a.useMemo)((()=>({node:t})),[t]);(0,a.useEffect)((()=>{c||setTimeout((()=>{null==l||l(t.id,null)}))}),[t.id,l,c]),(0,a.useEffect)((()=>()=>{null==d||d(t.id)}),[]);var u=(0,a.useCallback)((e=>{e&&setTimeout((()=>{null==l||l(t.id,e)}))}),[t.id,l]),f=(0,a.useCallback)((()=>{setTimeout((()=>{null==l||l(t.id,null)}))}),[t.id,l]);return c?r().createElement(i.ReactUseBrick,{refCallback:u,ignoredCallback:f,useBrick:c,data:s}):null}},6932:(e,t,n)=>{n.d(t,{Go:()=>o,Ij:()=>r,NN:()=>i,Oi:()=>d,WH:()=>l,es:()=>a});var a="var(--palette-gray-5)",r=1,i="curveBasis",o=20,l=.5,d=2},4580:(e,t,n)=>{n.d(t,{C:()=>w});var a=n(5600),r=n(4412),i=n(640),o=n(228),l=n.n(o),d=n(7568);function c(e,t,n){for(var a of e){var r,i,o=t.get(a.id);a.width=Math.max(null!==(r=null==o?void 0:o.offsetWidth)&&void 0!==r?r:0,10)+n[1]+n[3],a.height=Math.max(null!==(i=null==o?void 0:o.offsetHeight)&&void 0!==i?i:0,10)+n[0]+n[2]}}function s(e,t,n){for(var a of e){var r,i=a.x-a.width/2+n[3],o=a.y-a.height/2+n[0],l=null===(r=t.get(a.id))||void 0===r?void 0:r.parentElement;l&&(l.style.left="".concat(i,"px"),l.style.top="".concat(o,"px"),l.style.visibility="visible")}}function u(e){if(Array.isArray(e)){var t=e[0],n=e.length>1?e[1]:t;return[t,n,e.length>2?e[2]:t,e.length>3?e[3]:n]}return new Array(4).fill(e)}var f=["nodePadding"],v=n(1108),h=n(9472),p=n(7339),m=n(5336),g=n(9388),y=n(5064);function k(e,t){var n,{normalizedLinesMap:a,lineLabelsRefRepository:r}=t;return null!==(n=null==e?void 0:e.map((e=>{var t=a.get(e),n={};if(t)for(var i of["start","end"]){var o=r.get("".concat(t,"-").concat(i));o&&(n[i]=[o.offsetWidth,o.offsetHeight])}return{data:e,labelSize:n}})))&&void 0!==n?n:[]}function b(e,t){return new Array(t).fill(null).map(((t,n)=>({dummy:!0,id:"$dummy-".concat(e.source,"-").concat(e.target,"-").concat(n)})))}function x(e,t){return new Array(t+1).fill(null).map(((n,a)=>({dummy:!0,source:0===a?e.source:"$dummy-".concat(e.source,"-").concat(e.target,"-").concat(a-1),target:a===t?e.target:"$dummy-".concat(e.source,"-").concat(e.target,"-").concat(a)})))}function w(e){var{layout:t,nodes:n,edges:o,manualLayoutStatus:w,userViewReady:M,userViewNodesMap:E,nodeMovement:L,nodesRefRepository:R,lineLabelsRefRepository:C,normalizedLinesMap:P,nodesRenderId:I,lineLabelsRenderId:N,layoutOptions:S}=e,B="initial"===w?t:"manual",[T,W]=(0,a.useState)(null),[z,A]=(0,a.useState)({nodes:[],edges:[]});return(0,a.useEffect)((()=>{M&&W((e=>"dagre"===B?function(e,t,n,a){var o=(0,r.c)({nodePadding:0,rankdir:"TB",ranksep:50,edgesep:10,nodesep:50},(0,d.pick)(a,["nodePadding","rankdir","ranksep","edgesep","nodesep","align"])),{nodePadding:v}=o,h=(0,i.c)(o,f),p=u(v),m=new(l().graphlib.Graph);for(var g of(m.setGraph(h),m.setDefaultEdgeLabel((function(){return{}})),null!=t?t:[])){var y=null==e?void 0:e.getNode(g.id);m.setNode(g.id,(null==y?void 0:y.data)===g?y:{id:g.id,data:g})}for(var k of null!=n?n:[])m.setEdge(k.source,k.target,{data:k});return{layout:"dagre",getNode:e=>m.node(e),applyLayout(e){var{nodesRefRepository:t,lineLabelsRefRepository:n,normalizedLinesMap:a}=e,r=[];for(var i of m.nodes()){var o=m.node(i);o?r.push(o):console.error("Diagram node not found: %s",i)}if(0===r.length)return null;c(r,t,p);var d=m.edges().map((e=>m.edge(e)));for(var u of d){var f=a.get(u.data);if(f)for(var v of["center","start","end"]){var h=n.get("".concat(f,"-").concat(v));if(h){var g,{offsetWidth:y,offsetHeight:k}=h;"center"===v&&(u.labelpos="c",u.width=y,u.height=k),null!==(g=u.labelSize)&&void 0!==g||(u.labelSize={}),u.labelSize[v]=[y,k]}}}return l().layout(m),s(r,t,p),{nodes:r,edges:d}}}}(e,n,o,S):"force"===B?function(e,t,n,a,i){var{nodePadding:o,dummyNodesOnEdges:l,collide:f}=(0,r.c)((0,r.c)({nodePadding:0,dummyNodesOnEdges:0},(0,d.pick)(i,["nodePadding","dummyNodesOnEdges"])),{},{collide:!1!==(null==i?void 0:i.collide)&&(0,r.c)({dummyRadius:1,radiusDiff:5,strength:1,iterations:1},!0===(null==i?void 0:i.collide)?null:null==i?void 0:i.collide)}),w=u(o),M=[];for(var E of null!=t?t:[]){var L=null==e?void 0:e.getNode(E.id);if((null==L?void 0:L.data)===E)M.push(L);else{var R={id:E.id,data:E},C=null==a?void 0:a.get(E.id);C&&(R.fx=C.x,R.fy=C.y),M.push(R)}}return{layout:"force",getNode:function(e){return M.find((t=>t.data.id===e))},applyLayout(e){var{nodesRefRepository:t,lineLabelsRefRepository:a,normalizedLinesMap:i}=e;if(0===M.length)return null;c(M,t,w);var o=M.slice(),d=[];for(var u of null!=n?n:[])d.push((0,r.c)({},u)),l>0&&(o.push(...b(u,l)),d.push(...x(u,l)));var E=(0,v.c)(d).id((e=>e.id));l>0&&E.distance((e=>e.dummy?30/(l+1):30)).strength((e=>e.dummy?.5:1));var L=(0,h.c)(o).force("link",E).force("x",(0,p.c)()).force("y",(0,m.c)()).force("charge",(0,g.c)());f&&L.force("collide",(0,y.c)().radius((e=>e.dummy?f.dummyRadius:Math.sqrt(e.width**2+e.height**2)/2+f.radiusDiff)).strength(f.strength).iterations(f.iterations)),L.stop(),function(e){e.tick(Math.ceil(Math.log(e.alphaMin())/Math.log(1-e.alphaDecay())))}(L),s(M,t,w);var R=k(n,{normalizedLinesMap:i,lineLabelsRefRepository:a});return{nodes:M,edges:R}}}}(e,n,o,E,S):"manual"===B?function(e,t,n,a){var i,{nodePadding:o}=(0,r.c)({nodePadding:0},(0,d.pick)(a,["nodePadding"])),l=u(o),f=[];for(var v of null!=t?t:[]){var h=null==e?void 0:e.getNode(v.id);(null==h?void 0:h.data)===v?(f.push(h),h.x0=h.x,h.y0=h.y):f.push({id:v.id,data:v})}return{layout:"manual",getNode:function(e){return f.find((t=>t.data.id===e))},applyLayout(e){var t,a,{manualLayoutStatus:r,nodesRefRepository:o,lineLabelsRefRepository:d,normalizedLinesMap:u,nodeMovement:v}=e;if(0===f.length)return null;c(f,o,l),v&&(i=f.find((e=>e.id===v.id)),i&&(i.x=(null!==(t=i.x0)&&void 0!==t?t:0)+v.move[0],i.y=(null!==(a=i.y0)&&void 0!==a?a:0)+v.move[1])),"finished"===r&&i&&(i.x0=i.x,i.y0=i.y),s(f,o,l);var h=k(n,{normalizedLinesMap:u,lineLabelsRefRepository:d});return{nodes:f,edges:h}}}}(e,n,o,S):null))}),[o,n,B,S,M,E]),(0,a.useEffect)((()=>{if(R&&C&&B===(null==T?void 0:T.layout)){var e=null==T?void 0:T.applyLayout({manualLayoutStatus:w,nodesRefRepository:R,lineLabelsRefRepository:C,normalizedLinesMap:P,nodeMovement:L});e&&A(e)}}),[B,w,T,L,R,C,I,N,P]),z}},3888:(e,t,n)=>{n.d(t,{y:()=>s});var a=n(8944),r=n(5600),i=n(6960),o=n(6851),l=n(236),d=n(5996),c="GRAPH_USER_VIEW@EASYOPS";function s(e){var[t,n]=(0,r.useState)(!e),s=(0,r.useRef)(),[u,f]=(0,r.useState)(null),v=(0,r.useMemo)((()=>{return e=!1,t=[],function(){var n=(0,a.c)((function*(n){if(t.push(n),!e){var a;for(e=!0;a=t.shift();)try{yield a()}catch(e){console.error(e)}e=!1}}));return function(e){return n.apply(this,arguments)}}();var e,t}),[]);return(0,r.useEffect)((()=>{function t(){return(t=(0,a.c)((function*(){if(e){var{namespace:t,key:a}=e;if(!t||!a)return console.error("Namespace and key are required to save graph user view"),void n(!0);try{var r=(yield(0,o.c)(c,{fields:["nodes"],query:{namespace:{$eq:t},key:{$eq:a}},page:1,page_size:30})).list;if(r.length>0){var l,d=r[0],u=new Map(null===(l=d.nodes)||void 0===l?void 0:l.map((e=>[e.id,e])));s.current=d.instanceId,f(u)}else f(null)}catch(e){(0,i.handleHttpError)(e)}finally{n(!0)}}else n(!0)}))).apply(this,arguments)}!function(){t.apply(this,arguments)}()}),[e]),{userViewReady:t,userViewNodesMap:u,saveUserView:(0,r.useCallback)((t=>{var{namespace:n,key:r}=null!=e?e:{};n&&r&&v((0,a.c)((function*(){var e={namespace:n,key:r,nodes:t};try{if(s.current)yield(0,l.Y)(c,s.current,e,{interceptorParams:{ignoreLoadingBar:!0}});else{var a=yield(0,d.A)(c,e,{interceptorParams:{ignoreLoadingBar:!0}});s.current=a.instanceId}}catch(e){(0,i.handleHttpError)(e)}})))}),[e,v])}}},960:(e,t,n)=>{n.d(t,{g:()=>r});var a=n(3208);function r(e,t){if(e===t||(0,a.e)(e,t,0,0))return null;var n,r,i,o,l=t.x-e.x,d=t.y-e.y,c=l>0?1:-1;if(0!==d){var s=Math.abs(l/d),u=d>0?1:-1;s<e.width/e.height?(n=e.x+s*e.height/2*c,r=e.y+e.height/2*u):(n=e.x+e.width/2*c,r=e.y+e.width/2/s*u),s<t.width/t.height?(i=t.x-s*t.height/2*c,o=t.y-t.height/2*u):(i=t.x-t.width/2*c,o=t.y-t.width/2/s*u)}else n=e.x+e.width/2*c,i=t.x-t.width/2*c,r=o=e.y;return[{x:n,y:r},{x:i,y:o}]}},9900:(e,t,n)=>{function a(e,t){for(var{id:n,position:a,placement:r,angle:i,size:o}of e){var l=t.get(n);if(l&&(l.style.left="".concat(a[0],"px"),l.style.top="".concat(a[1],"px"),l.style.visibility="visible","center"!==r&&void 0!==i)){var[d,c]=null!=o?o:[0,0],s=Math.floor((i<0?2*Math.PI+i:i)/Math.PI*4),u="start"===r?s:(s+4)%8,f=Math.tan(i),v=i+("start"===r?1:-1)*Math.PI/2,h=2*Math.sin(v),p=2*Math.cos(v),m=void 0;switch(u){case 0:m="translate(0,".concat(d*f+h,"px)");break;case 1:m="translate(".concat(c/f-p,"px,0)");break;case 2:m="translate(calc(".concat(c/f+p,"px - 100%),0)");break;case 3:m="translate(-100%,".concat(-d*f-h,"px)");break;case 4:m="translate(-100%,calc(".concat(-d*f+h,"px - 100%))");break;case 5:m="translate(calc(".concat(-c/f-p,"px - 100%),-100%)");break;case 6:m="translate(".concat(-c/f+p,"px,-100%)");break;default:m="translate(0,calc(".concat(d*f-h,"px - 100%))")}l.style.transform=m}}}n.d(t,{c:()=>a})},3208:(e,t,n)=>{function a(e,t,n,a){var i=n?r(e,n):e,o=a?r(t,a):t,l=Math.min(i.x-i.width/2,o.x-o.width/2),d=Math.max(i.x+i.width/2,o.x+o.width/2),c=Math.min(i.y-i.height/2,o.y-o.height/2),s=Math.max(i.y+i.height/2,o.y+o.height/2);return d-l<i.width+o.width&&s-c<i.height+o.height}function r(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}}n.d(t,{e:()=>a})},3256:(e,t,n)=>{function a(e,t){var n=new Map;for(var{id:a,lineId:r,placement:i}of e)if(t&&"center"===i){var o=t.get(a);if(o){var{offsetWidth:l,offsetHeight:d}=o;0!==l&&0!==d&&n.set(r,[{left:o.offsetLeft-l/2-3,top:o.offsetTop-d/2-3,width:l+6,height:d+6}])}}return n}n.d(t,{E:()=>a})},3732:(e,t,n)=>{function a(e,t,n){return 0===e.length&&0===t.length?e:t.flatMap((e=>{var t,a,{line:{text:r,label:i,$id:o},edge:l,labelSize:d,angle:c}=e,s=n.get(o);if(!r&&!i||!s||!s.getAttribute("d"))return[];i?(t="label",a=[].concat(i)):(t="text",a=[].concat(r));var{x:u,y:f,width:v,height:h}=s.getBBox(),p=s.getTotalLength();return a.map((e=>{var n,a=null!==(n=e.placement)&&void 0!==n?n:"center",r=s.getPointAtLength("start"===a?Math.min(0,p/2):"end"===a?Math.max(p-0,p/2):p/2);return{[t]:e,edge:l,position:[r.x,r.y],lineRect:{left:u,top:f,width:v,height:h},id:"".concat(o,"-").concat(a),lineId:o,placement:a,angle:c,size:null==d?void 0:d[a]}}))}))}n.d(t,{c:()=>a})},3904:(e,t,n)=>{n.d(t,{e:()=>g});var a=n(4412),r=n(640),i=n(3584),o=n(2128),l=n(5416),d=n(4348),c=n(2760),s=n(1260);function u(e,t,n,a){if(!Array.isArray(e))return"";var r;switch(t){case"curveLinear":r=i.c;break;case"curveBumpX":r=o.KQ;break;case"curveBumpY":r=o.yM;break;case"curveMonotoneX":r=l.O;break;case"curveMonotoneY":r=l.o;break;case"curveNatural":r=d.c;break;default:r=c.cp}var u=f(e[1],e[0],n),v=f(e[e.length-2],e[e.length-1],a);return(0,s.c)().x(((t,n)=>t.x-(0===n?u.x:n===e.length-1?v.x:0))).y(((t,n)=>t.y-(0===n?u.y:n===e.length-1?v.y:0))).curve(r)(e)}function f(e,t,n){if(!n)return{x:0,y:0};var{x:a,y:r}=e,{x:i,y:o}=t,l=n/Math.sqrt(Math.pow(i-a,2)+Math.pow(o-r,2));return{x:(i-a)*l,y:(o-r)*l}}var v=n(960);function h(e,t,n){var{x:a,y:r,width:i,height:o}=e;switch(t){case"top":return{x:a-i/2+i*n,y:r-o/2};case"bottom":return{x:a-i/2+i*n,y:r+o/2};case"left":return{x:a-i/2,y:r-o/2+o*n};case"right":return{x:a+i/2,y:r-o/2+o*n}}}var p=n(3208),m=["line","edge","markers"];function g(e,t,n){var i=new WeakMap,o=new Map,l=new Map;for(var d of t)o.set(d.id,d);for(var c of e){var{data:s}=c;i.set(s,c)}var f=!1;return n.map((t=>{var n,d,c,s,{line:g,edge:b,markers:x}=t,w=(0,r.c)(t,m),M=i.get(b);if(M){var E,L=null!==(n=null===(d=x.find((e=>"default"===e.variant&&"start"===e.placement)))||void 0===d?void 0:d.offset)&&void 0!==n?n:0,R=null!==(c=null===(s=x.find((e=>"default"===e.variant&&"end"===e.placement)))||void 0===s?void 0:s.offset)&&void 0!==c?c:0,{points:C}=M;if(!C){var P=o.get(b.source),I=o.get(b.target);if(P&&I&&P!==I){if("polyline"===g.type){if(!(0,p.e)(P,I,L,R)){var N,S;(()=>{if(!f){f=!0;var t=(e,t)=>{var n=l.get(e);n||l.set(e,n=new Set);var a=o.get(t);a&&n.add(a)};for(var{data:{source:n,target:a}}of e)n!==a&&(t(n,a),t(a,n))}})();var B=y(P,I,L),T=y(I,P,R),W=k(null!==(N=l.get(b.source))&&void 0!==N?N:[],P,B,L),z=k(null!==(S=l.get(b.target))&&void 0!==S?S:[],I,T,R);C=function(e,t,n,a,r,i){var o,l,d=h(e,n,r),c=h(t,a,i);switch(n){case"top":case"bottom":o={x:d.x,y:(d.y+c.y)/2},l={x:c.x,y:o.y};break;default:l={x:(o={x:(d.x+c.x)/2,y:d.y}).x,y:c.y}}return[d,o,l,c]}(P,I,B,T,(W.indexOf(I)+1)/(W.length+1),(z.indexOf(P)+1)/(z.length+1))}}else C=(0,v.g)(P,I);if(C){var A=C[0],_=C[C.length-1];E=Math.atan2(_.y-A.y,_.x-A.x)}}}var H=u(C,g.curveType,L,R);return(0,a.c)((0,a.c)({},w),{},{markers:x,line:g,edge:b,d:H,angle:E,labelSize:M.labelSize})}})).filter(Boolean)}function y(e,t,n){var a=Math.atan2(e.height+2*n,e.width+2*n),{x:r,y:i}=e,{x:o,y:l}=t,d=Math.atan2(l-i,o-r),c=d<0?2*Math.PI+d:d;switch(Math.floor(c/Math.PI*2)){case 0:return c<a?"right":"bottom";case 1:return c<Math.PI-a?"bottom":"left";case 2:return c<Math.PI+a?"left":"top";default:return c<2*Math.PI-a?"top":"right"}}function k(e,t,n,a){return[...e].filter((e=>y(t,e,a)===n)).sort(((e,t)=>{var{x:a,y:r}=e,{x:i,y:o}=t;return"top"===n||"bottom"===n?a-i:r-o}))}},9140:(e,t,n)=>{n.d(t,{Y:()=>r});var a=n(7568);function r(e,t){var{renderedNodes:n,activeTarget:a}=t,r="node"===(null==a?void 0:a.type)?n.find((e=>e.id===a.nodeId)):void 0,o="edge"===(null==a?void 0:a.type)?a.edge:void 0;if(r||o){var l,d,c,s,u=e.key||e.keyCode||e.which;switch(u){case"Backspace":case 8:case"Delete":case 46:r?(l="delete-node",d=r):(l="delete-edge",c=o);break;default:if(!r)return;switch(u){case"ArrowLeft":case 37:d=i("x",n,r,-1),l="switch-active-node";break;case"ArrowUp":case 38:d=i("y",n,r,-1),l="switch-active-node";break;case"ArrowRight":case 39:d=i("x",n,r,1),l="switch-active-node";break;case"ArrowDown":case 40:d=i("y",n,r,1),l="switch-active-node"}}if(l)return e.preventDefault(),e.stopPropagation(),{action:l,node:null===(s=d)||void 0===s?void 0:s.data,edge:c}}}function i(e,t,n,r){var i,o="x"===e?"y":"x",l=t.filter((t=>t!==n&&(i=(t[e]-n[e])*r)>0&&i>Math.abs(n[o]-t[o])));return(0,a.minBy)(l,(t=>(n[o]-t[o])**2+(n[e]-t[e])**2))}},636:(e,t,n)=>{n.d(t,{w:()=>o});var a=n(4412),r=n(6960),i=n(6932);function o(e,t){var{nodes:n,nodesRefRepository:o,connectNodes:l,dragNodes:d,scale:c,setConnectLineState:s,setConnectLineTo:u,setManualLayoutStatus:f,setNodeMovement:v,onSwitchActiveTarget:h,onNodesConnect:p}=t;function m(e){if(o){var t,a=function(t){if(e(i))return{v:null==n?void 0:n.find((e=>e.id===t))}};for(var[r,i]of o)if(t=a(r))return t.v}}if(l||d){var g=m((t=>t.contains(e.target)));if(g&&function(e,t){return e.sourceType?[].concat(e.sourceType).includes(t.type):(0,r.checkIfByTransform)(e,{source:t})}(l||d,g)){e.stopPropagation();var y=[e.clientX,e.clientY];if(l){s({from:y,options:(0,a.c)({strokeColor:i.es,strokeWidth:i.Ij},r.__secret_internals.legacyDoTransform({source:g},l))}),u(y),null==h||h({type:"node",nodeId:g.id});var k=e=>{u([e.clientX,e.clientY])},b=e=>{document.removeEventListener("mousemove",k),document.removeEventListener("mouseup",b),s(null);var t=e.composedPath(),n=m((e=>t.includes(e)));n&&g!==n&&(null==p||p({source:g,target:n}))};return document.addEventListener("mousemove",k),void document.addEventListener("mouseup",b)}null==h||h({type:"node",nodeId:g.id});var x=!1,w=e=>{var t=[(e.clientX-y[0])/c,(e.clientY-y[1])/c];x||(x=t[0]**2+t[1]**2>=9)&&f("started"),x&&v({id:g.id,move:t})},M=()=>{x=!1,document.removeEventListener("mousemove",w),document.removeEventListener("mouseup",M),v(null),f("finished")};document.addEventListener("mousemove",w),document.addEventListener("mouseup",M)}}}},4378:(e,t,n)=>{n.d(t,{K:()=>c});var a=n(4412),r=n(640),i=n(7568),o=n(6960),l=n(6932),d=["label"];function c(e,t){var n=[],c=new WeakMap,u=[],f=function(e){var f,v,h=null!==(f=null==t?void 0:t.find((t=>function(e,t){return!!t&&(t.edgeType?[].concat(t.edgeType).includes(e.type):(0,o.checkIfByTransform)(t,{edge:e}))}(e,t))))&&void 0!==f?f:{},{label:p}=h,m=(0,r.c)(h,d),g=o.__secret_internals.legacyDoTransform({edge:e},m);if(!1===(null==g?void 0:g.draw))return 1;var y=(0,i.uniqueId)("line-"),k=(0,a.c)((0,a.c)({strokeColor:l.es,strokeWidth:l.Ij,curveType:"polyline"===(null==g?void 0:g.type)?"curveLinear":l.NN,interactStrokeWidth:l.Go,type:"auto"},g),{},{label:p,$id:y});c.set(e,y);var b=[],x=null!==(v=k.markers)&&void 0!==v?v:k.arrow?[{placement:"end",type:"arrow"}]:[];for(var w of x){var M,E,L,R,{placement:C,type:P}=w,I=null!=C?C:"end",N=void 0,S=void 0;switch(P){case"0..1":case"0..N":S=21,N=P;break;default:S=1,N="arrow"}var B=S*k.strokeWidth,T=s({type:N,strokeColor:k.strokeColor},u);b.push({index:T,placement:I,type:N,variant:"default",offset:B});var W=s({type:N,strokeColor:null!==(M=null===(E=k.overrides)||void 0===E||null===(E=E.active)||void 0===E?void 0:E.strokeColor)&&void 0!==M?M:k.strokeColor},u);b.push({index:W,placement:I,type:N,variant:"active",offset:B});var z=s({type:N,strokeColor:null!==(L=null===(R=k.overrides)||void 0===R||null===(R=R.activeRelated)||void 0===R?void 0:R.strokeColor)&&void 0!==L?L:k.strokeColor},u);b.push({index:z,placement:I,type:N,variant:"active-related",offset:B})}n.push({line:k,markers:b,edge:e})};for(var v of null!=e?e:[])f(v);return{normalizedLines:n,normalizedLinesMap:c,markers:u}}function s(e,t){var n=(0,i.findIndex)(t,e);return-1===n&&(n=t.push(e)-1),n}},4588:(e,t,n)=>{function a(e,t){return e?!!t&&e.type===t.type&&("node"===e.type?e.nodeId===t.nodeId:e.edge.source===t.edge.source&&e.edge.target===t.edge.target):!t}n.d(t,{M:()=>a})},3600:(e,t,n)=>{function a(e,t){var{canvasWidth:n,canvasHeight:a,scaleRange:r}=t,i=1/0,o=1/0,l=-1/0,d=-1/0;for(var c of e){var s=c.width/2,u=c.height/2,f=c.x-s,v=c.x+s,h=c.y-u,p=c.y+u;f<i&&(i=f),v>l&&(l=v),h<o&&(o=h),p>d&&(d=p)}var m=l-i,g=d-o,y=r&&(m>n||g>a)?Math.max(Math.min(n/m,a/g,r[1]),r[0]):1;return{x:(n-m*y)/2-i*y,y:(a-g*y)/2-o*y,k:y}}n.d(t,{c:()=>a})},6152:(e,t,n)=>{n.d(t,{c:()=>l});var a=n(8304),r=n.n(a),i=n(1849),o=n.n(i)()(r());o.push([e.id,":host{display:block;width:100%;height:100%;overflow:hidden}:host([hidden]){display:none}*{box-sizing:border-box}.diagram{width:100%;height:100%;position:relative;opacity:0}.diagram:focus{outline:none}.lines,\n.line-labels,\n.nodes{position:absolute;top:0;left:0}.line-labels{opacity:0}.ready{opacity:1}.diagram.ready.pannable{cursor:-webkit-grab;cursor:grab}.diagram.pannable.grabbing{cursor:-webkit-grabbing;cursor:grabbing}.nodes,\n.lines{transform-origin:0 0}.node,\n.line-label{position:absolute;visibility:hidden}.line-label{transform:translate(-50%,-50%);white-space:pre-line;width:-webkit-max-content;width:-moz-max-content;width:max-content;text-align:center;line-height:1}.lines{pointer-events:none}.line.interactable{pointer-events:auto;cursor:default}.connect-line{position:fixed;top:0;left:0;right:0;bottom:0;pointer-events:none}.connect-line:not(.connecting){display:none}.line:not(.active) .active-bg{display:none}",""]);const l=o.toString()}}]);
2
+ //# sourceMappingURL=8020.7d347956.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"chunks/8020.7d347956.js","mappings":"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","sources":["webpack:///./src/diagram/ConnectLineComponent.tsx","webpack:///./src/diagram/LineComponent.tsx","webpack:///./src/diagram/LineLabelComponent.tsx","webpack:///./src/diagram/LineMaskComponent.tsx","webpack:///./src/diagram/MarkerComponent.tsx","webpack:///./src/diagram/NodeComponent.tsx","webpack:///./src/diagram/processors/findNodeBrick.ts","webpack:///./src/diagram/constants.ts","webpack:///./src/diagram/processors/adjustNodesSize.ts","webpack:///./src/diagram/processors/adjustNodesPosition.ts","webpack:///./src/diagram/processors/extractPartialRectTuple.ts","webpack:///./src/diagram/processors/getRenderedEdges.ts","webpack:///./src/diagram/processors/getForceGraph.ts","webpack:///./src/diagram/hooks/useRenderedDiagram.ts","webpack:///./src/diagram/processors/getDagreGraph.ts","webpack:///./src/diagram/processors/getManualGraph.ts","webpack:///./src/diagram/hooks/useUserView.ts","webpack:///./src/diagram/processors/createAsyncQueue.ts","webpack:///./src/diagram/lines/getDirectLinePoints.ts","webpack:///./src/diagram/processors/adjustLineLabels.ts","webpack:///./src/diagram/processors/doTwoNodesOverlap.ts","webpack:///./src/diagram/processors/getLineMaskRects.ts","webpack:///./src/diagram/processors/getRenderedLineLabels.ts","webpack:///./src/diagram/lines/curveLine.ts","webpack:///./src/diagram/lines/getPolyLinePoints.ts","webpack:///./src/diagram/processors/getRenderedLines.ts","webpack:///./src/diagram/processors/handleKeyboard.ts","webpack:///./src/diagram/processors/handleNodesMouseDown.ts","webpack:///./src/diagram/processors/normalizeLinesAndMarkers.ts","webpack:///./src/diagram/processors/matchEdgeByFilter.ts","webpack:///./src/diagram/processors/sameTarget.ts","webpack:///./src/diagram/processors/transformToCenter.ts","webpack:///./src/diagram/styles.shadow.css"],"sourcesContent":["import React from \"react\";\nimport classNames from \"classnames\";\nimport type { ConnectLineState, PositionTuple } from \"./interfaces\";\nimport { MarkerComponent } from \"./MarkerComponent\";\n\nexport interface ConnectLineComponentProps {\n connectLineState: ConnectLineState | null;\n connectLineTo: PositionTuple;\n markerPrefix: string;\n}\n\nexport function ConnectLineComponent({\n connectLineState,\n connectLineTo,\n markerPrefix,\n}: ConnectLineComponentProps): JSX.Element {\n return (\n <svg\n width=\"100%\"\n height=\"100%\"\n className={classNames(\"connect-line\", {\n connecting:\n !!connectLineState &&\n // Do not show when the distance of mouse move is less than 5px\n (connectLineTo[0] - connectLineState.from[0]) ** 2 +\n (connectLineTo[1] - connectLineState.from[1]) ** 2 >\n 25,\n })}\n >\n <defs>\n <MarkerComponent\n type=\"arrow\"\n id={`${markerPrefix}connect-line`}\n strokeColor={connectLineState?.options.strokeColor}\n />\n </defs>\n <path\n d={\n connectLineState\n ? `M${connectLineState.from.join(\" \")}L${connectLineTo.join(\" \")}`\n : \"\"\n }\n fill=\"none\"\n stroke={connectLineState?.options.strokeColor}\n strokeWidth={connectLineState?.options.strokeWidth}\n markerEnd={\n connectLineState?.options.arrow\n ? `url(#${markerPrefix}connect-line)`\n : undefined\n }\n />\n </svg>\n );\n}\n","import React from \"react\";\nimport classNames from \"classnames\";\nimport type { LineTarget, RenderedLine, LineMaskRects } from \"./interfaces\";\n\nexport interface LineComponentProps {\n line: RenderedLine;\n linePaths: Map<string, SVGPathElement | null>;\n lineMaskRects: LineMaskRects;\n maskPrefix: string;\n markerPrefix: string;\n activeLineMarkerPrefix: string;\n active?: boolean;\n activeRelated?: boolean;\n onLineClick?(line: LineTarget): void;\n onLineDoubleClick?(line: LineTarget): void;\n}\n\nexport function LineComponent({\n line: { line, edge, d, markers },\n linePaths,\n lineMaskRects,\n maskPrefix,\n markerPrefix,\n activeLineMarkerPrefix,\n active,\n activeRelated,\n onLineClick,\n onLineDoubleClick,\n}: LineComponentProps): JSX.Element {\n const mask = lineMaskRects.has(line.$id)\n ? `url(#${maskPrefix}${line.$id})`\n : undefined;\n\n const { strokeColor, strokeWidth, interactStrokeWidth } = {\n ...line,\n ...(active\n ? line.overrides?.active\n : activeRelated\n ? line.overrides?.activeRelated\n : null),\n };\n\n const expectVariant = active\n ? \"active\"\n : activeRelated\n ? \"active-related\"\n : \"default\";\n\n let markerStart: string | undefined;\n let markerEnd: string | undefined;\n\n for (const marker of markers) {\n if (marker.variant === expectVariant) {\n if (marker.placement === \"start\") {\n markerStart = `url(#${markerPrefix}${marker.index})`;\n } else {\n markerEnd = `url(#${markerPrefix}${marker.index})`;\n }\n }\n }\n\n return (\n <g\n className={classNames(\"line\", {\n interactable: line.interactable,\n active,\n \"active-related\": activeRelated,\n })}\n onClick={\n line.interactable\n ? () => {\n onLineClick?.({ id: line.$id, edge });\n }\n : undefined\n }\n onDoubleClick={\n line.interactable\n ? (e) => {\n e.preventDefault();\n e.stopPropagation();\n onLineDoubleClick?.({ id: line.$id, edge });\n }\n : undefined\n }\n style={{ cursor: line.cursor }}\n >\n {line.interactable && (\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={interactStrokeWidth}\n />\n )}\n <path\n ref={(element) => linePaths.set(line.$id, element)}\n stroke={strokeColor}\n strokeWidth={strokeWidth}\n d={d}\n fill=\"none\"\n markerStart={markerStart}\n markerEnd={markerEnd}\n mask={mask}\n />\n <path\n stroke=\"var(--palette-blue-3)\"\n strokeWidth={strokeWidth}\n d={d}\n fill=\"none\"\n className=\"active-bg\"\n markerStart={`url(#${activeLineMarkerPrefix}start)`}\n markerEnd={`url(#${activeLineMarkerPrefix}end)`}\n mask={mask}\n />\n </g>\n );\n}\n","import React, { useCallback, useEffect, useMemo, useState } from \"react\";\nimport { ReactUseBrick } from \"@next-core/react-runtime\";\nimport { checkIfByTransform } from \"@next-core/runtime\";\nimport type {\n DiagramEdge,\n LineLabelConf,\n // PositionTuple,\n RefRepository,\n LineLabel,\n TextOptions,\n} from \"./interfaces\";\n\nexport interface LineLabelComponentGroupProps {\n labels?: LineLabel[];\n onRendered?: (refRepository: RefRepository | null) => void;\n}\n\nexport function LineLabelComponentGroup({\n labels,\n onRendered,\n}: LineLabelComponentGroupProps): JSX.Element {\n const [rendered, setRendered] = useState(false);\n const [renderedIds, setRenderedIds] = useState<string[]>([]);\n const refRepository = useMemo<RefRepository>(() => new Map(), []);\n\n const handleRenderer = useCallback(\n (id: string, element: HTMLElement | null) => {\n if (element) {\n refRepository.set(id, element);\n }\n setRenderedIds((previous) =>\n previous.includes(id) ? previous : previous.concat(id)\n );\n },\n [refRepository]\n );\n\n const handleUnmount = useCallback(\n (id: string) => {\n setRenderedIds((previous) => {\n const index = previous.indexOf(id);\n return index === -1\n ? previous\n : previous.slice(0, index).concat(previous.slice(index + 1));\n });\n refRepository.delete(id);\n },\n [refRepository]\n );\n\n useEffect(() => {\n // All nodes have been rendered.\n setRendered(!labels?.some((label) => !renderedIds.includes(label.id)));\n }, [labels, renderedIds]);\n\n useEffect(\n () => {\n onRendered?.(rendered ? refRepository : null);\n },\n // Dot not re-run effect when `onRendered` changed.\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [/* onRendered, */ refRepository, rendered]\n );\n\n return (\n <React.Fragment>\n {labels?.map(({ text, label, /* position, */ id, edge }) =>\n label ? (\n <div\n key={id}\n className=\"line-label\"\n // style={{\n // left: position[0],\n // top: position[1],\n // }}\n >\n <LineLabelComponent\n id={id}\n edge={edge}\n label={label}\n onRendered={handleRenderer}\n onUnmount={handleUnmount}\n />\n </div>\n ) : (\n <LineTextComponent\n key={id}\n id={id}\n text={text!}\n // position={position}\n onRendered={handleRenderer}\n />\n )\n )}\n </React.Fragment>\n );\n}\n\nexport interface LineTextComponentProps {\n id: string;\n text: TextOptions;\n // position: PositionTuple;\n onRendered?: (id: string, element: HTMLElement | null) => void;\n // onUnmount?: (id: string) => void;\n}\n\nexport function LineTextComponent({\n id,\n text,\n // position,\n onRendered /* , onUnmount */,\n}: LineTextComponentProps): JSX.Element {\n const refCallback = useCallback(\n (element: HTMLDivElement) => {\n onRendered?.(id, element);\n },\n [id, onRendered]\n );\n\n return (\n <div\n className=\"line-label\"\n ref={refCallback}\n // style={{\n // left: position[0],\n // top: position[1],\n // ...text!.style,\n // }}\n style={text.style}\n >\n {text!.content}\n </div>\n );\n}\n\n// export const LineLabelComponentGroup = React.memo(LegacyLineLabelComponentGroup);\n\nexport interface LineLabelComponentProps {\n id: string;\n edge: DiagramEdge;\n label: LineLabelConf;\n onRendered?: (id: string, element: HTMLElement | null) => void;\n onUnmount?: (id: string) => void;\n}\n\nexport function LineLabelComponent({\n id,\n edge,\n label,\n onRendered,\n onUnmount,\n}: LineLabelComponentProps): JSX.Element | null {\n const useBrick = useMemo(\n () => (checkIfByTransform(label, { edge }) ? label.useBrick : null),\n [edge, label]\n );\n\n const memoizedData = useMemo(() => ({ edge }), [edge]);\n\n useEffect(() => {\n if (!useBrick) {\n // Keep the same time delay for reporting rendered.\n setTimeout(() => {\n onRendered?.(id, null);\n });\n }\n }, [id, onRendered, useBrick]);\n\n useEffect(\n () => {\n return () => {\n onUnmount?.(id);\n };\n },\n // Only unmount once\n // eslint-disable-next-line react-hooks/exhaustive-deps\n []\n );\n\n const refCallback = useCallback(\n (element: HTMLElement | null) => {\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 onRendered?.(id, element.parentElement);\n });\n }\n },\n [id, onRendered]\n );\n\n const ignoredCallback = useCallback(() => {\n setTimeout(() => {\n onRendered?.(id, null);\n });\n }, [id, onRendered]);\n\n if (!useBrick) {\n return null;\n }\n\n return (\n <ReactUseBrick\n refCallback={refCallback}\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore For v3 only\n ignoredCallback={ignoredCallback}\n useBrick={useBrick}\n data={memoizedData}\n />\n );\n}\n","import React from \"react\";\nimport type { RenderedLineLabel, SimpleRect } from \"./interfaces\";\n\nexport interface LineMaskComponentProps {\n maskPrefix: string;\n lineId: string;\n rects: SimpleRect[];\n renderedLineLabels: RenderedLineLabel[];\n}\n\nexport function LineMaskComponent({\n lineId,\n rects,\n maskPrefix,\n renderedLineLabels,\n}: LineMaskComponentProps): JSX.Element | null {\n const lineText = renderedLineLabels.find(\n (item) => item.lineId === lineId && item.placement === \"center\"\n );\n // istanbul ignore next\n if (!lineText) {\n return null;\n }\n const { lineRect } = lineText;\n const bgRect = getRectWithPadding(lineRect, 1000);\n return (\n <mask\n id={`${maskPrefix}${lineId}`}\n x={bgRect.left}\n y={bgRect.top}\n width={bgRect.width}\n height={bgRect.height}\n >\n <rect\n x={bgRect.left}\n y={bgRect.top}\n width={bgRect.width}\n height={bgRect.height}\n // Everything under a white pixel will be visible\n fill=\"white\"\n />\n {rects.map((rect, index) => (\n <rect\n key={index}\n x={rect.left}\n y={rect.top}\n width={rect.width}\n height={rect.height}\n // Everything under a black pixel will be invisible\n fill=\"black\"\n />\n ))}\n </mask>\n );\n}\n\nfunction getRectWithPadding(rect: SimpleRect, padding: number): SimpleRect {\n return {\n left: rect.left - padding,\n top: rect.top - padding,\n width: rect.width + padding * 2,\n height: rect.height + padding * 2,\n };\n}\n","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 React, { useCallback, useEffect, useMemo, useState } from \"react\";\nimport { ReactUseBrick } from \"@next-core/react-runtime\";\nimport type {\n DiagramNode,\n DiagramNodeId,\n NodeBrickConf,\n RefRepository,\n} from \"./interfaces\";\nimport { findNodeBrick } from \"./processors/findNodeBrick\";\n\nexport interface NodeComponentGroupProps {\n nodes?: DiagramNode[];\n nodeBricks?: NodeBrickConf[];\n onRendered?: (refRepository: RefRepository | null) => void;\n}\n\nexport function NodeComponentGroup({\n nodes,\n nodeBricks,\n onRendered,\n}: NodeComponentGroupProps): JSX.Element {\n const [rendered, setRendered] = useState(false);\n const [renderedIds, setRenderedIds] = useState<DiagramNodeId[]>([]);\n const refRepository = useMemo<RefRepository>(() => new Map(), []);\n\n const handleRenderer = useCallback(\n (id: DiagramNodeId, element: HTMLElement | null) => {\n if (element) {\n refRepository.set(id, element);\n }\n setRenderedIds((previous) =>\n previous.includes(id) ? previous : previous.concat(id)\n );\n },\n [refRepository]\n );\n\n const handleUnmount = useCallback(\n (id: DiagramNodeId) => {\n setRenderedIds((previous) => {\n const index = previous.indexOf(id);\n return index === -1\n ? previous\n : previous.slice(0, index).concat(previous.slice(index + 1));\n });\n refRepository.delete(id);\n },\n [refRepository]\n );\n\n useEffect(() => {\n // All nodes have been rendered.\n setRendered(!nodes?.some((node) => !renderedIds.includes(node.id)));\n }, [nodes, renderedIds]);\n\n useEffect(\n () => {\n onRendered?.(rendered ? refRepository : null);\n },\n // Dot not re-run effect when `onRendered` changed.\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [/* onRendered, */ refRepository, rendered]\n );\n\n return (\n <React.Fragment>\n {nodes?.map((node) => (\n <div key={node.id} className=\"node\">\n <NodeComponent\n nodeBricks={nodeBricks}\n node={node}\n onRendered={handleRenderer}\n onUnmount={handleUnmount}\n />\n </div>\n ))}\n </React.Fragment>\n );\n}\n\nexport interface NodeComponentProps {\n node: DiagramNode;\n nodeBricks?: NodeBrickConf[];\n onRendered?: (id: DiagramNodeId, element: HTMLElement | null) => void;\n onUnmount?: (id: DiagramNodeId) => void;\n}\n\nexport function NodeComponent({\n node,\n nodeBricks,\n onRendered,\n onUnmount,\n}: NodeComponentProps): JSX.Element | null {\n const useBrick = useMemo(\n () => findNodeBrick(node, nodeBricks)?.useBrick,\n [node, nodeBricks]\n );\n const memoizedData = useMemo(() => ({ node }), [node]);\n\n useEffect(() => {\n if (!useBrick) {\n // Keep the same time delay for reporting rendered.\n setTimeout(() => {\n onRendered?.(node.id, null);\n });\n }\n }, [node.id, onRendered, useBrick]);\n\n useEffect(\n () => {\n return () => {\n onUnmount?.(node.id);\n };\n },\n // Only unmount once\n // eslint-disable-next-line react-hooks/exhaustive-deps\n []\n );\n\n const refCallback = useCallback(\n (element: HTMLElement | null) => {\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 onRendered?.(node.id, element);\n });\n }\n },\n [node.id, onRendered]\n );\n\n const ignoredCallback = useCallback(() => {\n setTimeout(() => {\n onRendered?.(node.id, null);\n });\n }, [node.id, onRendered]);\n\n if (!useBrick) {\n return null;\n }\n\n return (\n <ReactUseBrick\n refCallback={refCallback}\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore For v3 only\n ignoredCallback={ignoredCallback}\n useBrick={useBrick}\n data={memoizedData}\n />\n );\n}\n","import { checkIfByTransform } from \"@next-core/runtime\";\nimport { NodeBrickConf, DiagramNode } from \"../interfaces\";\n\nexport function findNodeBrick(\n node: DiagramNode,\n nodeBricks: NodeBrickConf[] | undefined\n): NodeBrickConf | undefined {\n return nodeBricks?.find((item) => {\n if (item.nodeType) {\n return ([] as unknown[]).concat(item.nodeType).includes(node.type);\n }\n return checkIfByTransform(item, { node });\n });\n}\n","export const DEFAULT_LINE_STROKE_COLOR = \"var(--palette-gray-5)\";\nexport const DEFAULT_LINE_STROKE_WIDTH = 1;\nexport const DEFAULT_LINE_CURVE_TYPE = \"curveBasis\";\nexport const DEFAULT_LINE_INTERACT_STROKE_WIDTH = 20;\nexport const DEFAULT_SCALE_RANGE_MIN = 0.5;\nexport const DEFAULT_SCALE_RANGE_MAX = 2;\n","import type { FullRectTuple, RefRepository, RenderedNode } from \"../interfaces\";\n\nexport function adjustNodesSize(\n nodes: RenderedNode[],\n nodesRefRepository: RefRepository,\n nodePaddings: FullRectTuple\n) {\n for (const node of nodes) {\n const element = nodesRefRepository.get(node.id);\n node.width =\n Math.max(element?.offsetWidth ?? 0, 10) +\n nodePaddings[1] +\n nodePaddings[3];\n node.height =\n Math.max(element?.offsetHeight ?? 0, 10) +\n nodePaddings[0] +\n nodePaddings[2];\n }\n}\n","import type { FullRectTuple, RefRepository, RenderedNode } from \"../interfaces\";\n\nexport function adjustNodesPosition(\n nodes: RenderedNode[],\n nodesRefRepository: RefRepository,\n nodePaddings: FullRectTuple\n) {\n for (const node of nodes) {\n const x = node.x - node.width / 2 + nodePaddings[3];\n const y = node.y - node.height / 2 + nodePaddings[0];\n\n const nodeContainer = nodesRefRepository.get(node.id)?.parentElement;\n if (nodeContainer) {\n nodeContainer.style.left = `${x}px`;\n nodeContainer.style.top = `${y}px`;\n nodeContainer.style.visibility = \"visible\";\n }\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","// istanbul ignore file: experimental\nimport type {\n DiagramEdge,\n LabelSize,\n RefRepository,\n RenderedEdge,\n} from \"../interfaces\";\n\nexport function getRenderedEdges(\n edges: DiagramEdge[] | undefined,\n {\n normalizedLinesMap,\n lineLabelsRefRepository,\n }: {\n normalizedLinesMap: WeakMap<DiagramEdge, string>;\n lineLabelsRefRepository: RefRepository;\n }\n) {\n return (\n edges?.map<RenderedEdge>((edge) => {\n const lineId = normalizedLinesMap.get(edge);\n const labelSize: LabelSize = {};\n if (lineId) {\n for (const placement of [/* \"center\", */ \"start\", \"end\"] as const) {\n const element = lineLabelsRefRepository.get(`${lineId}-${placement}`);\n if (element) {\n labelSize[placement] = [element.offsetWidth, element.offsetHeight];\n }\n }\n }\n\n return {\n data: edge,\n labelSize,\n };\n }) ?? []\n );\n}\n","// istanbul ignore file: experimental\nimport {\n forceSimulation,\n forceLink,\n forceCollide,\n forceManyBody,\n forceX,\n forceY,\n type Simulation,\n type SimulationNodeDatum,\n type SimulationLinkDatum,\n} from \"d3-force\";\nimport { pick } from \"lodash\";\nimport type {\n DiagramEdge,\n DiagramNode,\n ForceCollideOptions,\n LayoutOptionsForce,\n RenderedNode,\n UnifiedGraph,\n UserViewNodesMap,\n} from \"../interfaces\";\nimport { adjustNodesSize } from \"./adjustNodesSize\";\nimport { adjustNodesPosition } from \"./adjustNodesPosition\";\nimport { extractPartialRectTuple } from \"./extractPartialRectTuple\";\nimport { getRenderedEdges } from \"./getRenderedEdges\";\n\ninterface NormalNode extends SimulationNodeDatum {\n dummy?: false;\n id: string;\n data: DiagramNode;\n width: number;\n height: number;\n}\n\ninterface DummyNode extends SimulationNodeDatum {\n dummy: true;\n id: string;\n}\n\ntype ForceNode = NormalNode | DummyNode;\n\ntype ForceLink = SimulationLinkDatum<ForceNode> & {\n dummy?: boolean;\n};\n\nexport function getForceGraph(\n previousGraph: UnifiedGraph | null,\n nodes: DiagramNode[] | undefined,\n edges: DiagramEdge[] | undefined,\n userViewNodesMap: UserViewNodesMap | null,\n forceLayoutOptions: LayoutOptionsForce | undefined\n): UnifiedGraph {\n const { nodePadding, dummyNodesOnEdges, collide } = {\n nodePadding: 0,\n dummyNodesOnEdges: 0,\n ...pick(forceLayoutOptions, [\"nodePadding\", \"dummyNodesOnEdges\"]),\n collide:\n forceLayoutOptions?.collide !== false\n ? ({\n dummyRadius: 1,\n radiusDiff: 5,\n strength: 1,\n iterations: 1,\n ...(forceLayoutOptions?.collide === true\n ? null\n : (forceLayoutOptions?.collide as ForceCollideOptions)),\n } as Required<ForceCollideOptions>)\n : (false as const),\n };\n const nodePaddings = extractPartialRectTuple(nodePadding);\n\n const renderedNodes: RenderedNode[] = [];\n for (const node of nodes ?? []) {\n const previousNode = previousGraph?.getNode(node.id);\n if (previousNode?.data === node) {\n renderedNodes.push(previousNode);\n } else {\n const renderedNode = {\n id: node.id,\n data: node,\n } as RenderedNode & { fx?: number; fy?: number };\n const userViewNode = userViewNodesMap?.get(node.id);\n if (userViewNode) {\n renderedNode.fx = userViewNode.x;\n renderedNode.fy = userViewNode.y;\n }\n renderedNodes.push(renderedNode);\n }\n }\n\n function getNode(id: string) {\n return renderedNodes.find((node) => node.data.id === id);\n }\n\n return {\n layout: \"force\",\n getNode,\n applyLayout({\n nodesRefRepository,\n lineLabelsRefRepository,\n normalizedLinesMap,\n }) {\n if (renderedNodes.length === 0) {\n return null;\n }\n\n adjustNodesSize(renderedNodes, nodesRefRepository, nodePaddings);\n\n const forceNodes = renderedNodes.slice();\n const forceLinks: ForceLink[] = [];\n\n for (const edge of edges ?? []) {\n forceLinks.push({ ...edge });\n if (dummyNodesOnEdges > 0) {\n forceNodes.push(\n ...(getDummyNodes(\n edge,\n dummyNodesOnEdges\n ) as Partial<RenderedNode>[] as RenderedNode[])\n );\n forceLinks.push(...getDummyEdges(edge, dummyNodesOnEdges));\n }\n }\n\n const linkSimulation = forceLink<ForceNode, ForceLink>(forceLinks).id(\n (d) => d.id\n );\n\n if (dummyNodesOnEdges > 0) {\n linkSimulation\n .distance((l) => (l.dummy ? 30 / (dummyNodesOnEdges + 1) : 30))\n .strength((l) => (l.dummy ? 0.5 : 1));\n }\n\n const simulation = forceSimulation<ForceNode>(forceNodes)\n .force(\"link\", linkSimulation)\n .force(\"x\", forceX())\n .force(\"y\", forceY())\n .force(\"charge\", forceManyBody());\n\n if (collide) {\n simulation.force(\n \"collide\",\n forceCollide<ForceNode>()\n .radius((d) =>\n d.dummy\n ? collide.dummyRadius\n : Math.sqrt(d.width ** 2 + d.height ** 2) / 2 +\n collide.radiusDiff\n )\n .strength(collide.strength)\n .iterations(collide.iterations)\n );\n }\n\n simulation.stop();\n manuallyTickToTheEnd(simulation);\n\n adjustNodesPosition(renderedNodes, nodesRefRepository, nodePaddings);\n\n const renderedEdges = getRenderedEdges(edges, {\n normalizedLinesMap,\n lineLabelsRefRepository,\n });\n\n return { nodes: renderedNodes, edges: renderedEdges };\n },\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\nfunction getDummyNodes(edge: DiagramEdge, count: number): DummyNode[] {\n return new Array(count).fill(null).map<DummyNode>((v, i) => ({\n dummy: true,\n id: `$dummy-${edge.source}-${edge.target}-${i}`,\n }));\n}\n\nfunction getDummyEdges(edge: DiagramEdge, count: number): ForceLink[] {\n return new Array(count + 1).fill(null).map<ForceLink>((v, i) => ({\n dummy: true,\n source:\n i === 0 ? edge.source : `$dummy-${edge.source}-${edge.target}-${i - 1}`,\n target:\n i === count ? edge.target : `$dummy-${edge.source}-${edge.target}-${i}`,\n }));\n}\n","import { useEffect, useState } from \"react\";\nimport type {\n DiagramEdge,\n DiagramNode,\n LayoutOptions,\n LayoutOptionsDagre,\n LayoutOptionsForce,\n ManualLayoutStatus,\n NodeMovement,\n RefRepository,\n RenderedDiagram,\n UnifiedGraph,\n UserViewNodesMap,\n} from \"../interfaces\";\nimport { getDagreGraph } from \"../processors/getDagreGraph\";\nimport { getForceGraph } from \"../processors/getForceGraph\";\nimport { getManualGraph } from \"../processors/getManualGraph\";\n\nexport function useRenderedDiagram({\n layout: originalLayout,\n nodes,\n edges,\n manualLayoutStatus,\n userViewReady,\n userViewNodesMap,\n nodeMovement,\n nodesRefRepository,\n lineLabelsRefRepository,\n normalizedLinesMap,\n nodesRenderId,\n lineLabelsRenderId,\n layoutOptions,\n}: {\n layout: \"dagre\" | \"force\" | undefined;\n nodes: DiagramNode[] | undefined;\n edges: DiagramEdge[] | undefined;\n manualLayoutStatus: ManualLayoutStatus;\n userViewReady: boolean;\n userViewNodesMap: UserViewNodesMap | null;\n nodeMovement: NodeMovement | null;\n nodesRefRepository: RefRepository | null;\n lineLabelsRefRepository: RefRepository | null;\n normalizedLinesMap: WeakMap<DiagramEdge, string>;\n nodesRenderId: number;\n lineLabelsRenderId: number;\n layoutOptions?: LayoutOptions;\n}) {\n const layout = manualLayoutStatus === \"initial\" ? originalLayout : \"manual\";\n const [graph, setGraph] = useState<UnifiedGraph | null>(null);\n\n const [renderedDiagram, setRenderedDiagram] = useState<RenderedDiagram>({\n nodes: [],\n edges: [],\n });\n\n useEffect(() => {\n if (!userViewReady) {\n return;\n }\n setGraph((previousGraph) =>\n layout === \"dagre\"\n ? getDagreGraph(\n previousGraph,\n nodes,\n edges,\n layoutOptions as LayoutOptionsDagre\n )\n : layout === \"force\"\n ? getForceGraph(\n previousGraph,\n nodes,\n edges,\n userViewNodesMap,\n layoutOptions as LayoutOptionsForce\n )\n : layout === \"manual\"\n ? getManualGraph(previousGraph, nodes, edges, layoutOptions)\n : null\n );\n }, [edges, nodes, layout, layoutOptions, userViewReady, userViewNodesMap]);\n\n useEffect(() => {\n if (\n !nodesRefRepository ||\n !lineLabelsRefRepository ||\n layout !== graph?.layout\n ) {\n return;\n }\n const renderedDiagram = graph?.applyLayout({\n manualLayoutStatus,\n nodesRefRepository,\n lineLabelsRefRepository,\n normalizedLinesMap,\n nodeMovement,\n });\n if (renderedDiagram) {\n setRenderedDiagram(renderedDiagram);\n }\n }, [\n layout,\n manualLayoutStatus,\n graph,\n nodeMovement,\n nodesRefRepository,\n lineLabelsRefRepository,\n nodesRenderId,\n lineLabelsRenderId,\n normalizedLinesMap,\n ]);\n\n return renderedDiagram;\n}\n","import dagre from \"@dagrejs/dagre\";\nimport { pick } from \"lodash\";\nimport type {\n DiagramEdge,\n DiagramNode,\n LayoutOptionsDagre,\n RenderedEdge,\n RenderedNode,\n UnifiedGraph,\n} from \"../interfaces\";\nimport { adjustNodesSize } from \"./adjustNodesSize\";\nimport { adjustNodesPosition } from \"./adjustNodesPosition\";\nimport { extractPartialRectTuple } from \"./extractPartialRectTuple\";\n\nexport function getDagreGraph(\n previousGraph: UnifiedGraph | null,\n nodes: DiagramNode[] | undefined,\n edges: DiagramEdge[] | undefined,\n dagreLayoutOptions: LayoutOptionsDagre | undefined\n): UnifiedGraph {\n const { nodePadding, ...dagreGraphOptions } = {\n nodePadding: 0,\n rankdir: \"TB\",\n ranksep: 50,\n edgesep: 10,\n nodesep: 50,\n // align: undefined,\n ...pick(dagreLayoutOptions, [\n \"nodePadding\",\n \"rankdir\",\n \"ranksep\",\n \"edgesep\",\n \"nodesep\",\n \"align\",\n ]),\n };\n const nodePaddings = extractPartialRectTuple(nodePadding);\n\n // Create a new directed graph\n const graph = new dagre.graphlib.Graph<RenderedNode>();\n\n // Set an object for the graph label\n graph.setGraph(dagreGraphOptions);\n\n // Default to assigning a new object as a label for each new edge.\n graph.setDefaultEdgeLabel(function () {\n return {};\n });\n\n for (const node of nodes ?? []) {\n const previousNode = previousGraph?.getNode(node.id);\n graph.setNode(\n node.id,\n previousNode?.data === node\n ? previousNode\n : {\n id: node.id,\n data: node,\n }\n );\n }\n\n for (const edge of edges ?? []) {\n graph.setEdge(edge.source, edge.target, { data: edge });\n }\n\n return {\n layout: \"dagre\",\n getNode(id) {\n return graph.node(id);\n },\n applyLayout({\n nodesRefRepository,\n lineLabelsRefRepository,\n normalizedLinesMap,\n }) {\n const renderedNodes: RenderedNode[] = [];\n for (const id of graph.nodes()) {\n const node = graph.node(id);\n if (node) {\n renderedNodes.push(node);\n } else {\n // eslint-disable-next-line no-console\n console.error(\"Diagram node not found: %s\", id);\n }\n }\n\n if (renderedNodes.length === 0) {\n return null;\n }\n\n adjustNodesSize(renderedNodes, nodesRefRepository, nodePaddings);\n\n const renderedEdges = graph\n .edges()\n .map((e) => graph.edge(e) as RenderedEdge);\n for (const edge of renderedEdges) {\n const lineId = normalizedLinesMap.get(edge.data);\n if (lineId) {\n for (const placement of [\"center\", \"start\", \"end\"] as const) {\n const element = lineLabelsRefRepository.get(\n `${lineId}-${placement}`\n );\n if (element) {\n const { offsetWidth, offsetHeight } = element;\n if (placement === \"center\") {\n edge.labelpos = \"c\";\n edge.width = offsetWidth;\n edge.height = offsetHeight;\n }\n edge.labelSize ??= {};\n edge.labelSize[placement] = [offsetWidth, offsetHeight];\n }\n }\n }\n }\n dagre.layout(graph);\n\n adjustNodesPosition(renderedNodes, nodesRefRepository, nodePaddings);\n\n return {\n nodes: renderedNodes,\n edges: renderedEdges,\n };\n },\n };\n}\n","// istanbul ignore file: experimental\nimport { pick } from \"lodash\";\nimport type {\n DiagramEdge,\n DiagramNode,\n BaseLayoutOptions,\n RenderedNode,\n UnifiedGraph,\n} from \"../interfaces\";\nimport { extractPartialRectTuple } from \"./extractPartialRectTuple\";\nimport { adjustNodesSize } from \"./adjustNodesSize\";\nimport { adjustNodesPosition } from \"./adjustNodesPosition\";\nimport { getRenderedEdges } from \"./getRenderedEdges\";\n\nexport function getManualGraph(\n previousGraph: UnifiedGraph | null,\n nodes: DiagramNode[] | undefined,\n edges: DiagramEdge[] | undefined,\n layoutOptions: BaseLayoutOptions | undefined\n): UnifiedGraph {\n const { nodePadding } = {\n nodePadding: 0,\n ...pick(layoutOptions, [\"nodePadding\"]),\n };\n const nodePaddings = extractPartialRectTuple(nodePadding);\n\n const renderedNodes: RenderedNode[] = [];\n for (const node of nodes ?? []) {\n const previousNode = previousGraph?.getNode(node.id);\n if (previousNode?.data === node) {\n renderedNodes.push(previousNode);\n previousNode.x0 = previousNode.x;\n previousNode.y0 = previousNode.y;\n } else {\n renderedNodes.push({\n id: node.id,\n data: node,\n } as RenderedNode);\n }\n }\n\n function getNode(id: string) {\n return renderedNodes.find((node) => node.data.id === id);\n }\n\n let movedNode: RenderedNode | undefined;\n\n return {\n layout: \"manual\",\n getNode,\n applyLayout({\n manualLayoutStatus,\n nodesRefRepository,\n lineLabelsRefRepository,\n normalizedLinesMap,\n nodeMovement,\n }) {\n if (renderedNodes.length === 0) {\n return null;\n }\n\n adjustNodesSize(renderedNodes, nodesRefRepository, nodePaddings);\n\n if (nodeMovement) {\n movedNode = renderedNodes.find((node) => node.id === nodeMovement.id);\n if (movedNode) {\n movedNode.x = (movedNode.x0 ?? 0) + nodeMovement.move[0];\n movedNode.y = (movedNode.y0 ?? 0) + nodeMovement.move[1];\n }\n }\n\n if (manualLayoutStatus === \"finished\" && movedNode) {\n // Set x0/y0 after finished manual layout\n movedNode.x0 = movedNode.x;\n movedNode.y0 = movedNode.y;\n }\n\n adjustNodesPosition(renderedNodes, nodesRefRepository, nodePaddings);\n\n const renderedEdges = getRenderedEdges(edges, {\n normalizedLinesMap,\n lineLabelsRefRepository,\n });\n\n return { nodes: renderedNodes, edges: renderedEdges };\n },\n };\n}\n","import { useCallback, useEffect, useMemo, useRef, useState } from \"react\";\nimport { handleHttpError } from \"@next-core/runtime\";\nimport {\n InstanceApi_postSearchV3,\n InstanceApi_updateInstanceV2,\n InstanceApi_createInstance,\n} from \"@next-api-sdk/cmdb-sdk\";\nimport { createAsyncQueue } from \"../processors/createAsyncQueue\";\nimport {\n NodeUserView,\n UserView,\n UserViewNodesMap,\n UserViewQuery,\n} from \"../interfaces\";\n\nconst USER_VIEW_MODEL_ID = \"GRAPH_USER_VIEW@EASYOPS\";\n\nexport interface UserViewHook {\n userViewReady: boolean;\n userViewNodesMap: UserViewNodesMap | null;\n saveUserView: (nodes: NodeUserView[]) => void;\n}\n\nexport function useUserView(query: UserViewQuery | undefined): UserViewHook {\n const [userViewReady, setUserViewReady] = useState(!query);\n const userViewIdRef = useRef<string>();\n const [userViewNodesMap, setUserViewNodesMap] =\n useState<UserViewNodesMap | null>(null);\n const queue = useMemo(() => createAsyncQueue(), []);\n\n useEffect(() => {\n async function getUserView(): Promise<void> {\n if (!query) {\n setUserViewReady(true);\n return;\n }\n const { namespace, key } = query;\n if (!(namespace && key)) {\n // eslint-disable-next-line no-console\n console.error(\"Namespace and key are required to save graph user view\");\n setUserViewReady(true);\n return;\n }\n try {\n const list = (\n await InstanceApi_postSearchV3(USER_VIEW_MODEL_ID, {\n fields: [\"nodes\"],\n query: {\n namespace: {\n $eq: namespace,\n },\n key: {\n $eq: key,\n },\n },\n page: 1,\n page_size: 30,\n })\n ).list as UserView[];\n if (list.length > 0) {\n const userView = list[0];\n const userViewNodesMap = new Map(\n userView.nodes?.map((node) => [node.id, node])\n );\n userViewIdRef.current = userView.instanceId;\n setUserViewNodesMap(userViewNodesMap);\n } else {\n setUserViewNodesMap(null);\n }\n } catch (error) {\n handleHttpError(error as Error);\n } finally {\n setUserViewReady(true);\n }\n }\n getUserView();\n }, [query]);\n\n const saveUserView = useCallback(\n (nodes: NodeUserView[]) => {\n const { namespace, key } = query ?? {};\n if (!(namespace && key)) {\n return;\n }\n queue(async () => {\n const userViewData = {\n namespace,\n key,\n nodes,\n };\n try {\n if (userViewIdRef.current) {\n await InstanceApi_updateInstanceV2(\n USER_VIEW_MODEL_ID,\n userViewIdRef.current,\n userViewData,\n {\n interceptorParams: {\n ignoreLoadingBar: true,\n },\n }\n );\n } else {\n const userView = await InstanceApi_createInstance(\n USER_VIEW_MODEL_ID,\n userViewData,\n {\n interceptorParams: {\n ignoreLoadingBar: true,\n },\n }\n );\n userViewIdRef.current = userView.instanceId;\n }\n } catch (error) {\n handleHttpError(error);\n }\n });\n },\n [query, queue]\n );\n\n return {\n userViewReady,\n userViewNodesMap,\n saveUserView,\n };\n}\n","type Task = (...args: unknown[]) => unknown;\ntype Queue = (task: Task) => Promise<void>;\n\nexport function createAsyncQueue(): Queue {\n let working = false;\n const waitingTasks: Task[] = [];\n return async function queue(task: Task) {\n waitingTasks.push(task);\n if (!working) {\n working = true;\n let nextTask: Task | undefined;\n while ((nextTask = waitingTasks.shift())) {\n try {\n await nextTask();\n } catch (error) {\n // eslint-disable-next-line no-console\n console.error(error);\n }\n }\n working = false;\n }\n };\n}\n","import type { NodePosition, NodeRect } from \"../interfaces\";\nimport { doTwoNodesOverlap } from \"../processors/doTwoNodesOverlap\";\n\nexport function getDirectLinePoints(\n source: NodeRect,\n target: NodeRect\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 const dx = target.x - source.x;\n const dy = target.y - source.y;\n\n let x0: number, y0: number, x1: number, y1: number;\n const directionX = dx > 0 ? 1 : -1;\n if (dy !== 0) {\n const deltaRadio = Math.abs(dx / dy);\n const directionY = dy > 0 ? 1 : -1;\n const sourceRadio = source.width / source.height;\n if (deltaRadio < sourceRadio) {\n x0 = source.x + ((deltaRadio * source.height) / 2) * directionX;\n y0 = source.y + (source.height / 2) * directionY;\n } else {\n x0 = source.x + (source.width / 2) * directionX;\n y0 = source.y + (source.width / 2 / deltaRadio) * directionY;\n }\n const targetRadio = target.width / target.height;\n if (deltaRadio < targetRadio) {\n x1 = target.x - ((deltaRadio * target.height) / 2) * directionX;\n y1 = target.y - (target.height / 2) * directionY;\n } else {\n x1 = target.x - (target.width / 2) * directionX;\n y1 = target.y - (target.width / 2 / deltaRadio) * directionY;\n }\n } else {\n x0 = source.x + (source.width / 2) * directionX;\n x1 = target.x - (target.width / 2) * directionX;\n y0 = y1 = source.y;\n }\n\n return [\n { x: x0, y: y0 },\n { x: x1, y: y1 },\n ];\n}\n","import type { RefRepository, RenderedLineLabel } from \"../interfaces\";\n\nexport function adjustLineLabels(\n renderedLineLabels: RenderedLineLabel[],\n lineLabelsRefRepository: RefRepository\n) {\n for (const {\n id,\n position,\n placement,\n angle,\n size: _size,\n } of renderedLineLabels) {\n const label = lineLabelsRefRepository.get(id);\n if (label) {\n label.style.left = `${position[0]}px`;\n label.style.top = `${position[1]}px`;\n label.style.visibility = \"visible\";\n // label.classList.add(placement);\n if (placement !== \"center\" && angle !== undefined) {\n const [width, height] = _size ?? [0, 0];\n // Get the numbered direction of the line\n //\n // \\ | /\n // \\ 5 | 6 /\n // 4 \\ | / 7\n // -----x-----\n // 3 / | \\ 0\n // / 2 | 1 \\\n // / | \\\n const tempDirection = Math.floor(\n ((angle < 0 ? Math.PI * 2 + angle : angle) / Math.PI) * 4\n );\n // Swap direction for end labels.\n const direction =\n placement === \"start\" ? tempDirection : (tempDirection + 4) % 8;\n const tangent = Math.tan(angle);\n const offsetAngle =\n angle + ((placement === \"start\" ? 1 : -1) * Math.PI) / 2;\n const offset = 2;\n const offsetSin = Math.sin(offsetAngle) * offset;\n const offsetCos = Math.cos(offsetAngle) * offset;\n let transform: string;\n switch (direction) {\n case 0:\n transform = `translate(0,${width * tangent + offsetSin}px)`;\n break;\n case 1:\n transform = `translate(${height / tangent - offsetCos}px,0)`;\n break;\n case 2:\n transform = `translate(calc(${\n height / tangent + offsetCos\n }px - 100%),0)`;\n break;\n case 3:\n transform = `translate(-100%,${-width * tangent - offsetSin}px)`;\n break;\n case 4:\n transform = `translate(-100%,calc(${\n -width * tangent + offsetSin\n }px - 100%))`;\n break;\n case 5:\n transform = `translate(calc(${\n -height / tangent - offsetCos\n }px - 100%),-100%)`;\n break;\n case 6:\n transform = `translate(${-height / tangent + offsetCos}px,-100%)`;\n break;\n default:\n transform = `translate(0,calc(${\n width * tangent - offsetSin\n }px - 100%))`;\n }\n label.style.transform = transform;\n }\n }\n }\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 {\n LineMaskRects,\n RefRepository,\n RenderedLineLabel,\n} from \"../interfaces\";\n\nexport function getLineMaskRects(\n renderedLineLabels: RenderedLineLabel[],\n lineLabelsRefRepository: RefRepository\n) {\n const map: LineMaskRects = new Map();\n\n for (const { id, lineId, placement } of renderedLineLabels) {\n if (!lineLabelsRefRepository || placement !== \"center\") {\n continue;\n }\n const element = lineLabelsRefRepository.get(id);\n if (!element) {\n continue;\n }\n const { offsetWidth, offsetHeight } = element;\n // Do not mask out when the label takes no space.\n // istanbul ignore next\n if (\n process.env.NODE_ENV !== \"test\" &&\n (offsetWidth === 0 || offsetHeight === 0)\n ) {\n continue;\n }\n const padding = 3;\n // Currently no other rects\n map.set(lineId, [\n {\n left: element.offsetLeft - offsetWidth / 2 - padding,\n top: element.offsetTop - offsetHeight / 2 - padding,\n width: offsetWidth + padding * 2,\n height: offsetHeight + padding * 2,\n },\n ]);\n }\n\n return map;\n}\n","import type {\n LineLabelConf,\n RenderedLine,\n RenderedLineLabel,\n TextOptions,\n} from \"../interfaces\";\n\nexport function getRenderedLineLabels(\n previous: RenderedLineLabel[],\n renderedLines: RenderedLine[],\n linePaths: Map<string, SVGPathElement | null>\n) {\n if (previous.length === 0 && renderedLines.length === 0) {\n return previous;\n }\n return renderedLines.flatMap(\n ({ line: { text, label, $id }, edge, labelSize, angle }) => {\n const path = linePaths.get($id);\n if ((!text && !label) || !path || !path.getAttribute(\"d\")) {\n return [] as RenderedLineLabel[];\n }\n\n let key: \"label\" | \"text\";\n let list: LineLabelConf[] | TextOptions[];\n if (label) {\n key = \"label\";\n list = ([] as LineLabelConf[]).concat(label);\n } else {\n key = \"text\";\n list = ([] as TextOptions[]).concat(text!);\n }\n\n // istanbul ignore next\n const {\n x: left,\n y: top,\n width,\n height,\n } = process.env.NODE_ENV === \"test\"\n ? { x: 10, y: 20, width: 300, height: 400 }\n : path.getBBox();\n\n // istanbul ignore next\n const pathLength =\n process.env.NODE_ENV === \"test\" ? 50 : path.getTotalLength();\n\n return list.map<RenderedLineLabel>((item) => {\n const placement = item.placement ?? \"center\";\n const offset = 0;\n // istanbul ignore next\n const point =\n process.env.NODE_ENV === \"test\"\n ? { x: 50, y: 50 }\n : path.getPointAtLength(\n placement === \"start\"\n ? Math.min(offset, pathLength / 2)\n : placement === \"end\"\n ? Math.max(pathLength - offset, pathLength / 2)\n : pathLength / 2\n );\n\n return {\n [key as \"label\"]: item as LineLabelConf,\n edge,\n position: [point.x, point.y],\n lineRect: { left, top, width, height },\n id: `${$id}-${placement}`,\n lineId: $id,\n placement,\n angle,\n size: labelSize?.[placement],\n };\n });\n }\n );\n}\n","import {\n curveLinear,\n line,\n curveBasis,\n curveBumpX,\n curveBumpY,\n type CurveFactory,\n curveMonotoneX,\n curveNatural,\n curveMonotoneY,\n} from \"d3-shape\";\nimport type { CurveType, NodePosition } from \"../interfaces\";\n\n/**\n * Generate Line from points\n */\nexport function curveLine(\n points: Array<NodePosition> | null | undefined,\n curveType: CurveType | undefined,\n startOffset: number,\n endOffset: number\n): string {\n if (!Array.isArray(points)) {\n return \"\";\n }\n let curveFactory: CurveFactory;\n switch (curveType) {\n case \"curveLinear\":\n curveFactory = curveLinear;\n break;\n case \"curveBumpX\":\n curveFactory = curveBumpX;\n break;\n case \"curveBumpY\":\n curveFactory = curveBumpY;\n break;\n case \"curveMonotoneX\":\n curveFactory = curveMonotoneX;\n break;\n case \"curveMonotoneY\":\n curveFactory = curveMonotoneY;\n break;\n case \"curveNatural\":\n curveFactory = curveNatural;\n break;\n default:\n curveFactory = curveBasis;\n }\n const startOffsets = getOffsets(points[1], points[0], startOffset);\n const endOffsets = getOffsets(\n points[points.length - 2],\n points[points.length - 1],\n endOffset\n );\n const lineFunction = line()\n .x(\n (d, index) =>\n (d as unknown as { x: number }).x -\n (index === 0\n ? startOffsets.x\n : index === points.length - 1\n ? endOffsets.x\n : 0)\n )\n .y(\n (d, index) =>\n (d as unknown as { y: number }).y -\n (index === 0\n ? startOffsets.y\n : index === points.length - 1\n ? endOffsets.y\n : 0)\n )\n .curve(curveFactory);\n return lineFunction(points as unknown as Array<[number, number]>)!;\n}\n\nfunction getOffsets(\n start: NodePosition,\n end: NodePosition,\n offset: number\n): NodePosition {\n if (!offset) {\n return { x: 0, y: 0 };\n }\n const { x: x0, y: y0 } = start;\n const { x: x1, y: y1 } = end;\n const distance = Math.sqrt(Math.pow(x1 - x0, 2) + Math.pow(y1 - y0, 2));\n const ratio = offset / distance;\n return {\n x: (x1 - x0) * ratio,\n y: (y1 - y0) * ratio,\n };\n}\n","import type { Direction, NodePosition, RenderedNode } from \"../interfaces\";\n\nexport function getPolyLinePoints(\n source: RenderedNode,\n target: RenderedNode,\n sourceDirection: Direction,\n targetDirection: Direction,\n sourcePosition: number,\n targetPosition: number\n): NodePosition[] | null {\n const p0 = getCoordinates(source, sourceDirection, sourcePosition);\n const p1 = getCoordinates(target, targetDirection, targetPosition);\n\n let c1: NodePosition;\n let c2: NodePosition;\n switch (sourceDirection) {\n case \"top\":\n case \"bottom\":\n switch (targetDirection) {\n default:\n c1 = { x: p0.x, y: (p0.y + p1.y) / 2 };\n c2 = { x: p1.x, y: c1.y };\n break;\n }\n break;\n default:\n switch (targetDirection) {\n default:\n c1 = { x: (p0.x + p1.x) / 2, y: p0.y };\n c2 = { x: c1.x, y: p1.y };\n break;\n }\n }\n\n return [p0, c1, c2, p1];\n}\n\nfunction getCoordinates(\n node: RenderedNode,\n direction: Direction,\n position: number\n): NodePosition {\n const { x, y, width, height } = node;\n switch (direction) {\n case \"top\":\n return {\n x: x - width / 2 + width * position,\n y: y - height / 2,\n };\n case \"bottom\":\n return {\n x: x - width / 2 + width * position,\n y: y + height / 2,\n };\n case \"left\":\n return {\n x: x - width / 2,\n y: y - height / 2 + height * position,\n };\n case \"right\":\n return {\n x: x + width / 2,\n y: y - height / 2 + height * position,\n };\n }\n}\n","// istanbul ignore file: experimental\nimport type {\n DiagramEdge,\n Direction,\n NormalizedLine,\n RenderedEdge,\n RenderedLine,\n RenderedNode,\n} from \"../interfaces\";\nimport { curveLine } from \"../lines/curveLine\";\nimport { getDirectLinePoints } from \"../lines/getDirectLinePoints\";\nimport { getPolyLinePoints } from \"../lines/getPolyLinePoints\";\nimport { doTwoNodesOverlap } from \"./doTwoNodesOverlap\";\n\nexport function getRenderedLines(\n renderedEdges: RenderedEdge[],\n renderedNodes: RenderedNode[],\n normalizedLines: NormalizedLine[]\n): RenderedLine[] {\n const renderedEdgeMap = new WeakMap<DiagramEdge, RenderedEdge>();\n const renderedNodeMap = new Map<string, RenderedNode>();\n const relatedNodes = new Map<string, Set<RenderedNode>>();\n\n for (const renderedNode of renderedNodes) {\n renderedNodeMap.set(renderedNode.id, renderedNode);\n }\n\n for (const renderedEdge of renderedEdges) {\n const { data: edge } = renderedEdge;\n renderedEdgeMap.set(edge, renderedEdge);\n }\n\n let prepared = false;\n const prepareRelatedNodes = () => {\n if (prepared) {\n return;\n }\n prepared = true;\n\n const addRelatedNodes = (from: string, to: string) => {\n let relates = relatedNodes.get(from);\n if (!relates) {\n relatedNodes.set(from, (relates = new Set()));\n }\n const toNode = renderedNodeMap.get(to);\n if (toNode) {\n relates.add(toNode);\n }\n };\n\n for (const {\n data: { source, target },\n } of renderedEdges) {\n if (source !== target) {\n addRelatedNodes(source, target);\n addRelatedNodes(target, source);\n }\n }\n };\n\n return normalizedLines\n .map<RenderedLine | undefined>(({ line, edge, markers, ...rest }) => {\n const renderedEdge = renderedEdgeMap.get(edge);\n if (!renderedEdge) {\n return;\n }\n const startMarkerOffset =\n markers.find(\n (marker) =>\n marker.variant === \"default\" && marker.placement === \"start\"\n )?.offset ?? 0;\n const endMarkerOffset =\n markers.find(\n (marker) => marker.variant === \"default\" && marker.placement === \"end\"\n )?.offset ?? 0;\n let angle: number | undefined;\n\n let { points } = renderedEdge;\n // Only dagre graph will have pre-calculated line points\n if (!points) {\n const source = renderedNodeMap.get(edge.source);\n const target = renderedNodeMap.get(edge.target);\n\n if (source && target && source !== target) {\n if (line.type === \"polyline\") {\n if (\n !doTwoNodesOverlap(\n source,\n target,\n startMarkerOffset,\n endMarkerOffset\n )\n ) {\n prepareRelatedNodes();\n const sourceDirection = getDirection(\n source,\n target,\n startMarkerOffset\n );\n const targetDirection = getDirection(\n target,\n source,\n endMarkerOffset\n );\n const sourceRelates = getOrderedRelates(\n relatedNodes.get(edge.source) ?? [],\n source,\n sourceDirection,\n startMarkerOffset\n );\n const targetRelates = getOrderedRelates(\n relatedNodes.get(edge.target) ?? [],\n target,\n targetDirection,\n endMarkerOffset\n );\n\n const sourcePosition =\n (sourceRelates.indexOf(target) + 1) /\n (sourceRelates.length + 1);\n const targetPosition =\n (targetRelates.indexOf(source) + 1) /\n (targetRelates.length + 1);\n\n points = getPolyLinePoints(\n source,\n target,\n sourceDirection,\n targetDirection,\n sourcePosition,\n targetPosition\n );\n }\n } else {\n points = getDirectLinePoints(source, target);\n }\n\n if (points) {\n const start = points[0];\n const end = points[points.length - 1];\n angle = Math.atan2(end.y - start.y, end.x - start.x);\n }\n }\n }\n\n const d = curveLine(\n points,\n line.curveType,\n startMarkerOffset,\n endMarkerOffset\n );\n return {\n ...rest,\n markers,\n line,\n edge,\n d,\n angle,\n labelSize: renderedEdge.labelSize,\n };\n })\n .filter(Boolean) as RenderedLine[];\n}\n\nfunction getDirection(\n source: RenderedNode,\n target: RenderedNode,\n padding: number\n): Direction {\n // Add a padding to the source node to avoid the markers being warped.\n const sourceAngle = Math.atan2(\n source.height + padding * 2,\n source.width + padding * 2\n );\n const { x: sx, y: sy } = source;\n const { x: tx, y: ty } = target;\n const angle = Math.atan2(ty - sy, tx - sx);\n const fixedAngle = angle < 0 ? Math.PI * 2 + angle : angle;\n const direction = Math.floor((fixedAngle / Math.PI) * 2);\n switch (direction) {\n case 0:\n return fixedAngle < sourceAngle ? \"right\" : \"bottom\";\n case 1:\n return fixedAngle < Math.PI - sourceAngle ? \"bottom\" : \"left\";\n case 2:\n return fixedAngle < Math.PI + sourceAngle ? \"left\" : \"top\";\n default:\n return fixedAngle < Math.PI * 2 - sourceAngle ? \"top\" : \"right\";\n }\n}\n\nfunction getOrderedRelates(\n relates: Iterable<RenderedNode>,\n from: RenderedNode,\n direction: Direction,\n padding: number\n): RenderedNode[] {\n return [...relates]\n .filter((node) => getDirection(from, node, padding) === direction)\n .sort((a, b) => {\n const { x: ax, y: ay } = a;\n const { x: bx, y: by } = b;\n return direction === \"top\" || direction === \"bottom\" ? ax - bx : ay - by;\n });\n}\n","import { minBy } from \"lodash\";\nimport type {\n ActiveTarget,\n DiagramEdge,\n DiagramNode,\n RenderedNode,\n} from \"../interfaces\";\n\nexport type KeyboardAction =\n | KeyboardActionSwitchActiveNode\n | KeyboardActionDeleteNode\n | KeyboardActionDeleteEdge;\n\nexport interface KeyboardActionSwitchActiveNode {\n action: \"switch-active-node\";\n node?: DiagramNode;\n}\n\nexport interface KeyboardActionDeleteNode {\n action: \"delete-node\";\n node: DiagramNode;\n}\n\nexport interface KeyboardActionDeleteEdge {\n action: \"delete-edge\";\n edge: DiagramEdge;\n}\n\nexport function handleKeyboard(\n event: KeyboardEvent,\n {\n renderedNodes,\n activeTarget,\n }: {\n renderedNodes: RenderedNode[];\n activeTarget: ActiveTarget | null | undefined;\n }\n): KeyboardAction | undefined {\n const activeNode =\n activeTarget?.type === \"node\"\n ? renderedNodes.find((node) => node.id === activeTarget.nodeId)\n : undefined;\n const activeEdge =\n activeTarget?.type === \"edge\" ? activeTarget.edge : undefined;\n\n if (!activeNode && !activeEdge) {\n return;\n }\n\n const key =\n event.key ||\n /* istanbul ignore next: compatibility */ event.keyCode ||\n /* istanbul ignore next: compatibility */ event.which;\n let action: KeyboardAction[\"action\"] | undefined;\n let node: RenderedNode | undefined;\n let edge: DiagramEdge | undefined;\n\n switch (key) {\n case \"Backspace\":\n case 8:\n case \"Delete\":\n case 46: {\n if (activeNode) {\n action = \"delete-node\";\n node = activeNode;\n } else {\n action = \"delete-edge\";\n edge = activeEdge;\n }\n break;\n }\n default:\n if (!activeNode) {\n return;\n }\n switch (key) {\n case \"ArrowLeft\":\n case 37: {\n node = moveOnAxis(\"x\", renderedNodes, activeNode, -1);\n action = \"switch-active-node\";\n break;\n }\n case \"ArrowUp\":\n case 38: {\n node = moveOnAxis(\"y\", renderedNodes, activeNode, -1);\n action = \"switch-active-node\";\n break;\n }\n case \"ArrowRight\":\n case 39: {\n node = moveOnAxis(\"x\", renderedNodes, activeNode, 1);\n action = \"switch-active-node\";\n break;\n }\n case \"ArrowDown\":\n case 40: {\n node = moveOnAxis(\"y\", renderedNodes, activeNode, 1);\n action = \"switch-active-node\";\n break;\n }\n }\n }\n if (action) {\n event.preventDefault();\n event.stopPropagation();\n return { action, node: node?.data, edge } as KeyboardAction;\n }\n}\n\nfunction moveOnAxis(\n axis: \"x\" | \"y\",\n renderedNodes: RenderedNode[],\n activeNode: RenderedNode,\n direction: 1 | -1\n) {\n const oppositeAxis = axis === \"x\" ? \"y\" : \"x\";\n let diff: number;\n const candidates = renderedNodes.filter(\n (node) =>\n node !== activeNode &&\n ((diff = (node[axis] - activeNode[axis]) * direction), diff > 0) &&\n diff > Math.abs(activeNode[oppositeAxis] - node[oppositeAxis])\n );\n return minBy(\n candidates,\n (node) =>\n (activeNode[oppositeAxis] - node[oppositeAxis]) ** 2 +\n (activeNode[axis] - node[axis]) ** 2\n );\n}\n","import { checkIfByTransform, __secret_internals } from \"@next-core/runtime\";\nimport type React from \"react\";\nimport {\n DEFAULT_LINE_STROKE_COLOR,\n DEFAULT_LINE_STROKE_WIDTH,\n} from \"../constants\";\nimport type {\n ConnectLineState,\n DiagramNode,\n ConnectLineDetail,\n ConnectNodesOptions,\n PositionTuple,\n RefRepository,\n ActiveTarget,\n DragNodesOptions,\n NodesFilterOptions,\n NodeMovement,\n ManualLayoutStatus,\n} from \"../interfaces\";\n\nexport function handleNodesMouseDown(\n event: MouseEvent,\n {\n nodes,\n nodesRefRepository,\n connectNodes,\n dragNodes,\n scale,\n setConnectLineState,\n setConnectLineTo,\n setManualLayoutStatus,\n setNodeMovement,\n onSwitchActiveTarget,\n onNodesConnect,\n }: {\n nodes: DiagramNode[] | undefined;\n connectNodes: ConnectNodesOptions | undefined;\n dragNodes: DragNodesOptions | undefined;\n nodesRefRepository: RefRepository | null;\n scale: number;\n setConnectLineState: (\n value: React.SetStateAction<ConnectLineState | null>\n ) => void;\n setConnectLineTo: (value: React.SetStateAction<PositionTuple>) => void;\n setManualLayoutStatus: (\n value: React.SetStateAction<ManualLayoutStatus>\n ) => void;\n setNodeMovement: (value: React.SetStateAction<NodeMovement | null>) => void;\n onSwitchActiveTarget?(target: ActiveTarget | null): void;\n onNodesConnect?(detail: ConnectLineDetail): void;\n }\n) {\n function findNode(match: (element: HTMLElement) => boolean) {\n if (nodesRefRepository) {\n for (const [id, element] of nodesRefRepository) {\n if (match(element)) {\n return nodes?.find((node) => node.id === id);\n }\n }\n }\n }\n\n if (!connectNodes && !dragNodes) {\n return;\n }\n\n const source = findNode((element) =>\n element.contains(event.target as Node | null)\n );\n\n if (!source) {\n return;\n }\n\n if (!nodeMatched(connectNodes || dragNodes!, source)) {\n return;\n }\n\n event.stopPropagation();\n const from: PositionTuple = [event.clientX, event.clientY];\n\n if (connectNodes) {\n setConnectLineState({\n from,\n options: {\n strokeColor: DEFAULT_LINE_STROKE_COLOR,\n strokeWidth: DEFAULT_LINE_STROKE_WIDTH,\n ...(__secret_internals.legacyDoTransform(\n { source },\n connectNodes\n ) as ConnectNodesOptions),\n },\n });\n setConnectLineTo(from);\n\n onSwitchActiveTarget?.({ type: \"node\", nodeId: source.id });\n\n const onMouseMove = (e: MouseEvent) => {\n setConnectLineTo([e.clientX, e.clientY]);\n };\n const onMouseUp = (e: MouseEvent) => {\n document.removeEventListener(\"mousemove\", onMouseMove);\n document.removeEventListener(\"mouseup\", onMouseUp);\n setConnectLineState(null);\n const eventTargets = e.composedPath();\n const target = findNode((element) => eventTargets.includes(element));\n if (target && source !== target) {\n onNodesConnect?.({ source, target });\n }\n };\n document.addEventListener(\"mousemove\", onMouseMove);\n document.addEventListener(\"mouseup\", onMouseUp);\n return;\n }\n\n // Drag node\n onSwitchActiveTarget?.({ type: \"node\", nodeId: source.id });\n\n let moved = false;\n const onMouseMove = (e: MouseEvent) => {\n // Respect the scale\n const movement: PositionTuple = [\n (e.clientX - from[0]) / scale,\n (e.clientY - from[1]) / scale,\n ];\n if (!moved) {\n moved = movement[0] ** 2 + movement[1] ** 2 >= 9;\n if (moved) {\n setManualLayoutStatus(\"started\");\n }\n }\n if (moved) {\n setNodeMovement({ id: source.id, move: movement });\n }\n };\n const onMouseUp = () => {\n moved = false;\n document.removeEventListener(\"mousemove\", onMouseMove);\n document.removeEventListener(\"mouseup\", onMouseUp);\n setNodeMovement(null);\n setManualLayoutStatus(\"finished\");\n };\n document.addEventListener(\"mousemove\", onMouseMove);\n document.addEventListener(\"mouseup\", onMouseUp);\n}\n\nfunction nodeMatched(\n options: NodesFilterOptions,\n source: DiagramNode\n): boolean {\n return options.sourceType\n ? ([] as unknown[]).concat(options.sourceType).includes(source.type)\n : checkIfByTransform(options, { source });\n}\n","import { findIndex, uniqueId } from \"lodash\";\nimport { __secret_internals } from \"@next-core/runtime\";\nimport type {\n DiagramEdge,\n LineConf,\n LineMarker,\n LineMarkerConf,\n LineMarkerType,\n NormalizedLine,\n NormalizedLineMarker,\n} from \"../interfaces\";\nimport { matchEdgeByFilter } from \"./matchEdgeByFilter\";\nimport {\n DEFAULT_LINE_CURVE_TYPE,\n DEFAULT_LINE_INTERACT_STROKE_WIDTH,\n DEFAULT_LINE_STROKE_COLOR,\n DEFAULT_LINE_STROKE_WIDTH,\n} from \"../constants\";\n\nexport function normalizeLinesAndMarkers(\n edges: DiagramEdge[] | undefined,\n lines: LineConf[] | undefined\n) {\n const normalizedLines: NormalizedLine[] = [];\n const normalizedLinesMap = new WeakMap<DiagramEdge, string>();\n const markers: LineMarker[] = [];\n for (const edge of edges ?? []) {\n const { label, ...restLineConf } =\n lines?.find((line) => matchEdgeByFilter(edge, line)) ?? {};\n\n const computedLineConf = __secret_internals.legacyDoTransform(\n { edge },\n restLineConf\n ) as LineConf | undefined;\n if (computedLineConf?.draw === false) {\n continue;\n }\n const id = uniqueId(\"line-\");\n const line: NormalizedLine[\"line\"] = {\n strokeColor: DEFAULT_LINE_STROKE_COLOR,\n strokeWidth: DEFAULT_LINE_STROKE_WIDTH,\n curveType:\n computedLineConf?.type === \"polyline\"\n ? \"curveLinear\"\n : DEFAULT_LINE_CURVE_TYPE,\n interactStrokeWidth: DEFAULT_LINE_INTERACT_STROKE_WIDTH,\n type: \"auto\",\n ...computedLineConf,\n label,\n $id: id,\n };\n normalizedLinesMap.set(edge, id);\n\n const normalizedMarkers: NormalizedLineMarker[] = [];\n\n const lineMarkers: LineMarkerConf[] =\n line.markers ?? (line.arrow ? [{ placement: \"end\", type: \"arrow\" }] : []);\n for (const marker of lineMarkers) {\n const { placement: _placement, type: _type } = marker;\n const placement = _placement ?? \"end\";\n\n let type: LineMarkerType;\n let offsetUnit: number;\n\n switch (_type) {\n case \"0..1\":\n case \"0..N\":\n offsetUnit = 21;\n type = _type;\n break;\n default:\n offsetUnit = 1;\n type = \"arrow\";\n }\n const offset = offsetUnit * line.strokeWidth;\n\n const index = addMarker({ type, strokeColor: line.strokeColor }, markers);\n normalizedMarkers.push({\n index,\n placement,\n type,\n variant: \"default\",\n offset,\n });\n\n const activeStrokeColor =\n line.overrides?.active?.strokeColor ?? line.strokeColor;\n const activeMarkerIndex = addMarker(\n { type, strokeColor: activeStrokeColor },\n markers\n );\n normalizedMarkers.push({\n index: activeMarkerIndex,\n placement,\n type,\n variant: \"active\",\n offset,\n });\n const activeRelatedStrokeColor =\n line.overrides?.activeRelated?.strokeColor ?? line.strokeColor;\n const activeRelatedMarkerIndex = addMarker(\n { type, strokeColor: activeRelatedStrokeColor },\n markers\n );\n normalizedMarkers.push({\n index: activeRelatedMarkerIndex,\n placement,\n type,\n variant: \"active-related\",\n offset,\n });\n }\n\n normalizedLines.push({\n line,\n markers: normalizedMarkers,\n edge,\n });\n }\n return {\n normalizedLines,\n normalizedLinesMap,\n markers,\n };\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 { checkIfByTransform } from \"@next-core/runtime\";\nimport type { DiagramEdge, LineConf } from \"../interfaces\";\n\nexport function matchEdgeByFilter(\n edge: DiagramEdge,\n filter: LineConf\n): boolean {\n if (!filter) {\n return false;\n }\n if (filter.edgeType) {\n return ([] as string[]).concat(filter.edgeType).includes(edge.type!);\n }\n return checkIfByTransform(filter, { edge });\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\"\n ? a.nodeId === (b as ActiveTargetOfNode).nodeId\n : a.edge.source === (b as ActiveTargetOfEdge).edge.source &&\n a.edge.target === (b as ActiveTargetOfEdge).edge.target)\n : !b;\n}\n","import type { RenderedNode, TransformLiteral } from \"../interfaces\";\n\nexport interface TransformToCenterOptions {\n canvasWidth: number;\n canvasHeight: number;\n scaleRange?: [min: number, max: number];\n}\n\nexport function transformToCenter(\n renderedNodes: RenderedNode[],\n { canvasWidth, canvasHeight, scaleRange }: TransformToCenterOptions\n): TransformLiteral {\n let left = Infinity;\n let top = Infinity;\n let right = -Infinity;\n let bottom = -Infinity;\n for (const node of renderedNodes) {\n const hw = node.width / 2;\n const hh = node.height / 2;\n const l = node.x - hw;\n const r = node.x + hw;\n const t = node.y - hh;\n const b = node.y + hh;\n if (l < left) {\n left = l;\n }\n if (r > right) {\n right = r;\n }\n if (t < top) {\n top = t;\n }\n if (b > bottom) {\n bottom = b;\n }\n }\n\n const width = right - left;\n const height = bottom - top;\n\n const scale =\n scaleRange && (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 = (canvasWidth - width * scale) / 2 - left * scale;\n const y = (canvasHeight - height * scale) / 2 - top * scale;\n\n return { x, y, k: scale };\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, `:host{display:block;width:100%;height:100%;overflow:hidden}:host([hidden]){display:none}*{box-sizing:border-box}.diagram{width:100%;height:100%;position:relative;opacity:0}.diagram:focus{outline:none}.lines,\n.line-labels,\n.nodes{position:absolute;top:0;left:0}.line-labels{opacity:0}.ready{opacity:1}.diagram.ready.pannable{cursor:-webkit-grab;cursor:grab}.diagram.pannable.grabbing{cursor:-webkit-grabbing;cursor:grabbing}.nodes,\n.lines{transform-origin:0 0}.node,\n.line-label{position:absolute;visibility:hidden}.line-label{transform:translate(-50%,-50%);white-space:pre-line;width:-webkit-max-content;width:-moz-max-content;width:max-content;text-align:center;line-height:1}.lines{pointer-events:none}.line.interactable{pointer-events:auto;cursor:default}.connect-line{position:fixed;top:0;left:0;right:0;bottom:0;pointer-events:none}.connect-line:not(.connecting){display:none}.line:not(.active) .active-bg{display:none}`, \"\"]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___.toString();\n"],"names":["ConnectLineComponent","_ref","connectLineState","connectLineTo","markerPrefix","React","width","height","className","classNames","connecting","from","MarkerComponent","type","id","concat","strokeColor","options","d","join","fill","stroke","strokeWidth","markerEnd","arrow","undefined","LineComponent","_line$overrides","_line$overrides2","markerStart","line","edge","markers","linePaths","lineMaskRects","maskPrefix","activeLineMarkerPrefix","active","activeRelated","onLineClick","onLineDoubleClick","mask","has","$id","interactStrokeWidth","_objectSpread","overrides","expectVariant","marker","variant","placement","index","interactable","onClick","onDoubleClick","e","preventDefault","stopPropagation","style","cursor","ref","element","set","LineLabelComponentGroup","labels","onRendered","rendered","setRendered","useState","renderedIds","setRenderedIds","refRepository","useMemo","Map","handleRenderer","useCallback","previous","includes","handleUnmount","indexOf","slice","delete","useEffect","some","label","map","_ref2","text","key","LineLabelComponent","onUnmount","LineTextComponent","_ref3","refCallback","content","_ref4","useBrick","checkIfByTransform","memoizedData","setTimeout","parentElement","ignoredCallback","ReactUseBrick","data","LineMaskComponent","lineId","rects","renderedLineLabels","lineText","find","item","rect","padding","lineRect","bgRect","left","top","x","y","Component","EntityRelationZeroOrOneMarker","EntityRelationZeroOrManyMarker","ArrowMarker","viewBox","refX","refY","markerWidth","markerHeight","orient","strokeLinejoin","NodeComponentGroup","nodes","nodeBricks","node","NodeComponent","_findNodeBrick","nodeType","findNodeBrick","DEFAULT_LINE_STROKE_COLOR","DEFAULT_LINE_STROKE_WIDTH","DEFAULT_LINE_CURVE_TYPE","DEFAULT_LINE_INTERACT_STROKE_WIDTH","DEFAULT_SCALE_RANGE_MIN","DEFAULT_SCALE_RANGE_MAX","adjustNodesSize","nodesRefRepository","nodePaddings","_element$offsetWidth","_element$offsetHeight","get","Math","max","offsetWidth","offsetHeight","adjustNodesPosition","_nodesRefRepository$g","nodeContainer","visibility","extractPartialRectTuple","value","Array","isArray","v0","v1","length","getRenderedEdges","edges","_edges$map","normalizedLinesMap","lineLabelsRefRepository","labelSize","getDummyNodes","count","v","i","dummy","source","target","getDummyEdges","useRenderedDiagram","layout","originalLayout","manualLayoutStatus","userViewReady","userViewNodesMap","nodeMovement","nodesRenderId","lineLabelsRenderId","layoutOptions","graph","setGraph","renderedDiagram","setRenderedDiagram","previousGraph","dagreLayoutOptions","_nodePadding$rankdir$","nodePadding","rankdir","ranksep","edgesep","nodesep","pick","dagreGraphOptions","_objectWithoutProperties","_excluded","dagre","Graph","setDefaultEdgeLabel","previousNode","getNode","setNode","setEdge","applyLayout","renderedNodes","push","console","error","renderedEdges","_edge$labelSize","labelpos","getDagreGraph","forceLayoutOptions","dummyNodesOnEdges","collide","dummyRadius","radiusDiff","strength","iterations","renderedNode","userViewNode","fx","fy","forceNodes","forceLinks","linkSimulation","forceLink","distance","l","simulation","forceSimulation","force","forceX","forceY","forceManyBody","forceCollide","radius","sqrt","stop","tick","ceil","log","alphaMin","alphaDecay","manuallyTickToTheEnd","getForceGraph","movedNode","x0","y0","_movedNode$x","_movedNode$y","move","getManualGraph","USER_VIEW_MODEL_ID","useUserView","query","setUserViewReady","userViewIdRef","useRef","setUserViewNodesMap","queue","createAsyncQueue","working","waitingTasks","_queue","_asyncToGenerator","task","nextTask","shift","_x","apply","arguments","_getUserView","namespace","list","InstanceApi_postSearchV3","fields","$eq","page","page_size","_userView$nodes","userView","current","instanceId","handleHttpError","getUserView","saveUserView","userViewData","InstanceApi_updateInstanceV2","interceptorParams","ignoreLoadingBar","InstanceApi_createInstance","getDirectLinePoints","doTwoNodesOverlap","x1","y1","dx","dy","directionX","deltaRadio","abs","directionY","adjustLineLabels","position","angle","size","_size","tempDirection","floor","PI","direction","tangent","tan","offsetAngle","offsetSin","sin","offsetCos","cos","transform","a","b","paddingA","paddingB","A","getNodesWithPadding","B","min","right","bottom","getLineMaskRects","offsetLeft","offsetTop","getRenderedLineLabels","renderedLines","flatMap","path","getAttribute","getBBox","pathLength","getTotalLength","_item$placement","point","getPointAtLength","curveLine","points","curveType","startOffset","endOffset","curveFactory","curveLinear","curveBumpX","curveBumpY","curveMonotoneX","curveMonotoneY","curveNatural","curveBasis","startOffsets","getOffsets","endOffsets","curve","lineFunction","start","end","offset","ratio","pow","getCoordinates","getRenderedLines","normalizedLines","renderedEdgeMap","WeakMap","renderedNodeMap","relatedNodes","renderedEdge","prepared","_markers$find$offset","_markers$find","_markers$find$offset2","_markers$find2","rest","startMarkerOffset","endMarkerOffset","_relatedNodes$get","_relatedNodes$get2","prepareRelatedNodes","addRelatedNodes","to","relates","Set","toNode","add","sourceDirection","getDirection","targetDirection","sourceRelates","getOrderedRelates","targetRelates","sourcePosition","targetPosition","c1","c2","p0","p1","getPolyLinePoints","atan2","filter","Boolean","sourceAngle","sx","sy","tx","ty","fixedAngle","sort","ax","ay","bx","by","handleKeyboard","event","activeTarget","activeNode","nodeId","activeEdge","action","_node","keyCode","which","moveOnAxis","axis","diff","oppositeAxis","candidates","minBy","handleNodesMouseDown","connectNodes","dragNodes","scale","setConnectLineState","setConnectLineTo","setManualLayoutStatus","setNodeMovement","onSwitchActiveTarget","onNodesConnect","findNode","match","_ret","_loop","contains","sourceType","nodeMatched","clientX","clientY","__secret_internals","legacyDoTransform","onMouseMove","onMouseUp","document","removeEventListener","eventTargets","composedPath","addEventListener","moved","movement","normalizeLinesAndMarkers","lines","_lines$find","_line$markers","edgeType","matchEdgeByFilter","restLineConf","computedLineConf","draw","uniqueId","normalizedMarkers","lineMarkers","_line$overrides$activ","_line$overrides$activ2","_placement","_type","offsetUnit","addMarker","activeMarkerIndex","activeRelatedMarkerIndex","markerIndex","findIndex","sameTarget","transformToCenter","canvasWidth","canvasHeight","scaleRange","Infinity","hw","hh","r","t","k","___CSS_LOADER_EXPORT___","module","toString"],"sourceRoot":""}
@@ -0,0 +1,2 @@
1
+ "use strict";(self.webpackChunk_next_bricks_diagram=self.webpackChunk_next_bricks_diagram||[]).push([[8272],{8272:(e,t,a)=>{a.r(t);var n,i,l,r,s,o,c,u,d,h,v,g,p,b,w,m,f,k,y,E,M,x,W,N,L,R,S,z,C,D,T,B,O,A,I,H,P,K,Y,X,V,_,j,q,U,Z,$,F,G,J,Q,ee,te,ae,ne,ie,le,re,se=a(123),oe=a(592),ce=a(5866),ue=a(1412),de=a(8644),he=a(5600),ve=a.n(he),ge=a(7672),pe=a(8160),be=(a(48),a(5248)),we=a(1920),me=a(1252),fe=a.n(me),ke=a(7568),ye=a(2504),Ee=a(8996),Me=a(9140),xe=a(3600),We=a(3904),Ne=a(4378),Le=a(8276),Re=a(2092),Se=a(8752),ze=a(4092),Ce=a(3784),De=a(3732),Te=a(636),Be=a(6932),Oe=a(4580),Ae=a(9900),Ie=a(6152),He=a(3888),Pe=a(4588),Ke=a(3256),{defineElement:Ye,property:Xe,event:Ve,method:_e}=(0,ge.createDecorators)(),je=(0,he.forwardRef)(Pt);l=[Ye("eo-diagram",{styleTexts:[Ie.c]})],r=Xe({type:String}),o=Xe({attribute:!1}),u=Xe({attribute:!1}),h=Xe({attribute:!1}),g=Xe({attribute:!1}),b=Xe({attribute:!1}),m=Xe({attribute:!1}),k=Xe({type:Boolean}),E=Xe({attribute:!1}),x=Xe({attribute:!1}),N=Xe({type:Boolean}),R=Xe({type:Boolean}),z=Xe({type:Boolean}),D=Xe({attribute:!1}),B=Ve({type:"activeTarget.change"}),H=Ve({type:"node.delete"}),X=Ve({type:"edge.delete"}),q=Ve({type:"line.click"}),F=Ve({type:"line.dblclick"}),ee=Ve({type:"nodes.connect"}),ie=_e();var qe=new WeakMap,Ue=new WeakMap,Ze=new WeakMap,$e=new WeakMap,Fe=new WeakMap,Ge=new WeakMap,Je=new WeakMap,Qe=new WeakMap,et=new WeakMap,tt=new WeakMap,at=new WeakMap,nt=new WeakMap,it=new WeakMap,lt=new WeakMap,rt=new WeakMap,st=new WeakMap,ot=new WeakMap,ct=new WeakMap,ut=new WeakMap,dt=new WeakMap,ht=new WeakMap,vt=new WeakMap,gt=new WeakMap,pt=new WeakMap,bt=new WeakMap,wt=new WeakMap,mt=new WeakMap,ft=new WeakMap,kt=new WeakMap,yt=new WeakMap,Et=new WeakMap,Mt=new WeakMap,xt=new WeakMap,Wt=new WeakMap;class Nt extends pe.ReactNextElement{constructor(){super(...arguments),(0,se.c)(this,Et,{get:Ht,set:It}),(0,se.c)(this,ft,{get:At,set:Ot}),(0,se.c)(this,bt,{get:Bt,set:Tt}),(0,se.c)(this,vt,{get:Dt,set:Ct}),(0,se.c)(this,ut,{get:zt,set:St}),(0,se.c)(this,st,{get:Rt,set:Lt}),(0,se.c)(this,qe,{writable:!0,value:(n(this),s(this))}),(0,se.c)(this,Ue,{writable:!0,value:c(this)}),(0,se.c)(this,Ze,{writable:!0,value:d(this)}),(0,se.c)(this,$e,{writable:!0,value:v(this)}),(0,se.c)(this,Fe,{writable:!0,value:p(this)}),(0,se.c)(this,Ge,{writable:!0,value:w(this)}),(0,se.c)(this,Je,{writable:!0,value:f(this)}),(0,se.c)(this,Qe,{writable:!0,value:y(this)}),(0,se.c)(this,et,{writable:!0,value:M(this)}),(0,se.c)(this,tt,{writable:!0,value:W(this)}),(0,se.c)(this,at,{writable:!0,value:L(this,!0)}),(0,se.c)(this,nt,{writable:!0,value:S(this,!0)}),(0,se.c)(this,it,{writable:!0,value:C(this,!0)}),(0,se.c)(this,lt,{writable:!0,value:T(this)}),(0,se.c)(this,rt,{writable:!0,value:O(this)}),(0,se.c)(this,ot,{writable:!0,value:e=>{(0,ue.c)(this,st).emit(e)}}),(0,se.c)(this,ct,{writable:!0,value:P(this)}),(0,se.c)(this,dt,{writable:!0,value:e=>{(0,ue.c)(this,ut).emit(e)}}),(0,se.c)(this,ht,{writable:!0,value:V(this)}),(0,se.c)(this,gt,{writable:!0,value:e=>{(0,ue.c)(this,vt).emit(e)}}),(0,se.c)(this,pt,{writable:!0,value:U(this)}),(0,se.c)(this,wt,{writable:!0,value:e=>{(0,ue.c)(this,bt).emit(e)}}),(0,se.c)(this,mt,{writable:!0,value:G(this)}),(0,se.c)(this,kt,{writable:!0,value:e=>{(0,ue.c)(this,ft).emit(e)}}),(0,se.c)(this,yt,{writable:!0,value:te(this)}),(0,se.c)(this,Mt,{writable:!0,value:e=>{(0,ue.c)(this,Et).emit(e)}}),(0,se.c)(this,xt,{writable:!0,value:e=>{(0,Pe.M)(e,this.activeTarget)||(this.activeTarget=e)}}),(0,se.c)(this,Wt,{writable:!0,value:(0,he.createRef)()})}get layout(){return(0,ue.c)(this,qe)}set layout(e){(0,ce.c)(this,qe,e)}get nodes(){return(0,ue.c)(this,Ue)}set nodes(e){(0,ce.c)(this,Ue,e)}get edges(){return(0,ue.c)(this,Ze)}set edges(e){(0,ce.c)(this,Ze,e)}get nodeBricks(){return(0,ue.c)(this,$e)}set nodeBricks(e){(0,ce.c)(this,$e,e)}get lines(){return(0,ue.c)(this,Fe)}set lines(e){(0,ce.c)(this,Fe,e)}get layoutOptions(){return(0,ue.c)(this,Ge)}set layoutOptions(e){(0,ce.c)(this,Ge,e)}get activeTarget(){return(0,ue.c)(this,Je)}set activeTarget(e){(0,ce.c)(this,Je,e)}get disableKeyboardAction(){return(0,ue.c)(this,Qe)}set disableKeyboardAction(e){(0,ce.c)(this,Qe,e)}get connectNodes(){return(0,ue.c)(this,et)}set connectNodes(e){(0,ce.c)(this,et,e)}get dragNodes(){return(0,ue.c)(this,tt)}set dragNodes(e){(0,ce.c)(this,tt,e)}get zoomable(){return(0,ue.c)(this,at)}set zoomable(e){(0,ce.c)(this,at,e)}get scrollable(){return(0,ue.c)(this,nt)}set scrollable(e){(0,ce.c)(this,nt,e)}get pannable(){return(0,ue.c)(this,it)}set pannable(e){(0,ce.c)(this,it,e)}get scaleRange(){return(0,ue.c)(this,lt)}set scaleRange(e){(0,ce.c)(this,lt,e)}callOnLineLabel(e,t){for(var a,n=arguments.length,i=new Array(n>2?n-2:0),l=2;l<n;l++)i[l-2]=arguments[l];null===(a=(0,ue.c)(this,Wt).current)||void 0===a||a.callOnLineLabel(e,t,...i)}render(){return ve().createElement(je,{ref:(0,ue.c)(this,Wt),layout:this.layout,nodes:this.nodes,edges:this.edges,nodeBricks:this.nodeBricks,lines:this.lines,layoutOptions:this.layoutOptions,connectNodes:this.connectNodes,dragNodes:this.dragNodes,activeTarget:this.activeTarget,disableKeyboardAction:this.disableKeyboardAction,zoomable:this.zoomable,scrollable:this.scrollable,pannable:this.pannable,scaleRange:this.scaleRange,onActiveTargetChange:(0,ue.c)(this,ot),onSwitchActiveTarget:(0,ue.c)(this,xt),onNodeDelete:(0,ue.c)(this,dt),onEdgeDelete:(0,ue.c)(this,gt),onLineClick:(0,ue.c)(this,wt),onLineDoubleClick:(0,ue.c)(this,kt),onNodesConnect:(0,ue.c)(this,Mt)})}}function Lt(e){I(this,e)}function Rt(){return A(this)}function St(e){Y(this,e)}function zt(){return K(this)}function Ct(e){j(this,e)}function Dt(){return _(this)}function Tt(e){$(this,e)}function Bt(){return Z(this)}function Ot(e){Q(this,e)}function At(){return J(this)}function It(e){ne(this,e)}function Ht(){return ae(this)}function Pt(e,t){var{layout:a,nodes:n,edges:i,nodeBricks:l,lines:r,layoutOptions:s,connectNodes:o,dragNodes:c,activeTarget:u,disableKeyboardAction:d,zoomable:h,scrollable:v,pannable:g,scaleRange:p,onActiveTargetChange:b,onSwitchActiveTarget:w,onNodeDelete:m,onEdgeDelete:f,onLineClick:k,onLineDoubleClick:y,onNodesConnect:E}=e,[M,x]=(0,he.useState)(!1),[W,N]=(0,he.useState)(0),[L,R]=(0,he.useState)(null),[S,z]=(0,he.useState)(!1),[C,D]=(0,he.useState)(0),[T,B]=(0,he.useState)(null),[O,A]=(0,he.useState)([]),[I,H]=(0,he.useState)(!1),[P,K]=(0,he.useState)({k:1,x:0,y:0}),Y=(0,he.useRef)(new Map),X=(0,he.useRef)(null),V=(0,he.useRef)(null),[_,j]=(0,he.useState)(!1),{userViewReady:q,userViewNodesMap:U,saveUserView:Z}=(0,He.y)(null==c?void 0:c.save),[$,F]=(0,he.useState)([0,0]),[G,J]=(0,he.useState)(null),[Q,ee]=(0,he.useState)("initial"),[te,ae]=(0,he.useState)(null);(0,he.useImperativeHandle)(t,(()=>({callOnLineLabel(e,t){for(var a,n=arguments.length,i=new Array(n>2?n-2:0),l=2;l<n;l++)i[l-2]=arguments[l];null==T||null===(a=T.get(e))||void 0===a||null===(a=a.firstElementChild)||void 0===a||a[t](...i)}}))),(0,he.useEffect)((()=>{var e=e=>{(0,Te.w)(e,{nodes:n,nodesRefRepository:L,connectNodes:o,dragNodes:c,scale:P.k,setConnectLineState:J,setConnectLineTo:F,setManualLayoutStatus:ee,setNodeMovement:ae,onSwitchActiveTarget:w,onNodesConnect:E})},t=V.current;return null==t||t.addEventListener("mousedown",e),()=>{null==t||t.removeEventListener("mousedown",e)}}),[n,o,c,P.k,L,E,w]);var{normalizedLines:ne,normalizedLinesMap:ie,markers:le}=(0,he.useMemo)((()=>(0,Ne.K)(i,r)),[i,r]),re=(0,he.useMemo)((()=>ne.flatMap((e=>{var t,a,{line:{text:n,label:i,$id:l},edge:r}=e;return n||i?(i?(t="label",a=[].concat(i)):(t="text",a=[].concat(n)),a.map((e=>{var a;return{[t]:e,id:"".concat(l,"-").concat(null!==(a=e.placement)&&void 0!==a?a:"center"),edge:r}}))):[]}))),[ne]),{nodes:se,edges:oe}=(0,Oe.C)({layout:a,nodes:n,edges:i,manualLayoutStatus:Q,userViewReady:q,userViewNodesMap:U,nodeMovement:te,nodesRefRepository:L,lineLabelsRefRepository:T,normalizedLinesMap:ie,layoutOptions:s,nodesRenderId:W,lineLabelsRenderId:C});(0,he.useEffect)((()=>{"finished"===Q&&Z(se.map((e=>({id:e.id,x:e.x,y:e.y}))))}),[Q]);var ce=(0,he.useMemo)((()=>(0,We.e)(oe,se,ne)),[ne,se,oe]),ue=null!=u?u:null,[de,ge]=(0,he.useState)(ue);(0,he.useEffect)((()=>{ge((e=>(0,Pe.M)(e,ue)?e:ue))}),[ue]);var pe=(0,he.useRef)(!1);(0,he.useEffect)((()=>{pe.current?null==b||b(de):pe.current=!0}),[de,b]),(0,he.useEffect)((()=>{var e=X.current;if(e&&!d){var t=e=>{var t=(0,Me.Y)(e,{renderedNodes:se,activeTarget:de});"delete-node"===(null==t?void 0:t.action)?null==m||m(t.node):"delete-edge"===(null==t?void 0:t.action)?null==f||f(t.edge):"switch-active-node"===(null==t?void 0:t.action)&&t.node&&(null==w||w({type:"node",nodeId:t.node.id}))};return e.addEventListener("keydown",t),()=>{e.removeEventListener("keydown",t)}}}),[de,se,d,w,m,f]);var me=(0,he.useCallback)((e=>{e&&(N((e=>e+1)),R(e)),x((t=>t||!!e))}),[]),Ie=(0,he.useCallback)((e=>{e&&(D((e=>e+1)),B(e)),z((t=>t||!!e))}),[]),Ye=(0,he.useMemo)((()=>null!=p?p:[Be.WH,Be.Oi]),[p]),Xe=(0,he.useMemo)((()=>(0,we.AT)()),[]);(0,he.useEffect)((()=>{var e=!1;Xe.scaleExtent(h?Ye:[1,1]).on("start",(()=>{e=!1,H(!0)})).on("zoom",(t=>{e=!0,K(t.transform)})).on("end",(()=>{H(!1),e||null==w||w(null)}))}),[w,Ye,h,Xe]),(0,he.useEffect)((()=>{var e=X.current;if(e){var t=(0,be.c)(e),a=()=>{t.on(".zoom",null).on(".zoom.custom",null).on("wheel",null)};if(h||v||g)return(h||v)&&t.on("wheel.zoom.custom",(e=>{e.ctrlKey||(e.stopImmediatePropagation(),v&&(e.preventDefault(),Xe.translateBy(t,e.wheelDeltaX/5,e.wheelDeltaY/5)))})),t.call(Xe).on("wheel",(e=>e.preventDefault())).on("dblclick.zoom",null),g||t.on("mousedown.zoom",null).on("touchstart.zoom",null).on("touchmove.zoom",null).on("touchend.zoom",null),a;a()}}),[g,v,h,Xe]),(0,he.useEffect)((()=>{var e=X.current;if(0!==se.length&&e&&!_){var{k:t,x:a,y:n}=(0,xe.c)(se,{canvasWidth:e.clientWidth,canvasHeight:e.clientHeight,scaleRange:h?Ye:void 0});Xe.transform((0,be.c)(e),new we.O(t,a,n)),j(!0)}}),[_,se,Ye,h,Xe]);var Ve=(0,he.useMemo)((()=>"".concat((0,ke.uniqueId)("diagram-"),"-")),[]),_e="".concat(Ve,"line-arrow-"),je="".concat(Ve,"mask-"),qe="".concat(Ve,"active-line-");(0,he.useEffect)((()=>{A((e=>(0,De.c)(e,ce,Y.current)))}),[ce]);var[Ue,Ze]=ve().useState(new Map);return(0,he.useEffect)((()=>{if(T){(0,Ae.c)(O,T);var e=new ye.c((()=>{Ze((0,Ke.E)(O,T))}));for(var t of T.values())e.observe(t);return()=>{e.disconnect()}}}),[C,T,O]),"dagre"!==a&&"force"!==a?ve().createElement("div",null,'Diagram layout not supported: "'.concat(a,'"')):ve().createElement("div",{className:fe()("diagram",{ready:M&&_,grabbing:I,pannable:g}),tabIndex:-1,ref:X},ve().createElement("svg",{width:"100%",height:"100%",className:"lines"},ve().createElement("defs",null,le.map(((e,t)=>{var{type:a,strokeColor:n}=e;return ve().createElement(Se.y,{key:t,id:"".concat(_e).concat(t),type:a,strokeColor:n})})),[...Ue].map((e=>{var[t,a]=e;return ve().createElement(ze.g,{key:t,lineId:t,rects:a,maskPrefix:je,renderedLineLabels:O})})),ve().createElement("marker",{id:"".concat(qe,"start"),viewBox:"0 0 8 8",refX:4,refY:4,markerWidth:8,markerHeight:8,orient:"auto"},ve().createElement("path",{d:"M 0.5 0.5 H 7.5 V 7.5 H 0.5 Z",stroke:"var(--palette-gray-7)",strokeWidth:1,fill:"var(--palette-gray-1)"})),ve().createElement("marker",{id:"".concat(qe,"end"),viewBox:"0 0 14 8",refX:3,refY:4,markerWidth:14,markerHeight:8,orient:"auto"},ve().createElement("path",{d:"M 0.5 1.5 L 5.5 4 L 0.5 6.5 z",stroke:"var(--palette-blue-3)",strokeWidth:1,fill:"var(--palette-blue-3)"}),ve().createElement("path",{d:"M 6.5 0.5 H 13.5 V 7.5 H 6.5 Z",stroke:"var(--palette-gray-7)",strokeWidth:1,fill:"var(--palette-gray-1)"}))),ve().createElement("g",{transform:"translate(".concat(P.x," ").concat(P.y,") scale(").concat(P.k,")")},ce.map((e=>ve().createElement(Re.k,{key:e.line.$id,line:e,linePaths:Y.current,lineMaskRects:Ue,maskPrefix:je,markerPrefix:_e,activeLineMarkerPrefix:qe,active:"edge"===(null==de?void 0:de.type)&&de.edge.source===e.edge.source&&de.edge.target===e.edge.target,activeRelated:"node"===(null==de?void 0:de.type)&&(e.edge.source===de.nodeId||e.edge.target===de.nodeId),onLineClick:k,onLineDoubleClick:y}))))),ve().createElement("div",{className:fe()("line-labels",{ready:S}),style:{left:P.x,top:P.y,transform:"scale(".concat(P.k,")")}},ve().createElement(Le.Ar,{labels:re,onRendered:Ie})),ve().createElement("div",{className:"nodes",ref:V,style:{left:P.x,top:P.y,transform:"scale(".concat(P.k,")")}},ve().createElement(Ee._,{nodes:n,nodeBricks:l,onRendered:me})),ve().createElement(Ce.E,{connectLineState:G,connectLineTo:$,markerPrefix:_e}))}le=Nt,({e:[s,c,d,v,p,w,f,y,M,W,L,S,C,T,O,A,I,P,K,Y,V,_,j,U,Z,$,G,J,Q,te,ae,ne,n],c:[re,i]}=(0,de.c)(le,[[r,1,"layout"],[o,1,"nodes"],[u,1,"edges"],[h,1,"nodeBricks"],[g,1,"lines"],[b,1,"layoutOptions"],[m,1,"activeTarget"],[k,1,"disableKeyboardAction"],[E,1,"connectNodes"],[x,1,"dragNodes"],[N,1,"zoomable"],[R,1,"scrollable"],[z,1,"pannable"],[D,1,"scaleRange"],[B,1,"activeTargetChangeEvent",e=>(0,ue.c)(e,rt),(e,t)=>(0,ce.c)(e,rt,t)],[H,1,"nodeDelete",e=>(0,ue.c)(e,ct),(e,t)=>(0,ce.c)(e,ct,t)],[X,1,"edgeDelete",e=>(0,ue.c)(e,ht),(e,t)=>(0,ce.c)(e,ht,t)],[q,1,"lineClick",e=>(0,ue.c)(e,pt),(e,t)=>(0,ce.c)(e,pt,t)],[F,1,"lineDoubleClick",e=>(0,ue.c)(e,mt),(e,t)=>(0,ce.c)(e,mt,t)],[ee,1,"connectNodes",e=>(0,ue.c)(e,yt),(e,t)=>(0,ce.c)(e,yt,t)],[ie,2,"callOnLineLabel"]],l,0,(e=>Wt.has((0,oe.c)(e))),pe.ReactNextElement)),i();var Kt,Yt,Xt,Vt,_t,jt,qt,Ut,Zt,$t,Ft,Gt,Jt,Qt,ea,ta,aa,na,ia=a(7518),{defineElement:la,property:ra,event:sa,method:oa}=(0,ge.createDecorators)(),ca=(0,he.forwardRef)(xa);Xt=[la("diagram.editable-label",{styleTexts:[ia.c]})],Vt=ra(),jt=ra({render:!1}),Ut=sa({type:"label.editing.change"}),Gt=sa({type:"label.change"}),ta=oa();var ua=new WeakMap,da=new WeakMap,ha=new WeakMap,va=new WeakMap,ga=new WeakMap,pa=new WeakMap,ba=new WeakMap,wa=new WeakMap,ma=new WeakMap;class fa extends pe.ReactNextElement{constructor(){super(...arguments),(0,se.c)(this,ba,{get:Ma,set:Ea}),(0,se.c)(this,va,{get:ya,set:ka}),(0,se.c)(this,ua,{writable:!0,value:(Kt(this),_t(this))}),(0,se.c)(this,da,{writable:!0,value:qt(this)}),(0,se.c)(this,ha,{writable:!0,value:Zt(this)}),(0,se.c)(this,ga,{writable:!0,value:e=>{(0,ue.c)(this,va).emit(e)}}),(0,se.c)(this,pa,{writable:!0,value:Jt(this)}),(0,se.c)(this,wa,{writable:!0,value:e=>{(0,ue.c)(this,ba).emit(e)}}),(0,se.c)(this,ma,{writable:!0,value:(0,he.createRef)()})}get label(){return(0,ue.c)(this,ua)}set label(e){(0,ce.c)(this,ua,e)}get type(){return(0,ue.c)(this,da)}set type(e){(0,ce.c)(this,da,e)}enableEditing(){var e;null===(e=(0,ue.c)(this,ma).current)||void 0===e||e.enableEditing()}render(){return ve().createElement(ca,{ref:(0,ue.c)(this,ma),label:this.label,onLabelEditingChange:(0,ue.c)(this,ga),onLabelChange:(0,ue.c)(this,wa)})}}function ka(e){Ft(this,e)}function ya(){return $t(this)}function Ea(e){ea(this,e)}function Ma(){return Qt(this)}function xa(e,t){var{label:a,onLabelChange:n,onLabelEditingChange:i}=e,l=null!=a?a:"",[r,s]=(0,he.useState)(l),[o,c]=(0,he.useState)(!1),u=(0,he.useRef)(!1),[d,h]=(0,he.useState)(!1),v=(0,he.useRef)(null);(0,he.useImperativeHandle)(t,(()=>({enableEditing(){c(!0)}}))),(0,he.useEffect)((()=>{s(l)}),[l]);var g=(0,he.useCallback)((e=>{e.preventDefault(),e.stopPropagation(),c(!0)}),[]);(0,he.useEffect)((()=>{var e,t;o&&(null===(e=v.current)||void 0===e||e.focus({preventScroll:!0}),null===(t=v.current)||void 0===t||t.select())}),[o]),(0,he.useEffect)((()=>{u.current?null==i||i(o):u.current=!0}),[o,i]);var p=(0,he.useCallback)((e=>{s(e.target.value)}),[]),b=(0,he.useCallback)((e=>{var t,a=e.key||e.keyCode||e.which;"Enter"!==a&&13!==a||null===(t=v.current)||void 0===t||t.blur()}),[]),w=(0,he.useCallback)((()=>{c(!1),h(!0)}),[]);(0,he.useEffect)((()=>{d&&(null==n||n(r),h(!1))}),[r,n,d]);var m=(0,he.useCallback)((e=>{e.stopPropagation()}),[]);return ve().createElement("div",{className:fe()("label",{editing:o,empty:!r}),onDoubleClick:m,onMouseDown:m},ve().createElement("input",{className:"label-input",value:r,ref:v,onChange:p,onKeyDown:b,onBlur:w}),ve().createElement("div",{className:"label-text",onDoubleClick:g},r))}aa=fa,({e:[_t,qt,Zt,$t,Ft,Jt,Qt,ea,Kt],c:[na,Yt]}=(0,de.c)(aa,[[Vt,1,"label"],[jt,1,"type"],[Ut,1,"labelEditingChange",e=>(0,ue.c)(e,ha),(e,t)=>(0,ce.c)(e,ha,t)],[Gt,1,"labelChange",e=>(0,ue.c)(e,pa),(e,t)=>(0,ce.c)(e,pa,t)],[ta,2,"enableEditing"]],Xt,0,(e=>ma.has((0,oe.c)(e))),pe.ReactNextElement)),Yt();var Wa,Na=a(4412),La=a(640),Ra=a(8944),Sa=a(6196),za=(Wa={cells:(e,t)=>{switch(t.type){case"drop-node":return[...e,t.payload];case"add-nodes":return[...e,...t.payload];case"add-edge":var a=e.findLastIndex((e=>"edge"===e.type))+1;return[...e.slice(0,a),t.payload,...e.slice(a)]}return e}},(e,t)=>Object.fromEntries(Object.entries(Wa).map((a=>{var[n,i]=a;return[n,i(e[n],t)]})))),Ca=a(960);function Da(e){return"node"===e.type}var Ta,Ba,Oa,Aa,Ia,Ha,Pa,Ka,Ya,Xa,Va,_a,ja=a(7584),qa=["size"],Ua=20,{defineElement:Za,property:$a,method:Fa}=(0,ge.createDecorators)(),Ga=ve().forwardRef(an);Oa=[Za("eo-draw-canvas",{styleTexts:[ja.c]})],Aa=$a({attribute:!1}),Ha=$a({attribute:!1}),Ka=Fa(),Ya=Fa(),Xa=Fa();var Ja=new WeakMap,Qa=new WeakMap,en=new WeakMap;class tn extends pe.ReactNextElement{constructor(){super(...arguments),(0,se.c)(this,Ja,{writable:!0,value:(Ta(this),Ia(this))}),(0,se.c)(this,Qa,{writable:!0,value:Pa(this)}),(0,se.c)(this,en,{writable:!0,value:(0,he.createRef)()})}get cells(){return(0,ue.c)(this,Ja)}set cells(e){(0,ce.c)(this,Ja,e)}get defaultNodeSize(){return(0,ue.c)(this,Qa)}set defaultNodeSize(e){(0,ce.c)(this,Qa,e)}dropNode(e){var t=this;return(0,Ra.c)((function*(){var a,n,{id:i,position:l,size:r,data:s,useBrick:o}=e;if(null===(a=(n=document).elementsFromPoint)||void 0===a||null===(a=a.call(n,l[0],l[1]))||void 0===a?void 0:a.includes(t)){var c,u,d,h,v,g,p,b=t.getBoundingClientRect(),w={type:"node",id:i,view:{x:l[0]-b.left,y:l[1]-b.top,width:null!==(c=null!==(u=null==r?void 0:r[0])&&void 0!==u?u:null===(d=t.defaultNodeSize)||void 0===d?void 0:d[0])&&void 0!==c?c:Ua,height:null!==(h=null!==(v=null==r?void 0:r[1])&&void 0!==v?v:null===(g=t.defaultNodeSize)||void 0===g?void 0:g[0])&&void 0!==h?h:Ua},data:s,useBrick:o};return null===(p=(0,ue.c)(t,en).current)||void 0===p||p.dropNode(w),w}return null}))()}addNodes(e){var t=this;return(0,Ra.c)((function*(){var a,n,i,l,r;if(0===e.length)return[];var s=e[0],o=null!==(a=null===(n=s.size)||void 0===n?void 0:n[0])&&void 0!==a?a:Ua,c=null!==(i=null===(l=s.size)||void 0===l?void 0:l[1])&&void 0!==i?i:Ua,u=Math.floor(600/(c+20)),d=e.map(((e,a)=>{var n,i,l,r,s,d,{size:h}=e,v=(0,La.c)(e,qa);return(0,Na.c)((0,Na.c)({},v),{},{type:"node",view:{x:Math.floor(a/u)*(o+20)+20,y:a%u*(c+20)+20,width:null!==(n=null!==(i=null==h?void 0:h[0])&&void 0!==i?i:null===(l=t.defaultNodeSize)||void 0===l?void 0:l[0])&&void 0!==n?n:Ua,height:null!==(r=null!==(s=null==h?void 0:h[1])&&void 0!==s?s:null===(d=t.defaultNodeSize)||void 0===d?void 0:d[0])&&void 0!==r?r:Ua}})}));return null===(r=(0,ue.c)(t,en).current)||void 0===r||r.addNodes(d),d}))()}addEdge(e){var t=this;return(0,Ra.c)((function*(){var a,{source:n,target:i,data:l}=e,r={type:"edge",source:n,target:i,data:l};return null===(a=(0,ue.c)(t,en).current)||void 0===a||a.addEdge(r),r}))()}render(){return ve().createElement(Ga,{ref:(0,ue.c)(this,en),cells:this.cells,defaultNodeSize:this.defaultNodeSize})}}function an(e,t){var{cells:a,defaultNodeSize:n}=e,[{cells:i},l]=(0,he.useReducer)(za,a,(e=>{var t=null!=e?e:[];return{cells:n?t.map((e=>!function(e){return"node"===e.type}(e)||void 0!==e.view.width&&void 0!==e.view.height?e:(0,Na.c)((0,Na.c)({},e),{},{view:(0,Na.c)({width:n[0],height:n[1]},e.view)}))):t}}));(0,he.useImperativeHandle)(t,(()=>({dropNode(e){l({type:"drop-node",payload:e})},addNodes(e){l({type:"add-nodes",payload:e})},addEdge(e){l({type:"add-edge",payload:e})}})),[]);var r=(0,he.useMemo)((()=>"".concat((0,ke.uniqueId)("diagram-"),"-")),[]),s="".concat(r,"line-arrow-"),o="".concat(s,"1");return ve().createElement("svg",{width:800,height:600},ve().createElement("defs",null,ve().createElement(Se.y,{id:o,type:"arrow",strokeColor:"gray"})),ve().createElement("g",null,i.map((e=>Da(e)?e.useBrick?ve().createElement("foreignObject",{key:"node:".concat(e.id),x:e.view.x,y:e.view.y,width:e.view.width,height:e.view.height,style:{overflow:"visible"}},ve().createElement(Sa.ReactUseBrick,{useBrick:e.useBrick})):null:function(e){return"edge"===e.type}(e)?ve().createElement(nn,{key:"edge:".concat(e.source,"-").concat(e.target),edge:e,cells:i,markerEnd:o}):null))))}function nn(e){var{edge:t,cells:a,markerEnd:n}=e,i=(0,he.useMemo)((()=>{var e,n;for(var i of a)Da(i)&&(i.id===t.source&&(e=i),i.id===t.target&&(n=i));return e&&n?[e,n]:null}),[a,t.source,t.target]),l=(0,he.useMemo)((()=>i?(0,Ca.g)(ln(i[0].view,5),ln(i[1].view,5)):null),[i]);return l?ve().createElement("path",{className:"line",d:"M".concat(l[0].x," ").concat(l[0].y,"L").concat(l[1].x," ").concat(l[1].y),fill:"none",stroke:"gray",markerEnd:"url(#".concat(n,")")}):null}function ln(e,t){return{x:e.x+e.width/2,y:e.y+e.height/2,width:e.width+t,height:e.height+t}}Va=tn,({e:[Ia,Pa,Ta],c:[_a,Ba]}=(0,de.c)(Va,[[Aa,1,"cells"],[Ha,1,"defaultNodeSize"],[Ka,2,"dropNode"],[Ya,2,"addNodes"],[Xa,2,"addEdge"]],Oa,0,void 0,pe.ReactNextElement)),Ba();var rn,sn,on,cn,un,dn,hn,vn,gn,pn,bn,wn,mn,fn,kn,yn,En,Mn,xn,Wn=a(3704),{defineElement:Nn,property:Ln,event:Rn}=(0,ge.createDecorators)();on=[Nn("diagram.experimental-node",{styleTexts:[Wn.c]})],cn=Ln(),dn=Rn({type:"drag.start"}),pn=Rn({type:"drag.move"}),fn=Rn({type:"drag.end"});var Sn=new WeakMap,zn=new WeakMap,Cn=new WeakMap,Dn=new WeakMap,Tn=new WeakMap,Bn=new WeakMap,On=new WeakMap,An=new WeakMap,In=new WeakMap,Hn=new WeakMap;class Pn extends pe.ReactNextElement{constructor(){super(...arguments),(0,se.c)(this,In,{get:jn,set:_n}),(0,se.c)(this,Bn,{get:Vn,set:Xn}),(0,se.c)(this,Cn,{get:Yn,set:Kn}),(0,se.c)(this,Sn,{writable:!0,value:(rn(this),un(this))}),(0,se.c)(this,zn,{writable:!0,value:hn(this)}),(0,se.c)(this,Dn,{writable:!0,value:e=>{(0,ue.c)(this,Cn).emit(e)}}),(0,se.c)(this,Tn,{writable:!0,value:bn(this)}),(0,se.c)(this,On,{writable:!0,value:e=>{(0,ue.c)(this,Bn).emit(e)}}),(0,se.c)(this,An,{writable:!0,value:kn(this)}),(0,se.c)(this,Hn,{writable:!0,value:e=>{(0,ue.c)(this,In).emit(e)}})}get usage(){return(0,ue.c)(this,Sn)}set usage(e){(0,ce.c)(this,Sn,e)}render(){return ve().createElement(qn,{usage:this.usage,onDragStart:(0,ue.c)(this,Dn),onDragMove:(0,ue.c)(this,On),onDragEnd:(0,ue.c)(this,Hn)})}}function Kn(e){gn(this,e)}function Yn(){return vn(this)}function Xn(e){mn(this,e)}function Vn(){return wn(this)}function _n(e){En(this,e)}function jn(){return yn(this)}function qn(e){var{usage:t,onDragStart:a,onDragMove:n,onDragEnd:i}=e,l=(0,he.useCallback)((e=>{if("library"===t){e.stopPropagation(),e.preventDefault();var l=[e.clientX,e.clientY],r=!1,s=e=>{r||(r=(e.clientX-l[0])**2+(e.clientY-l[1])**2>=9)&&(null==a||a([e.clientX,e.clientY])),r&&(null==n||n([e.clientX,e.clientY]))},o=e=>{document.removeEventListener("mousemove",s),document.removeEventListener("mouseup",o),r&&(null==i||i([e.clientX,e.clientY]))};document.addEventListener("mousemove",s),document.addEventListener("mouseup",o)}}),[i,n,a,t]);return ve().createElement("div",{onMouseDown:l},ve().createElement("slot",null))}Mn=Pn,({e:[un,hn,vn,gn,bn,wn,mn,kn,yn,En,rn],c:[xn,sn]}=(0,de.c)(Mn,[[cn,1,"usage"],[dn,1,"dragStartEvent",e=>(0,ue.c)(e,zn),(e,t)=>(0,ce.c)(e,zn,t)],[pn,1,"dragMoveEvent",e=>(0,ue.c)(e,Tn),(e,t)=>(0,ce.c)(e,Tn,t)],[fn,1,"dragEndEvent",e=>(0,ue.c)(e,An),(e,t)=>(0,ce.c)(e,An,t)]],on,0,(e=>Hn.has((0,oe.c)(e))),pe.ReactNextElement)),sn()},7584:(e,t,a)=>{a.d(t,{c:()=>s});var n=a(8304),i=a.n(n),l=a(1849),r=a.n(l)()(i());r.push([e.id,"*{box-sizing:border-box}:host{display:block;background:var(--palette-gray-2);position:relative}:host([hidden]){display:none}",""]);const s=r.toString()},7518:(e,t,a)=>{a.d(t,{c:()=>s});var n=a(8304),i=a.n(n),l=a(1849),r=a.n(l)()(i());r.push([e.id,':host{display:block;--local-label-line-height:inherit;--local-label-font-size:inherit;--local-label-color:inherit;--local-label-font-weight:inherit}:host([hidden]){display:none}:host([type="line"]){--local-label-line-height:18px;--local-label-font-size:11px;--local-label-color:var(--color-secondary-text);--local-label-font-weight:400}*{box-sizing:border-box}.label{max-width:168px;margin:-3px}.label-text,\n.label-input{width:100%;height:24px;padding:3px;border:none;line-height:var(--local-label-line-height);font-size:var(--local-label-font-size);color:var(--local-label-color);font-weight:var(--local-label-font-weight);text-align:center;font-family:inherit;cursor:text;-webkit-user-select:text;-moz-user-select:text;user-select:text}.label-text{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.label.editing .label-text,\n.label.empty:not(.editing) .label-text,\n.label:not(.editing) .label-input{display:none}',""]);const s=r.toString()},3704:(e,t,a)=>{a.d(t,{c:()=>s});var n=a(8304),i=a.n(n),l=a(1849),r=a.n(l)()(i());r.push([e.id,'*{box-sizing:border-box}:host{display:block;border:1px solid var(--palette-gray-5);cursor:default}:host([hidden]){display:none}:host([usage="dragging"]){opacity:0.75;position:fixed}:host(:not([usage="library"])){background:var(--palette-gray-3);width:60px;height:60px}:host([usage="library"]){width:180px;height:30px;margin-bottom:10px}div{width:100%;height:100%;display:flex;align-items:center;justify-content:center}',""]);const s=r.toString()}}]);
2
+ //# sourceMappingURL=8272.fcc84aba.js.map