@next-bricks/diagram 0.54.3 → 0.54.4

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 (81) hide show
  1. package/dist/bricks.json +3 -3
  2. package/dist/chunks/{1122.c0ce4248.js → 1122.44c2d625.js} +2 -2
  3. package/dist/chunks/{1122.c0ce4248.js.map → 1122.44c2d625.js.map} +1 -1
  4. package/dist/chunks/{114.7840025a.js → 114.b0805615.js} +2 -2
  5. package/dist/chunks/{114.7840025a.js.map → 114.b0805615.js.map} +1 -1
  6. package/dist/chunks/1370.ff678c2c.js +2 -0
  7. package/dist/chunks/{1370.8d145ce9.js.map → 1370.ff678c2c.js.map} +1 -1
  8. package/dist/chunks/{1940.e4afab06.js → 1940.d4e8c5b9.js} +2 -2
  9. package/dist/chunks/{1940.e4afab06.js.map → 1940.d4e8c5b9.js.map} +1 -1
  10. package/dist/chunks/{2277.b9489bc0.js → 2277.83e80fbf.js} +2 -2
  11. package/dist/chunks/{4658.1c3c99dd.js.map → 2277.83e80fbf.js.map} +1 -1
  12. package/dist/chunks/{3025.d4a92d85.js → 3025.e8c7b486.js} +3 -3
  13. package/dist/chunks/{3025.d4a92d85.js.map → 3025.e8c7b486.js.map} +1 -1
  14. package/dist/chunks/{3171.46fd5b05.js → 3171.ad783275.js} +2 -2
  15. package/dist/chunks/{3171.46fd5b05.js.map → 3171.ad783275.js.map} +1 -1
  16. package/dist/chunks/{3233.289bdcbe.js → 3233.0b40a7de.js} +3 -3
  17. package/dist/chunks/{3233.289bdcbe.js.map → 3233.0b40a7de.js.map} +1 -1
  18. package/dist/chunks/{3933.42989e69.js → 3933.6f63c7d7.js} +2 -2
  19. package/dist/chunks/{3933.42989e69.js.map → 3933.6f63c7d7.js.map} +1 -1
  20. package/dist/chunks/{4306.837f4dc9.js → 4306.af11344a.js} +2 -2
  21. package/dist/chunks/{4306.837f4dc9.js.map → 4306.af11344a.js.map} +1 -1
  22. package/dist/chunks/{4658.1c3c99dd.js → 4658.df491375.js} +2 -2
  23. package/dist/chunks/{2277.b9489bc0.js.map → 4658.df491375.js.map} +1 -1
  24. package/dist/chunks/{4837.d99cfcee.js → 4837.6f8bf608.js} +2 -2
  25. package/dist/chunks/{7218.7e726731.js.map → 4837.6f8bf608.js.map} +1 -1
  26. package/dist/chunks/{5552.244a17f6.js → 5552.b60ebd94.js} +2 -2
  27. package/dist/chunks/{5552.244a17f6.js.map → 5552.b60ebd94.js.map} +1 -1
  28. package/dist/chunks/5582.ec75259d.js +3 -0
  29. package/dist/chunks/{5582.863f6bfa.js.map → 5582.ec75259d.js.map} +1 -1
  30. package/dist/chunks/{6314.57b02e4b.js → 6314.096c993f.js} +2 -2
  31. package/dist/chunks/{6314.57b02e4b.js.map → 6314.096c993f.js.map} +1 -1
  32. package/dist/chunks/{6519.fe9d3c07.js → 6519.4ddc3bd5.js} +2 -2
  33. package/dist/chunks/{6519.fe9d3c07.js.map → 6519.4ddc3bd5.js.map} +1 -1
  34. package/dist/chunks/{3210.199861ac.js → 6867.b522ea87.js} +2 -2
  35. package/dist/chunks/{3210.199861ac.js.map → 6867.b522ea87.js.map} +1 -1
  36. package/dist/chunks/{7218.7e726731.js → 7218.1cd0fca8.js} +2 -2
  37. package/dist/chunks/{4837.d99cfcee.js.map → 7218.1cd0fca8.js.map} +1 -1
  38. package/dist/chunks/{726.31d83c95.js → 726.aac643de.js} +2 -2
  39. package/dist/chunks/726.aac643de.js.map +1 -0
  40. package/dist/chunks/{7733.a2f6f661.js → 7733.a2c42502.js} +2 -2
  41. package/dist/chunks/{7733.a2f6f661.js.map → 7733.a2c42502.js.map} +1 -1
  42. package/dist/chunks/{8552.eda917ff.js → 8552.6623f1fa.js} +2 -2
  43. package/dist/chunks/{8552.eda917ff.js.map → 8552.6623f1fa.js.map} +1 -1
  44. package/dist/chunks/8989.c317f6cd.js +2 -0
  45. package/dist/chunks/{8989.0fc5ea84.js.map → 8989.c317f6cd.js.map} +1 -1
  46. package/dist/chunks/{9559.588b7ac2.js → 9559.f28defcc.js} +2 -2
  47. package/dist/chunks/{9559.588b7ac2.js.map → 9559.f28defcc.js.map} +1 -1
  48. package/dist/chunks/{9711.85eea38c.js → 9711.d48f441d.js} +2 -2
  49. package/dist/chunks/{9711.85eea38c.js.map → 9711.d48f441d.js.map} +1 -1
  50. package/dist/chunks/{editable-label.3cec419e.js → editable-label.a7b497ee.js} +3 -3
  51. package/dist/chunks/{editable-label.3cec419e.js.map → editable-label.a7b497ee.js.map} +1 -1
  52. package/dist/chunks/{eo-diagram.b1a87a4b.js → eo-diagram.44df31ee.js} +2 -2
  53. package/dist/chunks/{eo-diagram.b1a87a4b.js.map → eo-diagram.44df31ee.js.map} +1 -1
  54. package/dist/chunks/{eo-display-canvas.37483d85.js → eo-display-canvas.c4f21ed5.js} +2 -2
  55. package/dist/chunks/{eo-display-canvas.37483d85.js.map → eo-display-canvas.c4f21ed5.js.map} +1 -1
  56. package/dist/chunks/{eo-draw-canvas.d7cca02f.js → eo-draw-canvas.2f912dba.js} +2 -2
  57. package/dist/chunks/{eo-draw-canvas.d7cca02f.js.map → eo-draw-canvas.2f912dba.js.map} +1 -1
  58. package/dist/chunks/{experimental-node.3e7326f2.js → experimental-node.9b5d8200.js} +2 -2
  59. package/dist/chunks/{experimental-node.3e7326f2.js.map → experimental-node.9b5d8200.js.map} +1 -1
  60. package/dist/chunks/main.f10c14ce.js +2 -0
  61. package/dist/chunks/main.f10c14ce.js.map +1 -0
  62. package/dist/examples.json +3 -3
  63. package/dist/index.9d07653d.js +2 -0
  64. package/dist/index.9d07653d.js.map +1 -0
  65. package/dist/manifest.json +159 -159
  66. package/dist/types.json +4307 -4307
  67. package/package.json +6 -6
  68. package/dist/chunks/1370.8d145ce9.js +0 -2
  69. package/dist/chunks/3751.c544b621.js +0 -2
  70. package/dist/chunks/3751.c544b621.js.map +0 -1
  71. package/dist/chunks/5582.863f6bfa.js +0 -3
  72. package/dist/chunks/726.31d83c95.js.map +0 -1
  73. package/dist/chunks/8989.0fc5ea84.js +0 -2
  74. package/dist/chunks/main.9acd224f.js +0 -2
  75. package/dist/chunks/main.9acd224f.js.map +0 -1
  76. package/dist/index.d5395e53.js +0 -2
  77. package/dist/index.d5395e53.js.map +0 -1
  78. /package/dist/chunks/{3025.d4a92d85.js.LICENSE.txt → 3025.e8c7b486.js.LICENSE.txt} +0 -0
  79. /package/dist/chunks/{3233.289bdcbe.js.LICENSE.txt → 3233.0b40a7de.js.LICENSE.txt} +0 -0
  80. /package/dist/chunks/{5582.863f6bfa.js.LICENSE.txt → 5582.ec75259d.js.LICENSE.txt} +0 -0
  81. /package/dist/chunks/{editable-label.3cec419e.js.LICENSE.txt → editable-label.a7b497ee.js.LICENSE.txt} +0 -0
@@ -1,2 +1,2 @@
1
- "use strict";(globalThis.webpackChunk_next_bricks_diagram=globalThis.webpackChunk_next_bricks_diagram||[]).push([[9823],{6094:(e,t,a)=>{a.r(t),a.d(t,{EoDisplayCanvas:()=>Oe});var s,l=a(4635),i=a(918),o=a(6902),n=a(5536),r=a(6121),h=a(829),d=a(2740),c=a(8769),u=a.n(c),g=a(2786),A=a(3049),p=(a(6477),a(1030)),C=a(3373),k=a.n(C),b=a(7566),y=a(3739),v=a(8185),f=a(6787),m=a(3783),N=a(3033),T=a(8091),W=a(1819),R=a(5748),w=a(227),M=a(531),E=a(7099),S=a(1484),z=a(8197),B=a(7531),L=a(2098),x=a(3012),O=a(6237),$=a(5915);let F,Z,U,_,H,K,P,D,I,Y,q,J,j,G,Q,V,X,ee,te,ae,se,le,ie,oe,ne,re,he,de,ce,ue,ge,Ae,pe,Ce,ke,be,ye,ve,fe,me,Ne,Te,We,Re,we,Me,Ee,Se,ze;const{defineElement:Be,property:Le,event:xe}=(0,g.createDecorators)();let Oe;var $e=new WeakMap,Fe=new WeakMap,Ze=new WeakMap,Ue=new WeakMap,_e=new WeakMap,He=new WeakMap,Ke=new WeakMap,Pe=new WeakMap,De=new WeakMap,Ie=new WeakMap,Ye=new WeakMap,qe=new WeakMap,Je=new WeakMap,je=new WeakMap,Ge=new WeakMap,Qe=new WeakMap,Ve=new WeakMap,Xe=new WeakMap,et=new WeakMap,tt=new WeakSet,at=new WeakMap,st=new WeakMap,lt=new WeakMap,it=new WeakMap,ot=new WeakMap,nt=new WeakMap;class rt extends A.ReactNextElement{constructor(){super(...arguments),(0,l.A)(this,tt),(0,i.A)(this,$e,Z(this)),(0,i.A)(this,Fe,(U(this),_(this))),(0,i.A)(this,Ze,(H(this),K(this))),(0,i.A)(this,Ue,(P(this),D(this,[N.HP,N.HP]))),(0,i.A)(this,_e,(I(this),Y(this))),(0,i.A)(this,He,(q(this),J(this))),(0,i.A)(this,Ke,(j(this),G(this))),(0,i.A)(this,Pe,(Q(this),V(this))),(0,i.A)(this,De,(X(this),ee(this))),(0,i.A)(this,Ie,(te(this),ae(this))),(0,i.A)(this,Ye,(se(this),le(this,!0))),(0,i.A)(this,qe,(ie(this),oe(this,!0))),(0,i.A)(this,Je,(ne(this),re(this,!0))),(0,i.A)(this,je,(he(this),de(this))),(0,i.A)(this,Ge,(ce(this),ue(this))),(0,i.A)(this,Qe,(ge(this),Ae(this))),(0,i.A)(this,Ve,(pe(this),Ce(this))),(0,i.A)(this,Xe,(ke(this),be(this))),(0,i.A)(this,et,(ye(this),ve(this))),(0,i.A)(this,at,(Ne(this),e=>{(0,n.A)(tt,this,fe).emit(e)})),(0,i.A)(this,st,(e=>{(0,v.c)(e,this.activeTarget)||(this.activeTarget=e)})),(0,i.A)(this,lt,Te(this)),(0,i.A)(this,it,(we(this),e=>{(0,n.A)(tt,this,We).emit(e)})),(0,i.A)(this,ot,Me(this)),(0,i.A)(this,nt,(ze(this),e=>{(0,n.A)(tt,this,Ee).emit(e)}))}get cells(){return(0,h.A)($e,this)}set cells(e){(0,r.A)($e,this,e)}get layout(){return(0,h.A)(Fe,this)}set layout(e){(0,r.A)(Fe,this,e)}get layoutOptions(){return(0,h.A)(Ze,this)}set layoutOptions(e){(0,r.A)(Ze,this,e)}get defaultNodeSize(){return(0,h.A)(Ue,this)}set defaultNodeSize(e){(0,r.A)(Ue,this,e)}get defaultNodeBricks(){return(0,h.A)(_e,this)}set defaultNodeBricks(e){(0,r.A)(_e,this,e)}get degradedThreshold(){return(0,h.A)(He,this)}set degradedThreshold(e){(0,r.A)(He,this,e)}get degradedNodeLabel(){return(0,h.A)(Ke,this)}set degradedNodeLabel(e){(0,r.A)(Ke,this,e)}get defaultEdgeLines(){return(0,h.A)(Pe,this)}set defaultEdgeLines(e){(0,r.A)(Pe,this,e)}get activeTarget(){return(0,h.A)(De,this)}set activeTarget(e){(0,r.A)(De,this,e)}get fadeUnrelatedCells(){return(0,h.A)(Ie,this)}set fadeUnrelatedCells(e){(0,r.A)(Ie,this,e)}get zoomable(){return(0,h.A)(Ye,this)}set zoomable(e){(0,r.A)(Ye,this,e)}get scrollable(){return(0,h.A)(qe,this)}set scrollable(e){(0,r.A)(qe,this,e)}get pannable(){return(0,h.A)(Je,this)}set pannable(e){(0,r.A)(Je,this,e)}get scaleRange(){return(0,h.A)(je,this)}set scaleRange(e){(0,r.A)(je,this,e)}get hideZoomBar(){return(0,h.A)(Ge,this)}set hideZoomBar(e){(0,r.A)(Ge,this,e)}get autoCenterWhenCellsChange(){return(0,h.A)(Qe,this)}set autoCenterWhenCellsChange(e){(0,r.A)(Qe,this,e)}get doNotResetActiveTargetForSelector(){return(0,h.A)(Ve,this)}set doNotResetActiveTargetForSelector(e){(0,r.A)(Ve,this,e)}get doNotResetActiveTargetOutsideCanvas(){return(0,h.A)(Xe,this)}set doNotResetActiveTargetOutsideCanvas(e){(0,r.A)(Xe,this,e)}render(){return u().createElement(ht,{shadowRoot:this.shadowRoot,cells:this.cells,layout:this.layout,layoutOptions:this.layoutOptions,defaultNodeSize:this.defaultNodeSize,defaultNodeBricks:this.defaultNodeBricks,defaultEdgeLines:this.defaultEdgeLines,degradedThreshold:this.degradedThreshold,degradedNodeLabel:this.degradedNodeLabel,activeTarget:this.activeTarget,fadeUnrelatedCells:this.fadeUnrelatedCells,zoomable:this.zoomable,scrollable:this.scrollable,pannable:this.pannable,scaleRange:this.scaleRange,hideZoomBar:this.hideZoomBar,doNotResetActiveTargetForSelector:this.doNotResetActiveTargetForSelector,doNotResetActiveTargetOutsideCanvas:this.doNotResetActiveTargetOutsideCanvas,autoCenterWhenCellsChange:this.autoCenterWhenCellsChange,onActiveTargetChange:(0,h.A)(at,this),onSwitchActiveTarget:(0,h.A)(st,this),onCellContextMenu:(0,h.A)(it,this),onCellClick:(0,h.A)(nt,this)})}}function ht(e){let{shadowRoot:t,cells:a,layout:s,layoutOptions:l,defaultNodeSize:i,defaultNodeBricks:o,defaultEdgeLines:n,degradedThreshold:r,degradedNodeLabel:h,activeTarget:d,fadeUnrelatedCells:g,zoomable:A,scrollable:C,pannable:v,scaleRange:x,hideZoomBar:O,autoCenterWhenCellsChange:F,doNotResetActiveTargetForSelector:Z,doNotResetActiveTargetOutsideCanvas:U,onActiveTargetChange:_,onSwitchActiveTarget:H,onCellContextMenu:K,onCellClick:P}=e;const[{cells:D,layoutKey:I},Y]=(0,c.useReducer)(R.d,a,(e=>({cells:(0,m.C)(e,{defaultNodeSize:i}),layoutKey:1}))),q=(0,c.useMemo)((()=>D.filter(M.N).length>=(null!=r?r:N.pC)),[D,r]),J=(0,c.useRef)(null),{grabbing:j,transform:G,zoomer:Q,scaleRange:V}=(0,T.f)({rootRef:J,zoomable:A,scrollable:C,pannable:v,draggable:!0,scaleRange:x,onSwitchActiveTarget:H}),{centered:X,setCentered:ee,getNextLayoutKey:te}=(0,S.g)({layout:s,layoutOptions:l,rootRef:J,cells:D,zoomable:A,zoomer:Q,scaleRange:V,layoutKey:I,autoCenterWhenCellsChange:F,dispatch:Y}),ae=(0,c.useCallback)((()=>{ee(!1)}),[ee]),se=(0,c.useRef)(a);(0,c.useEffect)((()=>{if(a!==se.current){se.current=a;const e=(0,L.L)({canvasWidth:t.host.clientWidth,canvasHeight:t.host.clientHeight,defaultNodeSize:i,layout:s,previousCells:D,cells:a,scaleRange:V,transform:G});Y({type:"update-cells",payload:e.cells})}}),[D,i,a,s,V,t,G]);const le=(0,W.J)({rootRef:J,activeTarget:d,doNotResetActiveTargetForSelector:Z,doNotResetActiveTargetOutsideCanvas:U,onActiveTargetChange:_}),ie=`${(0,c.useMemo)((()=>`${(0,p.uniqueId)("diagram-")}-`),[])}line-arrow-`,oe=(0,c.useCallback)(((e,t)=>{Y({type:"update-node-size",payload:{id:e,size:t},layoutKey:te()})}),[te]),[ne,re]=(0,c.useState)(null),he=(0,c.useCallback)((e=>{re(e)}),[]),de=(0,c.useCallback)((e=>{re((t=>t===e?null:t))}),[]),[ce,ue]=(0,c.useState)([]);(0,c.useEffect)((()=>{const e=g?(0,w.Y)(D,null,ne):[];ue((t=>0===t.length&&0===e.length?t:e))}),[D,g,ne]);const ge=(0,c.useCallback)((e=>{Q.scaleTo((0,b.A)(J.current),e/100)}),[Q]),{lineConfMap:Ae,markers:pe}=(0,B.d)({cells:D,defaultEdgeLines:n,markerPrefix:ie}),Ce=(0,$.A)({cells:D,lineConfMap:Ae}),ke=(0,z.H)({cells:D,layout:s,centered:X});return u().createElement(u().Fragment,null,u().createElement("svg",{width:"100%",height:"100%",ref:J,className:k()("root",{grabbing:j,pannable:v,ready:ke}),tabIndex:-1},u().createElement("defs",null,pe.map(((e,t)=>u().createElement(y.c,{key:t,id:`${ie}${t}`,type:e.markerType,strokeColor:e.strokeColor})))),u().createElement("g",{transform:`translate(${G.x} ${G.y}) scale(${G.k})`},u().createElement("g",{className:"cells"},D.map((e=>u().createElement(f.m,{key:`${e.type}:${(0,M.WW)(e)?`${e.source}~${e.target}`:e.id}`,layout:s,cell:e,cells:D,degraded:q,degradedNodeLabel:h,defaultNodeBricks:o,lineConfMap:Ae,editableLineMap:Ce,transform:G,activeTarget:le,readOnly:!0,hoverCell:ne,unrelatedCells:ce,onSwitchActiveTarget:H,onCellContextMenu:K,onCellClick:P,onNodeBrickResize:oe,onCellMouseEnter:g&&((0,M.N)(e)||(0,M.WW)(e))?he:void 0,onCellMouseLeave:g&&((0,M.N)(e)||(0,M.WW)(e))?de:void 0})))))),!O&&u().createElement(E.Y,{shadowRoot:t,scale:G.k,scaleRange:V,onZoomChange:ge,onReCenter:ae}))}s=rt,({e:[Z,U,_,H,K,P,D,I,Y,q,J,j,G,Q,V,X,ee,te,ae,se,le,ie,oe,ne,re,he,de,ce,ue,ge,Ae,pe,Ce,ke,be,ye,ve,fe,me,Ne,Te,We,Re,we,Me,Ee,Se,ze],c:[Oe,F]}=(0,d.A)(s,[Be("eo-display-canvas",{styleTexts:[x.A,O.A]})],[[Le({attribute:!1}),1,"cells"],[Le({type:String}),1,"layout"],[Le({attribute:!1}),1,"layoutOptions"],[Le({attribute:!1}),1,"defaultNodeSize"],[Le({attribute:!1}),1,"defaultNodeBricks"],[Le({type:Number}),1,"degradedThreshold"],[Le({attribute:!1}),1,"degradedNodeLabel"],[Le({attribute:!1}),1,"defaultEdgeLines"],[Le({attribute:!1}),1,"activeTarget"],[Le({type:Boolean}),1,"fadeUnrelatedCells"],[Le({type:Boolean}),1,"zoomable"],[Le({type:Boolean}),1,"scrollable"],[Le({type:Boolean}),1,"pannable"],[Le({attribute:!1}),1,"scaleRange"],[Le({type:Boolean}),1,"hideZoomBar"],[Le({type:Boolean}),1,"autoCenterWhenCellsChange"],[Le(),1,"doNotResetActiveTargetForSelector"],[Le({type:Boolean}),1,"doNotResetActiveTargetOutsideCanvas"],[xe({type:"activeTarget.change"}),1,"activeTargetChangeEvent",e=>(0,h.A)(et,e),(e,t)=>(0,r.A)(et,e,t)],[xe({type:"cell.contextmenu"}),1,"cellContextMenu",e=>(0,h.A)(lt,e),(e,t)=>(0,r.A)(lt,e,t)],[xe({type:"cell.click"}),1,"cellClick",e=>(0,h.A)(ot,e),(e,t)=>(0,r.A)(ot,e,t)]],0,(e=>nt.has((0,o.A)(e))),A.ReactNextElement)),F()}}]);
2
- //# sourceMappingURL=eo-display-canvas.37483d85.js.map
1
+ "use strict";(globalThis.webpackChunk_next_bricks_diagram=globalThis.webpackChunk_next_bricks_diagram||[]).push([[9823],{6094:(e,t,a)=>{a.r(t),a.d(t,{EoDisplayCanvas:()=>Oe});var s,l=a(4635),i=a(918),o=a(6902),n=a(5536),r=a(6121),h=a(829),d=a(2740),c=a(8769),u=a.n(c),g=a(1123),A=a(9006),p=(a(6477),a(1030)),C=a(3373),k=a.n(C),b=a(7566),y=a(3739),v=a(8185),f=a(6787),m=a(3783),N=a(3033),T=a(8091),W=a(1819),R=a(5748),w=a(227),M=a(531),E=a(7099),S=a(1484),z=a(8197),B=a(7531),L=a(2098),x=a(3012),O=a(6237),$=a(5915);let F,Z,U,_,H,K,P,D,I,Y,q,J,j,G,Q,V,X,ee,te,ae,se,le,ie,oe,ne,re,he,de,ce,ue,ge,Ae,pe,Ce,ke,be,ye,ve,fe,me,Ne,Te,We,Re,we,Me,Ee,Se,ze;const{defineElement:Be,property:Le,event:xe}=(0,g.createDecorators)();let Oe;var $e=new WeakMap,Fe=new WeakMap,Ze=new WeakMap,Ue=new WeakMap,_e=new WeakMap,He=new WeakMap,Ke=new WeakMap,Pe=new WeakMap,De=new WeakMap,Ie=new WeakMap,Ye=new WeakMap,qe=new WeakMap,Je=new WeakMap,je=new WeakMap,Ge=new WeakMap,Qe=new WeakMap,Ve=new WeakMap,Xe=new WeakMap,et=new WeakMap,tt=new WeakSet,at=new WeakMap,st=new WeakMap,lt=new WeakMap,it=new WeakMap,ot=new WeakMap,nt=new WeakMap;class rt extends A.ReactNextElement{constructor(){super(...arguments),(0,l.A)(this,tt),(0,i.A)(this,$e,Z(this)),(0,i.A)(this,Fe,(U(this),_(this))),(0,i.A)(this,Ze,(H(this),K(this))),(0,i.A)(this,Ue,(P(this),D(this,[N.HP,N.HP]))),(0,i.A)(this,_e,(I(this),Y(this))),(0,i.A)(this,He,(q(this),J(this))),(0,i.A)(this,Ke,(j(this),G(this))),(0,i.A)(this,Pe,(Q(this),V(this))),(0,i.A)(this,De,(X(this),ee(this))),(0,i.A)(this,Ie,(te(this),ae(this))),(0,i.A)(this,Ye,(se(this),le(this,!0))),(0,i.A)(this,qe,(ie(this),oe(this,!0))),(0,i.A)(this,Je,(ne(this),re(this,!0))),(0,i.A)(this,je,(he(this),de(this))),(0,i.A)(this,Ge,(ce(this),ue(this))),(0,i.A)(this,Qe,(ge(this),Ae(this))),(0,i.A)(this,Ve,(pe(this),Ce(this))),(0,i.A)(this,Xe,(ke(this),be(this))),(0,i.A)(this,et,(ye(this),ve(this))),(0,i.A)(this,at,(Ne(this),e=>{(0,n.A)(tt,this,fe).emit(e)})),(0,i.A)(this,st,(e=>{(0,v.c)(e,this.activeTarget)||(this.activeTarget=e)})),(0,i.A)(this,lt,Te(this)),(0,i.A)(this,it,(we(this),e=>{(0,n.A)(tt,this,We).emit(e)})),(0,i.A)(this,ot,Me(this)),(0,i.A)(this,nt,(ze(this),e=>{(0,n.A)(tt,this,Ee).emit(e)}))}get cells(){return(0,h.A)($e,this)}set cells(e){(0,r.A)($e,this,e)}get layout(){return(0,h.A)(Fe,this)}set layout(e){(0,r.A)(Fe,this,e)}get layoutOptions(){return(0,h.A)(Ze,this)}set layoutOptions(e){(0,r.A)(Ze,this,e)}get defaultNodeSize(){return(0,h.A)(Ue,this)}set defaultNodeSize(e){(0,r.A)(Ue,this,e)}get defaultNodeBricks(){return(0,h.A)(_e,this)}set defaultNodeBricks(e){(0,r.A)(_e,this,e)}get degradedThreshold(){return(0,h.A)(He,this)}set degradedThreshold(e){(0,r.A)(He,this,e)}get degradedNodeLabel(){return(0,h.A)(Ke,this)}set degradedNodeLabel(e){(0,r.A)(Ke,this,e)}get defaultEdgeLines(){return(0,h.A)(Pe,this)}set defaultEdgeLines(e){(0,r.A)(Pe,this,e)}get activeTarget(){return(0,h.A)(De,this)}set activeTarget(e){(0,r.A)(De,this,e)}get fadeUnrelatedCells(){return(0,h.A)(Ie,this)}set fadeUnrelatedCells(e){(0,r.A)(Ie,this,e)}get zoomable(){return(0,h.A)(Ye,this)}set zoomable(e){(0,r.A)(Ye,this,e)}get scrollable(){return(0,h.A)(qe,this)}set scrollable(e){(0,r.A)(qe,this,e)}get pannable(){return(0,h.A)(Je,this)}set pannable(e){(0,r.A)(Je,this,e)}get scaleRange(){return(0,h.A)(je,this)}set scaleRange(e){(0,r.A)(je,this,e)}get hideZoomBar(){return(0,h.A)(Ge,this)}set hideZoomBar(e){(0,r.A)(Ge,this,e)}get autoCenterWhenCellsChange(){return(0,h.A)(Qe,this)}set autoCenterWhenCellsChange(e){(0,r.A)(Qe,this,e)}get doNotResetActiveTargetForSelector(){return(0,h.A)(Ve,this)}set doNotResetActiveTargetForSelector(e){(0,r.A)(Ve,this,e)}get doNotResetActiveTargetOutsideCanvas(){return(0,h.A)(Xe,this)}set doNotResetActiveTargetOutsideCanvas(e){(0,r.A)(Xe,this,e)}render(){return u().createElement(ht,{shadowRoot:this.shadowRoot,cells:this.cells,layout:this.layout,layoutOptions:this.layoutOptions,defaultNodeSize:this.defaultNodeSize,defaultNodeBricks:this.defaultNodeBricks,defaultEdgeLines:this.defaultEdgeLines,degradedThreshold:this.degradedThreshold,degradedNodeLabel:this.degradedNodeLabel,activeTarget:this.activeTarget,fadeUnrelatedCells:this.fadeUnrelatedCells,zoomable:this.zoomable,scrollable:this.scrollable,pannable:this.pannable,scaleRange:this.scaleRange,hideZoomBar:this.hideZoomBar,doNotResetActiveTargetForSelector:this.doNotResetActiveTargetForSelector,doNotResetActiveTargetOutsideCanvas:this.doNotResetActiveTargetOutsideCanvas,autoCenterWhenCellsChange:this.autoCenterWhenCellsChange,onActiveTargetChange:(0,h.A)(at,this),onSwitchActiveTarget:(0,h.A)(st,this),onCellContextMenu:(0,h.A)(it,this),onCellClick:(0,h.A)(nt,this)})}}function ht(e){let{shadowRoot:t,cells:a,layout:s,layoutOptions:l,defaultNodeSize:i,defaultNodeBricks:o,defaultEdgeLines:n,degradedThreshold:r,degradedNodeLabel:h,activeTarget:d,fadeUnrelatedCells:g,zoomable:A,scrollable:C,pannable:v,scaleRange:x,hideZoomBar:O,autoCenterWhenCellsChange:F,doNotResetActiveTargetForSelector:Z,doNotResetActiveTargetOutsideCanvas:U,onActiveTargetChange:_,onSwitchActiveTarget:H,onCellContextMenu:K,onCellClick:P}=e;const[{cells:D,layoutKey:I},Y]=(0,c.useReducer)(R.d,a,(e=>({cells:(0,m.C)(e,{defaultNodeSize:i}),layoutKey:1}))),q=(0,c.useMemo)((()=>D.filter(M.N).length>=(null!=r?r:N.pC)),[D,r]),J=(0,c.useRef)(null),{grabbing:j,transform:G,zoomer:Q,scaleRange:V}=(0,T.f)({rootRef:J,zoomable:A,scrollable:C,pannable:v,draggable:!0,scaleRange:x,onSwitchActiveTarget:H}),{centered:X,setCentered:ee,getNextLayoutKey:te}=(0,S.g)({layout:s,layoutOptions:l,rootRef:J,cells:D,zoomable:A,zoomer:Q,scaleRange:V,layoutKey:I,autoCenterWhenCellsChange:F,dispatch:Y}),ae=(0,c.useCallback)((()=>{ee(!1)}),[ee]),se=(0,c.useRef)(a);(0,c.useEffect)((()=>{if(a!==se.current){se.current=a;const e=(0,L.L)({canvasWidth:t.host.clientWidth,canvasHeight:t.host.clientHeight,defaultNodeSize:i,layout:s,previousCells:D,cells:a,scaleRange:V,transform:G});Y({type:"update-cells",payload:e.cells})}}),[D,i,a,s,V,t,G]);const le=(0,W.J)({rootRef:J,activeTarget:d,doNotResetActiveTargetForSelector:Z,doNotResetActiveTargetOutsideCanvas:U,onActiveTargetChange:_}),ie=`${(0,c.useMemo)((()=>`${(0,p.uniqueId)("diagram-")}-`),[])}line-arrow-`,oe=(0,c.useCallback)(((e,t)=>{Y({type:"update-node-size",payload:{id:e,size:t},layoutKey:te()})}),[te]),[ne,re]=(0,c.useState)(null),he=(0,c.useCallback)((e=>{re(e)}),[]),de=(0,c.useCallback)((e=>{re((t=>t===e?null:t))}),[]),[ce,ue]=(0,c.useState)([]);(0,c.useEffect)((()=>{const e=g?(0,w.Y)(D,null,ne):[];ue((t=>0===t.length&&0===e.length?t:e))}),[D,g,ne]);const ge=(0,c.useCallback)((e=>{Q.scaleTo((0,b.A)(J.current),e/100)}),[Q]),{lineConfMap:Ae,markers:pe}=(0,B.d)({cells:D,defaultEdgeLines:n,markerPrefix:ie}),Ce=(0,$.A)({cells:D,lineConfMap:Ae}),ke=(0,z.H)({cells:D,layout:s,centered:X});return u().createElement(u().Fragment,null,u().createElement("svg",{width:"100%",height:"100%",ref:J,className:k()("root",{grabbing:j,pannable:v,ready:ke}),tabIndex:-1},u().createElement("defs",null,pe.map(((e,t)=>u().createElement(y.c,{key:t,id:`${ie}${t}`,type:e.markerType,strokeColor:e.strokeColor})))),u().createElement("g",{transform:`translate(${G.x} ${G.y}) scale(${G.k})`},u().createElement("g",{className:"cells"},D.map((e=>u().createElement(f.m,{key:`${e.type}:${(0,M.WW)(e)?`${e.source}~${e.target}`:e.id}`,layout:s,cell:e,cells:D,degraded:q,degradedNodeLabel:h,defaultNodeBricks:o,lineConfMap:Ae,editableLineMap:Ce,transform:G,activeTarget:le,readOnly:!0,hoverCell:ne,unrelatedCells:ce,onSwitchActiveTarget:H,onCellContextMenu:K,onCellClick:P,onNodeBrickResize:oe,onCellMouseEnter:g&&((0,M.N)(e)||(0,M.WW)(e))?he:void 0,onCellMouseLeave:g&&((0,M.N)(e)||(0,M.WW)(e))?de:void 0})))))),!O&&u().createElement(E.Y,{shadowRoot:t,scale:G.k,scaleRange:V,onZoomChange:ge,onReCenter:ae}))}s=rt,({e:[Z,U,_,H,K,P,D,I,Y,q,J,j,G,Q,V,X,ee,te,ae,se,le,ie,oe,ne,re,he,de,ce,ue,ge,Ae,pe,Ce,ke,be,ye,ve,fe,me,Ne,Te,We,Re,we,Me,Ee,Se,ze],c:[Oe,F]}=(0,d.A)(s,[Be("eo-display-canvas",{styleTexts:[x.A,O.A]})],[[Le({attribute:!1}),1,"cells"],[Le({type:String}),1,"layout"],[Le({attribute:!1}),1,"layoutOptions"],[Le({attribute:!1}),1,"defaultNodeSize"],[Le({attribute:!1}),1,"defaultNodeBricks"],[Le({type:Number}),1,"degradedThreshold"],[Le({attribute:!1}),1,"degradedNodeLabel"],[Le({attribute:!1}),1,"defaultEdgeLines"],[Le({attribute:!1}),1,"activeTarget"],[Le({type:Boolean}),1,"fadeUnrelatedCells"],[Le({type:Boolean}),1,"zoomable"],[Le({type:Boolean}),1,"scrollable"],[Le({type:Boolean}),1,"pannable"],[Le({attribute:!1}),1,"scaleRange"],[Le({type:Boolean}),1,"hideZoomBar"],[Le({type:Boolean}),1,"autoCenterWhenCellsChange"],[Le(),1,"doNotResetActiveTargetForSelector"],[Le({type:Boolean}),1,"doNotResetActiveTargetOutsideCanvas"],[xe({type:"activeTarget.change"}),1,"activeTargetChangeEvent",e=>(0,h.A)(et,e),(e,t)=>(0,r.A)(et,e,t)],[xe({type:"cell.contextmenu"}),1,"cellContextMenu",e=>(0,h.A)(lt,e),(e,t)=>(0,r.A)(lt,e,t)],[xe({type:"cell.click"}),1,"cellClick",e=>(0,h.A)(ot,e),(e,t)=>(0,r.A)(ot,e,t)]],0,(e=>nt.has((0,o.A)(e))),A.ReactNextElement)),F()}}]);
2
+ //# sourceMappingURL=eo-display-canvas.c4f21ed5.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"chunks/eo-display-canvas.37483d85.js","mappings":"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","sources":["webpack:///./src/display-canvas/index.tsx"],"sourcesContent":["import React, {\n useCallback,\n useEffect,\n useMemo,\n useReducer,\n useRef,\n useState,\n} from \"react\";\nimport { createDecorators, type EventEmitter } from \"@next-core/element\";\nimport { ReactNextElement } from \"@next-core/react-element\";\nimport \"@next-core/theme\";\nimport { uniqueId } from \"lodash\";\nimport classNames from \"classnames\";\nimport { select } from \"d3-selection\";\nimport type { RangeTuple, SizeTuple } from \"../diagram/interfaces\";\nimport type {\n ActiveTarget,\n InitialCell,\n NodeBrickConf,\n CellContextMenuDetail,\n EdgeLineConf,\n Cell,\n LayoutType,\n LayoutOptions,\n} from \"../draw-canvas/interfaces\";\nimport { MarkerComponent } from \"../diagram/MarkerComponent\";\nimport { sameTarget } from \"../draw-canvas/processors/sameTarget\";\nimport { CellComponent } from \"../draw-canvas/CellComponent\";\nimport { initializeCells } from \"../draw-canvas/processors/initializeCells\";\nimport {\n DEFAULT_DEGRADED_THRESHOLD,\n DEFAULT_NODE_SIZE,\n} from \"../draw-canvas/constants\";\nimport { useZoom } from \"../shared/canvas/useZoom\";\nimport { useActiveTarget } from \"../shared/canvas/useActiveTarget\";\nimport { rootReducer } from \"../draw-canvas/reducers\";\nimport { getUnrelatedCells } from \"../draw-canvas/processors/getUnrelatedCells\";\nimport { isEdgeCell, isNodeCell } from \"../draw-canvas/processors/asserts\";\nimport { ZoomBarComponent } from \"../shared/canvas/ZoomBarComponent\";\nimport { useLayout } from \"../shared/canvas/useLayout\";\nimport { useReady } from \"../shared/canvas/useReady\";\nimport { useLineMarkers } from \"../shared/canvas/useLineMarkers\";\nimport { updateCells } from \"../draw-canvas/processors/updateCells\";\nimport styleText from \"../shared/canvas/styles.shadow.css\";\nimport zoomBarStyleText from \"../shared/canvas/ZoomBarComponent.shadow.css\";\nimport { useEditableLineMap } from \"../shared/canvas/useEditableLineMap\";\n\nconst { defineElement, property, event } = createDecorators();\n\nexport interface EoDisplayCanvasProps {\n cells: InitialCell[] | undefined;\n layout: LayoutType;\n layoutOptions?: LayoutOptions;\n defaultNodeSize: SizeTuple;\n defaultNodeBricks?: NodeBrickConf[];\n defaultEdgeLines?: EdgeLineConf[];\n degradedThreshold?: number;\n degradedNodeLabel?: string;\n activeTarget?: ActiveTarget | null;\n fadeUnrelatedCells?: boolean;\n zoomable?: boolean;\n scrollable?: boolean;\n pannable?: boolean;\n scaleRange?: RangeTuple;\n hideZoomBar?: boolean;\n autoCenterWhenCellsChange?: boolean;\n doNotResetActiveTargetForSelector?: string;\n doNotResetActiveTargetOutsideCanvas?: boolean;\n}\n\n/**\n * 用于展示查看的画布。\n */\nexport\n@defineElement(\"eo-display-canvas\", {\n styleTexts: [styleText, zoomBarStyleText],\n})\nclass EoDisplayCanvas extends ReactNextElement implements EoDisplayCanvasProps {\n /**\n * 用于查看的画布可以更新 `cells` 属性。\n */\n @property({ attribute: false })\n accessor cells: InitialCell[] | undefined;\n\n @property({ type: String })\n accessor layout: LayoutType;\n\n @property({ attribute: false })\n accessor layoutOptions: LayoutOptions | undefined;\n\n @property({ attribute: false })\n accessor defaultNodeSize: SizeTuple = [DEFAULT_NODE_SIZE, DEFAULT_NODE_SIZE];\n\n @property({ attribute: false })\n accessor defaultNodeBricks: NodeBrickConf[] | undefined;\n\n /**\n * 当节点数量达到或超过 `degradedThreshold` 时,节点将被降级展示。\n *\n * @default 500\n */\n @property({ type: Number })\n accessor degradedThreshold: number | undefined;\n\n // Set `attribute` to `false` event if it accepts string value.\n // Because when passing like \"<% DATA.node.data.name %>\", it will be\n // evaluated as object temporarily.\n /**\n * 设置节点将降级展示时显示的名称。\n *\n * @default \"<% DATA.node.id %>\"\n */\n @property({ attribute: false })\n accessor degradedNodeLabel: string | undefined;\n\n /**\n * 使用条件判断设置默认的边对应的连线。在 `if` 表达式中 `DATA` 为 `{ edge }`,例如:\n *\n * ```yaml\n * defaultEdgeLines:\n * - if: <% DATA.edge.data?.virtual %>\n * dashed: true\n * ```\n */\n @property({ attribute: false })\n accessor defaultEdgeLines: EdgeLineConf[] | undefined;\n\n @property({ attribute: false })\n accessor activeTarget: ActiveTarget | null | undefined;\n\n /**\n * 当鼠标悬浮到某节点上时,隐藏其他跟该节点无关的元素。\n */\n @property({ type: Boolean })\n accessor fadeUnrelatedCells: boolean | undefined;\n\n @property({ type: Boolean })\n accessor zoomable: boolean | undefined = true;\n\n @property({ type: Boolean })\n accessor scrollable: boolean | undefined = true;\n\n @property({ type: Boolean })\n accessor pannable: boolean | undefined = true;\n\n @property({ attribute: false })\n accessor scaleRange: RangeTuple | undefined;\n\n /**\n * 隐藏右下角放大缩小的控制栏\n */\n @property({ type: Boolean })\n accessor hideZoomBar: boolean | undefined;\n\n /**\n * 每当 cells 改变时,重新自动居中\n */\n @property({ type: Boolean })\n accessor autoCenterWhenCellsChange: boolean | undefined;\n\n /**\n * 选择器,点击该选择器对应的元素时不重置 `activeTarget`。\n */\n @property()\n accessor doNotResetActiveTargetForSelector: string | undefined;\n\n /**\n * 在画布外点击时不重置 `activeTarget`。\n */\n @property({ type: Boolean })\n accessor doNotResetActiveTargetOutsideCanvas: boolean | undefined;\n\n @event({ type: \"activeTarget.change\" })\n accessor #activeTargetChangeEvent!: EventEmitter<ActiveTarget | null>;\n\n #handleActiveTargetChange = (target: ActiveTarget | null) => {\n this.#activeTargetChangeEvent.emit(target);\n };\n\n #handleSwitchActiveTarget = (target: ActiveTarget | null) => {\n if (!sameTarget(target, this.activeTarget)) {\n this.activeTarget = target;\n }\n };\n\n @event({ type: \"cell.contextmenu\" })\n accessor #cellContextMenu!: EventEmitter<CellContextMenuDetail>;\n\n #handleCellContextMenu = (detail: CellContextMenuDetail) => {\n this.#cellContextMenu.emit(detail);\n };\n\n @event({ type: \"cell.click\" })\n accessor #cellClick!: EventEmitter<CellContextMenuDetail>;\n\n #handleCellClick = (detail: CellContextMenuDetail) => {\n this.#cellClick.emit(detail);\n };\n\n render() {\n return (\n <EoDisplayCanvasComponent\n shadowRoot={this.shadowRoot!}\n cells={this.cells}\n layout={this.layout}\n layoutOptions={this.layoutOptions}\n defaultNodeSize={this.defaultNodeSize}\n defaultNodeBricks={this.defaultNodeBricks}\n defaultEdgeLines={this.defaultEdgeLines}\n degradedThreshold={this.degradedThreshold}\n degradedNodeLabel={this.degradedNodeLabel}\n activeTarget={this.activeTarget}\n fadeUnrelatedCells={this.fadeUnrelatedCells}\n zoomable={this.zoomable}\n scrollable={this.scrollable}\n pannable={this.pannable}\n scaleRange={this.scaleRange}\n hideZoomBar={this.hideZoomBar}\n doNotResetActiveTargetForSelector={\n this.doNotResetActiveTargetForSelector\n }\n doNotResetActiveTargetOutsideCanvas={\n this.doNotResetActiveTargetOutsideCanvas\n }\n autoCenterWhenCellsChange={this.autoCenterWhenCellsChange}\n onActiveTargetChange={this.#handleActiveTargetChange}\n onSwitchActiveTarget={this.#handleSwitchActiveTarget}\n onCellContextMenu={this.#handleCellContextMenu}\n onCellClick={this.#handleCellClick}\n />\n );\n }\n}\n\nexport interface EoDisplayCanvasComponentProps extends EoDisplayCanvasProps {\n shadowRoot: ShadowRoot;\n onActiveTargetChange(target: ActiveTarget | null): void;\n onSwitchActiveTarget(target: ActiveTarget | null): void;\n onCellContextMenu(detail: CellContextMenuDetail): void;\n onCellClick(detail: CellContextMenuDetail): void;\n}\n\nfunction EoDisplayCanvasComponent({\n shadowRoot,\n cells: initialCells,\n layout,\n layoutOptions,\n defaultNodeSize,\n defaultNodeBricks,\n defaultEdgeLines,\n degradedThreshold,\n degradedNodeLabel,\n activeTarget: _activeTarget,\n fadeUnrelatedCells,\n zoomable,\n scrollable,\n pannable,\n scaleRange: _scaleRange,\n hideZoomBar,\n autoCenterWhenCellsChange,\n doNotResetActiveTargetForSelector,\n doNotResetActiveTargetOutsideCanvas,\n onActiveTargetChange,\n onSwitchActiveTarget,\n onCellContextMenu,\n onCellClick,\n}: EoDisplayCanvasComponentProps) {\n const [{ cells, layoutKey }, dispatch] = useReducer(\n rootReducer,\n initialCells,\n (initialCells) => ({\n cells: initializeCells(initialCells, { defaultNodeSize }),\n layoutKey: 1,\n })\n );\n\n // When nodes are greater or equal to threshold, the diagram will be degraded.\n // Thus all nodes will be displayed as simple svg elements instead of bricks.\n const degraded = useMemo(\n () =>\n cells.filter(isNodeCell).length >=\n (degradedThreshold ?? DEFAULT_DEGRADED_THRESHOLD),\n [cells, degradedThreshold]\n );\n\n const rootRef = useRef<SVGSVGElement>(null);\n\n const { grabbing, transform, zoomer, scaleRange } = useZoom({\n rootRef,\n zoomable,\n scrollable,\n pannable,\n draggable: true,\n scaleRange: _scaleRange,\n onSwitchActiveTarget,\n });\n\n const { centered, setCentered, getNextLayoutKey } = useLayout({\n layout,\n layoutOptions,\n rootRef,\n cells,\n zoomable,\n zoomer,\n scaleRange,\n layoutKey,\n autoCenterWhenCellsChange,\n dispatch,\n });\n\n const reCenter = useCallback(() => {\n setCentered(false);\n }, [setCentered]);\n\n const previousCellsRef = useRef(initialCells);\n\n useEffect(() => {\n if (initialCells !== previousCellsRef.current) {\n previousCellsRef.current = initialCells;\n const result = updateCells({\n canvasWidth: shadowRoot.host.clientWidth,\n canvasHeight: shadowRoot.host.clientHeight,\n defaultNodeSize,\n layout,\n previousCells: cells,\n cells: initialCells,\n scaleRange,\n transform,\n });\n dispatch({ type: \"update-cells\", payload: result.cells });\n }\n }, [\n cells,\n defaultNodeSize,\n initialCells,\n layout,\n scaleRange,\n shadowRoot,\n transform,\n ]);\n\n const activeTarget = useActiveTarget({\n rootRef,\n activeTarget: _activeTarget,\n doNotResetActiveTargetForSelector,\n doNotResetActiveTargetOutsideCanvas,\n onActiveTargetChange,\n });\n\n const defPrefix = useMemo(() => `${uniqueId(\"diagram-\")}-`, []);\n const markerPrefix = `${defPrefix}line-arrow-`;\n\n const handleNodeBrickResize = useCallback(\n (id: string, size: SizeTuple | null) => {\n dispatch({\n type: \"update-node-size\",\n payload: { id, size },\n layoutKey: getNextLayoutKey(),\n });\n },\n [getNextLayoutKey]\n );\n\n const [hoverCell, setHoverCell] = useState<Cell | null>(null);\n const handleCellMouseEnter = useCallback((cell: Cell) => {\n setHoverCell(cell);\n }, []);\n const handleCellMouseLeave = useCallback((cell: Cell) => {\n setHoverCell((prev) => (prev === cell ? null : prev));\n }, []);\n\n const [unrelatedCells, setUnrelatedCells] = useState<Cell[]>([]);\n useEffect(() => {\n const nextUnrelated = fadeUnrelatedCells\n ? getUnrelatedCells(cells, null, hoverCell)\n : [];\n // Do not update the state when prev and next are both empty.\n setUnrelatedCells((prev) =>\n prev.length === 0 && nextUnrelated.length === 0 ? prev : nextUnrelated\n );\n }, [cells, fadeUnrelatedCells, hoverCell]);\n\n const handleZoomSlide = useCallback(\n (value: number) => {\n // istanbul ignore next\n if (process.env.NODE_ENV !== \"test\") {\n zoomer.scaleTo(select(rootRef.current!), value / 100);\n }\n },\n [zoomer]\n );\n\n const { lineConfMap, markers } = useLineMarkers({\n cells,\n defaultEdgeLines,\n markerPrefix,\n });\n const editableLineMap = useEditableLineMap({ cells, lineConfMap });\n\n const ready = useReady({ cells, layout, centered });\n\n return (\n <>\n <svg\n width=\"100%\"\n height=\"100%\"\n ref={rootRef}\n className={classNames(\"root\", { grabbing, pannable, ready })}\n tabIndex={-1}\n >\n <defs>\n {markers.map((marker, index) => (\n <MarkerComponent\n key={index}\n id={`${markerPrefix}${index}`}\n type={marker.markerType}\n strokeColor={marker.strokeColor}\n />\n ))}\n </defs>\n <g\n transform={`translate(${transform.x} ${transform.y}) scale(${transform.k})`}\n >\n <g className=\"cells\">\n {cells.map((cell) => (\n <CellComponent\n key={`${cell.type}:${isEdgeCell(cell) ? `${cell.source}~${cell.target}` : cell.id}`}\n layout={layout}\n cell={cell}\n cells={cells}\n degraded={degraded}\n degradedNodeLabel={degradedNodeLabel}\n defaultNodeBricks={defaultNodeBricks}\n lineConfMap={lineConfMap}\n editableLineMap={editableLineMap}\n transform={transform}\n activeTarget={activeTarget}\n readOnly\n hoverCell={hoverCell}\n unrelatedCells={unrelatedCells}\n onSwitchActiveTarget={onSwitchActiveTarget}\n onCellContextMenu={onCellContextMenu}\n onCellClick={onCellClick}\n onNodeBrickResize={handleNodeBrickResize}\n onCellMouseEnter={\n fadeUnrelatedCells && (isNodeCell(cell) || isEdgeCell(cell))\n ? handleCellMouseEnter\n : undefined\n }\n onCellMouseLeave={\n fadeUnrelatedCells && (isNodeCell(cell) || isEdgeCell(cell))\n ? handleCellMouseLeave\n : undefined\n }\n />\n ))}\n </g>\n </g>\n </svg>\n {!hideZoomBar && (\n <ZoomBarComponent\n shadowRoot={shadowRoot}\n scale={transform.k}\n scaleRange={scaleRange}\n onZoomChange={handleZoomSlide}\n onReCenter={reCenter}\n />\n )}\n </>\n );\n}\n"],"names":["defineElement","property","event","createDecorators","_EoDisplayCanvas","_A","WeakMap","_B","_C","_D","_E","_F","_G","_H","_I","_J","_K","_L","_M","_N","_O","_P","_Q","_R","_S","_EoDisplayCanvas_brand","WeakSet","_handleActiveTargetChange","_handleSwitchActiveTarget","_T","_handleCellContextMenu","_U","_handleCellClick","EoDisplayCanvas","ReactNextElement","constructor","arguments","_classPrivateMethodInitSpec","_classPrivateFieldInitSpec","_init_cells","_init_extra_cells","_init_layout","_init_extra_layout","_init_layoutOptions","_init_extra_layoutOptions","_init_defaultNodeSize","DEFAULT_NODE_SIZE","_init_extra_defaultNodeSize","_init_defaultNodeBricks","_init_extra_defaultNodeBricks","_init_degradedThreshold","_init_extra_degradedThreshold","_init_degradedNodeLabel","_init_extra_degradedNodeLabel","_init_defaultEdgeLines","_init_extra_defaultEdgeLines","_init_activeTarget","_init_extra_activeTarget","_init_fadeUnrelatedCells","_init_extra_fadeUnrelatedCells","_init_zoomable","_init_extra_zoomable","_init_scrollable","_init_extra_scrollable","_init_pannable","_init_extra_pannable","_init_scaleRange","_init_extra_scaleRange","_init_hideZoomBar","_init_extra_hideZoomBar","_init_autoCenterWhenCellsChange","_init_extra_autoCenterWhenCellsChange","_init_doNotResetActiveTargetForSelector","_init_extra_doNotResetActiveTargetForSelector","_init_doNotResetActiveTargetOutsideCanvas","_init_extra_doNotResetActiveTargetOutsideCanvas","_init_activeTargetChangeEvent","_init_extra_activeTargetChangeEvent","target","_classPrivateGetter","this","_get_activeTargetChangeEvent","emit","sameTarget","activeTarget","_init_cellContextMenu","_init_extra_cellContextMenu","detail","_get_cellContextMenu","_init_cellClick","_init_extra_cellClick","_get_cellClick","cells","_classPrivateFieldGet","v","_classPrivateFieldSet","layout","layoutOptions","defaultNodeSize","defaultNodeBricks","degradedThreshold","degradedNodeLabel","defaultEdgeLines","fadeUnrelatedCells","zoomable","scrollable","pannable","scaleRange","hideZoomBar","autoCenterWhenCellsChange","doNotResetActiveTargetForSelector","doNotResetActiveTargetOutsideCanvas","render","React","EoDisplayCanvasComponent","shadowRoot","onActiveTargetChange","onSwitchActiveTarget","onCellContextMenu","onCellClick","_ref","initialCells","_activeTarget","_scaleRange","layoutKey","dispatch","useReducer","rootReducer","initializeCells","degraded","useMemo","filter","isNodeCell","length","DEFAULT_DEGRADED_THRESHOLD","rootRef","useRef","grabbing","transform","zoomer","useZoom","draggable","centered","setCentered","getNextLayoutKey","useLayout","reCenter","useCallback","previousCellsRef","useEffect","current","result","updateCells","canvasWidth","host","clientWidth","canvasHeight","clientHeight","previousCells","type","payload","useActiveTarget","markerPrefix","uniqueId","handleNodeBrickResize","id","size","hoverCell","setHoverCell","useState","handleCellMouseEnter","cell","handleCellMouseLeave","prev","unrelatedCells","setUnrelatedCells","nextUnrelated","getUnrelatedCells","handleZoomSlide","value","scaleTo","select","lineConfMap","markers","useLineMarkers","editableLineMap","useEditableLineMap","ready","useReady","width","height","ref","className","classNames","tabIndex","map","marker","index","MarkerComponent","key","markerType","strokeColor","x","y","k","CellComponent","isEdgeCell","source","readOnly","onNodeBrickResize","onCellMouseEnter","undefined","onCellMouseLeave","ZoomBarComponent","scale","onZoomChange","onReCenter","_EoDisplayCanvas2","e","_set_activeTargetChangeEvent","_set_cellContextMenu","_set_cellClick","c","_initClass","_applyDecs","styleTexts","styleText","zoomBarStyleText","attribute","String","Number","Boolean","o","_","has","_checkInRHS"],"sourceRoot":""}
1
+ {"version":3,"file":"chunks/eo-display-canvas.c4f21ed5.js","mappings":"yoBA+CA,MAAM,cAAEA,GAAa,SAAEC,GAAQ,MAAEC,KAAUC,EAAAA,EAAAA,oBAAmB,IAAAC,GAAA,IAAAC,GAAA,IAAAC,QAAAC,GAAA,IAAAD,QAAAE,GAAA,IAAAF,QAAAG,GAAA,IAAAH,QAAAI,GAAA,IAAAJ,QAAAK,GAAA,IAAAL,QAAAM,GAAA,IAAAN,QAAAO,GAAA,IAAAP,QAAAQ,GAAA,IAAAR,QAAAS,GAAA,IAAAT,QAAAU,GAAA,IAAAV,QAAAW,GAAA,IAAAX,QAAAY,GAAA,IAAAZ,QAAAa,GAAA,IAAAb,QAAAc,GAAA,IAAAd,QAAAe,GAAA,IAAAf,QAAAgB,GAAA,IAAAhB,QAAAiB,GAAA,IAAAjB,QAAAkB,GAAA,IAAAlB,QAAAmB,GAAA,IAAAC,QAAAC,GAAA,IAAArB,QAAAsB,GAAA,IAAAtB,QAAAuB,GAAA,IAAAvB,QAAAwB,GAAA,IAAAxB,QAAAyB,GAAA,IAAAzB,QAAA0B,GAAA,IAAA1B,QA2B9D,MAAA2B,WAG8BC,EAAAA,iBAAiDC,WAAAA,GAAA,SAAAC,YAAAC,EAAAA,EAAAA,GAAA,KAAAZ,KAC7Ea,EAAAA,EAAAA,GAAA,KAAAjC,GAAAkC,EAAA,QAAAD,EAAAA,EAAAA,GAAA,KAAA/B,IAAAiC,EAAA,MAAAC,EAAA,SAAAH,EAAAA,EAAAA,GAAA,KAAA9B,IAAAkC,EAAA,MAAAC,EAAA,SAAAL,EAAAA,EAAAA,GAAA,KAAA7B,IAAAmC,EAAA,MAAAC,EAAA,KAasC,CAACC,EAAAA,GAAmBA,EAAAA,QAAkBR,EAAAA,EAAAA,GAAA,KAAA5B,IAAAqC,EAAA,MAAAC,EAAA,SAK5EV,EAAAA,EAAAA,GAAA,KAAA3B,IAAAsC,EAAA,MAAAC,EAAA,SAWAZ,EAAAA,EAAAA,GAAA,KAAA1B,IAAAuC,EAAA,MAAAC,EAAA,SAQAd,EAAAA,EAAAA,GAAA,KAAAzB,IAAAwC,EAAA,MAAAC,EAAA,SAAAhB,EAAAA,EAAAA,GAAA,KAAAxB,IAAAyC,EAAA,MAAAC,GAAA,SAeAlB,EAAAA,EAAAA,GAAA,KAAAvB,IAAA0C,GAAA,MAAAC,GAAA,SAAApB,EAAAA,EAAAA,GAAA,KAAAtB,IAAA2C,GAAA,MAAAC,GAAA,MAOyC,MAAItB,EAAAA,EAAAA,GAAA,KAAArB,IAAA4C,GAAA,MAAAC,GAAA,MAGF,MAAIxB,EAAAA,EAAAA,GAAA,KAAApB,IAAA6C,GAAA,MAAAC,GAAA,MAGN,MAAI1B,EAAAA,EAAAA,GAAA,KAAAnB,IAAA8C,GAAA,MAAAC,GAAA,SAK7C5B,EAAAA,EAAAA,GAAA,KAAAlB,IAAA+C,GAAA,MAAAC,GAAA,SAMA9B,EAAAA,EAAAA,GAAA,KAAAjB,IAAAgD,GAAA,MAAAC,GAAA,SAMAhC,EAAAA,EAAAA,GAAA,KAAAhB,IAAAiD,GAAA,MAAAC,GAAA,SAMAlC,EAAAA,EAAAA,GAAA,KAAAf,IAAAkD,GAAA,MAAAC,GAAA,SAAApC,EAAAA,EAAAA,GAAA,KAAAd,IAAAmD,GAAA,MAAAC,GAAA,SASAtC,EAAAA,EAAAA,GAAA,KAAAX,IAAyBkD,GAAA,MAAIC,KAC3BC,EAAAA,EAAAA,GAAAtD,GAAAuD,KAAKC,IAAyBC,KAAKJ,EAAO,KAG5CxC,EAAAA,EAAAA,GAAA,KAAAV,IAA6BkD,KACtBK,EAAAA,EAAAA,GAAWL,EAAQE,KAAKI,gBAC3BJ,KAAKI,aAAeN,EACtB,KACAxC,EAAAA,EAAAA,GAAA,KAAAT,GAAAwD,GAAA,QAKF/C,EAAAA,EAAAA,GAAA,KAAAR,IAAsBwD,GAAA,MAAIC,KACxBR,EAAAA,EAAAA,GAAAtD,GAAAuD,KAAKQ,IAAiBN,KAAKK,EAAO,KAClCjD,EAAAA,EAAAA,GAAA,KAAAP,GAAA0D,GAAA,QAKFnD,EAAAA,EAAAA,GAAA,KAAAN,IAAgB0D,GAAA,MAAIH,KAClBR,EAAAA,EAAAA,GAAAtD,GAAAuD,KAAKW,IAAWT,KAAKK,EAAO,GAC5B,UAnHOK,GAAK,OAAAC,EAAAA,EAAAA,GAAAxF,GAAA,eAALuF,CAAKE,IAAAC,EAAAA,EAAAA,GAAA1F,GAAA,KAAAyF,EAAA,WAGLE,GAAM,OAAAH,EAAAA,EAAAA,GAAAtF,GAAA,gBAANyF,CAAMF,IAAAC,EAAAA,EAAAA,GAAAxF,GAAA,KAAAuF,EAAA,kBAGNG,GAAa,OAAAJ,EAAAA,EAAAA,GAAArF,GAAA,uBAAbyF,CAAaH,IAAAC,EAAAA,EAAAA,GAAAvF,GAAA,KAAAsF,EAAA,oBAGbI,GAAe,OAAAL,EAAAA,EAAAA,GAAApF,GAAA,yBAAfyF,CAAeJ,IAAAC,EAAAA,EAAAA,GAAAtF,GAAA,KAAAqF,EAAA,sBAGfK,GAAiB,OAAAN,EAAAA,EAAAA,GAAAnF,GAAA,2BAAjByF,CAAiBL,IAAAC,EAAAA,EAAAA,GAAArF,GAAA,KAAAoF,EAAA,sBAQjBM,GAAiB,OAAAP,EAAAA,EAAAA,GAAAlF,GAAA,2BAAjByF,CAAiBN,IAAAC,EAAAA,EAAAA,GAAApF,GAAA,KAAAmF,EAAA,sBAWjBO,GAAiB,OAAAR,EAAAA,EAAAA,GAAAjF,GAAA,2BAAjByF,CAAiBP,IAAAC,EAAAA,EAAAA,GAAAnF,GAAA,KAAAkF,EAAA,qBAYjBQ,GAAgB,OAAAT,EAAAA,EAAAA,GAAAhF,GAAA,0BAAhByF,CAAgBR,IAAAC,EAAAA,EAAAA,GAAAlF,GAAA,KAAAiF,EAAA,iBAGhBV,GAAY,OAAAS,EAAAA,EAAAA,GAAA/E,GAAA,sBAAZsE,CAAYU,IAAAC,EAAAA,EAAAA,GAAAjF,GAAA,KAAAgF,EAAA,uBAMZS,GAAkB,OAAAV,EAAAA,EAAAA,GAAA9E,GAAA,4BAAlBwF,CAAkBT,IAAAC,EAAAA,EAAAA,GAAAhF,GAAA,KAAA+E,EAAA,aAGlBU,GAAQ,OAAAX,EAAAA,EAAAA,GAAA7E,GAAA,kBAARwF,CAAQV,IAAAC,EAAAA,EAAAA,GAAA/E,GAAA,KAAA8E,EAAA,eAGRW,GAAU,OAAAZ,EAAAA,EAAAA,GAAA5E,GAAA,oBAAVwF,CAAUX,IAAAC,EAAAA,EAAAA,GAAA9E,GAAA,KAAA6E,EAAA,aAGVY,GAAQ,OAAAb,EAAAA,EAAAA,GAAA3E,GAAA,kBAARwF,CAAQZ,IAAAC,EAAAA,EAAAA,GAAA7E,GAAA,KAAA4E,EAAA,eAGRa,GAAU,OAAAd,EAAAA,EAAAA,GAAA1E,GAAA,oBAAVwF,CAAUb,IAAAC,EAAAA,EAAAA,GAAA5E,GAAA,KAAA2E,EAAA,gBAMVc,GAAW,OAAAf,EAAAA,EAAAA,GAAAzE,GAAA,qBAAXwF,CAAWd,IAAAC,EAAAA,EAAAA,GAAA3E,GAAA,KAAA0E,EAAA,8BAMXe,GAAyB,OAAAhB,EAAAA,EAAAA,GAAAxE,GAAA,mCAAzBwF,CAAyBf,IAAAC,EAAAA,EAAAA,GAAA1E,GAAA,KAAAyE,EAAA,sCAMzBgB,GAAiC,OAAAjB,EAAAA,EAAAA,GAAAvE,GAAA,2CAAjCwF,CAAiChB,IAAAC,EAAAA,EAAAA,GAAAzE,GAAA,KAAAwE,EAAA,wCAMjCiB,GAAmC,OAAAlB,EAAAA,EAAAA,GAAAtE,GAAA,6CAAnCwF,CAAmCjB,IAAAC,EAAAA,EAAAA,GAAAxE,GAAA,KAAAuE,EAAA,CA6B5CkB,MAAAA,GACE,OACEC,IAAAA,cAACC,GAAwB,CACvBC,WAAYnC,KAAKmC,WACjBvB,MAAOZ,KAAKY,MACZI,OAAQhB,KAAKgB,OACbC,cAAejB,KAAKiB,cACpBC,gBAAiBlB,KAAKkB,gBACtBC,kBAAmBnB,KAAKmB,kBACxBG,iBAAkBtB,KAAKsB,iBACvBF,kBAAmBpB,KAAKoB,kBACxBC,kBAAmBrB,KAAKqB,kBACxBjB,aAAcJ,KAAKI,aACnBmB,mBAAoBvB,KAAKuB,mBACzBC,SAAUxB,KAAKwB,SACfC,WAAYzB,KAAKyB,WACjBC,SAAU1B,KAAK0B,SACfC,WAAY3B,KAAK2B,WACjBC,YAAa5B,KAAK4B,YAClBE,kCACE9B,KAAK8B,kCAEPC,oCACE/B,KAAK+B,oCAEPF,0BAA2B7B,KAAK6B,0BAChCO,sBAAsBvB,EAAAA,EAAAA,GAAKlE,GAALqD,MACtBqC,sBAAsBxB,EAAAA,EAAAA,GAAKjE,GAALoD,MACtBsC,mBAAmBzB,EAAAA,EAAAA,GAAK/D,GAALkD,MACnBuC,aAAa1B,EAAAA,EAAAA,GAAK7D,GAALgD,OAGnB,EAWF,SAASkC,GAAwBM,GAwBC,IAxBA,WAChCL,EACAvB,MAAO6B,EAAY,OACnBzB,EAAM,cACNC,EAAa,gBACbC,EAAe,kBACfC,EAAiB,iBACjBG,EAAgB,kBAChBF,EAAiB,kBACjBC,EACAjB,aAAcsC,EAAa,mBAC3BnB,EAAkB,SAClBC,EAAQ,WACRC,EAAU,SACVC,EACAC,WAAYgB,EAAW,YACvBf,EAAW,0BACXC,EAAyB,kCACzBC,EAAiC,oCACjCC,EAAmC,qBACnCK,EAAoB,qBACpBC,EAAoB,kBACpBC,EAAiB,YACjBC,GAC8BC,EAC9B,OAAO,MAAE5B,EAAK,UAAEgC,GAAaC,IAAYC,EAAAA,EAAAA,YACvCC,EAAAA,EACAN,GACCA,IAAY,CACX7B,OAAOoC,EAAAA,EAAAA,GAAgBP,EAAc,CAAEvB,oBACvC0B,UAAW,MAMTK,GAAWC,EAAAA,EAAAA,UACf,IACEtC,EAAMuC,OAAOC,EAAAA,GAAYC,SACxBjC,QAAAA,EAAqBkC,EAAAA,KACxB,CAAC1C,EAAOQ,IAGJmC,GAAUC,EAAAA,EAAAA,QAAsB,OAEhC,SAAEC,EAAQ,UAAEC,EAAS,OAAEC,EAAM,WAAEhC,IAAeiC,EAAAA,EAAAA,GAAQ,CAC1DL,UACA/B,WACAC,aACAC,WACAmC,WAAW,EACXlC,WAAYgB,EACZN,0BAGI,SAAEyB,EAAQ,YAAEC,GAAW,iBAAEC,KAAqBC,EAAAA,EAAAA,GAAU,CAC5DjD,SACAC,gBACAsC,UACA3C,QACAY,WACAmC,SACAhC,aACAiB,YACAf,4BACAgB,aAGIqB,IAAWC,EAAAA,EAAAA,cAAY,KAC3BJ,IAAY,EAAM,GACjB,CAACA,KAEEK,IAAmBZ,EAAAA,EAAAA,QAAOf,IAEhC4B,EAAAA,EAAAA,YAAU,KACR,GAAI5B,IAAiB2B,GAAiBE,QAAS,CAC7CF,GAAiBE,QAAU7B,EAC3B,MAAM8B,GAASC,EAAAA,EAAAA,GAAY,CACzBC,YAAatC,EAAWuC,KAAKC,YAC7BC,aAAczC,EAAWuC,KAAKG,aAC9B3D,kBACAF,SACA8D,cAAelE,EACfA,MAAO6B,EACPd,aACA+B,cAEFb,EAAS,CAAEkC,KAAM,eAAgBC,QAAST,EAAO3D,OACnD,IACC,CACDA,EACAM,EACAuB,EACAzB,EACAW,EACAQ,EACAuB,IAGF,MAAMtD,IAAe6E,EAAAA,EAAAA,GAAgB,CACnC1B,UACAnD,aAAcsC,EACdZ,oCACAC,sCACAK,yBAII8C,GAAe,IADHhC,EAAAA,EAAAA,UAAQ,IAAM,IAAGiC,EAAAA,EAAAA,UAAS,gBAAgB,iBAGtDC,IAAwBjB,EAAAA,EAAAA,cAC5B,CAACkB,EAAYC,KACXzC,EAAS,CACPkC,KAAM,mBACNC,QAAS,CAAEK,KAAIC,QACf1C,UAAWoB,MACX,GAEJ,CAACA,MAGIuB,GAAWC,KAAgBC,EAAAA,EAAAA,UAAsB,MAClDC,IAAuBvB,EAAAA,EAAAA,cAAawB,IACxCH,GAAaG,EAAK,GACjB,IACGC,IAAuBzB,EAAAA,EAAAA,cAAawB,IACxCH,IAAcK,GAAUA,IAASF,EAAO,KAAOE,GAAM,GACpD,KAEIC,GAAgBC,KAAqBN,EAAAA,EAAAA,UAAiB,KAC7DpB,EAAAA,EAAAA,YAAU,KACR,MAAM2B,EAAgBzE,GAClB0E,EAAAA,EAAAA,GAAkBrF,EAAO,KAAM2E,IAC/B,GAEJQ,IAAmBF,GACD,IAAhBA,EAAKxC,QAAyC,IAAzB2C,EAAc3C,OAAewC,EAAOG,GAC1D,GACA,CAACpF,EAAOW,EAAoBgE,KAE/B,MAAMW,IAAkB/B,EAAAA,EAAAA,cACrBgC,IAGGxC,EAAOyC,SAAQC,EAAAA,EAAAA,GAAO9C,EAAQe,SAAW6B,EAAQ,IACnD,GAEF,CAACxC,KAGG,YAAE2C,GAAW,QAAEC,KAAYC,EAAAA,EAAAA,GAAe,CAC9C5F,QACAU,mBACA4D,kBAEIuB,IAAkBC,EAAAA,EAAAA,GAAmB,CAAE9F,QAAO0F,iBAE9CK,IAAQC,EAAAA,EAAAA,GAAS,CAAEhG,QAAOI,SAAQ8C,aAExC,OACE7B,IAAAA,cAAAA,IAAAA,SAAA,KACEA,IAAAA,cAAA,OACE4E,MAAM,OACNC,OAAO,OACPC,IAAKxD,EACLyD,UAAWC,IAAW,OAAQ,CAAExD,WAAU/B,WAAUiF,WACpDO,UAAW,GAEXjF,IAAAA,cAAA,YACGsE,GAAQY,KAAI,CAACC,EAAQC,IACpBpF,IAAAA,cAACqF,EAAAA,EAAe,CACdC,IAAKF,EACLhC,GAAI,GAAGH,KAAemC,IACtBtC,KAAMqC,EAAOI,WACbC,YAAaL,EAAOK,iBAI1BxF,IAAAA,cAAA,KACEyB,UAAW,aAAaA,EAAUgE,KAAKhE,EAAUiE,YAAYjE,EAAUkE,MAEvE3F,IAAAA,cAAA,KAAG+E,UAAU,SACVpG,EAAMuG,KAAKxB,GACV1D,IAAAA,cAAC4F,EAAAA,EAAa,CACZN,IAAK,GAAG5B,EAAKZ,SAAQ+C,EAAAA,EAAAA,IAAWnC,GAAQ,GAAGA,EAAKoC,UAAUpC,EAAK7F,SAAW6F,EAAKN,KAC/ErE,OAAQA,EACR2E,KAAMA,EACN/E,MAAOA,EACPqC,SAAUA,EACV5B,kBAAmBA,EACnBF,kBAAmBA,EACnBmF,YAAaA,GACbG,gBAAiBA,GACjB/C,UAAWA,EACXtD,aAAcA,GACd4H,UAAQ,EACRzC,UAAWA,GACXO,eAAgBA,GAChBzD,qBAAsBA,EACtBC,kBAAmBA,EACnBC,YAAaA,EACb0F,kBAAmB7C,GACnB8C,iBACE3G,KAAuB6B,EAAAA,EAAAA,GAAWuC,KAASmC,EAAAA,EAAAA,IAAWnC,IAClDD,QACAyC,EAENC,iBACE7G,KAAuB6B,EAAAA,EAAAA,GAAWuC,KAASmC,EAAAA,EAAAA,IAAWnC,IAClDC,QACAuC,UAOdvG,GACAK,IAAAA,cAACoG,EAAAA,EAAgB,CACflG,WAAYA,EACZmG,MAAO5E,EAAUkE,EACjBjG,WAAYA,EACZ4G,aAAcrC,GACdsC,WAAYtE,KAKtB,CA9OCuE,EAAAxL,KAAAyL,GAAAnL,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAE,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAK,GAAA0I,GAAA9I,GAAAQ,GAAAG,GAAAoI,GAAAtI,GAAAG,GAAAE,GAAAkI,GAAAnI,IAAAoI,GAAA1N,GAAA2N,KAAAC,EAAAA,EAAAA,GAAAP,EAAA,CA9JAzN,GAAc,oBAAqB,CAClCiO,WAAY,CAACC,EAAAA,EAAWC,EAAAA,MACxB,EAKClO,GAAS,CAAEmO,WAAW,IAAQ,YAG9BnO,GAAS,CAAE8J,KAAMsE,SAAS,aAG1BpO,GAAS,CAAEmO,WAAW,IAAQ,oBAG9BnO,GAAS,CAAEmO,WAAW,IAAQ,sBAG9BnO,GAAS,CAAEmO,WAAW,IAAQ,wBAQ9BnO,GAAS,CAAE8J,KAAMuE,SAAS,wBAW1BrO,GAAS,CAAEmO,WAAW,IAAQ,wBAY9BnO,GAAS,CAAEmO,WAAW,IAAQ,uBAG9BnO,GAAS,CAAEmO,WAAW,IAAQ,mBAM9BnO,GAAS,CAAE8J,KAAMwE,UAAU,yBAG3BtO,GAAS,CAAE8J,KAAMwE,UAAU,eAG3BtO,GAAS,CAAE8J,KAAMwE,UAAU,iBAG3BtO,GAAS,CAAE8J,KAAMwE,UAAU,eAG3BtO,GAAS,CAAEmO,WAAW,IAAQ,iBAM9BnO,GAAS,CAAE8J,KAAMwE,UAAU,kBAM3BtO,GAAS,CAAE8J,KAAMwE,UAAU,gCAM3BtO,KAAU,wCAMVA,GAAS,CAAE8J,KAAMwE,UAAU,0CAG3BrO,GAAM,CAAE6J,KAAM,wBAAwB,4BAAAyE,IAAA3I,EAAAA,EAAAA,GAAArE,GAAAgN,GAAA,CAAAA,EAAA1I,KAAAC,EAAAA,EAAAA,GAAAvE,GAAAgN,EAAA1I,IAAA,CAatC5F,GAAM,CAAE6J,KAAM,qBAAqB,oBAAAyE,IAAA3I,EAAAA,EAAAA,GAAAhE,GAAA2M,GAAA,CAAAA,EAAA1I,KAAAC,EAAAA,EAAAA,GAAAlE,GAAA2M,EAAA1I,IAAA,CAOnC5F,GAAM,CAAE6J,KAAM,eAAe,cAAAyE,IAAA3I,EAAAA,EAAAA,GAAA9D,GAAAyM,GAAA,CAAAA,EAAA1I,KAAAC,EAAAA,EAAAA,GAAAhE,GAAAyM,EAAA1I,KAAA,GAAA2I,GAAAzM,GAAA0M,KAAAC,EAAAA,EAAAA,GAAAF,KAnHFvM,EAAAA,mBAAgB6L,G","sources":["webpack:///./src/display-canvas/index.tsx"],"sourcesContent":["import React, {\n useCallback,\n useEffect,\n useMemo,\n useReducer,\n useRef,\n useState,\n} from \"react\";\nimport { createDecorators, type EventEmitter } from \"@next-core/element\";\nimport { ReactNextElement } from \"@next-core/react-element\";\nimport \"@next-core/theme\";\nimport { uniqueId } from \"lodash\";\nimport classNames from \"classnames\";\nimport { select } from \"d3-selection\";\nimport type { RangeTuple, SizeTuple } from \"../diagram/interfaces\";\nimport type {\n ActiveTarget,\n InitialCell,\n NodeBrickConf,\n CellContextMenuDetail,\n EdgeLineConf,\n Cell,\n LayoutType,\n LayoutOptions,\n} from \"../draw-canvas/interfaces\";\nimport { MarkerComponent } from \"../diagram/MarkerComponent\";\nimport { sameTarget } from \"../draw-canvas/processors/sameTarget\";\nimport { CellComponent } from \"../draw-canvas/CellComponent\";\nimport { initializeCells } from \"../draw-canvas/processors/initializeCells\";\nimport {\n DEFAULT_DEGRADED_THRESHOLD,\n DEFAULT_NODE_SIZE,\n} from \"../draw-canvas/constants\";\nimport { useZoom } from \"../shared/canvas/useZoom\";\nimport { useActiveTarget } from \"../shared/canvas/useActiveTarget\";\nimport { rootReducer } from \"../draw-canvas/reducers\";\nimport { getUnrelatedCells } from \"../draw-canvas/processors/getUnrelatedCells\";\nimport { isEdgeCell, isNodeCell } from \"../draw-canvas/processors/asserts\";\nimport { ZoomBarComponent } from \"../shared/canvas/ZoomBarComponent\";\nimport { useLayout } from \"../shared/canvas/useLayout\";\nimport { useReady } from \"../shared/canvas/useReady\";\nimport { useLineMarkers } from \"../shared/canvas/useLineMarkers\";\nimport { updateCells } from \"../draw-canvas/processors/updateCells\";\nimport styleText from \"../shared/canvas/styles.shadow.css\";\nimport zoomBarStyleText from \"../shared/canvas/ZoomBarComponent.shadow.css\";\nimport { useEditableLineMap } from \"../shared/canvas/useEditableLineMap\";\n\nconst { defineElement, property, event } = createDecorators();\n\nexport interface EoDisplayCanvasProps {\n cells: InitialCell[] | undefined;\n layout: LayoutType;\n layoutOptions?: LayoutOptions;\n defaultNodeSize: SizeTuple;\n defaultNodeBricks?: NodeBrickConf[];\n defaultEdgeLines?: EdgeLineConf[];\n degradedThreshold?: number;\n degradedNodeLabel?: string;\n activeTarget?: ActiveTarget | null;\n fadeUnrelatedCells?: boolean;\n zoomable?: boolean;\n scrollable?: boolean;\n pannable?: boolean;\n scaleRange?: RangeTuple;\n hideZoomBar?: boolean;\n autoCenterWhenCellsChange?: boolean;\n doNotResetActiveTargetForSelector?: string;\n doNotResetActiveTargetOutsideCanvas?: boolean;\n}\n\n/**\n * 用于展示查看的画布。\n */\nexport\n@defineElement(\"eo-display-canvas\", {\n styleTexts: [styleText, zoomBarStyleText],\n})\nclass EoDisplayCanvas extends ReactNextElement implements EoDisplayCanvasProps {\n /**\n * 用于查看的画布可以更新 `cells` 属性。\n */\n @property({ attribute: false })\n accessor cells: InitialCell[] | undefined;\n\n @property({ type: String })\n accessor layout: LayoutType;\n\n @property({ attribute: false })\n accessor layoutOptions: LayoutOptions | undefined;\n\n @property({ attribute: false })\n accessor defaultNodeSize: SizeTuple = [DEFAULT_NODE_SIZE, DEFAULT_NODE_SIZE];\n\n @property({ attribute: false })\n accessor defaultNodeBricks: NodeBrickConf[] | undefined;\n\n /**\n * 当节点数量达到或超过 `degradedThreshold` 时,节点将被降级展示。\n *\n * @default 500\n */\n @property({ type: Number })\n accessor degradedThreshold: number | undefined;\n\n // Set `attribute` to `false` event if it accepts string value.\n // Because when passing like \"<% DATA.node.data.name %>\", it will be\n // evaluated as object temporarily.\n /**\n * 设置节点将降级展示时显示的名称。\n *\n * @default \"<% DATA.node.id %>\"\n */\n @property({ attribute: false })\n accessor degradedNodeLabel: string | undefined;\n\n /**\n * 使用条件判断设置默认的边对应的连线。在 `if` 表达式中 `DATA` 为 `{ edge }`,例如:\n *\n * ```yaml\n * defaultEdgeLines:\n * - if: <% DATA.edge.data?.virtual %>\n * dashed: true\n * ```\n */\n @property({ attribute: false })\n accessor defaultEdgeLines: EdgeLineConf[] | undefined;\n\n @property({ attribute: false })\n accessor activeTarget: ActiveTarget | null | undefined;\n\n /**\n * 当鼠标悬浮到某节点上时,隐藏其他跟该节点无关的元素。\n */\n @property({ type: Boolean })\n accessor fadeUnrelatedCells: boolean | undefined;\n\n @property({ type: Boolean })\n accessor zoomable: boolean | undefined = true;\n\n @property({ type: Boolean })\n accessor scrollable: boolean | undefined = true;\n\n @property({ type: Boolean })\n accessor pannable: boolean | undefined = true;\n\n @property({ attribute: false })\n accessor scaleRange: RangeTuple | undefined;\n\n /**\n * 隐藏右下角放大缩小的控制栏\n */\n @property({ type: Boolean })\n accessor hideZoomBar: boolean | undefined;\n\n /**\n * 每当 cells 改变时,重新自动居中\n */\n @property({ type: Boolean })\n accessor autoCenterWhenCellsChange: boolean | undefined;\n\n /**\n * 选择器,点击该选择器对应的元素时不重置 `activeTarget`。\n */\n @property()\n accessor doNotResetActiveTargetForSelector: string | undefined;\n\n /**\n * 在画布外点击时不重置 `activeTarget`。\n */\n @property({ type: Boolean })\n accessor doNotResetActiveTargetOutsideCanvas: boolean | undefined;\n\n @event({ type: \"activeTarget.change\" })\n accessor #activeTargetChangeEvent!: EventEmitter<ActiveTarget | null>;\n\n #handleActiveTargetChange = (target: ActiveTarget | null) => {\n this.#activeTargetChangeEvent.emit(target);\n };\n\n #handleSwitchActiveTarget = (target: ActiveTarget | null) => {\n if (!sameTarget(target, this.activeTarget)) {\n this.activeTarget = target;\n }\n };\n\n @event({ type: \"cell.contextmenu\" })\n accessor #cellContextMenu!: EventEmitter<CellContextMenuDetail>;\n\n #handleCellContextMenu = (detail: CellContextMenuDetail) => {\n this.#cellContextMenu.emit(detail);\n };\n\n @event({ type: \"cell.click\" })\n accessor #cellClick!: EventEmitter<CellContextMenuDetail>;\n\n #handleCellClick = (detail: CellContextMenuDetail) => {\n this.#cellClick.emit(detail);\n };\n\n render() {\n return (\n <EoDisplayCanvasComponent\n shadowRoot={this.shadowRoot!}\n cells={this.cells}\n layout={this.layout}\n layoutOptions={this.layoutOptions}\n defaultNodeSize={this.defaultNodeSize}\n defaultNodeBricks={this.defaultNodeBricks}\n defaultEdgeLines={this.defaultEdgeLines}\n degradedThreshold={this.degradedThreshold}\n degradedNodeLabel={this.degradedNodeLabel}\n activeTarget={this.activeTarget}\n fadeUnrelatedCells={this.fadeUnrelatedCells}\n zoomable={this.zoomable}\n scrollable={this.scrollable}\n pannable={this.pannable}\n scaleRange={this.scaleRange}\n hideZoomBar={this.hideZoomBar}\n doNotResetActiveTargetForSelector={\n this.doNotResetActiveTargetForSelector\n }\n doNotResetActiveTargetOutsideCanvas={\n this.doNotResetActiveTargetOutsideCanvas\n }\n autoCenterWhenCellsChange={this.autoCenterWhenCellsChange}\n onActiveTargetChange={this.#handleActiveTargetChange}\n onSwitchActiveTarget={this.#handleSwitchActiveTarget}\n onCellContextMenu={this.#handleCellContextMenu}\n onCellClick={this.#handleCellClick}\n />\n );\n }\n}\n\nexport interface EoDisplayCanvasComponentProps extends EoDisplayCanvasProps {\n shadowRoot: ShadowRoot;\n onActiveTargetChange(target: ActiveTarget | null): void;\n onSwitchActiveTarget(target: ActiveTarget | null): void;\n onCellContextMenu(detail: CellContextMenuDetail): void;\n onCellClick(detail: CellContextMenuDetail): void;\n}\n\nfunction EoDisplayCanvasComponent({\n shadowRoot,\n cells: initialCells,\n layout,\n layoutOptions,\n defaultNodeSize,\n defaultNodeBricks,\n defaultEdgeLines,\n degradedThreshold,\n degradedNodeLabel,\n activeTarget: _activeTarget,\n fadeUnrelatedCells,\n zoomable,\n scrollable,\n pannable,\n scaleRange: _scaleRange,\n hideZoomBar,\n autoCenterWhenCellsChange,\n doNotResetActiveTargetForSelector,\n doNotResetActiveTargetOutsideCanvas,\n onActiveTargetChange,\n onSwitchActiveTarget,\n onCellContextMenu,\n onCellClick,\n}: EoDisplayCanvasComponentProps) {\n const [{ cells, layoutKey }, dispatch] = useReducer(\n rootReducer,\n initialCells,\n (initialCells) => ({\n cells: initializeCells(initialCells, { defaultNodeSize }),\n layoutKey: 1,\n })\n );\n\n // When nodes are greater or equal to threshold, the diagram will be degraded.\n // Thus all nodes will be displayed as simple svg elements instead of bricks.\n const degraded = useMemo(\n () =>\n cells.filter(isNodeCell).length >=\n (degradedThreshold ?? DEFAULT_DEGRADED_THRESHOLD),\n [cells, degradedThreshold]\n );\n\n const rootRef = useRef<SVGSVGElement>(null);\n\n const { grabbing, transform, zoomer, scaleRange } = useZoom({\n rootRef,\n zoomable,\n scrollable,\n pannable,\n draggable: true,\n scaleRange: _scaleRange,\n onSwitchActiveTarget,\n });\n\n const { centered, setCentered, getNextLayoutKey } = useLayout({\n layout,\n layoutOptions,\n rootRef,\n cells,\n zoomable,\n zoomer,\n scaleRange,\n layoutKey,\n autoCenterWhenCellsChange,\n dispatch,\n });\n\n const reCenter = useCallback(() => {\n setCentered(false);\n }, [setCentered]);\n\n const previousCellsRef = useRef(initialCells);\n\n useEffect(() => {\n if (initialCells !== previousCellsRef.current) {\n previousCellsRef.current = initialCells;\n const result = updateCells({\n canvasWidth: shadowRoot.host.clientWidth,\n canvasHeight: shadowRoot.host.clientHeight,\n defaultNodeSize,\n layout,\n previousCells: cells,\n cells: initialCells,\n scaleRange,\n transform,\n });\n dispatch({ type: \"update-cells\", payload: result.cells });\n }\n }, [\n cells,\n defaultNodeSize,\n initialCells,\n layout,\n scaleRange,\n shadowRoot,\n transform,\n ]);\n\n const activeTarget = useActiveTarget({\n rootRef,\n activeTarget: _activeTarget,\n doNotResetActiveTargetForSelector,\n doNotResetActiveTargetOutsideCanvas,\n onActiveTargetChange,\n });\n\n const defPrefix = useMemo(() => `${uniqueId(\"diagram-\")}-`, []);\n const markerPrefix = `${defPrefix}line-arrow-`;\n\n const handleNodeBrickResize = useCallback(\n (id: string, size: SizeTuple | null) => {\n dispatch({\n type: \"update-node-size\",\n payload: { id, size },\n layoutKey: getNextLayoutKey(),\n });\n },\n [getNextLayoutKey]\n );\n\n const [hoverCell, setHoverCell] = useState<Cell | null>(null);\n const handleCellMouseEnter = useCallback((cell: Cell) => {\n setHoverCell(cell);\n }, []);\n const handleCellMouseLeave = useCallback((cell: Cell) => {\n setHoverCell((prev) => (prev === cell ? null : prev));\n }, []);\n\n const [unrelatedCells, setUnrelatedCells] = useState<Cell[]>([]);\n useEffect(() => {\n const nextUnrelated = fadeUnrelatedCells\n ? getUnrelatedCells(cells, null, hoverCell)\n : [];\n // Do not update the state when prev and next are both empty.\n setUnrelatedCells((prev) =>\n prev.length === 0 && nextUnrelated.length === 0 ? prev : nextUnrelated\n );\n }, [cells, fadeUnrelatedCells, hoverCell]);\n\n const handleZoomSlide = useCallback(\n (value: number) => {\n // istanbul ignore next\n if (process.env.NODE_ENV !== \"test\") {\n zoomer.scaleTo(select(rootRef.current!), value / 100);\n }\n },\n [zoomer]\n );\n\n const { lineConfMap, markers } = useLineMarkers({\n cells,\n defaultEdgeLines,\n markerPrefix,\n });\n const editableLineMap = useEditableLineMap({ cells, lineConfMap });\n\n const ready = useReady({ cells, layout, centered });\n\n return (\n <>\n <svg\n width=\"100%\"\n height=\"100%\"\n ref={rootRef}\n className={classNames(\"root\", { grabbing, pannable, ready })}\n tabIndex={-1}\n >\n <defs>\n {markers.map((marker, index) => (\n <MarkerComponent\n key={index}\n id={`${markerPrefix}${index}`}\n type={marker.markerType}\n strokeColor={marker.strokeColor}\n />\n ))}\n </defs>\n <g\n transform={`translate(${transform.x} ${transform.y}) scale(${transform.k})`}\n >\n <g className=\"cells\">\n {cells.map((cell) => (\n <CellComponent\n key={`${cell.type}:${isEdgeCell(cell) ? `${cell.source}~${cell.target}` : cell.id}`}\n layout={layout}\n cell={cell}\n cells={cells}\n degraded={degraded}\n degradedNodeLabel={degradedNodeLabel}\n defaultNodeBricks={defaultNodeBricks}\n lineConfMap={lineConfMap}\n editableLineMap={editableLineMap}\n transform={transform}\n activeTarget={activeTarget}\n readOnly\n hoverCell={hoverCell}\n unrelatedCells={unrelatedCells}\n onSwitchActiveTarget={onSwitchActiveTarget}\n onCellContextMenu={onCellContextMenu}\n onCellClick={onCellClick}\n onNodeBrickResize={handleNodeBrickResize}\n onCellMouseEnter={\n fadeUnrelatedCells && (isNodeCell(cell) || isEdgeCell(cell))\n ? handleCellMouseEnter\n : undefined\n }\n onCellMouseLeave={\n fadeUnrelatedCells && (isNodeCell(cell) || isEdgeCell(cell))\n ? handleCellMouseLeave\n : undefined\n }\n />\n ))}\n </g>\n </g>\n </svg>\n {!hideZoomBar && (\n <ZoomBarComponent\n shadowRoot={shadowRoot}\n scale={transform.k}\n scaleRange={scaleRange}\n onZoomChange={handleZoomSlide}\n onReCenter={reCenter}\n />\n )}\n </>\n );\n}\n"],"names":["defineElement","property","event","createDecorators","_EoDisplayCanvas","_A","WeakMap","_B","_C","_D","_E","_F","_G","_H","_I","_J","_K","_L","_M","_N","_O","_P","_Q","_R","_S","_EoDisplayCanvas_brand","WeakSet","_handleActiveTargetChange","_handleSwitchActiveTarget","_T","_handleCellContextMenu","_U","_handleCellClick","EoDisplayCanvas","ReactNextElement","constructor","arguments","_classPrivateMethodInitSpec","_classPrivateFieldInitSpec","_init_cells","_init_extra_cells","_init_layout","_init_extra_layout","_init_layoutOptions","_init_extra_layoutOptions","_init_defaultNodeSize","DEFAULT_NODE_SIZE","_init_extra_defaultNodeSize","_init_defaultNodeBricks","_init_extra_defaultNodeBricks","_init_degradedThreshold","_init_extra_degradedThreshold","_init_degradedNodeLabel","_init_extra_degradedNodeLabel","_init_defaultEdgeLines","_init_extra_defaultEdgeLines","_init_activeTarget","_init_extra_activeTarget","_init_fadeUnrelatedCells","_init_extra_fadeUnrelatedCells","_init_zoomable","_init_extra_zoomable","_init_scrollable","_init_extra_scrollable","_init_pannable","_init_extra_pannable","_init_scaleRange","_init_extra_scaleRange","_init_hideZoomBar","_init_extra_hideZoomBar","_init_autoCenterWhenCellsChange","_init_extra_autoCenterWhenCellsChange","_init_doNotResetActiveTargetForSelector","_init_extra_doNotResetActiveTargetForSelector","_init_doNotResetActiveTargetOutsideCanvas","_init_extra_doNotResetActiveTargetOutsideCanvas","_init_activeTargetChangeEvent","_init_extra_activeTargetChangeEvent","target","_classPrivateGetter","this","_get_activeTargetChangeEvent","emit","sameTarget","activeTarget","_init_cellContextMenu","_init_extra_cellContextMenu","detail","_get_cellContextMenu","_init_cellClick","_init_extra_cellClick","_get_cellClick","cells","_classPrivateFieldGet","v","_classPrivateFieldSet","layout","layoutOptions","defaultNodeSize","defaultNodeBricks","degradedThreshold","degradedNodeLabel","defaultEdgeLines","fadeUnrelatedCells","zoomable","scrollable","pannable","scaleRange","hideZoomBar","autoCenterWhenCellsChange","doNotResetActiveTargetForSelector","doNotResetActiveTargetOutsideCanvas","render","React","EoDisplayCanvasComponent","shadowRoot","onActiveTargetChange","onSwitchActiveTarget","onCellContextMenu","onCellClick","_ref","initialCells","_activeTarget","_scaleRange","layoutKey","dispatch","useReducer","rootReducer","initializeCells","degraded","useMemo","filter","isNodeCell","length","DEFAULT_DEGRADED_THRESHOLD","rootRef","useRef","grabbing","transform","zoomer","useZoom","draggable","centered","setCentered","getNextLayoutKey","useLayout","reCenter","useCallback","previousCellsRef","useEffect","current","result","updateCells","canvasWidth","host","clientWidth","canvasHeight","clientHeight","previousCells","type","payload","useActiveTarget","markerPrefix","uniqueId","handleNodeBrickResize","id","size","hoverCell","setHoverCell","useState","handleCellMouseEnter","cell","handleCellMouseLeave","prev","unrelatedCells","setUnrelatedCells","nextUnrelated","getUnrelatedCells","handleZoomSlide","value","scaleTo","select","lineConfMap","markers","useLineMarkers","editableLineMap","useEditableLineMap","ready","useReady","width","height","ref","className","classNames","tabIndex","map","marker","index","MarkerComponent","key","markerType","strokeColor","x","y","k","CellComponent","isEdgeCell","source","readOnly","onNodeBrickResize","onCellMouseEnter","undefined","onCellMouseLeave","ZoomBarComponent","scale","onZoomChange","onReCenter","_EoDisplayCanvas2","e","_set_activeTargetChangeEvent","_set_cellContextMenu","_set_cellClick","c","_initClass","_applyDecs","styleTexts","styleText","zoomBarStyleText","attribute","String","Number","Boolean","o","_","has","_checkInRHS"],"sourceRoot":""}
@@ -1,2 +1,2 @@
1
- "use strict";(globalThis.webpackChunk_next_bricks_diagram=globalThis.webpackChunk_next_bricks_diagram||[]).push([[8939],{9068:(e,t,a)=>{a.r(t),a.d(t,{EoDrawCanvas:()=>qt,EoDrawCanvasComponent:()=>Yt,uuidV4:()=>qa});var i,n=a(4635),l=a(918),s=a(6902),o=a(2559),r=a(5536),d=a(6121),h=a(829),c=a(2740),u=a(8769),g=a.n(u),A=a(2786),p=a(3049),v=a(6878),y=(a(6477),a(1030)),C=a(3373),w=a.n(C),f=a(7566),m=a(5748),k=a(3739),b=a(531),M=a(8185),E=a(5114),x=a(6787),T=a(3639),N=a(3783),W=a(2098),S=a(227),R=a(3033),z=a(8091),L=a(1819),B=a(7099),D=a(1484),O=a(8197),P=a(7531),H=a(8875),$=a(2722),F=a(9978),_=a(2219),K=a(3012),U=a(6237),j=a(1103),V=a(9386),I=a(1991),X=a(2202),Y=a(1825),q=a(5915),G=a(4197);let J,Q,Z,ee,te,ae,ie,ne,le,se,oe,re,de,he,ce,ue,ge,Ae,pe,ve,ye,Ce,we,fe,me,ke,be,Me,Ee,xe,Te,Ne,We,Se,Re,ze,Le,Be,De,Oe,Pe,He,$e,Fe,_e,Ke,Ue,je,Ve,Ie,Xe,Ye,qe,Ge,Je,Qe,Ze,et,tt,at,it,nt,lt,st,ot,rt,dt,ht,ct,ut,gt,At,pt,vt,yt,Ct,wt,ft,mt,kt,bt,Mt,Et,xt,Tt,Nt,Wt,St,Rt,zt,Lt,Bt,Dt,Ot,Pt,Ht,$t,Ft,_t,Kt;const Ut=(0,v.unwrapProvider)("basic.lock-body-scroll"),{defineElement:jt,property:Vt,method:It,event:Xt}=(0,A.createDecorators)(),Yt=g().forwardRef(Ya);let qt;var Gt=new WeakMap,Jt=new WeakMap,Qt=new WeakMap,Zt=new WeakMap,ea=new WeakMap,ta=new WeakMap,aa=new WeakMap,ia=new WeakMap,na=new WeakMap,la=new WeakMap,sa=new WeakMap,oa=new WeakMap,ra=new WeakMap,da=new WeakMap,ha=new WeakMap,ca=new WeakMap,ua=new WeakMap,ga=new WeakMap,Aa=new WeakMap,pa=new WeakMap,va=new WeakMap,ya=new WeakMap,Ca=new WeakSet,wa=new WeakMap,fa=new WeakMap,ma=new WeakMap,ka=new WeakMap,ba=new WeakMap,Ma=new WeakMap,Ea=new WeakMap,xa=new WeakMap,Ta=new WeakMap,Na=new WeakMap,Wa=new WeakMap,Sa=new WeakMap,Ra=new WeakMap,za=new WeakMap,La=new WeakMap,Ba=new WeakMap,Da=new WeakMap,Oa=new WeakMap,Pa=new WeakMap,Ha=new WeakMap,$a=new WeakMap,Fa=new WeakMap,_a=new WeakMap,Ka=new WeakMap,Ua=new WeakMap,ja=new WeakMap,Va=new WeakMap;class Ia extends p.ReactNextElement{constructor(){super(...arguments),(0,n.A)(this,Ca),(0,l.A)(this,Gt,(J(this),Z(this))),(0,l.A)(this,Jt,(ee(this),te(this))),(0,l.A)(this,Qt,(ae(this),ie(this))),(0,l.A)(this,Zt,(ne(this),le(this,[R.HP,R.HP]))),(0,l.A)(this,ea,(se(this),oe(this))),(0,l.A)(this,ta,(re(this),de(this))),(0,l.A)(this,aa,(he(this),ce(this))),(0,l.A)(this,ia,(ue(this),ge(this))),(0,l.A)(this,na,(Ae(this),pe(this))),(0,l.A)(this,la,(ve(this),ye(this))),(0,l.A)(this,sa,(Ce(this),we(this,!0))),(0,l.A)(this,oa,(fe(this),me(this,!0))),(0,l.A)(this,ra,(ke(this),be(this,!0))),(0,l.A)(this,da,(Me(this),Ee(this,!1))),(0,l.A)(this,ha,(xe(this),Te(this))),(0,l.A)(this,ca,(Ne(this),We(this))),(0,l.A)(this,ua,(Se(this),Re(this))),(0,l.A)(this,ga,(ze(this),Le(this))),(0,l.A)(this,Aa,(Be(this),De(this))),(0,l.A)(this,pa,(Oe(this),Pe(this))),(0,l.A)(this,va,(He(this),$e(this))),(0,l.A)(this,ya,(Fe(this),_e(this))),(0,l.A)(this,wa,(je(this),e=>{(0,r.A)(Ca,this,Ke).emit(e)})),(0,l.A)(this,fa,(e=>{(0,M.c)(e,this.activeTarget)||(this.activeTarget=e)})),(0,l.A)(this,ma,Ve(this)),(0,l.A)(this,ka,(Ye(this),qe(this))),(0,l.A)(this,ba,(Qe(this),e=>{(0,r.A)(Ca,this,Ge).emit(e),"node"===e.type&&(0,r.A)(Ca,this,Ie).emit(e)})),(0,l.A)(this,Ma,Ze(this)),(0,l.A)(this,Ea,(at(this),e=>{(0,r.A)(Ca,this,et).emit(e)})),(0,l.A)(this,xa,it(this)),(0,l.A)(this,Ta,(st(this),e=>{(0,r.A)(Ca,this,nt).emit(e)})),(0,l.A)(this,Na,ot(this)),(0,l.A)(this,Wa,(ht(this),ct(this))),(0,l.A)(this,Sa,(At(this),e=>{(0,r.A)(Ca,this,ut).emit(e),"node"===e.type&&(0,r.A)(Ca,this,rt).emit(e)})),(0,l.A)(this,Ra,pt(this)),(0,l.A)(this,za,(Ct(this),e=>{(0,r.A)(Ca,this,vt).emit(e)})),(0,l.A)(this,La,wt(this)),(0,l.A)(this,Ba,(kt(this),e=>{(0,r.A)(Ca,this,ft).emit(e)})),(0,l.A)(this,Da,bt(this)),(0,l.A)(this,Oa,(xt(this),e=>{(0,r.A)(Ca,this,Mt).emit(e)})),(0,l.A)(this,Pa,Tt(this)),(0,l.A)(this,Ha,(St(this),e=>{(0,r.A)(Ca,this,Nt).emit(e)})),(0,l.A)(this,$a,Rt(this)),(0,l.A)(this,Fa,(Bt(this),e=>{(0,r.A)(Ca,this,zt).emit(e)})),(0,l.A)(this,_a,Dt(this)),(0,l.A)(this,Ka,(Ht(this),e=>{(0,r.A)(Ca,this,Ot).emit(e)})),(0,l.A)(this,Ua,$t(this)),(0,l.A)(this,ja,(Kt(this),e=>{(0,r.A)(Ca,this,Ft).emit(e)})),(0,l.A)(this,Va,(0,u.createRef)())}get cells(){return(0,h.A)(Gt,this)}set cells(e){(0,d.A)(Gt,this,e)}get layout(){return(0,h.A)(Jt,this)}set layout(e){(0,d.A)(Jt,this,e)}get layoutOptions(){return(0,h.A)(Qt,this)}set layoutOptions(e){(0,d.A)(Qt,this,e)}get defaultNodeSize(){return(0,h.A)(Zt,this)}set defaultNodeSize(e){(0,d.A)(Zt,this,e)}get defaultNodeBricks(){return(0,h.A)(ea,this)}set defaultNodeBricks(e){(0,d.A)(ea,this,e)}get degradedThreshold(){return(0,h.A)(ta,this)}set degradedThreshold(e){(0,d.A)(ta,this,e)}get degradedNodeLabel(){return(0,h.A)(aa,this)}set degradedNodeLabel(e){(0,d.A)(aa,this,e)}get defaultEdgeLines(){return(0,h.A)(ia,this)}set defaultEdgeLines(e){(0,d.A)(ia,this,e)}get activeTarget(){return(0,h.A)(na,this)}set activeTarget(e){(0,d.A)(na,this,e)}get fadeUnrelatedCells(){return(0,h.A)(la,this)}set fadeUnrelatedCells(e){(0,d.A)(la,this,e)}get zoomable(){return(0,h.A)(sa,this)}set zoomable(e){(0,d.A)(sa,this,e)}get scrollable(){return(0,h.A)(oa,this)}set scrollable(e){(0,d.A)(oa,this,e)}get pannable(){return(0,h.A)(ra,this)}set pannable(e){(0,d.A)(ra,this,e)}get allowEdgeToArea(){return(0,h.A)(da,this)}set allowEdgeToArea(e){(0,d.A)(da,this,e)}get dragBehavior(){return(0,h.A)(ha,this)}set dragBehavior(e){(0,d.A)(ha,this,e)}get ctrlDragBehavior(){return(0,h.A)(ca,this)}set ctrlDragBehavior(e){(0,d.A)(ca,this,e)}get scaleRange(){return(0,h.A)(ua,this)}set scaleRange(e){(0,d.A)(ua,this,e)}get lineSettings(){return(0,h.A)(ga,this)}set lineSettings(e){(0,d.A)(ga,this,e)}get lineConnector(){return(0,h.A)(Aa,this)}set lineConnector(e){(0,d.A)(Aa,this,e)}get doNotResetActiveTargetForSelector(){return(0,h.A)(pa,this)}set doNotResetActiveTargetForSelector(e){(0,d.A)(pa,this,e)}get doNotResetActiveTargetOutsideCanvas(){return(0,h.A)(va,this)}set doNotResetActiveTargetOutsideCanvas(e){(0,d.A)(va,this,e)}async dropNode(e){var t,a;let{id:i,position:n,size:l,data:s,useBrick:o}=e;if(null===(t=(a=document).elementsFromPoint)||void 0===t||null===(t=t.call(a,n[0],n[1]))||void 0===t?void 0:t.includes(this)){var r,d,c;const e=this.getBoundingClientRect(),t=(0,h.A)(Va,this).current.getTransform(),a={type:"node",id:i,view:{..."force"===this.layout||"dagre"===this.layout?null:{x:(n[0]-e.left-t.x)/t.k,y:(n[1]-e.top-t.y)/t.k},width:null!==(r=null==l?void 0:l[0])&&void 0!==r?r:this.defaultNodeSize[0],height:null!==(d=null==l?void 0:l[1])&&void 0!==d?d:this.defaultNodeSize[0]},data:s,useBrick:o};return null===(c=(0,h.A)(Va,this).current)||void 0===c||c.dropNode(a),a}return null}async dropDecorator(e){var t,a;let{position:i,decorator:n,text:l,direction:s}=e;if(null===(t=(a=document).elementsFromPoint)||void 0===t||null===(t=t.call(a,i[0],i[1]))||void 0===t?void 0:t.includes(this)){var o;const e=this.getBoundingClientRect(),t=(0,h.A)(Va,this).current.getTransform(),a={type:"decorator",decorator:n,id:qa(),view:{x:(i[0]-e.left-t.x)/t.k,y:(i[1]-e.top-t.y)/t.k,width:R.N8,height:R.w1,text:l,direction:s}};return null===(o=(0,h.A)(Va,this).current)||void 0===o||o.dropDecorator(a),a}return null}async addNodes(e){if(0===e.length)return[];const t=e.map((e=>{var t,a;let{size:i,useBrick:n,id:l,data:s}=e;return{type:"node",id:l,data:s,view:{width:null!==(t=null==i?void 0:i[0])&&void 0!==t?t:this.defaultNodeSize[0],height:null!==(a=null==i?void 0:i[1])&&void 0!==a?a:this.defaultNodeSize[0]},useBrick:n}}));return(0,h.A)(Va,this).current.addNodes(t,{defaultNodeSize:this.defaultNodeSize,canvasWidth:this.clientWidth,canvasHeight:this.clientHeight})}async addEdge(e){var t;let{source:a,target:i,data:n}=e;const l={type:"edge",source:a,target:i,data:n,view:this.lineSettings};return null===(t=(0,h.A)(Va,this).current)||void 0===t||t.addEdge(l),l}manuallyConnectNodes(e){return(0,h.A)(Va,this).current.manuallyConnectNodes(e)}async updateCells(e,t){await(0,o.A)(Ca,this,Xa).call(this);const{updated:a}=(0,h.A)(Va,this).current.updateCells(e,{...t,defaultNodeSize:this.defaultNodeSize,canvasWidth:this.clientWidth,canvasHeight:this.clientHeight});return{updated:a}}async reCenter(){var e;null===(e=(0,h.A)(Va,this).current)||void 0===e||e.reCenter()}disconnectedCallback(){super.disconnectedCallback(),Ut(this,!1)}render(){return g().createElement(Yt,{host:this,ref:(0,h.A)(Va,this),layout:this.layout,layoutOptions:this.layoutOptions,cells:this.cells,defaultNodeSize:this.defaultNodeSize,defaultNodeBricks:this.defaultNodeBricks,defaultEdgeLines:this.defaultEdgeLines,degradedThreshold:this.degradedThreshold,degradedNodeLabel:this.degradedNodeLabel,activeTarget:this.activeTarget,fadeUnrelatedCells:this.fadeUnrelatedCells,zoomable:this.zoomable,scrollable:this.scrollable,pannable:this.pannable,dragBehavior:this.dragBehavior,ctrlDragBehavior:this.ctrlDragBehavior,scaleRange:this.scaleRange,lineSettings:this.lineSettings,lineConnector:this.lineConnector,allowEdgeToArea:this.allowEdgeToArea,doNotResetActiveTargetForSelector:this.doNotResetActiveTargetForSelector,doNotResetActiveTargetOutsideCanvas:this.doNotResetActiveTargetOutsideCanvas,onActiveTargetChange:(0,h.A)(wa,this),onSwitchActiveTarget:(0,h.A)(fa,this),onCellMove:(0,h.A)(ba,this),onCellsMove:(0,h.A)(Ea,this),onCellResize:(0,h.A)(Ta,this),onCellDelete:(0,h.A)(Sa,this),onCellsDelete:(0,h.A)(za,this),onEdgeAdd:(0,h.A)(Oa,this),onCellContextMenu:(0,h.A)(Ba,this),onDecoratorTextChange:(0,h.A)(Fa,this),onContainerContainerChange:(0,h.A)(Ka,this),onScaleChange:(0,h.A)(ja,this),onEdgeViewChange:(0,h.A)(Ha,this)})}}function Xa(){return new Promise((e=>{const t=()=>{(0,h.A)(Va,this).current?e():setTimeout(t,10)};t()}))}function Ya(e,t){let{host:a,layout:i,layoutOptions:n,cells:l,defaultNodeSize:s,defaultNodeBricks:o,defaultEdgeLines:r,degradedThreshold:d,degradedNodeLabel:h,activeTarget:c,fadeUnrelatedCells:A,zoomable:p,scrollable:v,pannable:C,dragBehavior:M,ctrlDragBehavior:K,scaleRange:U,lineSettings:J,lineConnector:Q,allowEdgeToArea:Z,doNotResetActiveTargetForSelector:ee,doNotResetActiveTargetOutsideCanvas:te,onActiveTargetChange:ae,onSwitchActiveTarget:ie,onCellMove:ne,onCellResize:le,onCellDelete:se,onCellsMove:oe,onCellsDelete:re,onCellContextMenu:de,onEdgeAdd:he,onDecoratorTextChange:ce,onScaleChange:ue,onContainerContainerChange:ge,onEdgeViewChange:Ae}=e;const[{cells:pe,layoutKey:ve},ye]=(0,u.useReducer)(m.d,l,(e=>({cells:(0,N.C)(e,{defaultNodeSize:s}),layoutKey:0}))),Ce=(0,u.useMemo)((()=>pe.filter(b.N).length>=(null!=d?d:R.pC)),[pe,d]),we=(0,u.useRef)(null),fe=(0,u.useRef)(null),[me,ke]=(0,u.useState)([]),[be,Me]=(0,u.useState)([]),{grabbing:Ee,transform:xe,zoomer:Te,scaleRange:Ne}=(0,z.f)({rootRef:we,zoomable:p,scrollable:v,pannable:C,draggable:"grab"===M,ctrlDraggable:"grab"===K,scaleRange:U,onSwitchActiveTarget:ie});(0,u.useEffect)((()=>{ue(xe.k)}),[ue,xe.k]);const[We,Se]=(0,u.useState)(null),[Re,ze]=(0,u.useState)(null),{centered:Le,setCentered:Be,getNextLayoutKey:De}=(0,D.g)({layout:i,layoutOptions:n,rootRef:we,cells:pe,zoomable:p,zoomer:Te,scaleRange:Ne,layoutKey:ve,allowEdgeToArea:Z,dispatch:ye}),Oe=(0,u.useCallback)((()=>{Be(!1)}),[Be]);(0,u.useImperativeHandle)(t,(()=>({dropNode(e){"dagre"!==i&&"force"!==i&&Be(!0),ye({type:"drop-node",payload:e})},dropDecorator(e){"dagre"!==i&&"force"!==i&&Be(!0),ye({type:"drop-decorator",payload:e})},addNodes(e,t){let{defaultNodeSize:a,canvasWidth:n,canvasHeight:l}=t;const s=pe.findLastIndex((e=>!("decorator"===e.type&&"text"===e.decorator)))+1,o=[...pe.slice(0,s),...e,...pe.slice(s)],{cells:r,updated:d,shouldReCenter:h}=(0,W.L)({cells:o,layout:i,previousCells:pe,defaultNodeSize:a,canvasWidth:n,canvasHeight:l,scaleRange:Ne,transform:xe,allowEdgeToArea:Z});return h&&Be(!1),ye({type:"update-cells",payload:r}),d.filter((t=>e.includes(t)))},addEdge(e){ye({type:"add-edge",payload:e})},updateCells(e,t){const{shouldReCenter:a,...n}=(0,W.L)({...t,layout:i,previousCells:pe,cells:e,scaleRange:Ne,transform:xe,allowEdgeToArea:Z});return a&&Be(!1),ye({type:"update-cells",payload:n.cells}),n},getTransform:()=>xe,manuallyConnectNodes(e){const t=pe.find((t=>(0,b.bo)(t,Z)&&t.id===e));if(t){const e=we.current.getBoundingClientRect();return ze({source:t,from:[t.view.x+t.view.width/2,t.view.y+t.view.height/2],offset:[e.left,e.top]}),new Promise(((e,t)=>{fe.current={resolve:e,reject:t}}))}return Promise.reject(null)},reCenter:Oe})),[pe,i,Ne,Be,xe,Z,Oe]);const Pe=(0,u.useCallback)(((e,t)=>{var a;for(let a=pe.length-1;a>=0;a--){const n=pe[a];if((0,b.bo)(n,Z)&&n.id!==e.source.id&&n.view.x<t[0]&&n.view.x+n.view.width>t[0]&&n.view.y<t[1]&&n.view.y+n.view.height>t[1]){var i;null===(i=fe.current)||void 0===i||i.resolve({source:e.source,target:n});break}}null===(a=fe.current)||void 0===a||a.reject(null),ze(null)}),[Z,pe]),[He,$e]=(0,u.useState)(null);(0,u.useEffect)((()=>{Ut(a,!!(Re||He||We))}),[Re,a,He,We]);const Fe=(0,L.J)({rootRef:we,activeTarget:c,doNotResetActiveTargetForSelector:ee,doNotResetActiveTargetOutsideCanvas:te,onActiveTargetChange:ae}),[_e,Ke]=(0,u.useState)([]);(0,u.useEffect)((()=>{const e=A?(0,S.Y)(pe,Re,Fe,Z):[];Ke((t=>0===t.length&&0===e.length?t:e))}),[Fe,pe,Re,A,Z]),(0,u.useEffect)((()=>{const e=we.current;if(!e||me.length>0)return;const t=e=>{const t=(0,E.a)(e,{cells:pe,activeTarget:Fe});"delete-cells"===(null==t?void 0:t.action)&&(re(t.cells),1===t.cells.length&&se(t.cells[0]))};return e.addEventListener("keydown",t),()=>{e.removeEventListener("keydown",t)}}),[Fe,pe,me.length,se,re]);const Ue=`${(0,u.useMemo)((()=>`${(0,y.uniqueId)("diagram-")}-`),[])}line-arrow-`,[je,Ve]=(0,u.useState)([]),Ie=(0,u.useCallback)((e=>{ye({type:"move-cells",payload:e});const t=[];(0,I._)(e,pe).forEach((e=>{var a,i;null!==(a=e.containerCell)&&void 0!==a&&a.id&&t.push(null===(i=e.containerCell)||void 0===i?void 0:i.id)})),Me(t),Ve(e.flatMap((e=>{var t;return null!==(t=e.guideLines)&&void 0!==t?t:[]})))}),[pe]),Xe=(0,u.useCallback)((e=>{ye({type:"move-cells",payload:e}),oe(e),1===e.length&&ne(e[0]),(0,I._)(e,pe,ge),Me([]),Ve([])}),[ne,oe,pe,ge]),Ye=(0,u.useCallback)((e=>{ye({type:"resize-cell",payload:e})}),[]),qe=(0,u.useCallback)((e=>{ye({type:"resize-cell",payload:e}),le(e)}),[le]),Ge=(0,u.useCallback)((e=>{let{id:t,editing:a}=e;ke(a?e=>e.includes(t)?e:[...e,t]:e=>e.filter((e=>e!==t)))}),[]),Je=(0,u.useCallback)(((e,t)=>{const a=De();ye({type:"update-node-size",payload:{id:e,size:t},layoutKey:a})}),[De]),Qe=(0,u.useCallback)((e=>{Te.scaleTo((0,f.A)(we.current),e/100)}),[Te]),{lineConfMap:Ze,lineConnectorConf:et,markers:tt}=(0,P.d)({cells:pe,defaultEdgeLines:r,lineConnector:Q,markerPrefix:Ue}),at=(0,q.A)({cells:pe,lineConfMap:Ze}),it=(0,u.useMemo)((()=>{let e;return"edge"===(null==Fe?void 0:Fe.type)&&(e=pe.find((e=>(0,G.Q)(e,Fe)))),e&&at.has(e)?e:null}),[Fe,pe,at]),nt=(0,O.H)({cells:pe,layout:i,centered:Le}),[lt,st]=(0,u.useState)(null),ot=(0,u.useRef)(null),[rt,dt]=(0,u.useState)(null),ht=(0,u.useCallback)((e=>{if(et&&(0,b.bo)(e,Z)&&(!rt||"control"!==rt.type)){null!==ot.current&&(clearTimeout(ot.current),ot.current=null);const t=(0,H.G)();st({cell:e,relativePoints:t,points:Ga(t,e.view)})}}),[Z,et,rt]),ct=(0,u.useCallback)((e=>{et&&(0,b.N)(e)&&(ot.current=setTimeout((()=>{st(null)})))}),[et]),ut=(0,u.useCallback)(((e,t,a,i)=>{const n={source:e.id,target:t.id,view:{...J,exitPosition:a,entryPosition:i,vertices:null}};if(pe.find((a=>"edge"===a.type&&a.source===e.id&&a.target===t.id)))ye({type:"change-edge-view",payload:n}),null==Ae||Ae(n);else{const a={type:"edge",...n};ye({type:"add-edge",payload:a}),he({source:e,target:t,view:a.view})}}),[pe,J,he,Ae]),gt=(0,u.useCallback)(((e,t,a)=>{const i={source:e.id,target:t.id,view:a};ye({type:"change-edge-view",payload:i}),null==Ae||Ae(i)}),[Ae]),At=(0,u.useMemo)((()=>({rootRef:we,smartConnectLineState:He,unsetHoverStateTimeoutRef:ot,hoverState:lt,activeEditableEdge:it,lineEditorState:rt,setLineEditorState:dt,setHoverState:st,setSmartConnectLineState:$e,onConnect:ut,onChangeEdgeView:gt})),[it,gt,ut,lt,rt,He]);return(0,u.useEffect)((()=>{const e=we.current;if(!e||"lasso"!==M)return;const t=e.getBoundingClientRect(),a=e=>{(0,_.F)(e,{transform:xe,offset:[t.left,t.top],onLassoing(e){Se(e)},onLassoed(e){Se(null);const t=[];for(const a of pe)if((0,b.t2)(a)||(0,b.o6)(a)||(0,b.Hs)(a)){const i=a.view.x,n=a.view.y;i>=e.x&&i+a.view.width<=e.x+e.width&&n>=e.y&&n+a.view.height<=e.y+e.height&&t.push(a)}null==ie||ie(t.length>1?{type:"multi",targets:t.map(V.P)}:1===t.length?(0,V.P)(t[0]):null)}})};return e.addEventListener("mousedown",a),()=>{e.removeEventListener("mousedown",a)}}),[xe,pe,M,ie]),g().createElement(F.H.Provider,{value:At},g().createElement("svg",{width:"100%",height:"100%",ref:we,className:w()("root",{grabbing:Ee,pannable:C,ready:nt}),tabIndex:-1},g().createElement("defs",null,tt.map(((e,t)=>g().createElement(k.c,{key:t,id:`${Ue}${t}`,type:e.markerType,strokeColor:e.strokeColor})))),g().createElement("g",{transform:`translate(${xe.x} ${xe.y}) scale(${xe.k})`},g().createElement("g",{className:w()("cells",{allowEdgeToArea:Z})},pe.map((e=>g().createElement(x.m,{key:`${e.type}:${(0,b.WW)(e)?`${e.source}~${e.target}`:e.id}`,dragNodeToContainerActive:!(0,b.WW)(e)&&be.includes(e.id),layout:i,layoutOptions:n,cell:e,cells:pe,degraded:Ce,degradedNodeLabel:h,defaultNodeBricks:o,transform:xe,lineConfMap:Ze,editableLineMap:at,activeTarget:Fe,unrelatedCells:_e,allowEdgeToArea:Z,onCellsMoving:Ie,onCellsMoved:Xe,onCellResizing:Ye,onCellResized:qe,onSwitchActiveTarget:ie,onCellContextMenu:de,onDecoratorTextChange:ce,onDecoratorTextEditing:Ge,onNodeBrickResize:Je,onCellMouseEnter:ht,onCellMouseLeave:ct})))),g().createElement("g",null,g().createElement(T.w,{connectLineState:Re,transform:xe,markerEnd:`${Ue}0`,onConnect:Pe})),We&&g().createElement("rect",{x:We.x,y:We.y,width:We.width,height:We.height,fill:"var(--palette-gray-5)",fillOpacity:.3,stroke:"var(--palette-gray-5)",strokeDasharray:2}),et&&g().createElement("g",null,g().createElement(j.X,{transform:xe,lineSettings:J,options:et}),g().createElement(Y.W,{cells:pe,editableLineMap:at,transform:xe,options:et})),g().createElement("g",null,je.map(((e,t)=>g().createElement("path",{key:t,d:`M${e[0].join(" ")} L${e[1].join(" ")}`,stroke:"var(--palette-orange-5)",fill:"none",strokeWidth:1/xe.k})))),g().createElement("g",null,et&&g().createElement(X.F,{editableLineMap:at,scale:xe.k})),et&&g().createElement($.T,{activeTarget:Fe,editableLineMap:at,scale:xe.k,disabled:!!Re}))),g().createElement(B.Y,{shadowRoot:a.shadowRoot,scale:xe.k,scaleRange:Ne,onZoomChange:Qe,onReCenter:Oe}))}function qa(){return"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g,(function(e){const t=16*Math.random()|0;return("x"==e?t:3&t|8).toString(16)}))}function Ga(e,t){let a=arguments.length>2&&void 0!==arguments[2]?arguments[2]:1;const i=R.XK,n=i/2,l=t.x+a/2-n,s=t.y+a/2-n,o=t.width-a+i,r=t.height-a+i;return e.map((e=>({x:l+e.x*o,y:s+e.y*r})))}i=Ia,({e:[Z,ee,te,ae,ie,ne,le,se,oe,re,de,he,ce,ue,ge,Ae,pe,ve,ye,Ce,we,fe,me,ke,be,Me,Ee,xe,Te,Ne,We,Se,Re,ze,Le,Be,De,Oe,Pe,He,$e,Fe,_e,Ke,Ue,je,Ve,Ie,Xe,Ye,qe,Ge,Je,Qe,Ze,et,tt,at,it,nt,lt,st,ot,rt,dt,ht,ct,ut,gt,At,pt,vt,yt,Ct,wt,ft,mt,kt,bt,Mt,Et,xt,Tt,Nt,Wt,St,Rt,zt,Lt,Bt,Dt,Ot,Pt,Ht,$t,Ft,_t,Kt,J],c:[qt,Q]}=(0,c.A)(i,[jt("eo-draw-canvas",{styleTexts:[K.A,U.A]})],[[Vt({attribute:!1}),1,"cells"],[Vt({type:String}),1,"layout"],[Vt({attribute:!1}),1,"layoutOptions"],[Vt({attribute:!1}),1,"defaultNodeSize"],[Vt({attribute:!1}),1,"defaultNodeBricks"],[Vt({type:Number}),1,"degradedThreshold"],[Vt({attribute:!1}),1,"degradedNodeLabel"],[Vt({attribute:!1}),1,"defaultEdgeLines"],[Vt({attribute:!1}),1,"activeTarget"],[Vt({type:Boolean}),1,"fadeUnrelatedCells"],[Vt({type:Boolean}),1,"zoomable"],[Vt({type:Boolean}),1,"scrollable"],[Vt({type:Boolean}),1,"pannable"],[Vt({type:Boolean}),1,"allowEdgeToArea"],[Vt(),1,"dragBehavior"],[Vt(),1,"ctrlDragBehavior"],[Vt({attribute:!1}),1,"scaleRange"],[Vt({attribute:!1}),1,"lineSettings"],[Vt({attribute:!1}),1,"lineConnector"],[Vt(),1,"doNotResetActiveTargetForSelector"],[Vt({type:Boolean}),1,"doNotResetActiveTargetOutsideCanvas"],[Xt({type:"activeTarget.change"}),1,"activeTargetChangeEvent",e=>(0,h.A)(ya,e),(e,t)=>(0,d.A)(ya,e,t)],[Xt({type:"node.move"}),1,"nodeMoveEvent",e=>(0,h.A)(ma,e),(e,t)=>(0,d.A)(ma,e,t)],[Xt({type:"cell.move"}),1,"cellMoveEvent",e=>(0,h.A)(ka,e),(e,t)=>(0,d.A)(ka,e,t)],[Xt({type:"cells.move"}),1,"cellsMoveEvent",e=>(0,h.A)(Ma,e),(e,t)=>(0,d.A)(Ma,e,t)],[Xt({type:"cell.resize"}),1,"cellResizeEvent",e=>(0,h.A)(xa,e),(e,t)=>(0,d.A)(xa,e,t)],[Xt({type:"node.delete"}),1,"nodeDelete",e=>(0,h.A)(Na,e),(e,t)=>(0,d.A)(Na,e,t)],[Xt({type:"cell.delete"}),1,"cellDelete",e=>(0,h.A)(Wa,e),(e,t)=>(0,d.A)(Wa,e,t)],[Xt({type:"cells.delete"}),1,"cellsDelete",e=>(0,h.A)(Ra,e),(e,t)=>(0,d.A)(Ra,e,t)],[Xt({type:"cell.contextmenu"}),1,"cellContextMenu",e=>(0,h.A)(La,e),(e,t)=>(0,d.A)(La,e,t)],[Xt({type:"edge.add"}),1,"edgeAdd",e=>(0,h.A)(Da,e),(e,t)=>(0,d.A)(Da,e,t)],[Xt({type:"edge.view.change"}),1,"edgeViewChange",e=>(0,h.A)(Pa,e),(e,t)=>(0,d.A)(Pa,e,t)],[Xt({type:"decorator.text.change"}),1,"decoratorTextChange",e=>(0,h.A)($a,e),(e,t)=>(0,d.A)($a,e,t)],[Xt({type:"node.container.change"}),1,"containerContainerChange",e=>(0,h.A)(_a,e),(e,t)=>(0,d.A)(_a,e,t)],[Xt({type:"scale.change"}),1,"scaleChange",e=>(0,h.A)(Ua,e),(e,t)=>(0,d.A)(Ua,e,t)],[It(),2,"dropNode"],[It(),2,"dropDecorator"],[It(),2,"addNodes"],[It(),2,"addEdge"],[It(),2,"manuallyConnectNodes"],[It(),2,"updateCells"],[It(),2,"reCenter"]],0,(e=>Va.has((0,s.A)(e))),p.ReactNextElement)),Q()}}]);
2
- //# sourceMappingURL=eo-draw-canvas.d7cca02f.js.map
1
+ "use strict";(globalThis.webpackChunk_next_bricks_diagram=globalThis.webpackChunk_next_bricks_diagram||[]).push([[8939],{9068:(e,t,a)=>{a.r(t),a.d(t,{EoDrawCanvas:()=>qt,EoDrawCanvasComponent:()=>Yt,uuidV4:()=>qa});var i,n=a(4635),l=a(918),s=a(6902),o=a(2559),r=a(5536),d=a(6121),h=a(829),c=a(2740),u=a(8769),g=a.n(u),A=a(1123),p=a(9006),v=a(2729),y=(a(6477),a(1030)),C=a(3373),w=a.n(C),f=a(7566),m=a(5748),k=a(3739),b=a(531),M=a(8185),E=a(2733),x=a(6787),T=a(3639),N=a(3783),W=a(2098),S=a(227),R=a(3033),z=a(8091),L=a(1819),B=a(7099),D=a(1484),O=a(8197),P=a(7531),H=a(8875),$=a(2722),F=a(9978),_=a(2219),K=a(3012),U=a(6237),j=a(1103),V=a(9386),I=a(1991),X=a(2202),Y=a(1825),q=a(5915),G=a(4197);let J,Q,Z,ee,te,ae,ie,ne,le,se,oe,re,de,he,ce,ue,ge,Ae,pe,ve,ye,Ce,we,fe,me,ke,be,Me,Ee,xe,Te,Ne,We,Se,Re,ze,Le,Be,De,Oe,Pe,He,$e,Fe,_e,Ke,Ue,je,Ve,Ie,Xe,Ye,qe,Ge,Je,Qe,Ze,et,tt,at,it,nt,lt,st,ot,rt,dt,ht,ct,ut,gt,At,pt,vt,yt,Ct,wt,ft,mt,kt,bt,Mt,Et,xt,Tt,Nt,Wt,St,Rt,zt,Lt,Bt,Dt,Ot,Pt,Ht,$t,Ft,_t,Kt;const Ut=(0,v.unwrapProvider)("basic.lock-body-scroll"),{defineElement:jt,property:Vt,method:It,event:Xt}=(0,A.createDecorators)(),Yt=g().forwardRef(Ya);let qt;var Gt=new WeakMap,Jt=new WeakMap,Qt=new WeakMap,Zt=new WeakMap,ea=new WeakMap,ta=new WeakMap,aa=new WeakMap,ia=new WeakMap,na=new WeakMap,la=new WeakMap,sa=new WeakMap,oa=new WeakMap,ra=new WeakMap,da=new WeakMap,ha=new WeakMap,ca=new WeakMap,ua=new WeakMap,ga=new WeakMap,Aa=new WeakMap,pa=new WeakMap,va=new WeakMap,ya=new WeakMap,Ca=new WeakSet,wa=new WeakMap,fa=new WeakMap,ma=new WeakMap,ka=new WeakMap,ba=new WeakMap,Ma=new WeakMap,Ea=new WeakMap,xa=new WeakMap,Ta=new WeakMap,Na=new WeakMap,Wa=new WeakMap,Sa=new WeakMap,Ra=new WeakMap,za=new WeakMap,La=new WeakMap,Ba=new WeakMap,Da=new WeakMap,Oa=new WeakMap,Pa=new WeakMap,Ha=new WeakMap,$a=new WeakMap,Fa=new WeakMap,_a=new WeakMap,Ka=new WeakMap,Ua=new WeakMap,ja=new WeakMap,Va=new WeakMap;class Ia extends p.ReactNextElement{constructor(){super(...arguments),(0,n.A)(this,Ca),(0,l.A)(this,Gt,(J(this),Z(this))),(0,l.A)(this,Jt,(ee(this),te(this))),(0,l.A)(this,Qt,(ae(this),ie(this))),(0,l.A)(this,Zt,(ne(this),le(this,[R.HP,R.HP]))),(0,l.A)(this,ea,(se(this),oe(this))),(0,l.A)(this,ta,(re(this),de(this))),(0,l.A)(this,aa,(he(this),ce(this))),(0,l.A)(this,ia,(ue(this),ge(this))),(0,l.A)(this,na,(Ae(this),pe(this))),(0,l.A)(this,la,(ve(this),ye(this))),(0,l.A)(this,sa,(Ce(this),we(this,!0))),(0,l.A)(this,oa,(fe(this),me(this,!0))),(0,l.A)(this,ra,(ke(this),be(this,!0))),(0,l.A)(this,da,(Me(this),Ee(this,!1))),(0,l.A)(this,ha,(xe(this),Te(this))),(0,l.A)(this,ca,(Ne(this),We(this))),(0,l.A)(this,ua,(Se(this),Re(this))),(0,l.A)(this,ga,(ze(this),Le(this))),(0,l.A)(this,Aa,(Be(this),De(this))),(0,l.A)(this,pa,(Oe(this),Pe(this))),(0,l.A)(this,va,(He(this),$e(this))),(0,l.A)(this,ya,(Fe(this),_e(this))),(0,l.A)(this,wa,(je(this),e=>{(0,r.A)(Ca,this,Ke).emit(e)})),(0,l.A)(this,fa,(e=>{(0,M.c)(e,this.activeTarget)||(this.activeTarget=e)})),(0,l.A)(this,ma,Ve(this)),(0,l.A)(this,ka,(Ye(this),qe(this))),(0,l.A)(this,ba,(Qe(this),e=>{(0,r.A)(Ca,this,Ge).emit(e),"node"===e.type&&(0,r.A)(Ca,this,Ie).emit(e)})),(0,l.A)(this,Ma,Ze(this)),(0,l.A)(this,Ea,(at(this),e=>{(0,r.A)(Ca,this,et).emit(e)})),(0,l.A)(this,xa,it(this)),(0,l.A)(this,Ta,(st(this),e=>{(0,r.A)(Ca,this,nt).emit(e)})),(0,l.A)(this,Na,ot(this)),(0,l.A)(this,Wa,(ht(this),ct(this))),(0,l.A)(this,Sa,(At(this),e=>{(0,r.A)(Ca,this,ut).emit(e),"node"===e.type&&(0,r.A)(Ca,this,rt).emit(e)})),(0,l.A)(this,Ra,pt(this)),(0,l.A)(this,za,(Ct(this),e=>{(0,r.A)(Ca,this,vt).emit(e)})),(0,l.A)(this,La,wt(this)),(0,l.A)(this,Ba,(kt(this),e=>{(0,r.A)(Ca,this,ft).emit(e)})),(0,l.A)(this,Da,bt(this)),(0,l.A)(this,Oa,(xt(this),e=>{(0,r.A)(Ca,this,Mt).emit(e)})),(0,l.A)(this,Pa,Tt(this)),(0,l.A)(this,Ha,(St(this),e=>{(0,r.A)(Ca,this,Nt).emit(e)})),(0,l.A)(this,$a,Rt(this)),(0,l.A)(this,Fa,(Bt(this),e=>{(0,r.A)(Ca,this,zt).emit(e)})),(0,l.A)(this,_a,Dt(this)),(0,l.A)(this,Ka,(Ht(this),e=>{(0,r.A)(Ca,this,Ot).emit(e)})),(0,l.A)(this,Ua,$t(this)),(0,l.A)(this,ja,(Kt(this),e=>{(0,r.A)(Ca,this,Ft).emit(e)})),(0,l.A)(this,Va,(0,u.createRef)())}get cells(){return(0,h.A)(Gt,this)}set cells(e){(0,d.A)(Gt,this,e)}get layout(){return(0,h.A)(Jt,this)}set layout(e){(0,d.A)(Jt,this,e)}get layoutOptions(){return(0,h.A)(Qt,this)}set layoutOptions(e){(0,d.A)(Qt,this,e)}get defaultNodeSize(){return(0,h.A)(Zt,this)}set defaultNodeSize(e){(0,d.A)(Zt,this,e)}get defaultNodeBricks(){return(0,h.A)(ea,this)}set defaultNodeBricks(e){(0,d.A)(ea,this,e)}get degradedThreshold(){return(0,h.A)(ta,this)}set degradedThreshold(e){(0,d.A)(ta,this,e)}get degradedNodeLabel(){return(0,h.A)(aa,this)}set degradedNodeLabel(e){(0,d.A)(aa,this,e)}get defaultEdgeLines(){return(0,h.A)(ia,this)}set defaultEdgeLines(e){(0,d.A)(ia,this,e)}get activeTarget(){return(0,h.A)(na,this)}set activeTarget(e){(0,d.A)(na,this,e)}get fadeUnrelatedCells(){return(0,h.A)(la,this)}set fadeUnrelatedCells(e){(0,d.A)(la,this,e)}get zoomable(){return(0,h.A)(sa,this)}set zoomable(e){(0,d.A)(sa,this,e)}get scrollable(){return(0,h.A)(oa,this)}set scrollable(e){(0,d.A)(oa,this,e)}get pannable(){return(0,h.A)(ra,this)}set pannable(e){(0,d.A)(ra,this,e)}get allowEdgeToArea(){return(0,h.A)(da,this)}set allowEdgeToArea(e){(0,d.A)(da,this,e)}get dragBehavior(){return(0,h.A)(ha,this)}set dragBehavior(e){(0,d.A)(ha,this,e)}get ctrlDragBehavior(){return(0,h.A)(ca,this)}set ctrlDragBehavior(e){(0,d.A)(ca,this,e)}get scaleRange(){return(0,h.A)(ua,this)}set scaleRange(e){(0,d.A)(ua,this,e)}get lineSettings(){return(0,h.A)(ga,this)}set lineSettings(e){(0,d.A)(ga,this,e)}get lineConnector(){return(0,h.A)(Aa,this)}set lineConnector(e){(0,d.A)(Aa,this,e)}get doNotResetActiveTargetForSelector(){return(0,h.A)(pa,this)}set doNotResetActiveTargetForSelector(e){(0,d.A)(pa,this,e)}get doNotResetActiveTargetOutsideCanvas(){return(0,h.A)(va,this)}set doNotResetActiveTargetOutsideCanvas(e){(0,d.A)(va,this,e)}async dropNode(e){var t,a;let{id:i,position:n,size:l,data:s,useBrick:o}=e;if(null===(t=(a=document).elementsFromPoint)||void 0===t||null===(t=t.call(a,n[0],n[1]))||void 0===t?void 0:t.includes(this)){var r,d,c;const e=this.getBoundingClientRect(),t=(0,h.A)(Va,this).current.getTransform(),a={type:"node",id:i,view:{..."force"===this.layout||"dagre"===this.layout?null:{x:(n[0]-e.left-t.x)/t.k,y:(n[1]-e.top-t.y)/t.k},width:null!==(r=null==l?void 0:l[0])&&void 0!==r?r:this.defaultNodeSize[0],height:null!==(d=null==l?void 0:l[1])&&void 0!==d?d:this.defaultNodeSize[0]},data:s,useBrick:o};return null===(c=(0,h.A)(Va,this).current)||void 0===c||c.dropNode(a),a}return null}async dropDecorator(e){var t,a;let{position:i,decorator:n,text:l,direction:s}=e;if(null===(t=(a=document).elementsFromPoint)||void 0===t||null===(t=t.call(a,i[0],i[1]))||void 0===t?void 0:t.includes(this)){var o;const e=this.getBoundingClientRect(),t=(0,h.A)(Va,this).current.getTransform(),a={type:"decorator",decorator:n,id:qa(),view:{x:(i[0]-e.left-t.x)/t.k,y:(i[1]-e.top-t.y)/t.k,width:R.N8,height:R.w1,text:l,direction:s}};return null===(o=(0,h.A)(Va,this).current)||void 0===o||o.dropDecorator(a),a}return null}async addNodes(e){if(0===e.length)return[];const t=e.map((e=>{var t,a;let{size:i,useBrick:n,id:l,data:s}=e;return{type:"node",id:l,data:s,view:{width:null!==(t=null==i?void 0:i[0])&&void 0!==t?t:this.defaultNodeSize[0],height:null!==(a=null==i?void 0:i[1])&&void 0!==a?a:this.defaultNodeSize[0]},useBrick:n}}));return(0,h.A)(Va,this).current.addNodes(t,{defaultNodeSize:this.defaultNodeSize,canvasWidth:this.clientWidth,canvasHeight:this.clientHeight})}async addEdge(e){var t;let{source:a,target:i,data:n}=e;const l={type:"edge",source:a,target:i,data:n,view:this.lineSettings};return null===(t=(0,h.A)(Va,this).current)||void 0===t||t.addEdge(l),l}manuallyConnectNodes(e){return(0,h.A)(Va,this).current.manuallyConnectNodes(e)}async updateCells(e,t){await(0,o.A)(Ca,this,Xa).call(this);const{updated:a}=(0,h.A)(Va,this).current.updateCells(e,{...t,defaultNodeSize:this.defaultNodeSize,canvasWidth:this.clientWidth,canvasHeight:this.clientHeight});return{updated:a}}async reCenter(){var e;null===(e=(0,h.A)(Va,this).current)||void 0===e||e.reCenter()}disconnectedCallback(){super.disconnectedCallback(),Ut(this,!1)}render(){return g().createElement(Yt,{host:this,ref:(0,h.A)(Va,this),layout:this.layout,layoutOptions:this.layoutOptions,cells:this.cells,defaultNodeSize:this.defaultNodeSize,defaultNodeBricks:this.defaultNodeBricks,defaultEdgeLines:this.defaultEdgeLines,degradedThreshold:this.degradedThreshold,degradedNodeLabel:this.degradedNodeLabel,activeTarget:this.activeTarget,fadeUnrelatedCells:this.fadeUnrelatedCells,zoomable:this.zoomable,scrollable:this.scrollable,pannable:this.pannable,dragBehavior:this.dragBehavior,ctrlDragBehavior:this.ctrlDragBehavior,scaleRange:this.scaleRange,lineSettings:this.lineSettings,lineConnector:this.lineConnector,allowEdgeToArea:this.allowEdgeToArea,doNotResetActiveTargetForSelector:this.doNotResetActiveTargetForSelector,doNotResetActiveTargetOutsideCanvas:this.doNotResetActiveTargetOutsideCanvas,onActiveTargetChange:(0,h.A)(wa,this),onSwitchActiveTarget:(0,h.A)(fa,this),onCellMove:(0,h.A)(ba,this),onCellsMove:(0,h.A)(Ea,this),onCellResize:(0,h.A)(Ta,this),onCellDelete:(0,h.A)(Sa,this),onCellsDelete:(0,h.A)(za,this),onEdgeAdd:(0,h.A)(Oa,this),onCellContextMenu:(0,h.A)(Ba,this),onDecoratorTextChange:(0,h.A)(Fa,this),onContainerContainerChange:(0,h.A)(Ka,this),onScaleChange:(0,h.A)(ja,this),onEdgeViewChange:(0,h.A)(Ha,this)})}}function Xa(){return new Promise((e=>{const t=()=>{(0,h.A)(Va,this).current?e():setTimeout(t,10)};t()}))}function Ya(e,t){let{host:a,layout:i,layoutOptions:n,cells:l,defaultNodeSize:s,defaultNodeBricks:o,defaultEdgeLines:r,degradedThreshold:d,degradedNodeLabel:h,activeTarget:c,fadeUnrelatedCells:A,zoomable:p,scrollable:v,pannable:C,dragBehavior:M,ctrlDragBehavior:K,scaleRange:U,lineSettings:J,lineConnector:Q,allowEdgeToArea:Z,doNotResetActiveTargetForSelector:ee,doNotResetActiveTargetOutsideCanvas:te,onActiveTargetChange:ae,onSwitchActiveTarget:ie,onCellMove:ne,onCellResize:le,onCellDelete:se,onCellsMove:oe,onCellsDelete:re,onCellContextMenu:de,onEdgeAdd:he,onDecoratorTextChange:ce,onScaleChange:ue,onContainerContainerChange:ge,onEdgeViewChange:Ae}=e;const[{cells:pe,layoutKey:ve},ye]=(0,u.useReducer)(m.d,l,(e=>({cells:(0,N.C)(e,{defaultNodeSize:s}),layoutKey:0}))),Ce=(0,u.useMemo)((()=>pe.filter(b.N).length>=(null!=d?d:R.pC)),[pe,d]),we=(0,u.useRef)(null),fe=(0,u.useRef)(null),[me,ke]=(0,u.useState)([]),[be,Me]=(0,u.useState)([]),{grabbing:Ee,transform:xe,zoomer:Te,scaleRange:Ne}=(0,z.f)({rootRef:we,zoomable:p,scrollable:v,pannable:C,draggable:"grab"===M,ctrlDraggable:"grab"===K,scaleRange:U,onSwitchActiveTarget:ie});(0,u.useEffect)((()=>{ue(xe.k)}),[ue,xe.k]);const[We,Se]=(0,u.useState)(null),[Re,ze]=(0,u.useState)(null),{centered:Le,setCentered:Be,getNextLayoutKey:De}=(0,D.g)({layout:i,layoutOptions:n,rootRef:we,cells:pe,zoomable:p,zoomer:Te,scaleRange:Ne,layoutKey:ve,allowEdgeToArea:Z,dispatch:ye}),Oe=(0,u.useCallback)((()=>{Be(!1)}),[Be]);(0,u.useImperativeHandle)(t,(()=>({dropNode(e){"dagre"!==i&&"force"!==i&&Be(!0),ye({type:"drop-node",payload:e})},dropDecorator(e){"dagre"!==i&&"force"!==i&&Be(!0),ye({type:"drop-decorator",payload:e})},addNodes(e,t){let{defaultNodeSize:a,canvasWidth:n,canvasHeight:l}=t;const s=pe.findLastIndex((e=>!("decorator"===e.type&&"text"===e.decorator)))+1,o=[...pe.slice(0,s),...e,...pe.slice(s)],{cells:r,updated:d,shouldReCenter:h}=(0,W.L)({cells:o,layout:i,previousCells:pe,defaultNodeSize:a,canvasWidth:n,canvasHeight:l,scaleRange:Ne,transform:xe,allowEdgeToArea:Z});return h&&Be(!1),ye({type:"update-cells",payload:r}),d.filter((t=>e.includes(t)))},addEdge(e){ye({type:"add-edge",payload:e})},updateCells(e,t){const{shouldReCenter:a,...n}=(0,W.L)({...t,layout:i,previousCells:pe,cells:e,scaleRange:Ne,transform:xe,allowEdgeToArea:Z});return a&&Be(!1),ye({type:"update-cells",payload:n.cells}),n},getTransform:()=>xe,manuallyConnectNodes(e){const t=pe.find((t=>(0,b.bo)(t,Z)&&t.id===e));if(t){const e=we.current.getBoundingClientRect();return ze({source:t,from:[t.view.x+t.view.width/2,t.view.y+t.view.height/2],offset:[e.left,e.top]}),new Promise(((e,t)=>{fe.current={resolve:e,reject:t}}))}return Promise.reject(null)},reCenter:Oe})),[pe,i,Ne,Be,xe,Z,Oe]);const Pe=(0,u.useCallback)(((e,t)=>{var a;for(let a=pe.length-1;a>=0;a--){const n=pe[a];if((0,b.bo)(n,Z)&&n.id!==e.source.id&&n.view.x<t[0]&&n.view.x+n.view.width>t[0]&&n.view.y<t[1]&&n.view.y+n.view.height>t[1]){var i;null===(i=fe.current)||void 0===i||i.resolve({source:e.source,target:n});break}}null===(a=fe.current)||void 0===a||a.reject(null),ze(null)}),[Z,pe]),[He,$e]=(0,u.useState)(null);(0,u.useEffect)((()=>{Ut(a,!!(Re||He||We))}),[Re,a,He,We]);const Fe=(0,L.J)({rootRef:we,activeTarget:c,doNotResetActiveTargetForSelector:ee,doNotResetActiveTargetOutsideCanvas:te,onActiveTargetChange:ae}),[_e,Ke]=(0,u.useState)([]);(0,u.useEffect)((()=>{const e=A?(0,S.Y)(pe,Re,Fe,Z):[];Ke((t=>0===t.length&&0===e.length?t:e))}),[Fe,pe,Re,A,Z]),(0,u.useEffect)((()=>{const e=we.current;if(!e||me.length>0)return;const t=e=>{const t=(0,E.a)(e,{cells:pe,activeTarget:Fe});"delete-cells"===(null==t?void 0:t.action)&&(re(t.cells),1===t.cells.length&&se(t.cells[0]))};return e.addEventListener("keydown",t),()=>{e.removeEventListener("keydown",t)}}),[Fe,pe,me.length,se,re]);const Ue=`${(0,u.useMemo)((()=>`${(0,y.uniqueId)("diagram-")}-`),[])}line-arrow-`,[je,Ve]=(0,u.useState)([]),Ie=(0,u.useCallback)((e=>{ye({type:"move-cells",payload:e});const t=[];(0,I._)(e,pe).forEach((e=>{var a,i;null!==(a=e.containerCell)&&void 0!==a&&a.id&&t.push(null===(i=e.containerCell)||void 0===i?void 0:i.id)})),Me(t),Ve(e.flatMap((e=>{var t;return null!==(t=e.guideLines)&&void 0!==t?t:[]})))}),[pe]),Xe=(0,u.useCallback)((e=>{ye({type:"move-cells",payload:e}),oe(e),1===e.length&&ne(e[0]),(0,I._)(e,pe,ge),Me([]),Ve([])}),[ne,oe,pe,ge]),Ye=(0,u.useCallback)((e=>{ye({type:"resize-cell",payload:e})}),[]),qe=(0,u.useCallback)((e=>{ye({type:"resize-cell",payload:e}),le(e)}),[le]),Ge=(0,u.useCallback)((e=>{let{id:t,editing:a}=e;ke(a?e=>e.includes(t)?e:[...e,t]:e=>e.filter((e=>e!==t)))}),[]),Je=(0,u.useCallback)(((e,t)=>{const a=De();ye({type:"update-node-size",payload:{id:e,size:t},layoutKey:a})}),[De]),Qe=(0,u.useCallback)((e=>{Te.scaleTo((0,f.A)(we.current),e/100)}),[Te]),{lineConfMap:Ze,lineConnectorConf:et,markers:tt}=(0,P.d)({cells:pe,defaultEdgeLines:r,lineConnector:Q,markerPrefix:Ue}),at=(0,q.A)({cells:pe,lineConfMap:Ze}),it=(0,u.useMemo)((()=>{let e;return"edge"===(null==Fe?void 0:Fe.type)&&(e=pe.find((e=>(0,G.Q)(e,Fe)))),e&&at.has(e)?e:null}),[Fe,pe,at]),nt=(0,O.H)({cells:pe,layout:i,centered:Le}),[lt,st]=(0,u.useState)(null),ot=(0,u.useRef)(null),[rt,dt]=(0,u.useState)(null),ht=(0,u.useCallback)((e=>{if(et&&(0,b.bo)(e,Z)&&(!rt||"control"!==rt.type)){null!==ot.current&&(clearTimeout(ot.current),ot.current=null);const t=(0,H.G)();st({cell:e,relativePoints:t,points:Ga(t,e.view)})}}),[Z,et,rt]),ct=(0,u.useCallback)((e=>{et&&(0,b.N)(e)&&(ot.current=setTimeout((()=>{st(null)})))}),[et]),ut=(0,u.useCallback)(((e,t,a,i)=>{const n={source:e.id,target:t.id,view:{...J,exitPosition:a,entryPosition:i,vertices:null}};if(pe.find((a=>"edge"===a.type&&a.source===e.id&&a.target===t.id)))ye({type:"change-edge-view",payload:n}),null==Ae||Ae(n);else{const a={type:"edge",...n};ye({type:"add-edge",payload:a}),he({source:e,target:t,view:a.view})}}),[pe,J,he,Ae]),gt=(0,u.useCallback)(((e,t,a)=>{const i={source:e.id,target:t.id,view:a};ye({type:"change-edge-view",payload:i}),null==Ae||Ae(i)}),[Ae]),At=(0,u.useMemo)((()=>({rootRef:we,smartConnectLineState:He,unsetHoverStateTimeoutRef:ot,hoverState:lt,activeEditableEdge:it,lineEditorState:rt,setLineEditorState:dt,setHoverState:st,setSmartConnectLineState:$e,onConnect:ut,onChangeEdgeView:gt})),[it,gt,ut,lt,rt,He]);return(0,u.useEffect)((()=>{const e=we.current;if(!e||"lasso"!==M)return;const t=e.getBoundingClientRect(),a=e=>{(0,_.F)(e,{transform:xe,offset:[t.left,t.top],onLassoing(e){Se(e)},onLassoed(e){Se(null);const t=[];for(const a of pe)if((0,b.t2)(a)||(0,b.o6)(a)||(0,b.Hs)(a)){const i=a.view.x,n=a.view.y;i>=e.x&&i+a.view.width<=e.x+e.width&&n>=e.y&&n+a.view.height<=e.y+e.height&&t.push(a)}null==ie||ie(t.length>1?{type:"multi",targets:t.map(V.P)}:1===t.length?(0,V.P)(t[0]):null)}})};return e.addEventListener("mousedown",a),()=>{e.removeEventListener("mousedown",a)}}),[xe,pe,M,ie]),g().createElement(F.H.Provider,{value:At},g().createElement("svg",{width:"100%",height:"100%",ref:we,className:w()("root",{grabbing:Ee,pannable:C,ready:nt}),tabIndex:-1},g().createElement("defs",null,tt.map(((e,t)=>g().createElement(k.c,{key:t,id:`${Ue}${t}`,type:e.markerType,strokeColor:e.strokeColor})))),g().createElement("g",{transform:`translate(${xe.x} ${xe.y}) scale(${xe.k})`},g().createElement("g",{className:w()("cells",{allowEdgeToArea:Z})},pe.map((e=>g().createElement(x.m,{key:`${e.type}:${(0,b.WW)(e)?`${e.source}~${e.target}`:e.id}`,dragNodeToContainerActive:!(0,b.WW)(e)&&be.includes(e.id),layout:i,layoutOptions:n,cell:e,cells:pe,degraded:Ce,degradedNodeLabel:h,defaultNodeBricks:o,transform:xe,lineConfMap:Ze,editableLineMap:at,activeTarget:Fe,unrelatedCells:_e,allowEdgeToArea:Z,onCellsMoving:Ie,onCellsMoved:Xe,onCellResizing:Ye,onCellResized:qe,onSwitchActiveTarget:ie,onCellContextMenu:de,onDecoratorTextChange:ce,onDecoratorTextEditing:Ge,onNodeBrickResize:Je,onCellMouseEnter:ht,onCellMouseLeave:ct})))),g().createElement("g",null,g().createElement(T.w,{connectLineState:Re,transform:xe,markerEnd:`${Ue}0`,onConnect:Pe})),We&&g().createElement("rect",{x:We.x,y:We.y,width:We.width,height:We.height,fill:"var(--palette-gray-5)",fillOpacity:.3,stroke:"var(--palette-gray-5)",strokeDasharray:2}),et&&g().createElement("g",null,g().createElement(j.X,{transform:xe,lineSettings:J,options:et}),g().createElement(Y.W,{cells:pe,editableLineMap:at,transform:xe,options:et})),g().createElement("g",null,je.map(((e,t)=>g().createElement("path",{key:t,d:`M${e[0].join(" ")} L${e[1].join(" ")}`,stroke:"var(--palette-orange-5)",fill:"none",strokeWidth:1/xe.k})))),g().createElement("g",null,et&&g().createElement(X.F,{editableLineMap:at,scale:xe.k})),et&&g().createElement($.T,{activeTarget:Fe,editableLineMap:at,scale:xe.k,disabled:!!Re}))),g().createElement(B.Y,{shadowRoot:a.shadowRoot,scale:xe.k,scaleRange:Ne,onZoomChange:Qe,onReCenter:Oe}))}function qa(){return"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g,(function(e){const t=16*Math.random()|0;return("x"==e?t:3&t|8).toString(16)}))}function Ga(e,t){let a=arguments.length>2&&void 0!==arguments[2]?arguments[2]:1;const i=R.XK,n=i/2,l=t.x+a/2-n,s=t.y+a/2-n,o=t.width-a+i,r=t.height-a+i;return e.map((e=>({x:l+e.x*o,y:s+e.y*r})))}i=Ia,({e:[Z,ee,te,ae,ie,ne,le,se,oe,re,de,he,ce,ue,ge,Ae,pe,ve,ye,Ce,we,fe,me,ke,be,Me,Ee,xe,Te,Ne,We,Se,Re,ze,Le,Be,De,Oe,Pe,He,$e,Fe,_e,Ke,Ue,je,Ve,Ie,Xe,Ye,qe,Ge,Je,Qe,Ze,et,tt,at,it,nt,lt,st,ot,rt,dt,ht,ct,ut,gt,At,pt,vt,yt,Ct,wt,ft,mt,kt,bt,Mt,Et,xt,Tt,Nt,Wt,St,Rt,zt,Lt,Bt,Dt,Ot,Pt,Ht,$t,Ft,_t,Kt,J],c:[qt,Q]}=(0,c.A)(i,[jt("eo-draw-canvas",{styleTexts:[K.A,U.A]})],[[Vt({attribute:!1}),1,"cells"],[Vt({type:String}),1,"layout"],[Vt({attribute:!1}),1,"layoutOptions"],[Vt({attribute:!1}),1,"defaultNodeSize"],[Vt({attribute:!1}),1,"defaultNodeBricks"],[Vt({type:Number}),1,"degradedThreshold"],[Vt({attribute:!1}),1,"degradedNodeLabel"],[Vt({attribute:!1}),1,"defaultEdgeLines"],[Vt({attribute:!1}),1,"activeTarget"],[Vt({type:Boolean}),1,"fadeUnrelatedCells"],[Vt({type:Boolean}),1,"zoomable"],[Vt({type:Boolean}),1,"scrollable"],[Vt({type:Boolean}),1,"pannable"],[Vt({type:Boolean}),1,"allowEdgeToArea"],[Vt(),1,"dragBehavior"],[Vt(),1,"ctrlDragBehavior"],[Vt({attribute:!1}),1,"scaleRange"],[Vt({attribute:!1}),1,"lineSettings"],[Vt({attribute:!1}),1,"lineConnector"],[Vt(),1,"doNotResetActiveTargetForSelector"],[Vt({type:Boolean}),1,"doNotResetActiveTargetOutsideCanvas"],[Xt({type:"activeTarget.change"}),1,"activeTargetChangeEvent",e=>(0,h.A)(ya,e),(e,t)=>(0,d.A)(ya,e,t)],[Xt({type:"node.move"}),1,"nodeMoveEvent",e=>(0,h.A)(ma,e),(e,t)=>(0,d.A)(ma,e,t)],[Xt({type:"cell.move"}),1,"cellMoveEvent",e=>(0,h.A)(ka,e),(e,t)=>(0,d.A)(ka,e,t)],[Xt({type:"cells.move"}),1,"cellsMoveEvent",e=>(0,h.A)(Ma,e),(e,t)=>(0,d.A)(Ma,e,t)],[Xt({type:"cell.resize"}),1,"cellResizeEvent",e=>(0,h.A)(xa,e),(e,t)=>(0,d.A)(xa,e,t)],[Xt({type:"node.delete"}),1,"nodeDelete",e=>(0,h.A)(Na,e),(e,t)=>(0,d.A)(Na,e,t)],[Xt({type:"cell.delete"}),1,"cellDelete",e=>(0,h.A)(Wa,e),(e,t)=>(0,d.A)(Wa,e,t)],[Xt({type:"cells.delete"}),1,"cellsDelete",e=>(0,h.A)(Ra,e),(e,t)=>(0,d.A)(Ra,e,t)],[Xt({type:"cell.contextmenu"}),1,"cellContextMenu",e=>(0,h.A)(La,e),(e,t)=>(0,d.A)(La,e,t)],[Xt({type:"edge.add"}),1,"edgeAdd",e=>(0,h.A)(Da,e),(e,t)=>(0,d.A)(Da,e,t)],[Xt({type:"edge.view.change"}),1,"edgeViewChange",e=>(0,h.A)(Pa,e),(e,t)=>(0,d.A)(Pa,e,t)],[Xt({type:"decorator.text.change"}),1,"decoratorTextChange",e=>(0,h.A)($a,e),(e,t)=>(0,d.A)($a,e,t)],[Xt({type:"node.container.change"}),1,"containerContainerChange",e=>(0,h.A)(_a,e),(e,t)=>(0,d.A)(_a,e,t)],[Xt({type:"scale.change"}),1,"scaleChange",e=>(0,h.A)(Ua,e),(e,t)=>(0,d.A)(Ua,e,t)],[It(),2,"dropNode"],[It(),2,"dropDecorator"],[It(),2,"addNodes"],[It(),2,"addEdge"],[It(),2,"manuallyConnectNodes"],[It(),2,"updateCells"],[It(),2,"reCenter"]],0,(e=>Va.has((0,s.A)(e))),p.ReactNextElement)),Q()}}]);
2
+ //# sourceMappingURL=eo-draw-canvas.2f912dba.js.map