@next-bricks/diagram 0.55.0 → 0.56.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/bricks.json +3 -3
- package/dist/chunks/5903.ee85cf0c.js +2 -0
- package/dist/chunks/5903.ee85cf0c.js.map +1 -0
- package/dist/chunks/9711.a67e7f03.js +2 -0
- package/dist/chunks/9711.a67e7f03.js.map +1 -0
- package/dist/chunks/{eo-display-canvas.c4f21ed5.js → eo-display-canvas.28d0385d.js} +2 -2
- package/dist/chunks/{eo-display-canvas.c4f21ed5.js.map → eo-display-canvas.28d0385d.js.map} +1 -1
- package/dist/chunks/eo-draw-canvas.4b11d12e.js +2 -0
- package/dist/chunks/eo-draw-canvas.4b11d12e.js.map +1 -0
- package/dist/chunks/{main.3da92bd7.js → main.3238fda4.js} +2 -2
- package/dist/chunks/{main.3da92bd7.js.map → main.3238fda4.js.map} +1 -1
- package/dist/examples.json +4 -4
- package/dist/{index.415b685f.js → index.9e7c2eca.js} +2 -2
- package/dist/{index.415b685f.js.map → index.9e7c2eca.js.map} +1 -1
- package/dist/manifest.json +130 -124
- package/dist/types.json +4521 -4273
- package/dist-types/draw-canvas/CellComponent.d.ts +6 -6
- package/dist-types/draw-canvas/EdgeComponent.d.ts +3 -3
- package/dist-types/draw-canvas/EditingLineComponent.d.ts +4 -4
- package/dist-types/draw-canvas/HoverStateContext.d.ts +7 -3
- package/dist-types/draw-canvas/LineConnectorComponent.d.ts +4 -4
- package/dist-types/draw-canvas/LineEditorComponent.d.ts +5 -5
- package/dist-types/draw-canvas/constants.d.ts +1 -0
- package/dist-types/draw-canvas/decorators/DecoratorLine.d.ts +3 -0
- package/dist-types/draw-canvas/decorators/DecoratorLine.spec.d.ts +1 -0
- package/dist-types/draw-canvas/decorators/DecoratorRect.d.ts +3 -0
- package/dist-types/draw-canvas/decorators/DecoratorRect.spec.d.ts +1 -0
- package/dist-types/draw-canvas/decorators/index.d.ts +1 -1
- package/dist-types/draw-canvas/index.d.ts +17 -4
- package/dist-types/draw-canvas/interfaces.d.ts +32 -7
- package/dist-types/draw-canvas/processors/asserts.d.ts +4 -1
- package/dist-types/draw-canvas/processors/handleMouseDown.d.ts +3 -3
- package/dist-types/draw-canvas/reducers/interfaces.d.ts +14 -3
- package/dist-types/shared/canvas/processors/getEditingLinePoints.d.ts +3 -3
- package/dist-types/shared/canvas/processors/getSmartLinePoints.d.ts +4 -2
- package/dist-types/shared/canvas/useEditableLineMap.d.ts +3 -3
- package/dist-types/shared/canvas/useLineMarkers.d.ts +2 -2
- package/docs/eo-draw-canvas.md +70 -31
- package/package.json +2 -2
- package/dist/chunks/8552.b1182b74.js +0 -2
- package/dist/chunks/8552.b1182b74.js.map +0 -1
- package/dist/chunks/9711.6546e794.js +0 -2
- package/dist/chunks/9711.6546e794.js.map +0 -1
- package/dist/chunks/eo-draw-canvas.8d6f455b.js +0 -2
- package/dist/chunks/eo-draw-canvas.8d6f455b.js.map +0 -1
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
"use strict";(globalThis.webpackChunk_next_bricks_diagram=globalThis.webpackChunk_next_bricks_diagram||[]).push([[8939],{9068:(e,t,a)=>{a.r(t),a.d(t,{EoDrawCanvas:()=>qt,EoDrawCanvasComponent:()=>Yt,uuidV4:()=>qa});var i,l=a(4635),n=a(918),s=a(6902),o=a(2559),r=a(5536),d=a(6121),c=a(829),h=a(2740),u=a(8769),g=a.n(u),A=a(1123),p=a(9006),v=a(2729),y=(a(6477),a(1030)),C=a(3373),w=a.n(C),f=a(7566),m=a(5748),k=a(3739),b=a(531),E=a(8185),M=a(2733),x=a(6787),T=a(3639),N=a(3783),W=a(2098),S=a(227),R=a(3033),z=a(8091),L=a(1819),B=a(7099),D=a(1484),O=a(8197),$=a(7531),P=a(8875),H=a(2722),F=a(9978),_=a(2219),K=a(3012),U=a(6237),j=a(1103),V=a(9386),I=a(1991),X=a(2202),Y=a(1825),q=a(5915),G=a(4197);let J,Q,Z,ee,te,ae,ie,le,ne,se,oe,re,de,ce,he,ue,ge,Ae,pe,ve,ye,Ce,we,fe,me,ke,be,Ee,Me,xe,Te,Ne,We,Se,Re,ze,Le,Be,De,Oe,$e,Pe,He,Fe,_e,Ke,Ue,je,Ve,Ie,Xe,Ye,qe,Ge,Je,Qe,Ze,et,tt,at,it,lt,nt,st,ot,rt,dt,ct,ht,ut,gt,At,pt,vt,yt,Ct,wt,ft,mt,kt,bt,Et,Mt,xt,Tt,Nt,Wt,St,Rt,zt,Lt,Bt,Dt,Ot,$t,Pt,Ht,Ft,_t,Kt;const Ut=(0,v.unwrapProvider)("basic.lock-body-scroll"),{defineElement:jt,property:Vt,method:It,event:Xt}=(0,A.createDecorators)(),Yt=g().forwardRef(Ya);let qt;var Gt=new WeakMap,Jt=new WeakMap,Qt=new WeakMap,Zt=new WeakMap,ea=new WeakMap,ta=new WeakMap,aa=new WeakMap,ia=new WeakMap,la=new WeakMap,na=new WeakMap,sa=new WeakMap,oa=new WeakMap,ra=new WeakMap,da=new WeakMap,ca=new WeakMap,ha=new WeakMap,ua=new WeakMap,ga=new WeakMap,Aa=new WeakMap,pa=new WeakMap,va=new WeakMap,ya=new WeakMap,Ca=new WeakSet,wa=new WeakMap,fa=new WeakMap,ma=new WeakMap,ka=new WeakMap,ba=new WeakMap,Ea=new WeakMap,Ma=new WeakMap,xa=new WeakMap,Ta=new WeakMap,Na=new WeakMap,Wa=new WeakMap,Sa=new WeakMap,Ra=new WeakMap,za=new WeakMap,La=new WeakMap,Ba=new WeakMap,Da=new WeakMap,Oa=new WeakMap,$a=new WeakMap,Pa=new WeakMap,Ha=new WeakMap,Fa=new WeakMap,_a=new WeakMap,Ka=new WeakMap,Ua=new WeakMap,ja=new WeakMap,Va=new WeakMap;class Ia extends p.ReactNextElement{constructor(){super(...arguments),(0,l.A)(this,Ca),(0,n.A)(this,Gt,(J(this),Z(this))),(0,n.A)(this,Jt,(ee(this),te(this))),(0,n.A)(this,Qt,(ae(this),ie(this))),(0,n.A)(this,Zt,(le(this),ne(this,[R.HP,R.HP]))),(0,n.A)(this,ea,(se(this),oe(this))),(0,n.A)(this,ta,(re(this),de(this))),(0,n.A)(this,aa,(ce(this),he(this))),(0,n.A)(this,ia,(ue(this),ge(this))),(0,n.A)(this,la,(Ae(this),pe(this))),(0,n.A)(this,na,(ve(this),ye(this))),(0,n.A)(this,sa,(Ce(this),we(this,!0))),(0,n.A)(this,oa,(fe(this),me(this,!0))),(0,n.A)(this,ra,(ke(this),be(this,!0))),(0,n.A)(this,da,(Ee(this),Me(this,!1))),(0,n.A)(this,ca,(xe(this),Te(this))),(0,n.A)(this,ha,(Ne(this),We(this))),(0,n.A)(this,ua,(Se(this),Re(this))),(0,n.A)(this,ga,(ze(this),Le(this))),(0,n.A)(this,Aa,(Be(this),De(this))),(0,n.A)(this,pa,(Oe(this),$e(this))),(0,n.A)(this,va,(Pe(this),He(this))),(0,n.A)(this,ya,(Fe(this),_e(this))),(0,n.A)(this,wa,(je(this),e=>{(0,r.A)(Ca,this,Ke).emit(e)})),(0,n.A)(this,fa,(e=>{(0,E.c)(e,this.activeTarget)||(this.activeTarget=e)})),(0,n.A)(this,ma,Ve(this)),(0,n.A)(this,ka,(Ye(this),qe(this))),(0,n.A)(this,ba,(Qe(this),e=>{(0,r.A)(Ca,this,Ge).emit(e),"node"===e.type&&(0,r.A)(Ca,this,Ie).emit(e)})),(0,n.A)(this,Ea,Ze(this)),(0,n.A)(this,Ma,(at(this),e=>{(0,r.A)(Ca,this,et).emit(e)})),(0,n.A)(this,xa,it(this)),(0,n.A)(this,Ta,(st(this),e=>{(0,r.A)(Ca,this,lt).emit(e)})),(0,n.A)(this,Na,ot(this)),(0,n.A)(this,Wa,(ct(this),ht(this))),(0,n.A)(this,Sa,(At(this),e=>{(0,r.A)(Ca,this,ut).emit(e),"node"===e.type&&(0,r.A)(Ca,this,rt).emit(e)})),(0,n.A)(this,Ra,pt(this)),(0,n.A)(this,za,(Ct(this),e=>{(0,r.A)(Ca,this,vt).emit(e)})),(0,n.A)(this,La,wt(this)),(0,n.A)(this,Ba,(kt(this),e=>{(0,r.A)(Ca,this,ft).emit(e)})),(0,n.A)(this,Da,bt(this)),(0,n.A)(this,Oa,(xt(this),e=>{(0,r.A)(Ca,this,Et).emit(e)})),(0,n.A)(this,$a,Tt(this)),(0,n.A)(this,Pa,(St(this),e=>{(0,r.A)(Ca,this,Nt).emit(e)})),(0,n.A)(this,Ha,Rt(this)),(0,n.A)(this,Fa,(Bt(this),e=>{(0,r.A)(Ca,this,zt).emit(e)})),(0,n.A)(this,_a,Dt(this)),(0,n.A)(this,Ka,(Pt(this),e=>{(0,r.A)(Ca,this,Ot).emit(e)})),(0,n.A)(this,Ua,Ht(this)),(0,n.A)(this,ja,(Kt(this),e=>{(0,r.A)(Ca,this,Ft).emit(e)})),(0,n.A)(this,Va,(0,u.createRef)())}get cells(){return(0,c.A)(Gt,this)}set cells(e){(0,d.A)(Gt,this,e)}get layout(){return(0,c.A)(Jt,this)}set layout(e){(0,d.A)(Jt,this,e)}get layoutOptions(){return(0,c.A)(Qt,this)}set layoutOptions(e){(0,d.A)(Qt,this,e)}get defaultNodeSize(){return(0,c.A)(Zt,this)}set defaultNodeSize(e){(0,d.A)(Zt,this,e)}get defaultNodeBricks(){return(0,c.A)(ea,this)}set defaultNodeBricks(e){(0,d.A)(ea,this,e)}get degradedThreshold(){return(0,c.A)(ta,this)}set degradedThreshold(e){(0,d.A)(ta,this,e)}get degradedNodeLabel(){return(0,c.A)(aa,this)}set degradedNodeLabel(e){(0,d.A)(aa,this,e)}get defaultEdgeLines(){return(0,c.A)(ia,this)}set defaultEdgeLines(e){(0,d.A)(ia,this,e)}get activeTarget(){return(0,c.A)(la,this)}set activeTarget(e){(0,d.A)(la,this,e)}get fadeUnrelatedCells(){return(0,c.A)(na,this)}set fadeUnrelatedCells(e){(0,d.A)(na,this,e)}get zoomable(){return(0,c.A)(sa,this)}set zoomable(e){(0,d.A)(sa,this,e)}get scrollable(){return(0,c.A)(oa,this)}set scrollable(e){(0,d.A)(oa,this,e)}get pannable(){return(0,c.A)(ra,this)}set pannable(e){(0,d.A)(ra,this,e)}get allowEdgeToArea(){return(0,c.A)(da,this)}set allowEdgeToArea(e){(0,d.A)(da,this,e)}get dragBehavior(){return(0,c.A)(ca,this)}set dragBehavior(e){(0,d.A)(ca,this,e)}get ctrlDragBehavior(){return(0,c.A)(ha,this)}set ctrlDragBehavior(e){(0,d.A)(ha,this,e)}get scaleRange(){return(0,c.A)(ua,this)}set scaleRange(e){(0,d.A)(ua,this,e)}get lineSettings(){return(0,c.A)(ga,this)}set lineSettings(e){(0,d.A)(ga,this,e)}get lineConnector(){return(0,c.A)(Aa,this)}set lineConnector(e){(0,d.A)(Aa,this,e)}get doNotResetActiveTargetForSelector(){return(0,c.A)(pa,this)}set doNotResetActiveTargetForSelector(e){(0,d.A)(pa,this,e)}get doNotResetActiveTargetOutsideCanvas(){return(0,c.A)(va,this)}set doNotResetActiveTargetOutsideCanvas(e){(0,d.A)(va,this,e)}async dropNode(e){var t,a;let{id:i,position:l,size:n,data:s,useBrick:o}=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 r,d,h;const e=this.getBoundingClientRect(),t=(0,c.A)(Va,this).current.getTransform(),a={type:"node",id:i,view:{..."force"===this.layout||"dagre"===this.layout?null:{x:(l[0]-e.left-t.x)/t.k,y:(l[1]-e.top-t.y)/t.k},width:null!==(r=null==n?void 0:n[0])&&void 0!==r?r:this.defaultNodeSize[0],height:null!==(d=null==n?void 0:n[1])&&void 0!==d?d:this.defaultNodeSize[0]},data:s,useBrick:o};return null===(h=(0,c.A)(Va,this).current)||void 0===h||h.dropNode(a),a}return null}async dropDecorator(e){var t,a;let{position:i,decorator:l,text:n,direction:s}=e;if(null===(t=(a=document).elementsFromPoint)||void 0===t||null===(t=t.call(a,i[0],i[1]))||void 0===t?void 0:t.includes(this)){var o;const e=this.getBoundingClientRect(),t=(0,c.A)(Va,this).current.getTransform(),a={type:"decorator",decorator:l,id:qa(),view:{x:(i[0]-e.left-t.x)/t.k,y:(i[1]-e.top-t.y)/t.k,width:R.N8,height:R.w1,text:n,direction:s}};return null===(o=(0,c.A)(Va,this).current)||void 0===o||o.dropDecorator(a),a}return null}async addNodes(e){if(0===e.length)return[];const t=e.map((e=>{var t,a;let{size:i,useBrick:l,id:n,data:s}=e;return{type:"node",id:n,data:s,view:{width:null!==(t=null==i?void 0:i[0])&&void 0!==t?t:this.defaultNodeSize[0],height:null!==(a=null==i?void 0:i[1])&&void 0!==a?a:this.defaultNodeSize[0]},useBrick:l}}));return(0,c.A)(Va,this).current.addNodes(t,{defaultNodeSize:this.defaultNodeSize,canvasWidth:this.clientWidth,canvasHeight:this.clientHeight})}async addEdge(e){var t;let{source:a,target:i,data:l}=e;const n={type:"edge",source:a,target:i,data:l,view:this.lineSettings};return null===(t=(0,c.A)(Va,this).current)||void 0===t||t.addEdge(n),n}manuallyConnectNodes(e){return(0,c.A)(Va,this).current.manuallyConnectNodes(e)}async updateCells(e,t){await(0,o.A)(Ca,this,Xa).call(this);const{updated:a}=(0,c.A)(Va,this).current.updateCells(e,{...t,defaultNodeSize:this.defaultNodeSize,canvasWidth:this.clientWidth,canvasHeight:this.clientHeight});return{updated:a}}async reCenter(){var e;null===(e=(0,c.A)(Va,this).current)||void 0===e||e.reCenter()}disconnectedCallback(){super.disconnectedCallback(),Ut(this,!1)}render(){return g().createElement(Yt,{host:this,ref:(0,c.A)(Va,this),layout:this.layout,layoutOptions:this.layoutOptions,cells:this.cells,defaultNodeSize:this.defaultNodeSize,defaultNodeBricks:this.defaultNodeBricks,defaultEdgeLines:this.defaultEdgeLines,degradedThreshold:this.degradedThreshold,degradedNodeLabel:this.degradedNodeLabel,activeTarget:this.activeTarget,fadeUnrelatedCells:this.fadeUnrelatedCells,zoomable:this.zoomable,scrollable:this.scrollable,pannable:this.pannable,dragBehavior:this.dragBehavior,ctrlDragBehavior:this.ctrlDragBehavior,scaleRange:this.scaleRange,lineSettings:this.lineSettings,lineConnector:this.lineConnector,allowEdgeToArea:this.allowEdgeToArea,doNotResetActiveTargetForSelector:this.doNotResetActiveTargetForSelector,doNotResetActiveTargetOutsideCanvas:this.doNotResetActiveTargetOutsideCanvas,onActiveTargetChange:(0,c.A)(wa,this),onSwitchActiveTarget:(0,c.A)(fa,this),onCellMove:(0,c.A)(ba,this),onCellsMove:(0,c.A)(Ma,this),onCellResize:(0,c.A)(Ta,this),onCellDelete:(0,c.A)(Sa,this),onCellsDelete:(0,c.A)(za,this),onEdgeAdd:(0,c.A)(Oa,this),onCellContextMenu:(0,c.A)(Ba,this),onDecoratorTextChange:(0,c.A)(Fa,this),onContainerContainerChange:(0,c.A)(Ka,this),onScaleChange:(0,c.A)(ja,this),onEdgeViewChange:(0,c.A)(Pa,this)})}}function Xa(){return new Promise((e=>{const t=()=>{(0,c.A)(Va,this).current?e():setTimeout(t,10)};t()}))}function Ya(e,t){let{host:a,layout:i,layoutOptions:l,cells:n,defaultNodeSize:s,defaultNodeBricks:o,defaultEdgeLines:r,degradedThreshold:d,degradedNodeLabel:c,activeTarget:h,fadeUnrelatedCells:A,zoomable:p,scrollable:v,pannable:C,dragBehavior:E,ctrlDragBehavior:K,scaleRange:U,lineSettings:J,lineConnector:Q,allowEdgeToArea:Z,doNotResetActiveTargetForSelector:ee,doNotResetActiveTargetOutsideCanvas:te,onActiveTargetChange:ae,onSwitchActiveTarget:ie,onCellMove:le,onCellResize:ne,onCellDelete:se,onCellsMove:oe,onCellsDelete:re,onCellContextMenu:de,onEdgeAdd:ce,onDecoratorTextChange:he,onScaleChange:ue,onContainerContainerChange:ge,onEdgeViewChange:Ae}=e;const[{cells:pe,layoutKey:ve},ye]=(0,u.useReducer)(m.d,n,(e=>({cells:(0,N.C)(e,{defaultNodeSize:s}),layoutKey:0}))),Ce=(0,u.useMemo)((()=>pe.filter(b.N).length>=(null!=d?d:R.pC)),[pe,d]),we=(0,u.useRef)(null),fe=(0,u.useRef)(null),[me,ke]=(0,u.useState)([]),[be,Ee]=(0,u.useState)([]),[Me,xe]=(0,u.useState)(null),{grabbing:Te,transform:Ne,zoomer:We,scaleRange:Se}=(0,z.f)({rootRef:we,zoomable:p,scrollable:v,pannable:C,draggable:"grab"===E,ctrlDraggable:"grab"===K,scaleRange:U,onSwitchActiveTarget:ie});(0,u.useEffect)((()=>{ue(Ne.k)}),[ue,Ne.k]);const[Re,ze]=(0,u.useState)(null),[Le,Be]=(0,u.useState)(null),{centered:De,setCentered:Oe,getNextLayoutKey:$e}=(0,D.g)({layout:i,layoutOptions:l,rootRef:we,cells:pe,zoomable:p,zoomer:We,scaleRange:Se,layoutKey:ve,allowEdgeToArea:Z,dispatch:ye}),Pe=(0,u.useCallback)((()=>{Oe(!1)}),[Oe]);(0,u.useImperativeHandle)(t,(()=>({dropNode(e){"dagre"!==i&&"force"!==i&&Oe(!0),ye({type:"drop-node",payload:e})},dropDecorator(e){"dagre"!==i&&"force"!==i&&Oe(!0),ye({type:"drop-decorator",payload:e})},addNodes(e,t){let{defaultNodeSize:a,canvasWidth:l,canvasHeight:n}=t;const s=pe.findLastIndex((e=>!("decorator"===e.type&&"text"===e.decorator)))+1,o=[...pe.slice(0,s),...e,...pe.slice(s)],{cells:r,updated:d,shouldReCenter:c}=(0,W.L)({cells:o,layout:i,previousCells:pe,defaultNodeSize:a,canvasWidth:l,canvasHeight:n,scaleRange:Se,transform:Ne,allowEdgeToArea:Z});return c&&Oe(!1),ye({type:"update-cells",payload:r}),d.filter((t=>e.includes(t)))},addEdge(e){ye({type:"add-edge",payload:e})},updateCells(e,t){const{shouldReCenter:a,...l}=(0,W.L)({...t,layout:i,previousCells:pe,cells:e,scaleRange:Se,transform:Ne,allowEdgeToArea:Z});return a&&Oe(!1),ye({type:"update-cells",payload:l.cells}),l},getTransform:()=>Ne,manuallyConnectNodes(e){const t=pe.find((t=>(0,b.bo)(t,Z)&&t.id===e));if(t){const e=we.current.getBoundingClientRect();return Be({source:t,from:[t.view.x+t.view.width/2,t.view.y+t.view.height/2],offset:[e.left,e.top]}),new Promise(((e,t)=>{fe.current={resolve:e,reject:t}}))}return Promise.reject(null)},reCenter:Pe})),[pe,i,Se,Oe,Ne,Z,Pe]);const He=(0,u.useCallback)(((e,t)=>{var a;for(let a=pe.length-1;a>=0;a--){const l=pe[a];if((0,b.bo)(l,Z)&&l.id!==e.source.id&&l.view.x<t[0]&&l.view.x+l.view.width>t[0]&&l.view.y<t[1]&&l.view.y+l.view.height>t[1]){var i;null===(i=fe.current)||void 0===i||i.resolve({source:e.source,target:l});break}}null===(a=fe.current)||void 0===a||a.reject(null),Be(null)}),[Z,pe]),[Fe,_e]=(0,u.useState)(null);(0,u.useEffect)((()=>{Ut(a,!!(Le||Fe||Re))}),[Le,a,Fe,Re]);const Ke=(0,L.J)({rootRef:we,activeTarget:h,doNotResetActiveTargetForSelector:ee,doNotResetActiveTargetOutsideCanvas:te,onActiveTargetChange:ae}),[Ue,je]=(0,u.useState)([]);(0,u.useEffect)((()=>{const e=A?(0,S.Y)(pe,Le,Ke,Z):[];je((t=>0===t.length&&0===e.length?t:e))}),[Ke,pe,Le,A,Z]),(0,u.useEffect)((()=>{const e=we.current;if(!e||me.length>0)return;const t=e=>{const t=(0,M.a)(e,{cells:pe,activeTarget:Ke});"delete-cells"===(null==t?void 0:t.action)&&(re(t.cells),1===t.cells.length&&se(t.cells[0]))};return e.addEventListener("keydown",t),()=>{e.removeEventListener("keydown",t)}}),[Ke,pe,me.length,se,re]);const Ve=`${(0,u.useMemo)((()=>`${(0,y.uniqueId)("diagram-")}-`),[])}line-arrow-`,[Ie,Xe]=(0,u.useState)([]),Ye=(0,u.useCallback)((e=>{ye({type:"move-cells",payload:e});const t=[];(0,I._)(e,pe).forEach((e=>{var a,i;null!==(a=e.containerCell)&&void 0!==a&&a.id&&t.push(null===(i=e.containerCell)||void 0===i?void 0:i.id)})),Ee(t),Xe(e.flatMap((e=>{var t;return null!==(t=e.guideLines)&&void 0!==t?t:[]})))}),[pe]),qe=(0,u.useCallback)((e=>{ye({type:"move-cells",payload:e}),oe(e),1===e.length&&le(e[0]),(0,I._)(e,pe,ge),Ee([]),Xe([])}),[le,oe,pe,ge]),Ge=(0,u.useCallback)((e=>{ye({type:"resize-cell",payload:e})}),[]),Je=(0,u.useCallback)((e=>{ye({type:"resize-cell",payload:e}),ne(e)}),[ne]),Qe=(0,u.useCallback)((e=>{let{id:t,editing:a}=e;ke(a?e=>e.includes(t)?e:[...e,t]:e=>e.filter((e=>e!==t)))}),[]),Ze=(0,u.useCallback)(((e,t)=>{const a=$e();ye({type:"update-node-size",payload:{id:e,size:t},layoutKey:a})}),[$e]),et=(0,u.useCallback)((e=>{We.scaleTo((0,f.A)(we.current),e/100)}),[We]),{lineConfMap:tt,lineConnectorConf:at,markers:it}=(0,$.d)({cells:pe,defaultEdgeLines:r,lineConnector:Q,markerPrefix:Ve}),lt=(0,q.A)({cells:pe,lineConfMap:tt}),nt=(0,u.useMemo)((()=>{let e=[];return e=pe.filter((e=>(0,G.Q)(e,Ke)&&"edge"===e.type&<.has(e))),e}),[Ke,pe,lt]),st=(0,O.H)({cells:pe,layout:i,centered:De}),[ot,rt]=(0,u.useState)(null),dt=(0,u.useRef)(null),[ct,ht]=(0,u.useState)(null),ut=(0,u.useCallback)((e=>{if(at&&(0,b.bo)(e,Z)&&(!ct||"control"!==ct.type)){null!==dt.current&&(clearTimeout(dt.current),dt.current=null);const t=(0,P.G)();rt({cell:e,relativePoints:t,points:Ga(t,e.view)})}}),[Z,at,ct]),gt=(0,u.useCallback)((e=>{at&&(0,b.N)(e)&&(dt.current=setTimeout((()=>{rt(null)})))}),[at]),At=(0,u.useCallback)(((e,t,a,i)=>{const l={source:e.id,target:t.id,view:{...J,exitPosition:a,entryPosition:i,vertices:null}};if(pe.find((a=>"edge"===a.type&&a.source===e.id&&a.target===t.id)))ye({type:"change-edge-view",payload:l}),null==Ae||Ae(l);else{const a={type:"edge",...l};ye({type:"add-edge",payload:a}),ce({source:e,target:t,view:a.view})}}),[pe,J,ce,Ae]),pt=(0,u.useCallback)(((e,t,a)=>{const i={source:e.id,target:t.id,view:a};ye({type:"change-edge-view",payload:i}),null==Ae||Ae(i)}),[Ae]),vt=(0,u.useMemo)((()=>({rootRef:we,smartConnectLineState:Fe,unsetHoverStateTimeoutRef:dt,hoverState:ot,activeEditableEdges:nt,lineEditorState:ct,setLineEditorState:ht,setHoverState:rt,setSmartConnectLineState:_e,onConnect:At,onChangeEdgeView:pt})),[nt,pt,At,ot,ct,Fe]);return(0,u.useEffect)((()=>{const e=we.current;if(!e||"lasso"!==E)return;const t=e.getBoundingClientRect(),a=e=>{(0,_.F)(e,{transform:Ne,offset:[t.left,t.top],onLassoing(e){ze(e)},onLassoed(e){ze(null);const t=[];for(const a of pe)if((0,b.t2)(a)||(0,b.o6)(a)||(0,b.Hs)(a)||(0,b.WW)(a)){const i=(0,y.get)(a,"view.x",0),l=(0,y.get)(a,"view.y",0),n=(0,y.get)(a,"view.width",0),s=(0,y.get)(a,"view.height",0);i>=e.x&&i+n<=e.x+e.width&&l>=e.y&&l+s<=e.y+e.height&&t.push(a)}null==ie||ie(t.length>1?{type:"multi",targets:t.map(V.P)}:1===t.length?(0,V.P)(t[0]):null)}})};return e.addEventListener("mousedown",a),()=>{e.removeEventListener("mousedown",a)}}),[Ne,pe,E,ie]),g().createElement(F.H.Provider,{value:vt},g().createElement("svg",{width:"100%",height:"100%",ref:we,className:w()("root",{grabbing:Te,pannable:C,ready:st}),tabIndex:-1},g().createElement("defs",null,it.map(((e,t)=>g().createElement(k.c,{key:t,id:`${Ve}${t}`,type:e.markerType,strokeColor:e.strokeColor})))),g().createElement("g",{transform:`translate(${Ne.x} ${Ne.y}) scale(${Ne.k})`},g().createElement("g",{className:w()("cells",{allowEdgeToArea:Z})},pe.map((e=>g().createElement(x.m,{key:`${e.type}:${(0,b.WW)(e)?`${e.source}~${e.target}`:e.id}`,dragNodeToContainerActive:!(0,b.WW)(e)&&be.includes(e.id),layout:i,layoutOptions:l,cell:e,cells:pe,degraded:Ce,degradedNodeLabel:c,defaultNodeBricks:o,transform:Ne,lineConfMap:tt,editableLineMap:lt,activeTarget:Ke,unrelatedCells:Ue,allowEdgeToArea:Z,curActiveEditableEdge:Me,updateCurActiveEditableEdge:xe,onCellsMoving:Ye,onCellsMoved:qe,onCellResizing:Ge,onCellResized:Je,onSwitchActiveTarget:ie,onCellContextMenu:de,onDecoratorTextChange:he,onDecoratorTextEditing:Qe,onNodeBrickResize:Ze,onCellMouseEnter:ut,onCellMouseLeave:gt})))),g().createElement("g",null,g().createElement(T.w,{connectLineState:Le,transform:Ne,markerEnd:`${Ve}0`,onConnect:He})),Re&&g().createElement("rect",{x:Re.x,y:Re.y,width:Re.width,height:Re.height,fill:"var(--palette-gray-5)",fillOpacity:.3,stroke:"var(--palette-gray-5)",strokeDasharray:2}),at&&g().createElement("g",null,g().createElement(j.X,{transform:Ne,lineSettings:J,options:at}),g().createElement(Y.W,{cells:pe,editableLineMap:lt,transform:Ne,options:at,activeEditableEdge:Me})),g().createElement("g",null,Ie.map(((e,t)=>g().createElement("path",{key:t,d:`M${e[0].join(" ")} L${e[1].join(" ")}`,stroke:"var(--palette-orange-5)",fill:"none",strokeWidth:1/Ne.k})))),g().createElement("g",null,at&&(null==nt?void 0:nt.map((e=>g().createElement(X.F,{editableLineMap:lt,scale:Ne.k,activeEditableEdge:e,updateCurActiveEditableEdge:xe,key:`${e.source}-${e.target}`}))))),at&&g().createElement(H.T,{activeTarget:Ke,editableLineMap:lt,scale:Ne.k,activeEditableEdge:Me,disabled:!!Le}))),g().createElement(B.Y,{shadowRoot:a.shadowRoot,scale:Ne.k,scaleRange:Se,onZoomChange:et,onReCenter:Pe}))}function qa(){return"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g,(function(e){const t=16*Math.random()|0;return("x"==e?t:3&t|8).toString(16)}))}function Ga(e,t){let a=arguments.length>2&&void 0!==arguments[2]?arguments[2]:1;const i=R.XK,l=i/2,n=t.x+a/2-l,s=t.y+a/2-l,o=t.width-a+i,r=t.height-a+i;return e.map((e=>({x:n+e.x*o,y:s+e.y*r})))}i=Ia,({e:[Z,ee,te,ae,ie,le,ne,se,oe,re,de,ce,he,ue,ge,Ae,pe,ve,ye,Ce,we,fe,me,ke,be,Ee,Me,xe,Te,Ne,We,Se,Re,ze,Le,Be,De,Oe,$e,Pe,He,Fe,_e,Ke,Ue,je,Ve,Ie,Xe,Ye,qe,Ge,Je,Qe,Ze,et,tt,at,it,lt,nt,st,ot,rt,dt,ct,ht,ut,gt,At,pt,vt,yt,Ct,wt,ft,mt,kt,bt,Et,Mt,xt,Tt,Nt,Wt,St,Rt,zt,Lt,Bt,Dt,Ot,$t,Pt,Ht,Ft,_t,Kt,J],c:[qt,Q]}=(0,h.A)(i,[jt("eo-draw-canvas",{styleTexts:[K.A,U.A]})],[[Vt({attribute:!1}),1,"cells"],[Vt({type:String}),1,"layout"],[Vt({attribute:!1}),1,"layoutOptions"],[Vt({attribute:!1}),1,"defaultNodeSize"],[Vt({attribute:!1}),1,"defaultNodeBricks"],[Vt({type:Number}),1,"degradedThreshold"],[Vt({attribute:!1}),1,"degradedNodeLabel"],[Vt({attribute:!1}),1,"defaultEdgeLines"],[Vt({attribute:!1}),1,"activeTarget"],[Vt({type:Boolean}),1,"fadeUnrelatedCells"],[Vt({type:Boolean}),1,"zoomable"],[Vt({type:Boolean}),1,"scrollable"],[Vt({type:Boolean}),1,"pannable"],[Vt({type:Boolean}),1,"allowEdgeToArea"],[Vt(),1,"dragBehavior"],[Vt(),1,"ctrlDragBehavior"],[Vt({attribute:!1}),1,"scaleRange"],[Vt({attribute:!1}),1,"lineSettings"],[Vt({attribute:!1}),1,"lineConnector"],[Vt(),1,"doNotResetActiveTargetForSelector"],[Vt({type:Boolean}),1,"doNotResetActiveTargetOutsideCanvas"],[Xt({type:"activeTarget.change"}),1,"activeTargetChangeEvent",e=>(0,c.A)(ya,e),(e,t)=>(0,d.A)(ya,e,t)],[Xt({type:"node.move"}),1,"nodeMoveEvent",e=>(0,c.A)(ma,e),(e,t)=>(0,d.A)(ma,e,t)],[Xt({type:"cell.move"}),1,"cellMoveEvent",e=>(0,c.A)(ka,e),(e,t)=>(0,d.A)(ka,e,t)],[Xt({type:"cells.move"}),1,"cellsMoveEvent",e=>(0,c.A)(Ea,e),(e,t)=>(0,d.A)(Ea,e,t)],[Xt({type:"cell.resize"}),1,"cellResizeEvent",e=>(0,c.A)(xa,e),(e,t)=>(0,d.A)(xa,e,t)],[Xt({type:"node.delete"}),1,"nodeDelete",e=>(0,c.A)(Na,e),(e,t)=>(0,d.A)(Na,e,t)],[Xt({type:"cell.delete"}),1,"cellDelete",e=>(0,c.A)(Wa,e),(e,t)=>(0,d.A)(Wa,e,t)],[Xt({type:"cells.delete"}),1,"cellsDelete",e=>(0,c.A)(Ra,e),(e,t)=>(0,d.A)(Ra,e,t)],[Xt({type:"cell.contextmenu"}),1,"cellContextMenu",e=>(0,c.A)(La,e),(e,t)=>(0,d.A)(La,e,t)],[Xt({type:"edge.add"}),1,"edgeAdd",e=>(0,c.A)(Da,e),(e,t)=>(0,d.A)(Da,e,t)],[Xt({type:"edge.view.change"}),1,"edgeViewChange",e=>(0,c.A)($a,e),(e,t)=>(0,d.A)($a,e,t)],[Xt({type:"decorator.text.change"}),1,"decoratorTextChange",e=>(0,c.A)(Ha,e),(e,t)=>(0,d.A)(Ha,e,t)],[Xt({type:"node.container.change"}),1,"containerContainerChange",e=>(0,c.A)(_a,e),(e,t)=>(0,d.A)(_a,e,t)],[Xt({type:"scale.change"}),1,"scaleChange",e=>(0,c.A)(Ua,e),(e,t)=>(0,d.A)(Ua,e,t)],[It(),2,"dropNode"],[It(),2,"dropDecorator"],[It(),2,"addNodes"],[It(),2,"addEdge"],[It(),2,"manuallyConnectNodes"],[It(),2,"updateCells"],[It(),2,"reCenter"]],0,(e=>Va.has((0,s.A)(e))),p.ReactNextElement)),Q()}}]);
|
|
2
|
-
//# sourceMappingURL=eo-draw-canvas.8d6f455b.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"chunks/eo-draw-canvas.8d6f455b.js","mappings":"o+BAuGA,MAAMA,IAAiBC,EAAAA,EAAAA,gBACrB,2BAGI,cAAEC,GAAa,SAAEC,GAAQ,OAAEC,GAAM,MAAEC,KAAUC,EAAAA,EAAAA,oBAkEtCC,GAAwBC,IAAAA,WACnCC,IAGF,IAAAC,GAAA,IAAAC,GAAA,IAAAC,QAAAC,GAAA,IAAAD,QAAAE,GAAA,IAAAF,QAAAG,GAAA,IAAAH,QAAAI,GAAA,IAAAJ,QAAAK,GAAA,IAAAL,QAAAM,GAAA,IAAAN,QAAAO,GAAA,IAAAP,QAAAQ,GAAA,IAAAR,QAAAS,GAAA,IAAAT,QAAAU,GAAA,IAAAV,QAAAW,GAAA,IAAAX,QAAAY,GAAA,IAAAZ,QAAAa,GAAA,IAAAb,QAAAc,GAAA,IAAAd,QAAAe,GAAA,IAAAf,QAAAgB,GAAA,IAAAhB,QAAAiB,GAAA,IAAAjB,QAAAkB,GAAA,IAAAlB,QAAAmB,GAAA,IAAAnB,QAAAoB,GAAA,IAAApB,QAAAqB,GAAA,IAAArB,QAAAsB,GAAA,IAAAC,QAAAC,GAAA,IAAAxB,QAAAyB,GAAA,IAAAzB,QAAA0B,GAAA,IAAA1B,QAAA2B,GAAA,IAAA3B,QAAA4B,GAAA,IAAA5B,QAAA6B,GAAA,IAAA7B,QAAA8B,GAAA,IAAA9B,QAAA+B,GAAA,IAAA/B,QAAAgC,GAAA,IAAAhC,QAAAiC,GAAA,IAAAjC,QAAAkC,GAAA,IAAAlC,QAAAmC,GAAA,IAAAnC,QAAAoC,GAAA,IAAApC,QAAAqC,GAAA,IAAArC,QAAAsC,GAAA,IAAAtC,QAAAuC,GAAA,IAAAvC,QAAAwC,GAAA,IAAAxC,QAAAyC,GAAA,IAAAzC,QAAA0C,GAAA,IAAA1C,QAAA2C,GAAA,IAAA3C,QAAA4C,GAAA,IAAA5C,QAAA6C,GAAA,IAAA7C,QAAA8C,GAAA,IAAA9C,QAAA+C,GAAA,IAAA/C,QAAAgD,GAAA,IAAAhD,QAAAiD,GAAA,IAAAjD,QAAAkD,GAAA,IAAAlD,QAMA,MAAAmD,WAG2BC,EAAAA,iBAA8CC,WAAAA,GAAA,SAAAC,YAAAC,EAAAA,EAAAA,GAAA,KAAAjC,KACvEkC,EAAAA,EAAAA,GAAA,KAAAzD,IAAA0D,EAAA,MAAAC,EAAA,SAAAF,EAAAA,EAAAA,GAAA,KAAAvD,IAAA0D,GAAA,MAAAC,GAAA,SAAAJ,EAAAA,EAAAA,GAAA,KAAAtD,IAAA2D,GAAA,MAAAC,GAAA,SAYAN,EAAAA,EAAAA,GAAA,KAAArD,IAAA4D,GAAA,MAAAC,GAAA,KAIsC,CAACC,EAAAA,GAAmBA,EAAAA,QAAkBT,EAAAA,EAAAA,GAAA,KAAApD,IAAA8D,GAAA,MAAAC,GAAA,SAK5EX,EAAAA,EAAAA,GAAA,KAAAnD,IAAA+D,GAAA,MAAAC,GAAA,SAWAb,EAAAA,EAAAA,GAAA,KAAAlD,IAAAgE,GAAA,MAAAC,GAAA,SAQAf,EAAAA,EAAAA,GAAA,KAAAjD,IAAAiE,GAAA,MAAAC,GAAA,SAAAjB,EAAAA,EAAAA,GAAA,KAAAhD,IAAAkE,GAAA,MAAAC,GAAA,SAeAnB,EAAAA,EAAAA,GAAA,KAAA/C,IAAAmE,GAAA,MAAAC,GAAA,SAAArB,EAAAA,EAAAA,GAAA,KAAA9C,IAAAoE,GAAA,MAAAC,GAAA,MAOyC,MAAIvB,EAAAA,EAAAA,GAAA,KAAA7C,IAAAqE,GAAA,MAAAC,GAAA,MAGF,MAAIzB,EAAAA,EAAAA,GAAA,KAAA5C,IAAAsE,GAAA,MAAAC,GAAA,MAGN,MAAI3B,EAAAA,EAAAA,GAAA,KAAA3C,IAAAuE,GAAA,MAAAC,GAAA,MAGG,MAEhD7B,EAAAA,EAAAA,GAAA,KAAA1C,IAAAwE,GAAA,MAAAC,GAAA,SAWA/B,EAAAA,EAAAA,GAAA,KAAAzC,IAAAyE,GAAA,MAAAC,GAAA,SAAAjC,EAAAA,EAAAA,GAAA,KAAAxC,IAAA0E,GAAA,MAAAC,GAAA,SAAAnC,EAAAA,EAAAA,GAAA,KAAAvC,IAAA2E,GAAA,MAAAC,GAAA,SAAArC,EAAAA,EAAAA,GAAA,KAAAtC,IAAA4E,GAAA,MAAAC,GAAA,SAmBAvC,EAAAA,EAAAA,GAAA,KAAArC,IAAA6E,GAAA,MAAAC,GAAA,SAMAzC,EAAAA,EAAAA,GAAA,KAAApC,IAAA8E,GAAA,MAAAC,GAAA,SAAA3C,EAAAA,EAAAA,GAAA,KAAAnC,IAAA+E,GAAA,MAAAC,GAAA,SASA7C,EAAAA,EAAAA,GAAA,KAAAhC,IAAyB8E,GAAA,MAAIC,KAC3BC,EAAAA,EAAAA,GAAAlF,GAAAmF,KAAKC,IAAyBC,KAAKJ,EAAO,KAG5C/C,EAAAA,EAAAA,GAAA,KAAA/B,IAA6B8E,KACtBK,EAAAA,EAAAA,GAAWL,EAAQE,KAAKI,gBAC3BJ,KAAKI,aAAeN,EACtB,KAGF/C,EAAAA,EAAAA,GAAA,KAAA9B,GAAAoF,GAAA,QAAAtD,EAAAA,EAAAA,GAAA,KAAA7B,IAAAoF,GAAA,MAAAC,GAAA,SASAxD,EAAAA,EAAAA,GAAA,KAAA5B,IAAeqF,GAAA,MAAIC,KACjBV,EAAAA,EAAAA,GAAAlF,GAAAmF,KAAKU,IAAeR,KAAKO,GACP,SAAdA,EAAKE,OACPZ,EAAAA,EAAAA,GAAAlF,GAAAmF,KAAKY,IAAeV,KAAKO,EAC3B,KACA1D,EAAAA,EAAAA,GAAA,KAAA3B,GAAAyF,GAAA,QAKF9D,EAAAA,EAAAA,GAAA,KAAA1B,IAAgByF,GAAA,MAAIL,KAClBV,EAAAA,EAAAA,GAAAlF,GAAAmF,KAAKe,IAAgBb,KAAKO,EAAK,KAC/B1D,EAAAA,EAAAA,GAAA,KAAAzB,GAAA0F,GAAA,QAKFjE,EAAAA,EAAAA,GAAA,KAAAxB,IAAiB0F,GAAA,MAAIR,KACnBV,EAAAA,EAAAA,GAAAlF,GAAAmF,KAAKkB,IAAiBhB,KAAKO,EAAK,KAGlC1D,EAAAA,EAAAA,GAAA,KAAAvB,GAAA2F,GAAA,QAAApE,EAAAA,EAAAA,GAAA,KAAAtB,IAAA2F,GAAA,MAAAC,GAAA,SASAtE,EAAAA,EAAAA,GAAA,KAAArB,IAAiB4F,GAAA,MAAIC,KACnBxB,EAAAA,EAAAA,GAAAlF,GAAAmF,KAAKwB,IAAYtB,KAAKqB,GACJ,SAAdA,EAAKZ,OACPZ,EAAAA,EAAAA,GAAAlF,GAAAmF,KAAKyB,IAAYvB,KAAKqB,EACxB,KACAxE,EAAAA,EAAAA,GAAA,KAAApB,GAAA+F,GAAA,QAKF3E,EAAAA,EAAAA,GAAA,KAAAnB,IAAkB+F,GAAA,MAAIC,KACpB7B,EAAAA,EAAAA,GAAAlF,GAAAmF,KAAK6B,IAAa3B,KAAK0B,EAAM,KAC7B7E,EAAAA,EAAAA,GAAA,KAAAlB,GAAAiG,GAAA,QAKF/E,EAAAA,EAAAA,GAAA,KAAAjB,IAAsBiG,GAAA,MAAIC,KACxBjC,EAAAA,EAAAA,GAAAlF,GAAAmF,KAAKiC,IAAiB/B,KAAK8B,EAAO,KAGpCjF,EAAAA,EAAAA,GAAA,KAAAhB,GAAAmG,GAAA,QAMAnF,EAAAA,EAAAA,GAAA,KAAAf,IAAcmG,GAAA,MAAIC,KAChBrC,EAAAA,EAAAA,GAAAlF,GAAAmF,KAAKqC,IAASnC,KAAKkC,EAAK,KACxBrF,EAAAA,EAAAA,GAAA,KAAAd,GAAAqG,GAAA,QAKFvF,EAAAA,EAAAA,GAAA,KAAAb,IAAqBqG,GAAA,MAAIP,KACvBjC,EAAAA,EAAAA,GAAAlF,GAAAmF,KAAKwC,IAAgBtC,KAAK8B,EAAO,KACjCjF,EAAAA,EAAAA,GAAA,KAAAZ,GAAAsG,GAAA,QAKF1F,EAAAA,EAAAA,GAAA,KAAAX,IAA0BsG,GAAA,MAAIV,KAC5BjC,EAAAA,EAAAA,GAAAlF,GAAAmF,KAAK2C,IAAqBzC,KAAK8B,EAAO,KAGxCjF,EAAAA,EAAAA,GAAA,KAAAV,GAAAuG,GAAA,QAMA7F,EAAAA,EAAAA,GAAA,KAAAT,IAA+BuG,GAAA,MAAIb,KACjCjC,EAAAA,EAAAA,GAAAlF,GAAAmF,KAAK8C,IAA0B5C,KAAK8B,EAAO,KAG7CjF,EAAAA,EAAAA,GAAA,KAAAR,GAAAwG,GAAA,QAMAhG,EAAAA,EAAAA,GAAA,KAAAP,IAAkBwG,GAAA,MAAIC,KACpBlD,EAAAA,EAAAA,GAAAlF,GAAAmF,KAAKkD,IAAahD,KAAK+C,EAAM,KAwJ/BlG,EAAAA,EAAAA,GAAA,KAAAN,IAAa0G,EAAAA,EAAAA,aAA2B,UAzX/BvB,GAAK,OAAAwB,EAAAA,EAAAA,GAAA9J,GAAA,eAALsI,CAAKyB,IAAAC,EAAAA,EAAAA,GAAAhK,GAAA,KAAA+J,EAAA,WAGLE,GAAM,OAAAH,EAAAA,EAAAA,GAAA5J,GAAA,gBAAN+J,CAAMF,IAAAC,EAAAA,EAAAA,GAAA9J,GAAA,KAAA6J,EAAA,kBAGNG,GAAa,OAAAJ,EAAAA,EAAAA,GAAA3J,GAAA,uBAAb+J,CAAaH,IAAAC,EAAAA,EAAAA,GAAA7J,GAAA,KAAA4J,EAAA,oBAMbI,GAAe,OAAAL,EAAAA,EAAAA,GAAA1J,GAAA,yBAAf+J,CAAeJ,IAAAC,EAAAA,EAAAA,GAAA5J,GAAA,KAAA2J,EAAA,sBAGfK,GAAiB,OAAAN,EAAAA,EAAAA,GAAAzJ,GAAA,2BAAjB+J,CAAiBL,IAAAC,EAAAA,EAAAA,GAAA3J,GAAA,KAAA0J,EAAA,sBAQjBM,GAAiB,OAAAP,EAAAA,EAAAA,GAAAxJ,GAAA,2BAAjB+J,CAAiBN,IAAAC,EAAAA,EAAAA,GAAA1J,GAAA,KAAAyJ,EAAA,sBAWjBO,GAAiB,OAAAR,EAAAA,EAAAA,GAAAvJ,GAAA,2BAAjB+J,CAAiBP,IAAAC,EAAAA,EAAAA,GAAAzJ,GAAA,KAAAwJ,EAAA,qBAYjBQ,GAAgB,OAAAT,EAAAA,EAAAA,GAAAtJ,GAAA,0BAAhB+J,CAAgBR,IAAAC,EAAAA,EAAAA,GAAAxJ,GAAA,KAAAuJ,EAAA,iBAGhBjD,GAAY,OAAAgD,EAAAA,EAAAA,GAAArJ,GAAA,sBAAZqG,CAAYiD,IAAAC,EAAAA,EAAAA,GAAAvJ,GAAA,KAAAsJ,EAAA,uBAMZS,GAAkB,OAAAV,EAAAA,EAAAA,GAAApJ,GAAA,4BAAlB8J,CAAkBT,IAAAC,EAAAA,EAAAA,GAAAtJ,GAAA,KAAAqJ,EAAA,aAGlBU,GAAQ,OAAAX,EAAAA,EAAAA,GAAAnJ,GAAA,kBAAR8J,CAAQV,IAAAC,EAAAA,EAAAA,GAAArJ,GAAA,KAAAoJ,EAAA,eAGRW,GAAU,OAAAZ,EAAAA,EAAAA,GAAAlJ,GAAA,oBAAV8J,CAAUX,IAAAC,EAAAA,EAAAA,GAAApJ,GAAA,KAAAmJ,EAAA,aAGVY,GAAQ,OAAAb,EAAAA,EAAAA,GAAAjJ,GAAA,kBAAR8J,CAAQZ,IAAAC,EAAAA,EAAAA,GAAAnJ,GAAA,KAAAkJ,EAAA,oBAGRa,GAAe,OAAAd,EAAAA,EAAAA,GAAAhJ,GAAA,yBAAf8J,CAAeb,IAAAC,EAAAA,EAAAA,GAAAlJ,GAAA,KAAAiJ,EAAA,iBAWfc,GAAY,OAAAf,EAAAA,EAAAA,GAAA/I,GAAA,sBAAZ8J,CAAYd,IAAAC,EAAAA,EAAAA,GAAAjJ,GAAA,KAAAgJ,EAAA,qBAUZe,GAAgB,OAAAhB,EAAAA,EAAAA,GAAA9I,GAAA,0BAAhB8J,CAAgBf,IAAAC,EAAAA,EAAAA,GAAAhJ,GAAA,KAAA+I,EAAA,eAGhBgB,GAAU,OAAAjB,EAAAA,EAAAA,GAAA7I,GAAA,oBAAV8J,CAAUhB,IAAAC,EAAAA,EAAAA,GAAA/I,GAAA,KAAA8I,EAAA,iBAGViB,GAAY,OAAAlB,EAAAA,EAAAA,GAAA5I,GAAA,sBAAZ8J,CAAYjB,IAAAC,EAAAA,EAAAA,GAAA9I,GAAA,KAAA6I,EAAA,kBAGZkB,GAAa,OAAAnB,EAAAA,EAAAA,GAAA3I,GAAA,uBAAb8J,CAAalB,IAAAC,EAAAA,EAAAA,GAAA7I,GAAA,KAAA4I,EAAA,sCAMbmB,GAAiC,OAAApB,EAAAA,EAAAA,GAAA1I,GAAA,2CAAjC8J,CAAiCnB,IAAAC,EAAAA,EAAAA,GAAA5I,GAAA,KAAA2I,EAAA,wCAMjCoB,GAAmC,OAAArB,EAAAA,EAAAA,GAAAzI,GAAA,6CAAnC8J,CAAmCpB,IAAAC,EAAAA,EAAAA,GAAA3I,GAAA,KAAA0I,EAAA,CAuH5C,cACMqB,CAAQC,GAM6B,IAAAC,EAAAC,EAAA,IAN5B,GACbC,EAAE,SACFC,EAAQ,KACRC,EAAI,KACJC,EAAI,SACJC,GACaP,EAKb,GAFoB,QADDC,GAAGC,EAAAM,UACnBC,yBAAiB,IAAAR,GAA4B,QAA5BA,EADEA,EAAAS,KAAAR,EACCE,EAAS,GAAIA,EAAS,WAAG,IAAAH,OAAA,EAD1BA,EAElBU,SAAStF,MACM,KAAAuF,EAAAC,EAAAC,EACjB,MAAMC,EAAqB1F,KAAK2F,wBAC1BC,GAAYxC,EAAAA,EAAAA,GAAK3G,GAALuD,MAAgB6F,QAASC,eACrCC,EAAU,CACdpF,KAAM,OACNmE,KACAkB,KAAM,IACgB,UAAhBhG,KAAKuD,QAAsC,UAAhBvD,KAAKuD,OAChC,KACA,CACE0C,GACGlB,EAAS,GAAKW,EAAmBQ,KAAON,EAAUK,GACnDL,EAAUO,EACZC,GACGrB,EAAS,GAAKW,EAAmBW,IAAMT,EAAUQ,GAClDR,EAAUO,GAElBG,MAAgB,QAAXf,EAAEP,aAAI,EAAJA,EAAO,UAAE,IAAAO,EAAAA,EAAIvF,KAAKyD,gBAAgB,GACzC8C,OAAiB,QAAXf,EAAER,aAAI,EAAJA,EAAO,UAAE,IAAAQ,EAAAA,EAAIxF,KAAKyD,gBAAgB,IAE5CwB,OACAC,YAGF,OADuB,QAAvBO,GAAArC,EAAAA,EAAAA,GAAK3G,GAALuD,MAAgB6F,eAAO,IAAAJ,GAAvBA,EAAyBf,SAASqB,GAC3BA,CACT,CACA,OAAO,IACT,CAEA,mBACMS,CAAaC,GAKkC,IAAAC,EAAAC,EAAA,IALjC,SAClB5B,EAAQ,UACR6B,EAAS,KACTC,EAAI,UACJC,GACkBL,EAKlB,GAFoB,QADDC,GAAGC,EAAAxB,UACnBC,yBAAiB,IAAAsB,GAA4B,QAA5BA,EADEA,EAAArB,KAAAsB,EACC5B,EAAS,GAAIA,EAAS,WAAG,IAAA2B,OAAA,EAD1BA,EAElBpB,SAAStF,MACM,KAAA+G,EACjB,MAAMrB,EAAqB1F,KAAK2F,wBAC1BC,GAAYxC,EAAAA,EAAAA,GAAK3G,GAALuD,MAAgB6F,QAASC,eACrCkB,EAA8B,CAClCrG,KAAM,YACNiG,YACA9B,GAAImC,KACJjB,KAAM,CACJC,GACGlB,EAAS,GAAKW,EAAmBQ,KAAON,EAAUK,GAAKL,EAAUO,EACpEC,GAAIrB,EAAS,GAAKW,EAAmBW,IAAMT,EAAUQ,GAAKR,EAAUO,EACpEG,MAAOY,EAAAA,GACPX,OAAQY,EAAAA,GACRN,OACAC,cAIJ,OADuB,QAAvBC,GAAA3D,EAAAA,EAAAA,GAAK3G,GAALuD,MAAgB6F,eAAO,IAAAkB,GAAvBA,EAAyBP,cAAcQ,GAChCA,CACT,CACA,OAAO,IACT,CAEA,cACMI,CAASC,GACb,GAAqB,IAAjBA,EAAMC,OACR,MAAO,GAET,MAAMC,EAAWF,EAAMG,KAAcC,IAAA,IAAAC,EAAAC,EAAA,IAAC,KAAE3C,EAAI,SAAEE,EAAQ,GAAEJ,EAAE,KAAEG,GAAMwC,EAAA,MAAM,CACtE9G,KAAM,OACNmE,KACAG,OACAe,KAAM,CACJM,MAAgB,QAAXoB,EAAE1C,aAAI,EAAJA,EAAO,UAAE,IAAA0C,EAAAA,EAAI1H,KAAKyD,gBAAgB,GACzC8C,OAAiB,QAAXoB,EAAE3C,aAAI,EAAJA,EAAO,UAAE,IAAA2C,EAAAA,EAAI3H,KAAKyD,gBAAgB,IAE5CyB,WACD,IACD,OAAO9B,EAAAA,EAAAA,GAAK3G,GAALuD,MAAgB6F,QAASuB,SAASG,EAAU,CACjD9D,gBAAiBzD,KAAKyD,gBACtBmE,YAAa5H,KAAK6H,YAClBC,aAAc9H,KAAK+H,cAEvB,CAEA,aACMC,CAAOC,GAA2D,IAAAC,EAAA,IAA1D,OAAEC,EAAM,OAAErI,EAAM,KAAEmF,GAAmBgD,EACjD,MAAMG,EAAoB,CACxBzH,KAAM,OACNwH,SACArI,SACAmF,OACAe,KAAMhG,KAAKsE,cAGb,OADuB,QAAvB4D,GAAA9E,EAAAA,EAAAA,GAAK3G,GAALuD,MAAgB6F,eAAO,IAAAqC,GAAvBA,EAAyBF,QAAQI,GAC1BA,CACT,CAGAC,oBAAAA,CAAqBF,GACnB,OAAO/E,EAAAA,EAAAA,GAAK3G,GAALuD,MAAgB6F,QAASwC,qBAAqBF,EACvD,CAEA,iBACMG,CACJ1G,EACA2G,SAEMC,EAAAA,EAAAA,GAAA3N,GAAAmF,KAAKyI,IAAiBpD,KAAtBrF,MACN,MAAM,QAAE0I,IAAYtF,EAAAA,EAAAA,GAAK3G,GAALuD,MAAgB6F,QAASyC,YAAY1G,EAAO,IAC3D2G,EACH9E,gBAAiBzD,KAAKyD,gBACtBmE,YAAa5H,KAAK6H,YAClBC,aAAc9H,KAAK+H,eAErB,MAAO,CAAEW,UACX,CAGA,cACMC,GAAW,IAAAC,EACQ,QAAvBA,GAAAxF,EAAAA,EAAAA,GAAK3G,GAALuD,MAAgB6F,eAAO,IAAA+C,GAAvBA,EAAyBD,UAC3B,CAiBAE,oBAAAA,GACEC,MAAMD,uBACNlQ,GAAeqH,MAAM,EACvB,CAEA+I,MAAAA,GACE,OACE5P,IAAAA,cAACD,GAAqB,CACpB8P,KAAMhJ,KACNiJ,KAAK7F,EAAAA,EAAAA,GAAK3G,GAALuD,MACLuD,OAAQvD,KAAKuD,OACbC,cAAexD,KAAKwD,cACpB5B,MAAO5B,KAAK4B,MACZ6B,gBAAiBzD,KAAKyD,gBACtBC,kBAAmB1D,KAAK0D,kBACxBG,iBAAkB7D,KAAK6D,iBACvBF,kBAAmB3D,KAAK2D,kBACxBC,kBAAmB5D,KAAK4D,kBACxBxD,aAAcJ,KAAKI,aACnB0D,mBAAoB9D,KAAK8D,mBACzBC,SAAU/D,KAAK+D,SACfC,WAAYhE,KAAKgE,WACjBC,SAAUjE,KAAKiE,SACfE,aAAcnE,KAAKmE,aACnBC,iBAAkBpE,KAAKoE,iBACvBC,WAAYrE,KAAKqE,WACjBC,aAActE,KAAKsE,aACnBC,cAAevE,KAAKuE,cACpBL,gBAAiBlE,KAAKkE,gBACtBM,kCACExE,KAAKwE,kCAEPC,oCACEzE,KAAKyE,oCAEPyE,sBAAsB9F,EAAAA,EAAAA,GAAKrI,GAALiF,MACtBmJ,sBAAsB/F,EAAAA,EAAAA,GAAKpI,GAALgF,MACtBoJ,YAAYhG,EAAAA,EAAAA,GAAKjI,GAAL6E,MACZqJ,aAAajG,EAAAA,EAAAA,GAAK/H,GAAL2E,MACbsJ,cAAclG,EAAAA,EAAAA,GAAK7H,GAALyE,MACduJ,cAAcnG,EAAAA,EAAAA,GAAK1H,GAALsE,MACdwJ,eAAepG,EAAAA,EAAAA,GAAKxH,GAALoE,MACfyJ,WAAWrG,EAAAA,EAAAA,GAAKpH,GAALgE,MACX0J,mBAAmBtG,EAAAA,EAAAA,GAAKtH,GAALkE,MACnB2J,uBAAuBvG,EAAAA,EAAAA,GAAKhH,GAAL4D,MACvB4J,4BAA4BxG,EAAAA,EAAAA,GAAK9G,GAAL0D,MAC5B6J,eAAezG,EAAAA,EAAAA,GAAK5G,GAALwD,MACf8J,kBAAkB1G,EAAAA,EAAAA,GAAKlH,GAAL8D,OAGxB,EACD,SAAAyI,KAjEG,OAAO,IAAIsB,SAAeC,IACxB,MAAMC,EAAQA,MACR7G,EAAAA,EAAAA,GAAK3G,GAALuD,MAAgB6F,QAClBmE,IAEAE,WAAWD,EAAO,GACpB,EAEFA,GAAO,GAEX,CA+FF,SAAS7Q,GAA2B+Q,EAsClClB,GACA,IAtCA,KACED,EAAI,OACJzF,EAAM,cACNC,EACA5B,MAAOwI,EAAY,gBACnB3G,EAAe,kBACfC,EAAiB,iBACjBG,EAAgB,kBAChBF,EAAiB,kBACjBC,EACAxD,aAAciK,EAAa,mBAC3BvG,EAAkB,SAClBC,EAAQ,WACRC,EAAU,SACVC,EAAQ,aACRE,EAAY,iBACZC,EACAC,WAAYiG,EAAW,aACvBhG,EAAY,cACZC,EAAa,gBACbL,EAAe,kCACfM,GAAiC,oCACjCC,GAAmC,qBACnCyE,GAAoB,qBACpBC,GAAoB,WACpBC,GAAU,aACVE,GAAY,aACZC,GAAY,YACZF,GAAW,cACXG,GAAa,kBACbE,GAAiB,UACjBD,GAAS,sBACTE,GAAqB,cACrBE,GAAa,2BACbD,GAA0B,iBAC1BE,IAC2BK,EAG7B,OAAO,MAAEvI,GAAK,UAAE2I,IAAaC,KAAYC,EAAAA,EAAAA,YACvCC,EAAAA,EACAN,GACCA,IAAY,CACXxI,OAAO+I,EAAAA,EAAAA,GAAgBP,EAAc,CAAE3G,oBACvC8G,UAAW,MAMTK,IAAWC,EAAAA,EAAAA,UACf,IACEjJ,GAAMkJ,OAAOC,EAAAA,GAAYzD,SACxB3D,QAAAA,EAAqBqH,EAAAA,KACxB,CAACpJ,GAAO+B,IAGJsH,IAAUC,EAAAA,EAAAA,QAAsB,MAChCC,IAA2BD,EAAAA,EAAAA,QAC/B,OAEKE,GAAcC,KAAmBC,EAAAA,EAAAA,UAAmB,KACpDC,GAAkBC,KAAuBF,EAAAA,EAAAA,UAAmB,KAC5DG,GAAuBC,KAC5BJ,EAAAA,EAAAA,UAA8B,OAC1B,SAAEK,GAAQ,UAAE/F,GAAS,OAAEgG,GAAM,WAAEvH,KAAewH,EAAAA,EAAAA,GAAQ,CAC1DZ,WACAlH,WACAC,aACAC,WACA6H,UAA4B,SAAjB3H,EACX4H,cAAoC,SAArB3H,EACfC,WAAYiG,EACZnB,2BAGF6C,EAAAA,EAAAA,YAAU,KACRnC,GAAcjE,GAAUO,EAAE,GACzB,CAAC0D,GAAejE,GAAUO,IAE7B,MAAO8F,GAAWC,KAAgBZ,EAAAA,EAAAA,UAA0B,OAErDa,GAAkBC,KACvBd,EAAAA,EAAAA,UAAkC,OAE9B,SAAEe,GAAQ,YAAEC,GAAW,iBAAEC,KAAqBC,EAAAA,EAAAA,GAAU,CAC5DjJ,SACAC,gBACAyH,WACArJ,SACAmC,WACA6H,UACAvH,cACAkG,aACArG,kBACAsG,cAGI7B,IAAW8D,EAAAA,EAAAA,cAAY,KAC3BH,IAAY,EAAM,GACjB,CAACA,MAEJI,EAAAA,EAAAA,qBACEzD,GACA,KAAM,CACJvE,QAAAA,CAASiI,GAEQ,UAAXpJ,GAAiC,UAAXA,GACxB+I,IAAY,GAEd9B,GAAS,CAAE7J,KAAM,YAAaiM,QAASD,GACzC,EACAnG,aAAAA,CAAcI,GAEG,UAAXrD,GAAiC,UAAXA,GACxB+I,IAAY,GAEd9B,GAAS,CAAE7J,KAAM,iBAAkBiM,QAAShG,GAC9C,EACAQ,QAAAA,CACEC,EAAKwF,GAEL,IADA,gBAAEpJ,EAAe,YAAEmE,EAAW,aAAEE,GAA+B+E,EAE/D,MAAMC,EACJlL,GAAMmL,eACHxL,KAAyB,cAAdA,EAAKZ,MAA2C,SAAnBY,EAAKqF,aAC5C,EACAoG,EAAW,IACZpL,GAAMqL,MAAM,EAAGH,MACfzF,KACAzF,GAAMqL,MAAMH,KAGflL,MAAOsL,EAAQ,QACfxE,EAAO,eACPyE,IACE7E,EAAAA,EAAAA,GAAY,CACd1G,MAAOoL,EACPzJ,SACA6J,cAAexL,GACf6B,kBACAmE,cACAE,eACAzD,cACAuB,aACA1B,oBAMF,OAJIiJ,GACFb,IAAY,GAEd9B,GAAS,CAAE7J,KAAM,eAAgBiM,QAASM,IACnCxE,EAAQoC,QAAQ6B,GACrBtF,EAAM/B,SAASqH,IAEnB,EACA3E,OAAAA,CAAQ5F,GACNoI,GAAS,CAAE7J,KAAM,WAAYiM,QAASxK,GACxC,EACAkG,WAAAA,CAAY0E,EAAUzE,GACpB,MAAM,eAAE4E,KAAmBE,IAAW/E,EAAAA,EAAAA,GAAY,IAC7CC,EACHhF,SACA6J,cAAexL,GACfA,MAAOoL,EACP3I,cACAuB,aACA1B,oBAMF,OAJIiJ,GACFb,IAAY,GAEd9B,GAAS,CAAE7J,KAAM,eAAgBiM,QAASS,EAAOzL,QAC1CyL,CACT,EACAvH,aAAYA,IACHF,GAETyC,oBAAAA,CAAqBiF,GACnB,MAAMnF,EAASvG,GAAM2L,MAClBhM,IAASiM,EAAAA,EAAAA,IAAWjM,EAAM2C,IAAoB3C,EAAKuD,KAAOwI,IAE7D,GAAInF,EAAQ,CACV,MAAMsF,EAAOxC,GAAQpF,QAASF,wBAY9B,OAXAyG,GAAoB,CAClBjE,SACAuF,KAAM,CACJvF,EAAOnC,KAAKC,EAAIkC,EAAOnC,KAAKM,MAAQ,EACpC6B,EAAOnC,KAAKI,EAAI+B,EAAOnC,KAAKO,OAAS,GAEvCoH,OAAQ,CAACF,EAAKvH,KAAMuH,EAAKpH,OAEX,IAAI0D,SAA4B,CAACC,EAAS4D,KACxDzC,GAAyBtF,QAAU,CAAEmE,UAAS4D,SAAQ,GAG1D,CACA,OAAO7D,QAAQ6D,OAAO,KACxB,EACAjF,eAEF,CACE/G,GACA2B,EACAc,GACAiI,GACA1G,GACA1B,EACAyE,KAIJ,MAAMkF,IAAgBpB,EAAAA,EAAAA,cACpB,CAACqB,EAAyBC,KAAsB,IAAAC,EAG9C,IAAK,IAAIC,EAAIrM,GAAM0F,OAAS,EAAG2G,GAAK,EAAGA,IAAK,CAC1C,MAAM1M,EAAOK,GAAMqM,GAEnB,IAAIT,EAAAA,EAAAA,IAAWjM,EAAM2C,IAAoB3C,EAAKuD,KAAOgJ,EAAM3F,OAAOrD,IAE9DvD,EAAKyE,KAAKC,EAAI8H,EAAG,IACjBxM,EAAKyE,KAAKC,EAAI1E,EAAKyE,KAAKM,MAAQyH,EAAG,IACnCxM,EAAKyE,KAAKI,EAAI2H,EAAG,IACjBxM,EAAKyE,KAAKI,EAAI7E,EAAKyE,KAAKO,OAASwH,EAAG,GACpC,KAAAG,EACgC,QAAhCA,EAAA/C,GAAyBtF,eAAO,IAAAqI,GAAhCA,EAAkClE,QAAQ,CACxC7B,OAAQ2F,EAAM3F,OACdrI,OAAQyB,IAEV,KACF,CAEJ,CACgC,QAAhCyM,EAAA7C,GAAyBtF,eAAO,IAAAmI,GAAhCA,EAAkCJ,OAAO,MACzCxB,GAAoB,KAAK,GAE3B,CAAClI,EAAiBtC,MAEbuM,GAAuBC,KAC5B9C,EAAAA,EAAAA,UAAuC,OAEzCU,EAAAA,EAAAA,YAAU,KACRrT,GACEqQ,KACGmD,IAAsBgC,IAAyBlC,IACnD,GACA,CAACE,GAAkBnD,EAAMmF,GAAuBlC,KAEnD,MAAM7L,IAAeiO,EAAAA,EAAAA,GAAgB,CACnCpD,WACA7K,aAAciK,EACd7F,qCACAC,uCACAyE,2BAGKoF,GAAgBC,KAAqBjD,EAAAA,EAAAA,UAAiB,KAC7DU,EAAAA,EAAAA,YAAU,KACR,MAAMwC,EAAgB1K,GAClB2K,EAAAA,EAAAA,GACE7M,GACAuK,GACA/L,GACA8D,GAEF,GAEJqK,IAAmBG,GACD,IAAhBA,EAAKpH,QAAyC,IAAzBkH,EAAclH,OAAeoH,EAAOF,GAC1D,GACA,CACDpO,GACAwB,GACAuK,GACArI,EACAI,KAGF8H,EAAAA,EAAAA,YAAU,KACR,MAAM2C,EAAO1D,GAAQpF,QACrB,IAAK8I,GAAQvD,GAAa9D,OAAS,EACjC,OAEF,MAAMsH,EAAa5V,IACjB,MAAM6V,GAASC,EAAAA,EAAAA,GAAe9V,EAAO,CACnC4I,SACAxB,kBAIK,kBADCyO,aAAM,EAANA,EAAQA,UAEZrF,GAAcqF,EAAOjN,OACO,IAAxBiN,EAAOjN,MAAM0F,QACfiC,GAAasF,EAAOjN,MAAM,IAGhC,EAGF,OADA+M,EAAKI,iBAAiB,UAAWH,GAC1B,KACLD,EAAKK,oBAAoB,UAAWJ,EAAU,CAC/C,GACA,CAACxO,GAAcwB,GAAOwJ,GAAa9D,OAAQiC,GAAcC,KAE5D,MACMyF,GAAe,IADHpE,EAAAA,EAAAA,UAAQ,IAAM,IAAGqE,EAAAA,EAAAA,UAAS,gBAAgB,kBAGrDC,GAAYC,KAAiB9D,EAAAA,EAAAA,UAAsB,IAGpD+D,IAAoB5C,EAAAA,EAAAA,cACvBhM,IACC+J,GAAS,CAAE7J,KAAM,aAAciM,QAASnM,IACxC,MAAM6O,EAAyB,IAC/BC,EAAAA,EAAAA,GAA0B9O,EAAMmB,IAAO4N,SAASC,IAAM,IAAAC,EAAAC,EACjC,QAAnBD,EAAID,EAAEG,qBAAa,IAAAF,GAAfA,EAAiB5K,IAAIwK,EAAaO,KAAoB,QAAhBF,EAACF,EAAEG,qBAAa,IAAAD,OAAA,EAAfA,EAAiB7K,GAAG,IAEjE0G,GAAoB8D,GACpBF,GAAc3O,EAAKqP,SAASL,IAAC,IAAAM,EAAA,OAAiB,QAAjBA,EAAKN,EAAEN,kBAAU,IAAAY,EAAAA,EAAI,EAAE,IAAE,GAExD,CAACnO,KAIGoO,IAAmBvD,EAAAA,EAAAA,cACtBhM,IACC+J,GAAS,CAAE7J,KAAM,aAAciM,QAASnM,IACxC4I,GAAY5I,GACQ,IAAhBA,EAAK6G,QACP8B,GAAW3I,EAAK,KAElB8O,EAAAA,EAAAA,GAA0B9O,EAAMmB,GAAOgI,IACvC4B,GAAoB,IACpB4D,GAAc,GAAG,GAEnB,CAAChG,GAAYC,GAAazH,GAAOgI,KAG7BqG,IAAqBxD,EAAAA,EAAAA,cAAahM,IACtC+J,GAAS,CAAE7J,KAAM,cAAeiM,QAASnM,GAAO,GAC/C,IAEGyP,IAAoBzD,EAAAA,EAAAA,cACvBhM,IACC+J,GAAS,CAAE7J,KAAM,cAAeiM,QAASnM,IACzC6I,GAAa7I,EAAK,GAEpB,CAAC6I,KAGG6G,IAA6B1D,EAAAA,EAAAA,cACjC2D,IAAuD,IAAtD,GAAEtL,EAAE,QAAEuL,GAA2CD,EAE9C/E,GADEgF,EACeC,GACfA,EAAMhL,SAASR,GAAMwL,EAAQ,IAAIA,EAAOxL,GAGzBwL,GAAUA,EAAMxF,QAAQjE,GAASA,IAAS/B,IAC7D,GAEF,IAGIyL,IAAwB9D,EAAAA,EAAAA,cAC5B,CAAC3H,EAAYE,KACX,MAAMwL,EAAgBjE,KACtB/B,GAAS,CACP7J,KAAM,mBACNiM,QAAS,CAAE9H,KAAIE,QACfuF,UAAWiG,GACX,GAEJ,CAACjE,KAGGkE,IAAkBhE,EAAAA,EAAAA,cACrBiE,IAGG9E,GAAO+E,SAAQC,EAAAA,EAAAA,GAAO3F,GAAQpF,SAAW6K,EAAQ,IACnD,GAEF,CAAC9E,MAEG,YAAEiF,GAAW,kBAAEC,GAAiB,QAAEC,KAAYC,EAAAA,EAAAA,GAAe,CACjEpP,SACAiC,mBACAU,gBACA0K,kBAGIgC,IAAkBC,EAAAA,EAAAA,GAAmB,CAAEtP,SAAOiP,iBAE9CM,IAAsBtG,EAAAA,EAAAA,UAAQ,KAClC,IAAIuG,EAAoB,GAOxB,OANAA,EAAQxP,GAAMkJ,QACXvJ,IACC8P,EAAAA,EAAAA,GAAe9P,EAAMnB,KACP,SAAdmB,EAAKZ,MACLsQ,GAAgBK,IAAI/P,KAEjB6P,CAAK,GACX,CAAChR,GAAcwB,GAAOqP,KAEnBM,IAAQC,EAAAA,EAAAA,GAAS,CAAE5P,SAAO2B,SAAQ8I,eAEjCoF,GAAYC,KAAiBpG,EAAAA,EAAAA,UAA4B,MAC1DqG,IAA4BzG,EAAAA,EAAAA,QAAsB,OAEjD0G,GAAiBC,KACtBvG,EAAAA,EAAAA,UAAiC,MAG7BwG,IAAuBrF,EAAAA,EAAAA,cAC1BlL,IACC,GACEuP,KACAtD,EAAAA,EAAAA,IAAWjM,EAAM2C,MACf0N,IAA4C,YAAzBA,GAAgBjR,MACrC,CAC0C,OAAtCgR,GAA0B9L,UAC5BkM,aAAaJ,GAA0B9L,SACvC8L,GAA0B9L,QAAU,MAEtC,MAAMmM,GAAiBC,EAAAA,EAAAA,KACvBP,GAAc,CACZnQ,OACAyQ,iBACAE,OAAQC,GAAiBH,EAAgBzQ,EAAKyE,OAElD,IAEF,CAAC9B,EAAiB4M,GAAmBc,KAGjCQ,IAAuB3F,EAAAA,EAAAA,cAC1BlL,IACKuP,KAAqB/F,EAAAA,EAAAA,GAAWxJ,KAClCoQ,GAA0B9L,QAAUqE,YAAW,KAC7CwH,GAAc,KAAK,IAEvB,GAEF,CAACZ,KAIGuB,IAAqB5F,EAAAA,EAAAA,cACzB,CACEtE,EACArI,EACAwS,EACAC,KAEA,MAAM3F,EAAiC,CACrCzE,OAAQA,EAAOrD,GACfhF,OAAQA,EAAOgF,GACfkB,KAAM,IACD1B,EACHgO,eACAC,gBACAC,SAAU,OASd,GANoB5Q,GAAM2L,MACvBhM,GACe,SAAdA,EAAKZ,MACLY,EAAK4G,SAAWA,EAAOrD,IACvBvD,EAAKzB,SAAWA,EAAOgF,KAGzB0F,GAAS,CACP7J,KAAM,mBACNiM,YAEF9C,UAAAA,GAAmB8C,OACd,CACL,MAAMxE,EAAoB,CACxBzH,KAAM,UACHiM,GAELpC,GAAS,CACP7J,KAAM,WACNiM,QAASxE,IAEXqB,GAAU,CACRtB,SACArI,SACAkG,KAAMoC,EAAQpC,MAElB,IAEF,CAACpE,GAAO0C,EAAcmF,GAAWK,KAI7B2I,IAAuBhG,EAAAA,EAAAA,cAC3B,CACEtE,EACArI,EACAkG,KAEA,MAAM4G,EAAiC,CACrCzE,OAAQA,EAAOrD,GACfhF,OAAQA,EAAOgF,GACfkB,QAEFwE,GAAS,CACP7J,KAAM,mBACNiM,YAEF9C,UAAAA,GAAmB8C,EAAQ,GAE7B,CAAC9C,KAIG4I,IAAyB7H,EAAAA,EAAAA,UAC7B,KAAM,CACJI,WACAkD,yBACAwD,6BACAF,cACAN,uBACAS,mBACAC,sBACAH,iBACAtD,4BACAuE,UAAWN,GACXO,iBAAkBH,MAEpB,CACEtB,GACAsB,GACAJ,GACAZ,GACAG,GACAzD,KAyDJ,OAtDAnC,EAAAA,EAAAA,YAAU,KACR,MAAM2C,EAAO1D,GAAQpF,QACrB,IAAK8I,GAAyB,UAAjBxK,EACX,OAEF,MAAM0O,EAAWlE,EAAKhJ,wBAEhBmN,EAAe9Z,KACnB+Z,EAAAA,EAAAA,GAAY/Z,EAAO,CACjB4M,aACA+H,OAAQ,CAACkF,EAAS3M,KAAM2M,EAASxM,KACjC2M,UAAAA,CAAWvF,GACTvB,GAAauB,EACf,EACAwF,SAAAA,CAAUxF,GACRvB,GAAa,MACb,MAAMgH,EAAwD,GAC9D,IAAK,MAAM3R,KAAQK,GACjB,IACEuR,EAAAA,EAAAA,IAAyB5R,KACzB6R,EAAAA,EAAAA,IAA0B7R,KAC1B8R,EAAAA,EAAAA,IAAoB9R,KACpB+R,EAAAA,EAAAA,IAAW/R,GACX,CACA,MAAM0E,GAAIsN,EAAAA,EAAAA,KAAIhS,EAAM,SAAU,GACxB6E,GAAImN,EAAAA,EAAAA,KAAIhS,EAAM,SAAU,GACxB+E,GAAQiN,EAAAA,EAAAA,KAAIhS,EAAM,aAAc,GAChCgF,GAASgN,EAAAA,EAAAA,KAAIhS,EAAM,cAAe,GAEtC0E,GAAKwH,EAAKxH,GACVA,EAAIK,GAASmH,EAAKxH,EAAIwH,EAAKnH,OAC3BF,GAAKqH,EAAKrH,GACVA,EAAIG,GAAUkH,EAAKrH,EAAIqH,EAAKlH,QAE5B2M,EAAarD,KAAKtO,EAEtB,CAEF4H,UAAAA,GACE+J,EAAa5L,OAAS,EAClB,CAAE3G,KAAM,QAAS6S,QAASN,EAAa1L,IAAIiM,EAAAA,IACnB,IAAxBP,EAAa5L,QACXmM,EAAAA,EAAAA,GAAaP,EAAa,IAC1B,KAEV,GACA,EAGJ,OADAvE,EAAKI,iBAAiB,YAAa+D,GAC5B,KACLnE,EAAKK,oBAAoB,YAAa8D,EAAY,CACnD,GACA,CAAClN,GAAWhE,GAAOuC,EAAcgF,KAGlChQ,IAAAA,cAACua,EAAAA,EAAkBC,SAAQ,CAACjD,MAAOgC,IACjCvZ,IAAAA,cAAA,OACEmN,MAAM,OACNC,OAAO,OACP0C,IAAKgC,GACL2I,UAAWC,IAAW,OAAQ,CAAElI,YAAU1H,WAAUsN,WACpDuC,UAAW,GAEX3a,IAAAA,cAAA,YACG4X,GAAQvJ,KAAI,CAACuM,EAAQjH,IACpB3T,IAAAA,cAAC6a,EAAAA,EAAe,CACdC,IAAKnH,EACLhI,GAAI,GAAGmK,KAAenC,IACtBnM,KAAMoT,EAAOG,WACbC,YAAaJ,EAAOI,iBAI1Bhb,IAAAA,cAAA,KACEyM,UAAW,aAAaA,GAAUK,KAAKL,GAAUQ,YAAYR,GAAUO,MAEvEhN,IAAAA,cAAA,KAAGya,UAAWC,IAAW,QAAS,CAAE3P,qBACjCtC,GAAM4F,KAAKjG,GACVpI,IAAAA,cAACib,EAAAA,EAAa,CACZH,IAAK,GAAG1S,EAAKZ,SAAQ2S,EAAAA,EAAAA,IAAW/R,GAAQ,GAAGA,EAAK4G,UAAU5G,EAAKzB,SAAWyB,EAAKuD,KAC/EuP,4BACEf,EAAAA,EAAAA,IAAW/R,IAAgBgK,GAAiBjG,SAAS/D,EAAKuD,IAE5DvB,OAAQA,EACRC,cAAeA,EACfjC,KAAMA,EACNK,MAAOA,GACPgJ,SAAUA,GACVhH,kBAAmBA,EACnBF,kBAAmBA,EACnBkC,UAAWA,GACXiL,YAAaA,GACbI,gBAAiBA,GACjB7Q,aAAcA,GACdkO,eAAgBA,GAChBpK,gBAAiBA,EACjBuH,sBAAuBA,GACvB6I,4BAA6B5I,GAC7B6I,cAAelF,GACfmF,aAAcxE,GACdyE,eAAgBxE,GAChByE,cAAexE,GACf/G,qBAAsBA,GACtBO,kBAAmBA,GACnBC,sBAAuBA,GACvBgL,uBAAwBxE,GACxByE,kBAAmBrE,GACnBsE,iBAAkB/C,GAClBgD,iBAAkB1C,QAIxBjZ,IAAAA,cAAA,SACEA,IAAAA,cAAC4b,EAAAA,EAAoB,CACnB5I,iBAAkBA,GAClBvG,UAAWA,GACXoP,UAAW,GAAG/F,MACd0D,UAAW9E,MAGd5B,IACC9S,IAAAA,cAAA,QACE8M,EAAGgG,GAAUhG,EACbG,EAAG6F,GAAU7F,EACbE,MAAO2F,GAAU3F,MACjBC,OAAQ0F,GAAU1F,OAClB0O,KAAK,wBACLC,YAAa,GACbC,OAAO,wBACPC,gBAAiB,IAGpBtE,IACC3X,IAAAA,cAAA,SACEA,IAAAA,cAACkc,EAAAA,EAAyB,CACxBzP,UAAWA,GACXtB,aAAcA,EACdgR,QAASxE,KAEX3X,IAAAA,cAACoc,EAAAA,EAAoB,CACnB3T,MAAOA,GACPqP,gBAAiBA,GACjBrL,UAAWA,GACX0P,QAASxE,GACT0E,mBAAoB/J,MAI1BtS,IAAAA,cAAA,SACGgW,GAAW3H,KAAI,CAACiO,EAAM3I,IACrB3T,IAAAA,cAAA,QACE8a,IAAKnH,EACL4I,EAAG,IAAID,EAAK,GAAGE,KAAK,SAASF,EAAK,GAAGE,KAAK,OAC1CR,OAAO,0BACPF,KAAK,OACLW,YAAa,EAAIhQ,GAAUO,OAIjChN,IAAAA,cAAA,SACG2X,KACCK,cAAmB,EAAnBA,GAAqB3J,KAAKqO,GACxB1c,IAAAA,cAAC2c,EAAAA,EAAmB,CAClB7E,gBAAiBA,GACjBhO,MAAO2C,GAAUO,EACjBqP,mBAAoBK,EACpBvB,4BAA6B5I,GAC7BuI,IAAK,GAAG4B,EAAW1N,UAAU0N,EAAW/V,eAI/CgR,IACC3X,IAAAA,cAAC4c,EAAAA,EAAsB,CACrB3V,aAAcA,GACd6Q,gBAAiBA,GACjBhO,MAAO2C,GAAUO,EACjBqP,mBAAoB/J,GACpBuK,WAAY7J,OAKpBhT,IAAAA,cAAC8c,EAAAA,EAAgB,CACfC,WAAYlN,EAAKkN,WACjBjT,MAAO2C,GAAUO,EACjB9B,WAAYA,GACZ8R,aAAc1F,GACd2F,WAAYzN,KAIpB,CAEO,SAAS1B,KACd,MAAO,uCAAuCoP,QAAQ,SAAS,SAAU5G,GACvE,MAAM6G,EAAqB,GAAhBC,KAAKC,SAAiB,EAEjC,OADW,KAAL/G,EAAW6G,EAAS,EAAJA,EAAW,GACxBG,SAAS,GACpB,GACF,CAEA,SAAStE,GACPH,EACAhM,GAEA,IADA0Q,EAAM7Z,UAAAyK,OAAA,QAAAqP,IAAA9Z,UAAA,GAAAA,UAAA,GAAG,EAET,MAAM+Z,EAAUC,EAAAA,GACVC,EAAcF,EAAU,EAExBG,EACD/Q,EAAKC,EAAIyQ,EAAS,EAAII,EADrBC,EAED/Q,EAAKI,EAAIsQ,EAAS,EAAII,EAFrBC,EAGG/Q,EAAKM,MAAQoQ,EAASE,EAHzBG,EAII/Q,EAAKO,OAASmQ,EAASE,EAGjC,OAAO5E,EAAexK,KAAKwP,IAAC,CAC1B/Q,EAAG8Q,EAA6BC,EAAE/Q,EAAI8Q,EACtC3Q,EAAG2Q,EAA6BC,EAAE5Q,EAAI2Q,KAE1C,CAjyBCE,EAAAva,KAvDEwa,GAAAja,EAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAE,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAK,GAAAkX,GAAAtX,GAAAQ,GAAAO,GAAAwW,GAAA9W,GAAAC,GAAAG,GAAA2W,GAAA7W,GAAAK,GAAAE,GAAAuW,GAAAxW,GAAAE,GAAAE,GAAAqW,GAAAtW,GAAAE,GAAAM,GAAA+V,GAAApW,GAAAC,GAAAG,GAAAiW,GAAAnW,GAAAI,GAAAG,GAAA6V,GAAA/V,GAAAG,GAAAG,GAAA0V,GAAA5V,GAAAG,GAAAG,GAAAuV,GAAAzV,GAAAG,GAAAE,GAAAqV,GAAAtV,GAAAE,GAAAE,GAAAmV,GAAApV,GAAAE,GAAAE,GAAAiV,GAAAlV,GAAAE,GAAAG,GAAA8U,GAAAhV,GAAAhG,GAAAyS,GAAApW,GAAA4e,KAAAC,EAAAA,EAAAA,GAAAjB,EAAA,CA/XFpe,GAAc,iBAAkB,CAC/Bsf,WAAY,CAACC,EAAAA,EAAWC,EAAAA,MACxB,EAKCvf,GAAS,CAAEwf,WAAW,IAAQ,YAG9Bxf,GAAS,CAAE6H,KAAM4X,SAAS,aAG1Bzf,GAAS,CAAEwf,WAAW,IAAQ,oBAM9Bxf,GAAS,CAAEwf,WAAW,IAAQ,sBAG9Bxf,GAAS,CAAEwf,WAAW,IAAQ,wBAQ9Bxf,GAAS,CAAE6H,KAAM6X,SAAS,wBAW1B1f,GAAS,CAAEwf,WAAW,IAAQ,wBAY9Bxf,GAAS,CAAEwf,WAAW,IAAQ,uBAG9Bxf,GAAS,CAAEwf,WAAW,IAAQ,mBAM9Bxf,GAAS,CAAE6H,KAAM8X,UAAU,yBAG3B3f,GAAS,CAAE6H,KAAM8X,UAAU,eAG3B3f,GAAS,CAAE6H,KAAM8X,UAAU,iBAG3B3f,GAAS,CAAE6H,KAAM8X,UAAU,eAG3B3f,GAAS,CAAE6H,KAAM8X,UAAU,sBAW3B3f,KAAU,mBAUVA,KAAU,uBAGVA,GAAS,CAAEwf,WAAW,IAAQ,iBAG9Bxf,GAAS,CAAEwf,WAAW,IAAQ,mBAG9Bxf,GAAS,CAAEwf,WAAW,IAAQ,oBAM9Bxf,KAAU,wCAMVA,GAAS,CAAE6H,KAAM8X,UAAU,0CAG3Bzf,GAAM,CAAE2H,KAAM,wBAAwB,4BAAA+X,IAAAtV,EAAAA,EAAAA,GAAAxI,GAAA8d,GAAA,CAAAA,EAAArV,KAAAC,EAAAA,EAAAA,GAAA1I,GAAA8d,EAAArV,IAAA,CAgBtCrK,GAAM,CAAE2H,KAAM,cAAc,kBAAA+X,IAAAtV,EAAAA,EAAAA,GAAAnI,GAAAyd,GAAA,CAAAA,EAAArV,KAAAC,EAAAA,EAAAA,GAAArI,GAAAyd,EAAArV,IAAA,CAG5BrK,GAAM,CAAE2H,KAAM,cAAc,kBAAA+X,IAAAtV,EAAAA,EAAAA,GAAAlI,GAAAwd,GAAA,CAAAA,EAAArV,KAAAC,EAAAA,EAAAA,GAAApI,GAAAwd,EAAArV,IAAA,CAU5BrK,GAAM,CAAE2H,KAAM,eAAe,mBAAA+X,IAAAtV,EAAAA,EAAAA,GAAAhI,GAAAsd,GAAA,CAAAA,EAAArV,KAAAC,EAAAA,EAAAA,GAAAlI,GAAAsd,EAAArV,IAAA,CAO7BrK,GAAM,CAAE2H,KAAM,gBAAgB,oBAAA+X,IAAAtV,EAAAA,EAAAA,GAAA9H,GAAAod,GAAA,CAAAA,EAAArV,KAAAC,EAAAA,EAAAA,GAAAhI,GAAAod,EAAArV,IAAA,CAU9BrK,GAAM,CAAE2H,KAAM,gBAAgB,eAAA+X,IAAAtV,EAAAA,EAAAA,GAAA5H,GAAAkd,GAAA,CAAAA,EAAArV,KAAAC,EAAAA,EAAAA,GAAA9H,GAAAkd,EAAArV,IAAA,CAG9BrK,GAAM,CAAE2H,KAAM,gBAAgB,eAAA+X,IAAAtV,EAAAA,EAAAA,GAAA3H,GAAAid,GAAA,CAAAA,EAAArV,KAAAC,EAAAA,EAAAA,GAAA7H,GAAAid,EAAArV,IAAA,CAU9BrK,GAAM,CAAE2H,KAAM,iBAAiB,gBAAA+X,IAAAtV,EAAAA,EAAAA,GAAAzH,GAAA+c,GAAA,CAAAA,EAAArV,KAAAC,EAAAA,EAAAA,GAAA3H,GAAA+c,EAAArV,IAAA,CAO/BrK,GAAM,CAAE2H,KAAM,qBAAqB,oBAAA+X,IAAAtV,EAAAA,EAAAA,GAAAvH,GAAA6c,GAAA,CAAAA,EAAArV,KAAAC,EAAAA,EAAAA,GAAAzH,GAAA6c,EAAArV,IAAA,CAUnCrK,GAAM,CAAE2H,KAAM,aAAa,YAAA+X,IAAAtV,EAAAA,EAAAA,GAAArH,GAAA2c,GAAA,CAAAA,EAAArV,KAAAC,EAAAA,EAAAA,GAAAvH,GAAA2c,EAAArV,IAAA,CAO3BrK,GAAM,CAAE2H,KAAM,qBAAqB,mBAAA+X,IAAAtV,EAAAA,EAAAA,GAAAnH,GAAAyc,GAAA,CAAAA,EAAArV,KAAAC,EAAAA,EAAAA,GAAArH,GAAAyc,EAAArV,IAAA,CAOnCrK,GAAM,CAAE2H,KAAM,0BAA0B,wBAAA+X,IAAAtV,EAAAA,EAAAA,GAAAjH,GAAAuc,GAAA,CAAAA,EAAArV,KAAAC,EAAAA,EAAAA,GAAAnH,GAAAuc,EAAArV,IAAA,CAUxCrK,GAAM,CAAE2H,KAAM,0BAA0B,6BAAA+X,IAAAtV,EAAAA,EAAAA,GAAA/G,GAAAqc,GAAA,CAAAA,EAAArV,KAAAC,EAAAA,EAAAA,GAAAjH,GAAAqc,EAAArV,IAAA,CAUxCrK,GAAM,CAAE2H,KAAM,iBAAiB,gBAAA+X,IAAAtV,EAAAA,EAAAA,GAAA7G,GAAAmc,GAAA,CAAAA,EAAArV,KAAAC,EAAAA,EAAAA,GAAA/G,GAAAmc,EAAArV,IAAA,CAO/BtK,KAAQ,eAyCRA,KAAQ,oBAkCRA,KAAQ,eAsBRA,KAAQ,cAaRA,KAAQ,2BAKRA,KAAQ,kBAgBRA,KAAQ,kBAAA4f,GAAAlc,GAAA6U,KAAAsH,EAAAA,EAAAA,GAAAD,KA5WgBhc,EAAAA,mBAAgBsb,G","sources":["webpack:///./src/draw-canvas/index.tsx"],"sourcesContent":["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 { get, 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 NodePosition,\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 SmartConnectLineState,\n LineConnecterConf,\n Direction,\n LineEditorState,\n EdgeView,\n LineSettings,\n BaseEdgeCell,\n} from \"./interfaces\";\nimport { rootReducer } from \"./reducers\";\nimport { MarkerComponent } from \"../diagram/MarkerComponent\";\nimport {\n isContainerDecoratorCell,\n isEdgeCell,\n isEdgeSide,\n isNodeCell,\n isNodeOrAreaDecoratorCell,\n isTextDecoratorCell,\n} from \"./processors/asserts\";\nimport type {\n EdgeViewChangePayload,\n LineTuple,\n MoveCellPayload,\n ResizeCellPayload,\n} 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 DEFAULT_NODE_PADDING_FOR_SMART_LINES,\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 { getConnectPointsOfRectangle } from \"../shared/canvas/shapes/Rectangle\";\nimport { LineConnectorComponent } from \"./LineConnectorComponent\";\nimport { HoverStateContext, type HoverState } from \"./HoverStateContext\";\nimport { handleLasso } from \"./processors/handleLasso\";\nimport styleText from \"../shared/canvas/styles.shadow.css\";\nimport zoomBarStyleText from \"../shared/canvas/ZoomBarComponent.shadow.css\";\nimport { SmartConnectLineComponent } from \"./SmartConnectLineComponent\";\nimport { cellToTarget } from \"./processors/cellToTarget\";\nimport { handleNodeContainedChange } from \"./processors/handleNodeContainedChange\";\nimport { LineEditorComponent } from \"./LineEditorComponent\";\nimport { EditingLineComponent } from \"./EditingLineComponent\";\nimport { useEditableLineMap } from \"../shared/canvas/useEditableLineMap\";\nimport { targetIsActive } from \"./processors/targetIsActive\";\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 lineSettings?: LineSettings;\n lineConnector?: LineConnecterConf | boolean;\n allowEdgeToArea?: boolean;\n doNotResetActiveTargetOutsideCanvas?: boolean;\n doNotResetActiveTargetForSelector?: string;\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 /**\n * @default [100,20]\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` even 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 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 @property({ attribute: false })\n accessor lineSettings: LineSettings | undefined;\n\n @property({ attribute: false })\n accessor lineConnector: LineConnecterConf | boolean | undefined;\n\n /**\n * 选择器,点击该选择器对应的元素时不重置 `activeTarget`。\n */\n @property()\n accessor doNotResetActiveTargetForSelector: string | undefined;\n\n /**\n * 在画布外点击时不重置 `activeTarget`。\n */\n @property({ type: Boolean })\n accessor doNotResetActiveTargetOutsideCanvas: boolean | undefined;\n\n @event({ type: \"activeTarget.change\" })\n accessor #activeTargetChangeEvent!: EventEmitter<ActiveTarget | null>;\n\n #handleActiveTargetChange = (target: ActiveTarget | null) => {\n this.#activeTargetChangeEvent.emit(target);\n };\n\n #handleSwitchActiveTarget = (target: ActiveTarget | null) => {\n if (!sameTarget(target, this.activeTarget)) {\n this.activeTarget = target;\n }\n };\n\n /**\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 /**\n * 通过画布绘图的方式添加边(手动调用 `addEdge` 方法不会触发该事件)。\n */\n @event({ type: \"edge.add\" })\n accessor #edgeAdd!: EventEmitter<ConnectNodesDetail>;\n\n #handleEdgeAdd = (edge: ConnectNodesDetail) => {\n this.#edgeAdd.emit(edge);\n };\n\n @event({ type: \"edge.view.change\" })\n accessor #edgeViewChange!: EventEmitter<EdgeViewChangePayload>;\n\n #handleEdgeViewChange = (detail: EdgeViewChangePayload) => {\n this.#edgeViewChange.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 view: this.lineSettings!,\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 // istanbul ignore next\n @method()\n async reCenter() {\n this.#canvasRef.current?.reCenter();\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 lineSettings={this.lineSettings}\n lineConnector={this.lineConnector}\n allowEdgeToArea={this.allowEdgeToArea}\n doNotResetActiveTargetForSelector={\n this.doNotResetActiveTargetForSelector\n }\n doNotResetActiveTargetOutsideCanvas={\n this.doNotResetActiveTargetOutsideCanvas\n }\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 onEdgeAdd={this.#handleEdgeAdd}\n onCellContextMenu={this.#handleCellContextMenu}\n onDecoratorTextChange={this.#handleDecoratorTextChange}\n onContainerContainerChange={this.#handleContainerContainerChange}\n onScaleChange={this.#handleScaleChange}\n onEdgeViewChange={this.#handleEdgeViewChange}\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 onEdgeAdd(detail: ConnectNodesDetail): void;\n onEdgeViewChange(detail: EdgeViewChangePayload): 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 reCenter(): void;\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 lineSettings,\n lineConnector,\n allowEdgeToArea,\n doNotResetActiveTargetForSelector,\n doNotResetActiveTargetOutsideCanvas,\n onActiveTargetChange,\n onSwitchActiveTarget,\n onCellMove,\n onCellResize,\n onCellDelete,\n onCellsMove,\n onCellsDelete,\n onCellContextMenu,\n onEdgeAdd,\n onDecoratorTextChange,\n onScaleChange,\n onContainerContainerChange,\n onEdgeViewChange,\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 manualConnectDeferredRef = useRef<Deferred<ConnectNodesDetail> | null>(\n null\n );\n const [editingTexts, setEditingTexts] = useState<string[]>([]);\n const [activeContainers, setActiveContainers] = useState<string[]>([]);\n const [curActiveEditableEdge, setCurActiveEditableEdge] =\n useState<BaseEdgeCell | null>(null);\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 const reCenter = useCallback(() => {\n setCentered(false);\n }, [setCentered]);\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) => isEdgeSide(cell, allowEdgeToArea) && 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 reCenter,\n }),\n [\n cells,\n layout,\n scaleRange,\n setCentered,\n transform,\n allowEdgeToArea,\n reCenter,\n ]\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 (isEdgeSide(cell, allowEdgeToArea) && cell.id !== state.source.id) {\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 [allowEdgeToArea, cells]\n );\n const [smartConnectLineState, setSmartConnectLineState] =\n useState<SmartConnectLineState | null>(null);\n\n useEffect(() => {\n lockBodyScroll(\n host,\n !!(connectLineState || !!smartConnectLineState || lassoRect)\n );\n }, [connectLineState, host, smartConnectLineState, lassoRect]);\n\n const activeTarget = useActiveTarget({\n rootRef,\n activeTarget: _activeTarget,\n doNotResetActiveTargetForSelector,\n doNotResetActiveTargetOutsideCanvas,\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\n const [guideLines, setGuideLines] = useState<LineTuple[]>([]);\n\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 setGuideLines(info.flatMap((c) => c.guideLines ?? []));\n },\n [cells]\n );\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 setGuideLines([]);\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 const { lineConfMap, lineConnectorConf, markers } = useLineMarkers({\n cells,\n defaultEdgeLines,\n lineConnector,\n markerPrefix,\n });\n\n const editableLineMap = useEditableLineMap({ cells, lineConfMap });\n\n const activeEditableEdges = useMemo(() => {\n let edges: EdgeCell[] = [];\n edges = cells.filter(\n (cell) =>\n targetIsActive(cell, activeTarget) &&\n cell.type === \"edge\" &&\n editableLineMap.has(cell)\n ) as EdgeCell[];\n return edges;\n }, [activeTarget, cells, editableLineMap]);\n\n const ready = useReady({ cells, layout, centered });\n\n const [hoverState, setHoverState] = useState<HoverState | null>(null);\n const unsetHoverStateTimeoutRef = useRef<number | null>(null);\n\n const [lineEditorState, setLineEditorState] =\n useState<LineEditorState | null>(null);\n\n // istanbul ignore next\n const handleCellMouseEnter = useCallback(\n (cell: Cell) => {\n if (\n lineConnectorConf &&\n isEdgeSide(cell, allowEdgeToArea) &&\n (!lineEditorState || lineEditorState.type !== \"control\")\n ) {\n if (unsetHoverStateTimeoutRef.current !== null) {\n clearTimeout(unsetHoverStateTimeoutRef.current);\n unsetHoverStateTimeoutRef.current = null;\n }\n const relativePoints = getConnectPointsOfRectangle();\n setHoverState({\n cell,\n relativePoints,\n points: getConnectPoints(relativePoints, cell.view),\n });\n }\n },\n [allowEdgeToArea, lineConnectorConf, lineEditorState]\n );\n\n const handleCellMouseLeave = useCallback(\n (cell: Cell) => {\n if (lineConnectorConf && isNodeCell(cell)) {\n unsetHoverStateTimeoutRef.current = setTimeout(() => {\n setHoverState(null);\n }) as unknown as number;\n }\n },\n [lineConnectorConf]\n );\n\n // istanbul ignore next\n const handleSmartConnect = useCallback(\n (\n source: NodeCell | DecoratorCell,\n target: NodeCell | DecoratorCell,\n exitPosition: NodePosition,\n entryPosition: NodePosition | undefined\n ) => {\n const payload: EdgeViewChangePayload = {\n source: source.id,\n target: target.id,\n view: {\n ...lineSettings,\n exitPosition,\n entryPosition,\n vertices: null,\n },\n };\n const existedEdge = cells.find(\n (cell) =>\n cell.type === \"edge\" &&\n cell.source === source.id &&\n cell.target === target.id\n );\n if (existedEdge) {\n dispatch({\n type: \"change-edge-view\",\n payload,\n });\n onEdgeViewChange?.(payload);\n } else {\n const newEdge: EdgeCell = {\n type: \"edge\",\n ...payload,\n };\n dispatch({\n type: \"add-edge\",\n payload: newEdge,\n });\n onEdgeAdd({\n source,\n target,\n view: newEdge.view,\n });\n }\n },\n [cells, lineSettings, onEdgeAdd, onEdgeViewChange]\n );\n\n // istanbul ignore next\n const handleEdgeChangeView = useCallback(\n (\n source: NodeCell | DecoratorCell,\n target: NodeCell | DecoratorCell,\n view: EdgeView\n ) => {\n const payload: EdgeViewChangePayload = {\n source: source.id,\n target: target.id,\n view,\n };\n dispatch({\n type: \"change-edge-view\",\n payload,\n });\n onEdgeViewChange?.(payload);\n },\n [onEdgeViewChange]\n );\n\n // istanbul ignore next: experimental\n const hoverStateContextValue = useMemo(\n () => ({\n rootRef,\n smartConnectLineState,\n unsetHoverStateTimeoutRef,\n hoverState,\n activeEditableEdges,\n lineEditorState,\n setLineEditorState,\n setHoverState,\n setSmartConnectLineState,\n onConnect: handleSmartConnect,\n onChangeEdgeView: handleEdgeChangeView,\n }),\n [\n activeEditableEdges,\n handleEdgeChangeView,\n handleSmartConnect,\n hoverState,\n lineEditorState,\n smartConnectLineState,\n ]\n );\n useEffect(() => {\n const root = rootRef.current;\n if (!root || dragBehavior !== \"lasso\") {\n return;\n }\n const rootRect = root.getBoundingClientRect();\n // istanbul ignore next\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 | EdgeCell)[] = [];\n for (const cell of cells) {\n if (\n isContainerDecoratorCell(cell) ||\n isNodeOrAreaDecoratorCell(cell) ||\n isTextDecoratorCell(cell) ||\n isEdgeCell(cell)\n ) {\n const x = get(cell, \"view.x\", 0);\n const y = get(cell, \"view.y\", 0);\n const width = get(cell, \"view.width\", 0);\n const height = get(cell, \"view.height\", 0);\n if (\n x >= rect.x &&\n x + width <= rect.x + rect.width &&\n y >= rect.y &&\n y + 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\n return (\n <HoverStateContext.Provider value={hoverStateContextValue}>\n <svg\n width=\"100%\"\n height=\"100%\"\n ref={rootRef}\n className={classNames(\"root\", { grabbing, pannable, ready })}\n tabIndex={-1}\n >\n <defs>\n {markers.map((marker, index) => (\n <MarkerComponent\n key={index}\n id={`${markerPrefix}${index}`}\n type={marker.markerType}\n strokeColor={marker.strokeColor}\n />\n ))}\n </defs>\n <g\n transform={`translate(${transform.x} ${transform.y}) scale(${transform.k})`}\n >\n <g className={classNames(\"cells\", { allowEdgeToArea })}>\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 layoutOptions={layoutOptions}\n cell={cell}\n cells={cells}\n degraded={degraded}\n degradedNodeLabel={degradedNodeLabel}\n defaultNodeBricks={defaultNodeBricks}\n transform={transform}\n lineConfMap={lineConfMap}\n editableLineMap={editableLineMap}\n activeTarget={activeTarget}\n unrelatedCells={unrelatedCells}\n allowEdgeToArea={allowEdgeToArea}\n curActiveEditableEdge={curActiveEditableEdge}\n updateCurActiveEditableEdge={setCurActiveEditableEdge}\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 onCellMouseEnter={handleCellMouseEnter}\n onCellMouseLeave={handleCellMouseLeave}\n />\n ))}\n </g>\n <g>\n <ConnectLineComponent\n connectLineState={connectLineState}\n transform={transform}\n markerEnd={`${markerPrefix}0`}\n onConnect={handleConnect}\n />\n </g>\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 {lineConnectorConf && (\n <g>\n <SmartConnectLineComponent\n transform={transform}\n lineSettings={lineSettings}\n options={lineConnectorConf}\n />\n <EditingLineComponent\n cells={cells}\n editableLineMap={editableLineMap}\n transform={transform}\n options={lineConnectorConf}\n activeEditableEdge={curActiveEditableEdge}\n />\n </g>\n )}\n <g>\n {guideLines.map((line, index) => (\n <path\n key={index}\n d={`M${line[0].join(\" \")} L${line[1].join(\" \")}`}\n stroke=\"var(--palette-orange-5)\"\n fill=\"none\"\n strokeWidth={1 / transform.k}\n />\n ))}\n </g>\n <g>\n {lineConnectorConf &&\n activeEditableEdges?.map((activeEdge) => (\n <LineEditorComponent\n editableLineMap={editableLineMap}\n scale={transform.k}\n activeEditableEdge={activeEdge}\n updateCurActiveEditableEdge={setCurActiveEditableEdge}\n key={`${activeEdge.source}-${activeEdge.target}`}\n />\n ))}\n </g>\n {lineConnectorConf && (\n <LineConnectorComponent\n activeTarget={activeTarget}\n editableLineMap={editableLineMap}\n scale={transform.k}\n activeEditableEdge={curActiveEditableEdge}\n disabled={!!connectLineState}\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 </HoverStateContext.Provider>\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\nfunction getConnectPoints(\n relativePoints: ReadonlyArray<NodePosition>,\n view: NodeView,\n border = 1\n) {\n const padding = DEFAULT_NODE_PADDING_FOR_SMART_LINES;\n const halfPadding = padding / 2;\n\n const viewWithBorderAndPadding: NodeView = {\n x: view.x + border / 2 - halfPadding,\n y: view.y + border / 2 - halfPadding,\n width: view.width - border + padding,\n height: view.height - border + padding,\n };\n\n return relativePoints.map((p) => ({\n x: viewWithBorderAndPadding.x + p.x * viewWithBorderAndPadding.width,\n y: viewWithBorderAndPadding.y + p.y * viewWithBorderAndPadding.height,\n }));\n}\n"],"names":["lockBodyScroll","unwrapProvider","defineElement","property","method","event","createDecorators","EoDrawCanvasComponent","React","LegacyEoDrawCanvasComponent","_EoDrawCanvas","_A","WeakMap","_B","_C","_D","_E","_F","_G","_H","_I","_J","_K","_L","_M","_N","_O","_P","_Q","_R","_S","_T","_U","_V","_EoDrawCanvas_brand","WeakSet","_handleActiveTargetChange","_handleSwitchActiveTarget","_W","_X","_handleCellMove","_Y","_handleCellsMove","_Z","_handleCellResize","_a","_b","_handleCellDelete","_c","_handleCellsDelete","_d","_handleCellContextMenu","_e","_handleEdgeAdd","_f","_handleEdgeViewChange","_g","_handleDecoratorTextChange","_h","_handleContainerContainerChange","_i","_handleScaleChange","_canvasRef","EoDrawCanvas","ReactNextElement","constructor","arguments","_classPrivateMethodInitSpec","_classPrivateFieldInitSpec","_initProto","_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_allowEdgeToArea","_init_extra_allowEdgeToArea","_init_dragBehavior","_init_extra_dragBehavior","_init_ctrlDragBehavior","_init_extra_ctrlDragBehavior","_init_scaleRange","_init_extra_scaleRange","_init_lineSettings","_init_extra_lineSettings","_init_lineConnector","_init_extra_lineConnector","_init_doNotResetActiveTargetForSelector","_init_extra_doNotResetActiveTargetForSelector","_init_doNotResetActiveTargetOutsideCanvas","_init_extra_doNotResetActiveTargetOutsideCanvas","_init_activeTargetChangeEvent","_init_extra_activeTargetChangeEvent","target","_classPrivateGetter","this","_get_activeTargetChangeEvent","emit","sameTarget","activeTarget","_init_nodeMoveEvent","_init_extra_nodeMoveEvent","_init_cellMoveEvent","_init_extra_cellMoveEvent","info","_get_cellMoveEvent","type","_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","cell","_get_cellDelete","_get_nodeDelete","_init_cellsDelete","_init_extra_cellsDelete","cells","_get_cellsDelete","_init_cellContextMenu","_init_extra_cellContextMenu","detail","_get_cellContextMenu","_init_edgeAdd","_init_extra_edgeAdd","edge","_get_edgeAdd","_init_edgeViewChange","_init_extra_edgeViewChange","_get_edgeViewChange","_init_decoratorTextChange","_init_extra_decoratorTextChange","_get_decoratorTextChange","_init_containerContainerChange","_init_extra_containerContainerChange","_get_containerContainerChange","_init_scaleChange","_init_extra_scaleChange","scale","_get_scaleChange","createRef","_classPrivateFieldGet","v","_classPrivateFieldSet","layout","layoutOptions","defaultNodeSize","defaultNodeBricks","degradedThreshold","degradedNodeLabel","defaultEdgeLines","fadeUnrelatedCells","zoomable","scrollable","pannable","allowEdgeToArea","dragBehavior","ctrlDragBehavior","scaleRange","lineSettings","lineConnector","doNotResetActiveTargetForSelector","doNotResetActiveTargetOutsideCanvas","dropNode","_ref","_document$elementsFro","_document","id","position","size","data","useBrick","document","elementsFromPoint","call","includes","_size$","_size$2","_classPrivateFieldGet2","boundingClientRect","getBoundingClientRect","transform","current","getTransform","newNode","view","x","left","k","y","top","width","height","dropDecorator","_ref2","_document$elementsFro2","_document2","decorator","text","direction","_classPrivateFieldGet3","newDecorator","uuidV4","DEFAULT_AREA_WIDTH","DEFAULT_AREA_HEIGHT","addNodes","nodes","length","newNodes","map","_ref3","_size$3","_size$4","canvasWidth","clientWidth","canvasHeight","clientHeight","addEdge","_ref4","_classPrivateFieldGet4","source","newEdge","manuallyConnectNodes","updateCells","ctx","_assertClassBrand","_waitForCanvasRef","updated","reCenter","_classPrivateFieldGet5","disconnectedCallback","super","render","host","ref","onActiveTargetChange","onSwitchActiveTarget","onCellMove","onCellsMove","onCellResize","onCellDelete","onCellsDelete","onEdgeAdd","onCellContextMenu","onDecoratorTextChange","onContainerContainerChange","onScaleChange","onEdgeViewChange","Promise","resolve","check","setTimeout","_ref5","initialCells","_activeTarget","_scaleRange","layoutKey","dispatch","useReducer","rootReducer","initializeCells","degraded","useMemo","filter","isNodeCell","DEFAULT_DEGRADED_THRESHOLD","rootRef","useRef","manualConnectDeferredRef","editingTexts","setEditingTexts","useState","activeContainers","setActiveContainers","curActiveEditableEdge","setCurActiveEditableEdge","grabbing","zoomer","useZoom","draggable","ctrlDraggable","useEffect","lassoRect","setLassoRect","connectLineState","setConnectLineState","centered","setCentered","getNextLayoutKey","useLayout","useCallback","useImperativeHandle","node","payload","_ref6","index","findLastIndex","newCells","slice","allCells","shouldReCenter","previousCells","result","sourceId","find","isEdgeSide","rect","from","offset","reject","handleConnect","state","to","_manualConnectDeferre2","i","_manualConnectDeferre","smartConnectLineState","setSmartConnectLineState","useActiveTarget","unrelatedCells","setUnrelatedCells","nextUnrelated","getUnrelatedCells","prev","root","onKeydown","action","handleKeyboard","addEventListener","removeEventListener","markerPrefix","uniqueId","guideLines","setGuideLines","handleCellsMoving","containedIds","handleNodeContainedChange","forEach","c","_c$containerCell","_c$containerCell2","containerCell","push","flatMap","_c$guideLines","handleCellsMoved","handleCellResizing","handleCellResized","handleDecoratorTextEditing","_ref7","editing","texts","handleNodeBrickResize","nextLayoutKey","handleZoomSlide","value","scaleTo","select","lineConfMap","lineConnectorConf","markers","useLineMarkers","editableLineMap","useEditableLineMap","activeEditableEdges","edges","targetIsActive","has","ready","useReady","hoverState","setHoverState","unsetHoverStateTimeoutRef","lineEditorState","setLineEditorState","handleCellMouseEnter","clearTimeout","relativePoints","getConnectPointsOfRectangle","points","getConnectPoints","handleCellMouseLeave","handleSmartConnect","exitPosition","entryPosition","vertices","handleEdgeChangeView","hoverStateContextValue","onConnect","onChangeEdgeView","rootRect","onMouseDown","handleLasso","onLassoing","onLassoed","lassoedCells","isContainerDecoratorCell","isNodeOrAreaDecoratorCell","isTextDecoratorCell","isEdgeCell","get","targets","cellToTarget","HoverStateContext","Provider","className","classNames","tabIndex","marker","MarkerComponent","key","markerType","strokeColor","CellComponent","dragNodeToContainerActive","updateCurActiveEditableEdge","onCellsMoving","onCellsMoved","onCellResizing","onCellResized","onDecoratorTextEditing","onNodeBrickResize","onCellMouseEnter","onCellMouseLeave","ConnectLineComponent","markerEnd","fill","fillOpacity","stroke","strokeDasharray","SmartConnectLineComponent","options","EditingLineComponent","activeEditableEdge","line","d","join","strokeWidth","activeEdge","LineEditorComponent","LineConnectorComponent","disabled","ZoomBarComponent","shadowRoot","onZoomChange","onReCenter","replace","r","Math","random","toString","border","undefined","padding","DEFAULT_NODE_PADDING_FOR_SMART_LINES","halfPadding","viewWithBorderAndPadding","p","_EoDrawCanvas2","e","_set_activeTargetChangeEvent","_set_nodeMoveEvent","_set_cellMoveEvent","_set_cellsMoveEvent","_set_cellResizeEvent","_set_nodeDelete","_set_cellDelete","_set_cellsDelete","_set_cellContextMenu","_set_edgeAdd","_set_edgeViewChange","_set_decoratorTextChange","_set_containerContainerChange","_set_scaleChange","_initClass","_applyDecs","styleTexts","styleText","zoomBarStyleText","attribute","String","Number","Boolean","o","_","_checkInRHS"],"sourceRoot":""}
|