@next-bricks/diagram 0.5.2 → 0.7.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 (41) hide show
  1. package/dist/bricks.json +1 -1
  2. package/dist/chunks/{7312.3688d673.js → 7312.7dd56138.js} +3 -3
  3. package/dist/chunks/{7312.3688d673.js.map → 7312.7dd56138.js.map} +1 -1
  4. package/dist/chunks/7675.42d21e5c.js +2 -0
  5. package/dist/chunks/7675.42d21e5c.js.map +1 -0
  6. package/dist/chunks/9393.caf561ce.js +2 -0
  7. package/dist/chunks/9393.caf561ce.js.map +1 -0
  8. package/dist/chunks/editable-label.4f364423.js +3 -0
  9. package/dist/chunks/editable-label.4f364423.js.map +1 -0
  10. package/dist/chunks/eo-diagram.6168dc79.js +2 -0
  11. package/dist/chunks/eo-diagram.6168dc79.js.map +1 -0
  12. package/dist/chunks/{main.2d3b0cb6.js → main.b955f2dc.js} +2 -2
  13. package/dist/chunks/{main.2d3b0cb6.js.map → main.b955f2dc.js.map} +1 -1
  14. package/dist/examples.json +1 -1
  15. package/dist/{index.1993f974.js → index.cbfe9bdd.js} +2 -2
  16. package/dist/{index.1993f974.js.map → index.cbfe9bdd.js.map} +1 -1
  17. package/dist/manifest.json +32 -4
  18. package/dist/types.json +179 -6
  19. package/dist-types/diagram/LineComponent.d.ts +5 -2
  20. package/dist-types/diagram/constants.d.ts +2 -0
  21. package/dist-types/diagram/index.d.ts +14 -9
  22. package/dist-types/diagram/interfaces.d.ts +10 -0
  23. package/dist-types/diagram/processors/handleKeyboard.d.ts +8 -4
  24. package/dist-types/diagram/processors/{handleDiagramMouseDown.d.ts → handleNodesMouseDown.d.ts} +3 -3
  25. package/dist-types/diagram/processors/transformToCenter.d.ts +7 -0
  26. package/dist-types/diagram/processors/transformToCenter.spec.d.ts +1 -0
  27. package/docs/eo-diagram.md +70 -13
  28. package/package.json +2 -2
  29. package/dist/chunks/6457.0e22ff80.js +0 -2
  30. package/dist/chunks/6457.0e22ff80.js.map +0 -1
  31. package/dist/chunks/9393.4db156f6.js +0 -2
  32. package/dist/chunks/9393.4db156f6.js.map +0 -1
  33. package/dist/chunks/editable-label.6607b08b.js +0 -3
  34. package/dist/chunks/editable-label.6607b08b.js.map +0 -1
  35. package/dist/chunks/eo-diagram.a0684049.js +0 -2
  36. package/dist/chunks/eo-diagram.a0684049.js.map +0 -1
  37. package/dist-types/diagram/processors/getCenterOffsets.d.ts +0 -2
  38. /package/dist/chunks/{7312.3688d673.js.LICENSE.txt → 7312.7dd56138.js.LICENSE.txt} +0 -0
  39. /package/dist/chunks/{editable-label.6607b08b.js.LICENSE.txt → editable-label.4f364423.js.LICENSE.txt} +0 -0
  40. /package/dist-types/diagram/{processors/getCenterOffsets.spec.d.ts → ConnectLineComponent.spec.d.ts} +0 -0
  41. /package/dist-types/diagram/processors/{handleDiagramMouseDown.spec.d.ts → handleNodesMouseDown.spec.d.ts} +0 -0
@@ -0,0 +1,2 @@
1
+ "use strict";(self.webpackChunk_next_bricks_diagram=self.webpackChunk_next_bricks_diagram||[]).push([[7675],{2260:(e,t,n)=>{n.d(t,{K:()=>a});var r=n(8657),o=n.n(r);function a(e){var{clipPath:t,clipPathPrefix:n,renderedLineLabels:r}=e,{x0:a,y0:i,w:l,h:c,id:d}=t,s=r.find((e=>e.id===d));if(!s)return null;var{left:u,top:f,right:v,bottom:h}=s.lineRect;return o().createElement("clipPath",{key:d,id:"".concat(n).concat(d)},o().createElement("polygon",{points:["".concat(a,",").concat(i+c),"".concat(a+l,",").concat(i+c),"".concat(a+l,",").concat(i),"".concat(a,",").concat(i),"".concat(a,",").concat(f),"".concat(v,",").concat(f),"".concat(v,",").concat(h),"".concat(u,",").concat(h),"".concat(u,",").concat(f),"".concat(a,",").concat(f)].join(" ")}))}},7587:(e,t,n)=>{n.d(t,{f:()=>c});var r=n(8657),o=n.n(r),a=n(2779),i=n.n(a),l=n(9575);function c(e){var{connectLineState:t,connectLineTo:n,markerPrefix:r}=e;return o().createElement("svg",{width:"100%",height:"100%",className:i()("connect-line",{connecting:!!t&&(n[0]-t.from[0])**2+(n[1]-t.from[1])**2>25})},o().createElement("defs",null,o().createElement(l.C,{id:"".concat(r,"connect-line"),strokeColor:null==t?void 0:t.options.strokeColor})),o().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(r,"connect-line)"):void 0}))}},6462:(e,t,n)=>{n.d(t,{y:()=>l});var r=n(8657),o=n.n(r),a=n(2779),i=n.n(a);function l(e){var{line:{line:t,d:n,markerIndex:r,edge:a},linePaths:l,clipPathList:c,markerPrefix:d,clipPathPrefix:s,activeLineMarkerPrefix:u,activeEdge:f,onLineClick:v,onLineDoubleClick:h}=e,m=c.some((e=>e.id===t.$id))?"url(#".concat(s).concat(t.$id,")"):void 0;return o().createElement("g",{className:i()("line",{interactable:t.interactable,active:f&&a.source===f.source&&a.target===f.target}),onClick:t.interactable?()=>{null==v||v({id:t.$id,edge:a})}:void 0,onDoubleClick:t.interactable?e=>{e.preventDefault(),e.stopPropagation(),null==h||h({id:t.$id,edge:a})}:void 0,style:{cursor:t.cursor}},t.interactable&&o().createElement("path",{d:n,fill:"none",stroke:"transparent",strokeWidth:t.interactStrokeWidth}),o().createElement("path",{ref:e=>l.set(t.$id,e),stroke:t.strokeColor,strokeWidth:t.strokeWidth,d:n,fill:"none",markerEnd:void 0===r?void 0:"url(#".concat(d).concat(r,")"),clipPath:m}),o().createElement("path",{stroke:"var(--palette-blue-3)",strokeWidth:t.strokeWidth,d:n,fill:"none",className:"active-bg",markerStart:"url(#".concat(u,"start)"),markerEnd:"url(#".concat(u,"end)"),clipPath:m}))}},7853:(e,t,n)=>{n.d(t,{L8:()=>c});var r=n(3028),o=n(8657),a=n.n(o),i=n(9494),l=n(9464);function c(e){var{labels:t,onRendered:n}=e,[r,i]=(0,o.useState)(!1),[l,c]=(0,o.useState)([]),u=(0,o.useMemo)((()=>new Map),[]),f=(0,o.useCallback)(((e,t)=>{t&&u.set(e,t),c((t=>t.includes(e)?t:t.concat(e)))}),[u]),v=(0,o.useCallback)((e=>{c((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,o.useEffect)((()=>{i(!(null!=t&&t.some((e=>!l.includes(e.id)))))}),[t,l]),(0,o.useEffect)((()=>{null==n||n(r?u:null)}),[u,r]),a().createElement(a().Fragment,null,null==t?void 0:t.map((e=>{var{text:t,label:n,position:r,id:o,edge:i}=e;return n?a().createElement("div",{key:o,className:"line-label",style:{left:r[0],top:r[1]}},a().createElement(s,{id:o,edge:i,label:n,onRendered:f,onUnmount:v})):a().createElement(d,{key:o,id:o,text:t,position:r,onRendered:f})})))}function d(e){var{id:t,text:n,position:i,onRendered:l}=e,c=(0,o.useCallback)((e=>{null==l||l(t,e)}),[t,l]);return a().createElement("div",{className:"line-label",ref:c,style:(0,r.Z)({left:i[0],top:i[1]},n.style)},n.content)}function s(e){var{id:t,edge:n,label:r,onRendered:c,onUnmount:d}=e,s=(0,o.useMemo)((()=>(0,l.checkIfByTransform)(r,{edge:n})?r.useBrick:null),[n,r]),u=(0,o.useMemo)((()=>({edge:n})),[n]);(0,o.useEffect)((()=>{s||setTimeout((()=>{null==c||c(t,null)}))}),[t,c,s]),(0,o.useEffect)((()=>()=>{null==d||d(t)}),[]);var f=(0,o.useCallback)((e=>{e&&setTimeout((()=>{null==c||c(t,e.parentElement)}))}),[t,c]),v=(0,o.useCallback)((()=>{setTimeout((()=>{null==c||c(t,null)}))}),[t,c]);return s?a().createElement(i.ReactUseBrick,{refCallback:f,ignoredCallback:v,useBrick:s,data:u}):null}},9575:(e,t,n)=>{n.d(t,{C:()=>a});var r=n(8657),o=n.n(r);function a(e){var{id:t,strokeColor:n}=e;return o().createElement("marker",{id:t,viewBox:"0 0 6 6",refX:3,refY:3,markerWidth:6,markerHeight:6,orient:"auto"},o().createElement("path",{d:"M 0.5 0.5 L 5.5 3 L 0.5 5.5 z",stroke:n,strokeWidth:1,fill:n}))}},2370:(e,t,n)=>{n.d(t,{n:()=>l});var r=n(8657),o=n.n(r),a=n(9494),i=n(9464);function l(e){var{nodes:t,nodeBricks:n,onRendered:a}=e,[i,l]=(0,r.useState)(!1),[d,s]=(0,r.useState)([]),u=(0,r.useMemo)((()=>new Map),[]),f=(0,r.useCallback)(((e,t)=>{t&&u.set(e,t),s((t=>t.includes(e)?t:t.concat(e)))}),[u]),v=(0,r.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,r.useEffect)((()=>{l(!(null!=t&&t.some((e=>!d.includes(e.id)))))}),[t,d]),(0,r.useEffect)((()=>{null==a||a(i?u:null)}),[u,i]),o().createElement(o().Fragment,null,null==t?void 0:t.map((e=>o().createElement("div",{key:e.id,className:"node"},o().createElement(c,{nodeBricks:n,node:e,onRendered:f,onUnmount:v})))))}function c(e){var{node:t,nodeBricks:n,onRendered:l,onUnmount:c}=e,d=(0,r.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,i.checkIfByTransform)(t,{node:e})))}(t,n))||void 0===e?void 0:e.useBrick}),[t,n]),s=(0,r.useMemo)((()=>({node:t})),[t]);(0,r.useEffect)((()=>{d||setTimeout((()=>{null==l||l(t.id,null)}))}),[t.id,l,d]),(0,r.useEffect)((()=>()=>{null==c||c(t.id)}),[]);var u=(0,r.useCallback)((e=>{e&&setTimeout((()=>{null==l||l(t.id,e)}))}),[t.id,l]),f=(0,r.useCallback)((()=>{setTimeout((()=>{null==l||l(t.id,null)}))}),[t.id,l]);return d?o().createElement(a.ReactUseBrick,{refCallback:u,ignoredCallback:f,useBrick:d,data:s}):null}},5318:(e,t,n)=>{n.d(t,{IC:()=>r,_w:()=>o,no:()=>a,oh:()=>l,rN:()=>c,wl:()=>i});var r="var(--palette-gray-5)",o=1,a="curveBasis",i=20,l=.5,c=2},1251:(e,t,n)=>{function r(e,t){return e.map((e=>{var{id:n}=e,r=null==t?void 0:t.get(n);if(r){var{offsetWidth:o,offsetHeight:a}=r;if(0!==o&&0!==a)return{x0:r.offsetLeft-o/2-3,y0:r.offsetTop-a/2-3,w:o+6,h:a+6,id:n}}})).filter(Boolean)}n.d(t,{i:()=>r})},5173:(e,t,n)=>{n.d(t,{T:()=>a});var r=n(908),o=n.n(r);function a(e,t,n,r){var a=new(o().graphlib.Graph);for(var i of(a.setGraph(r),a.setDefaultEdgeLabel((function(){return{}})),null!=t?t:[])){var l=null==e?void 0:e.node(i.id);a.setNode(i.id,(null==l?void 0:l.data)===i?l:{id:i.id,data:i})}for(var c of null!=n?n:[])a.setEdge(c.source,c.target,{data:c});return a}},7201:(e,t,n)=>{n.d(t,{E:()=>a});var r=n(908),o=n.n(r);function a(e){var{graph:t,nodesRefRepository:n,nodePadding:r}=e;if(!t||!n||0===t.nodeCount())return null;var a=function(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)}(r);for(var i of t.nodes()){var l,c,d=t.node(i);if(d){var s=n.get(i);d.width=(null!==(l=null==s?void 0:s.offsetWidth)&&void 0!==l?l:10)+a[1]+a[3],d.height=(null!==(c=null==s?void 0:s.offsetHeight)&&void 0!==c?c:10)+a[0]+a[2]}else console.error("Diagram node not found: %s",i)}o().layout(t);var u=[];for(var f of t.nodes()){var v,h=t.node(f);if(h){u.push(h);var m=h.x-h.width/2+a[3],p=h.y-h.height/2+a[0],g=null===(v=n.get(f))||void 0===v?void 0:v.parentElement;g&&(g.style.left="".concat(m,"px"),g.style.top="".concat(p,"px"),g.style.visibility="visible")}}return{nodes:u,edges:t.edges().map((e=>t.edge(e)))}}},4126:(e,t,n)=>{function r(e,t,n){return 0===e.length&&0===t.length?e:t.map((e=>{var{line:{text:t,label:r,$id:o},edge:a}=e,i=n.get(o);if((t||r)&&i&&i.getAttribute("d")){var{x:l,y:c,width:d,height:s}=i.getBBox(),u=1e3,f=l-u,v=c-u,h=l+d+u,m=c+s+u,p=i.getPointAtLength(i.getTotalLength()/2);return{text:t,label:r,edge:a,position:[p.x,p.y],lineRect:{left:f,top:v,right:h,bottom:m},id:o}}})).filter(Boolean)}n.d(t,{K:()=>r})},5731:(e,t,n)=>{n.d(t,{b:()=>p});var r=n(3028),o=n(2159),a=n(1211),i=n(9464),l=n(5318),c=n(3698),d=n(1479),s=n(6481),u=n(9389),f=n(8282),v=n(5004);function h(e,t,n){if(!Array.isArray(e))return"";var r;switch(n){case"curveBasis":r=c.ZP;break;case"curveBumpX":r=d.sj;break;case"curveBumpY":r=d.BW;break;case"curveMonotoneX":r=s.Z;break;case"curveMonotoneY":r=s.s;break;case"curveNatural":r=u.Z;break;default:r=f.Z}var o=0,a=0;if(t){var{x:i,y:l}=e[e.length-2],{x:h,y:m}=e[e.length-1],p=t/Math.sqrt(Math.pow(h-i,2)+Math.pow(m-l,2));o=(i-h)*p,a=(l-m)*p}var g=e;return(0,v.Z)().x(((t,n)=>t.x-(n===e.length-1?o:0))).y(((t,n)=>t.y-(n===e.length-1?a:0))).curve(r)(g)}var m=["label"];function p(e,t){var n=[],c=[],d=function(e){var d,s=null!==(d=null==t?void 0:t.find((t=>{return n=e,!!(r=t)&&(r.edgeType?[].concat(r.edgeType).includes(n.type):(0,i.checkIfByTransform)(r,{edge:n}));var n,r})))&&void 0!==d?d:{},{label:f}=s,v=(0,o.Z)(s,m),p=i.__secret_internals.legacyDoTransform({edge:e},v);if(!1===(null==p?void 0:p.draw))return 1;var g,k=(0,r.Z)((0,r.Z)({strokeColor:l.IC,strokeWidth:l._w,curveType:l.no,interactStrokeWidth:l.wl},p),{},{label:f,$id:(0,a.uniqueId)("line-")});if(k.arrow){var b={strokeColor:k.strokeColor};-1===(g=(0,a.findIndex)(c,b))&&(g=c.push(b)-1)}var y=h(u,k.arrow?-5:0,k.curveType);n.push({line:k,d:y,markerIndex:g,edge:e})};for(var{data:s,points:u}of e)d(s);return{renderedLines:n,markers:c}}},5702:(e,t,n)=>{n.d(t,{p:()=>o});var r=n(1211);function o(e,t){var{renderedNodes:n,renderedEdges:r,activeTarget:o}=t,l="node"===(null==o?void 0:o.type)?n.find((e=>e.id===o.nodeId)):void 0,c="edge"===(null==o?void 0:o.type)?o.edge:void 0;if(l||c){var d,s,u,f,v=e.key||e.keyCode||e.which;switch(v){case"Backspace":case 8:case"Delete":case 46:l?(d="delete-node",s=l):(d="delete-edge",u=c);break;default:if(!l)return;switch(v){case"ArrowLeft":case 37:s=a(n,l,-1),d="switch-active-node";break;case"ArrowUp":case 38:s=i(n,r,l,-1),d="switch-active-node";break;case"ArrowRight":case 39:s=a(n,l,1),d="switch-active-node";break;case"ArrowDown":case 40:s=i(n,r,l,1),d="switch-active-node"}}if(d)return e.preventDefault(),e.stopPropagation(),{action:d,node:null===(f=s)||void 0===f?void 0:f.data,edge:u}}}function a(e,t,n){var o,a=e.filter((e=>e!==t&&(o=(e.x-t.x)*n)>0&&o>Math.abs(t.y-e.y)));return(0,r.minBy)(a,(e=>(t.y-e.y)**2+(t.x-e.x)**2))}function i(e,t,n,o){var a=1===o?"source":"target",i=1===o?"target":"source",l=t.filter((e=>{var{data:t}=e;return t[a]===n.id&&t[i]!==n.id})).map((t=>{var{data:n}=t;return e.find((e=>e.id===n[i]))})).filter((e=>e&&(e.y-n.y)*o>0));return(0,r.minBy)(l,(e=>(n.y-e.y)**2+(n.x-e.x)**2))}},542:(e,t,n)=>{n.d(t,{w:()=>i});var r=n(3028),o=n(9464),a=n(5318);function i(e,t){var{nodes:n,nodesRefRepository:i,nodesConnect:l,setConnectLineState:c,setConnectLineTo:d,onSwitchActiveTarget:s,onNodesConnect:u}=t;function f(e){if(i){var t,r=function(t){if(e(a))return{v:null==n?void 0:n.find((e=>e.id===t))}};for(var[o,a]of i)if(t=r(o))return t.v}}if(l){var v=f((t=>t.contains(e.target)));if(v){if(l.sourceType){if(![].concat(l.sourceType).includes(v.type))return}else if(!(0,o.checkIfByTransform)(l,{source:v}))return;e.stopPropagation(),c({from:[e.clientX,e.clientY],options:(0,r.Z)({strokeColor:a.IC,strokeWidth:a._w},o.__secret_internals.legacyDoTransform({source:v},l))}),d([e.clientX,e.clientY]),null==s||s({type:"node",nodeId:v.id});var h=e=>{d([e.clientX,e.clientY])},m=e=>{document.removeEventListener("mousemove",h),document.removeEventListener("mouseup",m),c(null);var t=e.composedPath(),n=f((e=>t.includes(e)));n&&v!==n&&(null==u||u({source:v,target:n}))};document.addEventListener("mousemove",h),document.addEventListener("mouseup",m)}}}},7441:(e,t,n)=>{function r(e,t){var{canvasWidth:n,canvasHeight:r,scaleRange:o}=t,a=1/0,i=1/0,l=-1/0,c=-1/0;for(var d of e){var s=d.width/2,u=d.height/2,f=d.x-s,v=d.x+s,h=d.y-u,m=d.y+u;f<a&&(a=f),v>l&&(l=v),h<i&&(i=h),m>c&&(c=m)}var p=l-a,g=c-i,k=o&&(p>n||g>r)?Math.max(Math.min(n/p,r/g,o[1]),o[0]):1;return{x:(n-p*k)/2-i,y:(r-g*k)/2-a,k}}n.d(t,{i:()=>r})},6436:(e,t,n)=>{n.d(t,{Z:()=>l});var r=n(9601),o=n.n(r),a=n(2609),i=n.n(a)()(o());i.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}.ready{opacity:1;cursor:-webkit-grab;cursor:grab}.lines,\n.line-labels,\n.nodes{position:absolute;top:0;left:0}.nodes,\n.lines{transform-origin:0 0}.node{position:absolute;visibility:hidden}.grabbing{cursor:-webkit-grabbing;cursor:grabbing}.line-label{position:absolute;transform:translate(-50%,-50%);white-space:pre-line;width:-webkit-max-content;width:-moz-max-content;width:max-content;text-align:center}.lines{pointer-events:none}.line.interactable{pointer-events:auto}.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=i.toString()}}]);
2
+ //# sourceMappingURL=7675.42d21e5c.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"chunks/7675.42d21e5c.js","mappings":"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","sources":["webpack:///./src/diagram/ClipPathComponent.tsx","webpack:///./src/diagram/ConnectLineComponent.tsx","webpack:///./src/diagram/LineComponent.tsx","webpack:///./src/diagram/LineLabelComponent.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/getClipPathList.ts","webpack:///./src/diagram/processors/getDagreGraph.ts","webpack:///./src/diagram/processors/getRenderedDiagram.ts","webpack:///./src/diagram/processors/extractPartialRectTuple.ts","webpack:///./src/diagram/processors/getRenderedLineLabels.ts","webpack:///./src/diagram/lines/curveLine.ts","webpack:///./src/diagram/processors/getRenderedLinesAndMarkers.ts","webpack:///./src/diagram/processors/matchEdgeByFilter.ts","webpack:///./src/diagram/processors/handleKeyboard.ts","webpack:///./src/diagram/processors/handleNodesMouseDown.ts","webpack:///./src/diagram/processors/transformToCenter.ts","webpack:///./src/diagram/styles.shadow.css"],"sourcesContent":["import React from \"react\";\nimport type { LineTextClipPath, RenderedLineLabel } from \"./interfaces\";\n\nexport interface ClipPathComponentProps {\n clipPathPrefix: string;\n clipPath: LineTextClipPath;\n renderedLineLabels: RenderedLineLabel[];\n}\n\nexport function ClipPathComponent({\n clipPath,\n clipPathPrefix,\n renderedLineLabels,\n}: ClipPathComponentProps): JSX.Element | null {\n const { x0, y0, w, h, id } = clipPath;\n const lineText = renderedLineLabels.find((item) => item.id === id);\n if (!lineText) {\n return null;\n }\n const { left, top, right, bottom } = lineText.lineRect;\n // https://css-tricks.com/cutting-inner-part-element-using-clip-path/\n return (\n <clipPath key={id} id={`${clipPathPrefix}${id}`}>\n <polygon\n points={[\n `${x0},${y0 + h}`,\n `${x0 + w},${y0 + h}`,\n `${x0 + w},${y0}`,\n `${x0},${y0}`,\n `${x0},${top}`,\n `${right},${top}`,\n `${right},${bottom}`,\n `${left},${bottom}`,\n `${left},${top}`,\n `${x0},${top}`,\n ].join(\" \")}\n />\n </clipPath>\n );\n}\n","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 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 {\n DiagramEdge,\n LineTarget,\n LineTextClipPath,\n RenderedLine,\n} from \"./interfaces\";\n\nexport interface LineComponentProps {\n line: RenderedLine;\n linePaths: Map<string, SVGPathElement | null>;\n clipPathList: LineTextClipPath[];\n markerPrefix: string;\n clipPathPrefix: string;\n activeLineMarkerPrefix: string;\n activeEdge: DiagramEdge | null;\n onLineClick?(line: LineTarget): void;\n onLineDoubleClick?(line: LineTarget): void;\n}\n\nexport function LineComponent({\n line: { line, d, markerIndex, edge },\n linePaths,\n clipPathList,\n markerPrefix,\n clipPathPrefix,\n activeLineMarkerPrefix,\n activeEdge,\n onLineClick,\n onLineDoubleClick,\n}: LineComponentProps): JSX.Element {\n const clipPath = clipPathList.some((clip) => clip.id === line.$id)\n ? `url(#${clipPathPrefix}${line.$id})`\n : undefined;\n return (\n <g\n className={classNames(\"line\", {\n interactable: line.interactable,\n active:\n activeEdge &&\n edge.source === activeEdge.source &&\n edge.target === activeEdge.target,\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={line.interactStrokeWidth}\n />\n )}\n <path\n ref={(element) => linePaths.set(line.$id, element)}\n stroke={line.strokeColor}\n strokeWidth={line.strokeWidth}\n d={d}\n fill=\"none\"\n markerEnd={\n markerIndex === undefined\n ? undefined\n : `url(#${markerPrefix}${markerIndex})`\n }\n clipPath={clipPath}\n />\n <path\n stroke=\"var(--palette-blue-3)\"\n strokeWidth={line.strokeWidth}\n d={d}\n fill=\"none\"\n className=\"active-bg\"\n markerStart={`url(#${activeLineMarkerPrefix}start)`}\n markerEnd={`url(#${activeLineMarkerPrefix}end)`}\n clipPath={clipPath}\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 RenderedLineLabel,\n TextOptions,\n} from \"./interfaces\";\n\nexport interface LineLabelComponentGroupProps {\n labels?: RenderedLineLabel[];\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 >\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\";\n\nexport interface MarkerComponentProps {\n id: string;\n strokeColor?: string;\n}\n\nexport function MarkerComponent({\n id,\n strokeColor,\n}: MarkerComponentProps): JSX.Element {\n return (\n <marker\n id={id}\n viewBox=\"0 0 6 6\"\n refX={3}\n refY={3}\n markerWidth={6}\n markerHeight={6}\n orient=\"auto\"\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","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 {\n LineTextClipPath,\n RefRepository,\n RenderedLineLabel,\n} from \"../interfaces\";\n\nexport function getClipPathList(\n renderedLineLabels: RenderedLineLabel[],\n lineLabelsRefRepository: RefRepository\n) {\n return renderedLineLabels\n .map(({ id }) => {\n const element = lineLabelsRefRepository?.get(id);\n if (!element) {\n return;\n }\n const { offsetWidth, offsetHeight } = element;\n // Do not clip when the label takes no space.\n if (\n process.env.NODE_ENV !== \"test\" &&\n (offsetWidth === 0 || offsetHeight === 0)\n ) {\n return;\n }\n const padding = 3;\n return {\n x0: element.offsetLeft - offsetWidth / 2 - padding,\n y0: element.offsetTop - offsetHeight / 2 - padding,\n w: offsetWidth + padding * 2,\n h: offsetHeight + padding * 2,\n id,\n };\n })\n .filter(Boolean) as LineTextClipPath[];\n}\n","import dagre from \"@dagrejs/dagre\";\nimport type { DiagramEdge, DiagramNode, RenderedNode } from \"../interfaces\";\n\nexport function getDagreGraph(\n previousGraph: dagre.graphlib.Graph<RenderedNode> | null,\n nodes: DiagramNode[] | undefined,\n edges: DiagramEdge[] | undefined,\n dagreGraphOptions: dagre.GraphLabel\n) {\n // Create a new directed graph\n const newGraph = new dagre.graphlib.Graph<RenderedNode>();\n\n // Set an object for the graph label\n newGraph.setGraph(dagreGraphOptions);\n\n // Default to assigning a new object as a label for each new edge.\n newGraph.setDefaultEdgeLabel(function () {\n return {};\n });\n\n for (const node of nodes ?? []) {\n const previousNode = previousGraph?.node(node.id);\n newGraph.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 newGraph.setEdge(edge.source, edge.target, { data: edge });\n }\n\n return newGraph;\n}\n","import dagre from \"@dagrejs/dagre\";\nimport type {\n PartialRectTuple,\n RefRepository,\n RenderedEdge,\n RenderedNode,\n} from \"../interfaces\";\nimport { extractPartialRectTuple } from \"./extractPartialRectTuple\";\n\nexport interface RenderedDiagram {\n nodes: RenderedNode[];\n edges: RenderedEdge[];\n}\n\nexport function getRenderedDiagram({\n graph,\n nodesRefRepository,\n nodePadding,\n}: {\n graph: dagre.graphlib.Graph<RenderedNode> | null;\n nodesRefRepository: RefRepository | null;\n nodePadding: PartialRectTuple;\n}): RenderedDiagram | null {\n if (!graph || !nodesRefRepository || graph.nodeCount() === 0) {\n return null;\n }\n\n const paddings = extractPartialRectTuple(nodePadding);\n\n for (const id of graph.nodes()) {\n const node = graph.node(id);\n if (!node) {\n // eslint-disable-next-line no-console\n console.error(\"Diagram node not found: %s\", id);\n continue;\n }\n const element = nodesRefRepository.get(id);\n node.width = (element?.offsetWidth ?? 10) + paddings[1] + paddings[3];\n node.height = (element?.offsetHeight ?? 10) + paddings[0] + paddings[2];\n }\n\n dagre.layout(graph);\n\n // const positions = new Map<DiagramNodeId, NodePosition>();\n const renderedNodes: RenderedNode[] = [];\n\n for (const v of graph.nodes()) {\n const node = graph.node(v);\n if (!node) {\n continue;\n }\n renderedNodes.push(node);\n const x = node.x - node.width / 2 + paddings[3];\n const y = node.y - node.height / 2 + paddings[0];\n // positions.set(v, { x, y });\n\n const nodeContainer = nodesRefRepository.get(v)?.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 return {\n nodes: renderedNodes,\n edges: graph.edges().map((e) => graph.edge(e) as RenderedEdge),\n };\n}\n","import type { FullRectTuple, PartialRectTuple } from \"../interfaces\";\n\nexport function extractPartialRectTuple(\n value: PartialRectTuple\n): FullRectTuple {\n if (Array.isArray(value)) {\n const v0 = value[0];\n const v1 = value.length > 1 ? value[1]! : v0;\n const v2 = value.length > 2 ? value[2]! : v0;\n const v3 = value.length > 3 ? value[3]! : v1;\n return [v0, v1, v2, v3];\n }\n return new Array(4).fill(value) as FullRectTuple;\n}\n","import type { RenderedLine, RenderedLineLabel } 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\n .map(({ line: { text, label, $id }, edge }) => {\n const path = linePaths.get($id);\n if ((!text && !label) || !path || !path.getAttribute(\"d\")) {\n return;\n }\n\n // istanbul ignore next\n const { x, y, width, height } =\n process.env.NODE_ENV === \"test\"\n ? { x: 10, y: 20, width: 300, height: 400 }\n : path.getBBox();\n // Make redundant extra padding.\n const padding = 1000;\n const left = x - padding;\n const top = y - padding;\n const right = x + width + padding;\n const bottom = y + height + padding;\n\n // istanbul ignore next\n const point =\n process.env.NODE_ENV === \"test\"\n ? { x: 50, y: 50 }\n : path.getPointAtLength(path.getTotalLength() / 2);\n return {\n text,\n label,\n edge,\n position: [point.x, point.y],\n lineRect: { left, top, right, bottom },\n id: $id,\n };\n })\n .filter(Boolean) as RenderedLineLabel[];\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>,\n arrowOffset: number,\n curveType?: CurveType\n): string {\n if (!Array.isArray(points)) {\n return \"\";\n }\n let curveFactory: CurveFactory;\n switch (curveType) {\n case \"curveBasis\":\n curveFactory = curveBasis;\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 = curveLinear;\n }\n let arrowOffsetX = 0;\n let arrowOffsetY = 0;\n if (arrowOffset) {\n const { x: x0, y: y0 } = points[points.length - 2];\n const { x: x1, y: y1 } = points[points.length - 1];\n const distance = Math.sqrt(Math.pow(x1 - x0, 2) + Math.pow(y1 - y0, 2));\n const ratio = arrowOffset / distance;\n arrowOffsetX = (x0 - x1) * ratio;\n arrowOffsetY = (y0 - y1) * ratio;\n }\n const transformPoints = points;\n const lineFunction = line()\n .x(\n (d, index) =>\n (d as unknown as { x: number }).x -\n (index === points.length - 1 ? arrowOffsetX : 0)\n )\n .y(\n (d, index) =>\n (d as unknown as { y: number }).y -\n (index === points.length - 1 ? arrowOffsetY : 0)\n )\n .curve(curveFactory);\n return lineFunction(transformPoints as unknown as Array<[number, number]>)!;\n}\n","import { findIndex, uniqueId } from \"lodash\";\nimport { __secret_internals } from \"@next-core/runtime\";\nimport type {\n LineConf,\n LineMarker,\n RenderedEdge,\n RenderedLine,\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\";\nimport { curveLine } from \"../lines/curveLine\";\n\nexport function getRenderedLinesAndMarkers(\n renderedEdges: RenderedEdge[],\n lines: LineConf[] | undefined\n) {\n const renderedLines: RenderedLine[] = [];\n const markers: LineMarker[] = [];\n for (const { data, points } of renderedEdges) {\n const { label, ...restLineConf } =\n lines?.find((line) => matchEdgeByFilter(data, line)) ?? {};\n\n const computedLineConf = __secret_internals.legacyDoTransform(\n { edge: data },\n restLineConf\n ) as LineConf | undefined;\n if (computedLineConf?.draw === false) {\n continue;\n }\n const line: RenderedLine[\"line\"] = {\n strokeColor: DEFAULT_LINE_STROKE_COLOR,\n strokeWidth: DEFAULT_LINE_STROKE_WIDTH,\n curveType: DEFAULT_LINE_CURVE_TYPE,\n interactStrokeWidth: DEFAULT_LINE_INTERACT_STROKE_WIDTH,\n ...computedLineConf,\n label,\n $id: uniqueId(\"line-\"),\n };\n\n let markerIndex: number | undefined;\n if (line.arrow) {\n const marker: LineMarker = {\n strokeColor: line.strokeColor,\n };\n markerIndex = findIndex(markers, marker);\n if (markerIndex === -1) {\n markerIndex = markers.push(marker) - 1;\n }\n }\n\n const d = curveLine(points, line.arrow ? -5 : 0, line.curveType);\n\n renderedLines.push({\n line,\n d,\n markerIndex,\n edge: data,\n });\n }\n return {\n renderedLines,\n markers,\n };\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 { minBy } from \"lodash\";\nimport type {\n ActiveTarget,\n DiagramEdge,\n DiagramNode,\n RenderedEdge,\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 renderedEdges,\n activeTarget,\n }: {\n renderedNodes: RenderedNode[];\n renderedEdges: RenderedEdge[];\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 = moveOnX(renderedNodes, activeNode, -1);\n action = \"switch-active-node\";\n break;\n }\n case \"ArrowUp\":\n case 38: {\n node = moveOnY(renderedNodes, renderedEdges, activeNode, -1);\n action = \"switch-active-node\";\n break;\n }\n case \"ArrowRight\":\n case 39: {\n node = moveOnX(renderedNodes, activeNode, 1);\n action = \"switch-active-node\";\n break;\n }\n case \"ArrowDown\":\n case 40: {\n node = moveOnY(renderedNodes, renderedEdges, 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 moveOnX(\n renderedNodes: RenderedNode[],\n activeNode: RenderedNode,\n direction: 1 | -1\n) {\n let diff: number;\n const candidates = renderedNodes.filter(\n (node) =>\n node !== activeNode &&\n ((diff = (node.x - activeNode.x) * direction), diff > 0) &&\n diff > Math.abs(activeNode.y - node.y)\n );\n return minBy(\n candidates,\n (node) => (activeNode.y - node.y) ** 2 + (activeNode.x - node.x) ** 2\n );\n}\n\nfunction moveOnY(\n renderedNodes: RenderedNode[],\n renderedEdges: RenderedEdge[],\n activeNode: RenderedNode,\n direction: 1 | -1\n) {\n const from = direction === 1 ? \"source\" : \"target\";\n const to = direction === 1 ? \"target\" : \"source\";\n const candidateEdges = renderedEdges.filter(\n ({ data }) => data[from] === activeNode.id && data[to] !== activeNode.id\n );\n const candidates = candidateEdges\n .map(({ data }) => renderedNodes.find((node) => node.id === data[to]))\n .filter(\n (node) => node && (node.y - activeNode.y) * direction > 0\n ) as RenderedNode[];\n return minBy(\n candidates,\n (node) => (activeNode.y - node.y) ** 2 + (activeNode.x - node.x) ** 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 NodesConnectOptions,\n PositionTuple,\n RefRepository,\n ActiveTarget,\n} from \"../interfaces\";\n\nexport function handleNodesMouseDown(\n event: MouseEvent,\n {\n nodes,\n nodesRefRepository,\n nodesConnect,\n setConnectLineState,\n setConnectLineTo,\n onSwitchActiveTarget,\n onNodesConnect,\n }: {\n nodes: DiagramNode[] | undefined;\n nodesConnect: NodesConnectOptions | undefined;\n nodesRefRepository: RefRepository | null;\n setConnectLineState: (\n value: React.SetStateAction<ConnectLineState | null>\n ) => void;\n setConnectLineTo: (value: React.SetStateAction<PositionTuple>) => 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 (!nodesConnect) {\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 (nodesConnect.sourceType) {\n if (\n !([] as unknown[]).concat(nodesConnect.sourceType).includes(source.type)\n ) {\n return;\n }\n } else if (!checkIfByTransform(nodesConnect, { source })) {\n return;\n }\n\n event.stopPropagation();\n\n setConnectLineState({\n from: [event.clientX, event.clientY],\n options: {\n strokeColor: DEFAULT_LINE_STROKE_COLOR,\n strokeWidth: DEFAULT_LINE_STROKE_WIDTH,\n ...(__secret_internals.legacyDoTransform(\n { source },\n nodesConnect\n ) as NodesConnectOptions),\n },\n });\n setConnectLineTo([event.clientX, event.clientY]);\n onSwitchActiveTarget?.({ type: \"node\", nodeId: source.id });\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}\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 - top;\n const y = (canvasHeight - height * scale) / 2 - left;\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}.ready{opacity:1;cursor:-webkit-grab;cursor:grab}.lines,\n.line-labels,\n.nodes{position:absolute;top:0;left:0}.nodes,\n.lines{transform-origin:0 0}.node{position:absolute;visibility:hidden}.grabbing{cursor:-webkit-grabbing;cursor:grabbing}.line-label{position:absolute;transform:translate(-50%,-50%);white-space:pre-line;width:-webkit-max-content;width:-moz-max-content;width:max-content;text-align:center}.lines{pointer-events:none}.line.interactable{pointer-events:auto}.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":["ClipPathComponent","_ref","clipPath","clipPathPrefix","renderedLineLabels","x0","y0","w","h","id","lineText","find","item","left","top","right","bottom","lineRect","React","key","concat","points","join","ConnectLineComponent","connectLineState","connectLineTo","markerPrefix","width","height","className","classNames","connecting","from","MarkerComponent","strokeColor","options","d","fill","stroke","strokeWidth","markerEnd","arrow","undefined","LineComponent","line","markerIndex","edge","linePaths","clipPathList","activeLineMarkerPrefix","activeEdge","onLineClick","onLineDoubleClick","some","clip","$id","interactable","active","source","target","onClick","onDoubleClick","e","preventDefault","stopPropagation","style","cursor","interactStrokeWidth","ref","element","set","markerStart","LineLabelComponentGroup","labels","onRendered","rendered","setRendered","useState","renderedIds","setRenderedIds","refRepository","useMemo","Map","handleRenderer","useCallback","previous","includes","handleUnmount","index","indexOf","slice","delete","useEffect","label","map","_ref2","text","position","LineLabelComponent","onUnmount","LineTextComponent","_ref3","refCallback","_objectSpread","content","_ref4","useBrick","checkIfByTransform","memoizedData","setTimeout","parentElement","ignoredCallback","ReactUseBrick","data","viewBox","refX","refY","markerWidth","markerHeight","orient","NodeComponentGroup","nodes","nodeBricks","node","NodeComponent","_findNodeBrick","nodeType","type","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","getClipPathList","lineLabelsRefRepository","get","offsetWidth","offsetHeight","offsetLeft","offsetTop","padding","filter","Boolean","getDagreGraph","previousGraph","edges","dagreGraphOptions","newGraph","dagre","Graph","setGraph","setDefaultEdgeLabel","previousNode","setNode","setEdge","getRenderedDiagram","graph","nodesRefRepository","nodePadding","nodeCount","paddings","value","Array","isArray","v0","v1","length","extractPartialRectTuple","_element$offsetWidth","_element$offsetHeight","console","error","renderedNodes","v","_nodesRefRepository$g","push","x","y","nodeContainer","visibility","getRenderedLineLabels","renderedLines","path","getAttribute","getBBox","point","getPointAtLength","getTotalLength","curveLine","arrowOffset","curveType","curveFactory","curveBasis","curveBumpX","curveBumpY","curveMonotoneX","curveMonotoneY","curveNatural","curveLinear","arrowOffsetX","arrowOffsetY","x1","y1","ratio","Math","sqrt","pow","transformPoints","curve","lineFunction","getRenderedLinesAndMarkers","renderedEdges","lines","markers","_loop","_lines$find","matchEdgeByFilter","edgeType","restLineConf","_objectWithoutProperties","_excluded","computedLineConf","__secret_internals","legacyDoTransform","draw","uniqueId","marker","findIndex","handleKeyboard","event","activeTarget","activeNode","nodeId","action","_node","keyCode","which","moveOnX","moveOnY","direction","diff","candidates","abs","minBy","to","handleNodesMouseDown","nodesConnect","setConnectLineState","setConnectLineTo","onSwitchActiveTarget","onNodesConnect","findNode","match","_ret","contains","sourceType","clientX","clientY","onMouseMove","onMouseUp","document","removeEventListener","eventTargets","composedPath","addEventListener","transformToCenter","canvasWidth","canvasHeight","scaleRange","Infinity","hw","hh","l","r","t","b","scale","max","min","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([[9393],{9393:(e,t,a)=>{a.r(t);var n,l,i,s,r,o,c,u,h,d,b,p,g,v,Z,w,f,k,m,y,E,M,W,C,x,L,R,S,D,T,z,N,P,B,A,H,K,O,I,_,X,Y,V,q,$,j,F,G,J,Q,U,ee,te,ae,ne=a(3028),le=a(3395),ie=a(1815),se=a(381),re=a(687),oe=a(5066),ce=a(8657),ue=a.n(ce),he=a(5727),de=a(305),be=(a(928),a(1105)),pe=a(7397),ge=a(2779),ve=a.n(ge),Ze=a(1211),we=a(2370),fe=a(5702),ke=a(7441),me=a(5731),ye=a(7853),Ee=a(6462),Me=a(9575),We=a(2260),Ce=a(7587),xe=a(1251),Le=a(4126),Re=a(7201),Se=a(5173),De=a(542),Te=a(6436),ze=a(5318),{defineElement:Ne,property:Pe,event:Be,method:Ae}=(0,he.createDecorators)(),He=(0,ce.forwardRef)(St);l=Ne("eo-diagram",{styleTexts:[Te.Z]}),i=Pe({type:String}),r=Pe({attribute:!1}),c=Pe({attribute:!1}),h=Pe({attribute:!1}),b=Pe({attribute:!1}),g=Pe({attribute:!1}),Z=Pe({attribute:!1}),f=Pe({type:Boolean}),m=Pe({attribute:!1}),E=Pe({type:Boolean}),W=Pe({type:Boolean}),x=Pe({attribute:!1}),R=Be({type:"activeTarget.change"}),z=Be({type:"node.delete"}),A=Be({type:"edge.delete"}),I=Be({type:"line.click"}),V=Be({type:"line.dblclick"}),F=Be({type:"nodes.connect"}),U=Ae();var Ke=new WeakMap,Oe=new WeakMap,Ie=new WeakMap,_e=new WeakMap,Xe=new WeakMap,Ye=new WeakMap,Ve=new WeakMap,qe=new WeakMap,$e=new WeakMap,je=new WeakMap,Fe=new WeakMap,Ge=new WeakMap,Je=new WeakMap,Qe=new WeakMap,Ue=new WeakMap,et=new WeakMap,tt=new WeakMap,at=new WeakMap,nt=new WeakMap,lt=new WeakMap,it=new WeakMap,st=new WeakMap,rt=new WeakMap,ot=new WeakMap,ct=new WeakMap,ut=new WeakMap,ht=new WeakMap,dt=new WeakMap,bt=new WeakMap,pt=new WeakMap,gt=new WeakMap,vt=new WeakMap;class Zt extends de.ReactNextElement{constructor(){super(...arguments),(0,le.Z)(this,bt,{get:Rt,set:Lt}),(0,le.Z)(this,ut,{get:xt,set:Ct}),(0,le.Z)(this,rt,{get:Wt,set:Mt}),(0,le.Z)(this,lt,{get:Et,set:yt}),(0,le.Z)(this,tt,{get:mt,set:kt}),(0,le.Z)(this,Qe,{get:ft,set:wt}),(0,le.Z)(this,Ke,{writable:!0,value:(ee(this),s(this))}),(0,le.Z)(this,Oe,{writable:!0,value:o(this)}),(0,le.Z)(this,Ie,{writable:!0,value:u(this)}),(0,le.Z)(this,_e,{writable:!0,value:d(this)}),(0,le.Z)(this,Xe,{writable:!0,value:p(this)}),(0,le.Z)(this,Ye,{writable:!0,value:v(this)}),(0,le.Z)(this,Ve,{writable:!0,value:w(this)}),(0,le.Z)(this,qe,{writable:!0,value:k(this)}),(0,le.Z)(this,$e,{writable:!0,value:y(this)}),(0,le.Z)(this,je,{writable:!0,value:M(this,!0)}),(0,le.Z)(this,Fe,{writable:!0,value:C(this,!0)}),(0,le.Z)(this,Ge,{writable:!0,value:L(this)}),(0,le.Z)(this,Je,{writable:!0,value:S(this)}),(0,le.Z)(this,Ue,{writable:!0,value:e=>{(0,re.Z)(this,Qe).emit(e)}}),(0,le.Z)(this,et,{writable:!0,value:N(this)}),(0,le.Z)(this,at,{writable:!0,value:e=>{(0,re.Z)(this,tt).emit(e)}}),(0,le.Z)(this,nt,{writable:!0,value:H(this)}),(0,le.Z)(this,it,{writable:!0,value:e=>{(0,re.Z)(this,lt).emit(e)}}),(0,le.Z)(this,st,{writable:!0,value:_(this)}),(0,le.Z)(this,ot,{writable:!0,value:e=>{(0,re.Z)(this,rt).emit(e)}}),(0,le.Z)(this,ct,{writable:!0,value:q(this)}),(0,le.Z)(this,ht,{writable:!0,value:e=>{(0,re.Z)(this,ut).emit(e)}}),(0,le.Z)(this,dt,{writable:!0,value:G(this)}),(0,le.Z)(this,pt,{writable:!0,value:e=>{(0,re.Z)(this,bt).emit(e)}}),(0,le.Z)(this,gt,{writable:!0,value:e=>{this.activeTarget=e}}),(0,le.Z)(this,vt,{writable:!0,value:(0,ce.createRef)()})}get layout(){return(0,re.Z)(this,Ke)}set layout(e){(0,se.Z)(this,Ke,e)}get nodes(){return(0,re.Z)(this,Oe)}set nodes(e){(0,se.Z)(this,Oe,e)}get edges(){return(0,re.Z)(this,Ie)}set edges(e){(0,se.Z)(this,Ie,e)}get nodeBricks(){return(0,re.Z)(this,_e)}set nodeBricks(e){(0,se.Z)(this,_e,e)}get lines(){return(0,re.Z)(this,Xe)}set lines(e){(0,se.Z)(this,Xe,e)}get layoutOptions(){return(0,re.Z)(this,Ye)}set layoutOptions(e){(0,se.Z)(this,Ye,e)}get activeTarget(){return(0,re.Z)(this,Ve)}set activeTarget(e){(0,se.Z)(this,Ve,e)}get disableKeyboardAction(){return(0,re.Z)(this,qe)}set disableKeyboardAction(e){(0,se.Z)(this,qe,e)}get nodesConnect(){return(0,re.Z)(this,$e)}set nodesConnect(e){(0,se.Z)(this,$e,e)}get zoomable(){return(0,re.Z)(this,je)}set zoomable(e){(0,se.Z)(this,je,e)}get scrollable(){return(0,re.Z)(this,Fe)}set scrollable(e){(0,se.Z)(this,Fe,e)}get scaleRange(){return(0,re.Z)(this,Ge)}set scaleRange(e){(0,se.Z)(this,Ge,e)}callOnLineLabel(e,t){for(var a,n=arguments.length,l=new Array(n>2?n-2:0),i=2;i<n;i++)l[i-2]=arguments[i];null===(a=(0,re.Z)(this,vt).current)||void 0===a||a.callOnLineLabel(e,t,...l)}render(){return ue().createElement(He,{ref:(0,re.Z)(this,vt),layout:this.layout,nodes:this.nodes,edges:this.edges,nodeBricks:this.nodeBricks,lines:this.lines,layoutOptions:this.layoutOptions,nodesConnect:this.nodesConnect,activeTarget:this.activeTarget,disableKeyboardAction:this.disableKeyboardAction,zoomable:this.zoomable,scrollable:this.scrollable,scaleRange:this.scaleRange,onActiveTargetChange:(0,re.Z)(this,Ue),onSwitchActiveTarget:(0,re.Z)(this,gt),onNodeDelete:(0,re.Z)(this,at),onEdgeDelete:(0,re.Z)(this,it),onLineClick:(0,re.Z)(this,ot),onLineDoubleClick:(0,re.Z)(this,ht),onNodesConnect:(0,re.Z)(this,pt)})}}function wt(e){T(this,e)}function ft(){return D(this)}function kt(e){B(this,e)}function mt(){return P(this)}function yt(e){O(this,e)}function Et(){return K(this)}function Mt(e){Y(this,e)}function Wt(){return X(this)}function Ct(e){j(this,e)}function xt(){return $(this)}function Lt(e){Q(this,e)}function Rt(){return J(this)}function St(e,t){var{layout:a,nodes:n,edges:l,nodeBricks:i,lines:s,layoutOptions:r,nodesConnect:o,activeTarget:c,disableKeyboardAction:u,zoomable:h,scrollable:d,scaleRange:b,onActiveTargetChange:p,onSwitchActiveTarget:g,onNodeDelete:v,onEdgeDelete:Z,onLineClick:w,onLineDoubleClick:f,onNodesConnect:k}=e,[m,y]=(0,ce.useState)(null),[E,M]=(0,ce.useState)(!1),[W,C]=(0,ce.useState)(0),[x,L]=(0,ce.useState)(null),[R,S]=(0,ce.useState)(0),[D,T]=(0,ce.useState)(null),[z,N]=(0,ce.useState)([]),[P,B]=(0,ce.useState)([]),[A,H]=(0,ce.useState)([]),[K,O]=(0,ce.useState)(!1),[I,_]=(0,ce.useState)({k:1,x:0,y:0}),X=(0,ce.useRef)(new Map),Y=(0,ce.useRef)(null),V=(0,ce.useRef)(null),[q,$]=(0,ce.useState)(!1),[j,F]=(0,ce.useState)([0,0]),[G,J]=(0,ce.useState)(null);(0,ce.useImperativeHandle)(t,(()=>({callOnLineLabel(e,t){for(var a,n=arguments.length,l=new Array(n>2?n-2:0),i=2;i<n;i++)l[i-2]=arguments[i];null==D||null===(a=D.get(e))||void 0===a||null===(a=a.firstElementChild)||void 0===a||a[t](...l)}}))),(0,ce.useEffect)((()=>{var e=e=>{(0,De.w)(e,{nodes:n,nodesRefRepository:x,nodesConnect:o,setConnectLineState:J,setConnectLineTo:F,onSwitchActiveTarget:g,onNodesConnect:k})},t=V.current;return null==t||t.addEventListener("mousedown",e),()=>{null==t||t.removeEventListener("mousedown",e)}}),[n,o,x,k,g]);var Q=(0,ce.useMemo)((()=>(0,ne.Z)({rankdir:"TB",ranksep:50,edgesep:10,nodesep:50,nodePadding:0},r)),[r]),{nodePadding:U}=Q,ee=(0,ce.useMemo)((()=>(0,Ze.pick)(Q,["rankdir","ranksep","edgesep","nodesep","align"])),[Q]),te=(0,ce.useRef)(!1);(0,ce.useEffect)((()=>{te.current?null==p||p(null!=c?c:null):te.current=!0}),[n,c,p]),(0,ce.useEffect)((()=>{y((e=>(0,Se.T)(e,n,l,ee)))}),[l,n,ee]),(0,ce.useEffect)((()=>{var e=(0,Re.E)({graph:m,nodesRefRepository:x,nodePadding:U});e&&(N(e.nodes),B(e.edges))}),[m,x,W,U]);var{renderedLines:ae,markers:le}=(0,ce.useMemo)((()=>(0,me.b)(P,s)),[s,P]);(0,ce.useEffect)((()=>{var e=Y.current;if(e&&!u){var t=e=>{var t=(0,fe.p)(e,{renderedNodes:z,renderedEdges:P,activeTarget:c});"delete-node"===(null==t?void 0:t.action)?null==v||v(t.node):"delete-edge"===(null==t?void 0:t.action)?null==Z||Z(t.edge):"switch-active-node"===(null==t?void 0:t.action)&&t.node&&(null==g||g({type:"node",nodeId:t.node.id}))};return e.addEventListener("keydown",t),()=>{e.removeEventListener("keydown",t)}}}),[c,z,P,u,g,v,Z]);var ie=(0,ce.useCallback)((e=>{e&&(C((e=>e+1)),L(e)),M((t=>t||!!e))}),[]),se=(0,ce.useCallback)((e=>{e&&(S((e=>e+1)),T(e))}),[]),re=(0,ce.useMemo)((()=>null!=b?b:[ze.oh,ze.rN]),[b]),oe=(0,ce.useMemo)((()=>(0,pe.sP)()),[]);(0,ce.useEffect)((()=>{var e=!1;oe.scaleExtent(h?re:[1,1]).on("start",(()=>{e=!1,O(!0)})).on("zoom",(t=>{e=!0,_(t.transform)})).on("end",(()=>{O(!1),e||null==g||g(null)}))}),[g,re,h,oe]),(0,ce.useEffect)((()=>{var e=Y.current;if(e){var t=(0,be.Z)(e);return h||d?t.on("wheel.zoom.custom",(e=>{e.ctrlKey||(e.stopImmediatePropagation(),d&&(e.preventDefault(),oe.translateBy(t,e.wheelDeltaX/5,e.wheelDeltaY/5)))})):t.on(".zoom",null),t.on("wheel",(e=>e.preventDefault())).call(oe).on("dblclick.zoom",null),()=>{t.on(".zoom",null),t.on(".zoom.custom",null)}}}),[d,h,oe]),(0,ce.useEffect)((()=>{var e=Y.current;if(0!==z.length&&e&&!q){var{k:t,x:a,y:n}=(0,ke.i)(z,{canvasWidth:e.clientWidth,canvasHeight:e.clientHeight,scaleRange:h?re:void 0});oe.transform((0,be.Z)(e),new pe.ax(t,a,n)),$(!0)}}),[q,z,re,h,oe]);var he=(0,ce.useMemo)((()=>"".concat((0,Ze.uniqueId)("diagram-"),"-")),[]),de="".concat(he,"line-arrow-"),ge="".concat(he,"clip-path-"),Te="".concat(he,"active-line-");(0,ce.useEffect)((()=>{H((e=>(0,Le.K)(e,ae,X.current)))}),[ae]);var[Ne,Pe]=ue().useState([]);return(0,ce.useEffect)((()=>{D&&Pe((0,xe.i)(A,D))}),[R,D,A]),"dagre"!==a?ue().createElement("div",null,'Diagram layout not supported: "'.concat(a,'"')):ue().createElement("div",{className:ve()("diagram",{ready:E&&q,grabbing:K}),tabIndex:-1,ref:Y},ue().createElement("svg",{width:"100%",height:"100%",className:"lines"},ue().createElement("defs",null,le.map(((e,t)=>{var{strokeColor:a}=e;return ue().createElement(Me.C,{key:t,id:"".concat(de).concat(t),strokeColor:a})})),Ne.map((e=>ue().createElement(We.K,{key:e.id,clipPath:e,clipPathPrefix:ge,renderedLineLabels:A}))),ue().createElement("marker",{id:"".concat(Te,"start"),viewBox:"0 0 8 8",refX:4,refY:4,markerWidth:8,markerHeight:8,orient:"auto"},ue().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)"})),ue().createElement("marker",{id:"".concat(Te,"end"),viewBox:"0 0 14 8",refX:3,refY:4,markerWidth:14,markerHeight:8,orient:"auto"},ue().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)"}),ue().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)"}))),ue().createElement("g",{transform:"translate(".concat(I.x," ").concat(I.y,") scale(").concat(I.k,")")},ae.map((e=>ue().createElement(Ee.y,{key:e.line.$id,line:e,linePaths:X.current,clipPathList:Ne,markerPrefix:de,clipPathPrefix:ge,activeLineMarkerPrefix:Te,activeEdge:"edge"===(null==c?void 0:c.type)?c.edge:null,onLineClick:w,onLineDoubleClick:f}))))),ue().createElement("div",{className:"line-labels",style:{left:I.x,top:I.y,transform:"scale(".concat(I.k,")")}},ue().createElement(ye.L8,{labels:A,onRendered:se})),ue().createElement("div",{className:"nodes",ref:V,style:{left:I.x,top:I.y,transform:"scale(".concat(I.k,")")}},ue().createElement(we.n,{nodes:n,nodeBricks:i,onRendered:ie})),ue().createElement(Ce.f,{connectLineState:G,connectLineTo:j,markerPrefix:de}))}te=Zt,({e:[s,o,u,d,p,v,w,k,y,M,C,L,S,D,T,N,P,B,H,K,O,_,X,Y,q,$,j,G,J,Q,ee],c:[ae,n]}=(0,oe.Z)(te,[[i,1,"layout"],[r,1,"nodes"],[c,1,"edges"],[h,1,"nodeBricks"],[b,1,"lines"],[g,1,"layoutOptions"],[Z,1,"activeTarget"],[f,1,"disableKeyboardAction"],[m,1,"nodesConnect"],[E,1,"zoomable"],[W,1,"scrollable"],[x,1,"scaleRange"],[R,1,"activeTargetChangeEvent",e=>(0,re.Z)(e,Je),(e,t)=>(0,se.Z)(e,Je,t)],[z,1,"nodeDelete",e=>(0,re.Z)(e,et),(e,t)=>(0,se.Z)(e,et,t)],[A,1,"edgeDelete",e=>(0,re.Z)(e,nt),(e,t)=>(0,se.Z)(e,nt,t)],[I,1,"lineClick",e=>(0,re.Z)(e,st),(e,t)=>(0,se.Z)(e,st,t)],[V,1,"lineDoubleClick",e=>(0,re.Z)(e,ct),(e,t)=>(0,se.Z)(e,ct,t)],[F,1,"nodesConnect",e=>(0,re.Z)(e,dt),(e,t)=>(0,se.Z)(e,dt,t)],[U,2,"callOnLineLabel"]],[l],0,(e=>vt.has((0,ie.Z)(e))),de.ReactNextElement)),n();var Dt,Tt,zt,Nt,Pt,Bt,At,Ht,Kt,Ot,It,_t,Xt,Yt,Vt,qt,$t,jt,Ft=a(8074),{defineElement:Gt,property:Jt,event:Qt,method:Ut}=(0,he.createDecorators)(),ea=(0,ce.forwardRef)(ga);Tt=Gt("diagram.editable-label",{styleTexts:[Ft.Z]}),zt=Jt(),Pt=Jt({render:!1}),At=Qt({type:"label.editing.change"}),It=Qt({type:"label.change"}),Vt=Ut();var ta=new WeakMap,aa=new WeakMap,na=new WeakMap,la=new WeakMap,ia=new WeakMap,sa=new WeakMap,ra=new WeakMap,oa=new WeakMap,ca=new WeakMap;class ua extends de.ReactNextElement{constructor(){super(...arguments),(0,le.Z)(this,ra,{get:pa,set:ba}),(0,le.Z)(this,la,{get:da,set:ha}),(0,le.Z)(this,ta,{writable:!0,value:(qt(this),Nt(this))}),(0,le.Z)(this,aa,{writable:!0,value:Bt(this)}),(0,le.Z)(this,na,{writable:!0,value:Ht(this)}),(0,le.Z)(this,ia,{writable:!0,value:e=>{(0,re.Z)(this,la).emit(e)}}),(0,le.Z)(this,sa,{writable:!0,value:_t(this)}),(0,le.Z)(this,oa,{writable:!0,value:e=>{(0,re.Z)(this,ra).emit(e)}}),(0,le.Z)(this,ca,{writable:!0,value:(0,ce.createRef)()})}get label(){return(0,re.Z)(this,ta)}set label(e){(0,se.Z)(this,ta,e)}get type(){return(0,re.Z)(this,aa)}set type(e){(0,se.Z)(this,aa,e)}enableEditing(){var e;null===(e=(0,re.Z)(this,ca).current)||void 0===e||e.enableEditing()}render(){return ue().createElement(ea,{ref:(0,re.Z)(this,ca),label:this.label,onLabelEditingChange:(0,re.Z)(this,ia),onLabelChange:(0,re.Z)(this,oa)})}}function ha(e){Ot(this,e)}function da(){return Kt(this)}function ba(e){Yt(this,e)}function pa(){return Xt(this)}function ga(e,t){var{label:a,onLabelChange:n,onLabelEditingChange:l}=e,i=null!=a?a:"",[s,r]=(0,ce.useState)(i),[o,c]=(0,ce.useState)(!1),u=(0,ce.useRef)(!1),[h,d]=(0,ce.useState)(!1),b=(0,ce.useRef)(null);(0,ce.useImperativeHandle)(t,(()=>({enableEditing(){c(!0)}}))),(0,ce.useEffect)((()=>{r(i)}),[i]);var p=(0,ce.useCallback)((e=>{e.preventDefault(),e.stopPropagation(),c(!0)}),[]);(0,ce.useEffect)((()=>{var e,t;o&&(null===(e=b.current)||void 0===e||e.focus({preventScroll:!0}),null===(t=b.current)||void 0===t||t.select())}),[o]),(0,ce.useEffect)((()=>{u.current?null==l||l(o):u.current=!0}),[o,l]);var g=(0,ce.useCallback)((e=>{r(e.target.value)}),[]),v=(0,ce.useCallback)((e=>{var t,a=e.key||e.keyCode||e.which;"Enter"!==a&&13!==a||null===(t=b.current)||void 0===t||t.blur()}),[]),Z=(0,ce.useCallback)((()=>{c(!1),d(!0)}),[]);(0,ce.useEffect)((()=>{h&&(null==n||n(s),d(!1))}),[s,n,h]);var w=(0,ce.useCallback)((e=>{e.stopPropagation()}),[]);return ue().createElement("div",{className:ve()("label",{editing:o,empty:!s}),onDoubleClick:w,onMouseDown:w},ue().createElement("input",{className:"label-input",value:s,ref:b,onChange:g,onKeyDown:v,onBlur:Z}),ue().createElement("div",{className:"label-text",onDoubleClick:p},s))}$t=ua,({e:[Nt,Bt,Ht,Kt,Ot,_t,Xt,Yt,qt],c:[jt,Dt]}=(0,oe.Z)($t,[[zt,1,"label"],[Pt,1,"type"],[At,1,"labelEditingChange",e=>(0,re.Z)(e,na),(e,t)=>(0,se.Z)(e,na,t)],[It,1,"labelChange",e=>(0,re.Z)(e,sa),(e,t)=>(0,se.Z)(e,sa,t)],[Vt,2,"enableEditing"]],[Tt],0,(e=>ca.has((0,ie.Z)(e))),de.ReactNextElement)),Dt()},8074:(e,t,a)=>{a.d(t,{Z:()=>r});var n=a(9601),l=a.n(n),i=a(2609),s=a.n(i)()(l());s.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 r=s.toString()}}]);
2
+ //# sourceMappingURL=9393.caf561ce.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"chunks/9393.caf561ce.js","mappings":"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","sources":["webpack:///./src/diagram/index.tsx","webpack:///./src/editable-label/index.tsx","webpack:///./src/editable-label/styles.shadow.css"],"sourcesContent":["import React, {\n createRef,\n forwardRef,\n useCallback,\n useEffect,\n useImperativeHandle,\n useMemo,\n useRef,\n useState,\n} from \"react\";\nimport { EventEmitter, createDecorators } from \"@next-core/element\";\nimport { ReactNextElement } from \"@next-core/react-element\";\nimport \"@next-core/theme\";\nimport dagre from \"@dagrejs/dagre\";\nimport { select } from \"d3-selection\";\nimport { ZoomTransform, zoom } from \"d3-zoom\";\nimport classNames from \"classnames\";\nimport { pick, uniqueId } from \"lodash\";\nimport type {\n DiagramEdge,\n DiagramNode,\n LayoutOptionsDagre,\n LineConf,\n NodeBrickConf,\n PositionTuple,\n RefRepository,\n RenderedEdge,\n RenderedLineLabel,\n RenderedNode,\n LineTextClipPath,\n TransformLiteral,\n LineTarget,\n ConnectLineDetail,\n NodesConnectOptions,\n ConnectLineState,\n ActiveTarget,\n RangeTuple,\n} from \"./interfaces\";\nimport { NodeComponentGroup } from \"./NodeComponent\";\nimport { handleKeyboard } from \"./processors/handleKeyboard\";\nimport { transformToCenter } from \"./processors/transformToCenter\";\nimport { getRenderedLinesAndMarkers } from \"./processors/getRenderedLinesAndMarkers\";\nimport { LineLabelComponentGroup } from \"./LineLabelComponent\";\nimport { LineComponent } from \"./LineComponent\";\nimport { MarkerComponent } from \"./MarkerComponent\";\nimport { ClipPathComponent } from \"./ClipPathComponent\";\nimport { ConnectLineComponent } from \"./ConnectLineComponent\";\nimport { getClipPathList } from \"./processors/getClipPathList\";\nimport { getRenderedLineLabels } from \"./processors/getRenderedLineLabels\";\nimport { getRenderedDiagram } from \"./processors/getRenderedDiagram\";\nimport { getDagreGraph } from \"./processors/getDagreGraph\";\nimport { handleNodesMouseDown } from \"./processors/handleNodesMouseDown\";\nimport styleText from \"./styles.shadow.css\";\nimport { DEFAULT_SCALE_RANGE_MAX, DEFAULT_SCALE_RANGE_MIN } from \"./constants\";\n\nconst { defineElement, property, event, method } = createDecorators();\n\nexport interface EoDiagramProps {\n layout?: \"dagre\";\n nodes?: DiagramNode[];\n edges?: DiagramEdge[];\n nodeBricks?: NodeBrickConf[];\n lines?: LineConf[];\n layoutOptions?: LayoutOptionsDagre;\n nodesConnect?: NodesConnectOptions;\n activeTarget?: ActiveTarget | null;\n disableKeyboardAction?: boolean;\n zoomable?: boolean;\n scrollable?: boolean;\n scaleRange?: RangeTuple;\n}\n\nexport interface DiagramRef {\n callOnLineLabel(id: string, method: string, ...args: unknown[]): void;\n}\n\nexport const EoDiagramComponent = forwardRef(LegacyEoDiagramComponent);\n\n/**\n * 构件 `eo-diagram`\n */\nexport\n@defineElement(\"eo-diagram\", {\n styleTexts: [styleText],\n})\nclass EoDiagram extends ReactNextElement implements EoDiagramProps {\n /**\n * @required\n */\n @property({ type: String })\n accessor layout: \"dagre\" | undefined;\n\n @property({ attribute: false })\n accessor nodes: DiagramNode[] | undefined;\n\n @property({ attribute: false })\n accessor edges: DiagramEdge[] | undefined;\n\n @property({ attribute: false })\n accessor nodeBricks: NodeBrickConf[] | undefined;\n\n @property({ attribute: false })\n accessor lines: LineConf[] | undefined;\n\n @property({ attribute: false })\n accessor layoutOptions: LayoutOptionsDagre | undefined;\n\n @property({ attribute: false })\n accessor activeTarget: ActiveTarget | null | undefined;\n\n @property({ type: Boolean })\n accessor disableKeyboardAction: boolean | undefined;\n\n @property({ attribute: false })\n accessor nodesConnect: NodesConnectOptions | undefined;\n\n @property({ type: Boolean })\n accessor zoomable: boolean | undefined = true;\n\n @property({ type: Boolean })\n accessor scrollable: boolean | undefined = true;\n\n @property({ attribute: false })\n accessor scaleRange: RangeTuple | undefined;\n\n @event({ type: \"activeTarget.change\" })\n accessor #activeTargetChangeEvent!: EventEmitter<ActiveTarget | null>;\n\n #handleActiveTargetChange = (target: ActiveTarget | null) => {\n this.#activeTargetChangeEvent.emit(target);\n };\n\n @event({ type: \"node.delete\" })\n accessor #nodeDelete!: EventEmitter<DiagramNode>;\n\n #handleNodeDelete = (node: DiagramNode) => {\n this.#nodeDelete.emit(node);\n };\n\n @event({ type: \"edge.delete\" })\n accessor #edgeDelete!: EventEmitter<DiagramEdge>;\n\n #handleEdgeDelete = (edge: DiagramEdge) => {\n this.#edgeDelete.emit(edge);\n };\n\n @event({ type: \"line.click\" })\n accessor #lineClick!: EventEmitter<LineTarget>;\n\n #handleLineClick = (line: LineTarget) => {\n this.#lineClick.emit(line);\n };\n\n @event({ type: \"line.dblclick\" })\n accessor #lineDoubleClick!: EventEmitter<LineTarget>;\n\n #handleLineDoubleClick = (line: LineTarget) => {\n this.#lineDoubleClick.emit(line);\n };\n\n @event({ type: \"nodes.connect\" })\n accessor #nodesConnect!: EventEmitter<ConnectLineDetail>;\n\n #handleNodesConnect = (detail: ConnectLineDetail) => {\n this.#nodesConnect.emit(detail);\n };\n\n #handleSwitchActiveTarget = (target: ActiveTarget | null) => {\n this.activeTarget = target;\n };\n\n #diagramRef = createRef<DiagramRef>();\n\n @method()\n callOnLineLabel(id: string, method: string, ...args: unknown[]) {\n this.#diagramRef.current?.callOnLineLabel(id, method, ...args);\n }\n\n render() {\n return (\n <EoDiagramComponent\n ref={this.#diagramRef}\n layout={this.layout}\n nodes={this.nodes}\n edges={this.edges}\n nodeBricks={this.nodeBricks}\n lines={this.lines}\n layoutOptions={this.layoutOptions}\n nodesConnect={this.nodesConnect}\n activeTarget={this.activeTarget}\n disableKeyboardAction={this.disableKeyboardAction}\n zoomable={this.zoomable}\n scrollable={this.scrollable}\n scaleRange={this.scaleRange}\n onActiveTargetChange={this.#handleActiveTargetChange}\n onSwitchActiveTarget={this.#handleSwitchActiveTarget}\n onNodeDelete={this.#handleNodeDelete}\n onEdgeDelete={this.#handleEdgeDelete}\n onLineClick={this.#handleLineClick}\n onLineDoubleClick={this.#handleLineDoubleClick}\n onNodesConnect={this.#handleNodesConnect}\n />\n );\n }\n}\n\nexport interface EoDiagramComponentProps extends EoDiagramProps {\n onActiveTargetChange?(target: ActiveTarget | null): void;\n onSwitchActiveTarget?(target: ActiveTarget | null): void;\n onNodeDelete?(node: DiagramNode): void;\n onEdgeDelete?(edge: DiagramEdge): void;\n onLineClick?(line: LineTarget): void;\n onLineDoubleClick?(line: LineTarget): void;\n onNodesConnect?(detail: ConnectLineDetail): void;\n}\n\nexport function LegacyEoDiagramComponent(\n {\n layout,\n nodes,\n edges,\n nodeBricks,\n lines,\n layoutOptions,\n nodesConnect,\n activeTarget,\n disableKeyboardAction,\n zoomable,\n scrollable,\n scaleRange: _scaleRange,\n onActiveTargetChange,\n onSwitchActiveTarget,\n onNodeDelete,\n onEdgeDelete,\n onLineClick,\n onLineDoubleClick,\n onNodesConnect,\n }: EoDiagramComponentProps,\n ref: React.Ref<DiagramRef>\n) {\n const [graph, setGraph] = useState<dagre.graphlib.Graph<RenderedNode> | null>(\n null\n );\n const [nodesReady, setNodesReady] = useState(false);\n const [nodesRenderId, setNodesRenderId] = useState(0);\n const [nodesRefRepository, setNodesRefRepository] =\n useState<RefRepository | null>(null);\n // const [lineLabelsReady, setLineLabelsReady] = useState(false);\n const [lineLabelsRenderId, setLineLabelsRenderId] = useState(0);\n const [lineLabelsRefRepository, setLineLabelsRefRepository] =\n useState<RefRepository | null>(null);\n const [renderedNodes, setRenderedNodes] = useState<RenderedNode[]>([]);\n const [renderedEdges, setRenderedEdges] = useState<RenderedEdge[]>([]);\n const [renderedLineLabels, setRenderedLineLabels] = useState<\n RenderedLineLabel[]\n >([]);\n\n const [grabbing, setGrabbing] = useState(false);\n const [transform, setTransform] = useState<TransformLiteral>({\n k: 1,\n x: 0,\n y: 0,\n });\n\n const linePathsRef = useRef(new Map<string, SVGPathElement | null>());\n\n const rootRef = useRef<HTMLDivElement>(null);\n const nodesRef = useRef<HTMLDivElement>(null);\n const [centered, setCentered] = useState(false);\n\n const [connectLineTo, setConnectLineTo] = useState<PositionTuple>([0, 0]);\n const [connectLineState, setConnectLineState] =\n useState<ConnectLineState | null>(null);\n\n useImperativeHandle(ref, () => ({\n callOnLineLabel(id, method, ...args) {\n (\n lineLabelsRefRepository?.get(id)\n ?.firstElementChild as unknown as Record<string, Function>\n )?.[method](...args);\n },\n }));\n\n useEffect(() => {\n const onNodesMouseDown = (event: MouseEvent) => {\n handleNodesMouseDown(event, {\n nodes,\n nodesRefRepository,\n nodesConnect,\n setConnectLineState,\n setConnectLineTo,\n onSwitchActiveTarget,\n onNodesConnect,\n });\n };\n // Bind mousedown event manually, since the React event handler can't work with\n // d3-zoom inside shadow DOM.\n const nodesContainer = nodesRef.current;\n nodesContainer?.addEventListener(\"mousedown\", onNodesMouseDown);\n return () => {\n nodesContainer?.removeEventListener(\"mousedown\", onNodesMouseDown);\n };\n }, [\n nodes,\n nodesConnect,\n nodesRefRepository,\n onNodesConnect,\n onSwitchActiveTarget,\n ]);\n\n const fixedOptions = useMemo(\n () => ({\n rankdir: \"TB\",\n ranksep: 50,\n edgesep: 10,\n nodesep: 50,\n // align: undefined,\n nodePadding: 0,\n ...layoutOptions,\n }),\n [layoutOptions]\n );\n\n const { nodePadding } = fixedOptions;\n const dagreGraphOptions = useMemo(\n () =>\n pick(fixedOptions, [\"rankdir\", \"ranksep\", \"edgesep\", \"nodesep\", \"align\"]),\n [fixedOptions]\n );\n\n const activeTargetChangeInitialized = useRef(false);\n useEffect(() => {\n if (!activeTargetChangeInitialized.current) {\n activeTargetChangeInitialized.current = true;\n return;\n }\n onActiveTargetChange?.(activeTarget ?? null);\n }, [nodes, activeTarget, onActiveTargetChange]);\n\n useEffect(() => {\n setGraph((previousGraph) =>\n getDagreGraph(previousGraph, nodes, edges, dagreGraphOptions)\n );\n }, [edges, nodes, dagreGraphOptions]);\n\n useEffect(() => {\n const renderedDiagram = getRenderedDiagram({\n graph,\n nodesRefRepository,\n nodePadding,\n });\n if (renderedDiagram) {\n setRenderedNodes(renderedDiagram.nodes);\n setRenderedEdges(renderedDiagram.edges);\n }\n }, [graph, nodesRefRepository, nodesRenderId, nodePadding]);\n\n const { renderedLines, markers } = useMemo(\n () => getRenderedLinesAndMarkers(renderedEdges, lines),\n [lines, renderedEdges]\n );\n\n useEffect(() => {\n const root = rootRef.current;\n if (!root || disableKeyboardAction) {\n return;\n }\n const onKeydown = (event: KeyboardEvent) => {\n const action = handleKeyboard(event, {\n renderedNodes,\n renderedEdges,\n activeTarget,\n });\n\n if (action?.action === \"delete-node\") {\n onNodeDelete?.(action.node);\n } else if (action?.action === \"delete-edge\") {\n onEdgeDelete?.(action.edge);\n } else if (action?.action === \"switch-active-node\" && action.node) {\n onSwitchActiveTarget?.({ type: \"node\", nodeId: action.node.id });\n }\n };\n root.addEventListener(\"keydown\", onKeydown);\n return () => {\n root.removeEventListener(\"keydown\", onKeydown);\n };\n }, [\n activeTarget,\n renderedNodes,\n renderedEdges,\n disableKeyboardAction,\n onSwitchActiveTarget,\n onNodeDelete,\n onEdgeDelete,\n ]);\n\n const handleNodesRendered = useCallback(\n (refRepository: RefRepository | null) => {\n if (refRepository) {\n setNodesRenderId((previous) => previous + 1);\n setNodesRefRepository(refRepository);\n }\n setNodesReady((previous) => previous || !!refRepository);\n },\n []\n );\n\n const handleLineLabelsRendered = useCallback(\n (refRepository: RefRepository | null) => {\n if (refRepository) {\n setLineLabelsRenderId((previous) => previous + 1);\n setLineLabelsRefRepository(refRepository);\n }\n // setLineLabelsReady((previous) => previous || !!refRepository);\n },\n []\n );\n\n const scaleRange = useMemo(\n () =>\n _scaleRange ??\n ([DEFAULT_SCALE_RANGE_MIN, DEFAULT_SCALE_RANGE_MAX] as RangeTuple),\n [_scaleRange]\n );\n\n const zoomer = useMemo(() => zoom<HTMLDivElement, unknown>(), []);\n\n useEffect(() => {\n let moved = false;\n zoomer\n .scaleExtent(zoomable ? scaleRange : [1, 1])\n .on(\"start\", () => {\n moved = false;\n setGrabbing(true);\n })\n .on(\"zoom\", (e: { transform: TransformLiteral }) => {\n moved = true;\n setTransform(e.transform);\n })\n .on(\"end\", () => {\n setGrabbing(false);\n if (!moved) {\n onSwitchActiveTarget?.(null);\n }\n });\n }, [onSwitchActiveTarget, scaleRange, zoomable, zoomer]);\n\n useEffect(() => {\n const root = rootRef.current;\n if (!root) {\n return;\n }\n\n const rootSelection = select(root);\n\n if (zoomable || scrollable) {\n // Do not override default d3 zoom handler.\n // Only handles *panning*\n rootSelection.on(\n \"wheel.zoom.custom\",\n (e: WheelEvent & { wheelDeltaX: number; wheelDeltaY: number }) => {\n // Mac OS trackpad pinch event is emitted as a wheel.zoom and d3.event.ctrlKey set to true\n if (!e.ctrlKey) {\n // Stop immediate propagation for default d3 zoom handler\n e.stopImmediatePropagation();\n if (scrollable) {\n e.preventDefault();\n zoomer.translateBy(\n rootSelection,\n e.wheelDeltaX / 5,\n e.wheelDeltaY / 5\n );\n }\n }\n // zoomer.scaleBy(rootSelection, Math.pow(2, defaultWheelDelta(e)))\n }\n );\n } else {\n rootSelection.on(\".zoom\", null);\n }\n\n rootSelection\n .on(\"wheel\", (e: WheelEvent) => e.preventDefault())\n .call(zoomer)\n .on(\"dblclick.zoom\", null);\n\n return () => {\n rootSelection.on(\".zoom\", null);\n rootSelection.on(\".zoom.custom\", null);\n };\n }, [scrollable, zoomable, zoomer]);\n\n useEffect(() => {\n const root = rootRef.current;\n if (renderedNodes.length === 0 || !root || centered) {\n return;\n }\n const { k, x, y } = transformToCenter(renderedNodes, {\n canvasWidth: root.clientWidth,\n canvasHeight: root.clientHeight,\n scaleRange: zoomable ? scaleRange : undefined,\n });\n zoomer.transform(select(root), new ZoomTransform(k, x, y));\n setCentered(true);\n }, [centered, renderedNodes, scaleRange, zoomable, zoomer]);\n\n const defPrefix = useMemo(() => `${uniqueId(\"diagram-\")}-`, []);\n const markerPrefix = `${defPrefix}line-arrow-`;\n const clipPathPrefix = `${defPrefix}clip-path-`;\n const activeLineMarkerPrefix = `${defPrefix}active-line-`;\n\n useEffect(() => {\n setRenderedLineLabels((previous) =>\n getRenderedLineLabels(previous, renderedLines, linePathsRef.current)\n );\n }, [renderedLines]);\n\n const [clipPathList, setClipPathList] = React.useState<LineTextClipPath[]>(\n []\n );\n\n useEffect(() => {\n if (!lineLabelsRefRepository) {\n return;\n }\n setClipPathList(\n getClipPathList(renderedLineLabels, lineLabelsRefRepository)\n );\n }, [lineLabelsRenderId, lineLabelsRefRepository, renderedLineLabels]);\n\n if (layout !== \"dagre\") {\n return <div>{`Diagram layout not supported: \"${layout}\"`}</div>;\n }\n\n return (\n <div\n className={classNames(\"diagram\", {\n ready: nodesReady && centered,\n grabbing,\n })}\n tabIndex={-1}\n ref={rootRef}\n >\n <svg width=\"100%\" height=\"100%\" className=\"lines\">\n <defs>\n {markers.map(({ strokeColor }, index) => (\n <MarkerComponent\n key={index}\n id={`${markerPrefix}${index}`}\n strokeColor={strokeColor}\n />\n ))}\n {clipPathList.map((clipPath) => (\n <ClipPathComponent\n key={clipPath.id}\n clipPath={clipPath}\n clipPathPrefix={clipPathPrefix}\n renderedLineLabels={renderedLineLabels}\n />\n ))}\n <marker\n id={`${activeLineMarkerPrefix}start`}\n viewBox=\"0 0 8 8\"\n refX={4}\n refY={4}\n markerWidth={8}\n markerHeight={8}\n orient=\"auto\"\n >\n <path\n d=\"M 0.5 0.5 H 7.5 V 7.5 H 0.5 Z\"\n stroke=\"var(--palette-gray-7)\"\n strokeWidth={1}\n fill=\"var(--palette-gray-1)\"\n />\n </marker>\n <marker\n id={`${activeLineMarkerPrefix}end`}\n viewBox=\"0 0 14 8\"\n refX={3}\n refY={4}\n markerWidth={14}\n markerHeight={8}\n orient=\"auto\"\n >\n <path\n d=\"M 0.5 1.5 L 5.5 4 L 0.5 6.5 z\"\n stroke=\"var(--palette-blue-3)\"\n strokeWidth={1}\n fill=\"var(--palette-blue-3)\"\n />\n <path\n d=\"M 6.5 0.5 H 13.5 V 7.5 H 6.5 Z\"\n stroke=\"var(--palette-gray-7)\"\n strokeWidth={1}\n fill=\"var(--palette-gray-1)\"\n />\n </marker>\n </defs>\n <g\n transform={`translate(${transform.x} ${transform.y}) scale(${transform.k})`}\n >\n {renderedLines.map((line) => (\n <LineComponent\n key={line.line.$id}\n line={line}\n linePaths={linePathsRef.current}\n clipPathList={clipPathList}\n markerPrefix={markerPrefix}\n clipPathPrefix={clipPathPrefix}\n activeLineMarkerPrefix={activeLineMarkerPrefix}\n activeEdge={\n activeTarget?.type === \"edge\" ? activeTarget.edge : null\n }\n onLineClick={onLineClick}\n onLineDoubleClick={onLineDoubleClick}\n />\n ))}\n </g>\n </svg>\n <div\n className=\"line-labels\"\n style={{\n left: transform.x,\n top: transform.y,\n transform: `scale(${transform.k})`,\n }}\n >\n <LineLabelComponentGroup\n labels={renderedLineLabels}\n onRendered={handleLineLabelsRendered}\n />\n </div>\n <div\n className=\"nodes\"\n ref={nodesRef}\n style={{\n left: transform.x,\n top: transform.y,\n transform: `scale(${transform.k})`,\n }}\n >\n <NodeComponentGroup\n nodes={nodes}\n nodeBricks={nodeBricks}\n // nodePositions={nodePositions}\n onRendered={handleNodesRendered}\n />\n </div>\n <ConnectLineComponent\n connectLineState={connectLineState}\n connectLineTo={connectLineTo}\n markerPrefix={markerPrefix}\n />\n </div>\n );\n}\n","import React, {\n createRef,\n forwardRef,\n useCallback,\n useEffect,\n useImperativeHandle,\n useRef,\n useState,\n} from \"react\";\nimport { EventEmitter, createDecorators } from \"@next-core/element\";\nimport { ReactNextElement } from \"@next-core/react-element\";\nimport \"@next-core/theme\";\nimport classNames from \"classnames\";\nimport styleText from \"./styles.shadow.css\";\n\nconst { defineElement, property, event, method } = createDecorators();\n\nexport interface EditableLabelProps {\n label?: string;\n type?: LabelType;\n}\n\nexport type LabelType = \"line\" | \"default\";\n\nexport interface EditableLabelRef {\n enableEditing(): void;\n}\n\nexport const EditableLabelComponent = forwardRef(LegacyEditableLabelComponent);\n\n/**\n * 构件 `diagram.editable-label`\n */\nexport\n@defineElement(\"diagram.editable-label\", {\n styleTexts: [styleText],\n})\nclass EditableLabel extends ReactNextElement implements EditableLabelProps {\n @property()\n accessor label: string | undefined;\n\n @property({ render: false })\n accessor type: LabelType | undefined;\n\n @event({ type: \"label.editing.change\" })\n accessor #labelEditingChange!: EventEmitter<boolean>;\n\n #handleLabelEditingChange = (value: boolean) => {\n this.#labelEditingChange.emit(value);\n };\n\n @event({ type: \"label.change\" })\n accessor #labelChange!: EventEmitter<string>;\n\n #handleLabelChange = (value: string) => {\n this.#labelChange.emit(value);\n };\n\n @method()\n enableEditing() {\n this.#editableLabelRef.current?.enableEditing();\n }\n\n #editableLabelRef = createRef<EditableLabelRef>();\n\n render() {\n return (\n <EditableLabelComponent\n ref={this.#editableLabelRef}\n label={this.label}\n onLabelEditingChange={this.#handleLabelEditingChange}\n onLabelChange={this.#handleLabelChange}\n />\n );\n }\n}\n\nexport interface EditableLabelComponentProps extends EditableLabelProps {\n onLabelEditingChange?(value: boolean): void;\n onLabelChange?(value: string): void;\n}\n\nexport function LegacyEditableLabelComponent(\n {\n label: _label,\n onLabelChange,\n onLabelEditingChange,\n }: EditableLabelComponentProps,\n ref: React.Ref<EditableLabelRef>\n) {\n const label = _label ?? \"\";\n const [currentLabel, setCurrentLabel] = useState<string>(label);\n const [editingLabel, setEditingLabel] = useState(false);\n const editingLabelInitialized = useRef(false);\n const [shouldEmitLabelChange, setShouldEmitLabelChange] = useState(false);\n const labelInputRef = useRef<HTMLInputElement>(null);\n\n useImperativeHandle(ref, () => ({\n enableEditing() {\n setEditingLabel(true);\n },\n }));\n\n useEffect(() => {\n setCurrentLabel(label);\n }, [label]);\n\n const handleEditLabel = useCallback((e: React.MouseEvent) => {\n e.preventDefault();\n e.stopPropagation();\n setEditingLabel(true);\n }, []);\n\n useEffect(() => {\n if (editingLabel) {\n // Prevent scroll when focusing.\n // Otherwise the diagram svg may be clipped in Chrome.\n labelInputRef.current?.focus({ preventScroll: true });\n labelInputRef.current?.select();\n }\n }, [editingLabel]);\n\n useEffect(() => {\n if (editingLabelInitialized.current) {\n onLabelEditingChange?.(editingLabel);\n } else {\n editingLabelInitialized.current = true;\n }\n }, [editingLabel, onLabelEditingChange]);\n\n const handleInputChange = useCallback(\n (event: React.ChangeEvent<HTMLInputElement>) => {\n setCurrentLabel(event.target.value);\n },\n []\n );\n\n const handleInputKeydown = useCallback((event: React.KeyboardEvent) => {\n const key =\n event.key ||\n /* istanbul ignore next: compatibility */ event.keyCode ||\n /* istanbul ignore next: compatibility */ event.which;\n if (key === \"Enter\" || key === 13) {\n labelInputRef.current?.blur();\n }\n }, []);\n\n const handleInputBlur = useCallback(() => {\n setEditingLabel(false);\n setShouldEmitLabelChange(true);\n }, []);\n\n useEffect(() => {\n if (shouldEmitLabelChange) {\n onLabelChange?.(currentLabel);\n setShouldEmitLabelChange(false);\n }\n }, [currentLabel, onLabelChange, shouldEmitLabelChange]);\n\n const stopPropagation = useCallback((e: React.MouseEvent) => {\n e.stopPropagation();\n }, []);\n\n return (\n <div\n className={classNames(\"label\", {\n editing: editingLabel,\n empty: !currentLabel,\n })}\n onDoubleClick={stopPropagation}\n onMouseDown={stopPropagation}\n >\n <input\n className=\"label-input\"\n value={currentLabel}\n ref={labelInputRef}\n onChange={handleInputChange}\n onKeyDown={handleInputKeydown}\n onBlur={handleInputBlur}\n />\n <div className=\"label-text\" onDoubleClick={handleEditLabel}>\n {currentLabel}\n </div>\n </div>\n );\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;--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}`, \"\"]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___.toString();\n"],"names":["_EoDiagram","defineElement","property","event","method","createDecorators","EoDiagramComponent","forwardRef","LegacyEoDiagramComponent","_dec","styleTexts","styleText","_dec2","type","String","_dec3","attribute","_dec4","_dec5","_dec6","_dec7","_dec8","_dec9","Boolean","_dec10","_dec11","_dec12","_dec13","_dec14","_dec15","_dec16","_dec17","_dec18","_dec19","_dec20","_A","WeakMap","_B","_C","_D","_E","_F","_G","_H","_I","_J","_K","_L","_M","_activeTargetChangeEvent","_handleActiveTargetChange","_N","_nodeDelete","_handleNodeDelete","_O","_edgeDelete","_handleEdgeDelete","_P","_lineClick","_handleLineClick","_Q","_lineDoubleClick","_handleLineDoubleClick","_R","_nodesConnect","_handleNodesConnect","_handleSwitchActiveTarget","_diagramRef","EoDiagram","ReactNextElement","constructor","arguments","_classPrivateFieldInitSpec","get","_get_nodesConnect2","set","_set_nodesConnect2","_get_lineDoubleClick2","_set_lineDoubleClick2","_get_lineClick2","_set_lineClick2","_get_edgeDelete2","_set_edgeDelete2","_get_nodeDelete2","_set_nodeDelete2","_get_activeTargetChangeEvent2","_set_activeTargetChangeEvent2","writable","value","_initProto","_init_layout","_init_nodes","_init_edges","_init_nodeBricks","_init_lines","_init_layoutOptions","_init_activeTarget","_init_disableKeyboardAction","_init_nodesConnect","_init_zoomable","_init_scrollable","_init_scaleRange","_init_activeTargetChangeEvent","target","_classPrivateFieldGet","this","emit","_init_nodeDelete","node","_init_edgeDelete","edge","_init_lineClick","line","_init_lineDoubleClick","_init_nodesConnect2","detail","activeTarget","createRef","layout","v","_classPrivateFieldSet","nodes","edges","nodeBricks","lines","layoutOptions","disableKeyboardAction","nodesConnect","zoomable","scrollable","scaleRange","callOnLineLabel","id","_classPrivateFieldGet2","_len","length","args","Array","_key","current","render","React","ref","onActiveTargetChange","onSwitchActiveTarget","onNodeDelete","onEdgeDelete","onLineClick","onLineDoubleClick","onNodesConnect","_set_activeTargetChangeEvent","_get_activeTargetChangeEvent","_set_nodeDelete","_get_nodeDelete","_set_edgeDelete","_get_edgeDelete","_set_lineClick","_get_lineClick","_set_lineDoubleClick","_get_lineDoubleClick","_set_nodesConnect","_get_nodesConnect","_ref","_scaleRange","graph","setGraph","useState","nodesReady","setNodesReady","nodesRenderId","setNodesRenderId","nodesRefRepository","setNodesRefRepository","lineLabelsRenderId","setLineLabelsRenderId","lineLabelsRefRepository","setLineLabelsRefRepository","renderedNodes","setRenderedNodes","renderedEdges","setRenderedEdges","renderedLineLabels","setRenderedLineLabels","grabbing","setGrabbing","transform","setTransform","k","x","y","linePathsRef","useRef","Map","rootRef","nodesRef","centered","setCentered","connectLineTo","setConnectLineTo","connectLineState","setConnectLineState","useImperativeHandle","_lineLabelsRefReposit","_len2","_key2","firstElementChild","useEffect","onNodesMouseDown","handleNodesMouseDown","nodesContainer","addEventListener","removeEventListener","fixedOptions","useMemo","_objectSpread","rankdir","ranksep","edgesep","nodesep","nodePadding","dagreGraphOptions","pick","activeTargetChangeInitialized","previousGraph","getDagreGraph","renderedDiagram","getRenderedDiagram","renderedLines","markers","getRenderedLinesAndMarkers","root","onKeydown","action","handleKeyboard","nodeId","handleNodesRendered","useCallback","refRepository","previous","handleLineLabelsRendered","DEFAULT_SCALE_RANGE_MIN","DEFAULT_SCALE_RANGE_MAX","zoomer","zoom","moved","scaleExtent","on","e","rootSelection","select","ctrlKey","stopImmediatePropagation","preventDefault","translateBy","wheelDeltaX","wheelDeltaY","call","transformToCenter","canvasWidth","clientWidth","canvasHeight","clientHeight","undefined","ZoomTransform","defPrefix","concat","uniqueId","markerPrefix","clipPathPrefix","activeLineMarkerPrefix","getRenderedLineLabels","clipPathList","setClipPathList","getClipPathList","className","classNames","ready","tabIndex","width","height","map","_ref2","index","strokeColor","MarkerComponent","key","clipPath","ClipPathComponent","viewBox","refX","refY","markerWidth","markerHeight","orient","d","stroke","strokeWidth","fill","LineComponent","$id","linePaths","activeEdge","style","left","top","LineLabelComponentGroup","labels","onRendered","NodeComponentGroup","ConnectLineComponent","_class","c","_initClass","_applyDecs","o","_","has","_checkInRHS","_EditableLabel","EditableLabelComponent","LegacyEditableLabelComponent","_labelEditingChange","_handleLabelEditingChange","_labelChange","_handleLabelChange","_editableLabelRef","EditableLabel","_get_labelChange2","_set_labelChange2","_get_labelEditingChange2","_set_labelEditingChange2","_init_label","_init_type","_init_labelEditingChange","_init_labelChange","label","enableEditing","onLabelEditingChange","onLabelChange","_set_labelEditingChange","_get_labelEditingChange","_set_labelChange","_get_labelChange","_label","currentLabel","setCurrentLabel","editingLabel","setEditingLabel","editingLabelInitialized","shouldEmitLabelChange","setShouldEmitLabelChange","labelInputRef","handleEditLabel","stopPropagation","_labelInputRef$curren","_labelInputRef$curren2","focus","preventScroll","handleInputChange","handleInputKeydown","_labelInputRef$curren3","keyCode","which","blur","handleInputBlur","editing","empty","onDoubleClick","onMouseDown","onChange","onKeyDown","onBlur","___CSS_LOADER_EXPORT___","push","module","toString"],"sourceRoot":""}
@@ -0,0 +1,3 @@
1
+ /*! For license information please see editable-label.4f364423.js.LICENSE.txt */
2
+ (self.webpackChunk_next_bricks_diagram=self.webpackChunk_next_bricks_diagram||[]).push([[3189,5628],{9067:(e,t,n)=>{"use strict";n.r(t),n.d(t,{EditableLabel:()=>w,EditableLabelComponent:()=>R,LegacyEditableLabelComponent:()=>Y});var r,a,i,l,o,s,c,u,f,h,p,b,d,v,g,y,m,w,Z=n(3395),x=n(1815),E=n(381),k=n(687),S=n(5066),C=n(8657),j=n.n(C),M=n(5727),z=n(305),P=(n(928),n(2779)),T=n.n(P),A=n(8074),{defineElement:O,property:W,event:L,method:D}=(0,M.createDecorators)(),R=(0,C.forwardRef)(Y);a=O("diagram.editable-label",{styleTexts:[A.Z]}),i=W(),o=W({render:!1}),c=L({type:"label.editing.change"}),p=L({type:"label.change"}),g=D();var _=new WeakMap,N=new WeakMap,I=new WeakMap,B=new WeakMap,H=new WeakMap,K=new WeakMap,q=new WeakMap,F=new WeakMap,G=new WeakMap;class J extends z.ReactNextElement{constructor(){super(...arguments),(0,Z.Z)(this,q,{get:X,set:V}),(0,Z.Z)(this,B,{get:U,set:Q}),(0,Z.Z)(this,_,{writable:!0,value:(y(this),l(this))}),(0,Z.Z)(this,N,{writable:!0,value:s(this)}),(0,Z.Z)(this,I,{writable:!0,value:u(this)}),(0,Z.Z)(this,H,{writable:!0,value:e=>{(0,k.Z)(this,B).emit(e)}}),(0,Z.Z)(this,K,{writable:!0,value:b(this)}),(0,Z.Z)(this,F,{writable:!0,value:e=>{(0,k.Z)(this,q).emit(e)}}),(0,Z.Z)(this,G,{writable:!0,value:(0,C.createRef)()})}get label(){return(0,k.Z)(this,_)}set label(e){(0,E.Z)(this,_,e)}get type(){return(0,k.Z)(this,N)}set type(e){(0,E.Z)(this,N,e)}enableEditing(){var e;null===(e=(0,k.Z)(this,G).current)||void 0===e||e.enableEditing()}render(){return j().createElement(R,{ref:(0,k.Z)(this,G),label:this.label,onLabelEditingChange:(0,k.Z)(this,H),onLabelChange:(0,k.Z)(this,F)})}}function Q(e){h(this,e)}function U(){return f(this)}function V(e){v(this,e)}function X(){return d(this)}function Y(e,t){var{label:n,onLabelChange:r,onLabelEditingChange:a}=e,i=null!=n?n:"",[l,o]=(0,C.useState)(i),[s,c]=(0,C.useState)(!1),u=(0,C.useRef)(!1),[f,h]=(0,C.useState)(!1),p=(0,C.useRef)(null);(0,C.useImperativeHandle)(t,(()=>({enableEditing(){c(!0)}}))),(0,C.useEffect)((()=>{o(i)}),[i]);var b=(0,C.useCallback)((e=>{e.preventDefault(),e.stopPropagation(),c(!0)}),[]);(0,C.useEffect)((()=>{var e,t;s&&(null===(e=p.current)||void 0===e||e.focus({preventScroll:!0}),null===(t=p.current)||void 0===t||t.select())}),[s]),(0,C.useEffect)((()=>{u.current?null==a||a(s):u.current=!0}),[s,a]);var d=(0,C.useCallback)((e=>{o(e.target.value)}),[]),v=(0,C.useCallback)((e=>{var t,n=e.key||e.keyCode||e.which;"Enter"!==n&&13!==n||null===(t=p.current)||void 0===t||t.blur()}),[]),g=(0,C.useCallback)((()=>{c(!1),h(!0)}),[]);(0,C.useEffect)((()=>{f&&(null==r||r(l),h(!1))}),[l,r,f]);var y=(0,C.useCallback)((e=>{e.stopPropagation()}),[]);return j().createElement("div",{className:T()("label",{editing:s,empty:!l}),onDoubleClick:y,onMouseDown:y},j().createElement("input",{className:"label-input",value:l,ref:p,onChange:d,onKeyDown:v,onBlur:g}),j().createElement("div",{className:"label-text",onDoubleClick:b},l))}m=J,({e:[l,s,u,f,h,b,d,v,y],c:[w,r]}=(0,S.Z)(m,[[i,1,"label"],[o,1,"type"],[c,1,"labelEditingChange",e=>(0,k.Z)(e,I),(e,t)=>(0,E.Z)(e,I,t)],[p,1,"labelChange",e=>(0,k.Z)(e,K),(e,t)=>(0,E.Z)(e,K,t)],[g,2,"enableEditing"]],[a],0,(e=>G.has((0,x.Z)(e))),z.ReactNextElement)),r()},2779:(e,t)=>{var n;!function(){"use strict";var r={}.hasOwnProperty;function a(){for(var e=[],t=0;t<arguments.length;t++){var n=arguments[t];if(n){var i=typeof n;if("string"===i||"number"===i)e.push(n);else if(Array.isArray(n)){if(n.length){var l=a.apply(null,n);l&&e.push(l)}}else if("object"===i){if(n.toString!==Object.prototype.toString&&!n.toString.toString().includes("[native code]")){e.push(n.toString());continue}for(var o in n)r.call(n,o)&&n[o]&&e.push(o)}}}return e.join(" ")}e.exports?(a.default=a,e.exports=a):void 0===(n=function(){return a}.apply(t,[]))||(e.exports=n)}()},8074:(e,t,n)=>{"use strict";n.d(t,{Z:()=>o});var r=n(9601),a=n.n(r),i=n(2609),l=n.n(i)()(a());l.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 o=l.toString()},2609:e=>{"use strict";e.exports=function(e){var t=[];return t.toString=function(){return this.map((function(t){var n="",r=void 0!==t[5];return t[4]&&(n+="@supports (".concat(t[4],") {")),t[2]&&(n+="@media ".concat(t[2]," {")),r&&(n+="@layer".concat(t[5].length>0?" ".concat(t[5]):""," {")),n+=e(t),r&&(n+="}"),t[2]&&(n+="}"),t[4]&&(n+="}"),n})).join("")},t.i=function(e,n,r,a,i){"string"==typeof e&&(e=[[null,e,void 0]]);var l={};if(r)for(var o=0;o<this.length;o++){var s=this[o][0];null!=s&&(l[s]=!0)}for(var c=0;c<e.length;c++){var u=[].concat(e[c]);r&&l[u[0]]||(void 0!==i&&(void 0===u[5]||(u[1]="@layer".concat(u[5].length>0?" ".concat(u[5]):""," {").concat(u[1],"}")),u[5]=i),n&&(u[2]?(u[1]="@media ".concat(u[2]," {").concat(u[1],"}"),u[2]=n):u[2]=n),a&&(u[4]?(u[1]="@supports (".concat(u[4],") {").concat(u[1],"}"),u[4]=a):u[4]="".concat(a)),t.push(u))}},t}},9601:e=>{"use strict";e.exports=function(e){return e[1]}},5066:(e,t,n)=>{"use strict";n.d(t,{Z:()=>o});var r=n(6522),a=n(1815);function i(e,t,n){"symbol"==(0,r.Z)(t)&&(t=(t=t.description)?"["+t+"]":"");try{Object.defineProperty(e,"name",{configurable:!0,value:n?n+" "+t:t})}catch(e){}return e}var l=n(5850);function o(e,t,n,o,s,c){function u(e,t,n){return function(r,a){return n&&n(r),e[t].call(r,a)}}function f(e,t){for(var n=0;n<e.length;n++)e[n].call(t);return t}function h(e,t,n,r){if("function"!=typeof e&&(r||void 0!==e))throw new TypeError(t+" must "+(n||"be")+" a function"+(r?"":" or undefined"));return e}function p(e,t,n,a,l,o,s,c,f,p,b,d,v){function g(e){if(!v(e))throw new TypeError("Attempted to access private element on non-instance")}var y,m,w=t[0],Z=t[3],x=!c;if(!x){n||Array.isArray(w)||(w=[w]);var E={},k=[],S=3===l?"get":4===l||d?"set":"value";p?(b||d?E={get:i((function(){return Z(this)}),a,"get"),set:function(e){t[4](this,e)}}:E[S]=Z,b||i(E[S],a,2===l?"":S)):b||(E=Object.getOwnPropertyDescriptor(e,a))}for(var C=w.length-1;C>=0;C-=n?2:1){var j=w[C],M=n?w[C-1]:void 0,z={},P={kind:["field","accessor","method","getter","setter","class"][l],name:a,metadata:o,addInitializer:function(e,t){if(e.v)throw new Error("attempted to call addInitializer after decoration was finished");h(t,"An initializer","be",!0),s.push(t)}.bind(null,z)};try{if(x)m=j.call(M,e,P);else{var T,A;P.static=f,P.private=p,p||!b&&2!==l?2===l?T=function(e){return g(e),E.value}:((l<2||3===l)&&(T=u(E,"get",p&&g)),(l<2||4===l)&&(A=u(E,"set",p&&g))):(T=function(e){return e[a]},b&&(A=function(e,t){e[a]=t}));var O=P.access={has:p?v.bind():function(e){return a in e}};if(T&&(O.get=T),A&&(O.set=A),m=j.call(M,d?{get:E.get,set:E.set}:E[S],P),d){if("object"==(0,r.Z)(m)&&m)(y=h(m.get,"accessor.get"))&&(E.get=y),(y=h(m.set,"accessor.set"))&&(E.set=y),(y=h(m.init,"accessor.init"))&&k.push(y);else if(void 0!==m)throw new TypeError("accessor decorators must return an object with get, set, or init properties or void 0")}else h(m,(b?"field":"method")+" decorators","return")&&(b?k.push(m):E[S]=m)}}finally{z.v=!0}}return(b||d)&&c.push((function(e,t){for(var n=k.length-1;n>=0;n--)t=k[n].call(e,t);return t})),b||x||(p?d?c.push(u(E,"get"),u(E,"set")):c.push(2===l?E[S]:u.call.bind(E[S])):Object.defineProperty(e,a,E)),m}function b(e,t){return Object.defineProperty(e,Symbol.metadata||Symbol.for("Symbol.metadata"),{configurable:!0,enumerable:!0,value:t})}if(arguments.length>=6)var d=c[Symbol.metadata||Symbol.for("Symbol.metadata")];var v=Object.create(null==d?null:d),g=function(e,t,n,r){var i,o,s=[],c=function(t){return(0,a.Z)(t)===e},u=new Map;function h(e){e&&s.push(f.bind(null,e))}for(var b=0;b<t.length;b++){var d=t[b];if(Array.isArray(d)){var v=d[1],g=d[2],y=d.length>3,m=16&v,w=!!(8&v),Z=0==(v&=7),x=g+"/"+w;if(!Z&&!y){var E=u.get(x);if(!0===E||3===E&&4!==v||4===E&&3!==v)throw new Error("Attempted to decorate a public method/accessor that has the same name as a previously decorated public method/accessor. This is not currently supported by the decorators plugin. Property name was: "+g);u.set(x,!(v>2)||v)}p(w?e:e.prototype,d,m,y?"#"+g:(0,l.Z)(g),v,r,w?o=o||[]:i=i||[],s,w,y,Z,1===v,w&&y?c:n)}}return h(i),h(o),s}(e,t,s,v);return n.length||b(e,v),{e:g,get c(){var t=[];return n.length&&[b(h(p(e,[n],o,e.name,5,v,t),"class decorators","return")||e,v),f.bind(null,t,e)]}}}},1815:(e,t,n)=>{"use strict";n.d(t,{Z:()=>a});var r=n(6522);function a(e){if(Object(e)!==e)throw TypeError("right-hand side of 'in' should be an object, got "+(null!==e?(0,r.Z)(e):"null"));return e}},5863:(e,t,n)=>{"use strict";function r(e,t){if(t.has(e))throw new TypeError("Cannot initialize the same private elements twice on an object")}n.d(t,{Z:()=>r})},175:(e,t,n)=>{"use strict";function r(e,t,n){if(!t.has(e))throw new TypeError("attempted to "+n+" private field on non-instance");return t.get(e)}n.d(t,{Z:()=>r})},687:(e,t,n)=>{"use strict";n.d(t,{Z:()=>a});var r=n(175);function a(e,t){return function(e,t){return t.get?t.get.call(e):t.value}(e,(0,r.Z)(e,t,"get"))}},3395:(e,t,n)=>{"use strict";n.d(t,{Z:()=>a});var r=n(5863);function a(e,t,n){(0,r.Z)(e,t),t.set(e,n)}},381:(e,t,n)=>{"use strict";n.d(t,{Z:()=>a});var r=n(175);function a(e,t,n){return function(e,t,n){if(t.set)t.set.call(e,n);else{if(!t.writable)throw new TypeError("attempted to set read only private field");t.value=n}}(e,(0,r.Z)(e,t,"set"),n),n}},5850:(e,t,n)=>{"use strict";n.d(t,{Z:()=>a});var r=n(6522);function a(e){var t=function(e,t){if("object"!=(0,r.Z)(e)||!e)return e;var n=e[Symbol.toPrimitive];if(void 0!==n){var a=n.call(e,"string");if("object"!=(0,r.Z)(a))return a;throw new TypeError("@@toPrimitive must return a primitive value.")}return String(e)}(e);return"symbol"==(0,r.Z)(t)?t:String(t)}},6522:(e,t,n)=>{"use strict";function r(e){return r="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},r(e)}n.d(t,{Z:()=>r})}}]);
3
+ //# sourceMappingURL=editable-label.4f364423.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"chunks/editable-label.4f364423.js","mappings":"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","sources":["webpack:///./src/editable-label/index.tsx","webpack:///../../node_modules/classnames/index.js","webpack:///./src/editable-label/styles.shadow.css","webpack:///../../node_modules/css-loader/dist/runtime/api.js","webpack:///../../node_modules/css-loader/dist/runtime/noSourceMaps.js","webpack:///../../node_modules/@babel/runtime/helpers/esm/setFunctionName.js","webpack:///../../node_modules/@babel/runtime/helpers/esm/applyDecs2305.js","webpack:///../../node_modules/@babel/runtime/helpers/esm/checkInRHS.js","webpack:///../../node_modules/@babel/runtime/helpers/esm/checkPrivateRedeclaration.js","webpack:///../../node_modules/@babel/runtime/helpers/esm/classExtractFieldDescriptor.js","webpack:///../../node_modules/@babel/runtime/helpers/esm/classPrivateFieldGet.js","webpack:///../../node_modules/@babel/runtime/helpers/esm/classApplyDescriptorGet.js","webpack:///../../node_modules/@babel/runtime/helpers/esm/classPrivateFieldInitSpec.js","webpack:///../../node_modules/@babel/runtime/helpers/esm/classPrivateFieldSet.js","webpack:///../../node_modules/@babel/runtime/helpers/esm/classApplyDescriptorSet.js","webpack:///../../node_modules/@babel/runtime/helpers/esm/toPropertyKey.js","webpack:///../../node_modules/@babel/runtime/helpers/esm/toPrimitive.js","webpack:///../../node_modules/@babel/runtime/helpers/esm/typeof.js"],"sourcesContent":["import React, {\n createRef,\n forwardRef,\n useCallback,\n useEffect,\n useImperativeHandle,\n useRef,\n useState,\n} from \"react\";\nimport { EventEmitter, createDecorators } from \"@next-core/element\";\nimport { ReactNextElement } from \"@next-core/react-element\";\nimport \"@next-core/theme\";\nimport classNames from \"classnames\";\nimport styleText from \"./styles.shadow.css\";\n\nconst { defineElement, property, event, method } = createDecorators();\n\nexport interface EditableLabelProps {\n label?: string;\n type?: LabelType;\n}\n\nexport type LabelType = \"line\" | \"default\";\n\nexport interface EditableLabelRef {\n enableEditing(): void;\n}\n\nexport const EditableLabelComponent = forwardRef(LegacyEditableLabelComponent);\n\n/**\n * 构件 `diagram.editable-label`\n */\nexport\n@defineElement(\"diagram.editable-label\", {\n styleTexts: [styleText],\n})\nclass EditableLabel extends ReactNextElement implements EditableLabelProps {\n @property()\n accessor label: string | undefined;\n\n @property({ render: false })\n accessor type: LabelType | undefined;\n\n @event({ type: \"label.editing.change\" })\n accessor #labelEditingChange!: EventEmitter<boolean>;\n\n #handleLabelEditingChange = (value: boolean) => {\n this.#labelEditingChange.emit(value);\n };\n\n @event({ type: \"label.change\" })\n accessor #labelChange!: EventEmitter<string>;\n\n #handleLabelChange = (value: string) => {\n this.#labelChange.emit(value);\n };\n\n @method()\n enableEditing() {\n this.#editableLabelRef.current?.enableEditing();\n }\n\n #editableLabelRef = createRef<EditableLabelRef>();\n\n render() {\n return (\n <EditableLabelComponent\n ref={this.#editableLabelRef}\n label={this.label}\n onLabelEditingChange={this.#handleLabelEditingChange}\n onLabelChange={this.#handleLabelChange}\n />\n );\n }\n}\n\nexport interface EditableLabelComponentProps extends EditableLabelProps {\n onLabelEditingChange?(value: boolean): void;\n onLabelChange?(value: string): void;\n}\n\nexport function LegacyEditableLabelComponent(\n {\n label: _label,\n onLabelChange,\n onLabelEditingChange,\n }: EditableLabelComponentProps,\n ref: React.Ref<EditableLabelRef>\n) {\n const label = _label ?? \"\";\n const [currentLabel, setCurrentLabel] = useState<string>(label);\n const [editingLabel, setEditingLabel] = useState(false);\n const editingLabelInitialized = useRef(false);\n const [shouldEmitLabelChange, setShouldEmitLabelChange] = useState(false);\n const labelInputRef = useRef<HTMLInputElement>(null);\n\n useImperativeHandle(ref, () => ({\n enableEditing() {\n setEditingLabel(true);\n },\n }));\n\n useEffect(() => {\n setCurrentLabel(label);\n }, [label]);\n\n const handleEditLabel = useCallback((e: React.MouseEvent) => {\n e.preventDefault();\n e.stopPropagation();\n setEditingLabel(true);\n }, []);\n\n useEffect(() => {\n if (editingLabel) {\n // Prevent scroll when focusing.\n // Otherwise the diagram svg may be clipped in Chrome.\n labelInputRef.current?.focus({ preventScroll: true });\n labelInputRef.current?.select();\n }\n }, [editingLabel]);\n\n useEffect(() => {\n if (editingLabelInitialized.current) {\n onLabelEditingChange?.(editingLabel);\n } else {\n editingLabelInitialized.current = true;\n }\n }, [editingLabel, onLabelEditingChange]);\n\n const handleInputChange = useCallback(\n (event: React.ChangeEvent<HTMLInputElement>) => {\n setCurrentLabel(event.target.value);\n },\n []\n );\n\n const handleInputKeydown = useCallback((event: React.KeyboardEvent) => {\n const key =\n event.key ||\n /* istanbul ignore next: compatibility */ event.keyCode ||\n /* istanbul ignore next: compatibility */ event.which;\n if (key === \"Enter\" || key === 13) {\n labelInputRef.current?.blur();\n }\n }, []);\n\n const handleInputBlur = useCallback(() => {\n setEditingLabel(false);\n setShouldEmitLabelChange(true);\n }, []);\n\n useEffect(() => {\n if (shouldEmitLabelChange) {\n onLabelChange?.(currentLabel);\n setShouldEmitLabelChange(false);\n }\n }, [currentLabel, onLabelChange, shouldEmitLabelChange]);\n\n const stopPropagation = useCallback((e: React.MouseEvent) => {\n e.stopPropagation();\n }, []);\n\n return (\n <div\n className={classNames(\"label\", {\n editing: editingLabel,\n empty: !currentLabel,\n })}\n onDoubleClick={stopPropagation}\n onMouseDown={stopPropagation}\n >\n <input\n className=\"label-input\"\n value={currentLabel}\n ref={labelInputRef}\n onChange={handleInputChange}\n onKeyDown={handleInputKeydown}\n onBlur={handleInputBlur}\n />\n <div className=\"label-text\" onDoubleClick={handleEditLabel}>\n {currentLabel}\n </div>\n </div>\n );\n}\n","/*!\n\tCopyright (c) 2018 Jed Watson.\n\tLicensed under the MIT License (MIT), see\n\thttp://jedwatson.github.io/classnames\n*/\n/* global define */\n\n(function () {\n\t'use strict';\n\n\tvar hasOwn = {}.hasOwnProperty;\n\tvar nativeCodeString = '[native code]';\n\n\tfunction classNames() {\n\t\tvar classes = [];\n\n\t\tfor (var i = 0; i < arguments.length; i++) {\n\t\t\tvar arg = arguments[i];\n\t\t\tif (!arg) continue;\n\n\t\t\tvar argType = typeof arg;\n\n\t\t\tif (argType === 'string' || argType === 'number') {\n\t\t\t\tclasses.push(arg);\n\t\t\t} else if (Array.isArray(arg)) {\n\t\t\t\tif (arg.length) {\n\t\t\t\t\tvar inner = classNames.apply(null, arg);\n\t\t\t\t\tif (inner) {\n\t\t\t\t\t\tclasses.push(inner);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} else if (argType === 'object') {\n\t\t\t\tif (arg.toString !== Object.prototype.toString && !arg.toString.toString().includes('[native code]')) {\n\t\t\t\t\tclasses.push(arg.toString());\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\n\t\t\t\tfor (var key in arg) {\n\t\t\t\t\tif (hasOwn.call(arg, key) && arg[key]) {\n\t\t\t\t\t\tclasses.push(key);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn classes.join(' ');\n\t}\n\n\tif (typeof module !== 'undefined' && module.exports) {\n\t\tclassNames.default = classNames;\n\t\tmodule.exports = classNames;\n\t} else if (typeof define === 'function' && typeof define.amd === 'object' && define.amd) {\n\t\t// register as 'classnames', consistent with npm package name\n\t\tdefine('classnames', [], function () {\n\t\t\treturn classNames;\n\t\t});\n\t} else {\n\t\twindow.classNames = classNames;\n\t}\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;--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}`, \"\"]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___.toString();\n","\"use strict\";\n\n/*\n MIT License http://www.opensource.org/licenses/mit-license.php\n Author Tobias Koppers @sokra\n*/\nmodule.exports = function (cssWithMappingToString) {\n var list = [];\n\n // return the list of modules as css string\n list.toString = function toString() {\n return this.map(function (item) {\n var content = \"\";\n var needLayer = typeof item[5] !== \"undefined\";\n if (item[4]) {\n content += \"@supports (\".concat(item[4], \") {\");\n }\n if (item[2]) {\n content += \"@media \".concat(item[2], \" {\");\n }\n if (needLayer) {\n content += \"@layer\".concat(item[5].length > 0 ? \" \".concat(item[5]) : \"\", \" {\");\n }\n content += cssWithMappingToString(item);\n if (needLayer) {\n content += \"}\";\n }\n if (item[2]) {\n content += \"}\";\n }\n if (item[4]) {\n content += \"}\";\n }\n return content;\n }).join(\"\");\n };\n\n // import a list of modules into the list\n list.i = function i(modules, media, dedupe, supports, layer) {\n if (typeof modules === \"string\") {\n modules = [[null, modules, undefined]];\n }\n var alreadyImportedModules = {};\n if (dedupe) {\n for (var k = 0; k < this.length; k++) {\n var id = this[k][0];\n if (id != null) {\n alreadyImportedModules[id] = true;\n }\n }\n }\n for (var _k = 0; _k < modules.length; _k++) {\n var item = [].concat(modules[_k]);\n if (dedupe && alreadyImportedModules[item[0]]) {\n continue;\n }\n if (typeof layer !== \"undefined\") {\n if (typeof item[5] === \"undefined\") {\n item[5] = layer;\n } else {\n item[1] = \"@layer\".concat(item[5].length > 0 ? \" \".concat(item[5]) : \"\", \" {\").concat(item[1], \"}\");\n item[5] = layer;\n }\n }\n if (media) {\n if (!item[2]) {\n item[2] = media;\n } else {\n item[1] = \"@media \".concat(item[2], \" {\").concat(item[1], \"}\");\n item[2] = media;\n }\n }\n if (supports) {\n if (!item[4]) {\n item[4] = \"\".concat(supports);\n } else {\n item[1] = \"@supports (\".concat(item[4], \") {\").concat(item[1], \"}\");\n item[4] = supports;\n }\n }\n list.push(item);\n }\n };\n return list;\n};","\"use strict\";\n\nmodule.exports = function (i) {\n return i[1];\n};","import _typeof from \"./typeof.js\";\nexport default function setFunctionName(e, t, n) {\n \"symbol\" == _typeof(t) && (t = (t = t.description) ? \"[\" + t + \"]\" : \"\");\n try {\n Object.defineProperty(e, \"name\", {\n configurable: !0,\n value: n ? n + \" \" + t : t\n });\n } catch (e) {}\n return e;\n}","import _typeof from \"./typeof.js\";\nimport checkInRHS from \"./checkInRHS.js\";\nimport setFunctionName from \"./setFunctionName.js\";\nimport toPropertyKey from \"./toPropertyKey.js\";\nexport default function applyDecs2305(e, t, r, n, o, a) {\n function i(e, t, r) {\n return function (n, o) {\n return r && r(n), e[t].call(n, o);\n };\n }\n function c(e, t) {\n for (var r = 0; r < e.length; r++) e[r].call(t);\n return t;\n }\n function s(e, t, r, n) {\n if (\"function\" != typeof e && (n || void 0 !== e)) throw new TypeError(t + \" must \" + (r || \"be\") + \" a function\" + (n ? \"\" : \" or undefined\"));\n return e;\n }\n function applyDec(e, t, r, n, o, a, c, u, l, f, p, d, h) {\n function m(e) {\n if (!h(e)) throw new TypeError(\"Attempted to access private element on non-instance\");\n }\n var y,\n v,\n g = t[0],\n b = t[3],\n w = !u;\n if (!w) {\n r || Array.isArray(g) || (g = [g]);\n var S = {},\n A = [],\n P = 3 === o ? \"get\" : 4 === o || d ? \"set\" : \"value\";\n f ? (p || d ? S = {\n get: setFunctionName(function () {\n return b(this);\n }, n, \"get\"),\n set: function set(e) {\n t[4](this, e);\n }\n } : S[P] = b, p || setFunctionName(S[P], n, 2 === o ? \"\" : P)) : p || (S = Object.getOwnPropertyDescriptor(e, n));\n }\n for (var j = g.length - 1; j >= 0; j -= r ? 2 : 1) {\n var D = g[j],\n E = r ? g[j - 1] : void 0,\n I = {},\n O = {\n kind: [\"field\", \"accessor\", \"method\", \"getter\", \"setter\", \"class\"][o],\n name: n,\n metadata: a,\n addInitializer: function (e, t) {\n if (e.v) throw new Error(\"attempted to call addInitializer after decoration was finished\");\n s(t, \"An initializer\", \"be\", !0), c.push(t);\n }.bind(null, I)\n };\n try {\n if (w) v = D.call(E, e, O);else {\n var k, F;\n O[\"static\"] = l, O[\"private\"] = f, f || !p && 2 !== o ? 2 === o ? k = function k(e) {\n return m(e), S.value;\n } : ((o < 2 || 3 === o) && (k = i(S, \"get\", f && m)), (o < 2 || 4 === o) && (F = i(S, \"set\", f && m))) : (k = function k(e) {\n return e[n];\n }, p && (F = function F(e, t) {\n e[n] = t;\n }));\n var N = O.access = {\n has: f ? h.bind() : function (e) {\n return n in e;\n }\n };\n if (k && (N.get = k), F && (N.set = F), v = D.call(E, d ? {\n get: S.get,\n set: S.set\n } : S[P], O), d) {\n if (\"object\" == _typeof(v) && v) (y = s(v.get, \"accessor.get\")) && (S.get = y), (y = s(v.set, \"accessor.set\")) && (S.set = y), (y = s(v.init, \"accessor.init\")) && A.push(y);else if (void 0 !== v) throw new TypeError(\"accessor decorators must return an object with get, set, or init properties or void 0\");\n } else s(v, (p ? \"field\" : \"method\") + \" decorators\", \"return\") && (p ? A.push(v) : S[P] = v);\n }\n } finally {\n I.v = !0;\n }\n }\n return (p || d) && u.push(function (e, t) {\n for (var r = A.length - 1; r >= 0; r--) t = A[r].call(e, t);\n return t;\n }), p || w || (f ? d ? u.push(i(S, \"get\"), i(S, \"set\")) : u.push(2 === o ? S[P] : i.call.bind(S[P])) : Object.defineProperty(e, n, S)), v;\n }\n function u(e, t) {\n return Object.defineProperty(e, Symbol.metadata || Symbol[\"for\"](\"Symbol.metadata\"), {\n configurable: !0,\n enumerable: !0,\n value: t\n });\n }\n if (arguments.length >= 6) var l = a[Symbol.metadata || Symbol[\"for\"](\"Symbol.metadata\")];\n var f = Object.create(null == l ? null : l),\n p = function (e, t, r, n) {\n var o,\n a,\n i = [],\n s = function s(t) {\n return checkInRHS(t) === e;\n },\n u = new Map();\n function l(e) {\n e && i.push(c.bind(null, e));\n }\n for (var f = 0; f < t.length; f++) {\n var p = t[f];\n if (Array.isArray(p)) {\n var d = p[1],\n h = p[2],\n m = p.length > 3,\n y = 16 & d,\n v = !!(8 & d),\n g = 0 == (d &= 7),\n b = h + \"/\" + v;\n if (!g && !m) {\n var w = u.get(b);\n if (!0 === w || 3 === w && 4 !== d || 4 === w && 3 !== d) throw new Error(\"Attempted to decorate a public method/accessor that has the same name as a previously decorated public method/accessor. This is not currently supported by the decorators plugin. Property name was: \" + h);\n u.set(b, !(d > 2) || d);\n }\n applyDec(v ? e : e.prototype, p, y, m ? \"#\" + h : toPropertyKey(h), d, n, v ? a = a || [] : o = o || [], i, v, m, g, 1 === d, v && m ? s : r);\n }\n }\n return l(o), l(a), i;\n }(e, t, o, f);\n return r.length || u(e, f), {\n e: p,\n get c() {\n var t = [];\n return r.length && [u(s(applyDec(e, [r], n, e.name, 5, f, t), \"class decorators\", \"return\") || e, f), c.bind(null, t, e)];\n }\n };\n}","import _typeof from \"./typeof.js\";\nexport default function _checkInRHS(e) {\n if (Object(e) !== e) throw TypeError(\"right-hand side of 'in' should be an object, got \" + (null !== e ? _typeof(e) : \"null\"));\n return e;\n}","export default function _checkPrivateRedeclaration(obj, privateCollection) {\n if (privateCollection.has(obj)) {\n throw new TypeError(\"Cannot initialize the same private elements twice on an object\");\n }\n}","export default function _classExtractFieldDescriptor(receiver, privateMap, action) {\n if (!privateMap.has(receiver)) {\n throw new TypeError(\"attempted to \" + action + \" private field on non-instance\");\n }\n return privateMap.get(receiver);\n}","import classApplyDescriptorGet from \"./classApplyDescriptorGet.js\";\nimport classExtractFieldDescriptor from \"./classExtractFieldDescriptor.js\";\nexport default function _classPrivateFieldGet(receiver, privateMap) {\n var descriptor = classExtractFieldDescriptor(receiver, privateMap, \"get\");\n return classApplyDescriptorGet(receiver, descriptor);\n}","export default function _classApplyDescriptorGet(receiver, descriptor) {\n if (descriptor.get) {\n return descriptor.get.call(receiver);\n }\n return descriptor.value;\n}","import checkPrivateRedeclaration from \"./checkPrivateRedeclaration.js\";\nexport default function _classPrivateFieldInitSpec(obj, privateMap, value) {\n checkPrivateRedeclaration(obj, privateMap);\n privateMap.set(obj, value);\n}","import classApplyDescriptorSet from \"./classApplyDescriptorSet.js\";\nimport classExtractFieldDescriptor from \"./classExtractFieldDescriptor.js\";\nexport default function _classPrivateFieldSet(receiver, privateMap, value) {\n var descriptor = classExtractFieldDescriptor(receiver, privateMap, \"set\");\n classApplyDescriptorSet(receiver, descriptor, value);\n return value;\n}","export default function _classApplyDescriptorSet(receiver, descriptor, value) {\n if (descriptor.set) {\n descriptor.set.call(receiver, value);\n } else {\n if (!descriptor.writable) {\n throw new TypeError(\"attempted to set read only private field\");\n }\n descriptor.value = value;\n }\n}","import _typeof from \"./typeof.js\";\nimport toPrimitive from \"./toPrimitive.js\";\nexport default function toPropertyKey(t) {\n var i = toPrimitive(t, \"string\");\n return \"symbol\" == _typeof(i) ? i : String(i);\n}","import _typeof from \"./typeof.js\";\nexport default function toPrimitive(t, r) {\n if (\"object\" != _typeof(t) || !t) return t;\n var e = t[Symbol.toPrimitive];\n if (void 0 !== e) {\n var i = e.call(t, r || \"default\");\n if (\"object\" != _typeof(i)) return i;\n throw new TypeError(\"@@toPrimitive must return a primitive value.\");\n }\n return (\"string\" === r ? String : Number)(t);\n}","export default function _typeof(o) {\n \"@babel/helpers - typeof\";\n\n return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (o) {\n return typeof o;\n } : function (o) {\n return o && \"function\" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? \"symbol\" : typeof o;\n }, _typeof(o);\n}"],"names":["_EditableLabel","defineElement","property","event","method","createDecorators","EditableLabelComponent","forwardRef","LegacyEditableLabelComponent","_dec","styleTexts","styleText","_dec2","_dec3","render","_dec4","type","_dec5","_dec6","_A","WeakMap","_B","_C","_labelEditingChange","_handleLabelEditingChange","_D","_labelChange","_handleLabelChange","_editableLabelRef","EditableLabel","ReactNextElement","constructor","arguments","_classPrivateFieldInitSpec","get","_get_labelChange2","set","_set_labelChange2","_get_labelEditingChange2","_set_labelEditingChange2","writable","value","_initProto","_init_label","_init_type","_init_labelEditingChange","_classPrivateFieldGet","this","emit","_init_labelChange","createRef","label","v","_classPrivateFieldSet","enableEditing","_classPrivateFieldGet2","current","React","ref","onLabelEditingChange","onLabelChange","_set_labelEditingChange","_get_labelEditingChange","_set_labelChange","_get_labelChange","_ref","_label","currentLabel","setCurrentLabel","useState","editingLabel","setEditingLabel","editingLabelInitialized","useRef","shouldEmitLabelChange","setShouldEmitLabelChange","labelInputRef","useImperativeHandle","useEffect","handleEditLabel","useCallback","e","preventDefault","stopPropagation","_labelInputRef$curren","_labelInputRef$curren2","focus","preventScroll","select","handleInputChange","target","handleInputKeydown","_labelInputRef$curren3","key","keyCode","which","blur","handleInputBlur","className","classNames","editing","empty","onDoubleClick","onMouseDown","onChange","onKeyDown","onBlur","_class","c","_initClass","_applyDecs","o","_","has","_checkInRHS","hasOwn","hasOwnProperty","classes","i","length","arg","argType","push","Array","isArray","inner","apply","toString","Object","prototype","includes","call","join","module","exports","default","___CSS_LOADER_EXPORT___","id","cssWithMappingToString","list","map","item","content","needLayer","concat","modules","media","dedupe","supports","layer","undefined","alreadyImportedModules","k","_k","setFunctionName","t","n","description","defineProperty","configurable","applyDecs2305","r","a","s","TypeError","applyDec","u","l","f","p","d","h","m","y","g","b","w","S","A","P","getOwnPropertyDescriptor","j","D","E","I","O","kind","name","metadata","addInitializer","Error","bind","F","N","access","init","Symbol","enumerable","create","checkInRHS","Map","toPropertyKey","_checkPrivateRedeclaration","obj","privateCollection","_classExtractFieldDescriptor","receiver","privateMap","action","descriptor","classExtractFieldDescriptor","toPrimitive","String","_typeof","iterator"],"sourceRoot":""}
@@ -0,0 +1,2 @@
1
+ "use strict";(self.webpackChunk_next_bricks_diagram=self.webpackChunk_next_bricks_diagram||[]).push([[9016],{2715:(e,t,a)=>{a.r(t),a.d(t,{EoDiagram:()=>ae,EoDiagramComponent:()=>Oe,LegacyEoDiagramComponent:()=>St});var n,i,s,l,r,o,c,u,d,h,v,g,p,k,Z,m,b,w,f,y,E,M,W,C,L,x,R,S,T,D,P,B,z,A,N,O,H,K,_,I,X,Y,V,q,$,j,F,G,J,Q,U,ee,te,ae,ne=a(3028),ie=a(3395),se=a(1815),le=a(381),re=a(687),oe=a(5066),ce=a(8657),ue=a.n(ce),de=a(5727),he=a(305),ve=(a(928),a(1105)),ge=a(7397),pe=a(2779),ke=a.n(pe),Ze=a(1211),me=a(2370),be=a(5702),we=a(7441),fe=a(5731),ye=a(7853),Ee=a(6462),Me=a(9575),We=a(2260),Ce=a(7587),Le=a(1251),xe=a(4126),Re=a(7201),Se=a(5173),Te=a(542),De=a(6436),Pe=a(5318),{defineElement:Be,property:ze,event:Ae,method:Ne}=(0,de.createDecorators)(),Oe=(0,ce.forwardRef)(St);i=Be("eo-diagram",{styleTexts:[De.Z]}),s=ze({type:String}),r=ze({attribute:!1}),c=ze({attribute:!1}),d=ze({attribute:!1}),v=ze({attribute:!1}),p=ze({attribute:!1}),Z=ze({attribute:!1}),b=ze({type:Boolean}),f=ze({attribute:!1}),E=ze({type:Boolean}),W=ze({type:Boolean}),L=ze({attribute:!1}),R=Ae({type:"activeTarget.change"}),P=Ae({type:"node.delete"}),N=Ae({type:"edge.delete"}),_=Ae({type:"line.click"}),V=Ae({type:"line.dblclick"}),F=Ae({type:"nodes.connect"}),U=Ne();var He=new WeakMap,Ke=new WeakMap,_e=new WeakMap,Ie=new WeakMap,Xe=new WeakMap,Ye=new WeakMap,Ve=new WeakMap,qe=new WeakMap,$e=new WeakMap,je=new WeakMap,Fe=new WeakMap,Ge=new WeakMap,Je=new WeakMap,Qe=new WeakMap,Ue=new WeakMap,et=new WeakMap,tt=new WeakMap,at=new WeakMap,nt=new WeakMap,it=new WeakMap,st=new WeakMap,lt=new WeakMap,rt=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,kt=new WeakMap;class Zt extends he.ReactNextElement{constructor(){super(...arguments),(0,ie.Z)(this,vt,{get:Rt,set:xt}),(0,ie.Z)(this,ut,{get:Lt,set:Ct}),(0,ie.Z)(this,rt,{get:Wt,set:Mt}),(0,ie.Z)(this,it,{get:Et,set:yt}),(0,ie.Z)(this,tt,{get:ft,set:wt}),(0,ie.Z)(this,Qe,{get:bt,set:mt}),(0,ie.Z)(this,He,{writable:!0,value:(ee(this),l(this))}),(0,ie.Z)(this,Ke,{writable:!0,value:o(this)}),(0,ie.Z)(this,_e,{writable:!0,value:u(this)}),(0,ie.Z)(this,Ie,{writable:!0,value:h(this)}),(0,ie.Z)(this,Xe,{writable:!0,value:g(this)}),(0,ie.Z)(this,Ye,{writable:!0,value:k(this)}),(0,ie.Z)(this,Ve,{writable:!0,value:m(this)}),(0,ie.Z)(this,qe,{writable:!0,value:w(this)}),(0,ie.Z)(this,$e,{writable:!0,value:y(this)}),(0,ie.Z)(this,je,{writable:!0,value:M(this,!0)}),(0,ie.Z)(this,Fe,{writable:!0,value:C(this,!0)}),(0,ie.Z)(this,Ge,{writable:!0,value:x(this)}),(0,ie.Z)(this,Je,{writable:!0,value:S(this)}),(0,ie.Z)(this,Ue,{writable:!0,value:e=>{(0,re.Z)(this,Qe).emit(e)}}),(0,ie.Z)(this,et,{writable:!0,value:B(this)}),(0,ie.Z)(this,at,{writable:!0,value:e=>{(0,re.Z)(this,tt).emit(e)}}),(0,ie.Z)(this,nt,{writable:!0,value:O(this)}),(0,ie.Z)(this,st,{writable:!0,value:e=>{(0,re.Z)(this,it).emit(e)}}),(0,ie.Z)(this,lt,{writable:!0,value:I(this)}),(0,ie.Z)(this,ot,{writable:!0,value:e=>{(0,re.Z)(this,rt).emit(e)}}),(0,ie.Z)(this,ct,{writable:!0,value:q(this)}),(0,ie.Z)(this,dt,{writable:!0,value:e=>{(0,re.Z)(this,ut).emit(e)}}),(0,ie.Z)(this,ht,{writable:!0,value:G(this)}),(0,ie.Z)(this,gt,{writable:!0,value:e=>{(0,re.Z)(this,vt).emit(e)}}),(0,ie.Z)(this,pt,{writable:!0,value:e=>{this.activeTarget=e}}),(0,ie.Z)(this,kt,{writable:!0,value:(0,ce.createRef)()})}get layout(){return(0,re.Z)(this,He)}set layout(e){(0,le.Z)(this,He,e)}get nodes(){return(0,re.Z)(this,Ke)}set nodes(e){(0,le.Z)(this,Ke,e)}get edges(){return(0,re.Z)(this,_e)}set edges(e){(0,le.Z)(this,_e,e)}get nodeBricks(){return(0,re.Z)(this,Ie)}set nodeBricks(e){(0,le.Z)(this,Ie,e)}get lines(){return(0,re.Z)(this,Xe)}set lines(e){(0,le.Z)(this,Xe,e)}get layoutOptions(){return(0,re.Z)(this,Ye)}set layoutOptions(e){(0,le.Z)(this,Ye,e)}get activeTarget(){return(0,re.Z)(this,Ve)}set activeTarget(e){(0,le.Z)(this,Ve,e)}get disableKeyboardAction(){return(0,re.Z)(this,qe)}set disableKeyboardAction(e){(0,le.Z)(this,qe,e)}get nodesConnect(){return(0,re.Z)(this,$e)}set nodesConnect(e){(0,le.Z)(this,$e,e)}get zoomable(){return(0,re.Z)(this,je)}set zoomable(e){(0,le.Z)(this,je,e)}get scrollable(){return(0,re.Z)(this,Fe)}set scrollable(e){(0,le.Z)(this,Fe,e)}get scaleRange(){return(0,re.Z)(this,Ge)}set scaleRange(e){(0,le.Z)(this,Ge,e)}callOnLineLabel(e,t){for(var a,n=arguments.length,i=new Array(n>2?n-2:0),s=2;s<n;s++)i[s-2]=arguments[s];null===(a=(0,re.Z)(this,kt).current)||void 0===a||a.callOnLineLabel(e,t,...i)}render(){return ue().createElement(Oe,{ref:(0,re.Z)(this,kt),layout:this.layout,nodes:this.nodes,edges:this.edges,nodeBricks:this.nodeBricks,lines:this.lines,layoutOptions:this.layoutOptions,nodesConnect:this.nodesConnect,activeTarget:this.activeTarget,disableKeyboardAction:this.disableKeyboardAction,zoomable:this.zoomable,scrollable:this.scrollable,scaleRange:this.scaleRange,onActiveTargetChange:(0,re.Z)(this,Ue),onSwitchActiveTarget:(0,re.Z)(this,pt),onNodeDelete:(0,re.Z)(this,at),onEdgeDelete:(0,re.Z)(this,st),onLineClick:(0,re.Z)(this,ot),onLineDoubleClick:(0,re.Z)(this,dt),onNodesConnect:(0,re.Z)(this,gt)})}}function mt(e){D(this,e)}function bt(){return T(this)}function wt(e){A(this,e)}function ft(){return z(this)}function yt(e){K(this,e)}function Et(){return H(this)}function Mt(e){Y(this,e)}function Wt(){return X(this)}function Ct(e){j(this,e)}function Lt(){return $(this)}function xt(e){Q(this,e)}function Rt(){return J(this)}function St(e,t){var{layout:a,nodes:n,edges:i,nodeBricks:s,lines:l,layoutOptions:r,nodesConnect:o,activeTarget:c,disableKeyboardAction:u,zoomable:d,scrollable:h,scaleRange:v,onActiveTargetChange:g,onSwitchActiveTarget:p,onNodeDelete:k,onEdgeDelete:Z,onLineClick:m,onLineDoubleClick:b,onNodesConnect:w}=e,[f,y]=(0,ce.useState)(null),[E,M]=(0,ce.useState)(!1),[W,C]=(0,ce.useState)(0),[L,x]=(0,ce.useState)(null),[R,S]=(0,ce.useState)(0),[T,D]=(0,ce.useState)(null),[P,B]=(0,ce.useState)([]),[z,A]=(0,ce.useState)([]),[N,O]=(0,ce.useState)([]),[H,K]=(0,ce.useState)(!1),[_,I]=(0,ce.useState)({k:1,x:0,y:0}),X=(0,ce.useRef)(new Map),Y=(0,ce.useRef)(null),V=(0,ce.useRef)(null),[q,$]=(0,ce.useState)(!1),[j,F]=(0,ce.useState)([0,0]),[G,J]=(0,ce.useState)(null);(0,ce.useImperativeHandle)(t,(()=>({callOnLineLabel(e,t){for(var a,n=arguments.length,i=new Array(n>2?n-2:0),s=2;s<n;s++)i[s-2]=arguments[s];null==T||null===(a=T.get(e))||void 0===a||null===(a=a.firstElementChild)||void 0===a||a[t](...i)}}))),(0,ce.useEffect)((()=>{var e=e=>{(0,Te.w)(e,{nodes:n,nodesRefRepository:L,nodesConnect:o,setConnectLineState:J,setConnectLineTo:F,onSwitchActiveTarget:p,onNodesConnect:w})},t=V.current;return null==t||t.addEventListener("mousedown",e),()=>{null==t||t.removeEventListener("mousedown",e)}}),[n,o,L,w,p]);var Q=(0,ce.useMemo)((()=>(0,ne.Z)({rankdir:"TB",ranksep:50,edgesep:10,nodesep:50,nodePadding:0},r)),[r]),{nodePadding:U}=Q,ee=(0,ce.useMemo)((()=>(0,Ze.pick)(Q,["rankdir","ranksep","edgesep","nodesep","align"])),[Q]),te=(0,ce.useRef)(!1);(0,ce.useEffect)((()=>{te.current?null==g||g(null!=c?c:null):te.current=!0}),[n,c,g]),(0,ce.useEffect)((()=>{y((e=>(0,Se.T)(e,n,i,ee)))}),[i,n,ee]),(0,ce.useEffect)((()=>{var e=(0,Re.E)({graph:f,nodesRefRepository:L,nodePadding:U});e&&(B(e.nodes),A(e.edges))}),[f,L,W,U]);var{renderedLines:ae,markers:ie}=(0,ce.useMemo)((()=>(0,fe.b)(z,l)),[l,z]);(0,ce.useEffect)((()=>{var e=Y.current;if(e&&!u){var t=e=>{var t=(0,be.p)(e,{renderedNodes:P,renderedEdges:z,activeTarget:c});"delete-node"===(null==t?void 0:t.action)?null==k||k(t.node):"delete-edge"===(null==t?void 0:t.action)?null==Z||Z(t.edge):"switch-active-node"===(null==t?void 0:t.action)&&t.node&&(null==p||p({type:"node",nodeId:t.node.id}))};return e.addEventListener("keydown",t),()=>{e.removeEventListener("keydown",t)}}}),[c,P,z,u,p,k,Z]);var se=(0,ce.useCallback)((e=>{e&&(C((e=>e+1)),x(e)),M((t=>t||!!e))}),[]),le=(0,ce.useCallback)((e=>{e&&(S((e=>e+1)),D(e))}),[]),re=(0,ce.useMemo)((()=>null!=v?v:[Pe.oh,Pe.rN]),[v]),oe=(0,ce.useMemo)((()=>(0,ge.sP)()),[]);(0,ce.useEffect)((()=>{var e=!1;oe.scaleExtent(d?re:[1,1]).on("start",(()=>{e=!1,K(!0)})).on("zoom",(t=>{e=!0,I(t.transform)})).on("end",(()=>{K(!1),e||null==p||p(null)}))}),[p,re,d,oe]),(0,ce.useEffect)((()=>{var e=Y.current;if(e){var t=(0,ve.Z)(e);return d||h?t.on("wheel.zoom.custom",(e=>{e.ctrlKey||(e.stopImmediatePropagation(),h&&(e.preventDefault(),oe.translateBy(t,e.wheelDeltaX/5,e.wheelDeltaY/5)))})):t.on(".zoom",null),t.on("wheel",(e=>e.preventDefault())).call(oe).on("dblclick.zoom",null),()=>{t.on(".zoom",null),t.on(".zoom.custom",null)}}}),[h,d,oe]),(0,ce.useEffect)((()=>{var e=Y.current;if(0!==P.length&&e&&!q){var{k:t,x:a,y:n}=(0,we.i)(P,{canvasWidth:e.clientWidth,canvasHeight:e.clientHeight,scaleRange:d?re:void 0});oe.transform((0,ve.Z)(e),new ge.ax(t,a,n)),$(!0)}}),[q,P,re,d,oe]);var de=(0,ce.useMemo)((()=>"".concat((0,Ze.uniqueId)("diagram-"),"-")),[]),he="".concat(de,"line-arrow-"),pe="".concat(de,"clip-path-"),De="".concat(de,"active-line-");(0,ce.useEffect)((()=>{O((e=>(0,xe.K)(e,ae,X.current)))}),[ae]);var[Be,ze]=ue().useState([]);return(0,ce.useEffect)((()=>{T&&ze((0,Le.i)(N,T))}),[R,T,N]),"dagre"!==a?ue().createElement("div",null,'Diagram layout not supported: "'.concat(a,'"')):ue().createElement("div",{className:ke()("diagram",{ready:E&&q,grabbing:H}),tabIndex:-1,ref:Y},ue().createElement("svg",{width:"100%",height:"100%",className:"lines"},ue().createElement("defs",null,ie.map(((e,t)=>{var{strokeColor:a}=e;return ue().createElement(Me.C,{key:t,id:"".concat(he).concat(t),strokeColor:a})})),Be.map((e=>ue().createElement(We.K,{key:e.id,clipPath:e,clipPathPrefix:pe,renderedLineLabels:N}))),ue().createElement("marker",{id:"".concat(De,"start"),viewBox:"0 0 8 8",refX:4,refY:4,markerWidth:8,markerHeight:8,orient:"auto"},ue().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)"})),ue().createElement("marker",{id:"".concat(De,"end"),viewBox:"0 0 14 8",refX:3,refY:4,markerWidth:14,markerHeight:8,orient:"auto"},ue().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)"}),ue().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)"}))),ue().createElement("g",{transform:"translate(".concat(_.x," ").concat(_.y,") scale(").concat(_.k,")")},ae.map((e=>ue().createElement(Ee.y,{key:e.line.$id,line:e,linePaths:X.current,clipPathList:Be,markerPrefix:he,clipPathPrefix:pe,activeLineMarkerPrefix:De,activeEdge:"edge"===(null==c?void 0:c.type)?c.edge:null,onLineClick:m,onLineDoubleClick:b}))))),ue().createElement("div",{className:"line-labels",style:{left:_.x,top:_.y,transform:"scale(".concat(_.k,")")}},ue().createElement(ye.L8,{labels:N,onRendered:le})),ue().createElement("div",{className:"nodes",ref:V,style:{left:_.x,top:_.y,transform:"scale(".concat(_.k,")")}},ue().createElement(me.n,{nodes:n,nodeBricks:s,onRendered:se})),ue().createElement(Ce.f,{connectLineState:G,connectLineTo:j,markerPrefix:he}))}te=Zt,({e:[l,o,u,h,g,k,m,w,y,M,C,x,S,T,D,B,z,A,O,H,K,I,X,Y,q,$,j,G,J,Q,ee],c:[ae,n]}=(0,oe.Z)(te,[[s,1,"layout"],[r,1,"nodes"],[c,1,"edges"],[d,1,"nodeBricks"],[v,1,"lines"],[p,1,"layoutOptions"],[Z,1,"activeTarget"],[b,1,"disableKeyboardAction"],[f,1,"nodesConnect"],[E,1,"zoomable"],[W,1,"scrollable"],[L,1,"scaleRange"],[R,1,"activeTargetChangeEvent",e=>(0,re.Z)(e,Je),(e,t)=>(0,le.Z)(e,Je,t)],[P,1,"nodeDelete",e=>(0,re.Z)(e,et),(e,t)=>(0,le.Z)(e,et,t)],[N,1,"edgeDelete",e=>(0,re.Z)(e,nt),(e,t)=>(0,le.Z)(e,nt,t)],[_,1,"lineClick",e=>(0,re.Z)(e,lt),(e,t)=>(0,le.Z)(e,lt,t)],[V,1,"lineDoubleClick",e=>(0,re.Z)(e,ct),(e,t)=>(0,le.Z)(e,ct,t)],[F,1,"nodesConnect",e=>(0,re.Z)(e,ht),(e,t)=>(0,le.Z)(e,ht,t)],[U,2,"callOnLineLabel"]],[i],0,(e=>kt.has((0,se.Z)(e))),he.ReactNextElement)),n()}}]);
2
+ //# sourceMappingURL=eo-diagram.6168dc79.js.map