@next-bricks/diagram 0.42.3 → 0.42.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.
- package/dist/bricks.json +5 -5
- package/dist/chunks/{1371.69ab52e0.js → 1371.f4b9a35d.js} +2 -2
- package/dist/chunks/{1371.69ab52e0.js.map → 1371.f4b9a35d.js.map} +1 -1
- package/dist/chunks/1889.1d67080e.js +2 -0
- package/dist/chunks/1889.1d67080e.js.map +1 -0
- package/dist/chunks/{2416.80f13b05.js → 2416.ebd9d2e4.js} +2 -2
- package/dist/chunks/{2416.80f13b05.js.map → 2416.ebd9d2e4.js.map} +1 -1
- package/dist/chunks/{3533.c55d2951.js → 3533.d9e236bb.js} +3 -3
- package/dist/chunks/3533.d9e236bb.js.map +1 -0
- package/dist/chunks/{4017.5d5f544d.js → 4017.3be5f2b8.js} +3 -3
- package/dist/chunks/{4017.5d5f544d.js.map → 4017.3be5f2b8.js.map} +1 -1
- package/dist/chunks/{4837.3951d2a2.js → 4837.45d51370.js} +2 -2
- package/dist/chunks/{4837.3951d2a2.js.map → 4837.45d51370.js.map} +1 -1
- package/dist/chunks/{7218.1a60c523.js → 7218.deb33f60.js} +2 -2
- package/dist/chunks/{7218.1a60c523.js.map → 7218.deb33f60.js.map} +1 -1
- package/dist/chunks/{editable-label.54bc7004.js → editable-label.48c0b927.js} +3 -3
- package/dist/chunks/{editable-label.54bc7004.js.map → editable-label.48c0b927.js.map} +1 -1
- package/dist/chunks/{eo-diagram.88025819.js → eo-diagram.7a793a39.js} +2 -2
- package/dist/chunks/{eo-diagram.88025819.js.map → eo-diagram.7a793a39.js.map} +1 -1
- package/dist/chunks/{eo-display-canvas.da51ba14.js → eo-display-canvas.431eb9f3.js} +2 -2
- package/dist/chunks/{eo-display-canvas.da51ba14.js.map → eo-display-canvas.431eb9f3.js.map} +1 -1
- package/dist/chunks/{eo-draw-canvas.ffc4b526.js → eo-draw-canvas.1a42c1af.js} +2 -2
- package/dist/chunks/{eo-draw-canvas.ffc4b526.js.map → eo-draw-canvas.1a42c1af.js.map} +1 -1
- package/dist/chunks/{experimental-node.33c53c19.js → experimental-node.b7fc05ff.js} +2 -2
- package/dist/chunks/{experimental-node.33c53c19.js.map → experimental-node.b7fc05ff.js.map} +1 -1
- package/dist/chunks/{main.5262e1e2.js → main.5ad8bc12.js} +2 -2
- package/dist/chunks/{main.5262e1e2.js.map → main.5ad8bc12.js.map} +1 -1
- package/dist/examples.json +3 -3
- package/dist/{index.b51e0a33.js → index.dccf2262.js} +2 -2
- package/dist/{index.b51e0a33.js.map → index.dccf2262.js.map} +1 -1
- package/dist/manifest.json +145 -145
- package/dist/types.json +3715 -3715
- package/package.json +2 -2
- package/dist/chunks/1889.a9c5273d.js +0 -2
- package/dist/chunks/1889.a9c5273d.js.map +0 -1
- package/dist/chunks/3533.c55d2951.js.map +0 -1
- /package/dist/chunks/{3533.c55d2951.js.LICENSE.txt → 3533.d9e236bb.js.LICENSE.txt} +0 -0
- /package/dist/chunks/{4017.5d5f544d.js.LICENSE.txt → 4017.3be5f2b8.js.LICENSE.txt} +0 -0
- /package/dist/chunks/{editable-label.54bc7004.js.LICENSE.txt → editable-label.48c0b927.js.LICENSE.txt} +0 -0
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";(globalThis.webpackChunk_next_bricks_diagram=globalThis.webpackChunk_next_bricks_diagram||[]).push([[9823,8939],{6094:(e,t,a)=>{a.r(t),a.d(t,{EoDisplayCanvas:()=>xe});var l,s=a(4635),i=a(918),n=a(6902),o=a(5536),r=a(6121),d=a(829),h=a(2740),c=a(8769),u=a.n(c),g=a(4782),A=a(1389),p=(a(9583),a(1030)),y=a(3373),f=a.n(y),v=a(7566),k=a(3739),w=a(8185),m=a(2140),C=a(3783),b=a(3033),M=a(8091),N=a(1819),x=a(5748),W=a(227),E=a(531),T=a(7099),R=a(1484),z=a(8197),S=a(7531),B=a(2098),L=a(3012),D=a(6237);let $,H,O,P,U,K,_,I,F,Y,j,q,J,Z,V,G,Q,X,ee,te,ae,le,se,ie,ne,oe,re,de,he,ce,ue,ge,Ae,pe,ye,fe,ve,ke,we,me,Ce;const{defineElement:be,property:Me,event:Ne}=(0,g.createDecorators)();let xe;var We=new WeakMap,Ee=new WeakMap,Te=new WeakMap,Re=new WeakMap,ze=new WeakMap,Se=new WeakMap,Be=new WeakMap,Le=new WeakMap,De=new WeakMap,$e=new WeakMap,He=new WeakMap,Oe=new WeakMap,Pe=new WeakMap,Ue=new WeakMap,Ke=new WeakMap,_e=new WeakSet,Ie=new WeakMap,Fe=new WeakMap,Ye=new WeakMap,je=new WeakMap,qe=new WeakMap,Je=new WeakMap;class Ze extends A.ReactNextElement{constructor(){super(...arguments),(0,s.A)(this,_e),(0,i.A)(this,We,H(this)),(0,i.A)(this,Ee,(O(this),P(this))),(0,i.A)(this,Te,(U(this),K(this))),(0,i.A)(this,Re,(_(this),I(this,[b.HP,b.HP]))),(0,i.A)(this,ze,(F(this),Y(this))),(0,i.A)(this,Se,(j(this),q(this))),(0,i.A)(this,Be,(J(this),Z(this))),(0,i.A)(this,Le,(V(this),G(this))),(0,i.A)(this,De,(Q(this),X(this))),(0,i.A)(this,$e,(ee(this),te(this))),(0,i.A)(this,He,(ae(this),le(this,!0))),(0,i.A)(this,Oe,(se(this),ie(this,!0))),(0,i.A)(this,Pe,(ne(this),oe(this,!0))),(0,i.A)(this,Ue,(re(this),de(this))),(0,i.A)(this,Ke,(he(this),ce(this))),(0,i.A)(this,Ie,(Ae(this),e=>{(0,o.A)(_e,this,ue).emit(e)})),(0,i.A)(this,Fe,(e=>{(0,w.c)(e,this.activeTarget)||(this.activeTarget=e)})),(0,i.A)(this,Ye,pe(this)),(0,i.A)(this,je,(ve(this),e=>{(0,o.A)(_e,this,ye).emit(e)})),(0,i.A)(this,qe,ke(this)),(0,i.A)(this,Je,(Ce(this),e=>{(0,o.A)(_e,this,we).emit(e)}))}get cells(){return(0,d.A)(We,this)}set cells(e){(0,r.A)(We,this,e)}get layout(){return(0,d.A)(Ee,this)}set layout(e){(0,r.A)(Ee,this,e)}get layoutOptions(){return(0,d.A)(Te,this)}set layoutOptions(e){(0,r.A)(Te,this,e)}get defaultNodeSize(){return(0,d.A)(Re,this)}set defaultNodeSize(e){(0,r.A)(Re,this,e)}get defaultNodeBricks(){return(0,d.A)(ze,this)}set defaultNodeBricks(e){(0,r.A)(ze,this,e)}get degradedThreshold(){return(0,d.A)(Se,this)}set degradedThreshold(e){(0,r.A)(Se,this,e)}get degradedNodeLabel(){return(0,d.A)(Be,this)}set degradedNodeLabel(e){(0,r.A)(Be,this,e)}get defaultEdgeLines(){return(0,d.A)(Le,this)}set defaultEdgeLines(e){(0,r.A)(Le,this,e)}get activeTarget(){return(0,d.A)(De,this)}set activeTarget(e){(0,r.A)(De,this,e)}get fadeUnrelatedCells(){return(0,d.A)($e,this)}set fadeUnrelatedCells(e){(0,r.A)($e,this,e)}get zoomable(){return(0,d.A)(He,this)}set zoomable(e){(0,r.A)(He,this,e)}get scrollable(){return(0,d.A)(Oe,this)}set scrollable(e){(0,r.A)(Oe,this,e)}get pannable(){return(0,d.A)(Pe,this)}set pannable(e){(0,r.A)(Pe,this,e)}get scaleRange(){return(0,d.A)(Ue,this)}set scaleRange(e){(0,r.A)(Ue,this,e)}render(){return u().createElement(Ve,{shadowRoot:this.shadowRoot,cells:this.cells,layout:this.layout,layoutOptions:this.layoutOptions,defaultNodeSize:this.defaultNodeSize,defaultNodeBricks:this.defaultNodeBricks,defaultEdgeLines:this.defaultEdgeLines,degradedThreshold:this.degradedThreshold,degradedNodeLabel:this.degradedNodeLabel,activeTarget:this.activeTarget,fadeUnrelatedCells:this.fadeUnrelatedCells,zoomable:this.zoomable,scrollable:this.scrollable,pannable:this.pannable,scaleRange:this.scaleRange,onActiveTargetChange:(0,d.A)(Ie,this),onSwitchActiveTarget:(0,d.A)(Fe,this),onCellContextMenu:(0,d.A)(je,this),onCellClick:(0,d.A)(Je,this)})}}function Ve(e){let{shadowRoot:t,cells:a,layout:l,layoutOptions:s,defaultNodeSize:i,defaultNodeBricks:n,defaultEdgeLines:o,degradedThreshold:r,degradedNodeLabel:d,activeTarget:h,fadeUnrelatedCells:g,zoomable:A,scrollable:y,pannable:w,scaleRange:L,onActiveTargetChange:D,onSwitchActiveTarget:$,onCellContextMenu:H,onCellClick:O}=e;const[{cells:P,layoutKey:U},K]=(0,c.useReducer)(x.d,a,(e=>({cells:(0,C.C)(e,{defaultNodeSize:i}),layoutKey:1}))),_=(0,c.useMemo)((()=>P.filter(E.N).length>=(r??b.pC)),[P,r]),I=(0,c.useRef)(null),F=(0,c.useRef)(null),{grabbing:Y,transform:j,zoomer:q,scaleRange:J}=(0,M.f)({rootRef:I,zoomable:A,scrollable:y,pannable:w,draggable:!0,scaleRange:L,onSwitchActiveTarget:$}),{centered:Z,setCentered:V,getNextLayoutKey:G}=(0,R.g)({layout:l,layoutOptions:s,rootRef:I,cells:P,zoomable:A,zoomer:q,scaleRange:J,layoutKey:U,dispatch:K}),Q=(0,c.useCallback)((()=>{V(!1)}),[V]),X=(0,c.useRef)(a);(0,c.useEffect)((()=>{if(a!==X.current){X.current=a;const e=(0,B.L)({canvasWidth:t.host.clientWidth,canvasHeight:t.host.clientHeight,defaultNodeSize:i,layout:l,previousCells:P,cells:a,scaleRange:J,transform:j});K({type:"update-cells",payload:e.cells})}}),[P,i,a,l,J,t,j]);const ee=(0,N.J)({cellsRef:F,activeTarget:h,onActiveTargetChange:D}),te=`${(0,c.useMemo)((()=>`${(0,p.uniqueId)("diagram-")}-`),[])}line-arrow-`,ae=(0,c.useCallback)(((e,t)=>{K({type:"update-node-size",payload:{id:e,size:t},layoutKey:G()})}),[G]),[le,se]=(0,c.useState)(null),ie=(0,c.useCallback)((e=>{se(e)}),[]),ne=(0,c.useCallback)((e=>{se((t=>t===e?null:t))}),[]),[oe,re]=(0,c.useState)([]);(0,c.useEffect)((()=>{const e=g?(0,W.Y)(P,null,le):[];re((t=>0===t.length&&0===e.length?t:e))}),[P,g,le]);const de=(0,c.useCallback)((e=>{q.scaleTo((0,v.A)(I.current),e/100)}),[q]),[he,ce]=(0,S.d)({cells:P,defaultEdgeLines:o,markerPrefix:te}),ue=(0,z.H)({cells:P,layout:l,centered:Z});return u().createElement(u().Fragment,null,u().createElement("svg",{width:"100%",height:"100%",ref:I,className:f()("root",{grabbing:Y,pannable:w,ready:ue}),tabIndex:-1},u().createElement("defs",null,ce.map(((e,t)=>u().createElement(k.c,{key:t,id:`${te}${t}`,type:"arrow",strokeColor:e.strokeColor})))),u().createElement("g",{transform:`translate(${j.x} ${j.y}) scale(${j.k})`},u().createElement("g",{className:"cells",ref:F},P.map((e=>u().createElement(m.m,{key:`${e.type}:${(0,E.WW)(e)?`${e.source}~${e.target}`:e.id}`,layout:l,cell:e,cells:P,degraded:_,degradedNodeLabel:d,defaultNodeBricks:n,lineConfMap:he,transform:j,activeTarget:ee,readOnly:!0,unrelatedCells:oe,onSwitchActiveTarget:$,onCellContextMenu:H,onCellClick:O,onNodeBrickResize:ae,onCellMouseEnter:g&&(0,E.N)(e)?ie:void 0,onCellMouseLeave:g&&(0,E.N)(e)?ne:void 0})))))),u().createElement(T.Y,{shadowRoot:t,scale:j.k,scaleRange:J,onZoomChange:de,onReCenter:Q}))}l=Ze,({e:[H,O,P,U,K,_,I,F,Y,j,q,J,Z,V,G,Q,X,ee,te,ae,le,se,ie,ne,oe,re,de,he,ce,ue,ge,Ae,pe,ye,fe,ve,ke,we,me,Ce],c:[xe,$]}=(0,h.A)(l,[be("eo-display-canvas",{styleTexts:[L.A,D.A]})],[[Me({attribute:!1}),1,"cells"],[Me({type:String}),1,"layout"],[Me({attribute:!1}),1,"layoutOptions"],[Me({attribute:!1}),1,"defaultNodeSize"],[Me({attribute:!1}),1,"defaultNodeBricks"],[Me({type:Number}),1,"degradedThreshold"],[Me({attribute:!1}),1,"degradedNodeLabel"],[Me({attribute:!1}),1,"defaultEdgeLines"],[Me({attribute:!1}),1,"activeTarget"],[Me({type:Boolean}),1,"fadeUnrelatedCells"],[Me({type:Boolean}),1,"zoomable"],[Me({type:Boolean}),1,"scrollable"],[Me({type:Boolean}),1,"pannable"],[Me({attribute:!1}),1,"scaleRange"],[Ne({type:"activeTarget.change"}),1,"activeTargetChangeEvent",e=>(0,d.A)(Ke,e),(e,t)=>(0,r.A)(Ke,e,t)],[Ne({type:"cell.contextmenu"}),1,"cellContextMenu",e=>(0,d.A)(Ye,e),(e,t)=>(0,r.A)(Ye,e,t)],[Ne({type:"cell.click"}),1,"cellClick",e=>(0,d.A)(qe,e),(e,t)=>(0,r.A)(qe,e,t)]],0,(e=>Je.has((0,n.A)(e))),A.ReactNextElement)),$()},9068:(e,t,a)=>{a.r(t),a.d(t,{EoDrawCanvas:()=>Wt,EoDrawCanvasComponent:()=>xt,uuidV4:()=>wa});var l,s=a(4635),i=a(918),n=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(4782),p=a(1389),y=a(3518),f=(a(9583),a(1030)),v=a(3373),k=a.n(v),w=a(7566),m=a(5748),C=a(3739),b=a(531),M=a(8185),N=a(5114),x=a(2140),W=a(3639),E=a(3783),T=a(2098),R=a(227),z=a(3033),S=a(8091),B=a(1819),L=a(7099),D=a(1484),$=a(8197),H=a(7531),O=a(2219),P=a(3012),U=a(6237),K=a(9386),_=a(1991);let I,F,Y,j,q,J,Z,V,G,Q,X,ee,te,ae,le,se,ie,ne,oe,re,de,he,ce,ue,ge,Ae,pe,ye,fe,ve,ke,we,me,Ce,be,Me,Ne,xe,We,Ee,Te,Re,ze,Se,Be,Le,De,$e,He,Oe,Pe,Ue,Ke,_e,Ie,Fe,Ye,je,qe,Je,Ze,Ve,Ge,Qe,Xe,et,tt,at,lt,st,it,nt,ot,rt,dt,ht,ct,ut,gt,At,pt,yt,ft,vt,kt,wt;const mt=(0,y.unwrapProvider)("basic.lock-body-scroll"),{defineElement:Ct,property:bt,method:Mt,event:Nt}=(0,A.createDecorators)(),xt=g().forwardRef(ka);let Wt;var Et=new WeakMap,Tt=new WeakMap,Rt=new WeakMap,zt=new WeakMap,St=new WeakMap,Bt=new WeakMap,Lt=new WeakMap,Dt=new WeakMap,$t=new WeakMap,Ht=new WeakMap,Ot=new WeakMap,Pt=new WeakMap,Ut=new WeakMap,Kt=new WeakMap,_t=new WeakMap,It=new WeakMap,Ft=new WeakMap,Yt=new WeakMap,jt=new WeakMap,qt=new WeakSet,Jt=new WeakMap,Zt=new WeakMap,Vt=new WeakMap,Gt=new WeakMap,Qt=new WeakMap,Xt=new WeakMap,ea=new WeakMap,ta=new WeakMap,aa=new WeakMap,la=new WeakMap,sa=new WeakMap,ia=new WeakMap,na=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,ya=new WeakMap;class fa extends p.ReactNextElement{constructor(){super(...arguments),(0,s.A)(this,qt),(0,i.A)(this,Et,(I(this),Y(this))),(0,i.A)(this,Tt,(j(this),q(this))),(0,i.A)(this,Rt,(J(this),Z(this))),(0,i.A)(this,zt,(V(this),G(this,[z.HP,z.HP]))),(0,i.A)(this,St,(Q(this),X(this))),(0,i.A)(this,Bt,(ee(this),te(this))),(0,i.A)(this,Lt,(ae(this),le(this))),(0,i.A)(this,Dt,(se(this),ie(this))),(0,i.A)(this,$t,(ne(this),oe(this))),(0,i.A)(this,Ht,(re(this),de(this))),(0,i.A)(this,Ot,(he(this),ce(this,!0))),(0,i.A)(this,Pt,(ue(this),ge(this,!0))),(0,i.A)(this,Ut,(Ae(this),pe(this,!0))),(0,i.A)(this,Kt,(ye(this),fe(this,!0))),(0,i.A)(this,_t,(ve(this),ke(this,!1))),(0,i.A)(this,It,(we(this),me(this))),(0,i.A)(this,Ft,(Ce(this),be(this))),(0,i.A)(this,Yt,(Me(this),Ne(this))),(0,i.A)(this,jt,(xe(this),We(this))),(0,i.A)(this,Jt,(Re(this),e=>{(0,r.A)(qt,this,Ee).emit(e)})),(0,i.A)(this,Zt,(e=>{(0,M.c)(e,this.activeTarget)||(this.activeTarget=e)})),(0,i.A)(this,Vt,ze(this)),(0,i.A)(this,Gt,(Le(this),De(this))),(0,i.A)(this,Qt,(Oe(this),e=>{(0,r.A)(qt,this,$e).emit(e),"node"===e.type&&(0,r.A)(qt,this,Se).emit(e)})),(0,i.A)(this,Xt,Pe(this)),(0,i.A)(this,ea,(_e(this),e=>{(0,r.A)(qt,this,Ue).emit(e)})),(0,i.A)(this,ta,Ie(this)),(0,i.A)(this,aa,(je(this),e=>{(0,r.A)(qt,this,Fe).emit(e)})),(0,i.A)(this,la,qe(this)),(0,i.A)(this,sa,(Ve(this),Ge(this))),(0,i.A)(this,ia,(et(this),e=>{(0,r.A)(qt,this,Qe).emit(e),"node"===e.type&&(0,r.A)(qt,this,Je).emit(e)})),(0,i.A)(this,na,tt(this)),(0,i.A)(this,oa,(st(this),e=>{(0,r.A)(qt,this,at).emit(e)})),(0,i.A)(this,ra,it(this)),(0,i.A)(this,da,(rt(this),e=>{(0,r.A)(qt,this,nt).emit(e)})),(0,i.A)(this,ha,dt(this)),(0,i.A)(this,ca,(ut(this),e=>{(0,r.A)(qt,this,ht).emit(e)})),(0,i.A)(this,ua,gt(this)),(0,i.A)(this,ga,(yt(this),e=>{(0,r.A)(qt,this,At).emit(e)})),(0,i.A)(this,Aa,ft(this)),(0,i.A)(this,pa,(wt(this),e=>{(0,r.A)(qt,this,vt).emit(e)})),(0,i.A)(this,ya,(0,u.createRef)())}get cells(){return(0,h.A)(Et,this)}set cells(e){(0,d.A)(Et,this,e)}get layout(){return(0,h.A)(Tt,this)}set layout(e){(0,d.A)(Tt,this,e)}get layoutOptions(){return(0,h.A)(Rt,this)}set layoutOptions(e){(0,d.A)(Rt,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)(St,this)}set defaultNodeBricks(e){(0,d.A)(St,this,e)}get degradedThreshold(){return(0,h.A)(Bt,this)}set degradedThreshold(e){(0,d.A)(Bt,this,e)}get degradedNodeLabel(){return(0,h.A)(Lt,this)}set degradedNodeLabel(e){(0,d.A)(Lt,this,e)}get defaultEdgeLines(){return(0,h.A)(Dt,this)}set defaultEdgeLines(e){(0,d.A)(Dt,this,e)}get activeTarget(){return(0,h.A)($t,this)}set activeTarget(e){(0,d.A)($t,this,e)}get fadeUnrelatedCells(){return(0,h.A)(Ht,this)}set fadeUnrelatedCells(e){(0,d.A)(Ht,this,e)}get zoomable(){return(0,h.A)(Ot,this)}set zoomable(e){(0,d.A)(Ot,this,e)}get scrollable(){return(0,h.A)(Pt,this)}set scrollable(e){(0,d.A)(Pt,this,e)}get pannable(){return(0,h.A)(Ut,this)}set pannable(e){(0,d.A)(Ut,this,e)}get selectable(){return(0,h.A)(Kt,this)}set selectable(e){(0,d.A)(Kt,this,e)}get allowEdgeToArea(){return(0,h.A)(_t,this)}set allowEdgeToArea(e){(0,d.A)(_t,this,e)}get dragBehavior(){return(0,h.A)(It,this)}set dragBehavior(e){(0,d.A)(It,this,e)}get ctrlDragBehavior(){return(0,h.A)(Ft,this)}set ctrlDragBehavior(e){(0,d.A)(Ft,this,e)}get scaleRange(){return(0,h.A)(Yt,this)}set scaleRange(e){(0,d.A)(Yt,this,e)}async dropNode(e){var t,a;let{id:l,position:s,size:i,data:n,useBrick:o}=e;if(null===(t=(a=document).elementsFromPoint)||void 0===t||null===(t=t.call(a,s[0],s[1]))||void 0===t?void 0:t.includes(this)){var r;const e=this.getBoundingClientRect(),t=(0,h.A)(ya,this).current.getTransform(),a={type:"node",id:l,view:{..."force"===this.layout||"dagre"===this.layout?null:{x:(s[0]-e.left-t.x)/t.k,y:(s[1]-e.top-t.y)/t.k},width:(null==i?void 0:i[0])??this.defaultNodeSize[0],height:(null==i?void 0:i[1])??this.defaultNodeSize[0]},data:n,useBrick:o};return null===(r=(0,h.A)(ya,this).current)||void 0===r||r.dropNode(a),a}return null}async dropDecorator(e){var t,a;let{position:l,decorator:s,text:i,direction:n}=e;if(null===(t=(a=document).elementsFromPoint)||void 0===t||null===(t=t.call(a,l[0],l[1]))||void 0===t?void 0:t.includes(this)){var o;const e=this.getBoundingClientRect(),t=(0,h.A)(ya,this).current.getTransform(),a={type:"decorator",decorator:s,id:wa(),view:{x:(l[0]-e.left-t.x)/t.k,y:(l[1]-e.top-t.y)/t.k,width:z.N8,height:z.w1,text:i,direction:n}};return null===(o=(0,h.A)(ya,this).current)||void 0===o||o.dropDecorator(a),a}return null}async addNodes(e){if(0===e.length)return[];const t=e.map((e=>{let{size:t,useBrick:a,id:l,data:s}=e;return{type:"node",id:l,data:s,view:{width:(null==t?void 0:t[0])??this.defaultNodeSize[0],height:(null==t?void 0:t[1])??this.defaultNodeSize[0]},useBrick:a}}));return(0,h.A)(ya,this).current.addNodes(t,{defaultNodeSize:this.defaultNodeSize,canvasWidth:this.clientWidth,canvasHeight:this.clientHeight})}async addEdge(e){var t;let{source:a,target:l,data:s}=e;const i={type:"edge",source:a,target:l,data:s};return null===(t=(0,h.A)(ya,this).current)||void 0===t||t.addEdge(i),i}manuallyConnectNodes(e){return(0,h.A)(ya,this).current.manuallyConnectNodes(e)}async updateCells(e,t){await(0,o.A)(qt,this,va).call(this);const{updated:a}=(0,h.A)(ya,this).current.updateCells(e,{...t,defaultNodeSize:this.defaultNodeSize,canvasWidth:this.clientWidth,canvasHeight:this.clientHeight});return{updated:a}}disconnectedCallback(){super.disconnectedCallback(),mt(this,!1)}render(){return g().createElement(xt,{host:this,ref:(0,h.A)(ya,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,allowEdgeToArea:this.allowEdgeToArea,onActiveTargetChange:(0,h.A)(Jt,this),onSwitchActiveTarget:(0,h.A)(Zt,this),onCellMove:(0,h.A)(Qt,this),onCellsMove:(0,h.A)(ea,this),onCellResize:(0,h.A)(aa,this),onCellDelete:(0,h.A)(ia,this),onCellsDelete:(0,h.A)(oa,this),onCellContextMenu:(0,h.A)(da,this),onDecoratorTextChange:(0,h.A)(ca,this),onContainerContainerChange:(0,h.A)(ga,this),onScaleChange:(0,h.A)(pa,this)})}}function va(){return new Promise((e=>{const t=()=>{(0,h.A)(ya,this).current?e():setTimeout(t,10)};t()}))}function ka(e,t){let{host:a,layout:l,layoutOptions:s,cells:i,defaultNodeSize:n,defaultNodeBricks:o,defaultEdgeLines:r,degradedThreshold:d,degradedNodeLabel:h,activeTarget:c,fadeUnrelatedCells:A,zoomable:p,scrollable:y,pannable:v,dragBehavior:M,ctrlDragBehavior:P,scaleRange:U,allowEdgeToArea:I,onActiveTargetChange:F,onSwitchActiveTarget:Y,onCellMove:j,onCellResize:q,onCellDelete:J,onCellsMove:Z,onCellsDelete:V,onCellContextMenu:G,onDecoratorTextChange:Q,onScaleChange:X,onContainerContainerChange:ee}=e;const[{cells:te,layoutKey:ae},le]=(0,u.useReducer)(m.d,i,(e=>({cells:(0,E.C)(e,{defaultNodeSize:n}),layoutKey:0}))),se=(0,u.useMemo)((()=>te.filter(b.N).length>=(d??z.pC)),[te,d]),ie=(0,u.useRef)(null),ne=(0,u.useRef)(null),oe=(0,u.useRef)(null),[re,de]=(0,u.useState)([]),[he,ce]=(0,u.useState)([]),{grabbing:ue,transform:ge,zoomer:Ae,scaleRange:pe}=(0,S.f)({rootRef:ie,zoomable:p,scrollable:y,pannable:v,draggable:"grab"===M,ctrlDraggable:"grab"===P,scaleRange:U,onSwitchActiveTarget:Y});(0,u.useEffect)((()=>{X(ge.k)}),[X,ge.k]);const[ye,fe]=(0,u.useState)(null),[ve,ke]=(0,u.useState)(null),{centered:we,setCentered:me,getNextLayoutKey:Ce}=(0,D.g)({layout:l,layoutOptions:s,rootRef:ie,cells:te,zoomable:p,zoomer:Ae,scaleRange:pe,layoutKey:ae,allowEdgeToArea:I,dispatch:le});(0,u.useImperativeHandle)(t,(()=>({dropNode(e){"dagre"!==l&&"force"!==l&&me(!0),le({type:"drop-node",payload:e})},dropDecorator(e){"dagre"!==l&&"force"!==l&&me(!0),le({type:"drop-decorator",payload:e})},addNodes(e,t){let{defaultNodeSize:a,canvasWidth:s,canvasHeight:i}=t;const n=te.findLastIndex((e=>!("decorator"===e.type&&"text"===e.decorator)))+1,o=[...te.slice(0,n),...e,...te.slice(n)],{cells:r,updated:d,shouldReCenter:h}=(0,T.L)({cells:o,layout:l,previousCells:te,defaultNodeSize:a,canvasWidth:s,canvasHeight:i,scaleRange:pe,transform:ge,allowEdgeToArea:I});return h&&me(!1),le({type:"update-cells",payload:r}),d.filter((t=>e.includes(t)))},addEdge(e){le({type:"add-edge",payload:e})},updateCells(e,t){const{shouldReCenter:a,...s}=(0,T.L)({...t,layout:l,previousCells:te,cells:e,scaleRange:pe,transform:ge,allowEdgeToArea:I});return a&&me(!1),le({type:"update-cells",payload:s.cells}),s},getTransform:()=>ge,manuallyConnectNodes(e){const t=te.find((t=>(I&&(0,b.o6)(t)||(0,b.N)(t))&&t.id===e));if(t){const e=ie.current.getBoundingClientRect();return ke({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)=>{oe.current={resolve:e,reject:t}}))}return Promise.reject(null)}})),[te,l,pe,me,ge,I]);const be=(0,u.useCallback)(((e,t)=>{var a;for(let a=te.length-1;a>=0;a--){const s=te[a];if((I&&(0,b.o6)(s)||(0,b.N)(s))&&s.id!==e.source.id&&s.view.x<t[0]&&s.view.x+s.view.width>t[0]&&s.view.y<t[1]&&s.view.y+s.view.height>t[1]){var l;null===(l=oe.current)||void 0===l||l.resolve({source:e.source,target:s});break}}null===(a=oe.current)||void 0===a||a.reject(null),ke(null)}),[te]);(0,u.useEffect)((()=>{mt(a,!(!ve&&!ye))}),[ve,a,ye]);const Me=(0,B.J)({cellsRef:ne,activeTarget:c,onActiveTargetChange:F}),[Ne,xe]=(0,u.useState)([]);(0,u.useEffect)((()=>{const e=A?(0,R.Y)(te,ve,Me,I):[];xe((t=>0===t.length&&0===e.length?t:e))}),[Me,te,ve,A,I]),(0,u.useEffect)((()=>{const e=ie.current;if(!e||re.length>0)return;const t=e=>{const t=(0,N.a)(e,{cells:te,activeTarget:Me});"delete-cells"===(null==t?void 0:t.action)&&(V(t.cells),1===t.cells.length&&J(t.cells[0]))};return e.addEventListener("keydown",t),()=>{e.removeEventListener("keydown",t)}}),[Me,te,re.length,J,V]);const We=`${(0,u.useMemo)((()=>`${(0,f.uniqueId)("diagram-")}-`),[])}line-arrow-`,Ee=(0,u.useCallback)((e=>{le({type:"move-cells",payload:e});const t=[];(0,_._)(e,te).forEach((e=>{var a,l;null!==(a=e.containerCell)&&void 0!==a&&a.id&&t.push(null===(l=e.containerCell)||void 0===l?void 0:l.id)})),ce(t)}),[te]),Te=(0,u.useCallback)((e=>{le({type:"move-cells",payload:e}),Z(e),1===e.length&&j(e[0]),(0,_._)(e,te,ee),ce([])}),[j,Z,te,ee]),Re=(0,u.useCallback)((e=>{le({type:"resize-cell",payload:e})}),[]),ze=(0,u.useCallback)((e=>{le({type:"resize-cell",payload:e}),q(e)}),[q]),Se=(0,u.useCallback)((e=>{let{id:t,editing:a}=e;de(a?e=>e.includes(t)?e:[...e,t]:e=>e.filter((e=>e!==t)))}),[]),Be=(0,u.useCallback)(((e,t)=>{const a=Ce();le({type:"update-node-size",payload:{id:e,size:t},layoutKey:a})}),[Ce]),Le=(0,u.useCallback)((e=>{Ae.scaleTo((0,w.A)(ie.current),e/100)}),[Ae]),De=(0,u.useCallback)((()=>{me(!1)}),[me]),[$e,He]=(0,H.d)({cells:te,defaultEdgeLines:r,markerPrefix:We}),Oe=(0,$.H)({cells:te,layout:l,centered:we});return(0,u.useEffect)((()=>{const e=ie.current;if(!e||"lasso"!==M)return;const t=e.getBoundingClientRect(),a=e=>{(0,O.F)(e,{transform:ge,offset:[t.left,t.top],onLassoing(e){fe(e)},onLassoed(e){fe(null);const t=[];for(const a of te)if((0,b.t2)(a)||(0,b.o6)(a)||(0,b.Hs)(a)){const l=a.view.x,s=a.view.y;l>=e.x&&l+a.view.width<=e.x+e.width&&s>=e.y&&s+a.view.height<=e.y+e.height&&t.push(a)}null==Y||Y(t.length>1?{type:"multi",targets:t.map(K.P)}:1===t.length?(0,K.P)(t[0]):null)}})};return e.addEventListener("mousedown",a),()=>{e.removeEventListener("mousedown",a)}}),[ge,te,M,Y]),g().createElement(g().Fragment,null,g().createElement("svg",{width:"100%",height:"100%",ref:ie,className:k()("root",{grabbing:ue,pannable:v,ready:Oe}),tabIndex:-1},g().createElement("defs",null,He.map(((e,t)=>g().createElement(C.c,{key:t,id:`${We}${t}`,type:"arrow",strokeColor:e.strokeColor})))),g().createElement("g",{transform:`translate(${ge.x} ${ge.y}) scale(${ge.k})`},g().createElement("g",{className:k()("cells",{allowEdgeToArea:I}),ref:ne},te.map((e=>g().createElement(x.m,{key:`${e.type}:${(0,b.WW)(e)?`${e.source}~${e.target}`:e.id}`,dragNodeToContainerActive:!(0,b.WW)(e)&&he.includes(e.id),layout:l,cell:e,cells:te,degraded:se,degradedNodeLabel:h,defaultNodeBricks:o,transform:ge,lineConfMap:$e,activeTarget:Me,unrelatedCells:Ne,onCellsMoving:Ee,onCellsMoved:Te,onCellResizing:Re,onCellResized:ze,onSwitchActiveTarget:Y,onCellContextMenu:G,onDecoratorTextChange:Q,onDecoratorTextEditing:Se,onNodeBrickResize:Be})))),g().createElement(W.w,{connectLineState:ve,transform:ge,markerEnd:`${We}0`,onConnect:be}),ye&&g().createElement("rect",{x:ye.x,y:ye.y,width:ye.width,height:ye.height,fill:"var(--palette-gray-5)",fillOpacity:.3,stroke:"var(--palette-gray-5)",strokeDasharray:2}))),g().createElement(L.Y,{shadowRoot:a.shadowRoot,scale:ge.k,scaleRange:pe,onZoomChange:Le,onReCenter:De}))}function wa(){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)}))}l=fa,({e:[Y,j,q,J,Z,V,G,Q,X,ee,te,ae,le,se,ie,ne,oe,re,de,he,ce,ue,ge,Ae,pe,ye,fe,ve,ke,we,me,Ce,be,Me,Ne,xe,We,Ee,Te,Re,ze,Se,Be,Le,De,$e,He,Oe,Pe,Ue,Ke,_e,Ie,Fe,Ye,je,qe,Je,Ze,Ve,Ge,Qe,Xe,et,tt,at,lt,st,it,nt,ot,rt,dt,ht,ct,ut,gt,At,pt,yt,ft,vt,kt,wt,I],c:[Wt,F]}=(0,c.A)(l,[Ct("eo-draw-canvas",{styleTexts:[P.A,U.A]})],[[bt({attribute:!1}),1,"cells"],[bt({type:String}),1,"layout"],[bt({attribute:!1}),1,"layoutOptions"],[bt({attribute:!1}),1,"defaultNodeSize"],[bt({attribute:!1}),1,"defaultNodeBricks"],[bt({type:Number}),1,"degradedThreshold"],[bt({attribute:!1}),1,"degradedNodeLabel"],[bt({attribute:!1}),1,"defaultEdgeLines"],[bt({attribute:!1}),1,"activeTarget"],[bt({type:Boolean}),1,"fadeUnrelatedCells"],[bt({type:Boolean}),1,"zoomable"],[bt({type:Boolean}),1,"scrollable"],[bt({type:Boolean}),1,"pannable"],[bt({type:Boolean}),1,"selectable"],[bt({type:Boolean}),1,"allowEdgeToArea"],[bt(),1,"dragBehavior"],[bt(),1,"ctrlDragBehavior"],[bt({attribute:!1}),1,"scaleRange"],[Nt({type:"activeTarget.change"}),1,"activeTargetChangeEvent",e=>(0,h.A)(jt,e),(e,t)=>(0,d.A)(jt,e,t)],[Nt({type:"node.move"}),1,"nodeMoveEvent",e=>(0,h.A)(Vt,e),(e,t)=>(0,d.A)(Vt,e,t)],[Nt({type:"cell.move"}),1,"cellMoveEvent",e=>(0,h.A)(Gt,e),(e,t)=>(0,d.A)(Gt,e,t)],[Nt({type:"cells.move"}),1,"cellsMoveEvent",e=>(0,h.A)(Xt,e),(e,t)=>(0,d.A)(Xt,e,t)],[Nt({type:"cell.resize"}),1,"cellResizeEvent",e=>(0,h.A)(ta,e),(e,t)=>(0,d.A)(ta,e,t)],[Nt({type:"node.delete"}),1,"nodeDelete",e=>(0,h.A)(la,e),(e,t)=>(0,d.A)(la,e,t)],[Nt({type:"cell.delete"}),1,"cellDelete",e=>(0,h.A)(sa,e),(e,t)=>(0,d.A)(sa,e,t)],[Nt({type:"cells.delete"}),1,"cellsDelete",e=>(0,h.A)(na,e),(e,t)=>(0,d.A)(na,e,t)],[Nt({type:"cell.contextmenu"}),1,"cellContextMenu",e=>(0,h.A)(ra,e),(e,t)=>(0,d.A)(ra,e,t)],[Nt({type:"decorator.text.change"}),1,"decoratorTextChange",e=>(0,h.A)(ha,e),(e,t)=>(0,d.A)(ha,e,t)],[Nt({type:"node.container.change"}),1,"containerContainerChange",e=>(0,h.A)(ua,e),(e,t)=>(0,d.A)(ua,e,t)],[Nt({type:"scale.change"}),1,"scaleChange",e=>(0,h.A)(Aa,e),(e,t)=>(0,d.A)(Aa,e,t)],[Mt(),2,"dropNode"],[Mt(),2,"dropDecorator"],[Mt(),2,"addNodes"],[Mt(),2,"addEdge"],[Mt(),2,"manuallyConnectNodes"],[Mt(),2,"updateCells"]],0,(e=>ya.has((0,n.A)(e))),p.ReactNextElement)),F()}}]);
|
|
2
|
-
//# sourceMappingURL=eo-display-canvas.
|
|
1
|
+
"use strict";(globalThis.webpackChunk_next_bricks_diagram=globalThis.webpackChunk_next_bricks_diagram||[]).push([[9823,8939],{6094:(e,t,a)=>{a.r(t),a.d(t,{EoDisplayCanvas:()=>xe});var l,s=a(4635),i=a(918),n=a(6902),o=a(5536),r=a(6121),d=a(829),h=a(2740),c=a(8769),u=a.n(c),g=a(4782),A=a(1389),p=(a(9772),a(1030)),y=a(3373),f=a.n(y),v=a(7566),k=a(3739),w=a(8185),m=a(2140),C=a(3783),b=a(3033),M=a(8091),N=a(1819),x=a(5748),W=a(227),E=a(531),T=a(7099),R=a(1484),z=a(8197),S=a(7531),B=a(2098),L=a(3012),D=a(6237);let $,H,O,P,U,K,_,I,F,Y,j,q,J,Z,V,G,Q,X,ee,te,ae,le,se,ie,ne,oe,re,de,he,ce,ue,ge,Ae,pe,ye,fe,ve,ke,we,me,Ce;const{defineElement:be,property:Me,event:Ne}=(0,g.createDecorators)();let xe;var We=new WeakMap,Ee=new WeakMap,Te=new WeakMap,Re=new WeakMap,ze=new WeakMap,Se=new WeakMap,Be=new WeakMap,Le=new WeakMap,De=new WeakMap,$e=new WeakMap,He=new WeakMap,Oe=new WeakMap,Pe=new WeakMap,Ue=new WeakMap,Ke=new WeakMap,_e=new WeakSet,Ie=new WeakMap,Fe=new WeakMap,Ye=new WeakMap,je=new WeakMap,qe=new WeakMap,Je=new WeakMap;class Ze extends A.ReactNextElement{constructor(){super(...arguments),(0,s.A)(this,_e),(0,i.A)(this,We,H(this)),(0,i.A)(this,Ee,(O(this),P(this))),(0,i.A)(this,Te,(U(this),K(this))),(0,i.A)(this,Re,(_(this),I(this,[b.HP,b.HP]))),(0,i.A)(this,ze,(F(this),Y(this))),(0,i.A)(this,Se,(j(this),q(this))),(0,i.A)(this,Be,(J(this),Z(this))),(0,i.A)(this,Le,(V(this),G(this))),(0,i.A)(this,De,(Q(this),X(this))),(0,i.A)(this,$e,(ee(this),te(this))),(0,i.A)(this,He,(ae(this),le(this,!0))),(0,i.A)(this,Oe,(se(this),ie(this,!0))),(0,i.A)(this,Pe,(ne(this),oe(this,!0))),(0,i.A)(this,Ue,(re(this),de(this))),(0,i.A)(this,Ke,(he(this),ce(this))),(0,i.A)(this,Ie,(Ae(this),e=>{(0,o.A)(_e,this,ue).emit(e)})),(0,i.A)(this,Fe,(e=>{(0,w.c)(e,this.activeTarget)||(this.activeTarget=e)})),(0,i.A)(this,Ye,pe(this)),(0,i.A)(this,je,(ve(this),e=>{(0,o.A)(_e,this,ye).emit(e)})),(0,i.A)(this,qe,ke(this)),(0,i.A)(this,Je,(Ce(this),e=>{(0,o.A)(_e,this,we).emit(e)}))}get cells(){return(0,d.A)(We,this)}set cells(e){(0,r.A)(We,this,e)}get layout(){return(0,d.A)(Ee,this)}set layout(e){(0,r.A)(Ee,this,e)}get layoutOptions(){return(0,d.A)(Te,this)}set layoutOptions(e){(0,r.A)(Te,this,e)}get defaultNodeSize(){return(0,d.A)(Re,this)}set defaultNodeSize(e){(0,r.A)(Re,this,e)}get defaultNodeBricks(){return(0,d.A)(ze,this)}set defaultNodeBricks(e){(0,r.A)(ze,this,e)}get degradedThreshold(){return(0,d.A)(Se,this)}set degradedThreshold(e){(0,r.A)(Se,this,e)}get degradedNodeLabel(){return(0,d.A)(Be,this)}set degradedNodeLabel(e){(0,r.A)(Be,this,e)}get defaultEdgeLines(){return(0,d.A)(Le,this)}set defaultEdgeLines(e){(0,r.A)(Le,this,e)}get activeTarget(){return(0,d.A)(De,this)}set activeTarget(e){(0,r.A)(De,this,e)}get fadeUnrelatedCells(){return(0,d.A)($e,this)}set fadeUnrelatedCells(e){(0,r.A)($e,this,e)}get zoomable(){return(0,d.A)(He,this)}set zoomable(e){(0,r.A)(He,this,e)}get scrollable(){return(0,d.A)(Oe,this)}set scrollable(e){(0,r.A)(Oe,this,e)}get pannable(){return(0,d.A)(Pe,this)}set pannable(e){(0,r.A)(Pe,this,e)}get scaleRange(){return(0,d.A)(Ue,this)}set scaleRange(e){(0,r.A)(Ue,this,e)}render(){return u().createElement(Ve,{shadowRoot:this.shadowRoot,cells:this.cells,layout:this.layout,layoutOptions:this.layoutOptions,defaultNodeSize:this.defaultNodeSize,defaultNodeBricks:this.defaultNodeBricks,defaultEdgeLines:this.defaultEdgeLines,degradedThreshold:this.degradedThreshold,degradedNodeLabel:this.degradedNodeLabel,activeTarget:this.activeTarget,fadeUnrelatedCells:this.fadeUnrelatedCells,zoomable:this.zoomable,scrollable:this.scrollable,pannable:this.pannable,scaleRange:this.scaleRange,onActiveTargetChange:(0,d.A)(Ie,this),onSwitchActiveTarget:(0,d.A)(Fe,this),onCellContextMenu:(0,d.A)(je,this),onCellClick:(0,d.A)(Je,this)})}}function Ve(e){let{shadowRoot:t,cells:a,layout:l,layoutOptions:s,defaultNodeSize:i,defaultNodeBricks:n,defaultEdgeLines:o,degradedThreshold:r,degradedNodeLabel:d,activeTarget:h,fadeUnrelatedCells:g,zoomable:A,scrollable:y,pannable:w,scaleRange:L,onActiveTargetChange:D,onSwitchActiveTarget:$,onCellContextMenu:H,onCellClick:O}=e;const[{cells:P,layoutKey:U},K]=(0,c.useReducer)(x.d,a,(e=>({cells:(0,C.C)(e,{defaultNodeSize:i}),layoutKey:1}))),_=(0,c.useMemo)((()=>P.filter(E.N).length>=(r??b.pC)),[P,r]),I=(0,c.useRef)(null),F=(0,c.useRef)(null),{grabbing:Y,transform:j,zoomer:q,scaleRange:J}=(0,M.f)({rootRef:I,zoomable:A,scrollable:y,pannable:w,draggable:!0,scaleRange:L,onSwitchActiveTarget:$}),{centered:Z,setCentered:V,getNextLayoutKey:G}=(0,R.g)({layout:l,layoutOptions:s,rootRef:I,cells:P,zoomable:A,zoomer:q,scaleRange:J,layoutKey:U,dispatch:K}),Q=(0,c.useCallback)((()=>{V(!1)}),[V]),X=(0,c.useRef)(a);(0,c.useEffect)((()=>{if(a!==X.current){X.current=a;const e=(0,B.L)({canvasWidth:t.host.clientWidth,canvasHeight:t.host.clientHeight,defaultNodeSize:i,layout:l,previousCells:P,cells:a,scaleRange:J,transform:j});K({type:"update-cells",payload:e.cells})}}),[P,i,a,l,J,t,j]);const ee=(0,N.J)({cellsRef:F,activeTarget:h,onActiveTargetChange:D}),te=`${(0,c.useMemo)((()=>`${(0,p.uniqueId)("diagram-")}-`),[])}line-arrow-`,ae=(0,c.useCallback)(((e,t)=>{K({type:"update-node-size",payload:{id:e,size:t},layoutKey:G()})}),[G]),[le,se]=(0,c.useState)(null),ie=(0,c.useCallback)((e=>{se(e)}),[]),ne=(0,c.useCallback)((e=>{se((t=>t===e?null:t))}),[]),[oe,re]=(0,c.useState)([]);(0,c.useEffect)((()=>{const e=g?(0,W.Y)(P,null,le):[];re((t=>0===t.length&&0===e.length?t:e))}),[P,g,le]);const de=(0,c.useCallback)((e=>{q.scaleTo((0,v.A)(I.current),e/100)}),[q]),[he,ce]=(0,S.d)({cells:P,defaultEdgeLines:o,markerPrefix:te}),ue=(0,z.H)({cells:P,layout:l,centered:Z});return u().createElement(u().Fragment,null,u().createElement("svg",{width:"100%",height:"100%",ref:I,className:f()("root",{grabbing:Y,pannable:w,ready:ue}),tabIndex:-1},u().createElement("defs",null,ce.map(((e,t)=>u().createElement(k.c,{key:t,id:`${te}${t}`,type:"arrow",strokeColor:e.strokeColor})))),u().createElement("g",{transform:`translate(${j.x} ${j.y}) scale(${j.k})`},u().createElement("g",{className:"cells",ref:F},P.map((e=>u().createElement(m.m,{key:`${e.type}:${(0,E.WW)(e)?`${e.source}~${e.target}`:e.id}`,layout:l,cell:e,cells:P,degraded:_,degradedNodeLabel:d,defaultNodeBricks:n,lineConfMap:he,transform:j,activeTarget:ee,readOnly:!0,unrelatedCells:oe,onSwitchActiveTarget:$,onCellContextMenu:H,onCellClick:O,onNodeBrickResize:ae,onCellMouseEnter:g&&(0,E.N)(e)?ie:void 0,onCellMouseLeave:g&&(0,E.N)(e)?ne:void 0})))))),u().createElement(T.Y,{shadowRoot:t,scale:j.k,scaleRange:J,onZoomChange:de,onReCenter:Q}))}l=Ze,({e:[H,O,P,U,K,_,I,F,Y,j,q,J,Z,V,G,Q,X,ee,te,ae,le,se,ie,ne,oe,re,de,he,ce,ue,ge,Ae,pe,ye,fe,ve,ke,we,me,Ce],c:[xe,$]}=(0,h.A)(l,[be("eo-display-canvas",{styleTexts:[L.A,D.A]})],[[Me({attribute:!1}),1,"cells"],[Me({type:String}),1,"layout"],[Me({attribute:!1}),1,"layoutOptions"],[Me({attribute:!1}),1,"defaultNodeSize"],[Me({attribute:!1}),1,"defaultNodeBricks"],[Me({type:Number}),1,"degradedThreshold"],[Me({attribute:!1}),1,"degradedNodeLabel"],[Me({attribute:!1}),1,"defaultEdgeLines"],[Me({attribute:!1}),1,"activeTarget"],[Me({type:Boolean}),1,"fadeUnrelatedCells"],[Me({type:Boolean}),1,"zoomable"],[Me({type:Boolean}),1,"scrollable"],[Me({type:Boolean}),1,"pannable"],[Me({attribute:!1}),1,"scaleRange"],[Ne({type:"activeTarget.change"}),1,"activeTargetChangeEvent",e=>(0,d.A)(Ke,e),(e,t)=>(0,r.A)(Ke,e,t)],[Ne({type:"cell.contextmenu"}),1,"cellContextMenu",e=>(0,d.A)(Ye,e),(e,t)=>(0,r.A)(Ye,e,t)],[Ne({type:"cell.click"}),1,"cellClick",e=>(0,d.A)(qe,e),(e,t)=>(0,r.A)(qe,e,t)]],0,(e=>Je.has((0,n.A)(e))),A.ReactNextElement)),$()},9068:(e,t,a)=>{a.r(t),a.d(t,{EoDrawCanvas:()=>Wt,EoDrawCanvasComponent:()=>xt,uuidV4:()=>wa});var l,s=a(4635),i=a(918),n=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(4782),p=a(1389),y=a(3518),f=(a(9772),a(1030)),v=a(3373),k=a.n(v),w=a(7566),m=a(5748),C=a(3739),b=a(531),M=a(8185),N=a(5114),x=a(2140),W=a(3639),E=a(3783),T=a(2098),R=a(227),z=a(3033),S=a(8091),B=a(1819),L=a(7099),D=a(1484),$=a(8197),H=a(7531),O=a(2219),P=a(3012),U=a(6237),K=a(9386),_=a(1991);let I,F,Y,j,q,J,Z,V,G,Q,X,ee,te,ae,le,se,ie,ne,oe,re,de,he,ce,ue,ge,Ae,pe,ye,fe,ve,ke,we,me,Ce,be,Me,Ne,xe,We,Ee,Te,Re,ze,Se,Be,Le,De,$e,He,Oe,Pe,Ue,Ke,_e,Ie,Fe,Ye,je,qe,Je,Ze,Ve,Ge,Qe,Xe,et,tt,at,lt,st,it,nt,ot,rt,dt,ht,ct,ut,gt,At,pt,yt,ft,vt,kt,wt;const mt=(0,y.unwrapProvider)("basic.lock-body-scroll"),{defineElement:Ct,property:bt,method:Mt,event:Nt}=(0,A.createDecorators)(),xt=g().forwardRef(ka);let Wt;var Et=new WeakMap,Tt=new WeakMap,Rt=new WeakMap,zt=new WeakMap,St=new WeakMap,Bt=new WeakMap,Lt=new WeakMap,Dt=new WeakMap,$t=new WeakMap,Ht=new WeakMap,Ot=new WeakMap,Pt=new WeakMap,Ut=new WeakMap,Kt=new WeakMap,_t=new WeakMap,It=new WeakMap,Ft=new WeakMap,Yt=new WeakMap,jt=new WeakMap,qt=new WeakSet,Jt=new WeakMap,Zt=new WeakMap,Vt=new WeakMap,Gt=new WeakMap,Qt=new WeakMap,Xt=new WeakMap,ea=new WeakMap,ta=new WeakMap,aa=new WeakMap,la=new WeakMap,sa=new WeakMap,ia=new WeakMap,na=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,ya=new WeakMap;class fa extends p.ReactNextElement{constructor(){super(...arguments),(0,s.A)(this,qt),(0,i.A)(this,Et,(I(this),Y(this))),(0,i.A)(this,Tt,(j(this),q(this))),(0,i.A)(this,Rt,(J(this),Z(this))),(0,i.A)(this,zt,(V(this),G(this,[z.HP,z.HP]))),(0,i.A)(this,St,(Q(this),X(this))),(0,i.A)(this,Bt,(ee(this),te(this))),(0,i.A)(this,Lt,(ae(this),le(this))),(0,i.A)(this,Dt,(se(this),ie(this))),(0,i.A)(this,$t,(ne(this),oe(this))),(0,i.A)(this,Ht,(re(this),de(this))),(0,i.A)(this,Ot,(he(this),ce(this,!0))),(0,i.A)(this,Pt,(ue(this),ge(this,!0))),(0,i.A)(this,Ut,(Ae(this),pe(this,!0))),(0,i.A)(this,Kt,(ye(this),fe(this,!0))),(0,i.A)(this,_t,(ve(this),ke(this,!1))),(0,i.A)(this,It,(we(this),me(this))),(0,i.A)(this,Ft,(Ce(this),be(this))),(0,i.A)(this,Yt,(Me(this),Ne(this))),(0,i.A)(this,jt,(xe(this),We(this))),(0,i.A)(this,Jt,(Re(this),e=>{(0,r.A)(qt,this,Ee).emit(e)})),(0,i.A)(this,Zt,(e=>{(0,M.c)(e,this.activeTarget)||(this.activeTarget=e)})),(0,i.A)(this,Vt,ze(this)),(0,i.A)(this,Gt,(Le(this),De(this))),(0,i.A)(this,Qt,(Oe(this),e=>{(0,r.A)(qt,this,$e).emit(e),"node"===e.type&&(0,r.A)(qt,this,Se).emit(e)})),(0,i.A)(this,Xt,Pe(this)),(0,i.A)(this,ea,(_e(this),e=>{(0,r.A)(qt,this,Ue).emit(e)})),(0,i.A)(this,ta,Ie(this)),(0,i.A)(this,aa,(je(this),e=>{(0,r.A)(qt,this,Fe).emit(e)})),(0,i.A)(this,la,qe(this)),(0,i.A)(this,sa,(Ve(this),Ge(this))),(0,i.A)(this,ia,(et(this),e=>{(0,r.A)(qt,this,Qe).emit(e),"node"===e.type&&(0,r.A)(qt,this,Je).emit(e)})),(0,i.A)(this,na,tt(this)),(0,i.A)(this,oa,(st(this),e=>{(0,r.A)(qt,this,at).emit(e)})),(0,i.A)(this,ra,it(this)),(0,i.A)(this,da,(rt(this),e=>{(0,r.A)(qt,this,nt).emit(e)})),(0,i.A)(this,ha,dt(this)),(0,i.A)(this,ca,(ut(this),e=>{(0,r.A)(qt,this,ht).emit(e)})),(0,i.A)(this,ua,gt(this)),(0,i.A)(this,ga,(yt(this),e=>{(0,r.A)(qt,this,At).emit(e)})),(0,i.A)(this,Aa,ft(this)),(0,i.A)(this,pa,(wt(this),e=>{(0,r.A)(qt,this,vt).emit(e)})),(0,i.A)(this,ya,(0,u.createRef)())}get cells(){return(0,h.A)(Et,this)}set cells(e){(0,d.A)(Et,this,e)}get layout(){return(0,h.A)(Tt,this)}set layout(e){(0,d.A)(Tt,this,e)}get layoutOptions(){return(0,h.A)(Rt,this)}set layoutOptions(e){(0,d.A)(Rt,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)(St,this)}set defaultNodeBricks(e){(0,d.A)(St,this,e)}get degradedThreshold(){return(0,h.A)(Bt,this)}set degradedThreshold(e){(0,d.A)(Bt,this,e)}get degradedNodeLabel(){return(0,h.A)(Lt,this)}set degradedNodeLabel(e){(0,d.A)(Lt,this,e)}get defaultEdgeLines(){return(0,h.A)(Dt,this)}set defaultEdgeLines(e){(0,d.A)(Dt,this,e)}get activeTarget(){return(0,h.A)($t,this)}set activeTarget(e){(0,d.A)($t,this,e)}get fadeUnrelatedCells(){return(0,h.A)(Ht,this)}set fadeUnrelatedCells(e){(0,d.A)(Ht,this,e)}get zoomable(){return(0,h.A)(Ot,this)}set zoomable(e){(0,d.A)(Ot,this,e)}get scrollable(){return(0,h.A)(Pt,this)}set scrollable(e){(0,d.A)(Pt,this,e)}get pannable(){return(0,h.A)(Ut,this)}set pannable(e){(0,d.A)(Ut,this,e)}get selectable(){return(0,h.A)(Kt,this)}set selectable(e){(0,d.A)(Kt,this,e)}get allowEdgeToArea(){return(0,h.A)(_t,this)}set allowEdgeToArea(e){(0,d.A)(_t,this,e)}get dragBehavior(){return(0,h.A)(It,this)}set dragBehavior(e){(0,d.A)(It,this,e)}get ctrlDragBehavior(){return(0,h.A)(Ft,this)}set ctrlDragBehavior(e){(0,d.A)(Ft,this,e)}get scaleRange(){return(0,h.A)(Yt,this)}set scaleRange(e){(0,d.A)(Yt,this,e)}async dropNode(e){var t,a;let{id:l,position:s,size:i,data:n,useBrick:o}=e;if(null===(t=(a=document).elementsFromPoint)||void 0===t||null===(t=t.call(a,s[0],s[1]))||void 0===t?void 0:t.includes(this)){var r;const e=this.getBoundingClientRect(),t=(0,h.A)(ya,this).current.getTransform(),a={type:"node",id:l,view:{..."force"===this.layout||"dagre"===this.layout?null:{x:(s[0]-e.left-t.x)/t.k,y:(s[1]-e.top-t.y)/t.k},width:(null==i?void 0:i[0])??this.defaultNodeSize[0],height:(null==i?void 0:i[1])??this.defaultNodeSize[0]},data:n,useBrick:o};return null===(r=(0,h.A)(ya,this).current)||void 0===r||r.dropNode(a),a}return null}async dropDecorator(e){var t,a;let{position:l,decorator:s,text:i,direction:n}=e;if(null===(t=(a=document).elementsFromPoint)||void 0===t||null===(t=t.call(a,l[0],l[1]))||void 0===t?void 0:t.includes(this)){var o;const e=this.getBoundingClientRect(),t=(0,h.A)(ya,this).current.getTransform(),a={type:"decorator",decorator:s,id:wa(),view:{x:(l[0]-e.left-t.x)/t.k,y:(l[1]-e.top-t.y)/t.k,width:z.N8,height:z.w1,text:i,direction:n}};return null===(o=(0,h.A)(ya,this).current)||void 0===o||o.dropDecorator(a),a}return null}async addNodes(e){if(0===e.length)return[];const t=e.map((e=>{let{size:t,useBrick:a,id:l,data:s}=e;return{type:"node",id:l,data:s,view:{width:(null==t?void 0:t[0])??this.defaultNodeSize[0],height:(null==t?void 0:t[1])??this.defaultNodeSize[0]},useBrick:a}}));return(0,h.A)(ya,this).current.addNodes(t,{defaultNodeSize:this.defaultNodeSize,canvasWidth:this.clientWidth,canvasHeight:this.clientHeight})}async addEdge(e){var t;let{source:a,target:l,data:s}=e;const i={type:"edge",source:a,target:l,data:s};return null===(t=(0,h.A)(ya,this).current)||void 0===t||t.addEdge(i),i}manuallyConnectNodes(e){return(0,h.A)(ya,this).current.manuallyConnectNodes(e)}async updateCells(e,t){await(0,o.A)(qt,this,va).call(this);const{updated:a}=(0,h.A)(ya,this).current.updateCells(e,{...t,defaultNodeSize:this.defaultNodeSize,canvasWidth:this.clientWidth,canvasHeight:this.clientHeight});return{updated:a}}disconnectedCallback(){super.disconnectedCallback(),mt(this,!1)}render(){return g().createElement(xt,{host:this,ref:(0,h.A)(ya,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,allowEdgeToArea:this.allowEdgeToArea,onActiveTargetChange:(0,h.A)(Jt,this),onSwitchActiveTarget:(0,h.A)(Zt,this),onCellMove:(0,h.A)(Qt,this),onCellsMove:(0,h.A)(ea,this),onCellResize:(0,h.A)(aa,this),onCellDelete:(0,h.A)(ia,this),onCellsDelete:(0,h.A)(oa,this),onCellContextMenu:(0,h.A)(da,this),onDecoratorTextChange:(0,h.A)(ca,this),onContainerContainerChange:(0,h.A)(ga,this),onScaleChange:(0,h.A)(pa,this)})}}function va(){return new Promise((e=>{const t=()=>{(0,h.A)(ya,this).current?e():setTimeout(t,10)};t()}))}function ka(e,t){let{host:a,layout:l,layoutOptions:s,cells:i,defaultNodeSize:n,defaultNodeBricks:o,defaultEdgeLines:r,degradedThreshold:d,degradedNodeLabel:h,activeTarget:c,fadeUnrelatedCells:A,zoomable:p,scrollable:y,pannable:v,dragBehavior:M,ctrlDragBehavior:P,scaleRange:U,allowEdgeToArea:I,onActiveTargetChange:F,onSwitchActiveTarget:Y,onCellMove:j,onCellResize:q,onCellDelete:J,onCellsMove:Z,onCellsDelete:V,onCellContextMenu:G,onDecoratorTextChange:Q,onScaleChange:X,onContainerContainerChange:ee}=e;const[{cells:te,layoutKey:ae},le]=(0,u.useReducer)(m.d,i,(e=>({cells:(0,E.C)(e,{defaultNodeSize:n}),layoutKey:0}))),se=(0,u.useMemo)((()=>te.filter(b.N).length>=(d??z.pC)),[te,d]),ie=(0,u.useRef)(null),ne=(0,u.useRef)(null),oe=(0,u.useRef)(null),[re,de]=(0,u.useState)([]),[he,ce]=(0,u.useState)([]),{grabbing:ue,transform:ge,zoomer:Ae,scaleRange:pe}=(0,S.f)({rootRef:ie,zoomable:p,scrollable:y,pannable:v,draggable:"grab"===M,ctrlDraggable:"grab"===P,scaleRange:U,onSwitchActiveTarget:Y});(0,u.useEffect)((()=>{X(ge.k)}),[X,ge.k]);const[ye,fe]=(0,u.useState)(null),[ve,ke]=(0,u.useState)(null),{centered:we,setCentered:me,getNextLayoutKey:Ce}=(0,D.g)({layout:l,layoutOptions:s,rootRef:ie,cells:te,zoomable:p,zoomer:Ae,scaleRange:pe,layoutKey:ae,allowEdgeToArea:I,dispatch:le});(0,u.useImperativeHandle)(t,(()=>({dropNode(e){"dagre"!==l&&"force"!==l&&me(!0),le({type:"drop-node",payload:e})},dropDecorator(e){"dagre"!==l&&"force"!==l&&me(!0),le({type:"drop-decorator",payload:e})},addNodes(e,t){let{defaultNodeSize:a,canvasWidth:s,canvasHeight:i}=t;const n=te.findLastIndex((e=>!("decorator"===e.type&&"text"===e.decorator)))+1,o=[...te.slice(0,n),...e,...te.slice(n)],{cells:r,updated:d,shouldReCenter:h}=(0,T.L)({cells:o,layout:l,previousCells:te,defaultNodeSize:a,canvasWidth:s,canvasHeight:i,scaleRange:pe,transform:ge,allowEdgeToArea:I});return h&&me(!1),le({type:"update-cells",payload:r}),d.filter((t=>e.includes(t)))},addEdge(e){le({type:"add-edge",payload:e})},updateCells(e,t){const{shouldReCenter:a,...s}=(0,T.L)({...t,layout:l,previousCells:te,cells:e,scaleRange:pe,transform:ge,allowEdgeToArea:I});return a&&me(!1),le({type:"update-cells",payload:s.cells}),s},getTransform:()=>ge,manuallyConnectNodes(e){const t=te.find((t=>(I&&(0,b.o6)(t)||(0,b.N)(t))&&t.id===e));if(t){const e=ie.current.getBoundingClientRect();return ke({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)=>{oe.current={resolve:e,reject:t}}))}return Promise.reject(null)}})),[te,l,pe,me,ge,I]);const be=(0,u.useCallback)(((e,t)=>{var a;for(let a=te.length-1;a>=0;a--){const s=te[a];if((I&&(0,b.o6)(s)||(0,b.N)(s))&&s.id!==e.source.id&&s.view.x<t[0]&&s.view.x+s.view.width>t[0]&&s.view.y<t[1]&&s.view.y+s.view.height>t[1]){var l;null===(l=oe.current)||void 0===l||l.resolve({source:e.source,target:s});break}}null===(a=oe.current)||void 0===a||a.reject(null),ke(null)}),[te]);(0,u.useEffect)((()=>{mt(a,!(!ve&&!ye))}),[ve,a,ye]);const Me=(0,B.J)({cellsRef:ne,activeTarget:c,onActiveTargetChange:F}),[Ne,xe]=(0,u.useState)([]);(0,u.useEffect)((()=>{const e=A?(0,R.Y)(te,ve,Me,I):[];xe((t=>0===t.length&&0===e.length?t:e))}),[Me,te,ve,A,I]),(0,u.useEffect)((()=>{const e=ie.current;if(!e||re.length>0)return;const t=e=>{const t=(0,N.a)(e,{cells:te,activeTarget:Me});"delete-cells"===(null==t?void 0:t.action)&&(V(t.cells),1===t.cells.length&&J(t.cells[0]))};return e.addEventListener("keydown",t),()=>{e.removeEventListener("keydown",t)}}),[Me,te,re.length,J,V]);const We=`${(0,u.useMemo)((()=>`${(0,f.uniqueId)("diagram-")}-`),[])}line-arrow-`,Ee=(0,u.useCallback)((e=>{le({type:"move-cells",payload:e});const t=[];(0,_._)(e,te).forEach((e=>{var a,l;null!==(a=e.containerCell)&&void 0!==a&&a.id&&t.push(null===(l=e.containerCell)||void 0===l?void 0:l.id)})),ce(t)}),[te]),Te=(0,u.useCallback)((e=>{le({type:"move-cells",payload:e}),Z(e),1===e.length&&j(e[0]),(0,_._)(e,te,ee),ce([])}),[j,Z,te,ee]),Re=(0,u.useCallback)((e=>{le({type:"resize-cell",payload:e})}),[]),ze=(0,u.useCallback)((e=>{le({type:"resize-cell",payload:e}),q(e)}),[q]),Se=(0,u.useCallback)((e=>{let{id:t,editing:a}=e;de(a?e=>e.includes(t)?e:[...e,t]:e=>e.filter((e=>e!==t)))}),[]),Be=(0,u.useCallback)(((e,t)=>{const a=Ce();le({type:"update-node-size",payload:{id:e,size:t},layoutKey:a})}),[Ce]),Le=(0,u.useCallback)((e=>{Ae.scaleTo((0,w.A)(ie.current),e/100)}),[Ae]),De=(0,u.useCallback)((()=>{me(!1)}),[me]),[$e,He]=(0,H.d)({cells:te,defaultEdgeLines:r,markerPrefix:We}),Oe=(0,$.H)({cells:te,layout:l,centered:we});return(0,u.useEffect)((()=>{const e=ie.current;if(!e||"lasso"!==M)return;const t=e.getBoundingClientRect(),a=e=>{(0,O.F)(e,{transform:ge,offset:[t.left,t.top],onLassoing(e){fe(e)},onLassoed(e){fe(null);const t=[];for(const a of te)if((0,b.t2)(a)||(0,b.o6)(a)||(0,b.Hs)(a)){const l=a.view.x,s=a.view.y;l>=e.x&&l+a.view.width<=e.x+e.width&&s>=e.y&&s+a.view.height<=e.y+e.height&&t.push(a)}null==Y||Y(t.length>1?{type:"multi",targets:t.map(K.P)}:1===t.length?(0,K.P)(t[0]):null)}})};return e.addEventListener("mousedown",a),()=>{e.removeEventListener("mousedown",a)}}),[ge,te,M,Y]),g().createElement(g().Fragment,null,g().createElement("svg",{width:"100%",height:"100%",ref:ie,className:k()("root",{grabbing:ue,pannable:v,ready:Oe}),tabIndex:-1},g().createElement("defs",null,He.map(((e,t)=>g().createElement(C.c,{key:t,id:`${We}${t}`,type:"arrow",strokeColor:e.strokeColor})))),g().createElement("g",{transform:`translate(${ge.x} ${ge.y}) scale(${ge.k})`},g().createElement("g",{className:k()("cells",{allowEdgeToArea:I}),ref:ne},te.map((e=>g().createElement(x.m,{key:`${e.type}:${(0,b.WW)(e)?`${e.source}~${e.target}`:e.id}`,dragNodeToContainerActive:!(0,b.WW)(e)&&he.includes(e.id),layout:l,cell:e,cells:te,degraded:se,degradedNodeLabel:h,defaultNodeBricks:o,transform:ge,lineConfMap:$e,activeTarget:Me,unrelatedCells:Ne,onCellsMoving:Ee,onCellsMoved:Te,onCellResizing:Re,onCellResized:ze,onSwitchActiveTarget:Y,onCellContextMenu:G,onDecoratorTextChange:Q,onDecoratorTextEditing:Se,onNodeBrickResize:Be})))),g().createElement(W.w,{connectLineState:ve,transform:ge,markerEnd:`${We}0`,onConnect:be}),ye&&g().createElement("rect",{x:ye.x,y:ye.y,width:ye.width,height:ye.height,fill:"var(--palette-gray-5)",fillOpacity:.3,stroke:"var(--palette-gray-5)",strokeDasharray:2}))),g().createElement(L.Y,{shadowRoot:a.shadowRoot,scale:ge.k,scaleRange:pe,onZoomChange:Le,onReCenter:De}))}function wa(){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)}))}l=fa,({e:[Y,j,q,J,Z,V,G,Q,X,ee,te,ae,le,se,ie,ne,oe,re,de,he,ce,ue,ge,Ae,pe,ye,fe,ve,ke,we,me,Ce,be,Me,Ne,xe,We,Ee,Te,Re,ze,Se,Be,Le,De,$e,He,Oe,Pe,Ue,Ke,_e,Ie,Fe,Ye,je,qe,Je,Ze,Ve,Ge,Qe,Xe,et,tt,at,lt,st,it,nt,ot,rt,dt,ht,ct,ut,gt,At,pt,yt,ft,vt,kt,wt,I],c:[Wt,F]}=(0,c.A)(l,[Ct("eo-draw-canvas",{styleTexts:[P.A,U.A]})],[[bt({attribute:!1}),1,"cells"],[bt({type:String}),1,"layout"],[bt({attribute:!1}),1,"layoutOptions"],[bt({attribute:!1}),1,"defaultNodeSize"],[bt({attribute:!1}),1,"defaultNodeBricks"],[bt({type:Number}),1,"degradedThreshold"],[bt({attribute:!1}),1,"degradedNodeLabel"],[bt({attribute:!1}),1,"defaultEdgeLines"],[bt({attribute:!1}),1,"activeTarget"],[bt({type:Boolean}),1,"fadeUnrelatedCells"],[bt({type:Boolean}),1,"zoomable"],[bt({type:Boolean}),1,"scrollable"],[bt({type:Boolean}),1,"pannable"],[bt({type:Boolean}),1,"selectable"],[bt({type:Boolean}),1,"allowEdgeToArea"],[bt(),1,"dragBehavior"],[bt(),1,"ctrlDragBehavior"],[bt({attribute:!1}),1,"scaleRange"],[Nt({type:"activeTarget.change"}),1,"activeTargetChangeEvent",e=>(0,h.A)(jt,e),(e,t)=>(0,d.A)(jt,e,t)],[Nt({type:"node.move"}),1,"nodeMoveEvent",e=>(0,h.A)(Vt,e),(e,t)=>(0,d.A)(Vt,e,t)],[Nt({type:"cell.move"}),1,"cellMoveEvent",e=>(0,h.A)(Gt,e),(e,t)=>(0,d.A)(Gt,e,t)],[Nt({type:"cells.move"}),1,"cellsMoveEvent",e=>(0,h.A)(Xt,e),(e,t)=>(0,d.A)(Xt,e,t)],[Nt({type:"cell.resize"}),1,"cellResizeEvent",e=>(0,h.A)(ta,e),(e,t)=>(0,d.A)(ta,e,t)],[Nt({type:"node.delete"}),1,"nodeDelete",e=>(0,h.A)(la,e),(e,t)=>(0,d.A)(la,e,t)],[Nt({type:"cell.delete"}),1,"cellDelete",e=>(0,h.A)(sa,e),(e,t)=>(0,d.A)(sa,e,t)],[Nt({type:"cells.delete"}),1,"cellsDelete",e=>(0,h.A)(na,e),(e,t)=>(0,d.A)(na,e,t)],[Nt({type:"cell.contextmenu"}),1,"cellContextMenu",e=>(0,h.A)(ra,e),(e,t)=>(0,d.A)(ra,e,t)],[Nt({type:"decorator.text.change"}),1,"decoratorTextChange",e=>(0,h.A)(ha,e),(e,t)=>(0,d.A)(ha,e,t)],[Nt({type:"node.container.change"}),1,"containerContainerChange",e=>(0,h.A)(ua,e),(e,t)=>(0,d.A)(ua,e,t)],[Nt({type:"scale.change"}),1,"scaleChange",e=>(0,h.A)(Aa,e),(e,t)=>(0,d.A)(Aa,e,t)],[Mt(),2,"dropNode"],[Mt(),2,"dropDecorator"],[Mt(),2,"addNodes"],[Mt(),2,"addEdge"],[Mt(),2,"manuallyConnectNodes"],[Mt(),2,"updateCells"]],0,(e=>ya.has((0,n.A)(e))),p.ReactNextElement)),F()}}]);
|
|
2
|
+
//# sourceMappingURL=eo-display-canvas.431eb9f3.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"chunks/eo-display-canvas.da51ba14.js","mappings":"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","sources":["webpack:///./src/display-canvas/index.tsx","webpack:///./src/draw-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\";\n\nconst { defineElement, property, event } = createDecorators();\n\nexport interface EoDisplayCanvasProps {\n cells: InitialCell[] | undefined;\n layout: LayoutType;\n layoutOptions?: LayoutOptions;\n defaultNodeSize: SizeTuple;\n defaultNodeBricks?: NodeBrickConf[];\n defaultEdgeLines?: EdgeLineConf[];\n degradedThreshold?: number;\n degradedNodeLabel?: string;\n activeTarget?: ActiveTarget | null;\n fadeUnrelatedCells?: boolean;\n zoomable?: boolean;\n scrollable?: boolean;\n pannable?: boolean;\n scaleRange?: RangeTuple;\n}\n\n/**\n * 用于展示查看的画布。\n */\nexport\n@defineElement(\"eo-display-canvas\", {\n styleTexts: [styleText, zoomBarStyleText],\n})\nclass EoDisplayCanvas extends ReactNextElement implements EoDisplayCanvasProps {\n /**\n * 用于查看的画布可以更新 `cells` 属性。\n */\n @property({ attribute: false })\n accessor cells: InitialCell[] | undefined;\n\n @property({ type: String })\n accessor layout: LayoutType;\n\n @property({ attribute: false })\n accessor layoutOptions: LayoutOptions | undefined;\n\n @property({ attribute: false })\n accessor defaultNodeSize: SizeTuple = [DEFAULT_NODE_SIZE, DEFAULT_NODE_SIZE];\n\n @property({ attribute: false })\n accessor defaultNodeBricks: NodeBrickConf[] | undefined;\n\n /**\n * 当节点数量达到或超过 `degradedThreshold` 时,节点将被降级展示。\n *\n * @default 500\n */\n @property({ type: Number })\n accessor degradedThreshold: number | undefined;\n\n // Set `attribute` to `false` event if it accepts string value.\n // Because when passing like \"<% DATA.node.data.name %>\", it will be\n // evaluated as object temporarily.\n /**\n * 设置节点将降级展示时显示的名称。\n *\n * @default \"<% DATA.node.id %>\"\n */\n @property({ attribute: false })\n accessor degradedNodeLabel: string | undefined;\n\n /**\n * 使用条件判断设置默认的边对应的连线。在 `if` 表达式中 `DATA` 为 `{ edge }`,例如:\n *\n * ```yaml\n * defaultEdgeLines:\n * - if: <% DATA.edge.data?.virtual %>\n * dashed: true\n * ```\n */\n @property({ attribute: false })\n accessor defaultEdgeLines: EdgeLineConf[] | undefined;\n\n @property({ attribute: false })\n accessor activeTarget: ActiveTarget | null | undefined;\n\n /**\n * 当鼠标悬浮到某节点上时,隐藏其他跟该节点无关的元素。\n */\n @property({ type: Boolean })\n accessor fadeUnrelatedCells: boolean | undefined;\n\n @property({ type: Boolean })\n accessor zoomable: boolean | undefined = true;\n\n @property({ type: Boolean })\n accessor scrollable: boolean | undefined = true;\n\n @property({ type: Boolean })\n accessor pannable: boolean | undefined = true;\n\n @property({ attribute: false })\n accessor scaleRange: RangeTuple | undefined;\n\n @event({ type: \"activeTarget.change\" })\n accessor #activeTargetChangeEvent!: EventEmitter<ActiveTarget | null>;\n\n #handleActiveTargetChange = (target: ActiveTarget | null) => {\n this.#activeTargetChangeEvent.emit(target);\n };\n\n #handleSwitchActiveTarget = (target: ActiveTarget | null) => {\n if (!sameTarget(target, this.activeTarget)) {\n this.activeTarget = target;\n }\n };\n\n @event({ type: \"cell.contextmenu\" })\n accessor #cellContextMenu!: EventEmitter<CellContextMenuDetail>;\n\n #handleCellContextMenu = (detail: CellContextMenuDetail) => {\n this.#cellContextMenu.emit(detail);\n };\n\n @event({ type: \"cell.click\" })\n accessor #cellClick!: EventEmitter<CellContextMenuDetail>;\n\n #handleCellClick = (detail: CellContextMenuDetail) => {\n this.#cellClick.emit(detail);\n };\n\n render() {\n return (\n <EoDisplayCanvasComponent\n shadowRoot={this.shadowRoot!}\n cells={this.cells}\n layout={this.layout}\n layoutOptions={this.layoutOptions}\n defaultNodeSize={this.defaultNodeSize}\n defaultNodeBricks={this.defaultNodeBricks}\n defaultEdgeLines={this.defaultEdgeLines}\n degradedThreshold={this.degradedThreshold}\n degradedNodeLabel={this.degradedNodeLabel}\n activeTarget={this.activeTarget}\n fadeUnrelatedCells={this.fadeUnrelatedCells}\n zoomable={this.zoomable}\n scrollable={this.scrollable}\n pannable={this.pannable}\n scaleRange={this.scaleRange}\n onActiveTargetChange={this.#handleActiveTargetChange}\n onSwitchActiveTarget={this.#handleSwitchActiveTarget}\n onCellContextMenu={this.#handleCellContextMenu}\n onCellClick={this.#handleCellClick}\n />\n );\n }\n}\n\nexport interface EoDisplayCanvasComponentProps extends EoDisplayCanvasProps {\n shadowRoot: ShadowRoot;\n onActiveTargetChange(target: ActiveTarget | null): void;\n onSwitchActiveTarget(target: ActiveTarget | null): void;\n onCellContextMenu(detail: CellContextMenuDetail): void;\n onCellClick(detail: CellContextMenuDetail): void;\n}\n\nfunction EoDisplayCanvasComponent({\n shadowRoot,\n cells: initialCells,\n layout,\n layoutOptions,\n defaultNodeSize,\n defaultNodeBricks,\n defaultEdgeLines,\n degradedThreshold,\n degradedNodeLabel,\n activeTarget: _activeTarget,\n fadeUnrelatedCells,\n zoomable,\n scrollable,\n pannable,\n scaleRange: _scaleRange,\n onActiveTargetChange,\n onSwitchActiveTarget,\n onCellContextMenu,\n onCellClick,\n}: EoDisplayCanvasComponentProps) {\n const [{ cells, layoutKey }, dispatch] = useReducer(\n rootReducer,\n initialCells,\n (initialCells) => ({\n cells: initializeCells(initialCells, { defaultNodeSize }),\n layoutKey: 1,\n })\n );\n\n // When nodes are greater or equal to threshold, the diagram will be degraded.\n // Thus all nodes will be displayed as simple svg elements instead of bricks.\n const degraded = useMemo(\n () =>\n cells.filter(isNodeCell).length >=\n (degradedThreshold ?? DEFAULT_DEGRADED_THRESHOLD),\n [cells, degradedThreshold]\n );\n\n const rootRef = useRef<SVGSVGElement>(null);\n const cellsRef = useRef<SVGGElement>(null);\n\n const { grabbing, transform, zoomer, scaleRange } = useZoom({\n rootRef,\n zoomable,\n scrollable,\n pannable,\n 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 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 cellsRef,\n activeTarget: _activeTarget,\n onActiveTargetChange,\n });\n\n const defPrefix = useMemo(() => `${uniqueId(\"diagram-\")}-`, []);\n const markerPrefix = `${defPrefix}line-arrow-`;\n\n const handleNodeBrickResize = useCallback(\n (id: string, size: SizeTuple | null) => {\n dispatch({\n type: \"update-node-size\",\n payload: { id, size },\n layoutKey: getNextLayoutKey(),\n });\n },\n [getNextLayoutKey]\n );\n\n const [hoverCell, setHoverCell] = useState<Cell | null>(null);\n const handleCellMouseEnter = useCallback((cell: Cell) => {\n setHoverCell(cell);\n }, []);\n const handleCellMouseLeave = useCallback((cell: Cell) => {\n setHoverCell((prev) => (prev === cell ? null : prev));\n }, []);\n\n const [unrelatedCells, setUnrelatedCells] = useState<Cell[]>([]);\n useEffect(() => {\n const nextUnrelated = fadeUnrelatedCells\n ? getUnrelatedCells(cells, null, hoverCell)\n : [];\n // Do not update the state when prev and next are both empty.\n setUnrelatedCells((prev) =>\n prev.length === 0 && nextUnrelated.length === 0 ? prev : nextUnrelated\n );\n }, [cells, fadeUnrelatedCells, hoverCell]);\n\n const handleZoomSlide = useCallback(\n (value: number) => {\n // istanbul ignore next\n if (process.env.NODE_ENV !== \"test\") {\n zoomer.scaleTo(select(rootRef.current!), value / 100);\n }\n },\n [zoomer]\n );\n\n const [lineConfMap, markers] = useLineMarkers({\n cells,\n defaultEdgeLines,\n markerPrefix,\n });\n\n const ready = useReady({ cells, layout, centered });\n\n return (\n <>\n <svg\n width=\"100%\"\n height=\"100%\"\n ref={rootRef}\n className={classNames(\"root\", { grabbing, pannable, ready })}\n tabIndex={-1}\n >\n <defs>\n {markers.map((marker, index) => (\n <MarkerComponent\n key={index}\n id={`${markerPrefix}${index}`}\n type=\"arrow\"\n strokeColor={marker.strokeColor}\n />\n ))}\n </defs>\n <g\n transform={`translate(${transform.x} ${transform.y}) scale(${transform.k})`}\n >\n <g className=\"cells\" ref={cellsRef}>\n {cells.map((cell) => (\n <CellComponent\n key={`${cell.type}:${isEdgeCell(cell) ? `${cell.source}~${cell.target}` : cell.id}`}\n layout={layout}\n cell={cell}\n cells={cells}\n degraded={degraded}\n degradedNodeLabel={degradedNodeLabel}\n defaultNodeBricks={defaultNodeBricks}\n lineConfMap={lineConfMap}\n transform={transform}\n activeTarget={activeTarget}\n readOnly\n unrelatedCells={unrelatedCells}\n onSwitchActiveTarget={onSwitchActiveTarget}\n onCellContextMenu={onCellContextMenu}\n onCellClick={onCellClick}\n onNodeBrickResize={handleNodeBrickResize}\n onCellMouseEnter={\n fadeUnrelatedCells && isNodeCell(cell)\n ? handleCellMouseEnter\n : undefined\n }\n onCellMouseLeave={\n fadeUnrelatedCells && isNodeCell(cell)\n ? handleCellMouseLeave\n : undefined\n }\n />\n ))}\n </g>\n </g>\n </svg>\n <ZoomBarComponent\n shadowRoot={shadowRoot}\n scale={transform.k}\n scaleRange={scaleRange}\n onZoomChange={handleZoomSlide}\n onReCenter={reCenter}\n />\n </>\n );\n}\n","import React, {\n createRef,\n useCallback,\n useEffect,\n useImperativeHandle,\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 type { UseSingleBrickConf } from \"@next-core/react-runtime\";\nimport { unwrapProvider } from \"@next-core/utils/general\";\nimport \"@next-core/theme\";\nimport { uniqueId } from \"lodash\";\nimport classNames from \"classnames\";\nimport { select } from \"d3-selection\";\nimport type { lockBodyScroll as _lockBodyScroll } from \"@next-bricks/basic/data-providers/lock-body-scroll/lock-body-scroll\";\nimport type {\n PositionTuple,\n RangeTuple,\n SizeTuple,\n TransformLiteral,\n} from \"../diagram/interfaces\";\nimport type {\n ActiveTarget,\n Cell,\n EdgeCell,\n InitialCell,\n NodeBrickConf,\n NodeCell,\n NodeId,\n DecoratorCell,\n DecoratorType,\n CellContextMenuDetail,\n ConnectLineState,\n Deferred,\n ConnectNodesDetail,\n EdgeLineConf,\n DecoratorTextChangeDetail,\n NodeView,\n LayoutType,\n LayoutOptions,\n Direction,\n} from \"./interfaces\";\nimport { rootReducer } from \"./reducers\";\nimport { MarkerComponent } from \"../diagram/MarkerComponent\";\nimport {\n isContainerDecoratorCell,\n isEdgeCell,\n isNodeCell,\n isNodeOrAreaDecoratorCell,\n isTextDecoratorCell,\n} from \"./processors/asserts\";\nimport type { MoveCellPayload, ResizeCellPayload } from \"./reducers/interfaces\";\nimport { sameTarget } from \"./processors/sameTarget\";\nimport { handleKeyboard } from \"./processors/handleKeyboard\";\nimport { CellComponent } from \"./CellComponent\";\nimport { ConnectLineComponent } from \"./ConnectLineComponent\";\nimport { initializeCells } from \"./processors/initializeCells\";\nimport { updateCells } from \"./processors/updateCells\";\nimport { getUnrelatedCells } from \"./processors/getUnrelatedCells\";\nimport {\n DEFAULT_NODE_SIZE,\n DEFAULT_AREA_WIDTH,\n DEFAULT_AREA_HEIGHT,\n DEFAULT_DEGRADED_THRESHOLD,\n} from \"./constants\";\nimport { useZoom } from \"../shared/canvas/useZoom\";\nimport { useActiveTarget } from \"../shared/canvas/useActiveTarget\";\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 { handleLasso } from \"./processors/handleLasso\";\nimport styleText from \"../shared/canvas/styles.shadow.css\";\nimport zoomBarStyleText from \"../shared/canvas/ZoomBarComponent.shadow.css\";\nimport { cellToTarget } from \"./processors/cellToTarget\";\nimport { handleNodeContainedChange } from \"./processors/handleNodeContainedChange\";\n\nconst lockBodyScroll = unwrapProvider<typeof _lockBodyScroll>(\n \"basic.lock-body-scroll\"\n);\n\nconst { defineElement, property, method, event } = createDecorators();\n\nexport interface EoDrawCanvasProps {\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 dragBehavior?: DragBehavior;\n ctrlDragBehavior?: CtrlDragBehavior;\n scaleRange?: RangeTuple;\n allowEdgeToArea?: boolean;\n}\n\nexport type DragBehavior = \"none\" | \"lasso\" | \"grab\";\nexport type CtrlDragBehavior = \"none\" | \"grab\";\n\nexport interface DropNodeInfo extends AddNodeInfo {\n /** [PointerEvent::clientX, PointerEvent::clientY] */\n position: PositionTuple;\n}\n\nexport interface DropDecoratorInfo {\n decorator: DecoratorType;\n /** [PointerEvent::clientX, PointerEvent::clientY] */\n position: PositionTuple;\n text?: string;\n direction?: Direction;\n}\n\nexport interface AddNodeInfo {\n id: NodeId;\n useBrick?: UseSingleBrickConf;\n data?: unknown;\n size?: SizeTuple;\n}\n\nexport interface AddEdgeInfo {\n source: NodeId;\n target: NodeId;\n data?: unknown;\n}\n\nexport interface UpdateCellsContext {\n reason: \"add-related-nodes\";\n parent: NodeId;\n}\n\nexport interface AddNodesContext {\n defaultNodeSize: SizeTuple;\n canvasWidth: number;\n canvasHeight: number;\n}\n\nexport const EoDrawCanvasComponent = React.forwardRef(\n LegacyEoDrawCanvasComponent\n);\n\n/**\n * 用于手工绘图的画布。\n *\n * 注意:将配套另外一个用于展示的画布构件。\n */\nexport\n@defineElement(\"eo-draw-canvas\", {\n styleTexts: [styleText, zoomBarStyleText],\n})\nclass EoDrawCanvas extends ReactNextElement implements EoDrawCanvasProps {\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 * 当 `activeTarget` 不为 `null` 时,隐藏其他跟该 `activeTarget` 无关的元素。\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({ type: Boolean })\n accessor selectable: boolean | undefined = true;\n\n @property({ type: Boolean })\n accessor allowEdgeToArea: boolean | undefined = false;\n\n /**\n * 按住鼠标拖动时的行为:\n * - `none`:无\n * - `lasso`:绘制选区\n * - `grab`:拖动画布\n *\n * @default \"none\"\n */\n @property()\n accessor dragBehavior: DragBehavior | undefined;\n\n /**\n * 按住 ctrl 键并按住鼠标拖动时的行为:\n * - `none`:无\n * - `grab`:拖动画布\n *\n * @default \"none\"\n */\n @property()\n accessor ctrlDragBehavior: CtrlDragBehavior | undefined;\n\n @property({ attribute: false })\n accessor scaleRange: RangeTuple | undefined;\n\n @event({ type: \"activeTarget.change\" })\n accessor #activeTargetChangeEvent!: EventEmitter<ActiveTarget | null>;\n\n #handleActiveTargetChange = (target: ActiveTarget | null) => {\n this.#activeTargetChangeEvent.emit(target);\n };\n\n #handleSwitchActiveTarget = (target: ActiveTarget | null) => {\n if (!sameTarget(target, this.activeTarget)) {\n this.activeTarget = target;\n }\n };\n\n /**\n * @deprecated Use `cell.move` instead.\n */\n @event({ type: \"node.move\" })\n accessor #nodeMoveEvent!: EventEmitter<MoveCellPayload>;\n\n @event({ type: \"cell.move\" })\n accessor #cellMoveEvent!: EventEmitter<MoveCellPayload>;\n\n #handleCellMove = (info: MoveCellPayload) => {\n this.#cellMoveEvent.emit(info);\n if (info.type === \"node\") {\n this.#nodeMoveEvent.emit(info);\n }\n };\n\n @event({ type: \"cells.move\" })\n accessor #cellsMoveEvent!: EventEmitter<MoveCellPayload[]>;\n\n #handleCellsMove = (info: MoveCellPayload[]) => {\n this.#cellsMoveEvent.emit(info);\n };\n\n @event({ type: \"cell.resize\" })\n accessor #cellResizeEvent!: EventEmitter<ResizeCellPayload>;\n\n #handleCellResize = (info: ResizeCellPayload) => {\n this.#cellResizeEvent.emit(info);\n };\n\n /**\n * @deprecated Use `cell.delete` instead.\n */\n @event({ type: \"node.delete\" })\n accessor #nodeDelete!: EventEmitter<Cell>;\n\n @event({ type: \"cell.delete\" })\n accessor #cellDelete!: EventEmitter<Cell>;\n\n #handleCellDelete = (cell: Cell) => {\n this.#cellDelete.emit(cell);\n if (cell.type === \"node\") {\n this.#nodeDelete.emit(cell);\n }\n };\n\n @event({ type: \"cells.delete\" })\n accessor #cellsDelete!: EventEmitter<Cell[]>;\n\n #handleCellsDelete = (cells: Cell[]) => {\n this.#cellsDelete.emit(cells);\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: \"decorator.text.change\" })\n accessor #decoratorTextChange!: EventEmitter<DecoratorTextChangeDetail>;\n\n #handleDecoratorTextChange = (detail: DecoratorTextChangeDetail) => {\n this.#decoratorTextChange.emit(detail);\n };\n\n /**\n * node节点跟容器组关系改变事件,有containerCell是新增关系,否则删除关系\n */\n @event({ type: \"node.container.change\" })\n accessor #containerContainerChange!: EventEmitter<MoveCellPayload[]>;\n\n #handleContainerContainerChange = (detail: MoveCellPayload[]) => {\n this.#containerContainerChange.emit(detail);\n };\n\n /**\n * 缩放变化后,从素材库拖拽元素进画布时,拖拽图像应设置对应的缩放比例。\n */\n @event({ type: \"scale.change\" })\n accessor #scaleChange!: EventEmitter<number>;\n\n #handleScaleChange = (scale: number) => {\n this.#scaleChange.emit(scale);\n };\n\n @method()\n async dropNode({\n id,\n position,\n size,\n data,\n useBrick,\n }: DropNodeInfo): Promise<NodeCell | null> {\n // Drag and then drop a node\n const droppedInside = document\n .elementsFromPoint?.(position[0], position[1])\n ?.includes(this);\n if (droppedInside) {\n const boundingClientRect = this.getBoundingClientRect();\n const transform = this.#canvasRef.current!.getTransform();\n const newNode = {\n type: \"node\",\n id,\n view: {\n ...(this.layout === \"force\" || this.layout === \"dagre\"\n ? null\n : {\n x:\n (position[0] - boundingClientRect.left - transform.x) /\n transform.k,\n y:\n (position[1] - boundingClientRect.top - transform.y) /\n transform.k,\n }),\n width: size?.[0] ?? this.defaultNodeSize[0],\n height: size?.[1] ?? this.defaultNodeSize[0],\n },\n data,\n useBrick,\n } as NodeCell;\n this.#canvasRef.current?.dropNode(newNode);\n return newNode;\n }\n return null;\n }\n\n @method()\n async dropDecorator({\n position,\n decorator,\n text,\n direction,\n }: DropDecoratorInfo): Promise<DecoratorCell | null> {\n // Drag and then drop a node\n const droppedInside = document\n .elementsFromPoint?.(position[0], position[1])\n ?.includes(this);\n if (droppedInside) {\n const boundingClientRect = this.getBoundingClientRect();\n const transform = this.#canvasRef.current!.getTransform();\n const newDecorator: DecoratorCell = {\n type: \"decorator\",\n decorator,\n id: uuidV4(),\n view: {\n x:\n (position[0] - boundingClientRect.left - transform.x) / transform.k,\n y: (position[1] - boundingClientRect.top - transform.y) / transform.k,\n width: DEFAULT_AREA_WIDTH,\n height: DEFAULT_AREA_HEIGHT,\n text,\n direction,\n },\n };\n this.#canvasRef.current?.dropDecorator(newDecorator);\n return newDecorator;\n }\n return null;\n }\n\n @method()\n async addNodes(nodes: AddNodeInfo[]): Promise<NodeCell[]> {\n if (nodes.length === 0) {\n return [];\n }\n const newNodes = nodes.map<NodeCell>(({ size, useBrick, id, data }) => ({\n type: \"node\",\n id,\n data,\n view: {\n width: size?.[0] ?? this.defaultNodeSize[0],\n height: size?.[1] ?? this.defaultNodeSize[0],\n } as NodeView,\n useBrick,\n }));\n return this.#canvasRef.current!.addNodes(newNodes, {\n defaultNodeSize: this.defaultNodeSize,\n canvasWidth: this.clientWidth,\n canvasHeight: this.clientHeight,\n });\n }\n\n @method()\n async addEdge({ source, target, data }: AddEdgeInfo): Promise<EdgeCell> {\n const newEdge: EdgeCell = {\n type: \"edge\",\n source,\n target,\n data,\n };\n this.#canvasRef.current?.addEdge(newEdge);\n return newEdge;\n }\n\n @method()\n manuallyConnectNodes(source: NodeId): Promise<ConnectNodesDetail> {\n return this.#canvasRef.current!.manuallyConnectNodes(source);\n }\n\n @method()\n async updateCells(\n cells: InitialCell[],\n ctx?: UpdateCellsContext\n ): Promise<{ updated: Cell[] }> {\n await this.#waitForCanvasRef();\n const { updated } = this.#canvasRef.current!.updateCells(cells, {\n ...ctx,\n defaultNodeSize: this.defaultNodeSize,\n canvasWidth: this.clientWidth,\n canvasHeight: this.clientHeight,\n });\n return { updated };\n }\n\n #waitForCanvasRef() {\n return new Promise<void>((resolve) => {\n const check = () => {\n if (this.#canvasRef.current) {\n resolve();\n } else {\n setTimeout(check, 10);\n }\n };\n check();\n });\n }\n\n #canvasRef = createRef<DrawCanvasRef>();\n\n disconnectedCallback(): void {\n super.disconnectedCallback();\n lockBodyScroll(this, false);\n }\n\n render() {\n return (\n <EoDrawCanvasComponent\n host={this}\n ref={this.#canvasRef}\n layout={this.layout}\n layoutOptions={this.layoutOptions}\n cells={this.cells}\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 dragBehavior={this.dragBehavior}\n ctrlDragBehavior={this.ctrlDragBehavior}\n scaleRange={this.scaleRange}\n allowEdgeToArea={this.allowEdgeToArea}\n onActiveTargetChange={this.#handleActiveTargetChange}\n onSwitchActiveTarget={this.#handleSwitchActiveTarget}\n onCellMove={this.#handleCellMove}\n onCellsMove={this.#handleCellsMove}\n onCellResize={this.#handleCellResize}\n onCellDelete={this.#handleCellDelete}\n onCellsDelete={this.#handleCellsDelete}\n onCellContextMenu={this.#handleCellContextMenu}\n onDecoratorTextChange={this.#handleDecoratorTextChange}\n onContainerContainerChange={this.#handleContainerContainerChange}\n onScaleChange={this.#handleScaleChange}\n />\n );\n }\n}\n\nexport interface EoDrawCanvasComponentProps extends EoDrawCanvasProps {\n host: HTMLElement;\n onActiveTargetChange(target: ActiveTarget | null): void;\n onSwitchActiveTarget(target: ActiveTarget | null): void;\n onCellMove(info: MoveCellPayload): void;\n onCellResize(cell: ResizeCellPayload): void;\n onCellDelete(cell: Cell): void;\n onCellsMove(info: MoveCellPayload[]): void;\n onCellsDelete(cells: Cell[]): void;\n onCellContextMenu(detail: CellContextMenuDetail): void;\n onDecoratorTextChange(detail: DecoratorTextChangeDetail): void;\n onContainerContainerChange(detail: MoveCellPayload[]): void;\n onScaleChange(scale: number): void;\n}\n\nexport interface DrawCanvasRef {\n dropNode(node: NodeCell): void;\n dropDecorator(decorator: DecoratorCell): void;\n addNodes(nodes: NodeCell[], ctx: AddNodesContext): NodeCell[];\n addEdge(edge: EdgeCell): void;\n manuallyConnectNodes(source: NodeId): Promise<ConnectNodesDetail>;\n updateCells(\n cells: InitialCell[],\n ctx: Partial<UpdateCellsContext> & {\n defaultNodeSize: SizeTuple;\n canvasWidth: number;\n canvasHeight: number;\n }\n ): {\n cells: Cell[];\n updated: Cell[];\n };\n getTransform(): TransformLiteral;\n}\n\nfunction LegacyEoDrawCanvasComponent(\n {\n host,\n layout,\n layoutOptions,\n cells: initialCells,\n defaultNodeSize,\n defaultNodeBricks,\n defaultEdgeLines,\n degradedThreshold,\n degradedNodeLabel,\n activeTarget: _activeTarget,\n fadeUnrelatedCells,\n zoomable,\n scrollable,\n pannable,\n dragBehavior,\n ctrlDragBehavior,\n scaleRange: _scaleRange,\n allowEdgeToArea,\n onActiveTargetChange,\n onSwitchActiveTarget,\n onCellMove,\n onCellResize,\n onCellDelete,\n onCellsMove,\n onCellsDelete,\n onCellContextMenu,\n onDecoratorTextChange,\n onScaleChange,\n onContainerContainerChange,\n }: EoDrawCanvasComponentProps,\n ref: React.Ref<DrawCanvasRef>\n) {\n const [{ cells, layoutKey }, dispatch] = useReducer(\n rootReducer,\n initialCells,\n (initialCells) => ({\n cells: initializeCells(initialCells, { defaultNodeSize }),\n layoutKey: 0,\n })\n );\n\n // When nodes are greater or equal to threshold, the diagram will be degraded.\n // Thus all nodes will be displayed as simple svg elements instead of bricks.\n const degraded = useMemo(\n () =>\n cells.filter(isNodeCell).length >=\n (degradedThreshold ?? DEFAULT_DEGRADED_THRESHOLD),\n [cells, degradedThreshold]\n );\n\n const rootRef = useRef<SVGSVGElement>(null);\n const cellsRef = useRef<SVGGElement>(null);\n const manualConnectDeferredRef = useRef<Deferred<ConnectNodesDetail> | null>(\n null\n );\n const [editingTexts, setEditingTexts] = useState<string[]>([]);\n const [activeContainers, setActiveContainers] = useState<string[]>([]);\n const { grabbing, transform, zoomer, scaleRange } = useZoom({\n rootRef,\n zoomable,\n scrollable,\n pannable,\n draggable: dragBehavior === \"grab\",\n ctrlDraggable: ctrlDragBehavior === \"grab\",\n scaleRange: _scaleRange,\n onSwitchActiveTarget,\n });\n\n useEffect(() => {\n onScaleChange(transform.k);\n }, [onScaleChange, transform.k]);\n\n const [lassoRect, setLassoRect] = useState<NodeView | null>(null);\n\n const [connectLineState, setConnectLineState] =\n useState<ConnectLineState | null>(null);\n\n const { centered, setCentered, getNextLayoutKey } = useLayout({\n layout,\n layoutOptions,\n rootRef,\n cells,\n zoomable,\n zoomer,\n scaleRange,\n layoutKey,\n allowEdgeToArea,\n dispatch,\n });\n\n useImperativeHandle(\n ref,\n () => ({\n dropNode(node) {\n // Do not apply auto centering when dropping a node in manual layout.\n if (layout !== \"dagre\" && layout !== \"force\") {\n setCentered(true);\n }\n dispatch({ type: \"drop-node\", payload: node });\n },\n dropDecorator(decorator) {\n // Do not apply auto centering when dropping a decorator in manual layout.\n if (layout !== \"dagre\" && layout !== \"force\") {\n setCentered(true);\n }\n dispatch({ type: \"drop-decorator\", payload: decorator });\n },\n addNodes(\n nodes,\n { defaultNodeSize, canvasWidth, canvasHeight }: AddNodesContext\n ) {\n const index =\n cells.findLastIndex(\n (cell) => !(cell.type === \"decorator\" && cell.decorator === \"text\")\n ) + 1;\n const newCells = [\n ...cells.slice(0, index),\n ...nodes,\n ...cells.slice(index),\n ];\n const {\n cells: allCells,\n updated,\n shouldReCenter,\n } = updateCells({\n cells: newCells,\n layout,\n previousCells: cells,\n defaultNodeSize,\n canvasWidth,\n canvasHeight,\n scaleRange,\n transform,\n allowEdgeToArea,\n });\n if (shouldReCenter) {\n setCentered(false);\n }\n dispatch({ type: \"update-cells\", payload: allCells });\n return updated.filter((node) =>\n nodes.includes(node as NodeCell)\n ) as NodeCell[];\n },\n addEdge(edge) {\n dispatch({ type: \"add-edge\", payload: edge });\n },\n updateCells(newCells, ctx) {\n const { shouldReCenter, ...result } = updateCells({\n ...ctx,\n layout,\n previousCells: cells,\n cells: newCells,\n scaleRange,\n transform,\n allowEdgeToArea,\n });\n if (shouldReCenter) {\n setCentered(false);\n }\n dispatch({ type: \"update-cells\", payload: result.cells });\n return result;\n },\n getTransform() {\n return transform;\n },\n manuallyConnectNodes(sourceId) {\n const source = cells.find(\n (cell) =>\n ((allowEdgeToArea && isNodeOrAreaDecoratorCell(cell)) ||\n isNodeCell(cell)) &&\n cell.id === sourceId\n ) as NodeCell | DecoratorCell | undefined;\n if (source) {\n const rect = rootRef.current!.getBoundingClientRect();\n setConnectLineState({\n source,\n from: [\n source.view.x + source.view.width / 2,\n source.view.y + source.view.height / 2,\n ],\n offset: [rect.left, rect.top],\n });\n const promise = new Promise<ConnectNodesDetail>((resolve, reject) => {\n manualConnectDeferredRef.current = { resolve, reject };\n });\n return promise;\n }\n return Promise.reject(null);\n },\n }),\n [cells, layout, scaleRange, setCentered, transform, allowEdgeToArea]\n );\n\n const handleConnect = useCallback(\n (state: ConnectLineState, to: PositionTuple) => {\n // Find the target node from top bo bottom,\n // detect whether the pointer is inside the target node.\n for (let i = cells.length - 1; i >= 0; i--) {\n const cell = cells[i];\n // Currently ignore connecting to self\n if (\n ((allowEdgeToArea && isNodeOrAreaDecoratorCell(cell)) ||\n isNodeCell(cell)) &&\n cell.id !== state.source.id\n ) {\n if (\n cell.view.x < to[0] &&\n cell.view.x + cell.view.width > to[0] &&\n cell.view.y < to[1] &&\n cell.view.y + cell.view.height > to[1]\n ) {\n manualConnectDeferredRef.current?.resolve({\n source: state.source,\n target: cell,\n });\n break;\n }\n }\n }\n manualConnectDeferredRef.current?.reject(null);\n setConnectLineState(null);\n },\n [cells]\n );\n\n useEffect(() => {\n lockBodyScroll(host, !!(connectLineState || lassoRect));\n }, [connectLineState, host, lassoRect]);\n\n const activeTarget = useActiveTarget({\n cellsRef,\n activeTarget: _activeTarget,\n onActiveTargetChange,\n });\n\n const [unrelatedCells, setUnrelatedCells] = useState<Cell[]>([]);\n useEffect(() => {\n const nextUnrelated = fadeUnrelatedCells\n ? getUnrelatedCells(\n cells,\n connectLineState,\n activeTarget,\n allowEdgeToArea\n )\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 }, [\n activeTarget,\n cells,\n connectLineState,\n fadeUnrelatedCells,\n allowEdgeToArea,\n ]);\n\n useEffect(() => {\n const root = rootRef.current;\n if (!root || editingTexts.length > 0) {\n return;\n }\n const onKeydown = (event: KeyboardEvent) => {\n const action = handleKeyboard(event, {\n cells,\n activeTarget,\n });\n\n switch (action?.action) {\n case \"delete-cells\":\n onCellsDelete(action.cells);\n if (action.cells.length === 1) {\n onCellDelete(action.cells[0]);\n }\n break;\n }\n };\n root.addEventListener(\"keydown\", onKeydown);\n return () => {\n root.removeEventListener(\"keydown\", onKeydown);\n };\n }, [activeTarget, cells, editingTexts.length, onCellDelete, onCellsDelete]);\n\n const defPrefix = useMemo(() => `${uniqueId(\"diagram-\")}-`, []);\n const markerPrefix = `${defPrefix}line-arrow-`;\n /* istanbul ignore next */\n const handleCellsMoving = useCallback(\n (info: MoveCellPayload[]) => {\n dispatch({ type: \"move-cells\", payload: info });\n const containedIds: string[] = [];\n handleNodeContainedChange(info, cells).forEach((c) => {\n if (c.containerCell?.id) containedIds.push(c.containerCell?.id);\n });\n setActiveContainers(containedIds);\n },\n [cells]\n );\n /* istanbul ignore next */\n const handleCellsMoved = useCallback(\n (info: MoveCellPayload[]) => {\n dispatch({ type: \"move-cells\", payload: info });\n onCellsMove(info);\n if (info.length === 1) {\n onCellMove(info[0]);\n }\n handleNodeContainedChange(info, cells, onContainerContainerChange);\n setActiveContainers([]);\n },\n [onCellMove, onCellsMove, cells, onContainerContainerChange]\n );\n\n const handleCellResizing = useCallback((info: ResizeCellPayload) => {\n dispatch({ type: \"resize-cell\", payload: info });\n }, []);\n\n const handleCellResized = useCallback(\n (info: ResizeCellPayload) => {\n dispatch({ type: \"resize-cell\", payload: info });\n onCellResize(info);\n },\n [onCellResize]\n );\n\n const handleDecoratorTextEditing = useCallback(\n ({ id, editing }: { id: string; editing: boolean }) => {\n if (editing) {\n setEditingTexts((texts) =>\n texts.includes(id) ? texts : [...texts, id]\n );\n } else {\n setEditingTexts((texts) => texts.filter((text) => text !== id));\n }\n },\n []\n );\n\n const handleNodeBrickResize = useCallback(\n (id: string, size: SizeTuple | null) => {\n const nextLayoutKey = getNextLayoutKey();\n dispatch({\n type: \"update-node-size\",\n payload: { id, size },\n layoutKey: nextLayoutKey,\n });\n },\n [getNextLayoutKey]\n );\n\n const handleZoomSlide = useCallback(\n (value: number) => {\n // istanbul ignore next\n if (process.env.NODE_ENV !== \"test\") {\n zoomer.scaleTo(select(rootRef.current!), value / 100);\n }\n },\n [zoomer]\n );\n\n const reCenter = useCallback(() => {\n setCentered(false);\n }, [setCentered]);\n const [lineConfMap, markers] = useLineMarkers({\n cells,\n defaultEdgeLines,\n markerPrefix,\n });\n\n const ready = useReady({ cells, layout, centered });\n\n useEffect(() => {\n const root = rootRef.current;\n if (!root || dragBehavior !== \"lasso\") {\n return;\n }\n const rootRect = root.getBoundingClientRect();\n const onMouseDown = (event: MouseEvent) => {\n handleLasso(event, {\n transform,\n offset: [rootRect.left, rootRect.top],\n onLassoing(rect) {\n setLassoRect(rect);\n },\n onLassoed(rect) {\n setLassoRect(null);\n const lassoedCells: (NodeCell | DecoratorCell)[] = [];\n for (const cell of cells) {\n if (\n isContainerDecoratorCell(cell) ||\n isNodeOrAreaDecoratorCell(cell) ||\n isTextDecoratorCell(cell)\n ) {\n const x = cell.view.x;\n const y = cell.view.y;\n if (\n x >= rect.x &&\n x + cell.view.width <= rect.x + rect.width &&\n y >= rect.y &&\n y + cell.view.height <= rect.y + rect.height\n ) {\n lassoedCells.push(cell);\n }\n }\n }\n onSwitchActiveTarget?.(\n lassoedCells.length > 1\n ? { type: \"multi\", targets: lassoedCells.map(cellToTarget) }\n : lassoedCells.length === 1\n ? cellToTarget(lassoedCells[0])\n : null\n );\n },\n });\n };\n root.addEventListener(\"mousedown\", onMouseDown);\n return () => {\n root.removeEventListener(\"mousedown\", onMouseDown);\n };\n }, [transform, cells, dragBehavior, onSwitchActiveTarget]);\n return (\n <>\n <svg\n width=\"100%\"\n height=\"100%\"\n ref={rootRef}\n className={classNames(\"root\", { grabbing, pannable, ready })}\n tabIndex={-1}\n >\n <defs>\n {markers.map((marker, index) => (\n <MarkerComponent\n key={index}\n id={`${markerPrefix}${index}`}\n type=\"arrow\"\n strokeColor={marker.strokeColor}\n />\n ))}\n </defs>\n <g\n transform={`translate(${transform.x} ${transform.y}) scale(${transform.k})`}\n >\n <g\n className={classNames(\"cells\", { allowEdgeToArea })}\n ref={cellsRef}\n >\n {cells.map((cell) => (\n <CellComponent\n key={`${cell.type}:${isEdgeCell(cell) ? `${cell.source}~${cell.target}` : cell.id}`}\n dragNodeToContainerActive={\n isEdgeCell(cell) ? false : activeContainers.includes(cell.id)\n }\n layout={layout}\n cell={cell}\n cells={cells}\n degraded={degraded}\n degradedNodeLabel={degradedNodeLabel}\n defaultNodeBricks={defaultNodeBricks}\n transform={transform}\n lineConfMap={lineConfMap}\n activeTarget={activeTarget}\n unrelatedCells={unrelatedCells}\n onCellsMoving={handleCellsMoving}\n onCellsMoved={handleCellsMoved}\n onCellResizing={handleCellResizing}\n onCellResized={handleCellResized}\n onSwitchActiveTarget={onSwitchActiveTarget}\n onCellContextMenu={onCellContextMenu}\n onDecoratorTextChange={onDecoratorTextChange}\n onDecoratorTextEditing={handleDecoratorTextEditing}\n onNodeBrickResize={handleNodeBrickResize}\n />\n ))}\n </g>\n <ConnectLineComponent\n connectLineState={connectLineState}\n transform={transform}\n markerEnd={`${markerPrefix}0`}\n onConnect={handleConnect}\n />\n {lassoRect && (\n <rect\n x={lassoRect.x}\n y={lassoRect.y}\n width={lassoRect.width}\n height={lassoRect.height}\n fill=\"var(--palette-gray-5)\"\n fillOpacity={0.3}\n stroke=\"var(--palette-gray-5)\"\n strokeDasharray={2}\n />\n )}\n </g>\n </svg>\n <ZoomBarComponent\n shadowRoot={host.shadowRoot!}\n scale={transform.k}\n scaleRange={scaleRange}\n onZoomChange={handleZoomSlide}\n onReCenter={reCenter}\n />\n </>\n );\n}\n\nexport function uuidV4() {\n return \"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx\".replace(/[xy]/g, function (c) {\n const r = (Math.random() * 16) | 0,\n v = c == \"x\" ? r : (r & 0x3) | 0x8;\n return v.toString(16);\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","_EoDisplayCanvas_brand","WeakSet","_handleActiveTargetChange","_handleSwitchActiveTarget","_P","_handleCellContextMenu","_Q","_handleCellClick","EoDisplayCanvas","ReactNextElement","constructor","arguments","_classPrivateMethodInitSpec","_classPrivateFieldInitSpec","_init_cells","_init_extra_cells","_init_layout","_init_extra_layout","_init_layoutOptions","_init_extra_layoutOptions","_init_defaultNodeSize","DEFAULT_NODE_SIZE","_init_extra_defaultNodeSize","_init_defaultNodeBricks","_init_extra_defaultNodeBricks","_init_degradedThreshold","_init_extra_degradedThreshold","_init_degradedNodeLabel","_init_extra_degradedNodeLabel","_init_defaultEdgeLines","_init_extra_defaultEdgeLines","_init_activeTarget","_init_extra_activeTarget","_init_fadeUnrelatedCells","_init_extra_fadeUnrelatedCells","_init_zoomable","_init_extra_zoomable","_init_scrollable","_init_extra_scrollable","_init_pannable","_init_extra_pannable","_init_scaleRange","_init_extra_scaleRange","_init_activeTargetChangeEvent","_init_extra_activeTargetChangeEvent","target","_classPrivateGetter","this","_get_activeTargetChangeEvent","emit","sameTarget","activeTarget","_init_cellContextMenu","_init_extra_cellContextMenu","detail","_get_cellContextMenu","_init_cellClick","_init_extra_cellClick","_get_cellClick","cells","_classPrivateFieldGet","v","_classPrivateFieldSet","layout","layoutOptions","defaultNodeSize","defaultNodeBricks","degradedThreshold","degradedNodeLabel","defaultEdgeLines","fadeUnrelatedCells","zoomable","scrollable","pannable","scaleRange","render","React","EoDisplayCanvasComponent","shadowRoot","onActiveTargetChange","onSwitchActiveTarget","onCellContextMenu","onCellClick","_ref","initialCells","_activeTarget","_scaleRange","layoutKey","dispatch","useReducer","rootReducer","initializeCells","degraded","useMemo","filter","isNodeCell","length","DEFAULT_DEGRADED_THRESHOLD","rootRef","useRef","cellsRef","grabbing","transform","zoomer","useZoom","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","ready","useReady","width","height","ref","className","classNames","tabIndex","map","marker","index","MarkerComponent","key","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","lockBodyScroll","unwrapProvider","method","EoDrawCanvasComponent","LegacyEoDrawCanvasComponent","_EoDrawCanvas","_R","_S","_EoDrawCanvas_brand","_T","_U","_handleCellMove","_V","_handleCellsMove","_W","_handleCellResize","_X","_Y","_handleCellDelete","_Z","_handleCellsDelete","_a","_b","_handleDecoratorTextChange","_c","_handleContainerContainerChange","_d","_handleScaleChange","_canvasRef","EoDrawCanvas","_initProto","_init_selectable","_init_extra_selectable","_init_allowEdgeToArea","_init_extra_allowEdgeToArea","_init_dragBehavior","_init_extra_dragBehavior","_init_ctrlDragBehavior","_init_extra_ctrlDragBehavior","_init_nodeMoveEvent","_init_extra_nodeMoveEvent","_init_cellMoveEvent","_init_extra_cellMoveEvent","info","_get_cellMoveEvent","_get_nodeMoveEvent","_init_cellsMoveEvent","_init_extra_cellsMoveEvent","_get_cellsMoveEvent","_init_cellResizeEvent","_init_extra_cellResizeEvent","_get_cellResizeEvent","_init_nodeDelete","_init_extra_nodeDelete","_init_cellDelete","_init_extra_cellDelete","_get_cellDelete","_get_nodeDelete","_init_cellsDelete","_init_extra_cellsDelete","_get_cellsDelete","_init_decoratorTextChange","_init_extra_decoratorTextChange","_get_decoratorTextChange","_init_containerContainerChange","_init_extra_containerContainerChange","_get_containerContainerChange","_init_scaleChange","_init_extra_scaleChange","_get_scaleChange","createRef","selectable","allowEdgeToArea","dragBehavior","ctrlDragBehavior","dropNode","_document$elementsFro","_document","position","data","useBrick","document","elementsFromPoint","call","includes","_classPrivateFieldGet2","boundingClientRect","getBoundingClientRect","getTransform","newNode","view","left","top","dropDecorator","_ref2","_document$elementsFro2","_document2","decorator","text","direction","_classPrivateFieldGet3","newDecorator","uuidV4","DEFAULT_AREA_WIDTH","DEFAULT_AREA_HEIGHT","addNodes","nodes","newNodes","_ref3","addEdge","_ref4","_classPrivateFieldGet4","newEdge","manuallyConnectNodes","ctx","_assertClassBrand","_waitForCanvasRef","updated","disconnectedCallback","super","onCellMove","onCellsMove","onCellResize","onCellDelete","onCellsDelete","onDecoratorTextChange","onContainerContainerChange","onScaleChange","Promise","resolve","check","setTimeout","_ref5","manualConnectDeferredRef","editingTexts","setEditingTexts","activeContainers","setActiveContainers","ctrlDraggable","lassoRect","setLassoRect","connectLineState","setConnectLineState","useImperativeHandle","node","_ref6","findLastIndex","newCells","slice","allCells","shouldReCenter","edge","sourceId","find","isNodeOrAreaDecoratorCell","rect","from","offset","reject","handleConnect","state","to","_manualConnectDeferre2","i","_manualConnectDeferre","root","onKeydown","action","handleKeyboard","addEventListener","removeEventListener","handleCellsMoving","containedIds","handleNodeContainedChange","forEach","_c$containerCell","_c$containerCell2","containerCell","push","handleCellsMoved","handleCellResizing","handleCellResized","handleDecoratorTextEditing","_ref7","editing","texts","nextLayoutKey","rootRect","onMouseDown","handleLasso","onLassoing","onLassoed","lassoedCells","isContainerDecoratorCell","isTextDecoratorCell","targets","cellToTarget","dragNodeToContainerActive","onCellsMoving","onCellsMoved","onCellResizing","onCellResized","onDecoratorTextEditing","ConnectLineComponent","markerEnd","onConnect","fill","fillOpacity","stroke","strokeDasharray","replace","r","Math","random","toString","_EoDrawCanvas2","_set_nodeMoveEvent","_set_cellMoveEvent","_set_cellsMoveEvent","_set_cellResizeEvent","_set_nodeDelete","_set_cellDelete","_set_cellsDelete","_set_decoratorTextChange","_set_containerContainerChange","_set_scaleChange"],"sourceRoot":""}
|
|
1
|
+
{"version":3,"file":"chunks/eo-display-canvas.431eb9f3.js","mappings":"2mBA8CA,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,IAAAC,QAAAC,GAAA,IAAAjB,QAAAkB,GAAA,IAAAlB,QAAAmB,GAAA,IAAAnB,QAAAoB,GAAA,IAAApB,QAAAqB,GAAA,IAAArB,QAAAsB,GAAA,IAAAtB,QAuB9D,MAAAuB,WAG8BC,EAAAA,iBAAiDC,WAAAA,GAAA,SAAAC,YAAAC,EAAAA,EAAAA,GAAA,KAAAZ,KAC7Ea,EAAAA,EAAAA,GAAA,KAAA7B,GAAA8B,EAAA,QAAAD,EAAAA,EAAAA,GAAA,KAAA3B,IAAA6B,EAAA,MAAAC,EAAA,SAAAH,EAAAA,EAAAA,GAAA,KAAA1B,IAAA8B,EAAA,MAAAC,EAAA,SAAAL,EAAAA,EAAAA,GAAA,KAAAzB,IAAA+B,EAAA,MAAAC,EAAA,KAasC,CAACC,EAAAA,GAAmBA,EAAAA,QAAkBR,EAAAA,EAAAA,GAAA,KAAAxB,IAAAiC,EAAA,MAAAC,EAAA,SAK5EV,EAAAA,EAAAA,GAAA,KAAAvB,IAAAkC,EAAA,MAAAC,EAAA,SAWAZ,EAAAA,EAAAA,GAAA,KAAAtB,IAAAmC,EAAA,MAAAC,EAAA,SAQAd,EAAAA,EAAAA,GAAA,KAAArB,IAAAoC,EAAA,MAAAC,EAAA,SAAAhB,EAAAA,EAAAA,GAAA,KAAApB,IAAAqC,EAAA,MAAAC,EAAA,SAeAlB,EAAAA,EAAAA,GAAA,KAAAnB,IAAAsC,GAAA,MAAAC,GAAA,SAAApB,EAAAA,EAAAA,GAAA,KAAAlB,IAAAuC,GAAA,MAAAC,GAAA,MAOyC,MAAItB,EAAAA,EAAAA,GAAA,KAAAjB,IAAAwC,GAAA,MAAAC,GAAA,MAGF,MAAIxB,EAAAA,EAAAA,GAAA,KAAAhB,IAAAyC,GAAA,MAAAC,GAAA,MAGN,MAAI1B,EAAAA,EAAAA,GAAA,KAAAf,IAAA0C,GAAA,MAAAC,GAAA,SAAA5B,EAAAA,EAAAA,GAAA,KAAAd,IAAA2C,GAAA,MAAAC,GAAA,SAQ7C9B,EAAAA,EAAAA,GAAA,KAAAX,IAAyB0C,GAAA,MAAIC,KAC3BC,EAAAA,EAAAA,GAAA9C,GAAA+C,KAAKC,IAAyBC,KAAKJ,EAAO,KAG5ChC,EAAAA,EAAAA,GAAA,KAAAV,IAA6B0C,KACtBK,EAAAA,EAAAA,GAAWL,EAAQE,KAAKI,gBAC3BJ,KAAKI,aAAeN,EACtB,KACAhC,EAAAA,EAAAA,GAAA,KAAAT,GAAAgD,GAAA,QAKFvC,EAAAA,EAAAA,GAAA,KAAAR,IAAsBgD,GAAA,MAAIC,KACxBR,EAAAA,EAAAA,GAAA9C,GAAA+C,KAAKQ,IAAiBN,KAAKK,EAAO,KAClCzC,EAAAA,EAAAA,GAAA,KAAAP,GAAAkD,GAAA,QAKF3C,EAAAA,EAAAA,GAAA,KAAAN,IAAgBkD,GAAA,MAAIH,KAClBR,EAAAA,EAAAA,GAAA9C,GAAA+C,KAAKW,IAAWT,KAAKK,EAAO,GAC5B,UA3FOK,GAAK,OAAAC,EAAAA,EAAAA,GAAA5E,GAAA,eAAL2E,CAAKE,IAAAC,EAAAA,EAAAA,GAAA9E,GAAA,KAAA6E,EAAA,WAGLE,GAAM,OAAAH,EAAAA,EAAAA,GAAA1E,GAAA,gBAAN6E,CAAMF,IAAAC,EAAAA,EAAAA,GAAA5E,GAAA,KAAA2E,EAAA,kBAGNG,GAAa,OAAAJ,EAAAA,EAAAA,GAAAzE,GAAA,uBAAb6E,CAAaH,IAAAC,EAAAA,EAAAA,GAAA3E,GAAA,KAAA0E,EAAA,oBAGbI,GAAe,OAAAL,EAAAA,EAAAA,GAAAxE,GAAA,yBAAf6E,CAAeJ,IAAAC,EAAAA,EAAAA,GAAA1E,GAAA,KAAAyE,EAAA,sBAGfK,GAAiB,OAAAN,EAAAA,EAAAA,GAAAvE,GAAA,2BAAjB6E,CAAiBL,IAAAC,EAAAA,EAAAA,GAAAzE,GAAA,KAAAwE,EAAA,sBAQjBM,GAAiB,OAAAP,EAAAA,EAAAA,GAAAtE,GAAA,2BAAjB6E,CAAiBN,IAAAC,EAAAA,EAAAA,GAAAxE,GAAA,KAAAuE,EAAA,sBAWjBO,GAAiB,OAAAR,EAAAA,EAAAA,GAAArE,GAAA,2BAAjB6E,CAAiBP,IAAAC,EAAAA,EAAAA,GAAAvE,GAAA,KAAAsE,EAAA,qBAYjBQ,GAAgB,OAAAT,EAAAA,EAAAA,GAAApE,GAAA,0BAAhB6E,CAAgBR,IAAAC,EAAAA,EAAAA,GAAAtE,GAAA,KAAAqE,EAAA,iBAGhBV,GAAY,OAAAS,EAAAA,EAAAA,GAAAnE,GAAA,sBAAZ0D,CAAYU,IAAAC,EAAAA,EAAAA,GAAArE,GAAA,KAAAoE,EAAA,uBAMZS,GAAkB,OAAAV,EAAAA,EAAAA,GAAAlE,GAAA,4BAAlB4E,CAAkBT,IAAAC,EAAAA,EAAAA,GAAApE,GAAA,KAAAmE,EAAA,aAGlBU,GAAQ,OAAAX,EAAAA,EAAAA,GAAAjE,GAAA,kBAAR4E,CAAQV,IAAAC,EAAAA,EAAAA,GAAAnE,GAAA,KAAAkE,EAAA,eAGRW,GAAU,OAAAZ,EAAAA,EAAAA,GAAAhE,GAAA,oBAAV4E,CAAUX,IAAAC,EAAAA,EAAAA,GAAAlE,GAAA,KAAAiE,EAAA,aAGVY,GAAQ,OAAAb,EAAAA,EAAAA,GAAA/D,GAAA,kBAAR4E,CAAQZ,IAAAC,EAAAA,EAAAA,GAAAjE,GAAA,KAAAgE,EAAA,eAGRa,GAAU,OAAAd,EAAAA,EAAAA,GAAA9D,GAAA,oBAAV4E,CAAUb,IAAAC,EAAAA,EAAAA,GAAAhE,GAAA,KAAA+D,EAAA,CA6BnBc,MAAAA,GACE,OACEC,IAAAA,cAACC,GAAwB,CACvBC,WAAY/B,KAAK+B,WACjBnB,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,WACjBK,sBAAsBnB,EAAAA,EAAAA,GAAK1D,GAAL6C,MACtBiC,sBAAsBpB,EAAAA,EAAAA,GAAKzD,GAAL4C,MACtBkC,mBAAmBrB,EAAAA,EAAAA,GAAKvD,GAAL0C,MACnBmC,aAAatB,EAAAA,EAAAA,GAAKrD,GAALwC,OAGnB,EAWF,SAAS8B,GAAwBM,GAoBC,IApBA,WAChCL,EACAnB,MAAOyB,EAAY,OACnBrB,EAAM,cACNC,EAAa,gBACbC,EAAe,kBACfC,EAAiB,iBACjBG,EAAgB,kBAChBF,EAAiB,kBACjBC,EACAjB,aAAckC,EAAa,mBAC3Bf,EAAkB,SAClBC,EAAQ,WACRC,EAAU,SACVC,EACAC,WAAYY,EAAW,qBACvBP,EAAoB,qBACpBC,EAAoB,kBACpBC,EAAiB,YACjBC,GAC8BC,EAC9B,OAAO,MAAExB,EAAK,UAAE4B,GAAaC,IAAYC,EAAAA,EAAAA,YACvCC,EAAAA,EACAN,GACCA,IAAY,CACXzB,OAAOgC,EAAAA,EAAAA,GAAgBP,EAAc,CAAEnB,oBACvCsB,UAAW,MAMTK,GAAWC,EAAAA,EAAAA,UACf,IACElC,EAAMmC,OAAOC,EAAAA,GAAYC,SACxB7B,GAAqB8B,EAAAA,KACxB,CAACtC,EAAOQ,IAGJ+B,GAAUC,EAAAA,EAAAA,QAAsB,MAChCC,GAAWD,EAAAA,EAAAA,QAAoB,OAE/B,SAAEE,EAAQ,UAAEC,EAAS,OAAEC,EAAM,WAAE7B,IAAe8B,EAAAA,EAAAA,GAAQ,CAC1DN,UACA3B,WACAC,aACAC,WACAgC,WAAW,EACX/B,WAAYY,EACZN,0BAGI,SAAE0B,EAAQ,YAAEC,EAAW,iBAAEC,IAAqBC,EAAAA,EAAAA,GAAU,CAC5D9C,SACAC,gBACAkC,UACAvC,QACAY,WACAgC,SACA7B,aACAa,YACAC,aAGIsB,GAAWC,EAAAA,EAAAA,cAAY,KAC3BJ,GAAY,EAAM,GACjB,CAACA,IAEEK,GAAmBb,EAAAA,EAAAA,QAAOf,IAEhC6B,EAAAA,EAAAA,YAAU,KACR,GAAI7B,IAAiB4B,EAAiBE,QAAS,CAC7CF,EAAiBE,QAAU9B,EAC3B,MAAM+B,GAASC,EAAAA,EAAAA,GAAY,CACzBC,YAAavC,EAAWwC,KAAKC,YAC7BC,aAAc1C,EAAWwC,KAAKG,aAC9BxD,kBACAF,SACA2D,cAAe/D,EACfA,MAAOyB,EACPV,aACA4B,cAEFd,EAAS,CAAEmC,KAAM,eAAgBC,QAAST,EAAOxD,OACnD,IACC,CACDA,EACAM,EACAmB,EACArB,EACAW,EACAI,EACAwB,IAGF,MAAMnD,IAAe0E,EAAAA,EAAAA,GAAgB,CACnCzB,WACAjD,aAAckC,EACdN,yBAII+C,GAAe,IADHjC,EAAAA,EAAAA,UAAQ,IAAM,IAAGkC,EAAAA,EAAAA,UAAS,gBAAgB,iBAGtDC,IAAwBjB,EAAAA,EAAAA,cAC5B,CAACkB,EAAYC,KACX1C,EAAS,CACPmC,KAAM,mBACNC,QAAS,CAAEK,KAAIC,QACf3C,UAAWqB,KACX,GAEJ,CAACA,KAGIuB,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,EAAgBtE,GAClBuE,EAAAA,EAAAA,GAAkBlF,EAAO,KAAMwE,IAC/B,GAEJQ,IAAmBF,GACD,IAAhBA,EAAKzC,QAAyC,IAAzB4C,EAAc5C,OAAeyC,EAAOG,GAC1D,GACA,CAACjF,EAAOW,EAAoB6D,KAE/B,MAAMW,IAAkB/B,EAAAA,EAAAA,cACrBgC,IAGGxC,EAAOyC,SAAQC,EAAAA,EAAAA,GAAO/C,EAAQgB,SAAW6B,EAAQ,IACnD,GAEF,CAACxC,KAGI2C,GAAaC,KAAWC,EAAAA,EAAAA,GAAe,CAC5CzF,QACAU,mBACAyD,kBAGIuB,IAAQC,EAAAA,EAAAA,GAAS,CAAE3F,QAAOI,SAAQ2C,aAExC,OACE9B,IAAAA,cAAAA,IAAAA,SAAA,KACEA,IAAAA,cAAA,OACE2E,MAAM,OACNC,OAAO,OACPC,IAAKvD,EACLwD,UAAWC,IAAW,OAAQ,CAAEtD,WAAU5B,WAAU4E,WACpDO,UAAW,GAEXhF,IAAAA,cAAA,YACGuE,GAAQU,KAAI,CAACC,EAAQC,IACpBnF,IAAAA,cAACoF,EAAAA,EAAe,CACdC,IAAKF,EACL9B,GAAI,GAAGH,KAAeiC,IACtBpC,KAAK,QACLuC,YAAaJ,EAAOI,iBAI1BtF,IAAAA,cAAA,KACE0B,UAAW,aAAaA,EAAU6D,KAAK7D,EAAU8D,YAAY9D,EAAU+D,MAEvEzF,IAAAA,cAAA,KAAG8E,UAAU,QAAQD,IAAKrD,GACvBzC,EAAMkG,KAAKtB,GACV3D,IAAAA,cAAC0F,EAAAA,EAAa,CACZL,IAAK,GAAG1B,EAAKZ,SAAQ4C,EAAAA,EAAAA,IAAWhC,GAAQ,GAAGA,EAAKiC,UAAUjC,EAAK1F,SAAW0F,EAAKN,KAC/ElE,OAAQA,EACRwE,KAAMA,EACN5E,MAAOA,EACPiC,SAAUA,EACVxB,kBAAmBA,EACnBF,kBAAmBA,EACnBgF,YAAaA,GACb5C,UAAWA,EACXnD,aAAcA,GACdsH,UAAQ,EACR/B,eAAgBA,GAChB1D,qBAAsBA,EACtBC,kBAAmBA,EACnBC,YAAaA,EACbwF,kBAAmB1C,GACnB2C,iBACErG,IAAsByB,EAAAA,EAAAA,GAAWwC,GAC7BD,QACAsC,EAENC,iBACEvG,IAAsByB,EAAAA,EAAAA,GAAWwC,GAC7BC,QACAoC,SAOhBhG,IAAAA,cAACkG,EAAAA,EAAgB,CACfhG,WAAYA,EACZiG,MAAOzE,EAAU+D,EACjB3F,WAAYA,EACZsG,aAAclC,GACdmC,WAAYnE,IAIpB,CAnOCoE,EAAA1K,KAAA2K,GAAArK,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAE,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAK,GAAAoI,GAAAxI,GAAAQ,GAAAG,GAAA8H,GAAAhI,GAAAG,GAAAE,GAAA4H,GAAA7H,IAAA8H,GAAAxM,GAAAyM,KAAAC,EAAAA,EAAAA,GAAAP,EAAA,CA9HAvM,GAAc,oBAAqB,CAClC+M,WAAY,CAACC,EAAAA,EAAWC,EAAAA,MACxB,EAKChN,GAAS,CAAEiN,WAAW,IAAQ,YAG9BjN,GAAS,CAAE+I,KAAMmE,SAAS,aAG1BlN,GAAS,CAAEiN,WAAW,IAAQ,oBAG9BjN,GAAS,CAAEiN,WAAW,IAAQ,sBAG9BjN,GAAS,CAAEiN,WAAW,IAAQ,wBAQ9BjN,GAAS,CAAE+I,KAAMoE,SAAS,wBAW1BnN,GAAS,CAAEiN,WAAW,IAAQ,wBAY9BjN,GAAS,CAAEiN,WAAW,IAAQ,uBAG9BjN,GAAS,CAAEiN,WAAW,IAAQ,mBAM9BjN,GAAS,CAAE+I,KAAMqE,UAAU,yBAG3BpN,GAAS,CAAE+I,KAAMqE,UAAU,eAG3BpN,GAAS,CAAE+I,KAAMqE,UAAU,iBAG3BpN,GAAS,CAAE+I,KAAMqE,UAAU,eAG3BpN,GAAS,CAAEiN,WAAW,IAAQ,iBAG9BhN,GAAM,CAAE8I,KAAM,wBAAwB,4BAAAsE,IAAArI,EAAAA,EAAAA,GAAA7D,GAAAkM,GAAA,CAAAA,EAAApI,KAAAC,EAAAA,EAAAA,GAAA/D,GAAAkM,EAAApI,IAAA,CAatChF,GAAM,CAAE8I,KAAM,qBAAqB,oBAAAsE,IAAArI,EAAAA,EAAAA,GAAAxD,GAAA6L,GAAA,CAAAA,EAAApI,KAAAC,EAAAA,EAAAA,GAAA1D,GAAA6L,EAAApI,IAAA,CAOnChF,GAAM,CAAE8I,KAAM,eAAe,cAAAsE,IAAArI,EAAAA,EAAAA,GAAAtD,GAAA2L,GAAA,CAAAA,EAAApI,KAAAC,EAAAA,EAAAA,GAAAxD,GAAA2L,EAAApI,KAAA,GAAAqI,GAAA3L,GAAA4L,KAAAC,EAAAA,EAAAA,GAAAF,KA3FFzL,EAAAA,mBAAgB+K,G,2uBCS9C,MAAMa,IAAiBC,EAAAA,EAAAA,gBACrB,2BAGI,cAAE3N,GAAa,SAAEC,GAAQ,OAAE2N,GAAM,MAAE1N,KAAUC,EAAAA,EAAAA,oBA8DtC0N,GAAwB5H,IAAAA,WACnC6H,IAGF,IAAAC,GAAA,IAAA1N,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,QAAAmB,GAAA,IAAAnB,QAAAqB,GAAA,IAAArB,QAAA0N,GAAA,IAAA1N,QAAA2N,GAAA,IAAA3N,QAAA4N,GAAA,IAAA5M,QAAAC,GAAA,IAAAjB,QAAAkB,GAAA,IAAAlB,QAAA6N,GAAA,IAAA7N,QAAA8N,GAAA,IAAA9N,QAAA+N,GAAA,IAAA/N,QAAAgO,GAAA,IAAAhO,QAAAiO,GAAA,IAAAjO,QAAAkO,GAAA,IAAAlO,QAAAmO,GAAA,IAAAnO,QAAAoO,GAAA,IAAApO,QAAAqO,GAAA,IAAArO,QAAAsO,GAAA,IAAAtO,QAAAuO,GAAA,IAAAvO,QAAAwO,GAAA,IAAAxO,QAAAyO,GAAA,IAAAzO,QAAAoB,GAAA,IAAApB,QAAA0O,GAAA,IAAA1O,QAAA2O,GAAA,IAAA3O,QAAA4O,GAAA,IAAA5O,QAAA6O,GAAA,IAAA7O,QAAA8O,GAAA,IAAA9O,QAAA+O,GAAA,IAAA/O,QAAAgP,GAAA,IAAAhP,QAMA,MAAAiP,WAG2BzN,EAAAA,iBAA8CC,WAAAA,GAAA,SAAAC,YAAAC,EAAAA,EAAAA,GAAA,KAAAiM,KACvEhM,EAAAA,EAAAA,GAAA,KAAA7B,IAAAmP,EAAA,MAAArN,EAAA,SAAAD,EAAAA,EAAAA,GAAA,KAAA3B,IAAA6B,EAAA,MAAAC,EAAA,SAAAH,EAAAA,EAAAA,GAAA,KAAA1B,IAAA8B,EAAA,MAAAC,EAAA,SAAAL,EAAAA,EAAAA,GAAA,KAAAzB,IAAA+B,EAAA,MAAAC,EAAA,KAasC,CAACC,EAAAA,GAAmBA,EAAAA,QAAkBR,EAAAA,EAAAA,GAAA,KAAAxB,IAAAiC,EAAA,MAAAC,EAAA,SAK5EV,EAAAA,EAAAA,GAAA,KAAAvB,IAAAkC,GAAA,MAAAC,GAAA,SAWAZ,EAAAA,EAAAA,GAAA,KAAAtB,IAAAmC,GAAA,MAAAC,GAAA,SAQAd,EAAAA,EAAAA,GAAA,KAAArB,IAAAoC,GAAA,MAAAC,GAAA,SAAAhB,EAAAA,EAAAA,GAAA,KAAApB,IAAAqC,GAAA,MAAAC,GAAA,SAeAlB,EAAAA,EAAAA,GAAA,KAAAnB,IAAAsC,GAAA,MAAAC,GAAA,SAAApB,EAAAA,EAAAA,GAAA,KAAAlB,IAAAuC,GAAA,MAAAC,GAAA,MAOyC,MAAItB,EAAAA,EAAAA,GAAA,KAAAjB,IAAAwC,GAAA,MAAAC,GAAA,MAGF,MAAIxB,EAAAA,EAAAA,GAAA,KAAAhB,IAAAyC,GAAA,MAAAC,GAAA,MAGN,MAAI1B,EAAAA,EAAAA,GAAA,KAAAf,IAAA0C,GAAA,MAAA4L,GAAA,MAGF,MAAIvN,EAAAA,EAAAA,GAAA,KAAAd,IAAAsO,GAAA,MAAAC,GAAA,MAGC,MAEhDzN,EAAAA,EAAAA,GAAA,KAAAT,IAAAmO,GAAA,MAAAC,GAAA,SAWA3N,EAAAA,EAAAA,GAAA,KAAAP,IAAAmO,GAAA,MAAAC,GAAA,SAAA7N,EAAAA,EAAAA,GAAA,KAAA8L,IAAAgC,GAAA,MAAAlM,GAAA,SAAA5B,EAAAA,EAAAA,GAAA,KAAA+L,IAAAlK,GAAA,MAAAC,GAAA,SAgBA9B,EAAAA,EAAAA,GAAA,KAAAX,IAAyB0C,GAAA,MAAIC,KAC3BC,EAAAA,EAAAA,GAAA+J,GAAA9J,KAAKC,IAAyBC,KAAKJ,EAAO,KAG5ChC,EAAAA,EAAAA,GAAA,KAAAV,IAA6B0C,KACtBK,EAAAA,EAAAA,GAAWL,EAAQE,KAAKI,gBAC3BJ,KAAKI,aAAeN,EACtB,KAGFhC,EAAAA,EAAAA,GAAA,KAAAiM,GAAA8B,GAAA,QAAA/N,EAAAA,EAAAA,GAAA,KAAAkM,IAAA8B,GAAA,MAAAC,GAAA,SASAjO,EAAAA,EAAAA,GAAA,KAAAmM,IAAe+B,GAAA,MAAIC,KACjBlM,EAAAA,EAAAA,GAAA+J,GAAA9J,KAAKkM,IAAehM,KAAK+L,GACP,SAAdA,EAAKrH,OACP7E,EAAAA,EAAAA,GAAA+J,GAAA9J,KAAKmM,IAAejM,KAAK+L,EAC3B,KACAnO,EAAAA,EAAAA,GAAA,KAAAoM,GAAAkC,GAAA,QAKFtO,EAAAA,EAAAA,GAAA,KAAAqM,IAAgBkC,GAAA,MAAIJ,KAClBlM,EAAAA,EAAAA,GAAA+J,GAAA9J,KAAKsM,IAAgBpM,KAAK+L,EAAK,KAC/BnO,EAAAA,EAAAA,GAAA,KAAAsM,GAAAmC,GAAA,QAKFzO,EAAAA,EAAAA,GAAA,KAAAuM,IAAiBmC,GAAA,MAAIP,KACnBlM,EAAAA,EAAAA,GAAA+J,GAAA9J,KAAKyM,IAAiBvM,KAAK+L,EAAK,KAGlCnO,EAAAA,EAAAA,GAAA,KAAAwM,GAAAoC,GAAA,QAAA5O,EAAAA,EAAAA,GAAA,KAAAyM,IAAAoC,GAAA,MAAAC,GAAA,SASA9O,EAAAA,EAAAA,GAAA,KAAA0M,IAAiBqC,GAAA,MAAIrH,KACnBzF,EAAAA,EAAAA,GAAA+J,GAAA9J,KAAK8M,IAAY5M,KAAKsF,GACJ,SAAdA,EAAKZ,OACP7E,EAAAA,EAAAA,GAAA+J,GAAA9J,KAAK+M,IAAY7M,KAAKsF,EACxB,KACA1H,EAAAA,EAAAA,GAAA,KAAA2M,GAAAuC,GAAA,QAKFlP,EAAAA,EAAAA,GAAA,KAAA4M,IAAkBuC,GAAA,MAAIrM,KACpBb,EAAAA,EAAAA,GAAA+J,GAAA9J,KAAKkN,IAAahN,KAAKU,EAAM,KAC7B9C,EAAAA,EAAAA,GAAA,KAAA6M,GAAAtK,GAAA,QAKFvC,EAAAA,EAAAA,GAAA,KAAAR,IAAsBgD,GAAA,MAAIC,KACxBR,EAAAA,EAAAA,GAAA+J,GAAA9J,KAAKQ,IAAiBN,KAAKK,EAAO,KAClCzC,EAAAA,EAAAA,GAAA,KAAA8M,GAAAuC,GAAA,QAKFrP,EAAAA,EAAAA,GAAA,KAAA+M,IAA0BuC,GAAA,MAAI7M,KAC5BR,EAAAA,EAAAA,GAAA+J,GAAA9J,KAAKqN,IAAqBnN,KAAKK,EAAO,KAGxCzC,EAAAA,EAAAA,GAAA,KAAAgN,GAAAwC,GAAA,QAMAxP,EAAAA,EAAAA,GAAA,KAAAiN,IAA+BwC,GAAA,MAAIhN,KACjCR,EAAAA,EAAAA,GAAA+J,GAAA9J,KAAKwN,IAA0BtN,KAAKK,EAAO,KAG7CzC,EAAAA,EAAAA,GAAA,KAAAkN,GAAAyC,GAAA,QAMA3P,EAAAA,EAAAA,GAAA,KAAAmN,IAAkByC,GAAA,MAAI1F,KACpBjI,EAAAA,EAAAA,GAAA+J,GAAA9J,KAAK2N,IAAazN,KAAK8H,EAAM,KAiJ/BlK,EAAAA,EAAAA,GAAA,KAAAoN,IAAa0C,EAAAA,EAAAA,aAA2B,UA/U/BhN,GAAK,OAAAC,EAAAA,EAAAA,GAAA5E,GAAA,eAAL2E,CAAKE,IAAAC,EAAAA,EAAAA,GAAA9E,GAAA,KAAA6E,EAAA,WAGLE,GAAM,OAAAH,EAAAA,EAAAA,GAAA1E,GAAA,gBAAN6E,CAAMF,IAAAC,EAAAA,EAAAA,GAAA5E,GAAA,KAAA2E,EAAA,kBAGNG,GAAa,OAAAJ,EAAAA,EAAAA,GAAAzE,GAAA,uBAAb6E,CAAaH,IAAAC,EAAAA,EAAAA,GAAA3E,GAAA,KAAA0E,EAAA,oBAGbI,GAAe,OAAAL,EAAAA,EAAAA,GAAAxE,GAAA,yBAAf6E,CAAeJ,IAAAC,EAAAA,EAAAA,GAAA1E,GAAA,KAAAyE,EAAA,sBAGfK,GAAiB,OAAAN,EAAAA,EAAAA,GAAAvE,GAAA,2BAAjB6E,CAAiBL,IAAAC,EAAAA,EAAAA,GAAAzE,GAAA,KAAAwE,EAAA,sBAQjBM,GAAiB,OAAAP,EAAAA,EAAAA,GAAAtE,GAAA,2BAAjB6E,CAAiBN,IAAAC,EAAAA,EAAAA,GAAAxE,GAAA,KAAAuE,EAAA,sBAWjBO,GAAiB,OAAAR,EAAAA,EAAAA,GAAArE,GAAA,2BAAjB6E,CAAiBP,IAAAC,EAAAA,EAAAA,GAAAvE,GAAA,KAAAsE,EAAA,qBAYjBQ,GAAgB,OAAAT,EAAAA,EAAAA,GAAApE,GAAA,0BAAhB6E,CAAgBR,IAAAC,EAAAA,EAAAA,GAAAtE,GAAA,KAAAqE,EAAA,iBAGhBV,GAAY,OAAAS,EAAAA,EAAAA,GAAAnE,GAAA,sBAAZ0D,CAAYU,IAAAC,EAAAA,EAAAA,GAAArE,GAAA,KAAAoE,EAAA,uBAMZS,GAAkB,OAAAV,EAAAA,EAAAA,GAAAlE,GAAA,4BAAlB4E,CAAkBT,IAAAC,EAAAA,EAAAA,GAAApE,GAAA,KAAAmE,EAAA,aAGlBU,GAAQ,OAAAX,EAAAA,EAAAA,GAAAjE,GAAA,kBAAR4E,CAAQV,IAAAC,EAAAA,EAAAA,GAAAnE,GAAA,KAAAkE,EAAA,eAGRW,GAAU,OAAAZ,EAAAA,EAAAA,GAAAhE,GAAA,oBAAV4E,CAAUX,IAAAC,EAAAA,EAAAA,GAAAlE,GAAA,KAAAiE,EAAA,aAGVY,GAAQ,OAAAb,EAAAA,EAAAA,GAAA/D,GAAA,kBAAR4E,CAAQZ,IAAAC,EAAAA,EAAAA,GAAAjE,GAAA,KAAAgE,EAAA,eAGR+M,GAAU,OAAAhN,EAAAA,EAAAA,GAAA9D,GAAA,oBAAV8Q,CAAU/M,IAAAC,EAAAA,EAAAA,GAAAhE,GAAA,KAAA+D,EAAA,oBAGVgN,GAAe,OAAAjN,EAAAA,EAAAA,GAAA7D,GAAA,yBAAf8Q,CAAehN,IAAAC,EAAAA,EAAAA,GAAA/D,GAAA,KAAA8D,EAAA,iBAWfiN,GAAY,OAAAlN,EAAAA,EAAAA,GAAAxD,GAAA,sBAAZ0Q,CAAYjN,IAAAC,EAAAA,EAAAA,GAAA1D,GAAA,KAAAyD,EAAA,qBAUZkN,GAAgB,OAAAnN,EAAAA,EAAAA,GAAAtD,GAAA,0BAAhByQ,CAAgBlN,IAAAC,EAAAA,EAAAA,GAAAxD,GAAA,KAAAuD,EAAA,eAGhBa,GAAU,OAAAd,EAAAA,EAAAA,GAAA+I,GAAA,oBAAVjI,CAAUb,IAAAC,EAAAA,EAAAA,GAAA6I,GAAA,KAAA9I,EAAA,CAsGnB,cACMmN,CAAQ7L,GAM6B,IAAA8L,EAAAC,EAAA,IAN5B,GACbjJ,EAAE,SACFkJ,EAAQ,KACRjJ,EAAI,KACJkJ,EAAI,SACJC,GACalM,EAKb,GAFoB,QADD8L,GAAGC,EAAAI,UACnBC,yBAAiB,IAAAN,GAA4B,QAA5BA,EADEA,EAAAO,KAAAN,EACCC,EAAS,GAAIA,EAAS,WAAG,IAAAF,OAAA,EAD1BA,EAElBQ,SAAS1O,MACM,KAAA2O,EACjB,MAAMC,EAAqB5O,KAAK6O,wBAC1BtL,GAAY1C,EAAAA,EAAAA,GAAKqK,GAALlL,MAAgBmE,QAAS2K,eACrCC,EAAU,CACdnK,KAAM,OACNM,KACA8J,KAAM,IACgB,UAAhBhP,KAAKgB,QAAsC,UAAhBhB,KAAKgB,OAChC,KACA,CACEoG,GACGgH,EAAS,GAAKQ,EAAmBK,KAAO1L,EAAU6D,GACnD7D,EAAU+D,EACZD,GACG+G,EAAS,GAAKQ,EAAmBM,IAAM3L,EAAU8D,GAClD9D,EAAU+D,GAElBd,OAAOrB,aAAI,EAAJA,EAAO,KAAMnF,KAAKkB,gBAAgB,GACzCuF,QAAQtB,aAAI,EAAJA,EAAO,KAAMnF,KAAKkB,gBAAgB,IAE5CmN,OACAC,YAGF,OADuB,QAAvBK,GAAA9N,EAAAA,EAAAA,GAAKqK,GAALlL,MAAgBmE,eAAO,IAAAwK,GAAvBA,EAAyBV,SAASc,GAC3BA,CACT,CACA,OAAO,IACT,CAEA,mBACMI,CAAaC,GAKkC,IAAAC,EAAAC,EAAA,IALjC,SAClBlB,EAAQ,UACRmB,EAAS,KACTC,EAAI,UACJC,GACkBL,EAKlB,GAFoB,QADDC,GAAGC,EAAAf,UACnBC,yBAAiB,IAAAa,GAA4B,QAA5BA,EADEA,EAAAZ,KAAAa,EACClB,EAAS,GAAIA,EAAS,WAAG,IAAAiB,OAAA,EAD1BA,EAElBX,SAAS1O,MACM,KAAA0P,EACjB,MAAMd,EAAqB5O,KAAK6O,wBAC1BtL,GAAY1C,EAAAA,EAAAA,GAAKqK,GAALlL,MAAgBmE,QAAS2K,eACrCa,EAA8B,CAClC/K,KAAM,YACN2K,YACArK,GAAI0K,KACJZ,KAAM,CACJ5H,GACGgH,EAAS,GAAKQ,EAAmBK,KAAO1L,EAAU6D,GAAK7D,EAAU+D,EACpED,GAAI+G,EAAS,GAAKQ,EAAmBM,IAAM3L,EAAU8D,GAAK9D,EAAU+D,EACpEd,MAAOqJ,EAAAA,GACPpJ,OAAQqJ,EAAAA,GACRN,OACAC,cAIJ,OADuB,QAAvBC,GAAA7O,EAAAA,EAAAA,GAAKqK,GAALlL,MAAgBmE,eAAO,IAAAuL,GAAvBA,EAAyBP,cAAcQ,GAChCA,CACT,CACA,OAAO,IACT,CAEA,cACMI,CAASC,GACb,GAAqB,IAAjBA,EAAM/M,OACR,MAAO,GAET,MAAMgN,EAAWD,EAAMlJ,KAAcoJ,IAAA,IAAC,KAAE/K,EAAI,SAAEmJ,EAAQ,GAAEpJ,EAAE,KAAEmJ,GAAM6B,EAAA,MAAM,CACtEtL,KAAM,OACNM,KACAmJ,OACAW,KAAM,CACJxI,OAAOrB,aAAI,EAAJA,EAAO,KAAMnF,KAAKkB,gBAAgB,GACzCuF,QAAQtB,aAAI,EAAJA,EAAO,KAAMnF,KAAKkB,gBAAgB,IAE5CoN,WACD,IACD,OAAOzN,EAAAA,EAAAA,GAAKqK,GAALlL,MAAgBmE,QAAS4L,SAASE,EAAU,CACjD/O,gBAAiBlB,KAAKkB,gBACtBoD,YAAatE,KAAKwE,YAClBC,aAAczE,KAAK0E,cAEvB,CAEA,aACMyL,CAAOC,GAA2D,IAAAC,EAAA,IAA1D,OAAE5I,EAAM,OAAE3H,EAAM,KAAEuO,GAAmB+B,EACjD,MAAME,EAAoB,CACxB1L,KAAM,OACN6C,SACA3H,SACAuO,QAGF,OADuB,QAAvBgC,GAAAxP,EAAAA,EAAAA,GAAKqK,GAALlL,MAAgBmE,eAAO,IAAAkM,GAAvBA,EAAyBF,QAAQG,GAC1BA,CACT,CAGAC,oBAAAA,CAAqB9I,GACnB,OAAO5G,EAAAA,EAAAA,GAAKqK,GAALlL,MAAgBmE,QAASoM,qBAAqB9I,EACvD,CAEA,iBACMpD,CACJzD,EACA4P,SAEMC,EAAAA,EAAAA,GAAA3G,GAAA9J,KAAK0Q,IAAiBjC,KAAtBzO,MACN,MAAM,QAAE2Q,IAAY9P,EAAAA,EAAAA,GAAKqK,GAALlL,MAAgBmE,QAASE,YAAYzD,EAAO,IAC3D4P,EACHtP,gBAAiBlB,KAAKkB,gBACtBoD,YAAatE,KAAKwE,YAClBC,aAAczE,KAAK0E,eAErB,MAAO,CAAEiM,UACX,CAiBAC,oBAAAA,GACEC,MAAMD,uBACNtH,GAAetJ,MAAM,EACvB,CAEA4B,MAAAA,GACE,OACEC,IAAAA,cAAC4H,GAAqB,CACpBlF,KAAMvE,KACN0G,KAAK7F,EAAAA,EAAAA,GAAKqK,GAALlL,MACLgB,OAAQhB,KAAKgB,OACbC,cAAejB,KAAKiB,cACpBL,MAAOZ,KAAKY,MACZM,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,SACfqM,aAAc/N,KAAK+N,aACnBC,iBAAkBhO,KAAKgO,iBACvBrM,WAAY3B,KAAK2B,WACjBmM,gBAAiB9N,KAAK8N,gBACtB9L,sBAAsBnB,EAAAA,EAAAA,GAAK1D,GAAL6C,MACtBiC,sBAAsBpB,EAAAA,EAAAA,GAAKzD,GAAL4C,MACtB8Q,YAAYjQ,EAAAA,EAAAA,GAAKoJ,GAALjK,MACZ+Q,aAAalQ,EAAAA,EAAAA,GAAKsJ,GAALnK,MACbgR,cAAcnQ,EAAAA,EAAAA,GAAKwJ,GAALrK,MACdiR,cAAcpQ,EAAAA,EAAAA,GAAK2J,GAALxK,MACdkR,eAAerQ,EAAAA,EAAAA,GAAK6J,GAAL1K,MACfkC,mBAAmBrB,EAAAA,EAAAA,GAAKvD,GAAL0C,MACnBmR,uBAAuBtQ,EAAAA,EAAAA,GAAKgK,GAAL7K,MACvBoR,4BAA4BvQ,EAAAA,EAAAA,GAAKkK,GAAL/K,MAC5BqR,eAAexQ,EAAAA,EAAAA,GAAKoK,GAALjL,OAGrB,EACD,SAAA0Q,KAvDG,OAAO,IAAIY,SAAeC,IACxB,MAAMC,EAAQA,MACR3Q,EAAAA,EAAAA,GAAKqK,GAALlL,MAAgBmE,QAClBoN,IAEAE,WAAWD,EAAO,GACpB,EAEFA,GAAO,GAEX,CAkFF,SAAS9H,GAA2BgI,EAgClChL,GACA,IAhCA,KACEnC,EAAI,OACJvD,EAAM,cACNC,EACAL,MAAOyB,EAAY,gBACnBnB,EAAe,kBACfC,EAAiB,iBACjBG,EAAgB,kBAChBF,EAAiB,kBACjBC,EACAjB,aAAckC,EAAa,mBAC3Bf,EAAkB,SAClBC,EAAQ,WACRC,EAAU,SACVC,EAAQ,aACRqM,EAAY,iBACZC,EACArM,WAAYY,EAAW,gBACvBuL,EAAe,qBACf9L,EAAoB,qBACpBC,EAAoB,WACpB6O,EAAU,aACVE,EAAY,aACZC,EAAY,YACZF,EAAW,cACXG,EAAa,kBACbhP,EAAiB,sBACjBiP,EAAqB,cACrBE,EAAa,2BACbD,IAC2BM,EAG7B,OAAO,MAAE9Q,GAAK,UAAE4B,IAAaC,KAAYC,EAAAA,EAAAA,YACvCC,EAAAA,EACAN,GACCA,IAAY,CACXzB,OAAOgC,EAAAA,EAAAA,GAAgBP,EAAc,CAAEnB,oBACvCsB,UAAW,MAMTK,IAAWC,EAAAA,EAAAA,UACf,IACElC,GAAMmC,OAAOC,EAAAA,GAAYC,SACxB7B,GAAqB8B,EAAAA,KACxB,CAACtC,GAAOQ,IAGJ+B,IAAUC,EAAAA,EAAAA,QAAsB,MAChCC,IAAWD,EAAAA,EAAAA,QAAoB,MAC/BuO,IAA2BvO,EAAAA,EAAAA,QAC/B,OAEKwO,GAAcC,KAAmBvM,EAAAA,EAAAA,UAAmB,KACpDwM,GAAkBC,KAAuBzM,EAAAA,EAAAA,UAAmB,KAC7D,SAAEhC,GAAQ,UAAEC,GAAS,OAAEC,GAAM,WAAE7B,KAAe8B,EAAAA,EAAAA,GAAQ,CAC1DN,WACA3B,WACAC,aACAC,WACAgC,UAA4B,SAAjBqK,EACXiE,cAAoC,SAArBhE,EACfrM,WAAYY,EACZN,0BAGFiC,EAAAA,EAAAA,YAAU,KACRmN,EAAc9N,GAAU+D,EAAE,GACzB,CAAC+J,EAAe9N,GAAU+D,IAE7B,MAAO2K,GAAWC,KAAgB5M,EAAAA,EAAAA,UAA0B,OAErD6M,GAAkBC,KACvB9M,EAAAA,EAAAA,UAAkC,OAE9B,SAAE3B,GAAQ,YAAEC,GAAW,iBAAEC,KAAqBC,EAAAA,EAAAA,GAAU,CAC5D9C,SACAC,gBACAkC,WACAvC,SACAY,WACAgC,UACA7B,cACAa,aACAsL,kBACArL,eAGF4P,EAAAA,EAAAA,qBACE3L,GACA,KAAM,CACJuH,QAAAA,CAASqE,GAEQ,UAAXtR,GAAiC,UAAXA,GACxB4C,IAAY,GAEdnB,GAAS,CAAEmC,KAAM,YAAaC,QAASyN,GACzC,EACAnD,aAAAA,CAAcI,GAEG,UAAXvO,GAAiC,UAAXA,GACxB4C,IAAY,GAEdnB,GAAS,CAAEmC,KAAM,iBAAkBC,QAAS0K,GAC9C,EACAQ,QAAAA,CACEC,EAAKuC,GAEL,IADA,gBAAErR,EAAe,YAAEoD,EAAW,aAAEG,GAA+B8N,EAE/D,MAAMvL,EACJpG,GAAM4R,eACHhN,KAAyB,cAAdA,EAAKZ,MAA2C,SAAnBY,EAAK+J,aAC5C,EACAkD,EAAW,IACZ7R,GAAM8R,MAAM,EAAG1L,MACfgJ,KACApP,GAAM8R,MAAM1L,KAGfpG,MAAO+R,EAAQ,QACfhC,EAAO,eACPiC,IACEvO,EAAAA,EAAAA,GAAY,CACdzD,MAAO6R,EACPzR,SACA2D,cAAe/D,GACfM,kBACAoD,cACAG,eACA9C,cACA4B,aACAuK,oBAMF,OAJI8E,GACFhP,IAAY,GAEdnB,GAAS,CAAEmC,KAAM,eAAgBC,QAAS8N,IACnChC,EAAQ5N,QAAQuP,GACrBtC,EAAMtB,SAAS4D,IAEnB,EACAnC,OAAAA,CAAQ0C,GACNpQ,GAAS,CAAEmC,KAAM,WAAYC,QAASgO,GACxC,EACAxO,WAAAA,CAAYoO,EAAUjC,GACpB,MAAM,eAAEoC,KAAmBxO,IAAWC,EAAAA,EAAAA,GAAY,IAC7CmM,EACHxP,SACA2D,cAAe/D,GACfA,MAAO6R,EACP9Q,cACA4B,aACAuK,oBAMF,OAJI8E,GACFhP,IAAY,GAEdnB,GAAS,CAAEmC,KAAM,eAAgBC,QAAST,EAAOxD,QAC1CwD,CACT,EACA0K,aAAYA,IACHvL,GAETgN,oBAAAA,CAAqBuC,GACnB,MAAMrL,EAAS7G,GAAMmS,MAClBvN,IACGsI,IAAmBkF,EAAAA,EAAAA,IAA0BxN,KAC7CxC,EAAAA,EAAAA,GAAWwC,KACbA,EAAKN,KAAO4N,IAEhB,GAAIrL,EAAQ,CACV,MAAMwL,EAAO9P,GAAQgB,QAAS0K,wBAY9B,OAXAuD,GAAoB,CAClB3K,SACAyL,KAAM,CACJzL,EAAOuH,KAAK5H,EAAIK,EAAOuH,KAAKxI,MAAQ,EACpCiB,EAAOuH,KAAK3H,EAAII,EAAOuH,KAAKvI,OAAS,GAEvC0M,OAAQ,CAACF,EAAKhE,KAAMgE,EAAK/D,OAEX,IAAIoC,SAA4B,CAACC,EAAS6B,KACxDzB,GAAyBxN,QAAU,CAAEoN,UAAS6B,SAAQ,GAG1D,CACA,OAAO9B,QAAQ8B,OAAO,KACxB,KAEF,CAACxS,GAAOI,EAAQW,GAAYiC,GAAaL,GAAWuK,IAGtD,MAAMuF,IAAgBrP,EAAAA,EAAAA,cACpB,CAACsP,EAAyBC,KAAsB,IAAAC,EAG9C,IAAK,IAAIC,EAAI7S,GAAMqC,OAAS,EAAGwQ,GAAK,EAAGA,IAAK,CAC1C,MAAMjO,EAAO5E,GAAM6S,GAEnB,IACI3F,IAAmBkF,EAAAA,EAAAA,IAA0BxN,KAC7CxC,EAAAA,EAAAA,GAAWwC,KACbA,EAAKN,KAAOoO,EAAM7L,OAAOvC,IAGvBM,EAAKwJ,KAAK5H,EAAImM,EAAG,IACjB/N,EAAKwJ,KAAK5H,EAAI5B,EAAKwJ,KAAKxI,MAAQ+M,EAAG,IACnC/N,EAAKwJ,KAAK3H,EAAIkM,EAAG,IACjB/N,EAAKwJ,KAAK3H,EAAI7B,EAAKwJ,KAAKvI,OAAS8M,EAAG,GACpC,KAAAG,EACgC,QAAhCA,EAAA/B,GAAyBxN,eAAO,IAAAuP,GAAhCA,EAAkCnC,QAAQ,CACxC9J,OAAQ6L,EAAM7L,OACd3H,OAAQ0F,IAEV,KACF,CAEJ,CACgC,QAAhCgO,EAAA7B,GAAyBxN,eAAO,IAAAqP,GAAhCA,EAAkCJ,OAAO,MACzChB,GAAoB,KAAK,GAE3B,CAACxR,MAGHsD,EAAAA,EAAAA,YAAU,KACRoF,GAAe/E,KAAS4N,KAAoBF,IAAW,GACtD,CAACE,GAAkB5N,EAAM0N,KAE5B,MAAM7R,IAAe0E,EAAAA,EAAAA,GAAgB,CACnCzB,YACAjD,aAAckC,EACdN,0BAGK2D,GAAgBC,KAAqBN,EAAAA,EAAAA,UAAiB,KAC7DpB,EAAAA,EAAAA,YAAU,KACR,MAAM2B,EAAgBtE,GAClBuE,EAAAA,EAAAA,GACElF,GACAuR,GACA/R,GACA0N,GAEF,GAEJlI,IAAmBF,GACD,IAAhBA,EAAKzC,QAAyC,IAAzB4C,EAAc5C,OAAeyC,EAAOG,GAC1D,GACA,CACDzF,GACAQ,GACAuR,GACA5Q,EACAuM,KAGF5J,EAAAA,EAAAA,YAAU,KACR,MAAMyP,EAAOxQ,GAAQgB,QACrB,IAAKwP,GAAQ/B,GAAa3O,OAAS,EACjC,OAEF,MAAM2Q,EAAa9X,IACjB,MAAM+X,GAASC,EAAAA,EAAAA,GAAehY,EAAO,CACnC8E,SACAR,kBAIK,kBADCyT,aAAM,EAANA,EAAQA,UAEZ3C,EAAc2C,EAAOjT,OACO,IAAxBiT,EAAOjT,MAAMqC,QACfgO,EAAa4C,EAAOjT,MAAM,IAGhC,EAGF,OADA+S,EAAKI,iBAAiB,UAAWH,GAC1B,KACLD,EAAKK,oBAAoB,UAAWJ,EAAU,CAC/C,GACA,CAACxT,GAAcQ,GAAOgR,GAAa3O,OAAQgO,EAAcC,IAE5D,MACMnM,GAAe,IADHjC,EAAAA,EAAAA,UAAQ,IAAM,IAAGkC,EAAAA,EAAAA,UAAS,gBAAgB,iBAGtDiP,IAAoBjQ,EAAAA,EAAAA,cACvBiI,IACCxJ,GAAS,CAAEmC,KAAM,aAAcC,QAASoH,IACxC,MAAMiI,EAAyB,IAC/BC,EAAAA,EAAAA,GAA0BlI,EAAMrL,IAAOwT,SAAS5L,IAAM,IAAA6L,EAAAC,EACjC,QAAnBD,EAAI7L,EAAE+L,qBAAa,IAAAF,GAAfA,EAAiBnP,IAAIgP,EAAaM,KAAoB,QAAhBF,EAAC9L,EAAE+L,qBAAa,IAAAD,OAAA,EAAfA,EAAiBpP,GAAG,IAEjE6M,GAAoBmC,EAAa,GAEnC,CAACtT,KAGG6T,IAAmBzQ,EAAAA,EAAAA,cACtBiI,IACCxJ,GAAS,CAAEmC,KAAM,aAAcC,QAASoH,IACxC8E,EAAY9E,GACQ,IAAhBA,EAAKhJ,QACP6N,EAAW7E,EAAK,KAElBkI,EAAAA,EAAAA,GAA0BlI,EAAMrL,GAAOwQ,IACvCW,GAAoB,GAAG,GAEzB,CAACjB,EAAYC,EAAanQ,GAAOwQ,KAG7BsD,IAAqB1Q,EAAAA,EAAAA,cAAaiI,IACtCxJ,GAAS,CAAEmC,KAAM,cAAeC,QAASoH,GAAO,GAC/C,IAEG0I,IAAoB3Q,EAAAA,EAAAA,cACvBiI,IACCxJ,GAAS,CAAEmC,KAAM,cAAeC,QAASoH,IACzC+E,EAAa/E,EAAK,GAEpB,CAAC+E,IAGG4D,IAA6B5Q,EAAAA,EAAAA,cACjC6Q,IAAuD,IAAtD,GAAE3P,EAAE,QAAE4P,GAA2CD,EAE9ChD,GADEiD,EACeC,GACfA,EAAMrG,SAASxJ,GAAM6P,EAAQ,IAAIA,EAAO7P,GAGzB6P,GAAUA,EAAMhS,QAAQyM,GAASA,IAAStK,IAC7D,GAEF,IAGID,IAAwBjB,EAAAA,EAAAA,cAC5B,CAACkB,EAAYC,KACX,MAAM6P,EAAgBnR,KACtBpB,GAAS,CACPmC,KAAM,mBACNC,QAAS,CAAEK,KAAIC,QACf3C,UAAWwS,GACX,GAEJ,CAACnR,KAGGkC,IAAkB/B,EAAAA,EAAAA,cACrBgC,IAGGxC,GAAOyC,SAAQC,EAAAA,EAAAA,GAAO/C,GAAQgB,SAAW6B,EAAQ,IACnD,GAEF,CAACxC,KAGGO,IAAWC,EAAAA,EAAAA,cAAY,KAC3BJ,IAAY,EAAM,GACjB,CAACA,MACGuC,GAAaC,KAAWC,EAAAA,EAAAA,GAAe,CAC5CzF,SACAU,mBACAyD,kBAGIuB,IAAQC,EAAAA,EAAAA,GAAS,CAAE3F,SAAOI,SAAQ2C,cAmDxC,OAjDAO,EAAAA,EAAAA,YAAU,KACR,MAAMyP,EAAOxQ,GAAQgB,QACrB,IAAKwP,GAAyB,UAAjB5F,EACX,OAEF,MAAMkH,EAAWtB,EAAK9E,wBAChBqG,EAAepZ,KACnBqZ,EAAAA,EAAAA,GAAYrZ,EAAO,CACjByH,aACA4P,OAAQ,CAAC8B,EAAShG,KAAMgG,EAAS/F,KACjCkG,UAAAA,CAAWnC,GACTf,GAAae,EACf,EACAoC,SAAAA,CAAUpC,GACRf,GAAa,MACb,MAAMoD,EAA6C,GACnD,IAAK,MAAM9P,KAAQ5E,GACjB,IACE2U,EAAAA,EAAAA,IAAyB/P,KACzBwN,EAAAA,EAAAA,IAA0BxN,KAC1BgQ,EAAAA,EAAAA,IAAoBhQ,GACpB,CACA,MAAM4B,EAAI5B,EAAKwJ,KAAK5H,EACdC,EAAI7B,EAAKwJ,KAAK3H,EAElBD,GAAK6L,EAAK7L,GACVA,EAAI5B,EAAKwJ,KAAKxI,OAASyM,EAAK7L,EAAI6L,EAAKzM,OACrCa,GAAK4L,EAAK5L,GACVA,EAAI7B,EAAKwJ,KAAKvI,QAAUwM,EAAK5L,EAAI4L,EAAKxM,QAEtC6O,EAAad,KAAKhP,EAEtB,CAEFvD,SAAAA,EACEqT,EAAarS,OAAS,EAClB,CAAE2B,KAAM,QAAS6Q,QAASH,EAAaxO,IAAI4O,EAAAA,IACnB,IAAxBJ,EAAarS,QACXyS,EAAAA,EAAAA,GAAaJ,EAAa,IAC1B,KAEV,GACA,EAGJ,OADA3B,EAAKI,iBAAiB,YAAamB,GAC5B,KACLvB,EAAKK,oBAAoB,YAAakB,EAAY,CACnD,GACA,CAAC3R,GAAW3C,GAAOmN,EAAc9L,IAElCJ,IAAAA,cAAAA,IAAAA,SAAA,KACEA,IAAAA,cAAA,OACE2E,MAAM,OACNC,OAAO,OACPC,IAAKvD,GACLwD,UAAWC,IAAW,OAAQ,CAAEtD,YAAU5B,WAAU4E,WACpDO,UAAW,GAEXhF,IAAAA,cAAA,YACGuE,GAAQU,KAAI,CAACC,EAAQC,IACpBnF,IAAAA,cAACoF,EAAAA,EAAe,CACdC,IAAKF,EACL9B,GAAI,GAAGH,KAAeiC,IACtBpC,KAAK,QACLuC,YAAaJ,EAAOI,iBAI1BtF,IAAAA,cAAA,KACE0B,UAAW,aAAaA,GAAU6D,KAAK7D,GAAU8D,YAAY9D,GAAU+D,MAEvEzF,IAAAA,cAAA,KACE8E,UAAWC,IAAW,QAAS,CAAEkH,oBACjCpH,IAAKrD,IAEJzC,GAAMkG,KAAKtB,GACV3D,IAAAA,cAAC0F,EAAAA,EAAa,CACZL,IAAK,GAAG1B,EAAKZ,SAAQ4C,EAAAA,EAAAA,IAAWhC,GAAQ,GAAGA,EAAKiC,UAAUjC,EAAK1F,SAAW0F,EAAKN,KAC/EyQ,4BACEnO,EAAAA,EAAAA,IAAWhC,IAAgBsM,GAAiBpD,SAASlJ,EAAKN,IAE5DlE,OAAQA,EACRwE,KAAMA,EACN5E,MAAOA,GACPiC,SAAUA,GACVxB,kBAAmBA,EACnBF,kBAAmBA,EACnBoC,UAAWA,GACX4C,YAAaA,GACb/F,aAAcA,GACduF,eAAgBA,GAChBiQ,cAAe3B,GACf4B,aAAcpB,GACdqB,eAAgBpB,GAChBqB,cAAepB,GACf1S,qBAAsBA,EACtBC,kBAAmBA,EACnBiP,sBAAuBA,EACvB6E,uBAAwBpB,GACxBjN,kBAAmB1C,QAIzBpD,IAAAA,cAACoU,EAAAA,EAAoB,CACnB9D,iBAAkBA,GAClB5O,UAAWA,GACX2S,UAAW,GAAGnR,MACdoR,UAAW9C,KAEZpB,IACCpQ,IAAAA,cAAA,QACEuF,EAAG6K,GAAU7K,EACbC,EAAG4K,GAAU5K,EACbb,MAAOyL,GAAUzL,MACjBC,OAAQwL,GAAUxL,OAClB2P,KAAK,wBACLC,YAAa,GACbC,OAAO,wBACPC,gBAAiB,MAKzB1U,IAAAA,cAACkG,EAAAA,EAAgB,CACfhG,WAAYwC,EAAKxC,WACjBiG,MAAOzE,GAAU+D,EACjB3F,WAAYA,GACZsG,aAAclC,GACdmC,WAAYnE,KAIpB,CAEO,SAAS6L,KACd,MAAO,uCAAuC4G,QAAQ,SAAS,SAAUhO,GACvE,MAAMiO,EAAqB,GAAhBC,KAAKC,SAAiB,EAEjC,OADW,KAALnO,EAAWiO,EAAS,EAAJA,EAAW,GACxBG,SAAS,GACpB,GACF,CApiBCC,EAAA1L,KA7CE/C,GAAArK,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAE,EAAAC,EAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAA4L,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAlM,GAAAC,GAAAC,GAAAK,GAAAoI,GAAAxI,GAAAgM,GAAAM,GAAA2K,GAAAhL,GAAAC,GAAAG,GAAA6K,GAAA/K,GAAAI,GAAAE,GAAA0K,GAAA3K,GAAAE,GAAAE,GAAAwK,GAAAzK,GAAAE,GAAAK,GAAAmK,GAAAvK,GAAAC,GAAAE,GAAAqK,GAAAtK,GAAAG,GAAAE,GAAAkK,GAAAnK,GAAA5M,GAAAG,GAAA8H,GAAAhI,GAAA6M,GAAAE,GAAAgK,GAAAjK,GAAAE,GAAAE,GAAA8J,GAAA/J,GAAAE,GAAAE,GAAA4J,GAAA7J,GAAAtC,GAAA5C,GAAAmB,GAAAlB,KAAAC,EAAAA,EAAAA,GAAAmO,EAAA,CArVFjb,GAAc,iBAAkB,CAC/B+M,WAAY,CAACC,EAAAA,EAAWC,EAAAA,MACxB,EAKChN,GAAS,CAAEiN,WAAW,IAAQ,YAG9BjN,GAAS,CAAE+I,KAAMmE,SAAS,aAG1BlN,GAAS,CAAEiN,WAAW,IAAQ,oBAG9BjN,GAAS,CAAEiN,WAAW,IAAQ,sBAG9BjN,GAAS,CAAEiN,WAAW,IAAQ,wBAQ9BjN,GAAS,CAAE+I,KAAMoE,SAAS,wBAW1BnN,GAAS,CAAEiN,WAAW,IAAQ,wBAY9BjN,GAAS,CAAEiN,WAAW,IAAQ,uBAG9BjN,GAAS,CAAEiN,WAAW,IAAQ,mBAM9BjN,GAAS,CAAE+I,KAAMqE,UAAU,yBAG3BpN,GAAS,CAAE+I,KAAMqE,UAAU,eAG3BpN,GAAS,CAAE+I,KAAMqE,UAAU,iBAG3BpN,GAAS,CAAE+I,KAAMqE,UAAU,eAG3BpN,GAAS,CAAE+I,KAAMqE,UAAU,iBAG3BpN,GAAS,CAAE+I,KAAMqE,UAAU,sBAW3BpN,KAAU,mBAUVA,KAAU,uBAGVA,GAAS,CAAEiN,WAAW,IAAQ,iBAG9BhN,GAAM,CAAE8I,KAAM,wBAAwB,4BAAAsE,IAAArI,EAAAA,EAAAA,GAAAgJ,GAAAX,GAAA,CAAAA,EAAApI,KAAAC,EAAAA,EAAAA,GAAA8I,GAAAX,EAAApI,IAAA,CAgBtChF,GAAM,CAAE8I,KAAM,cAAc,kBAAAsE,IAAArI,EAAAA,EAAAA,GAAAkJ,GAAAb,GAAA,CAAAA,EAAApI,KAAAC,EAAAA,EAAAA,GAAAgJ,GAAAb,EAAApI,IAAA,CAG5BhF,GAAM,CAAE8I,KAAM,cAAc,kBAAAsE,IAAArI,EAAAA,EAAAA,GAAAmJ,GAAAd,GAAA,CAAAA,EAAApI,KAAAC,EAAAA,EAAAA,GAAAiJ,GAAAd,EAAApI,IAAA,CAU5BhF,GAAM,CAAE8I,KAAM,eAAe,mBAAAsE,IAAArI,EAAAA,EAAAA,GAAAqJ,GAAAhB,GAAA,CAAAA,EAAApI,KAAAC,EAAAA,EAAAA,GAAAmJ,GAAAhB,EAAApI,IAAA,CAO7BhF,GAAM,CAAE8I,KAAM,gBAAgB,oBAAAsE,IAAArI,EAAAA,EAAAA,GAAAuJ,GAAAlB,GAAA,CAAAA,EAAApI,KAAAC,EAAAA,EAAAA,GAAAqJ,GAAAlB,EAAApI,IAAA,CAU9BhF,GAAM,CAAE8I,KAAM,gBAAgB,eAAAsE,IAAArI,EAAAA,EAAAA,GAAAyJ,GAAApB,GAAA,CAAAA,EAAApI,KAAAC,EAAAA,EAAAA,GAAAuJ,GAAApB,EAAApI,IAAA,CAG9BhF,GAAM,CAAE8I,KAAM,gBAAgB,eAAAsE,IAAArI,EAAAA,EAAAA,GAAA0J,GAAArB,GAAA,CAAAA,EAAApI,KAAAC,EAAAA,EAAAA,GAAAwJ,GAAArB,EAAApI,IAAA,CAU9BhF,GAAM,CAAE8I,KAAM,iBAAiB,gBAAAsE,IAAArI,EAAAA,EAAAA,GAAA4J,GAAAvB,GAAA,CAAAA,EAAApI,KAAAC,EAAAA,EAAAA,GAAA0J,GAAAvB,EAAApI,IAAA,CAO/BhF,GAAM,CAAE8I,KAAM,qBAAqB,oBAAAsE,IAAArI,EAAAA,EAAAA,GAAA8J,GAAAzB,GAAA,CAAAA,EAAApI,KAAAC,EAAAA,EAAAA,GAAA4J,GAAAzB,EAAApI,IAAA,CAOnChF,GAAM,CAAE8I,KAAM,0BAA0B,wBAAAsE,IAAArI,EAAAA,EAAAA,GAAA+J,GAAA1B,GAAA,CAAAA,EAAApI,KAAAC,EAAAA,EAAAA,GAAA6J,GAAA1B,EAAApI,IAAA,CAUxChF,GAAM,CAAE8I,KAAM,0BAA0B,6BAAAsE,IAAArI,EAAAA,EAAAA,GAAAiK,GAAA5B,GAAA,CAAAA,EAAApI,KAAAC,EAAAA,EAAAA,GAAA+J,GAAA5B,EAAApI,IAAA,CAUxChF,GAAM,CAAE8I,KAAM,iBAAiB,gBAAAsE,IAAArI,EAAAA,EAAAA,GAAAmK,GAAA9B,GAAA,CAAAA,EAAApI,KAAAC,EAAAA,EAAAA,GAAAiK,GAAA9B,EAAApI,IAAA,CAO/B0I,KAAQ,eAyCRA,KAAQ,oBAkCRA,KAAQ,eAsBRA,KAAQ,cAYRA,KAAQ,2BAKRA,KAAQ,qBAAAL,GAAA+B,GAAA9B,KAAAC,EAAAA,EAAAA,GAAAF,KAxTgBzL,EAAAA,mBAAgB+K,G","sources":["webpack:///./src/display-canvas/index.tsx","webpack:///./src/draw-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\";\n\nconst { defineElement, property, event } = createDecorators();\n\nexport interface EoDisplayCanvasProps {\n cells: InitialCell[] | undefined;\n layout: LayoutType;\n layoutOptions?: LayoutOptions;\n defaultNodeSize: SizeTuple;\n defaultNodeBricks?: NodeBrickConf[];\n defaultEdgeLines?: EdgeLineConf[];\n degradedThreshold?: number;\n degradedNodeLabel?: string;\n activeTarget?: ActiveTarget | null;\n fadeUnrelatedCells?: boolean;\n zoomable?: boolean;\n scrollable?: boolean;\n pannable?: boolean;\n scaleRange?: RangeTuple;\n}\n\n/**\n * 用于展示查看的画布。\n */\nexport\n@defineElement(\"eo-display-canvas\", {\n styleTexts: [styleText, zoomBarStyleText],\n})\nclass EoDisplayCanvas extends ReactNextElement implements EoDisplayCanvasProps {\n /**\n * 用于查看的画布可以更新 `cells` 属性。\n */\n @property({ attribute: false })\n accessor cells: InitialCell[] | undefined;\n\n @property({ type: String })\n accessor layout: LayoutType;\n\n @property({ attribute: false })\n accessor layoutOptions: LayoutOptions | undefined;\n\n @property({ attribute: false })\n accessor defaultNodeSize: SizeTuple = [DEFAULT_NODE_SIZE, DEFAULT_NODE_SIZE];\n\n @property({ attribute: false })\n accessor defaultNodeBricks: NodeBrickConf[] | undefined;\n\n /**\n * 当节点数量达到或超过 `degradedThreshold` 时,节点将被降级展示。\n *\n * @default 500\n */\n @property({ type: Number })\n accessor degradedThreshold: number | undefined;\n\n // Set `attribute` to `false` event if it accepts string value.\n // Because when passing like \"<% DATA.node.data.name %>\", it will be\n // evaluated as object temporarily.\n /**\n * 设置节点将降级展示时显示的名称。\n *\n * @default \"<% DATA.node.id %>\"\n */\n @property({ attribute: false })\n accessor degradedNodeLabel: string | undefined;\n\n /**\n * 使用条件判断设置默认的边对应的连线。在 `if` 表达式中 `DATA` 为 `{ edge }`,例如:\n *\n * ```yaml\n * defaultEdgeLines:\n * - if: <% DATA.edge.data?.virtual %>\n * dashed: true\n * ```\n */\n @property({ attribute: false })\n accessor defaultEdgeLines: EdgeLineConf[] | undefined;\n\n @property({ attribute: false })\n accessor activeTarget: ActiveTarget | null | undefined;\n\n /**\n * 当鼠标悬浮到某节点上时,隐藏其他跟该节点无关的元素。\n */\n @property({ type: Boolean })\n accessor fadeUnrelatedCells: boolean | undefined;\n\n @property({ type: Boolean })\n accessor zoomable: boolean | undefined = true;\n\n @property({ type: Boolean })\n accessor scrollable: boolean | undefined = true;\n\n @property({ type: Boolean })\n accessor pannable: boolean | undefined = true;\n\n @property({ attribute: false })\n accessor scaleRange: RangeTuple | undefined;\n\n @event({ type: \"activeTarget.change\" })\n accessor #activeTargetChangeEvent!: EventEmitter<ActiveTarget | null>;\n\n #handleActiveTargetChange = (target: ActiveTarget | null) => {\n this.#activeTargetChangeEvent.emit(target);\n };\n\n #handleSwitchActiveTarget = (target: ActiveTarget | null) => {\n if (!sameTarget(target, this.activeTarget)) {\n this.activeTarget = target;\n }\n };\n\n @event({ type: \"cell.contextmenu\" })\n accessor #cellContextMenu!: EventEmitter<CellContextMenuDetail>;\n\n #handleCellContextMenu = (detail: CellContextMenuDetail) => {\n this.#cellContextMenu.emit(detail);\n };\n\n @event({ type: \"cell.click\" })\n accessor #cellClick!: EventEmitter<CellContextMenuDetail>;\n\n #handleCellClick = (detail: CellContextMenuDetail) => {\n this.#cellClick.emit(detail);\n };\n\n render() {\n return (\n <EoDisplayCanvasComponent\n shadowRoot={this.shadowRoot!}\n cells={this.cells}\n layout={this.layout}\n layoutOptions={this.layoutOptions}\n defaultNodeSize={this.defaultNodeSize}\n defaultNodeBricks={this.defaultNodeBricks}\n defaultEdgeLines={this.defaultEdgeLines}\n degradedThreshold={this.degradedThreshold}\n degradedNodeLabel={this.degradedNodeLabel}\n activeTarget={this.activeTarget}\n fadeUnrelatedCells={this.fadeUnrelatedCells}\n zoomable={this.zoomable}\n scrollable={this.scrollable}\n pannable={this.pannable}\n scaleRange={this.scaleRange}\n onActiveTargetChange={this.#handleActiveTargetChange}\n onSwitchActiveTarget={this.#handleSwitchActiveTarget}\n onCellContextMenu={this.#handleCellContextMenu}\n onCellClick={this.#handleCellClick}\n />\n );\n }\n}\n\nexport interface EoDisplayCanvasComponentProps extends EoDisplayCanvasProps {\n shadowRoot: ShadowRoot;\n onActiveTargetChange(target: ActiveTarget | null): void;\n onSwitchActiveTarget(target: ActiveTarget | null): void;\n onCellContextMenu(detail: CellContextMenuDetail): void;\n onCellClick(detail: CellContextMenuDetail): void;\n}\n\nfunction EoDisplayCanvasComponent({\n shadowRoot,\n cells: initialCells,\n layout,\n layoutOptions,\n defaultNodeSize,\n defaultNodeBricks,\n defaultEdgeLines,\n degradedThreshold,\n degradedNodeLabel,\n activeTarget: _activeTarget,\n fadeUnrelatedCells,\n zoomable,\n scrollable,\n pannable,\n scaleRange: _scaleRange,\n onActiveTargetChange,\n onSwitchActiveTarget,\n onCellContextMenu,\n onCellClick,\n}: EoDisplayCanvasComponentProps) {\n const [{ cells, layoutKey }, dispatch] = useReducer(\n rootReducer,\n initialCells,\n (initialCells) => ({\n cells: initializeCells(initialCells, { defaultNodeSize }),\n layoutKey: 1,\n })\n );\n\n // When nodes are greater or equal to threshold, the diagram will be degraded.\n // Thus all nodes will be displayed as simple svg elements instead of bricks.\n const degraded = useMemo(\n () =>\n cells.filter(isNodeCell).length >=\n (degradedThreshold ?? DEFAULT_DEGRADED_THRESHOLD),\n [cells, degradedThreshold]\n );\n\n const rootRef = useRef<SVGSVGElement>(null);\n const cellsRef = useRef<SVGGElement>(null);\n\n const { grabbing, transform, zoomer, scaleRange } = useZoom({\n rootRef,\n zoomable,\n scrollable,\n pannable,\n 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 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 cellsRef,\n activeTarget: _activeTarget,\n onActiveTargetChange,\n });\n\n const defPrefix = useMemo(() => `${uniqueId(\"diagram-\")}-`, []);\n const markerPrefix = `${defPrefix}line-arrow-`;\n\n const handleNodeBrickResize = useCallback(\n (id: string, size: SizeTuple | null) => {\n dispatch({\n type: \"update-node-size\",\n payload: { id, size },\n layoutKey: getNextLayoutKey(),\n });\n },\n [getNextLayoutKey]\n );\n\n const [hoverCell, setHoverCell] = useState<Cell | null>(null);\n const handleCellMouseEnter = useCallback((cell: Cell) => {\n setHoverCell(cell);\n }, []);\n const handleCellMouseLeave = useCallback((cell: Cell) => {\n setHoverCell((prev) => (prev === cell ? null : prev));\n }, []);\n\n const [unrelatedCells, setUnrelatedCells] = useState<Cell[]>([]);\n useEffect(() => {\n const nextUnrelated = fadeUnrelatedCells\n ? getUnrelatedCells(cells, null, hoverCell)\n : [];\n // Do not update the state when prev and next are both empty.\n setUnrelatedCells((prev) =>\n prev.length === 0 && nextUnrelated.length === 0 ? prev : nextUnrelated\n );\n }, [cells, fadeUnrelatedCells, hoverCell]);\n\n const handleZoomSlide = useCallback(\n (value: number) => {\n // istanbul ignore next\n if (process.env.NODE_ENV !== \"test\") {\n zoomer.scaleTo(select(rootRef.current!), value / 100);\n }\n },\n [zoomer]\n );\n\n const [lineConfMap, markers] = useLineMarkers({\n cells,\n defaultEdgeLines,\n markerPrefix,\n });\n\n const ready = useReady({ cells, layout, centered });\n\n return (\n <>\n <svg\n width=\"100%\"\n height=\"100%\"\n ref={rootRef}\n className={classNames(\"root\", { grabbing, pannable, ready })}\n tabIndex={-1}\n >\n <defs>\n {markers.map((marker, index) => (\n <MarkerComponent\n key={index}\n id={`${markerPrefix}${index}`}\n type=\"arrow\"\n strokeColor={marker.strokeColor}\n />\n ))}\n </defs>\n <g\n transform={`translate(${transform.x} ${transform.y}) scale(${transform.k})`}\n >\n <g className=\"cells\" ref={cellsRef}>\n {cells.map((cell) => (\n <CellComponent\n key={`${cell.type}:${isEdgeCell(cell) ? `${cell.source}~${cell.target}` : cell.id}`}\n layout={layout}\n cell={cell}\n cells={cells}\n degraded={degraded}\n degradedNodeLabel={degradedNodeLabel}\n defaultNodeBricks={defaultNodeBricks}\n lineConfMap={lineConfMap}\n transform={transform}\n activeTarget={activeTarget}\n readOnly\n unrelatedCells={unrelatedCells}\n onSwitchActiveTarget={onSwitchActiveTarget}\n onCellContextMenu={onCellContextMenu}\n onCellClick={onCellClick}\n onNodeBrickResize={handleNodeBrickResize}\n onCellMouseEnter={\n fadeUnrelatedCells && isNodeCell(cell)\n ? handleCellMouseEnter\n : undefined\n }\n onCellMouseLeave={\n fadeUnrelatedCells && isNodeCell(cell)\n ? handleCellMouseLeave\n : undefined\n }\n />\n ))}\n </g>\n </g>\n </svg>\n <ZoomBarComponent\n shadowRoot={shadowRoot}\n scale={transform.k}\n scaleRange={scaleRange}\n onZoomChange={handleZoomSlide}\n onReCenter={reCenter}\n />\n </>\n );\n}\n","import React, {\n createRef,\n useCallback,\n useEffect,\n useImperativeHandle,\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 type { UseSingleBrickConf } from \"@next-core/react-runtime\";\nimport { unwrapProvider } from \"@next-core/utils/general\";\nimport \"@next-core/theme\";\nimport { uniqueId } from \"lodash\";\nimport classNames from \"classnames\";\nimport { select } from \"d3-selection\";\nimport type { lockBodyScroll as _lockBodyScroll } from \"@next-bricks/basic/data-providers/lock-body-scroll/lock-body-scroll\";\nimport type {\n PositionTuple,\n RangeTuple,\n SizeTuple,\n TransformLiteral,\n} from \"../diagram/interfaces\";\nimport type {\n ActiveTarget,\n Cell,\n EdgeCell,\n InitialCell,\n NodeBrickConf,\n NodeCell,\n NodeId,\n DecoratorCell,\n DecoratorType,\n CellContextMenuDetail,\n ConnectLineState,\n Deferred,\n ConnectNodesDetail,\n EdgeLineConf,\n DecoratorTextChangeDetail,\n NodeView,\n LayoutType,\n LayoutOptions,\n Direction,\n} from \"./interfaces\";\nimport { rootReducer } from \"./reducers\";\nimport { MarkerComponent } from \"../diagram/MarkerComponent\";\nimport {\n isContainerDecoratorCell,\n isEdgeCell,\n isNodeCell,\n isNodeOrAreaDecoratorCell,\n isTextDecoratorCell,\n} from \"./processors/asserts\";\nimport type { MoveCellPayload, ResizeCellPayload } from \"./reducers/interfaces\";\nimport { sameTarget } from \"./processors/sameTarget\";\nimport { handleKeyboard } from \"./processors/handleKeyboard\";\nimport { CellComponent } from \"./CellComponent\";\nimport { ConnectLineComponent } from \"./ConnectLineComponent\";\nimport { initializeCells } from \"./processors/initializeCells\";\nimport { updateCells } from \"./processors/updateCells\";\nimport { getUnrelatedCells } from \"./processors/getUnrelatedCells\";\nimport {\n DEFAULT_NODE_SIZE,\n DEFAULT_AREA_WIDTH,\n DEFAULT_AREA_HEIGHT,\n DEFAULT_DEGRADED_THRESHOLD,\n} from \"./constants\";\nimport { useZoom } from \"../shared/canvas/useZoom\";\nimport { useActiveTarget } from \"../shared/canvas/useActiveTarget\";\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 { handleLasso } from \"./processors/handleLasso\";\nimport styleText from \"../shared/canvas/styles.shadow.css\";\nimport zoomBarStyleText from \"../shared/canvas/ZoomBarComponent.shadow.css\";\nimport { cellToTarget } from \"./processors/cellToTarget\";\nimport { handleNodeContainedChange } from \"./processors/handleNodeContainedChange\";\n\nconst lockBodyScroll = unwrapProvider<typeof _lockBodyScroll>(\n \"basic.lock-body-scroll\"\n);\n\nconst { defineElement, property, method, event } = createDecorators();\n\nexport interface EoDrawCanvasProps {\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 dragBehavior?: DragBehavior;\n ctrlDragBehavior?: CtrlDragBehavior;\n scaleRange?: RangeTuple;\n allowEdgeToArea?: boolean;\n}\n\nexport type DragBehavior = \"none\" | \"lasso\" | \"grab\";\nexport type CtrlDragBehavior = \"none\" | \"grab\";\n\nexport interface DropNodeInfo extends AddNodeInfo {\n /** [PointerEvent::clientX, PointerEvent::clientY] */\n position: PositionTuple;\n}\n\nexport interface DropDecoratorInfo {\n decorator: DecoratorType;\n /** [PointerEvent::clientX, PointerEvent::clientY] */\n position: PositionTuple;\n text?: string;\n direction?: Direction;\n}\n\nexport interface AddNodeInfo {\n id: NodeId;\n useBrick?: UseSingleBrickConf;\n data?: unknown;\n size?: SizeTuple;\n}\n\nexport interface AddEdgeInfo {\n source: NodeId;\n target: NodeId;\n data?: unknown;\n}\n\nexport interface UpdateCellsContext {\n reason: \"add-related-nodes\";\n parent: NodeId;\n}\n\nexport interface AddNodesContext {\n defaultNodeSize: SizeTuple;\n canvasWidth: number;\n canvasHeight: number;\n}\n\nexport const EoDrawCanvasComponent = React.forwardRef(\n LegacyEoDrawCanvasComponent\n);\n\n/**\n * 用于手工绘图的画布。\n *\n * 注意:将配套另外一个用于展示的画布构件。\n */\nexport\n@defineElement(\"eo-draw-canvas\", {\n styleTexts: [styleText, zoomBarStyleText],\n})\nclass EoDrawCanvas extends ReactNextElement implements EoDrawCanvasProps {\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 * 当 `activeTarget` 不为 `null` 时,隐藏其他跟该 `activeTarget` 无关的元素。\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({ type: Boolean })\n accessor selectable: boolean | undefined = true;\n\n @property({ type: Boolean })\n accessor allowEdgeToArea: boolean | undefined = false;\n\n /**\n * 按住鼠标拖动时的行为:\n * - `none`:无\n * - `lasso`:绘制选区\n * - `grab`:拖动画布\n *\n * @default \"none\"\n */\n @property()\n accessor dragBehavior: DragBehavior | undefined;\n\n /**\n * 按住 ctrl 键并按住鼠标拖动时的行为:\n * - `none`:无\n * - `grab`:拖动画布\n *\n * @default \"none\"\n */\n @property()\n accessor ctrlDragBehavior: CtrlDragBehavior | undefined;\n\n @property({ attribute: false })\n accessor scaleRange: RangeTuple | undefined;\n\n @event({ type: \"activeTarget.change\" })\n accessor #activeTargetChangeEvent!: EventEmitter<ActiveTarget | null>;\n\n #handleActiveTargetChange = (target: ActiveTarget | null) => {\n this.#activeTargetChangeEvent.emit(target);\n };\n\n #handleSwitchActiveTarget = (target: ActiveTarget | null) => {\n if (!sameTarget(target, this.activeTarget)) {\n this.activeTarget = target;\n }\n };\n\n /**\n * @deprecated Use `cell.move` instead.\n */\n @event({ type: \"node.move\" })\n accessor #nodeMoveEvent!: EventEmitter<MoveCellPayload>;\n\n @event({ type: \"cell.move\" })\n accessor #cellMoveEvent!: EventEmitter<MoveCellPayload>;\n\n #handleCellMove = (info: MoveCellPayload) => {\n this.#cellMoveEvent.emit(info);\n if (info.type === \"node\") {\n this.#nodeMoveEvent.emit(info);\n }\n };\n\n @event({ type: \"cells.move\" })\n accessor #cellsMoveEvent!: EventEmitter<MoveCellPayload[]>;\n\n #handleCellsMove = (info: MoveCellPayload[]) => {\n this.#cellsMoveEvent.emit(info);\n };\n\n @event({ type: \"cell.resize\" })\n accessor #cellResizeEvent!: EventEmitter<ResizeCellPayload>;\n\n #handleCellResize = (info: ResizeCellPayload) => {\n this.#cellResizeEvent.emit(info);\n };\n\n /**\n * @deprecated Use `cell.delete` instead.\n */\n @event({ type: \"node.delete\" })\n accessor #nodeDelete!: EventEmitter<Cell>;\n\n @event({ type: \"cell.delete\" })\n accessor #cellDelete!: EventEmitter<Cell>;\n\n #handleCellDelete = (cell: Cell) => {\n this.#cellDelete.emit(cell);\n if (cell.type === \"node\") {\n this.#nodeDelete.emit(cell);\n }\n };\n\n @event({ type: \"cells.delete\" })\n accessor #cellsDelete!: EventEmitter<Cell[]>;\n\n #handleCellsDelete = (cells: Cell[]) => {\n this.#cellsDelete.emit(cells);\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: \"decorator.text.change\" })\n accessor #decoratorTextChange!: EventEmitter<DecoratorTextChangeDetail>;\n\n #handleDecoratorTextChange = (detail: DecoratorTextChangeDetail) => {\n this.#decoratorTextChange.emit(detail);\n };\n\n /**\n * node节点跟容器组关系改变事件,有containerCell是新增关系,否则删除关系\n */\n @event({ type: \"node.container.change\" })\n accessor #containerContainerChange!: EventEmitter<MoveCellPayload[]>;\n\n #handleContainerContainerChange = (detail: MoveCellPayload[]) => {\n this.#containerContainerChange.emit(detail);\n };\n\n /**\n * 缩放变化后,从素材库拖拽元素进画布时,拖拽图像应设置对应的缩放比例。\n */\n @event({ type: \"scale.change\" })\n accessor #scaleChange!: EventEmitter<number>;\n\n #handleScaleChange = (scale: number) => {\n this.#scaleChange.emit(scale);\n };\n\n @method()\n async dropNode({\n id,\n position,\n size,\n data,\n useBrick,\n }: DropNodeInfo): Promise<NodeCell | null> {\n // Drag and then drop a node\n const droppedInside = document\n .elementsFromPoint?.(position[0], position[1])\n ?.includes(this);\n if (droppedInside) {\n const boundingClientRect = this.getBoundingClientRect();\n const transform = this.#canvasRef.current!.getTransform();\n const newNode = {\n type: \"node\",\n id,\n view: {\n ...(this.layout === \"force\" || this.layout === \"dagre\"\n ? null\n : {\n x:\n (position[0] - boundingClientRect.left - transform.x) /\n transform.k,\n y:\n (position[1] - boundingClientRect.top - transform.y) /\n transform.k,\n }),\n width: size?.[0] ?? this.defaultNodeSize[0],\n height: size?.[1] ?? this.defaultNodeSize[0],\n },\n data,\n useBrick,\n } as NodeCell;\n this.#canvasRef.current?.dropNode(newNode);\n return newNode;\n }\n return null;\n }\n\n @method()\n async dropDecorator({\n position,\n decorator,\n text,\n direction,\n }: DropDecoratorInfo): Promise<DecoratorCell | null> {\n // Drag and then drop a node\n const droppedInside = document\n .elementsFromPoint?.(position[0], position[1])\n ?.includes(this);\n if (droppedInside) {\n const boundingClientRect = this.getBoundingClientRect();\n const transform = this.#canvasRef.current!.getTransform();\n const newDecorator: DecoratorCell = {\n type: \"decorator\",\n decorator,\n id: uuidV4(),\n view: {\n x:\n (position[0] - boundingClientRect.left - transform.x) / transform.k,\n y: (position[1] - boundingClientRect.top - transform.y) / transform.k,\n width: DEFAULT_AREA_WIDTH,\n height: DEFAULT_AREA_HEIGHT,\n text,\n direction,\n },\n };\n this.#canvasRef.current?.dropDecorator(newDecorator);\n return newDecorator;\n }\n return null;\n }\n\n @method()\n async addNodes(nodes: AddNodeInfo[]): Promise<NodeCell[]> {\n if (nodes.length === 0) {\n return [];\n }\n const newNodes = nodes.map<NodeCell>(({ size, useBrick, id, data }) => ({\n type: \"node\",\n id,\n data,\n view: {\n width: size?.[0] ?? this.defaultNodeSize[0],\n height: size?.[1] ?? this.defaultNodeSize[0],\n } as NodeView,\n useBrick,\n }));\n return this.#canvasRef.current!.addNodes(newNodes, {\n defaultNodeSize: this.defaultNodeSize,\n canvasWidth: this.clientWidth,\n canvasHeight: this.clientHeight,\n });\n }\n\n @method()\n async addEdge({ source, target, data }: AddEdgeInfo): Promise<EdgeCell> {\n const newEdge: EdgeCell = {\n type: \"edge\",\n source,\n target,\n data,\n };\n this.#canvasRef.current?.addEdge(newEdge);\n return newEdge;\n }\n\n @method()\n manuallyConnectNodes(source: NodeId): Promise<ConnectNodesDetail> {\n return this.#canvasRef.current!.manuallyConnectNodes(source);\n }\n\n @method()\n async updateCells(\n cells: InitialCell[],\n ctx?: UpdateCellsContext\n ): Promise<{ updated: Cell[] }> {\n await this.#waitForCanvasRef();\n const { updated } = this.#canvasRef.current!.updateCells(cells, {\n ...ctx,\n defaultNodeSize: this.defaultNodeSize,\n canvasWidth: this.clientWidth,\n canvasHeight: this.clientHeight,\n });\n return { updated };\n }\n\n #waitForCanvasRef() {\n return new Promise<void>((resolve) => {\n const check = () => {\n if (this.#canvasRef.current) {\n resolve();\n } else {\n setTimeout(check, 10);\n }\n };\n check();\n });\n }\n\n #canvasRef = createRef<DrawCanvasRef>();\n\n disconnectedCallback(): void {\n super.disconnectedCallback();\n lockBodyScroll(this, false);\n }\n\n render() {\n return (\n <EoDrawCanvasComponent\n host={this}\n ref={this.#canvasRef}\n layout={this.layout}\n layoutOptions={this.layoutOptions}\n cells={this.cells}\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 dragBehavior={this.dragBehavior}\n ctrlDragBehavior={this.ctrlDragBehavior}\n scaleRange={this.scaleRange}\n allowEdgeToArea={this.allowEdgeToArea}\n onActiveTargetChange={this.#handleActiveTargetChange}\n onSwitchActiveTarget={this.#handleSwitchActiveTarget}\n onCellMove={this.#handleCellMove}\n onCellsMove={this.#handleCellsMove}\n onCellResize={this.#handleCellResize}\n onCellDelete={this.#handleCellDelete}\n onCellsDelete={this.#handleCellsDelete}\n onCellContextMenu={this.#handleCellContextMenu}\n onDecoratorTextChange={this.#handleDecoratorTextChange}\n onContainerContainerChange={this.#handleContainerContainerChange}\n onScaleChange={this.#handleScaleChange}\n />\n );\n }\n}\n\nexport interface EoDrawCanvasComponentProps extends EoDrawCanvasProps {\n host: HTMLElement;\n onActiveTargetChange(target: ActiveTarget | null): void;\n onSwitchActiveTarget(target: ActiveTarget | null): void;\n onCellMove(info: MoveCellPayload): void;\n onCellResize(cell: ResizeCellPayload): void;\n onCellDelete(cell: Cell): void;\n onCellsMove(info: MoveCellPayload[]): void;\n onCellsDelete(cells: Cell[]): void;\n onCellContextMenu(detail: CellContextMenuDetail): void;\n onDecoratorTextChange(detail: DecoratorTextChangeDetail): void;\n onContainerContainerChange(detail: MoveCellPayload[]): void;\n onScaleChange(scale: number): void;\n}\n\nexport interface DrawCanvasRef {\n dropNode(node: NodeCell): void;\n dropDecorator(decorator: DecoratorCell): void;\n addNodes(nodes: NodeCell[], ctx: AddNodesContext): NodeCell[];\n addEdge(edge: EdgeCell): void;\n manuallyConnectNodes(source: NodeId): Promise<ConnectNodesDetail>;\n updateCells(\n cells: InitialCell[],\n ctx: Partial<UpdateCellsContext> & {\n defaultNodeSize: SizeTuple;\n canvasWidth: number;\n canvasHeight: number;\n }\n ): {\n cells: Cell[];\n updated: Cell[];\n };\n getTransform(): TransformLiteral;\n}\n\nfunction LegacyEoDrawCanvasComponent(\n {\n host,\n layout,\n layoutOptions,\n cells: initialCells,\n defaultNodeSize,\n defaultNodeBricks,\n defaultEdgeLines,\n degradedThreshold,\n degradedNodeLabel,\n activeTarget: _activeTarget,\n fadeUnrelatedCells,\n zoomable,\n scrollable,\n pannable,\n dragBehavior,\n ctrlDragBehavior,\n scaleRange: _scaleRange,\n allowEdgeToArea,\n onActiveTargetChange,\n onSwitchActiveTarget,\n onCellMove,\n onCellResize,\n onCellDelete,\n onCellsMove,\n onCellsDelete,\n onCellContextMenu,\n onDecoratorTextChange,\n onScaleChange,\n onContainerContainerChange,\n }: EoDrawCanvasComponentProps,\n ref: React.Ref<DrawCanvasRef>\n) {\n const [{ cells, layoutKey }, dispatch] = useReducer(\n rootReducer,\n initialCells,\n (initialCells) => ({\n cells: initializeCells(initialCells, { defaultNodeSize }),\n layoutKey: 0,\n })\n );\n\n // When nodes are greater or equal to threshold, the diagram will be degraded.\n // Thus all nodes will be displayed as simple svg elements instead of bricks.\n const degraded = useMemo(\n () =>\n cells.filter(isNodeCell).length >=\n (degradedThreshold ?? DEFAULT_DEGRADED_THRESHOLD),\n [cells, degradedThreshold]\n );\n\n const rootRef = useRef<SVGSVGElement>(null);\n const cellsRef = useRef<SVGGElement>(null);\n const manualConnectDeferredRef = useRef<Deferred<ConnectNodesDetail> | null>(\n null\n );\n const [editingTexts, setEditingTexts] = useState<string[]>([]);\n const [activeContainers, setActiveContainers] = useState<string[]>([]);\n const { grabbing, transform, zoomer, scaleRange } = useZoom({\n rootRef,\n zoomable,\n scrollable,\n pannable,\n draggable: dragBehavior === \"grab\",\n ctrlDraggable: ctrlDragBehavior === \"grab\",\n scaleRange: _scaleRange,\n onSwitchActiveTarget,\n });\n\n useEffect(() => {\n onScaleChange(transform.k);\n }, [onScaleChange, transform.k]);\n\n const [lassoRect, setLassoRect] = useState<NodeView | null>(null);\n\n const [connectLineState, setConnectLineState] =\n useState<ConnectLineState | null>(null);\n\n const { centered, setCentered, getNextLayoutKey } = useLayout({\n layout,\n layoutOptions,\n rootRef,\n cells,\n zoomable,\n zoomer,\n scaleRange,\n layoutKey,\n allowEdgeToArea,\n dispatch,\n });\n\n useImperativeHandle(\n ref,\n () => ({\n dropNode(node) {\n // Do not apply auto centering when dropping a node in manual layout.\n if (layout !== \"dagre\" && layout !== \"force\") {\n setCentered(true);\n }\n dispatch({ type: \"drop-node\", payload: node });\n },\n dropDecorator(decorator) {\n // Do not apply auto centering when dropping a decorator in manual layout.\n if (layout !== \"dagre\" && layout !== \"force\") {\n setCentered(true);\n }\n dispatch({ type: \"drop-decorator\", payload: decorator });\n },\n addNodes(\n nodes,\n { defaultNodeSize, canvasWidth, canvasHeight }: AddNodesContext\n ) {\n const index =\n cells.findLastIndex(\n (cell) => !(cell.type === \"decorator\" && cell.decorator === \"text\")\n ) + 1;\n const newCells = [\n ...cells.slice(0, index),\n ...nodes,\n ...cells.slice(index),\n ];\n const {\n cells: allCells,\n updated,\n shouldReCenter,\n } = updateCells({\n cells: newCells,\n layout,\n previousCells: cells,\n defaultNodeSize,\n canvasWidth,\n canvasHeight,\n scaleRange,\n transform,\n allowEdgeToArea,\n });\n if (shouldReCenter) {\n setCentered(false);\n }\n dispatch({ type: \"update-cells\", payload: allCells });\n return updated.filter((node) =>\n nodes.includes(node as NodeCell)\n ) as NodeCell[];\n },\n addEdge(edge) {\n dispatch({ type: \"add-edge\", payload: edge });\n },\n updateCells(newCells, ctx) {\n const { shouldReCenter, ...result } = updateCells({\n ...ctx,\n layout,\n previousCells: cells,\n cells: newCells,\n scaleRange,\n transform,\n allowEdgeToArea,\n });\n if (shouldReCenter) {\n setCentered(false);\n }\n dispatch({ type: \"update-cells\", payload: result.cells });\n return result;\n },\n getTransform() {\n return transform;\n },\n manuallyConnectNodes(sourceId) {\n const source = cells.find(\n (cell) =>\n ((allowEdgeToArea && isNodeOrAreaDecoratorCell(cell)) ||\n isNodeCell(cell)) &&\n cell.id === sourceId\n ) as NodeCell | DecoratorCell | undefined;\n if (source) {\n const rect = rootRef.current!.getBoundingClientRect();\n setConnectLineState({\n source,\n from: [\n source.view.x + source.view.width / 2,\n source.view.y + source.view.height / 2,\n ],\n offset: [rect.left, rect.top],\n });\n const promise = new Promise<ConnectNodesDetail>((resolve, reject) => {\n manualConnectDeferredRef.current = { resolve, reject };\n });\n return promise;\n }\n return Promise.reject(null);\n },\n }),\n [cells, layout, scaleRange, setCentered, transform, allowEdgeToArea]\n );\n\n const handleConnect = useCallback(\n (state: ConnectLineState, to: PositionTuple) => {\n // Find the target node from top bo bottom,\n // detect whether the pointer is inside the target node.\n for (let i = cells.length - 1; i >= 0; i--) {\n const cell = cells[i];\n // Currently ignore connecting to self\n if (\n ((allowEdgeToArea && isNodeOrAreaDecoratorCell(cell)) ||\n isNodeCell(cell)) &&\n cell.id !== state.source.id\n ) {\n if (\n cell.view.x < to[0] &&\n cell.view.x + cell.view.width > to[0] &&\n cell.view.y < to[1] &&\n cell.view.y + cell.view.height > to[1]\n ) {\n manualConnectDeferredRef.current?.resolve({\n source: state.source,\n target: cell,\n });\n break;\n }\n }\n }\n manualConnectDeferredRef.current?.reject(null);\n setConnectLineState(null);\n },\n [cells]\n );\n\n useEffect(() => {\n lockBodyScroll(host, !!(connectLineState || lassoRect));\n }, [connectLineState, host, lassoRect]);\n\n const activeTarget = useActiveTarget({\n cellsRef,\n activeTarget: _activeTarget,\n onActiveTargetChange,\n });\n\n const [unrelatedCells, setUnrelatedCells] = useState<Cell[]>([]);\n useEffect(() => {\n const nextUnrelated = fadeUnrelatedCells\n ? getUnrelatedCells(\n cells,\n connectLineState,\n activeTarget,\n allowEdgeToArea\n )\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 }, [\n activeTarget,\n cells,\n connectLineState,\n fadeUnrelatedCells,\n allowEdgeToArea,\n ]);\n\n useEffect(() => {\n const root = rootRef.current;\n if (!root || editingTexts.length > 0) {\n return;\n }\n const onKeydown = (event: KeyboardEvent) => {\n const action = handleKeyboard(event, {\n cells,\n activeTarget,\n });\n\n switch (action?.action) {\n case \"delete-cells\":\n onCellsDelete(action.cells);\n if (action.cells.length === 1) {\n onCellDelete(action.cells[0]);\n }\n break;\n }\n };\n root.addEventListener(\"keydown\", onKeydown);\n return () => {\n root.removeEventListener(\"keydown\", onKeydown);\n };\n }, [activeTarget, cells, editingTexts.length, onCellDelete, onCellsDelete]);\n\n const defPrefix = useMemo(() => `${uniqueId(\"diagram-\")}-`, []);\n const markerPrefix = `${defPrefix}line-arrow-`;\n /* istanbul ignore next */\n const handleCellsMoving = useCallback(\n (info: MoveCellPayload[]) => {\n dispatch({ type: \"move-cells\", payload: info });\n const containedIds: string[] = [];\n handleNodeContainedChange(info, cells).forEach((c) => {\n if (c.containerCell?.id) containedIds.push(c.containerCell?.id);\n });\n setActiveContainers(containedIds);\n },\n [cells]\n );\n /* istanbul ignore next */\n const handleCellsMoved = useCallback(\n (info: MoveCellPayload[]) => {\n dispatch({ type: \"move-cells\", payload: info });\n onCellsMove(info);\n if (info.length === 1) {\n onCellMove(info[0]);\n }\n handleNodeContainedChange(info, cells, onContainerContainerChange);\n setActiveContainers([]);\n },\n [onCellMove, onCellsMove, cells, onContainerContainerChange]\n );\n\n const handleCellResizing = useCallback((info: ResizeCellPayload) => {\n dispatch({ type: \"resize-cell\", payload: info });\n }, []);\n\n const handleCellResized = useCallback(\n (info: ResizeCellPayload) => {\n dispatch({ type: \"resize-cell\", payload: info });\n onCellResize(info);\n },\n [onCellResize]\n );\n\n const handleDecoratorTextEditing = useCallback(\n ({ id, editing }: { id: string; editing: boolean }) => {\n if (editing) {\n setEditingTexts((texts) =>\n texts.includes(id) ? texts : [...texts, id]\n );\n } else {\n setEditingTexts((texts) => texts.filter((text) => text !== id));\n }\n },\n []\n );\n\n const handleNodeBrickResize = useCallback(\n (id: string, size: SizeTuple | null) => {\n const nextLayoutKey = getNextLayoutKey();\n dispatch({\n type: \"update-node-size\",\n payload: { id, size },\n layoutKey: nextLayoutKey,\n });\n },\n [getNextLayoutKey]\n );\n\n const handleZoomSlide = useCallback(\n (value: number) => {\n // istanbul ignore next\n if (process.env.NODE_ENV !== \"test\") {\n zoomer.scaleTo(select(rootRef.current!), value / 100);\n }\n },\n [zoomer]\n );\n\n const reCenter = useCallback(() => {\n setCentered(false);\n }, [setCentered]);\n const [lineConfMap, markers] = useLineMarkers({\n cells,\n defaultEdgeLines,\n markerPrefix,\n });\n\n const ready = useReady({ cells, layout, centered });\n\n useEffect(() => {\n const root = rootRef.current;\n if (!root || dragBehavior !== \"lasso\") {\n return;\n }\n const rootRect = root.getBoundingClientRect();\n const onMouseDown = (event: MouseEvent) => {\n handleLasso(event, {\n transform,\n offset: [rootRect.left, rootRect.top],\n onLassoing(rect) {\n setLassoRect(rect);\n },\n onLassoed(rect) {\n setLassoRect(null);\n const lassoedCells: (NodeCell | DecoratorCell)[] = [];\n for (const cell of cells) {\n if (\n isContainerDecoratorCell(cell) ||\n isNodeOrAreaDecoratorCell(cell) ||\n isTextDecoratorCell(cell)\n ) {\n const x = cell.view.x;\n const y = cell.view.y;\n if (\n x >= rect.x &&\n x + cell.view.width <= rect.x + rect.width &&\n y >= rect.y &&\n y + cell.view.height <= rect.y + rect.height\n ) {\n lassoedCells.push(cell);\n }\n }\n }\n onSwitchActiveTarget?.(\n lassoedCells.length > 1\n ? { type: \"multi\", targets: lassoedCells.map(cellToTarget) }\n : lassoedCells.length === 1\n ? cellToTarget(lassoedCells[0])\n : null\n );\n },\n });\n };\n root.addEventListener(\"mousedown\", onMouseDown);\n return () => {\n root.removeEventListener(\"mousedown\", onMouseDown);\n };\n }, [transform, cells, dragBehavior, onSwitchActiveTarget]);\n return (\n <>\n <svg\n width=\"100%\"\n height=\"100%\"\n ref={rootRef}\n className={classNames(\"root\", { grabbing, pannable, ready })}\n tabIndex={-1}\n >\n <defs>\n {markers.map((marker, index) => (\n <MarkerComponent\n key={index}\n id={`${markerPrefix}${index}`}\n type=\"arrow\"\n strokeColor={marker.strokeColor}\n />\n ))}\n </defs>\n <g\n transform={`translate(${transform.x} ${transform.y}) scale(${transform.k})`}\n >\n <g\n className={classNames(\"cells\", { allowEdgeToArea })}\n ref={cellsRef}\n >\n {cells.map((cell) => (\n <CellComponent\n key={`${cell.type}:${isEdgeCell(cell) ? `${cell.source}~${cell.target}` : cell.id}`}\n dragNodeToContainerActive={\n isEdgeCell(cell) ? false : activeContainers.includes(cell.id)\n }\n layout={layout}\n cell={cell}\n cells={cells}\n degraded={degraded}\n degradedNodeLabel={degradedNodeLabel}\n defaultNodeBricks={defaultNodeBricks}\n transform={transform}\n lineConfMap={lineConfMap}\n activeTarget={activeTarget}\n unrelatedCells={unrelatedCells}\n onCellsMoving={handleCellsMoving}\n onCellsMoved={handleCellsMoved}\n onCellResizing={handleCellResizing}\n onCellResized={handleCellResized}\n onSwitchActiveTarget={onSwitchActiveTarget}\n onCellContextMenu={onCellContextMenu}\n onDecoratorTextChange={onDecoratorTextChange}\n onDecoratorTextEditing={handleDecoratorTextEditing}\n onNodeBrickResize={handleNodeBrickResize}\n />\n ))}\n </g>\n <ConnectLineComponent\n connectLineState={connectLineState}\n transform={transform}\n markerEnd={`${markerPrefix}0`}\n onConnect={handleConnect}\n />\n {lassoRect && (\n <rect\n x={lassoRect.x}\n y={lassoRect.y}\n width={lassoRect.width}\n height={lassoRect.height}\n fill=\"var(--palette-gray-5)\"\n fillOpacity={0.3}\n stroke=\"var(--palette-gray-5)\"\n strokeDasharray={2}\n />\n )}\n </g>\n </svg>\n <ZoomBarComponent\n shadowRoot={host.shadowRoot!}\n scale={transform.k}\n scaleRange={scaleRange}\n onZoomChange={handleZoomSlide}\n onReCenter={reCenter}\n />\n </>\n );\n}\n\nexport function uuidV4() {\n return \"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx\".replace(/[xy]/g, function (c) {\n const r = (Math.random() * 16) | 0,\n v = c == \"x\" ? r : (r & 0x3) | 0x8;\n return v.toString(16);\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","_EoDisplayCanvas_brand","WeakSet","_handleActiveTargetChange","_handleSwitchActiveTarget","_P","_handleCellContextMenu","_Q","_handleCellClick","EoDisplayCanvas","ReactNextElement","constructor","arguments","_classPrivateMethodInitSpec","_classPrivateFieldInitSpec","_init_cells","_init_extra_cells","_init_layout","_init_extra_layout","_init_layoutOptions","_init_extra_layoutOptions","_init_defaultNodeSize","DEFAULT_NODE_SIZE","_init_extra_defaultNodeSize","_init_defaultNodeBricks","_init_extra_defaultNodeBricks","_init_degradedThreshold","_init_extra_degradedThreshold","_init_degradedNodeLabel","_init_extra_degradedNodeLabel","_init_defaultEdgeLines","_init_extra_defaultEdgeLines","_init_activeTarget","_init_extra_activeTarget","_init_fadeUnrelatedCells","_init_extra_fadeUnrelatedCells","_init_zoomable","_init_extra_zoomable","_init_scrollable","_init_extra_scrollable","_init_pannable","_init_extra_pannable","_init_scaleRange","_init_extra_scaleRange","_init_activeTargetChangeEvent","_init_extra_activeTargetChangeEvent","target","_classPrivateGetter","this","_get_activeTargetChangeEvent","emit","sameTarget","activeTarget","_init_cellContextMenu","_init_extra_cellContextMenu","detail","_get_cellContextMenu","_init_cellClick","_init_extra_cellClick","_get_cellClick","cells","_classPrivateFieldGet","v","_classPrivateFieldSet","layout","layoutOptions","defaultNodeSize","defaultNodeBricks","degradedThreshold","degradedNodeLabel","defaultEdgeLines","fadeUnrelatedCells","zoomable","scrollable","pannable","scaleRange","render","React","EoDisplayCanvasComponent","shadowRoot","onActiveTargetChange","onSwitchActiveTarget","onCellContextMenu","onCellClick","_ref","initialCells","_activeTarget","_scaleRange","layoutKey","dispatch","useReducer","rootReducer","initializeCells","degraded","useMemo","filter","isNodeCell","length","DEFAULT_DEGRADED_THRESHOLD","rootRef","useRef","cellsRef","grabbing","transform","zoomer","useZoom","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","ready","useReady","width","height","ref","className","classNames","tabIndex","map","marker","index","MarkerComponent","key","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","lockBodyScroll","unwrapProvider","method","EoDrawCanvasComponent","LegacyEoDrawCanvasComponent","_EoDrawCanvas","_R","_S","_EoDrawCanvas_brand","_T","_U","_handleCellMove","_V","_handleCellsMove","_W","_handleCellResize","_X","_Y","_handleCellDelete","_Z","_handleCellsDelete","_a","_b","_handleDecoratorTextChange","_c","_handleContainerContainerChange","_d","_handleScaleChange","_canvasRef","EoDrawCanvas","_initProto","_init_selectable","_init_extra_selectable","_init_allowEdgeToArea","_init_extra_allowEdgeToArea","_init_dragBehavior","_init_extra_dragBehavior","_init_ctrlDragBehavior","_init_extra_ctrlDragBehavior","_init_nodeMoveEvent","_init_extra_nodeMoveEvent","_init_cellMoveEvent","_init_extra_cellMoveEvent","info","_get_cellMoveEvent","_get_nodeMoveEvent","_init_cellsMoveEvent","_init_extra_cellsMoveEvent","_get_cellsMoveEvent","_init_cellResizeEvent","_init_extra_cellResizeEvent","_get_cellResizeEvent","_init_nodeDelete","_init_extra_nodeDelete","_init_cellDelete","_init_extra_cellDelete","_get_cellDelete","_get_nodeDelete","_init_cellsDelete","_init_extra_cellsDelete","_get_cellsDelete","_init_decoratorTextChange","_init_extra_decoratorTextChange","_get_decoratorTextChange","_init_containerContainerChange","_init_extra_containerContainerChange","_get_containerContainerChange","_init_scaleChange","_init_extra_scaleChange","_get_scaleChange","createRef","selectable","allowEdgeToArea","dragBehavior","ctrlDragBehavior","dropNode","_document$elementsFro","_document","position","data","useBrick","document","elementsFromPoint","call","includes","_classPrivateFieldGet2","boundingClientRect","getBoundingClientRect","getTransform","newNode","view","left","top","dropDecorator","_ref2","_document$elementsFro2","_document2","decorator","text","direction","_classPrivateFieldGet3","newDecorator","uuidV4","DEFAULT_AREA_WIDTH","DEFAULT_AREA_HEIGHT","addNodes","nodes","newNodes","_ref3","addEdge","_ref4","_classPrivateFieldGet4","newEdge","manuallyConnectNodes","ctx","_assertClassBrand","_waitForCanvasRef","updated","disconnectedCallback","super","onCellMove","onCellsMove","onCellResize","onCellDelete","onCellsDelete","onDecoratorTextChange","onContainerContainerChange","onScaleChange","Promise","resolve","check","setTimeout","_ref5","manualConnectDeferredRef","editingTexts","setEditingTexts","activeContainers","setActiveContainers","ctrlDraggable","lassoRect","setLassoRect","connectLineState","setConnectLineState","useImperativeHandle","node","_ref6","findLastIndex","newCells","slice","allCells","shouldReCenter","edge","sourceId","find","isNodeOrAreaDecoratorCell","rect","from","offset","reject","handleConnect","state","to","_manualConnectDeferre2","i","_manualConnectDeferre","root","onKeydown","action","handleKeyboard","addEventListener","removeEventListener","handleCellsMoving","containedIds","handleNodeContainedChange","forEach","_c$containerCell","_c$containerCell2","containerCell","push","handleCellsMoved","handleCellResizing","handleCellResized","handleDecoratorTextEditing","_ref7","editing","texts","nextLayoutKey","rootRect","onMouseDown","handleLasso","onLassoing","onLassoed","lassoedCells","isContainerDecoratorCell","isTextDecoratorCell","targets","cellToTarget","dragNodeToContainerActive","onCellsMoving","onCellsMoved","onCellResizing","onCellResized","onDecoratorTextEditing","ConnectLineComponent","markerEnd","onConnect","fill","fillOpacity","stroke","strokeDasharray","replace","r","Math","random","toString","_EoDrawCanvas2","_set_nodeMoveEvent","_set_cellMoveEvent","_set_cellsMoveEvent","_set_cellResizeEvent","_set_nodeDelete","_set_cellDelete","_set_cellsDelete","_set_decoratorTextChange","_set_containerContainerChange","_set_scaleChange"],"sourceRoot":""}
|