@next-bricks/diagram 0.43.0 → 0.43.2
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 +1 -1
- package/dist/chunks/3025.d4a92d85.js +3 -0
- package/dist/chunks/{3025.6d94cc70.js.map → 3025.d4a92d85.js.map} +1 -1
- package/dist/chunks/{3171.633b30e8.js → 3171.2943688e.js} +2 -2
- package/dist/chunks/{3171.633b30e8.js.map → 3171.2943688e.js.map} +1 -1
- package/dist/chunks/3233.4eabc5cc.js +3 -0
- package/dist/chunks/{3233.70157b34.js.map → 3233.4eabc5cc.js.map} +1 -1
- package/dist/chunks/3252.d94ce52c.js +2 -0
- package/dist/chunks/{3252.0a5098f4.js.map → 3252.d94ce52c.js.map} +1 -1
- package/dist/chunks/{3933.fca8ae82.js → 3933.6624dcbe.js} +2 -2
- package/dist/chunks/{3933.fca8ae82.js.map → 3933.6624dcbe.js.map} +1 -1
- package/dist/chunks/{4837.44f22425.js → 4837.578ffe7d.js} +2 -2
- package/dist/chunks/{7218.6822e904.js.map → 4837.578ffe7d.js.map} +1 -1
- package/dist/chunks/{5552.ad11237e.js → 5552.e3e4dddb.js} +2 -2
- package/dist/chunks/{5552.ad11237e.js.map → 5552.e3e4dddb.js.map} +1 -1
- package/dist/chunks/{6314.f35cc928.js → 6314.2c1f22e1.js} +2 -2
- package/dist/chunks/{6314.f35cc928.js.map → 6314.2c1f22e1.js.map} +1 -1
- package/dist/chunks/{7218.6822e904.js → 7218.0b7934fd.js} +2 -2
- package/dist/chunks/{4837.44f22425.js.map → 7218.0b7934fd.js.map} +1 -1
- package/dist/chunks/{799.5e6749ba.js → 799.dd5f32fb.js} +3 -3
- package/dist/chunks/799.dd5f32fb.js.map +1 -0
- package/dist/chunks/{9711.d7bd00df.js → 9711.2d99e6d9.js} +2 -2
- package/dist/chunks/{9711.d7bd00df.js.map → 9711.2d99e6d9.js.map} +1 -1
- package/dist/chunks/{eo-display-canvas.f874fb2f.js → eo-display-canvas.2b754ef1.js} +2 -2
- package/dist/chunks/{eo-display-canvas.f874fb2f.js.map → eo-display-canvas.2b754ef1.js.map} +1 -1
- package/dist/chunks/{eo-draw-canvas.84ade234.js → eo-draw-canvas.79b100f8.js} +2 -2
- package/dist/chunks/{eo-draw-canvas.84ade234.js.map → eo-draw-canvas.79b100f8.js.map} +1 -1
- package/dist/chunks/main.1a8affb8.js +2 -0
- package/dist/chunks/{main.9e233da7.js.map → main.1a8affb8.js.map} +1 -1
- package/dist/index.05f1b5e3.js +2 -0
- package/dist/{index.d6687c6f.js.map → index.05f1b5e3.js.map} +1 -1
- package/package.json +3 -3
- package/dist/chunks/3025.6d94cc70.js +0 -3
- package/dist/chunks/3233.70157b34.js +0 -3
- package/dist/chunks/3252.0a5098f4.js +0 -2
- package/dist/chunks/799.5e6749ba.js.map +0 -1
- package/dist/chunks/main.9e233da7.js +0 -2
- package/dist/index.d6687c6f.js +0 -2
- /package/dist/chunks/{3025.6d94cc70.js.LICENSE.txt → 3025.d4a92d85.js.LICENSE.txt} +0 -0
- /package/dist/chunks/{3233.70157b34.js.LICENSE.txt → 3233.4eabc5cc.js.LICENSE.txt} +0 -0
- /package/dist/chunks/{799.5e6749ba.js.LICENSE.txt → 799.dd5f32fb.js.LICENSE.txt} +0 -0
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";(globalThis.webpackChunk_next_bricks_diagram=globalThis.webpackChunk_next_bricks_diagram||[]).push([[8939],{9068:(e,t,a)=>{a.r(t),a.d(t,{EoDrawCanvas:()=>Dt,EoDrawCanvasComponent:()=>Lt,uuidV4:()=>Sa});var n,l=a(4635),i=a(918),s=a(6902),o=a(2559),r=a(5536),d=a(6121),h=a(829),c=a(2740),u=a(8769),g=a.n(u),p=a(4799),A=a(8610),v=a(5701),y=(a(6477),a(1030)),f=a(3373),C=a.n(f),m=a(7566),w=a(5748),k=a(3739),b=a(531),x=a(8185),M=a(5114),E=a(4932),N=a(3639),T=a(3783),W=a(2098),S=a(227),R=a(3033),z=a(8091),B=a(1819),L=a(7099),D=a(1484),P=a(8197),H=a(7531),$=a(8875),O=a(2722),_=a(9978),j=a(2219),U=a(3012),K=a(6237),I=a(1103),F=a(9386),Y=a(1991);let q,G,J,V,X,Z,Q,ee,te,ae,ne,le,ie,se,oe,re,de,he,ce,ue,ge,pe,Ae,ve,ye,fe,Ce,me,we,ke,be,xe,Me,Ee,Ne,Te,We,Se,Re,ze,Be,Le,De,Pe,He,$e,Oe,_e,je,Ue,Ke,Ie,Fe,Ye,qe,Ge,Je,Ve,Xe,Ze,Qe,et,tt,at,nt,lt,it,st,ot,rt,dt,ht,ct,ut,gt,pt,At,vt,yt,ft,Ct,mt,wt,kt,bt,xt,Mt,Et,Nt,Tt;const Wt=(0,v.unwrapProvider)("basic.lock-body-scroll"),{defineElement:St,property:Rt,method:zt,event:Bt}=(0,p.createDecorators)(),Lt=g().forwardRef(Wa);let Dt;var Pt=new WeakMap,Ht=new WeakMap,$t=new WeakMap,Ot=new WeakMap,_t=new WeakMap,jt=new WeakMap,Ut=new WeakMap,Kt=new WeakMap,It=new WeakMap,Ft=new WeakMap,Yt=new WeakMap,qt=new WeakMap,Gt=new WeakMap,Jt=new WeakMap,Vt=new WeakMap,Xt=new WeakMap,Zt=new WeakMap,Qt=new WeakMap,ea=new WeakMap,ta=new WeakSet,aa=new WeakMap,na=new WeakMap,la=new WeakMap,ia=new WeakMap,sa=new WeakMap,oa=new WeakMap,ra=new WeakMap,da=new WeakMap,ha=new WeakMap,ca=new WeakMap,ua=new WeakMap,ga=new WeakMap,pa=new WeakMap,Aa=new WeakMap,va=new WeakMap,ya=new WeakMap,fa=new WeakMap,Ca=new WeakMap,ma=new WeakMap,wa=new WeakMap,ka=new WeakMap,ba=new WeakMap,xa=new WeakMap,Ma=new WeakMap,Ea=new WeakMap;class Na extends A.ReactNextElement{constructor(){super(...arguments),(0,l.A)(this,ta),(0,i.A)(this,Pt,(q(this),J(this))),(0,i.A)(this,Ht,(V(this),X(this))),(0,i.A)(this,$t,(Z(this),Q(this))),(0,i.A)(this,Ot,(ee(this),te(this,[R.HP,R.HP]))),(0,i.A)(this,_t,(ae(this),ne(this))),(0,i.A)(this,jt,(le(this),ie(this))),(0,i.A)(this,Ut,(se(this),oe(this))),(0,i.A)(this,Kt,(re(this),de(this))),(0,i.A)(this,It,(he(this),ce(this))),(0,i.A)(this,Ft,(ue(this),ge(this))),(0,i.A)(this,Yt,(pe(this),Ae(this,!0))),(0,i.A)(this,qt,(ve(this),ye(this,!0))),(0,i.A)(this,Gt,(fe(this),Ce(this,!0))),(0,i.A)(this,Jt,(me(this),we(this,!1))),(0,i.A)(this,Vt,(ke(this),be(this))),(0,i.A)(this,Xt,(xe(this),Me(this))),(0,i.A)(this,Zt,(Ee(this),Ne(this))),(0,i.A)(this,Qt,(Te(this),We(this))),(0,i.A)(this,ea,(Se(this),Re(this))),(0,i.A)(this,aa,(Le(this),e=>{(0,r.A)(ta,this,ze).emit(e)})),(0,i.A)(this,na,(e=>{(0,x.c)(e,this.activeTarget)||(this.activeTarget=e)})),(0,i.A)(this,la,De(this)),(0,i.A)(this,ia,($e(this),Oe(this))),(0,i.A)(this,sa,(Ue(this),e=>{(0,r.A)(ta,this,_e).emit(e),"node"===e.type&&(0,r.A)(ta,this,Pe).emit(e)})),(0,i.A)(this,oa,Ke(this)),(0,i.A)(this,ra,(Ye(this),e=>{(0,r.A)(ta,this,Ie).emit(e)})),(0,i.A)(this,da,qe(this)),(0,i.A)(this,ha,(Ve(this),e=>{(0,r.A)(ta,this,Ge).emit(e)})),(0,i.A)(this,ca,Xe(this)),(0,i.A)(this,ua,(et(this),tt(this))),(0,i.A)(this,ga,(lt(this),e=>{(0,r.A)(ta,this,at).emit(e),"node"===e.type&&(0,r.A)(ta,this,Ze).emit(e)})),(0,i.A)(this,pa,it(this)),(0,i.A)(this,Aa,(rt(this),e=>{(0,r.A)(ta,this,st).emit(e)})),(0,i.A)(this,va,dt(this)),(0,i.A)(this,ya,(ut(this),e=>{(0,r.A)(ta,this,ht).emit(e)})),(0,i.A)(this,fa,gt(this)),(0,i.A)(this,Ca,(vt(this),e=>{(0,r.A)(ta,this,pt).emit(e)})),(0,i.A)(this,ma,yt(this)),(0,i.A)(this,wa,(mt(this),e=>{(0,r.A)(ta,this,ft).emit(e)})),(0,i.A)(this,ka,wt(this)),(0,i.A)(this,ba,(xt(this),e=>{(0,r.A)(ta,this,kt).emit(e)})),(0,i.A)(this,xa,Mt(this)),(0,i.A)(this,Ma,(Tt(this),e=>{(0,r.A)(ta,this,Et).emit(e)})),(0,i.A)(this,Ea,(0,u.createRef)())}get cells(){return(0,h.A)(Pt,this)}set cells(e){(0,d.A)(Pt,this,e)}get layout(){return(0,h.A)(Ht,this)}set layout(e){(0,d.A)(Ht,this,e)}get layoutOptions(){return(0,h.A)($t,this)}set layoutOptions(e){(0,d.A)($t,this,e)}get defaultNodeSize(){return(0,h.A)(Ot,this)}set defaultNodeSize(e){(0,d.A)(Ot,this,e)}get defaultNodeBricks(){return(0,h.A)(_t,this)}set defaultNodeBricks(e){(0,d.A)(_t,this,e)}get degradedThreshold(){return(0,h.A)(jt,this)}set degradedThreshold(e){(0,d.A)(jt,this,e)}get degradedNodeLabel(){return(0,h.A)(Ut,this)}set degradedNodeLabel(e){(0,d.A)(Ut,this,e)}get defaultEdgeLines(){return(0,h.A)(Kt,this)}set defaultEdgeLines(e){(0,d.A)(Kt,this,e)}get activeTarget(){return(0,h.A)(It,this)}set activeTarget(e){(0,d.A)(It,this,e)}get fadeUnrelatedCells(){return(0,h.A)(Ft,this)}set fadeUnrelatedCells(e){(0,d.A)(Ft,this,e)}get zoomable(){return(0,h.A)(Yt,this)}set zoomable(e){(0,d.A)(Yt,this,e)}get scrollable(){return(0,h.A)(qt,this)}set scrollable(e){(0,d.A)(qt,this,e)}get pannable(){return(0,h.A)(Gt,this)}set pannable(e){(0,d.A)(Gt,this,e)}get allowEdgeToArea(){return(0,h.A)(Jt,this)}set allowEdgeToArea(e){(0,d.A)(Jt,this,e)}get dragBehavior(){return(0,h.A)(Vt,this)}set dragBehavior(e){(0,d.A)(Vt,this,e)}get ctrlDragBehavior(){return(0,h.A)(Xt,this)}set ctrlDragBehavior(e){(0,d.A)(Xt,this,e)}get scaleRange(){return(0,h.A)(Zt,this)}set scaleRange(e){(0,d.A)(Zt,this,e)}get lineConnector(){return(0,h.A)(Qt,this)}set lineConnector(e){(0,d.A)(Qt,this,e)}async dropNode(e){var t,a;let{id:n,position:l,size:i,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;const e=this.getBoundingClientRect(),t=(0,h.A)(Ea,this).current.getTransform(),a={type:"node",id:n,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==i?void 0:i[0])??this.defaultNodeSize[0],height:(null==i?void 0:i[1])??this.defaultNodeSize[0]},data:s,useBrick:o};return null===(r=(0,h.A)(Ea,this).current)||void 0===r||r.dropNode(a),a}return null}async dropDecorator(e){var t,a;let{position:n,decorator:l,text:i,direction:s}=e;if(null===(t=(a=document).elementsFromPoint)||void 0===t||null===(t=t.call(a,n[0],n[1]))||void 0===t?void 0:t.includes(this)){var o;const e=this.getBoundingClientRect(),t=(0,h.A)(Ea,this).current.getTransform(),a={type:"decorator",decorator:l,id:Sa(),view:{x:(n[0]-e.left-t.x)/t.k,y:(n[1]-e.top-t.y)/t.k,width:R.N8,height:R.w1,text:i,direction:s}};return null===(o=(0,h.A)(Ea,this).current)||void 0===o||o.dropDecorator(a),a}return null}async addNodes(e){if(0===e.length)return[];const t=e.map((e=>{let{size:t,useBrick:a,id:n,data:l}=e;return{type:"node",id:n,data:l,view:{width:(null==t?void 0:t[0])??this.defaultNodeSize[0],height:(null==t?void 0:t[1])??this.defaultNodeSize[0]},useBrick:a}}));return(0,h.A)(Ea,this).current.addNodes(t,{defaultNodeSize:this.defaultNodeSize,canvasWidth:this.clientWidth,canvasHeight:this.clientHeight})}async addEdge(e){var t;let{source:a,target:n,data:l}=e;const i={type:"edge",source:a,target:n,data:l};return null===(t=(0,h.A)(Ea,this).current)||void 0===t||t.addEdge(i),i}manuallyConnectNodes(e){return(0,h.A)(Ea,this).current.manuallyConnectNodes(e)}async updateCells(e,t){await(0,o.A)(ta,this,Ta).call(this);const{updated:a}=(0,h.A)(Ea,this).current.updateCells(e,{...t,defaultNodeSize:this.defaultNodeSize,canvasWidth:this.clientWidth,canvasHeight:this.clientHeight});return{updated:a}}disconnectedCallback(){super.disconnectedCallback(),Wt(this,!1)}render(){return g().createElement(Lt,{host:this,ref:(0,h.A)(Ea,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,lineConnector:this.lineConnector,allowEdgeToArea:this.allowEdgeToArea,onActiveTargetChange:(0,h.A)(aa,this),onSwitchActiveTarget:(0,h.A)(na,this),onCellMove:(0,h.A)(sa,this),onCellsMove:(0,h.A)(ra,this),onCellResize:(0,h.A)(ha,this),onCellDelete:(0,h.A)(ga,this),onCellsDelete:(0,h.A)(Aa,this),onEdgeAdd:(0,h.A)(Ca,this),onCellContextMenu:(0,h.A)(ya,this),onDecoratorTextChange:(0,h.A)(wa,this),onContainerContainerChange:(0,h.A)(ba,this),onScaleChange:(0,h.A)(Ma,this)})}}function Ta(){return new Promise((e=>{const t=()=>{(0,h.A)(Ea,this).current?e():setTimeout(t,10)};t()}))}function Wa(e,t){let{host:a,layout:n,layoutOptions:l,cells:i,defaultNodeSize:s,defaultNodeBricks:o,defaultEdgeLines:r,degradedThreshold:d,degradedNodeLabel:h,activeTarget:c,fadeUnrelatedCells:p,zoomable:A,scrollable:f,pannable:x,dragBehavior:U,ctrlDragBehavior:K,scaleRange:q,lineConnector:G,allowEdgeToArea:J,onActiveTargetChange:V,onSwitchActiveTarget:X,onCellMove:Z,onCellResize:Q,onCellDelete:ee,onCellsMove:te,onCellsDelete:ae,onCellContextMenu:ne,onEdgeAdd:le,onDecoratorTextChange:ie,onScaleChange:se,onContainerContainerChange:oe}=e;const[{cells:re,layoutKey:de},he]=(0,u.useReducer)(w.d,i,(e=>({cells:(0,T.C)(e,{defaultNodeSize:s}),layoutKey:0}))),ce=(0,u.useMemo)((()=>re.filter(b.N).length>=(d??R.pC)),[re,d]),ue=(0,u.useRef)(null),ge=(0,u.useRef)(null),pe=(0,u.useRef)(null),[Ae,ve]=(0,u.useState)([]),[ye,fe]=(0,u.useState)([]),{grabbing:Ce,transform:me,zoomer:we,scaleRange:ke}=(0,z.f)({rootRef:ue,zoomable:A,scrollable:f,pannable:x,draggable:"grab"===U,ctrlDraggable:"grab"===K,scaleRange:q,onSwitchActiveTarget:X});(0,u.useEffect)((()=>{se(me.k)}),[se,me.k]);const[be,xe]=(0,u.useState)(null),[Me,Ee]=(0,u.useState)(null),{centered:Ne,setCentered:Te,getNextLayoutKey:We}=(0,D.g)({layout:n,layoutOptions:l,rootRef:ue,cells:re,zoomable:A,zoomer:we,scaleRange:ke,layoutKey:de,allowEdgeToArea:J,dispatch:he});(0,u.useImperativeHandle)(t,(()=>({dropNode(e){"dagre"!==n&&"force"!==n&&Te(!0),he({type:"drop-node",payload:e})},dropDecorator(e){"dagre"!==n&&"force"!==n&&Te(!0),he({type:"drop-decorator",payload:e})},addNodes(e,t){let{defaultNodeSize:a,canvasWidth:l,canvasHeight:i}=t;const s=re.findLastIndex((e=>!("decorator"===e.type&&"text"===e.decorator)))+1,o=[...re.slice(0,s),...e,...re.slice(s)],{cells:r,updated:d,shouldReCenter:h}=(0,W.L)({cells:o,layout:n,previousCells:re,defaultNodeSize:a,canvasWidth:l,canvasHeight:i,scaleRange:ke,transform:me,allowEdgeToArea:J});return h&&Te(!1),he({type:"update-cells",payload:r}),d.filter((t=>e.includes(t)))},addEdge(e){he({type:"add-edge",payload:e})},updateCells(e,t){const{shouldReCenter:a,...l}=(0,W.L)({...t,layout:n,previousCells:re,cells:e,scaleRange:ke,transform:me,allowEdgeToArea:J});return a&&Te(!1),he({type:"update-cells",payload:l.cells}),l},getTransform:()=>me,manuallyConnectNodes(e){const t=re.find((t=>(J&&(0,b.o6)(t)||(0,b.N)(t))&&t.id===e));if(t){const e=ue.current.getBoundingClientRect();return Ee({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)=>{pe.current={resolve:e,reject:t}}))}return Promise.reject(null)}})),[re,n,ke,Te,me,J]);const Se=(0,u.useCallback)(((e,t)=>{var a;for(let a=re.length-1;a>=0;a--){const l=re[a];if((J&&(0,b.o6)(l)||(0,b.N)(l))&&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 n;null===(n=pe.current)||void 0===n||n.resolve({source:e.source,target:l});break}}null===(a=pe.current)||void 0===a||a.reject(null),Ee(null)}),[re]),[Re,ze]=(0,u.useState)(null);(0,u.useEffect)((()=>{Wt(a,!!(Me||Re||be))}),[Me,a,Re,be]);const Be=(0,B.J)({cellsRef:ge,activeTarget:c,onActiveTargetChange:V}),[Le,De]=(0,u.useState)([]);(0,u.useEffect)((()=>{const e=p?(0,S.Y)(re,Me,Be,J):[];De((t=>0===t.length&&0===e.length?t:e))}),[Be,re,Me,p,J]),(0,u.useEffect)((()=>{const e=ue.current;if(!e||Ae.length>0)return;const t=e=>{const t=(0,M.a)(e,{cells:re,activeTarget:Be});"delete-cells"===(null==t?void 0:t.action)&&(ae(t.cells),1===t.cells.length&&ee(t.cells[0]))};return e.addEventListener("keydown",t),()=>{e.removeEventListener("keydown",t)}}),[Be,re,Ae.length,ee,ae]);const Pe=`${(0,u.useMemo)((()=>`${(0,y.uniqueId)("diagram-")}-`),[])}line-arrow-`,[He,$e]=(0,u.useState)([]),Oe=(0,u.useCallback)((e=>{he({type:"move-cells",payload:e});const t=[];(0,Y._)(e,re).forEach((e=>{var a,n;null!==(a=e.containerCell)&&void 0!==a&&a.id&&t.push(null===(n=e.containerCell)||void 0===n?void 0:n.id)})),fe(t),$e(e.flatMap((e=>e.guideLines??[])))}),[re]),_e=(0,u.useCallback)((e=>{he({type:"move-cells",payload:e}),te(e),1===e.length&&Z(e[0]),(0,Y._)(e,re,oe),fe([]),$e([])}),[Z,te,re,oe]),je=(0,u.useCallback)((e=>{he({type:"resize-cell",payload:e})}),[]),Ue=(0,u.useCallback)((e=>{he({type:"resize-cell",payload:e}),Q(e)}),[Q]),Ke=(0,u.useCallback)((e=>{let{id:t,editing:a}=e;ve(a?e=>e.includes(t)?e:[...e,t]:e=>e.filter((e=>e!==t)))}),[]),Ie=(0,u.useCallback)(((e,t)=>{const a=We();he({type:"update-node-size",payload:{id:e,size:t},layoutKey:a})}),[We]),Fe=(0,u.useCallback)((e=>{we.scaleTo((0,m.A)(ue.current),e/100)}),[we]),Ye=(0,u.useCallback)((()=>{Te(!1)}),[Te]),{lineConfMap:qe,lineConnectorConf:Ge,markers:Je}=(0,H.d)({cells:re,defaultEdgeLines:r,lineConnector:G,markerPrefix:Pe}),Ve=(0,P.H)({cells:re,layout:n,centered:Ne}),[Xe,Ze]=(0,u.useState)(null),Qe=(0,u.useRef)(null),et=(0,u.useCallback)((e=>{if(Ge&&(0,b.N)(e)){null!==Qe.current&&(clearTimeout(Qe.current),Qe.current=null);const t=(0,$.G)();Ze({cell:e,relativePoints:t,points:Ra(t,e.view)})}}),[Ge]),tt=(0,u.useCallback)((e=>{Ge&&(0,b.N)(e)&&(Qe.current=setTimeout((()=>{Ze(null)})))}),[Ge]),at=(0,u.useMemo)((()=>({rootRef:ue,smartConnectLineState:Re,unsetHoverStateTimeoutRef:Qe,hoverState:Xe,setHoverState:Ze,setSmartConnectLineState:ze,onConnect(e,t,a,n){const l={type:"edge",source:e.id,target:t.id,view:{exitPosition:a,entryPosition:n,...(0,v.isObject)(G)?G:null}};he({type:"add-edge",payload:l}),le(l)}})),[Re,Xe,G,le]);return(0,u.useEffect)((()=>{const e=ue.current;if(!e||"lasso"!==U)return;const t=e.getBoundingClientRect(),a=e=>{(0,j.F)(e,{transform:me,offset:[t.left,t.top],onLassoing(e){xe(e)},onLassoed(e){xe(null);const t=[];for(const a of re)if((0,b.t2)(a)||(0,b.o6)(a)||(0,b.Hs)(a)){const n=a.view.x,l=a.view.y;n>=e.x&&n+a.view.width<=e.x+e.width&&l>=e.y&&l+a.view.height<=e.y+e.height&&t.push(a)}null==X||X(t.length>1?{type:"multi",targets:t.map(F.P)}:1===t.length?(0,F.P)(t[0]):null)}})};return e.addEventListener("mousedown",a),()=>{e.removeEventListener("mousedown",a)}}),[me,re,U,X]),g().createElement(_.H.Provider,{value:at},g().createElement("svg",{width:"100%",height:"100%",ref:ue,className:C()("root",{grabbing:Ce,pannable:x,ready:Ve}),tabIndex:-1},g().createElement("defs",null,Je.map(((e,t)=>g().createElement(k.c,{key:t,id:`${Pe}${t}`,type:"arrow",strokeColor:e.strokeColor})))),g().createElement("g",{transform:`translate(${me.x} ${me.y}) scale(${me.k})`},g().createElement("g",{className:C()("cells",{allowEdgeToArea:J}),ref:ge},re.map((e=>g().createElement(E.m,{key:`${e.type}:${(0,b.WW)(e)?`${e.source}~${e.target}`:e.id}`,dragNodeToContainerActive:!(0,b.WW)(e)&&ye.includes(e.id),layout:n,layoutOptions:l,cell:e,cells:re,degraded:ce,degradedNodeLabel:h,defaultNodeBricks:o,transform:me,lineConfMap:qe,activeTarget:Be,unrelatedCells:Le,onCellsMoving:Oe,onCellsMoved:_e,onCellResizing:je,onCellResized:Ue,onSwitchActiveTarget:X,onCellContextMenu:ne,onDecoratorTextChange:ie,onDecoratorTextEditing:Ke,onNodeBrickResize:Ie,onCellMouseEnter:et,onCellMouseLeave:tt})))),g().createElement(N.w,{connectLineState:Me,transform:me,markerEnd:`${Pe}0`,onConnect:Se}),be&&g().createElement("rect",{x:be.x,y:be.y,width:be.width,height:be.height,fill:"var(--palette-gray-5)",fillOpacity:.3,stroke:"var(--palette-gray-5)",strokeDasharray:2}),Ge&&g().createElement(I.X,{smartConnectLineState:Re,transform:me,options:Ge}),He.map(((e,t)=>g().createElement("path",{key:t,d:`M${e[0].join(" ")} L${e[1].join(" ")}`,stroke:"var(--palette-orange-5)",fill:"none"})))),Ge&&g().createElement(O.T,{activeTarget:Be,transform:me,disabled:!!Me,smartConnectLineState:Re})),g().createElement(L.Y,{shadowRoot:a.shadowRoot,scale:me.k,scaleRange:ke,onZoomChange:Fe,onReCenter:Ye}))}function Sa(){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 Ra(e,t){let a=arguments.length>2&&void 0!==arguments[2]?arguments[2]:1;const n=t.x+a/2,l=t.y+a/2,i=t.width-a,s=t.height-a;return e.map((e=>({x:n+e.x*i,y:l+e.y*s})))}n=Na,({e:[J,V,X,Z,Q,ee,te,ae,ne,le,ie,se,oe,re,de,he,ce,ue,ge,pe,Ae,ve,ye,fe,Ce,me,we,ke,be,xe,Me,Ee,Ne,Te,We,Se,Re,ze,Be,Le,De,Pe,He,$e,Oe,_e,je,Ue,Ke,Ie,Fe,Ye,qe,Ge,Je,Ve,Xe,Ze,Qe,et,tt,at,nt,lt,it,st,ot,rt,dt,ht,ct,ut,gt,pt,At,vt,yt,ft,Ct,mt,wt,kt,bt,xt,Mt,Et,Nt,Tt,q],c:[Dt,G]}=(0,c.A)(n,[St("eo-draw-canvas",{styleTexts:[U.A,K.A]})],[[Rt({attribute:!1}),1,"cells"],[Rt({type:String}),1,"layout"],[Rt({attribute:!1}),1,"layoutOptions"],[Rt({attribute:!1}),1,"defaultNodeSize"],[Rt({attribute:!1}),1,"defaultNodeBricks"],[Rt({type:Number}),1,"degradedThreshold"],[Rt({attribute:!1}),1,"degradedNodeLabel"],[Rt({attribute:!1}),1,"defaultEdgeLines"],[Rt({attribute:!1}),1,"activeTarget"],[Rt({type:Boolean}),1,"fadeUnrelatedCells"],[Rt({type:Boolean}),1,"zoomable"],[Rt({type:Boolean}),1,"scrollable"],[Rt({type:Boolean}),1,"pannable"],[Rt({type:Boolean}),1,"allowEdgeToArea"],[Rt(),1,"dragBehavior"],[Rt(),1,"ctrlDragBehavior"],[Rt({attribute:!1}),1,"scaleRange"],[Rt({attribute:!1}),1,"lineConnector"],[Bt({type:"activeTarget.change"}),1,"activeTargetChangeEvent",e=>(0,h.A)(ea,e),(e,t)=>(0,d.A)(ea,e,t)],[Bt({type:"node.move"}),1,"nodeMoveEvent",e=>(0,h.A)(la,e),(e,t)=>(0,d.A)(la,e,t)],[Bt({type:"cell.move"}),1,"cellMoveEvent",e=>(0,h.A)(ia,e),(e,t)=>(0,d.A)(ia,e,t)],[Bt({type:"cells.move"}),1,"cellsMoveEvent",e=>(0,h.A)(oa,e),(e,t)=>(0,d.A)(oa,e,t)],[Bt({type:"cell.resize"}),1,"cellResizeEvent",e=>(0,h.A)(da,e),(e,t)=>(0,d.A)(da,e,t)],[Bt({type:"node.delete"}),1,"nodeDelete",e=>(0,h.A)(ca,e),(e,t)=>(0,d.A)(ca,e,t)],[Bt({type:"cell.delete"}),1,"cellDelete",e=>(0,h.A)(ua,e),(e,t)=>(0,d.A)(ua,e,t)],[Bt({type:"cells.delete"}),1,"cellsDelete",e=>(0,h.A)(pa,e),(e,t)=>(0,d.A)(pa,e,t)],[Bt({type:"cell.contextmenu"}),1,"cellContextMenu",e=>(0,h.A)(va,e),(e,t)=>(0,d.A)(va,e,t)],[Bt({type:"edge.add"}),1,"edgeAdd",e=>(0,h.A)(fa,e),(e,t)=>(0,d.A)(fa,e,t)],[Bt({type:"decorator.text.change"}),1,"decoratorTextChange",e=>(0,h.A)(ma,e),(e,t)=>(0,d.A)(ma,e,t)],[Bt({type:"node.container.change"}),1,"containerContainerChange",e=>(0,h.A)(ka,e),(e,t)=>(0,d.A)(ka,e,t)],[Bt({type:"scale.change"}),1,"scaleChange",e=>(0,h.A)(xa,e),(e,t)=>(0,d.A)(xa,e,t)],[zt(),2,"dropNode"],[zt(),2,"dropDecorator"],[zt(),2,"addNodes"],[zt(),2,"addEdge"],[zt(),2,"manuallyConnectNodes"],[zt(),2,"updateCells"]],0,(e=>Ea.has((0,s.A)(e))),A.ReactNextElement)),G()}}]);
|
|
2
|
-
//# sourceMappingURL=eo-draw-canvas.
|
|
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:()=>Dt,EoDrawCanvasComponent:()=>Lt,uuidV4:()=>Sa});var n,l=a(4635),i=a(918),s=a(6902),o=a(2559),r=a(5536),d=a(6121),h=a(829),c=a(2740),u=a(8769),g=a.n(u),p=a(4799),A=a(8610),v=a(4218),y=(a(6477),a(1030)),f=a(3373),C=a.n(f),m=a(7566),w=a(5748),k=a(3739),b=a(531),x=a(8185),M=a(5114),E=a(4932),N=a(3639),T=a(3783),W=a(2098),S=a(227),R=a(3033),z=a(8091),B=a(1819),L=a(7099),D=a(1484),P=a(8197),H=a(7531),$=a(8875),O=a(2722),_=a(9978),j=a(2219),U=a(3012),K=a(6237),I=a(1103),F=a(9386),Y=a(1991);let q,G,J,V,X,Z,Q,ee,te,ae,ne,le,ie,se,oe,re,de,he,ce,ue,ge,pe,Ae,ve,ye,fe,Ce,me,we,ke,be,xe,Me,Ee,Ne,Te,We,Se,Re,ze,Be,Le,De,Pe,He,$e,Oe,_e,je,Ue,Ke,Ie,Fe,Ye,qe,Ge,Je,Ve,Xe,Ze,Qe,et,tt,at,nt,lt,it,st,ot,rt,dt,ht,ct,ut,gt,pt,At,vt,yt,ft,Ct,mt,wt,kt,bt,xt,Mt,Et,Nt,Tt;const Wt=(0,v.unwrapProvider)("basic.lock-body-scroll"),{defineElement:St,property:Rt,method:zt,event:Bt}=(0,p.createDecorators)(),Lt=g().forwardRef(Wa);let Dt;var Pt=new WeakMap,Ht=new WeakMap,$t=new WeakMap,Ot=new WeakMap,_t=new WeakMap,jt=new WeakMap,Ut=new WeakMap,Kt=new WeakMap,It=new WeakMap,Ft=new WeakMap,Yt=new WeakMap,qt=new WeakMap,Gt=new WeakMap,Jt=new WeakMap,Vt=new WeakMap,Xt=new WeakMap,Zt=new WeakMap,Qt=new WeakMap,ea=new WeakMap,ta=new WeakSet,aa=new WeakMap,na=new WeakMap,la=new WeakMap,ia=new WeakMap,sa=new WeakMap,oa=new WeakMap,ra=new WeakMap,da=new WeakMap,ha=new WeakMap,ca=new WeakMap,ua=new WeakMap,ga=new WeakMap,pa=new WeakMap,Aa=new WeakMap,va=new WeakMap,ya=new WeakMap,fa=new WeakMap,Ca=new WeakMap,ma=new WeakMap,wa=new WeakMap,ka=new WeakMap,ba=new WeakMap,xa=new WeakMap,Ma=new WeakMap,Ea=new WeakMap;class Na extends A.ReactNextElement{constructor(){super(...arguments),(0,l.A)(this,ta),(0,i.A)(this,Pt,(q(this),J(this))),(0,i.A)(this,Ht,(V(this),X(this))),(0,i.A)(this,$t,(Z(this),Q(this))),(0,i.A)(this,Ot,(ee(this),te(this,[R.HP,R.HP]))),(0,i.A)(this,_t,(ae(this),ne(this))),(0,i.A)(this,jt,(le(this),ie(this))),(0,i.A)(this,Ut,(se(this),oe(this))),(0,i.A)(this,Kt,(re(this),de(this))),(0,i.A)(this,It,(he(this),ce(this))),(0,i.A)(this,Ft,(ue(this),ge(this))),(0,i.A)(this,Yt,(pe(this),Ae(this,!0))),(0,i.A)(this,qt,(ve(this),ye(this,!0))),(0,i.A)(this,Gt,(fe(this),Ce(this,!0))),(0,i.A)(this,Jt,(me(this),we(this,!1))),(0,i.A)(this,Vt,(ke(this),be(this))),(0,i.A)(this,Xt,(xe(this),Me(this))),(0,i.A)(this,Zt,(Ee(this),Ne(this))),(0,i.A)(this,Qt,(Te(this),We(this))),(0,i.A)(this,ea,(Se(this),Re(this))),(0,i.A)(this,aa,(Le(this),e=>{(0,r.A)(ta,this,ze).emit(e)})),(0,i.A)(this,na,(e=>{(0,x.c)(e,this.activeTarget)||(this.activeTarget=e)})),(0,i.A)(this,la,De(this)),(0,i.A)(this,ia,($e(this),Oe(this))),(0,i.A)(this,sa,(Ue(this),e=>{(0,r.A)(ta,this,_e).emit(e),"node"===e.type&&(0,r.A)(ta,this,Pe).emit(e)})),(0,i.A)(this,oa,Ke(this)),(0,i.A)(this,ra,(Ye(this),e=>{(0,r.A)(ta,this,Ie).emit(e)})),(0,i.A)(this,da,qe(this)),(0,i.A)(this,ha,(Ve(this),e=>{(0,r.A)(ta,this,Ge).emit(e)})),(0,i.A)(this,ca,Xe(this)),(0,i.A)(this,ua,(et(this),tt(this))),(0,i.A)(this,ga,(lt(this),e=>{(0,r.A)(ta,this,at).emit(e),"node"===e.type&&(0,r.A)(ta,this,Ze).emit(e)})),(0,i.A)(this,pa,it(this)),(0,i.A)(this,Aa,(rt(this),e=>{(0,r.A)(ta,this,st).emit(e)})),(0,i.A)(this,va,dt(this)),(0,i.A)(this,ya,(ut(this),e=>{(0,r.A)(ta,this,ht).emit(e)})),(0,i.A)(this,fa,gt(this)),(0,i.A)(this,Ca,(vt(this),e=>{(0,r.A)(ta,this,pt).emit(e)})),(0,i.A)(this,ma,yt(this)),(0,i.A)(this,wa,(mt(this),e=>{(0,r.A)(ta,this,ft).emit(e)})),(0,i.A)(this,ka,wt(this)),(0,i.A)(this,ba,(xt(this),e=>{(0,r.A)(ta,this,kt).emit(e)})),(0,i.A)(this,xa,Mt(this)),(0,i.A)(this,Ma,(Tt(this),e=>{(0,r.A)(ta,this,Et).emit(e)})),(0,i.A)(this,Ea,(0,u.createRef)())}get cells(){return(0,h.A)(Pt,this)}set cells(e){(0,d.A)(Pt,this,e)}get layout(){return(0,h.A)(Ht,this)}set layout(e){(0,d.A)(Ht,this,e)}get layoutOptions(){return(0,h.A)($t,this)}set layoutOptions(e){(0,d.A)($t,this,e)}get defaultNodeSize(){return(0,h.A)(Ot,this)}set defaultNodeSize(e){(0,d.A)(Ot,this,e)}get defaultNodeBricks(){return(0,h.A)(_t,this)}set defaultNodeBricks(e){(0,d.A)(_t,this,e)}get degradedThreshold(){return(0,h.A)(jt,this)}set degradedThreshold(e){(0,d.A)(jt,this,e)}get degradedNodeLabel(){return(0,h.A)(Ut,this)}set degradedNodeLabel(e){(0,d.A)(Ut,this,e)}get defaultEdgeLines(){return(0,h.A)(Kt,this)}set defaultEdgeLines(e){(0,d.A)(Kt,this,e)}get activeTarget(){return(0,h.A)(It,this)}set activeTarget(e){(0,d.A)(It,this,e)}get fadeUnrelatedCells(){return(0,h.A)(Ft,this)}set fadeUnrelatedCells(e){(0,d.A)(Ft,this,e)}get zoomable(){return(0,h.A)(Yt,this)}set zoomable(e){(0,d.A)(Yt,this,e)}get scrollable(){return(0,h.A)(qt,this)}set scrollable(e){(0,d.A)(qt,this,e)}get pannable(){return(0,h.A)(Gt,this)}set pannable(e){(0,d.A)(Gt,this,e)}get allowEdgeToArea(){return(0,h.A)(Jt,this)}set allowEdgeToArea(e){(0,d.A)(Jt,this,e)}get dragBehavior(){return(0,h.A)(Vt,this)}set dragBehavior(e){(0,d.A)(Vt,this,e)}get ctrlDragBehavior(){return(0,h.A)(Xt,this)}set ctrlDragBehavior(e){(0,d.A)(Xt,this,e)}get scaleRange(){return(0,h.A)(Zt,this)}set scaleRange(e){(0,d.A)(Zt,this,e)}get lineConnector(){return(0,h.A)(Qt,this)}set lineConnector(e){(0,d.A)(Qt,this,e)}async dropNode(e){var t,a;let{id:n,position:l,size:i,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;const e=this.getBoundingClientRect(),t=(0,h.A)(Ea,this).current.getTransform(),a={type:"node",id:n,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==i?void 0:i[0])??this.defaultNodeSize[0],height:(null==i?void 0:i[1])??this.defaultNodeSize[0]},data:s,useBrick:o};return null===(r=(0,h.A)(Ea,this).current)||void 0===r||r.dropNode(a),a}return null}async dropDecorator(e){var t,a;let{position:n,decorator:l,text:i,direction:s}=e;if(null===(t=(a=document).elementsFromPoint)||void 0===t||null===(t=t.call(a,n[0],n[1]))||void 0===t?void 0:t.includes(this)){var o;const e=this.getBoundingClientRect(),t=(0,h.A)(Ea,this).current.getTransform(),a={type:"decorator",decorator:l,id:Sa(),view:{x:(n[0]-e.left-t.x)/t.k,y:(n[1]-e.top-t.y)/t.k,width:R.N8,height:R.w1,text:i,direction:s}};return null===(o=(0,h.A)(Ea,this).current)||void 0===o||o.dropDecorator(a),a}return null}async addNodes(e){if(0===e.length)return[];const t=e.map((e=>{let{size:t,useBrick:a,id:n,data:l}=e;return{type:"node",id:n,data:l,view:{width:(null==t?void 0:t[0])??this.defaultNodeSize[0],height:(null==t?void 0:t[1])??this.defaultNodeSize[0]},useBrick:a}}));return(0,h.A)(Ea,this).current.addNodes(t,{defaultNodeSize:this.defaultNodeSize,canvasWidth:this.clientWidth,canvasHeight:this.clientHeight})}async addEdge(e){var t;let{source:a,target:n,data:l}=e;const i={type:"edge",source:a,target:n,data:l};return null===(t=(0,h.A)(Ea,this).current)||void 0===t||t.addEdge(i),i}manuallyConnectNodes(e){return(0,h.A)(Ea,this).current.manuallyConnectNodes(e)}async updateCells(e,t){await(0,o.A)(ta,this,Ta).call(this);const{updated:a}=(0,h.A)(Ea,this).current.updateCells(e,{...t,defaultNodeSize:this.defaultNodeSize,canvasWidth:this.clientWidth,canvasHeight:this.clientHeight});return{updated:a}}disconnectedCallback(){super.disconnectedCallback(),Wt(this,!1)}render(){return g().createElement(Lt,{host:this,ref:(0,h.A)(Ea,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,lineConnector:this.lineConnector,allowEdgeToArea:this.allowEdgeToArea,onActiveTargetChange:(0,h.A)(aa,this),onSwitchActiveTarget:(0,h.A)(na,this),onCellMove:(0,h.A)(sa,this),onCellsMove:(0,h.A)(ra,this),onCellResize:(0,h.A)(ha,this),onCellDelete:(0,h.A)(ga,this),onCellsDelete:(0,h.A)(Aa,this),onEdgeAdd:(0,h.A)(Ca,this),onCellContextMenu:(0,h.A)(ya,this),onDecoratorTextChange:(0,h.A)(wa,this),onContainerContainerChange:(0,h.A)(ba,this),onScaleChange:(0,h.A)(Ma,this)})}}function Ta(){return new Promise((e=>{const t=()=>{(0,h.A)(Ea,this).current?e():setTimeout(t,10)};t()}))}function Wa(e,t){let{host:a,layout:n,layoutOptions:l,cells:i,defaultNodeSize:s,defaultNodeBricks:o,defaultEdgeLines:r,degradedThreshold:d,degradedNodeLabel:h,activeTarget:c,fadeUnrelatedCells:p,zoomable:A,scrollable:f,pannable:x,dragBehavior:U,ctrlDragBehavior:K,scaleRange:q,lineConnector:G,allowEdgeToArea:J,onActiveTargetChange:V,onSwitchActiveTarget:X,onCellMove:Z,onCellResize:Q,onCellDelete:ee,onCellsMove:te,onCellsDelete:ae,onCellContextMenu:ne,onEdgeAdd:le,onDecoratorTextChange:ie,onScaleChange:se,onContainerContainerChange:oe}=e;const[{cells:re,layoutKey:de},he]=(0,u.useReducer)(w.d,i,(e=>({cells:(0,T.C)(e,{defaultNodeSize:s}),layoutKey:0}))),ce=(0,u.useMemo)((()=>re.filter(b.N).length>=(d??R.pC)),[re,d]),ue=(0,u.useRef)(null),ge=(0,u.useRef)(null),pe=(0,u.useRef)(null),[Ae,ve]=(0,u.useState)([]),[ye,fe]=(0,u.useState)([]),{grabbing:Ce,transform:me,zoomer:we,scaleRange:ke}=(0,z.f)({rootRef:ue,zoomable:A,scrollable:f,pannable:x,draggable:"grab"===U,ctrlDraggable:"grab"===K,scaleRange:q,onSwitchActiveTarget:X});(0,u.useEffect)((()=>{se(me.k)}),[se,me.k]);const[be,xe]=(0,u.useState)(null),[Me,Ee]=(0,u.useState)(null),{centered:Ne,setCentered:Te,getNextLayoutKey:We}=(0,D.g)({layout:n,layoutOptions:l,rootRef:ue,cells:re,zoomable:A,zoomer:we,scaleRange:ke,layoutKey:de,allowEdgeToArea:J,dispatch:he});(0,u.useImperativeHandle)(t,(()=>({dropNode(e){"dagre"!==n&&"force"!==n&&Te(!0),he({type:"drop-node",payload:e})},dropDecorator(e){"dagre"!==n&&"force"!==n&&Te(!0),he({type:"drop-decorator",payload:e})},addNodes(e,t){let{defaultNodeSize:a,canvasWidth:l,canvasHeight:i}=t;const s=re.findLastIndex((e=>!("decorator"===e.type&&"text"===e.decorator)))+1,o=[...re.slice(0,s),...e,...re.slice(s)],{cells:r,updated:d,shouldReCenter:h}=(0,W.L)({cells:o,layout:n,previousCells:re,defaultNodeSize:a,canvasWidth:l,canvasHeight:i,scaleRange:ke,transform:me,allowEdgeToArea:J});return h&&Te(!1),he({type:"update-cells",payload:r}),d.filter((t=>e.includes(t)))},addEdge(e){he({type:"add-edge",payload:e})},updateCells(e,t){const{shouldReCenter:a,...l}=(0,W.L)({...t,layout:n,previousCells:re,cells:e,scaleRange:ke,transform:me,allowEdgeToArea:J});return a&&Te(!1),he({type:"update-cells",payload:l.cells}),l},getTransform:()=>me,manuallyConnectNodes(e){const t=re.find((t=>(J&&(0,b.o6)(t)||(0,b.N)(t))&&t.id===e));if(t){const e=ue.current.getBoundingClientRect();return Ee({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)=>{pe.current={resolve:e,reject:t}}))}return Promise.reject(null)}})),[re,n,ke,Te,me,J]);const Se=(0,u.useCallback)(((e,t)=>{var a;for(let a=re.length-1;a>=0;a--){const l=re[a];if((J&&(0,b.o6)(l)||(0,b.N)(l))&&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 n;null===(n=pe.current)||void 0===n||n.resolve({source:e.source,target:l});break}}null===(a=pe.current)||void 0===a||a.reject(null),Ee(null)}),[re]),[Re,ze]=(0,u.useState)(null);(0,u.useEffect)((()=>{Wt(a,!!(Me||Re||be))}),[Me,a,Re,be]);const Be=(0,B.J)({cellsRef:ge,activeTarget:c,onActiveTargetChange:V}),[Le,De]=(0,u.useState)([]);(0,u.useEffect)((()=>{const e=p?(0,S.Y)(re,Me,Be,J):[];De((t=>0===t.length&&0===e.length?t:e))}),[Be,re,Me,p,J]),(0,u.useEffect)((()=>{const e=ue.current;if(!e||Ae.length>0)return;const t=e=>{const t=(0,M.a)(e,{cells:re,activeTarget:Be});"delete-cells"===(null==t?void 0:t.action)&&(ae(t.cells),1===t.cells.length&&ee(t.cells[0]))};return e.addEventListener("keydown",t),()=>{e.removeEventListener("keydown",t)}}),[Be,re,Ae.length,ee,ae]);const Pe=`${(0,u.useMemo)((()=>`${(0,y.uniqueId)("diagram-")}-`),[])}line-arrow-`,[He,$e]=(0,u.useState)([]),Oe=(0,u.useCallback)((e=>{he({type:"move-cells",payload:e});const t=[];(0,Y._)(e,re).forEach((e=>{var a,n;null!==(a=e.containerCell)&&void 0!==a&&a.id&&t.push(null===(n=e.containerCell)||void 0===n?void 0:n.id)})),fe(t),$e(e.flatMap((e=>e.guideLines??[])))}),[re]),_e=(0,u.useCallback)((e=>{he({type:"move-cells",payload:e}),te(e),1===e.length&&Z(e[0]),(0,Y._)(e,re,oe),fe([]),$e([])}),[Z,te,re,oe]),je=(0,u.useCallback)((e=>{he({type:"resize-cell",payload:e})}),[]),Ue=(0,u.useCallback)((e=>{he({type:"resize-cell",payload:e}),Q(e)}),[Q]),Ke=(0,u.useCallback)((e=>{let{id:t,editing:a}=e;ve(a?e=>e.includes(t)?e:[...e,t]:e=>e.filter((e=>e!==t)))}),[]),Ie=(0,u.useCallback)(((e,t)=>{const a=We();he({type:"update-node-size",payload:{id:e,size:t},layoutKey:a})}),[We]),Fe=(0,u.useCallback)((e=>{we.scaleTo((0,m.A)(ue.current),e/100)}),[we]),Ye=(0,u.useCallback)((()=>{Te(!1)}),[Te]),{lineConfMap:qe,lineConnectorConf:Ge,markers:Je}=(0,H.d)({cells:re,defaultEdgeLines:r,lineConnector:G,markerPrefix:Pe}),Ve=(0,P.H)({cells:re,layout:n,centered:Ne}),[Xe,Ze]=(0,u.useState)(null),Qe=(0,u.useRef)(null),et=(0,u.useCallback)((e=>{if(Ge&&(0,b.N)(e)){null!==Qe.current&&(clearTimeout(Qe.current),Qe.current=null);const t=(0,$.G)();Ze({cell:e,relativePoints:t,points:Ra(t,e.view)})}}),[Ge]),tt=(0,u.useCallback)((e=>{Ge&&(0,b.N)(e)&&(Qe.current=setTimeout((()=>{Ze(null)})))}),[Ge]),at=(0,u.useMemo)((()=>({rootRef:ue,smartConnectLineState:Re,unsetHoverStateTimeoutRef:Qe,hoverState:Xe,setHoverState:Ze,setSmartConnectLineState:ze,onConnect(e,t,a,n){const l={type:"edge",source:e.id,target:t.id,view:{exitPosition:a,entryPosition:n,...(0,v.isObject)(G)?G:null}};he({type:"add-edge",payload:l}),le(l)}})),[Re,Xe,G,le]);return(0,u.useEffect)((()=>{const e=ue.current;if(!e||"lasso"!==U)return;const t=e.getBoundingClientRect(),a=e=>{(0,j.F)(e,{transform:me,offset:[t.left,t.top],onLassoing(e){xe(e)},onLassoed(e){xe(null);const t=[];for(const a of re)if((0,b.t2)(a)||(0,b.o6)(a)||(0,b.Hs)(a)){const n=a.view.x,l=a.view.y;n>=e.x&&n+a.view.width<=e.x+e.width&&l>=e.y&&l+a.view.height<=e.y+e.height&&t.push(a)}null==X||X(t.length>1?{type:"multi",targets:t.map(F.P)}:1===t.length?(0,F.P)(t[0]):null)}})};return e.addEventListener("mousedown",a),()=>{e.removeEventListener("mousedown",a)}}),[me,re,U,X]),g().createElement(_.H.Provider,{value:at},g().createElement("svg",{width:"100%",height:"100%",ref:ue,className:C()("root",{grabbing:Ce,pannable:x,ready:Ve}),tabIndex:-1},g().createElement("defs",null,Je.map(((e,t)=>g().createElement(k.c,{key:t,id:`${Pe}${t}`,type:"arrow",strokeColor:e.strokeColor})))),g().createElement("g",{transform:`translate(${me.x} ${me.y}) scale(${me.k})`},g().createElement("g",{className:C()("cells",{allowEdgeToArea:J}),ref:ge},re.map((e=>g().createElement(E.m,{key:`${e.type}:${(0,b.WW)(e)?`${e.source}~${e.target}`:e.id}`,dragNodeToContainerActive:!(0,b.WW)(e)&&ye.includes(e.id),layout:n,layoutOptions:l,cell:e,cells:re,degraded:ce,degradedNodeLabel:h,defaultNodeBricks:o,transform:me,lineConfMap:qe,activeTarget:Be,unrelatedCells:Le,onCellsMoving:Oe,onCellsMoved:_e,onCellResizing:je,onCellResized:Ue,onSwitchActiveTarget:X,onCellContextMenu:ne,onDecoratorTextChange:ie,onDecoratorTextEditing:Ke,onNodeBrickResize:Ie,onCellMouseEnter:et,onCellMouseLeave:tt})))),g().createElement(N.w,{connectLineState:Me,transform:me,markerEnd:`${Pe}0`,onConnect:Se}),be&&g().createElement("rect",{x:be.x,y:be.y,width:be.width,height:be.height,fill:"var(--palette-gray-5)",fillOpacity:.3,stroke:"var(--palette-gray-5)",strokeDasharray:2}),Ge&&g().createElement(I.X,{smartConnectLineState:Re,transform:me,options:Ge}),He.map(((e,t)=>g().createElement("path",{key:t,d:`M${e[0].join(" ")} L${e[1].join(" ")}`,stroke:"var(--palette-orange-5)",fill:"none"})))),Ge&&g().createElement(O.T,{activeTarget:Be,transform:me,disabled:!!Me,smartConnectLineState:Re})),g().createElement(L.Y,{shadowRoot:a.shadowRoot,scale:me.k,scaleRange:ke,onZoomChange:Fe,onReCenter:Ye}))}function Sa(){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 Ra(e,t){let a=arguments.length>2&&void 0!==arguments[2]?arguments[2]:1;const n=t.x+a/2,l=t.y+a/2,i=t.width-a,s=t.height-a;return e.map((e=>({x:n+e.x*i,y:l+e.y*s})))}n=Na,({e:[J,V,X,Z,Q,ee,te,ae,ne,le,ie,se,oe,re,de,he,ce,ue,ge,pe,Ae,ve,ye,fe,Ce,me,we,ke,be,xe,Me,Ee,Ne,Te,We,Se,Re,ze,Be,Le,De,Pe,He,$e,Oe,_e,je,Ue,Ke,Ie,Fe,Ye,qe,Ge,Je,Ve,Xe,Ze,Qe,et,tt,at,nt,lt,it,st,ot,rt,dt,ht,ct,ut,gt,pt,At,vt,yt,ft,Ct,mt,wt,kt,bt,xt,Mt,Et,Nt,Tt,q],c:[Dt,G]}=(0,c.A)(n,[St("eo-draw-canvas",{styleTexts:[U.A,K.A]})],[[Rt({attribute:!1}),1,"cells"],[Rt({type:String}),1,"layout"],[Rt({attribute:!1}),1,"layoutOptions"],[Rt({attribute:!1}),1,"defaultNodeSize"],[Rt({attribute:!1}),1,"defaultNodeBricks"],[Rt({type:Number}),1,"degradedThreshold"],[Rt({attribute:!1}),1,"degradedNodeLabel"],[Rt({attribute:!1}),1,"defaultEdgeLines"],[Rt({attribute:!1}),1,"activeTarget"],[Rt({type:Boolean}),1,"fadeUnrelatedCells"],[Rt({type:Boolean}),1,"zoomable"],[Rt({type:Boolean}),1,"scrollable"],[Rt({type:Boolean}),1,"pannable"],[Rt({type:Boolean}),1,"allowEdgeToArea"],[Rt(),1,"dragBehavior"],[Rt(),1,"ctrlDragBehavior"],[Rt({attribute:!1}),1,"scaleRange"],[Rt({attribute:!1}),1,"lineConnector"],[Bt({type:"activeTarget.change"}),1,"activeTargetChangeEvent",e=>(0,h.A)(ea,e),(e,t)=>(0,d.A)(ea,e,t)],[Bt({type:"node.move"}),1,"nodeMoveEvent",e=>(0,h.A)(la,e),(e,t)=>(0,d.A)(la,e,t)],[Bt({type:"cell.move"}),1,"cellMoveEvent",e=>(0,h.A)(ia,e),(e,t)=>(0,d.A)(ia,e,t)],[Bt({type:"cells.move"}),1,"cellsMoveEvent",e=>(0,h.A)(oa,e),(e,t)=>(0,d.A)(oa,e,t)],[Bt({type:"cell.resize"}),1,"cellResizeEvent",e=>(0,h.A)(da,e),(e,t)=>(0,d.A)(da,e,t)],[Bt({type:"node.delete"}),1,"nodeDelete",e=>(0,h.A)(ca,e),(e,t)=>(0,d.A)(ca,e,t)],[Bt({type:"cell.delete"}),1,"cellDelete",e=>(0,h.A)(ua,e),(e,t)=>(0,d.A)(ua,e,t)],[Bt({type:"cells.delete"}),1,"cellsDelete",e=>(0,h.A)(pa,e),(e,t)=>(0,d.A)(pa,e,t)],[Bt({type:"cell.contextmenu"}),1,"cellContextMenu",e=>(0,h.A)(va,e),(e,t)=>(0,d.A)(va,e,t)],[Bt({type:"edge.add"}),1,"edgeAdd",e=>(0,h.A)(fa,e),(e,t)=>(0,d.A)(fa,e,t)],[Bt({type:"decorator.text.change"}),1,"decoratorTextChange",e=>(0,h.A)(ma,e),(e,t)=>(0,d.A)(ma,e,t)],[Bt({type:"node.container.change"}),1,"containerContainerChange",e=>(0,h.A)(ka,e),(e,t)=>(0,d.A)(ka,e,t)],[Bt({type:"scale.change"}),1,"scaleChange",e=>(0,h.A)(xa,e),(e,t)=>(0,d.A)(xa,e,t)],[zt(),2,"dropNode"],[zt(),2,"dropDecorator"],[zt(),2,"addNodes"],[zt(),2,"addEdge"],[zt(),2,"manuallyConnectNodes"],[zt(),2,"updateCells"]],0,(e=>Ea.has((0,s.A)(e))),A.ReactNextElement)),G()}}]);
|
|
2
|
+
//# sourceMappingURL=eo-draw-canvas.79b100f8.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"chunks/eo-draw-canvas.84ade234.js","mappings":"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","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 { isObject, unwrapProvider } from \"@next-core/utils/general\";\nimport \"@next-core/theme\";\nimport { uniqueId } from \"lodash\";\nimport classNames from \"classnames\";\nimport { select } from \"d3-selection\";\nimport type { lockBodyScroll as _lockBodyScroll } from \"@next-bricks/basic/data-providers/lock-body-scroll/lock-body-scroll\";\nimport type {\n 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} from \"./interfaces\";\nimport { rootReducer } from \"./reducers\";\nimport { MarkerComponent } from \"../diagram/MarkerComponent\";\nimport {\n isContainerDecoratorCell,\n isEdgeCell,\n isNodeCell,\n isNodeOrAreaDecoratorCell,\n isTextDecoratorCell,\n} from \"./processors/asserts\";\nimport type {\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} 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\";\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 lineConnector?: LineConnecterConf | boolean;\n allowEdgeToArea?: boolean;\n}\n\nexport type DragBehavior = \"none\" | \"lasso\" | \"grab\";\nexport type CtrlDragBehavior = \"none\" | \"grab\";\n\nexport interface DropNodeInfo extends AddNodeInfo {\n /** [PointerEvent::clientX, PointerEvent::clientY] */\n position: PositionTuple;\n}\n\nexport interface DropDecoratorInfo {\n decorator: DecoratorType;\n /** [PointerEvent::clientX, PointerEvent::clientY] */\n position: PositionTuple;\n text?: string;\n direction?: Direction;\n}\n\nexport interface AddNodeInfo {\n id: NodeId;\n useBrick?: UseSingleBrickConf;\n data?: unknown;\n size?: SizeTuple;\n}\n\nexport interface AddEdgeInfo {\n source: NodeId;\n target: NodeId;\n data?: unknown;\n}\n\nexport interface UpdateCellsContext {\n reason: \"add-related-nodes\";\n parent: NodeId;\n}\n\nexport interface AddNodesContext {\n defaultNodeSize: SizeTuple;\n canvasWidth: number;\n canvasHeight: number;\n}\n\nexport const EoDrawCanvasComponent = React.forwardRef(\n LegacyEoDrawCanvasComponent\n);\n\n/**\n * 用于手工绘图的画布。\n *\n * 注意:将配套另外一个用于展示的画布构件。\n */\nexport\n@defineElement(\"eo-draw-canvas\", {\n styleTexts: [styleText, zoomBarStyleText],\n})\nclass EoDrawCanvas extends ReactNextElement implements EoDrawCanvasProps {\n /**\n * 仅当初始化时使用,渲染后重新设置 `cells` 将无效。\n */\n @property({ attribute: false })\n accessor cells: InitialCell[] | undefined;\n\n @property({ type: String })\n accessor layout: LayoutType;\n\n @property({ attribute: false })\n accessor layoutOptions: LayoutOptions | undefined;\n\n @property({ attribute: false })\n accessor defaultNodeSize: SizeTuple = [DEFAULT_NODE_SIZE, DEFAULT_NODE_SIZE];\n\n @property({ attribute: false })\n accessor defaultNodeBricks: NodeBrickConf[] | undefined;\n\n /**\n * 当节点数量达到或超过 `degradedThreshold` 时,节点将被降级展示。\n *\n * @default 500\n */\n @property({ type: Number })\n accessor degradedThreshold: number | undefined;\n\n // Set `attribute` to `false` 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 lineConnector: LineConnecterConf | 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<EdgeCell>;\n\n #handleEdgeAdd = (edge: EdgeCell) => {\n this.#edgeAdd.emit(edge);\n };\n\n @event({ type: \"decorator.text.change\" })\n accessor #decoratorTextChange!: EventEmitter<DecoratorTextChangeDetail>;\n\n #handleDecoratorTextChange = (detail: DecoratorTextChangeDetail) => {\n this.#decoratorTextChange.emit(detail);\n };\n\n /**\n * node节点跟容器组关系改变事件,有containerCell是新增关系,否则删除关系\n */\n @event({ type: \"node.container.change\" })\n accessor #containerContainerChange!: EventEmitter<MoveCellPayload[]>;\n\n #handleContainerContainerChange = (detail: MoveCellPayload[]) => {\n this.#containerContainerChange.emit(detail);\n };\n\n /**\n * 缩放变化后,从素材库拖拽元素进画布时,拖拽图像应设置对应的缩放比例。\n */\n @event({ type: \"scale.change\" })\n accessor #scaleChange!: EventEmitter<number>;\n\n #handleScaleChange = (scale: number) => {\n this.#scaleChange.emit(scale);\n };\n\n @method()\n async dropNode({\n id,\n position,\n size,\n data,\n useBrick,\n }: DropNodeInfo): Promise<NodeCell | null> {\n // Drag and then drop a node\n const droppedInside = document\n .elementsFromPoint?.(position[0], position[1])\n ?.includes(this);\n if (droppedInside) {\n const boundingClientRect = this.getBoundingClientRect();\n const transform = this.#canvasRef.current!.getTransform();\n const newNode = {\n type: \"node\",\n id,\n view: {\n ...(this.layout === \"force\" || this.layout === \"dagre\"\n ? null\n : {\n x:\n (position[0] - boundingClientRect.left - transform.x) /\n transform.k,\n y:\n (position[1] - boundingClientRect.top - transform.y) /\n transform.k,\n }),\n width: size?.[0] ?? this.defaultNodeSize[0],\n height: size?.[1] ?? this.defaultNodeSize[0],\n },\n data,\n useBrick,\n } as NodeCell;\n this.#canvasRef.current?.dropNode(newNode);\n return newNode;\n }\n return null;\n }\n\n @method()\n async dropDecorator({\n position,\n decorator,\n text,\n direction,\n }: DropDecoratorInfo): Promise<DecoratorCell | null> {\n // Drag and then drop a node\n const droppedInside = document\n .elementsFromPoint?.(position[0], position[1])\n ?.includes(this);\n if (droppedInside) {\n const boundingClientRect = this.getBoundingClientRect();\n const transform = this.#canvasRef.current!.getTransform();\n const newDecorator: DecoratorCell = {\n type: \"decorator\",\n decorator,\n id: uuidV4(),\n view: {\n x:\n (position[0] - boundingClientRect.left - transform.x) / transform.k,\n y: (position[1] - boundingClientRect.top - transform.y) / transform.k,\n width: DEFAULT_AREA_WIDTH,\n height: DEFAULT_AREA_HEIGHT,\n text,\n direction,\n },\n };\n this.#canvasRef.current?.dropDecorator(newDecorator);\n return newDecorator;\n }\n return null;\n }\n\n @method()\n async addNodes(nodes: AddNodeInfo[]): Promise<NodeCell[]> {\n if (nodes.length === 0) {\n return [];\n }\n const newNodes = nodes.map<NodeCell>(({ size, useBrick, id, data }) => ({\n type: \"node\",\n id,\n data,\n view: {\n width: size?.[0] ?? this.defaultNodeSize[0],\n height: size?.[1] ?? this.defaultNodeSize[0],\n } as NodeView,\n useBrick,\n }));\n return this.#canvasRef.current!.addNodes(newNodes, {\n defaultNodeSize: this.defaultNodeSize,\n canvasWidth: this.clientWidth,\n canvasHeight: this.clientHeight,\n });\n }\n\n @method()\n async addEdge({ source, target, data }: AddEdgeInfo): Promise<EdgeCell> {\n const newEdge: EdgeCell = {\n type: \"edge\",\n source,\n target,\n data,\n };\n this.#canvasRef.current?.addEdge(newEdge);\n return newEdge;\n }\n\n @method()\n manuallyConnectNodes(source: NodeId): Promise<ConnectNodesDetail> {\n return this.#canvasRef.current!.manuallyConnectNodes(source);\n }\n\n @method()\n async updateCells(\n cells: InitialCell[],\n ctx?: UpdateCellsContext\n ): Promise<{ updated: Cell[] }> {\n await this.#waitForCanvasRef();\n const { updated } = this.#canvasRef.current!.updateCells(cells, {\n ...ctx,\n defaultNodeSize: this.defaultNodeSize,\n canvasWidth: this.clientWidth,\n canvasHeight: this.clientHeight,\n });\n return { updated };\n }\n\n #waitForCanvasRef() {\n return new Promise<void>((resolve) => {\n const check = () => {\n if (this.#canvasRef.current) {\n resolve();\n } else {\n setTimeout(check, 10);\n }\n };\n check();\n });\n }\n\n #canvasRef = createRef<DrawCanvasRef>();\n\n disconnectedCallback(): void {\n super.disconnectedCallback();\n lockBodyScroll(this, false);\n }\n\n render() {\n return (\n <EoDrawCanvasComponent\n host={this}\n ref={this.#canvasRef}\n layout={this.layout}\n layoutOptions={this.layoutOptions}\n cells={this.cells}\n defaultNodeSize={this.defaultNodeSize}\n defaultNodeBricks={this.defaultNodeBricks}\n defaultEdgeLines={this.defaultEdgeLines}\n degradedThreshold={this.degradedThreshold}\n degradedNodeLabel={this.degradedNodeLabel}\n activeTarget={this.activeTarget}\n fadeUnrelatedCells={this.fadeUnrelatedCells}\n zoomable={this.zoomable}\n scrollable={this.scrollable}\n pannable={this.pannable}\n dragBehavior={this.dragBehavior}\n ctrlDragBehavior={this.ctrlDragBehavior}\n scaleRange={this.scaleRange}\n lineConnector={this.lineConnector}\n allowEdgeToArea={this.allowEdgeToArea}\n onActiveTargetChange={this.#handleActiveTargetChange}\n onSwitchActiveTarget={this.#handleSwitchActiveTarget}\n onCellMove={this.#handleCellMove}\n onCellsMove={this.#handleCellsMove}\n onCellResize={this.#handleCellResize}\n onCellDelete={this.#handleCellDelete}\n onCellsDelete={this.#handleCellsDelete}\n onEdgeAdd={this.#handleEdgeAdd}\n onCellContextMenu={this.#handleCellContextMenu}\n onDecoratorTextChange={this.#handleDecoratorTextChange}\n onContainerContainerChange={this.#handleContainerContainerChange}\n onScaleChange={this.#handleScaleChange}\n />\n );\n }\n}\n\nexport interface EoDrawCanvasComponentProps extends EoDrawCanvasProps {\n host: HTMLElement;\n onActiveTargetChange(target: ActiveTarget | null): void;\n onSwitchActiveTarget(target: ActiveTarget | null): void;\n onCellMove(info: MoveCellPayload): void;\n onCellResize(cell: ResizeCellPayload): void;\n onCellDelete(cell: Cell): void;\n onCellsMove(info: MoveCellPayload[]): void;\n onCellsDelete(cells: Cell[]): void;\n onCellContextMenu(detail: CellContextMenuDetail): void;\n onEdgeAdd(detail: EdgeCell): void;\n onDecoratorTextChange(detail: DecoratorTextChangeDetail): void;\n onContainerContainerChange(detail: MoveCellPayload[]): void;\n onScaleChange(scale: number): void;\n}\n\nexport interface DrawCanvasRef {\n dropNode(node: NodeCell): void;\n dropDecorator(decorator: DecoratorCell): void;\n addNodes(nodes: NodeCell[], ctx: AddNodesContext): NodeCell[];\n addEdge(edge: EdgeCell): void;\n manuallyConnectNodes(source: NodeId): Promise<ConnectNodesDetail>;\n updateCells(\n cells: InitialCell[],\n ctx: Partial<UpdateCellsContext> & {\n defaultNodeSize: SizeTuple;\n canvasWidth: number;\n canvasHeight: number;\n }\n ): {\n cells: Cell[];\n updated: Cell[];\n };\n getTransform(): TransformLiteral;\n}\n\nfunction LegacyEoDrawCanvasComponent(\n {\n host,\n layout,\n layoutOptions,\n cells: initialCells,\n defaultNodeSize,\n defaultNodeBricks,\n defaultEdgeLines,\n degradedThreshold,\n degradedNodeLabel,\n activeTarget: _activeTarget,\n fadeUnrelatedCells,\n zoomable,\n scrollable,\n pannable,\n dragBehavior,\n ctrlDragBehavior,\n scaleRange: _scaleRange,\n lineConnector,\n allowEdgeToArea,\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 }: EoDrawCanvasComponentProps,\n ref: React.Ref<DrawCanvasRef>\n) {\n const [{ cells, layoutKey }, dispatch] = useReducer(\n rootReducer,\n initialCells,\n (initialCells) => ({\n cells: initializeCells(initialCells, { defaultNodeSize }),\n layoutKey: 0,\n })\n );\n\n // When nodes are greater or equal to threshold, the diagram will be degraded.\n // Thus all nodes will be displayed as simple svg elements instead of bricks.\n const degraded = useMemo(\n () =>\n cells.filter(isNodeCell).length >=\n (degradedThreshold ?? DEFAULT_DEGRADED_THRESHOLD),\n [cells, degradedThreshold]\n );\n\n const rootRef = useRef<SVGSVGElement>(null);\n const cellsRef = useRef<SVGGElement>(null);\n const manualConnectDeferredRef = useRef<Deferred<ConnectNodesDetail> | null>(\n null\n );\n const [editingTexts, setEditingTexts] = useState<string[]>([]);\n const [activeContainers, setActiveContainers] = useState<string[]>([]);\n const { grabbing, transform, zoomer, scaleRange } = useZoom({\n rootRef,\n zoomable,\n scrollable,\n pannable,\n draggable: dragBehavior === \"grab\",\n ctrlDraggable: ctrlDragBehavior === \"grab\",\n scaleRange: _scaleRange,\n onSwitchActiveTarget,\n });\n\n useEffect(() => {\n onScaleChange(transform.k);\n }, [onScaleChange, transform.k]);\n\n const [lassoRect, setLassoRect] = useState<NodeView | null>(null);\n\n const [connectLineState, setConnectLineState] =\n useState<ConnectLineState | null>(null);\n\n const { centered, setCentered, getNextLayoutKey } = useLayout({\n layout,\n layoutOptions,\n rootRef,\n cells,\n zoomable,\n zoomer,\n scaleRange,\n layoutKey,\n allowEdgeToArea,\n dispatch,\n });\n\n useImperativeHandle(\n ref,\n () => ({\n dropNode(node) {\n // Do not apply auto centering when dropping a node in manual layout.\n if (layout !== \"dagre\" && layout !== \"force\") {\n setCentered(true);\n }\n dispatch({ type: \"drop-node\", payload: node });\n },\n dropDecorator(decorator) {\n // Do not apply auto centering when dropping a decorator in manual layout.\n if (layout !== \"dagre\" && layout !== \"force\") {\n setCentered(true);\n }\n dispatch({ type: \"drop-decorator\", payload: decorator });\n },\n addNodes(\n nodes,\n { defaultNodeSize, canvasWidth, canvasHeight }: AddNodesContext\n ) {\n const index =\n cells.findLastIndex(\n (cell) => !(cell.type === \"decorator\" && cell.decorator === \"text\")\n ) + 1;\n const newCells = [\n ...cells.slice(0, index),\n ...nodes,\n ...cells.slice(index),\n ];\n const {\n cells: allCells,\n updated,\n shouldReCenter,\n } = updateCells({\n cells: newCells,\n layout,\n previousCells: cells,\n defaultNodeSize,\n canvasWidth,\n canvasHeight,\n scaleRange,\n transform,\n allowEdgeToArea,\n });\n if (shouldReCenter) {\n setCentered(false);\n }\n dispatch({ type: \"update-cells\", payload: allCells });\n return updated.filter((node) =>\n nodes.includes(node as NodeCell)\n ) as NodeCell[];\n },\n addEdge(edge) {\n dispatch({ type: \"add-edge\", payload: edge });\n },\n updateCells(newCells, ctx) {\n const { shouldReCenter, ...result } = updateCells({\n ...ctx,\n layout,\n previousCells: cells,\n cells: newCells,\n scaleRange,\n transform,\n allowEdgeToArea,\n });\n if (shouldReCenter) {\n setCentered(false);\n }\n dispatch({ type: \"update-cells\", payload: result.cells });\n return result;\n },\n getTransform() {\n return transform;\n },\n manuallyConnectNodes(sourceId) {\n const source = cells.find(\n (cell) =>\n ((allowEdgeToArea && isNodeOrAreaDecoratorCell(cell)) ||\n isNodeCell(cell)) &&\n cell.id === sourceId\n ) as NodeCell | DecoratorCell | undefined;\n if (source) {\n const rect = rootRef.current!.getBoundingClientRect();\n setConnectLineState({\n source,\n from: [\n source.view.x + source.view.width / 2,\n source.view.y + source.view.height / 2,\n ],\n offset: [rect.left, rect.top],\n });\n const promise = new Promise<ConnectNodesDetail>((resolve, reject) => {\n manualConnectDeferredRef.current = { resolve, reject };\n });\n return promise;\n }\n return Promise.reject(null);\n },\n }),\n [cells, layout, scaleRange, setCentered, transform, allowEdgeToArea]\n );\n\n const handleConnect = useCallback(\n (state: ConnectLineState, to: PositionTuple) => {\n // Find the target node from top bo bottom,\n // detect whether the pointer is inside the target node.\n for (let i = cells.length - 1; i >= 0; i--) {\n const cell = cells[i];\n // Currently ignore connecting to self\n if (\n ((allowEdgeToArea && isNodeOrAreaDecoratorCell(cell)) ||\n isNodeCell(cell)) &&\n cell.id !== state.source.id\n ) {\n if (\n cell.view.x < to[0] &&\n cell.view.x + cell.view.width > to[0] &&\n cell.view.y < to[1] &&\n cell.view.y + cell.view.height > to[1]\n ) {\n manualConnectDeferredRef.current?.resolve({\n source: state.source,\n target: cell,\n });\n break;\n }\n }\n }\n manualConnectDeferredRef.current?.reject(null);\n setConnectLineState(null);\n },\n [cells]\n );\n 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 cellsRef,\n activeTarget: _activeTarget,\n onActiveTargetChange,\n });\n\n const [unrelatedCells, setUnrelatedCells] = useState<Cell[]>([]);\n useEffect(() => {\n const nextUnrelated = fadeUnrelatedCells\n ? getUnrelatedCells(\n cells,\n connectLineState,\n activeTarget,\n allowEdgeToArea\n )\n : [];\n // Do not update the state when prev and next are both empty.\n setUnrelatedCells((prev) =>\n prev.length === 0 && nextUnrelated.length === 0 ? prev : nextUnrelated\n );\n }, [\n activeTarget,\n cells,\n connectLineState,\n fadeUnrelatedCells,\n allowEdgeToArea,\n ]);\n\n useEffect(() => {\n const root = rootRef.current;\n if (!root || editingTexts.length > 0) {\n return;\n }\n const onKeydown = (event: KeyboardEvent) => {\n const action = handleKeyboard(event, {\n cells,\n activeTarget,\n });\n\n switch (action?.action) {\n case \"delete-cells\":\n onCellsDelete(action.cells);\n if (action.cells.length === 1) {\n onCellDelete(action.cells[0]);\n }\n break;\n }\n };\n root.addEventListener(\"keydown\", onKeydown);\n return () => {\n root.removeEventListener(\"keydown\", onKeydown);\n };\n }, [activeTarget, cells, editingTexts.length, onCellDelete, onCellsDelete]);\n\n const defPrefix = useMemo(() => `${uniqueId(\"diagram-\")}-`, []);\n const markerPrefix = `${defPrefix}line-arrow-`;\n\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\n const reCenter = useCallback(() => {\n setCentered(false);\n }, [setCentered]);\n const { lineConfMap, lineConnectorConf, markers } = useLineMarkers({\n cells,\n defaultEdgeLines,\n lineConnector,\n markerPrefix,\n });\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 handleCellMouseEnter = useCallback(\n (cell: Cell) => {\n if (lineConnectorConf && isNodeCell(cell)) {\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 [lineConnectorConf]\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 const hoverStateContextValue = useMemo(\n () => ({\n rootRef,\n smartConnectLineState,\n unsetHoverStateTimeoutRef,\n hoverState,\n setHoverState,\n setSmartConnectLineState,\n onConnect(\n source: NodeCell,\n target: NodeCell,\n exitPosition: NodePosition,\n entryPosition: NodePosition\n ) {\n const newEdge: EdgeCell = {\n type: \"edge\",\n source: source.id,\n target: target.id,\n view: {\n exitPosition,\n entryPosition,\n ...(isObject(lineConnector) ? lineConnector : null),\n },\n };\n dispatch({\n type: \"add-edge\",\n payload: newEdge,\n });\n onEdgeAdd(newEdge);\n },\n }),\n [smartConnectLineState, hoverState, lineConnector, onEdgeAdd]\n );\n\n useEffect(() => {\n const root = rootRef.current;\n if (!root || dragBehavior !== \"lasso\") {\n return;\n }\n const rootRect = root.getBoundingClientRect();\n const onMouseDown = (event: MouseEvent) => {\n handleLasso(event, {\n transform,\n offset: [rootRect.left, rootRect.top],\n onLassoing(rect) {\n setLassoRect(rect);\n },\n onLassoed(rect) {\n setLassoRect(null);\n const lassoedCells: (NodeCell | DecoratorCell)[] = [];\n for (const cell of cells) {\n if (\n isContainerDecoratorCell(cell) ||\n isNodeOrAreaDecoratorCell(cell) ||\n isTextDecoratorCell(cell)\n ) {\n const x = cell.view.x;\n const y = cell.view.y;\n if (\n x >= rect.x &&\n x + cell.view.width <= rect.x + rect.width &&\n y >= rect.y &&\n y + cell.view.height <= rect.y + rect.height\n ) {\n lassoedCells.push(cell);\n }\n }\n }\n onSwitchActiveTarget?.(\n lassoedCells.length > 1\n ? { type: \"multi\", targets: lassoedCells.map(cellToTarget) }\n : lassoedCells.length === 1\n ? cellToTarget(lassoedCells[0])\n : null\n );\n },\n });\n };\n root.addEventListener(\"mousedown\", onMouseDown);\n return () => {\n root.removeEventListener(\"mousedown\", onMouseDown);\n };\n }, [transform, cells, dragBehavior, onSwitchActiveTarget]);\n\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=\"arrow\"\n strokeColor={marker.strokeColor}\n />\n ))}\n </defs>\n <g\n transform={`translate(${transform.x} ${transform.y}) scale(${transform.k})`}\n >\n <g\n className={classNames(\"cells\", { allowEdgeToArea })}\n ref={cellsRef}\n >\n {cells.map((cell) => (\n <CellComponent\n key={`${cell.type}:${isEdgeCell(cell) ? `${cell.source}~${cell.target}` : cell.id}`}\n dragNodeToContainerActive={\n isEdgeCell(cell) ? false : activeContainers.includes(cell.id)\n }\n layout={layout}\n layoutOptions={layoutOptions}\n cell={cell}\n cells={cells}\n degraded={degraded}\n degradedNodeLabel={degradedNodeLabel}\n defaultNodeBricks={defaultNodeBricks}\n transform={transform}\n lineConfMap={lineConfMap}\n activeTarget={activeTarget}\n unrelatedCells={unrelatedCells}\n onCellsMoving={handleCellsMoving}\n onCellsMoved={handleCellsMoved}\n onCellResizing={handleCellResizing}\n onCellResized={handleCellResized}\n onSwitchActiveTarget={onSwitchActiveTarget}\n onCellContextMenu={onCellContextMenu}\n onDecoratorTextChange={onDecoratorTextChange}\n onDecoratorTextEditing={handleDecoratorTextEditing}\n onNodeBrickResize={handleNodeBrickResize}\n onCellMouseEnter={handleCellMouseEnter}\n onCellMouseLeave={handleCellMouseLeave}\n />\n ))}\n </g>\n <ConnectLineComponent\n connectLineState={connectLineState}\n transform={transform}\n markerEnd={`${markerPrefix}0`}\n onConnect={handleConnect}\n />\n {lassoRect && (\n <rect\n x={lassoRect.x}\n y={lassoRect.y}\n width={lassoRect.width}\n height={lassoRect.height}\n fill=\"var(--palette-gray-5)\"\n fillOpacity={0.3}\n stroke=\"var(--palette-gray-5)\"\n strokeDasharray={2}\n />\n )}\n {lineConnectorConf && (\n <SmartConnectLineComponent\n smartConnectLineState={smartConnectLineState}\n transform={transform}\n options={lineConnectorConf}\n />\n )}\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 />\n ))}\n </g>\n {lineConnectorConf && (\n <LineConnectorComponent\n activeTarget={activeTarget}\n transform={transform}\n disabled={!!connectLineState}\n smartConnectLineState={smartConnectLineState}\n />\n )}\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 viewWithBorder: NodeView = {\n x: view.x + border / 2,\n y: view.y + border / 2,\n width: view.width - border,\n height: view.height - border,\n };\n\n return relativePoints.map((p) => ({\n x: viewWithBorder.x + p.x * viewWithBorder.width,\n y: viewWithBorder.y + p.y * viewWithBorder.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","_EoDrawCanvas_brand","WeakSet","_handleActiveTargetChange","_handleSwitchActiveTarget","_T","_U","_handleCellMove","_V","_handleCellsMove","_W","_handleCellResize","_X","_Y","_handleCellDelete","_Z","_handleCellsDelete","_a","_handleCellContextMenu","_b","_handleEdgeAdd","_c","_handleDecoratorTextChange","_d","_handleContainerContainerChange","_e","_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_lineConnector","_init_extra_lineConnector","_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_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","lineConnector","dropNode","_ref","_document$elementsFro","_document","id","position","size","data","useBrick","document","elementsFromPoint","call","includes","_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","canvasWidth","clientWidth","canvasHeight","clientHeight","addEdge","_ref4","_classPrivateFieldGet4","source","newEdge","manuallyConnectNodes","updateCells","ctx","_assertClassBrand","_waitForCanvasRef","updated","disconnectedCallback","super","render","host","ref","onActiveTargetChange","onSwitchActiveTarget","onCellMove","onCellsMove","onCellResize","onCellDelete","onCellsDelete","onEdgeAdd","onCellContextMenu","onDecoratorTextChange","onContainerContainerChange","onScaleChange","Promise","resolve","check","setTimeout","_ref5","initialCells","_activeTarget","_scaleRange","layoutKey","dispatch","useReducer","rootReducer","initializeCells","degraded","useMemo","filter","isNodeCell","DEFAULT_DEGRADED_THRESHOLD","rootRef","useRef","cellsRef","manualConnectDeferredRef","editingTexts","setEditingTexts","useState","activeContainers","setActiveContainers","grabbing","zoomer","useZoom","draggable","ctrlDraggable","useEffect","lassoRect","setLassoRect","connectLineState","setConnectLineState","centered","setCentered","getNextLayoutKey","useLayout","useImperativeHandle","node","payload","_ref6","index","findLastIndex","newCells","slice","allCells","shouldReCenter","previousCells","result","sourceId","find","isNodeOrAreaDecoratorCell","rect","from","offset","reject","handleConnect","useCallback","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","handleCellsMoved","handleCellResizing","handleCellResized","handleDecoratorTextEditing","_ref7","editing","texts","handleNodeBrickResize","nextLayoutKey","handleZoomSlide","value","scaleTo","select","reCenter","lineConfMap","lineConnectorConf","markers","useLineMarkers","ready","useReady","hoverState","setHoverState","unsetHoverStateTimeoutRef","handleCellMouseEnter","clearTimeout","relativePoints","getConnectPointsOfRectangle","points","getConnectPoints","handleCellMouseLeave","hoverStateContextValue","onConnect","exitPosition","entryPosition","isObject","rootRect","onMouseDown","handleLasso","onLassoing","onLassoed","lassoedCells","isContainerDecoratorCell","isTextDecoratorCell","targets","cellToTarget","HoverStateContext","Provider","className","classNames","tabIndex","marker","MarkerComponent","key","strokeColor","CellComponent","isEdgeCell","dragNodeToContainerActive","onCellsMoving","onCellsMoved","onCellResizing","onCellResized","onDecoratorTextEditing","onNodeBrickResize","onCellMouseEnter","onCellMouseLeave","ConnectLineComponent","markerEnd","fill","fillOpacity","stroke","strokeDasharray","SmartConnectLineComponent","options","line","d","join","LineConnectorComponent","disabled","ZoomBarComponent","shadowRoot","onZoomChange","onReCenter","replace","r","Math","random","toString","border","undefined","viewWithBorder","p","_EoDrawCanvas2","e","_set_activeTargetChangeEvent","_set_nodeMoveEvent","_set_cellMoveEvent","_set_cellsMoveEvent","_set_cellResizeEvent","_set_nodeDelete","_set_cellDelete","_set_cellsDelete","_set_cellContextMenu","_set_edgeAdd","_set_decoratorTextChange","_set_containerContainerChange","_set_scaleChange","_initClass","_applyDecs","styleTexts","styleText","zoomBarStyleText","attribute","String","Number","Boolean","o","_","has","_checkInRHS"],"sourceRoot":""}
|
|
1
|
+
{"version":3,"file":"chunks/eo-draw-canvas.79b100f8.js","mappings":"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","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 { isObject, unwrapProvider } from \"@next-core/utils/general\";\nimport \"@next-core/theme\";\nimport { uniqueId } from \"lodash\";\nimport classNames from \"classnames\";\nimport { select } from \"d3-selection\";\nimport type { lockBodyScroll as _lockBodyScroll } from \"@next-bricks/basic/data-providers/lock-body-scroll/lock-body-scroll\";\nimport type {\n 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} from \"./interfaces\";\nimport { rootReducer } from \"./reducers\";\nimport { MarkerComponent } from \"../diagram/MarkerComponent\";\nimport {\n isContainerDecoratorCell,\n isEdgeCell,\n isNodeCell,\n isNodeOrAreaDecoratorCell,\n isTextDecoratorCell,\n} from \"./processors/asserts\";\nimport type {\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} 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\";\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 lineConnector?: LineConnecterConf | boolean;\n allowEdgeToArea?: boolean;\n}\n\nexport type DragBehavior = \"none\" | \"lasso\" | \"grab\";\nexport type CtrlDragBehavior = \"none\" | \"grab\";\n\nexport interface DropNodeInfo extends AddNodeInfo {\n /** [PointerEvent::clientX, PointerEvent::clientY] */\n position: PositionTuple;\n}\n\nexport interface DropDecoratorInfo {\n decorator: DecoratorType;\n /** [PointerEvent::clientX, PointerEvent::clientY] */\n position: PositionTuple;\n text?: string;\n direction?: Direction;\n}\n\nexport interface AddNodeInfo {\n id: NodeId;\n useBrick?: UseSingleBrickConf;\n data?: unknown;\n size?: SizeTuple;\n}\n\nexport interface AddEdgeInfo {\n source: NodeId;\n target: NodeId;\n data?: unknown;\n}\n\nexport interface UpdateCellsContext {\n reason: \"add-related-nodes\";\n parent: NodeId;\n}\n\nexport interface AddNodesContext {\n defaultNodeSize: SizeTuple;\n canvasWidth: number;\n canvasHeight: number;\n}\n\nexport const EoDrawCanvasComponent = React.forwardRef(\n LegacyEoDrawCanvasComponent\n);\n\n/**\n * 用于手工绘图的画布。\n *\n * 注意:将配套另外一个用于展示的画布构件。\n */\nexport\n@defineElement(\"eo-draw-canvas\", {\n styleTexts: [styleText, zoomBarStyleText],\n})\nclass EoDrawCanvas extends ReactNextElement implements EoDrawCanvasProps {\n /**\n * 仅当初始化时使用,渲染后重新设置 `cells` 将无效。\n */\n @property({ attribute: false })\n accessor cells: InitialCell[] | undefined;\n\n @property({ type: String })\n accessor layout: LayoutType;\n\n @property({ attribute: false })\n accessor layoutOptions: LayoutOptions | undefined;\n\n @property({ attribute: false })\n accessor defaultNodeSize: SizeTuple = [DEFAULT_NODE_SIZE, DEFAULT_NODE_SIZE];\n\n @property({ attribute: false })\n accessor defaultNodeBricks: NodeBrickConf[] | undefined;\n\n /**\n * 当节点数量达到或超过 `degradedThreshold` 时,节点将被降级展示。\n *\n * @default 500\n */\n @property({ type: Number })\n accessor degradedThreshold: number | undefined;\n\n // Set `attribute` to `false` 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 lineConnector: LineConnecterConf | 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<EdgeCell>;\n\n #handleEdgeAdd = (edge: EdgeCell) => {\n this.#edgeAdd.emit(edge);\n };\n\n @event({ type: \"decorator.text.change\" })\n accessor #decoratorTextChange!: EventEmitter<DecoratorTextChangeDetail>;\n\n #handleDecoratorTextChange = (detail: DecoratorTextChangeDetail) => {\n this.#decoratorTextChange.emit(detail);\n };\n\n /**\n * node节点跟容器组关系改变事件,有containerCell是新增关系,否则删除关系\n */\n @event({ type: \"node.container.change\" })\n accessor #containerContainerChange!: EventEmitter<MoveCellPayload[]>;\n\n #handleContainerContainerChange = (detail: MoveCellPayload[]) => {\n this.#containerContainerChange.emit(detail);\n };\n\n /**\n * 缩放变化后,从素材库拖拽元素进画布时,拖拽图像应设置对应的缩放比例。\n */\n @event({ type: \"scale.change\" })\n accessor #scaleChange!: EventEmitter<number>;\n\n #handleScaleChange = (scale: number) => {\n this.#scaleChange.emit(scale);\n };\n\n @method()\n async dropNode({\n id,\n position,\n size,\n data,\n useBrick,\n }: DropNodeInfo): Promise<NodeCell | null> {\n // Drag and then drop a node\n const droppedInside = document\n .elementsFromPoint?.(position[0], position[1])\n ?.includes(this);\n if (droppedInside) {\n const boundingClientRect = this.getBoundingClientRect();\n const transform = this.#canvasRef.current!.getTransform();\n const newNode = {\n type: \"node\",\n id,\n view: {\n ...(this.layout === \"force\" || this.layout === \"dagre\"\n ? null\n : {\n x:\n (position[0] - boundingClientRect.left - transform.x) /\n transform.k,\n y:\n (position[1] - boundingClientRect.top - transform.y) /\n transform.k,\n }),\n width: size?.[0] ?? this.defaultNodeSize[0],\n height: size?.[1] ?? this.defaultNodeSize[0],\n },\n data,\n useBrick,\n } as NodeCell;\n this.#canvasRef.current?.dropNode(newNode);\n return newNode;\n }\n return null;\n }\n\n @method()\n async dropDecorator({\n position,\n decorator,\n text,\n direction,\n }: DropDecoratorInfo): Promise<DecoratorCell | null> {\n // Drag and then drop a node\n const droppedInside = document\n .elementsFromPoint?.(position[0], position[1])\n ?.includes(this);\n if (droppedInside) {\n const boundingClientRect = this.getBoundingClientRect();\n const transform = this.#canvasRef.current!.getTransform();\n const newDecorator: DecoratorCell = {\n type: \"decorator\",\n decorator,\n id: uuidV4(),\n view: {\n x:\n (position[0] - boundingClientRect.left - transform.x) / transform.k,\n y: (position[1] - boundingClientRect.top - transform.y) / transform.k,\n width: DEFAULT_AREA_WIDTH,\n height: DEFAULT_AREA_HEIGHT,\n text,\n direction,\n },\n };\n this.#canvasRef.current?.dropDecorator(newDecorator);\n return newDecorator;\n }\n return null;\n }\n\n @method()\n async addNodes(nodes: AddNodeInfo[]): Promise<NodeCell[]> {\n if (nodes.length === 0) {\n return [];\n }\n const newNodes = nodes.map<NodeCell>(({ size, useBrick, id, data }) => ({\n type: \"node\",\n id,\n data,\n view: {\n width: size?.[0] ?? this.defaultNodeSize[0],\n height: size?.[1] ?? this.defaultNodeSize[0],\n } as NodeView,\n useBrick,\n }));\n return this.#canvasRef.current!.addNodes(newNodes, {\n defaultNodeSize: this.defaultNodeSize,\n canvasWidth: this.clientWidth,\n canvasHeight: this.clientHeight,\n });\n }\n\n @method()\n async addEdge({ source, target, data }: AddEdgeInfo): Promise<EdgeCell> {\n const newEdge: EdgeCell = {\n type: \"edge\",\n source,\n target,\n data,\n };\n this.#canvasRef.current?.addEdge(newEdge);\n return newEdge;\n }\n\n @method()\n manuallyConnectNodes(source: NodeId): Promise<ConnectNodesDetail> {\n return this.#canvasRef.current!.manuallyConnectNodes(source);\n }\n\n @method()\n async updateCells(\n cells: InitialCell[],\n ctx?: UpdateCellsContext\n ): Promise<{ updated: Cell[] }> {\n await this.#waitForCanvasRef();\n const { updated } = this.#canvasRef.current!.updateCells(cells, {\n ...ctx,\n defaultNodeSize: this.defaultNodeSize,\n canvasWidth: this.clientWidth,\n canvasHeight: this.clientHeight,\n });\n return { updated };\n }\n\n #waitForCanvasRef() {\n return new Promise<void>((resolve) => {\n const check = () => {\n if (this.#canvasRef.current) {\n resolve();\n } else {\n setTimeout(check, 10);\n }\n };\n check();\n });\n }\n\n #canvasRef = createRef<DrawCanvasRef>();\n\n disconnectedCallback(): void {\n super.disconnectedCallback();\n lockBodyScroll(this, false);\n }\n\n render() {\n return (\n <EoDrawCanvasComponent\n host={this}\n ref={this.#canvasRef}\n layout={this.layout}\n layoutOptions={this.layoutOptions}\n cells={this.cells}\n defaultNodeSize={this.defaultNodeSize}\n defaultNodeBricks={this.defaultNodeBricks}\n defaultEdgeLines={this.defaultEdgeLines}\n degradedThreshold={this.degradedThreshold}\n degradedNodeLabel={this.degradedNodeLabel}\n activeTarget={this.activeTarget}\n fadeUnrelatedCells={this.fadeUnrelatedCells}\n zoomable={this.zoomable}\n scrollable={this.scrollable}\n pannable={this.pannable}\n dragBehavior={this.dragBehavior}\n ctrlDragBehavior={this.ctrlDragBehavior}\n scaleRange={this.scaleRange}\n lineConnector={this.lineConnector}\n allowEdgeToArea={this.allowEdgeToArea}\n onActiveTargetChange={this.#handleActiveTargetChange}\n onSwitchActiveTarget={this.#handleSwitchActiveTarget}\n onCellMove={this.#handleCellMove}\n onCellsMove={this.#handleCellsMove}\n onCellResize={this.#handleCellResize}\n onCellDelete={this.#handleCellDelete}\n onCellsDelete={this.#handleCellsDelete}\n onEdgeAdd={this.#handleEdgeAdd}\n onCellContextMenu={this.#handleCellContextMenu}\n onDecoratorTextChange={this.#handleDecoratorTextChange}\n onContainerContainerChange={this.#handleContainerContainerChange}\n onScaleChange={this.#handleScaleChange}\n />\n );\n }\n}\n\nexport interface EoDrawCanvasComponentProps extends EoDrawCanvasProps {\n host: HTMLElement;\n onActiveTargetChange(target: ActiveTarget | null): void;\n onSwitchActiveTarget(target: ActiveTarget | null): void;\n onCellMove(info: MoveCellPayload): void;\n onCellResize(cell: ResizeCellPayload): void;\n onCellDelete(cell: Cell): void;\n onCellsMove(info: MoveCellPayload[]): void;\n onCellsDelete(cells: Cell[]): void;\n onCellContextMenu(detail: CellContextMenuDetail): void;\n onEdgeAdd(detail: EdgeCell): void;\n onDecoratorTextChange(detail: DecoratorTextChangeDetail): void;\n onContainerContainerChange(detail: MoveCellPayload[]): void;\n onScaleChange(scale: number): void;\n}\n\nexport interface DrawCanvasRef {\n dropNode(node: NodeCell): void;\n dropDecorator(decorator: DecoratorCell): void;\n addNodes(nodes: NodeCell[], ctx: AddNodesContext): NodeCell[];\n addEdge(edge: EdgeCell): void;\n manuallyConnectNodes(source: NodeId): Promise<ConnectNodesDetail>;\n updateCells(\n cells: InitialCell[],\n ctx: Partial<UpdateCellsContext> & {\n defaultNodeSize: SizeTuple;\n canvasWidth: number;\n canvasHeight: number;\n }\n ): {\n cells: Cell[];\n updated: Cell[];\n };\n getTransform(): TransformLiteral;\n}\n\nfunction LegacyEoDrawCanvasComponent(\n {\n host,\n layout,\n layoutOptions,\n cells: initialCells,\n defaultNodeSize,\n defaultNodeBricks,\n defaultEdgeLines,\n degradedThreshold,\n degradedNodeLabel,\n activeTarget: _activeTarget,\n fadeUnrelatedCells,\n zoomable,\n scrollable,\n pannable,\n dragBehavior,\n ctrlDragBehavior,\n scaleRange: _scaleRange,\n lineConnector,\n allowEdgeToArea,\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 }: EoDrawCanvasComponentProps,\n ref: React.Ref<DrawCanvasRef>\n) {\n const [{ cells, layoutKey }, dispatch] = useReducer(\n rootReducer,\n initialCells,\n (initialCells) => ({\n cells: initializeCells(initialCells, { defaultNodeSize }),\n layoutKey: 0,\n })\n );\n\n // When nodes are greater or equal to threshold, the diagram will be degraded.\n // Thus all nodes will be displayed as simple svg elements instead of bricks.\n const degraded = useMemo(\n () =>\n cells.filter(isNodeCell).length >=\n (degradedThreshold ?? DEFAULT_DEGRADED_THRESHOLD),\n [cells, degradedThreshold]\n );\n\n const rootRef = useRef<SVGSVGElement>(null);\n const cellsRef = useRef<SVGGElement>(null);\n const manualConnectDeferredRef = useRef<Deferred<ConnectNodesDetail> | null>(\n null\n );\n const [editingTexts, setEditingTexts] = useState<string[]>([]);\n const [activeContainers, setActiveContainers] = useState<string[]>([]);\n const { grabbing, transform, zoomer, scaleRange } = useZoom({\n rootRef,\n zoomable,\n scrollable,\n pannable,\n draggable: dragBehavior === \"grab\",\n ctrlDraggable: ctrlDragBehavior === \"grab\",\n scaleRange: _scaleRange,\n onSwitchActiveTarget,\n });\n\n useEffect(() => {\n onScaleChange(transform.k);\n }, [onScaleChange, transform.k]);\n\n const [lassoRect, setLassoRect] = useState<NodeView | null>(null);\n\n const [connectLineState, setConnectLineState] =\n useState<ConnectLineState | null>(null);\n\n const { centered, setCentered, getNextLayoutKey } = useLayout({\n layout,\n layoutOptions,\n rootRef,\n cells,\n zoomable,\n zoomer,\n scaleRange,\n layoutKey,\n allowEdgeToArea,\n dispatch,\n });\n\n useImperativeHandle(\n ref,\n () => ({\n dropNode(node) {\n // Do not apply auto centering when dropping a node in manual layout.\n if (layout !== \"dagre\" && layout !== \"force\") {\n setCentered(true);\n }\n dispatch({ type: \"drop-node\", payload: node });\n },\n dropDecorator(decorator) {\n // Do not apply auto centering when dropping a decorator in manual layout.\n if (layout !== \"dagre\" && layout !== \"force\") {\n setCentered(true);\n }\n dispatch({ type: \"drop-decorator\", payload: decorator });\n },\n addNodes(\n nodes,\n { defaultNodeSize, canvasWidth, canvasHeight }: AddNodesContext\n ) {\n const index =\n cells.findLastIndex(\n (cell) => !(cell.type === \"decorator\" && cell.decorator === \"text\")\n ) + 1;\n const newCells = [\n ...cells.slice(0, index),\n ...nodes,\n ...cells.slice(index),\n ];\n const {\n cells: allCells,\n updated,\n shouldReCenter,\n } = updateCells({\n cells: newCells,\n layout,\n previousCells: cells,\n defaultNodeSize,\n canvasWidth,\n canvasHeight,\n scaleRange,\n transform,\n allowEdgeToArea,\n });\n if (shouldReCenter) {\n setCentered(false);\n }\n dispatch({ type: \"update-cells\", payload: allCells });\n return updated.filter((node) =>\n nodes.includes(node as NodeCell)\n ) as NodeCell[];\n },\n addEdge(edge) {\n dispatch({ type: \"add-edge\", payload: edge });\n },\n updateCells(newCells, ctx) {\n const { shouldReCenter, ...result } = updateCells({\n ...ctx,\n layout,\n previousCells: cells,\n cells: newCells,\n scaleRange,\n transform,\n allowEdgeToArea,\n });\n if (shouldReCenter) {\n setCentered(false);\n }\n dispatch({ type: \"update-cells\", payload: result.cells });\n return result;\n },\n getTransform() {\n return transform;\n },\n manuallyConnectNodes(sourceId) {\n const source = cells.find(\n (cell) =>\n ((allowEdgeToArea && isNodeOrAreaDecoratorCell(cell)) ||\n isNodeCell(cell)) &&\n cell.id === sourceId\n ) as NodeCell | DecoratorCell | undefined;\n if (source) {\n const rect = rootRef.current!.getBoundingClientRect();\n setConnectLineState({\n source,\n from: [\n source.view.x + source.view.width / 2,\n source.view.y + source.view.height / 2,\n ],\n offset: [rect.left, rect.top],\n });\n const promise = new Promise<ConnectNodesDetail>((resolve, reject) => {\n manualConnectDeferredRef.current = { resolve, reject };\n });\n return promise;\n }\n return Promise.reject(null);\n },\n }),\n [cells, layout, scaleRange, setCentered, transform, allowEdgeToArea]\n );\n\n const handleConnect = useCallback(\n (state: ConnectLineState, to: PositionTuple) => {\n // Find the target node from top bo bottom,\n // detect whether the pointer is inside the target node.\n for (let i = cells.length - 1; i >= 0; i--) {\n const cell = cells[i];\n // Currently ignore connecting to self\n if (\n ((allowEdgeToArea && isNodeOrAreaDecoratorCell(cell)) ||\n isNodeCell(cell)) &&\n cell.id !== state.source.id\n ) {\n if (\n cell.view.x < to[0] &&\n cell.view.x + cell.view.width > to[0] &&\n cell.view.y < to[1] &&\n cell.view.y + cell.view.height > to[1]\n ) {\n manualConnectDeferredRef.current?.resolve({\n source: state.source,\n target: cell,\n });\n break;\n }\n }\n }\n manualConnectDeferredRef.current?.reject(null);\n setConnectLineState(null);\n },\n [cells]\n );\n 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 cellsRef,\n activeTarget: _activeTarget,\n onActiveTargetChange,\n });\n\n const [unrelatedCells, setUnrelatedCells] = useState<Cell[]>([]);\n useEffect(() => {\n const nextUnrelated = fadeUnrelatedCells\n ? getUnrelatedCells(\n cells,\n connectLineState,\n activeTarget,\n allowEdgeToArea\n )\n : [];\n // Do not update the state when prev and next are both empty.\n setUnrelatedCells((prev) =>\n prev.length === 0 && nextUnrelated.length === 0 ? prev : nextUnrelated\n );\n }, [\n activeTarget,\n cells,\n connectLineState,\n fadeUnrelatedCells,\n allowEdgeToArea,\n ]);\n\n useEffect(() => {\n const root = rootRef.current;\n if (!root || editingTexts.length > 0) {\n return;\n }\n const onKeydown = (event: KeyboardEvent) => {\n const action = handleKeyboard(event, {\n cells,\n activeTarget,\n });\n\n switch (action?.action) {\n case \"delete-cells\":\n onCellsDelete(action.cells);\n if (action.cells.length === 1) {\n onCellDelete(action.cells[0]);\n }\n break;\n }\n };\n root.addEventListener(\"keydown\", onKeydown);\n return () => {\n root.removeEventListener(\"keydown\", onKeydown);\n };\n }, [activeTarget, cells, editingTexts.length, onCellDelete, onCellsDelete]);\n\n const defPrefix = useMemo(() => `${uniqueId(\"diagram-\")}-`, []);\n const markerPrefix = `${defPrefix}line-arrow-`;\n\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\n const reCenter = useCallback(() => {\n setCentered(false);\n }, [setCentered]);\n const { lineConfMap, lineConnectorConf, markers } = useLineMarkers({\n cells,\n defaultEdgeLines,\n lineConnector,\n markerPrefix,\n });\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 handleCellMouseEnter = useCallback(\n (cell: Cell) => {\n if (lineConnectorConf && isNodeCell(cell)) {\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 [lineConnectorConf]\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 const hoverStateContextValue = useMemo(\n () => ({\n rootRef,\n smartConnectLineState,\n unsetHoverStateTimeoutRef,\n hoverState,\n setHoverState,\n setSmartConnectLineState,\n onConnect(\n source: NodeCell,\n target: NodeCell,\n exitPosition: NodePosition,\n entryPosition: NodePosition\n ) {\n const newEdge: EdgeCell = {\n type: \"edge\",\n source: source.id,\n target: target.id,\n view: {\n exitPosition,\n entryPosition,\n ...(isObject(lineConnector) ? lineConnector : null),\n },\n };\n dispatch({\n type: \"add-edge\",\n payload: newEdge,\n });\n onEdgeAdd(newEdge);\n },\n }),\n [smartConnectLineState, hoverState, lineConnector, onEdgeAdd]\n );\n\n useEffect(() => {\n const root = rootRef.current;\n if (!root || dragBehavior !== \"lasso\") {\n return;\n }\n const rootRect = root.getBoundingClientRect();\n const onMouseDown = (event: MouseEvent) => {\n handleLasso(event, {\n transform,\n offset: [rootRect.left, rootRect.top],\n onLassoing(rect) {\n setLassoRect(rect);\n },\n onLassoed(rect) {\n setLassoRect(null);\n const lassoedCells: (NodeCell | DecoratorCell)[] = [];\n for (const cell of cells) {\n if (\n isContainerDecoratorCell(cell) ||\n isNodeOrAreaDecoratorCell(cell) ||\n isTextDecoratorCell(cell)\n ) {\n const x = cell.view.x;\n const y = cell.view.y;\n if (\n x >= rect.x &&\n x + cell.view.width <= rect.x + rect.width &&\n y >= rect.y &&\n y + cell.view.height <= rect.y + rect.height\n ) {\n lassoedCells.push(cell);\n }\n }\n }\n onSwitchActiveTarget?.(\n lassoedCells.length > 1\n ? { type: \"multi\", targets: lassoedCells.map(cellToTarget) }\n : lassoedCells.length === 1\n ? cellToTarget(lassoedCells[0])\n : null\n );\n },\n });\n };\n root.addEventListener(\"mousedown\", onMouseDown);\n return () => {\n root.removeEventListener(\"mousedown\", onMouseDown);\n };\n }, [transform, cells, dragBehavior, onSwitchActiveTarget]);\n\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=\"arrow\"\n strokeColor={marker.strokeColor}\n />\n ))}\n </defs>\n <g\n transform={`translate(${transform.x} ${transform.y}) scale(${transform.k})`}\n >\n <g\n className={classNames(\"cells\", { allowEdgeToArea })}\n ref={cellsRef}\n >\n {cells.map((cell) => (\n <CellComponent\n key={`${cell.type}:${isEdgeCell(cell) ? `${cell.source}~${cell.target}` : cell.id}`}\n dragNodeToContainerActive={\n isEdgeCell(cell) ? false : activeContainers.includes(cell.id)\n }\n layout={layout}\n layoutOptions={layoutOptions}\n cell={cell}\n cells={cells}\n degraded={degraded}\n degradedNodeLabel={degradedNodeLabel}\n defaultNodeBricks={defaultNodeBricks}\n transform={transform}\n lineConfMap={lineConfMap}\n activeTarget={activeTarget}\n unrelatedCells={unrelatedCells}\n onCellsMoving={handleCellsMoving}\n onCellsMoved={handleCellsMoved}\n onCellResizing={handleCellResizing}\n onCellResized={handleCellResized}\n onSwitchActiveTarget={onSwitchActiveTarget}\n onCellContextMenu={onCellContextMenu}\n onDecoratorTextChange={onDecoratorTextChange}\n onDecoratorTextEditing={handleDecoratorTextEditing}\n onNodeBrickResize={handleNodeBrickResize}\n onCellMouseEnter={handleCellMouseEnter}\n onCellMouseLeave={handleCellMouseLeave}\n />\n ))}\n </g>\n <ConnectLineComponent\n connectLineState={connectLineState}\n transform={transform}\n markerEnd={`${markerPrefix}0`}\n onConnect={handleConnect}\n />\n {lassoRect && (\n <rect\n x={lassoRect.x}\n y={lassoRect.y}\n width={lassoRect.width}\n height={lassoRect.height}\n fill=\"var(--palette-gray-5)\"\n fillOpacity={0.3}\n stroke=\"var(--palette-gray-5)\"\n strokeDasharray={2}\n />\n )}\n {lineConnectorConf && (\n <SmartConnectLineComponent\n smartConnectLineState={smartConnectLineState}\n transform={transform}\n options={lineConnectorConf}\n />\n )}\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 />\n ))}\n </g>\n {lineConnectorConf && (\n <LineConnectorComponent\n activeTarget={activeTarget}\n transform={transform}\n disabled={!!connectLineState}\n smartConnectLineState={smartConnectLineState}\n />\n )}\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 viewWithBorder: NodeView = {\n x: view.x + border / 2,\n y: view.y + border / 2,\n width: view.width - border,\n height: view.height - border,\n };\n\n return relativePoints.map((p) => ({\n x: viewWithBorder.x + p.x * viewWithBorder.width,\n y: viewWithBorder.y + p.y * viewWithBorder.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","_EoDrawCanvas_brand","WeakSet","_handleActiveTargetChange","_handleSwitchActiveTarget","_T","_U","_handleCellMove","_V","_handleCellsMove","_W","_handleCellResize","_X","_Y","_handleCellDelete","_Z","_handleCellsDelete","_a","_handleCellContextMenu","_b","_handleEdgeAdd","_c","_handleDecoratorTextChange","_d","_handleContainerContainerChange","_e","_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_lineConnector","_init_extra_lineConnector","_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_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","lineConnector","dropNode","_ref","_document$elementsFro","_document","id","position","size","data","useBrick","document","elementsFromPoint","call","includes","_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","canvasWidth","clientWidth","canvasHeight","clientHeight","addEdge","_ref4","_classPrivateFieldGet4","source","newEdge","manuallyConnectNodes","updateCells","ctx","_assertClassBrand","_waitForCanvasRef","updated","disconnectedCallback","super","render","host","ref","onActiveTargetChange","onSwitchActiveTarget","onCellMove","onCellsMove","onCellResize","onCellDelete","onCellsDelete","onEdgeAdd","onCellContextMenu","onDecoratorTextChange","onContainerContainerChange","onScaleChange","Promise","resolve","check","setTimeout","_ref5","initialCells","_activeTarget","_scaleRange","layoutKey","dispatch","useReducer","rootReducer","initializeCells","degraded","useMemo","filter","isNodeCell","DEFAULT_DEGRADED_THRESHOLD","rootRef","useRef","cellsRef","manualConnectDeferredRef","editingTexts","setEditingTexts","useState","activeContainers","setActiveContainers","grabbing","zoomer","useZoom","draggable","ctrlDraggable","useEffect","lassoRect","setLassoRect","connectLineState","setConnectLineState","centered","setCentered","getNextLayoutKey","useLayout","useImperativeHandle","node","payload","_ref6","index","findLastIndex","newCells","slice","allCells","shouldReCenter","previousCells","result","sourceId","find","isNodeOrAreaDecoratorCell","rect","from","offset","reject","handleConnect","useCallback","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","handleCellsMoved","handleCellResizing","handleCellResized","handleDecoratorTextEditing","_ref7","editing","texts","handleNodeBrickResize","nextLayoutKey","handleZoomSlide","value","scaleTo","select","reCenter","lineConfMap","lineConnectorConf","markers","useLineMarkers","ready","useReady","hoverState","setHoverState","unsetHoverStateTimeoutRef","handleCellMouseEnter","clearTimeout","relativePoints","getConnectPointsOfRectangle","points","getConnectPoints","handleCellMouseLeave","hoverStateContextValue","onConnect","exitPosition","entryPosition","isObject","rootRect","onMouseDown","handleLasso","onLassoing","onLassoed","lassoedCells","isContainerDecoratorCell","isTextDecoratorCell","targets","cellToTarget","HoverStateContext","Provider","className","classNames","tabIndex","marker","MarkerComponent","key","strokeColor","CellComponent","isEdgeCell","dragNodeToContainerActive","onCellsMoving","onCellsMoved","onCellResizing","onCellResized","onDecoratorTextEditing","onNodeBrickResize","onCellMouseEnter","onCellMouseLeave","ConnectLineComponent","markerEnd","fill","fillOpacity","stroke","strokeDasharray","SmartConnectLineComponent","options","line","d","join","LineConnectorComponent","disabled","ZoomBarComponent","shadowRoot","onZoomChange","onReCenter","replace","r","Math","random","toString","border","undefined","viewWithBorder","p","_EoDrawCanvas2","e","_set_activeTargetChangeEvent","_set_nodeMoveEvent","_set_cellMoveEvent","_set_cellsMoveEvent","_set_cellResizeEvent","_set_nodeDelete","_set_cellDelete","_set_cellsDelete","_set_cellContextMenu","_set_edgeAdd","_set_decoratorTextChange","_set_containerContainerChange","_set_scaleChange","_initClass","_applyDecs","styleTexts","styleText","zoomBarStyleText","attribute","String","Number","Boolean","o","_","has","_checkInRHS"],"sourceRoot":""}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
(()=>{var e,t,r,n,a,o,l,i,c,s,u,d,f,h,p,m,b,v,g,x,y,P,k,w={7934:(e,t,r)=>{Promise.all([r.e(7507),r.e(3025),r.e(788),r.e(8769),r.e(1030),r.e(4799),r.e(4218),r.e(8610),r.e(6477),r.e(9435),r.e(3204),r.e(564),r.e(3252),r.e(3233),r.e(9711)]).then(r.bind(r,9711))}},j={};function S(e){var t=j[e];if(void 0!==t)return t.exports;var r=j[e]={id:e,loaded:!1,exports:{}};return w[e].call(r.exports,r,r.exports,S),r.loaded=!0,r.exports}S.m=w,S.c=j,S.n=e=>{var t=e&&e.__esModule?()=>e.default:()=>e;return S.d(t,{a:t}),t},S.d=(e,t)=>{for(var r in t)S.o(t,r)&&!S.o(e,r)&&Object.defineProperty(e,r,{enumerable:!0,get:t[r]})},S.f={},S.e=e=>Promise.all(Object.keys(S.f).reduce(((t,r)=>(S.f[r](e,t),t)),[])),S.u=e=>"chunks/"+e+"."+{114:"d27688d7",564:"c34c8ee4",726:"31d83c95",788:"5a8dd377",799:"dd5f32fb",871:"c60deabc",1030:"b2de5ee5",1045:"63c485a7",1122:"dea87200",1302:"4f0b92f3",1370:"8d145ce9",1889:"1d67080e",1940:"e1fdb1c6",2052:"a8ed8891",2277:"0b3548af",3025:"d4a92d85",3136:"ffdcaceb",3144:"94428cca",3171:"2943688e",3204:"e6639cd3",3233:"4eabc5cc",3241:"0acaec0d",3252:"d94ce52c",3426:"ae8ab421",3751:"c544b621",3933:"6624dcbe",4041:"d221940a",4218:"e3ccb934",4658:"d4d0115b",4741:"4a7e366d",4799:"98992dcf",4837:"578ffe7d",4946:"6de8db44",5250:"d0a6e755",5384:"b76b4b24",5399:"1f67d9c4",5552:"e3e4dddb",6314:"2c1f22e1",6477:"1a6ac6f5",6519:"bdf67396",6688:"0764fdb6",6773:"8b791d47",7106:"fa321717",7218:"0b7934fd",7304:"3d0757fa",7507:"f8686358",7721:"6ac62398",7733:"e752ca8f",8610:"6bef21d7",8769:"4c91b468",8989:"0fc5ea84",9435:"904b4066",9515:"4b4e0758",9559:"1cd5e0b2",9654:"c3a806a4",9711:"2d99e6d9",9755:"0a240b26",9844:"4a3a83f7"}[e]+".js",S.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(e){if("object"==typeof window)return window}}(),S.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),e={},t="@next-bricks/diagram:",S.l=(r,n,a,o)=>{if(e[r])e[r].push(n);else{var l,i;if(void 0!==a)for(var c=document.getElementsByTagName("script"),s=0;s<c.length;s++){var u=c[s];if(u.getAttribute("src")==r||u.getAttribute("data-webpack")==t+a){l=u;break}}l||(i=!0,(l=document.createElement("script")).charset="utf-8",l.timeout=120,S.nc&&l.setAttribute("nonce",S.nc),l.setAttribute("data-webpack",t+a),l.src=r),e[r]=[n];var d=(t,n)=>{l.onerror=l.onload=null,clearTimeout(f);var a=e[r];if(delete e[r],l.parentNode&&l.parentNode.removeChild(l),a&&a.forEach((e=>e(n))),t)return t(n)},f=setTimeout(d.bind(null,void 0,{type:"timeout",target:l}),12e4);l.onerror=d.bind(null,l.onerror),l.onload=d.bind(null,l.onload),i&&document.head.appendChild(l)}},S.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},S.nmd=e=>(e.paths=[],e.children||(e.children=[]),e),(()=>{S.S={};var e={},t={};S.I=(r,n)=>{n||(n=[]);var a=t[r];if(a||(a=t[r]={}),!(n.indexOf(a)>=0)){if(n.push(a),e[r])return e[r];S.o(S.S,r)||(S.S[r]={});var o=S.S[r],l="@next-bricks/diagram",i=(e,t,r,n)=>{var a=o[e]=o[e]||{},i=a[t];(!i||!i.loaded&&(!n!=!i.eager?n:l>i.from))&&(a[t]={get:r,from:l,eager:!!n})},c=[];return"default"===r&&(i("@babel/parser","7.25.3",(()=>S.e(6773).then((()=>()=>S(6773))))),i("@easyops-cn/brick-next-pipes","0.6.0",(()=>Promise.all([S.e(4741),S.e(1030),S.e(6688)]).then((()=>()=>S(4741))))),i("@next-core/cook","2.4.9",(()=>Promise.all([S.e(1122),S.e(9654)]).then((()=>()=>S(1122))))),i("@next-core/element","1.2.12",(()=>S.e(1045).then((()=>()=>S(1045))))),i("@next-core/http","1.2.7",(()=>S.e(8989).then((()=>()=>S(8989))))),i("@next-core/i18n","1.0.65",(()=>Promise.all([S.e(4218),S.e(3241),S.e(9755),S.e(5552)]).then((()=>()=>S(5552))))),i("@next-core/inject","1.0.44",(()=>Promise.all([S.e(1030),S.e(7106),S.e(2277)]).then((()=>()=>S(2277))))),i("@next-core/loader","1.6.8",(()=>S.e(5399).then((()=>()=>S(7780))))),i("@next-core/pipes","2.0.25",(()=>S.e(6519).then((()=>()=>S(6519))))),i("@next-core/react-element","1.0.31",(()=>Promise.all([S.e(8769),S.e(4799),S.e(9435),S.e(114)]).then((()=>()=>S(114))))),i("@next-core/react-runtime","1.6.39",(()=>Promise.all([S.e(8769),S.e(1030),S.e(8610),S.e(3204),S.e(4837)]).then((()=>()=>S(4837))))),i("@next-core/runtime","1.54.16",(()=>Promise.all([S.e(7507),S.e(799),S.e(1030),S.e(4218),S.e(1302),S.e(3241),S.e(3136),S.e(4946)]).then((()=>()=>S(799))))),i("@next-core/supply","2.1.21",(()=>Promise.all([S.e(1030),S.e(7106),S.e(1302),S.e(9559)]).then((()=>()=>S(9559))))),i("@next-core/theme","1.5.4",(()=>Promise.all([S.e(1889),S.e(2052)]).then((()=>()=>S(1889))))),i("@next-core/utils/general","1.7.23",(()=>S.e(871).then((()=>()=>S(871))))),i("@next-core/utils/storyboard","1.7.23",(()=>Promise.all([S.e(4218),S.e(3136),S.e(3933)]).then((()=>()=>S(3933))))),i("history","4.10.1",(()=>S.e(5384).then((()=>()=>S(5384))))),i("i18next-browser-languagedetector","7.2.1",(()=>S.e(726).then((()=>()=>S(726))))),i("i18next","22.5.1",(()=>S.e(7304).then((()=>()=>S(7304))))),i("js-yaml","3.14.1",(()=>S.e(9515).then((()=>()=>S(9515))))),i("lodash","4.17.21",(()=>S.e(5250).then((()=>()=>S(5250))))),i("moment/locale/zh-cn.js","2.30.1",(()=>Promise.all([S.e(7721),S.e(9844)]).then((()=>()=>S(1329))))),i("moment","2.30.1",(()=>Promise.all([S.e(7721),S.e(9844)]).then((()=>()=>S(9420))))),i("react-dom","0.0.0-experimental-ee8509801-20230117",(()=>Promise.all([S.e(3144),S.e(8769)]).then((()=>()=>S(3144))))),i("react","0.0.0-experimental-ee8509801-20230117",(()=>S.e(4041).then((()=>()=>S(4041)))))),e[r]=c.length?Promise.all(c).then((()=>e[r]=1)):1}}})(),(()=>{var e;S.g.importScripts&&(e=S.g.location+"");var t=S.g.document;if(!e&&t&&(t.currentScript&&"SCRIPT"===t.currentScript.tagName.toUpperCase()&&(e=t.currentScript.src),!e)){var r=t.getElementsByTagName("script");if(r.length)for(var n=r.length-1;n>-1&&(!e||!/^http(s?):/.test(e));)e=r[n--].src}if(!e)throw new Error("Automatic publicPath is not supported in this browser");e=e.replace(/#.*$/,"").replace(/\?.*$/,"").replace(/\/[^\/]+$/,"/"),S.p=e+"../"})(),r=e=>{var t=e=>e.split(".").map((e=>+e==e?+e:e)),r=/^([^-+]+)?(?:-([^+]+))?(?:\+(.+))?$/.exec(e),n=r[1]?t(r[1]):[];return r[2]&&(n.length++,n.push.apply(n,t(r[2]))),r[3]&&(n.push([]),n.push.apply(n,t(r[3]))),n},n=(e,t)=>{e=r(e),t=r(t);for(var n=0;;){if(n>=e.length)return n<t.length&&"u"!=(typeof t[n])[0];var a=e[n],o=(typeof a)[0];if(n>=t.length)return"u"==o;var l=t[n],i=(typeof l)[0];if(o!=i)return"o"==o&&"n"==i||"s"==i||"u"==o;if("o"!=o&&"u"!=o&&a!=l)return a<l;n++}},a=e=>{var t=e[0],r="";if(1===e.length)return"*";if(t+.5){r+=0==t?">=":-1==t?"<":1==t?"^":2==t?"~":t>0?"=":"!=";for(var n=1,o=1;o<e.length;o++)n--,r+="u"==(typeof(i=e[o]))[0]?"-":(n>0?".":"")+(n=2,i);return r}var l=[];for(o=1;o<e.length;o++){var i=e[o];l.push(0===i?"not("+c()+")":1===i?"("+c()+" || "+c()+")":2===i?l.pop()+" "+l.pop():a(i))}return c();function c(){return l.pop().replace(/^\((.+)\)$/,"$1")}},o=(e,t)=>{if(0 in e){t=r(t);var n=e[0],a=n<0;a&&(n=-n-1);for(var l=0,i=1,c=!0;;i++,l++){var s,u,d=i<e.length?(typeof e[i])[0]:"";if(l>=t.length||"o"==(u=(typeof(s=t[l]))[0]))return!c||("u"==d?i>n&&!a:""==d!=a);if("u"==u){if(!c||"u"!=d)return!1}else if(c)if(d==u)if(i<=n){if(s!=e[i])return!1}else{if(a?s>e[i]:s<e[i])return!1;s!=e[i]&&(c=!1)}else if("s"!=d&&"n"!=d){if(a||i<=n)return!1;c=!1,i--}else{if(i<=n||u<d!=a)return!1;c=!1}else"s"!=d&&"n"!=d&&(c=!1,i--)}}var f=[],h=f.pop.bind(f);for(l=1;l<e.length;l++){var p=e[l];f.push(1==p?h()|h():2==p?h()&h():p?o(p,t):!h())}return!!h()},l=(e,t)=>e&&S.o(e,t),i=e=>(e.loaded=1,e.get()),c=e=>Object.keys(e).reduce(((t,r)=>(e[r].eager&&(t[r]=e[r]),t)),{}),s=(e,t,r,a)=>{var l=a?c(e[t]):e[t];return(t=Object.keys(l).reduce(((e,t)=>!o(r,t)||e&&!n(e,t)?e:t),0))&&l[t]},u=(e,t,r)=>{var a=r?c(e[t]):e[t];return Object.keys(a).reduce(((e,t)=>!e||!a[e].loaded&&n(e,t)?t:e),0)},d=(e,t,r,n)=>"Unsatisfied version "+r+" from "+(r&&e[t][r].from)+" of shared singleton module "+t+" (required "+a(n)+")",f=(e,t,r,n,o)=>{var l=e[r];return"No satisfying version ("+a(n)+")"+(o?" for eager consumption":"")+" of shared module "+r+" found in shared scope "+t+".\nAvailable versions: "+Object.keys(l).map((e=>e+" from "+l[e].from)).join(", ")},h=e=>{throw new Error(e)},p=e=>{"undefined"!=typeof console&&console.warn&&console.warn(e)},b=(e,t,r)=>r?r():((e,t)=>h("Shared module "+t+" doesn't exist in shared scope "+e))(e,t),v=(m=e=>function(t,r,n,a,o){var l=S.I(t);return l&&l.then&&!n?l.then(e.bind(e,t,S.S[t],r,!1,a,o)):e(t,S.S[t],r,n,a,o)})(((e,t,r,n,a,o)=>{if(!l(t,r))return b(e,r,o);var c=s(t,r,a,n);return c?i(c):o?o():void h(f(t,e,r,a,n))})),g=m(((e,t,r,n,a,c)=>{if(!l(t,r))return b(e,r,c);var s=u(t,r,n);return o(a,s)||p(d(t,r,s,a)),i(t[r][s])})),x={},y={8769:()=>v("default","react",!1,[6,0,0,0,,"experimental-ee8509801-20230117"],(()=>S.e(4041).then((()=>()=>S(4041))))),1030:()=>g("default","lodash",!1,[1,4,17,21],(()=>S.e(5250).then((()=>()=>S(5250))))),4799:()=>v("default","@next-core/element",!1,[1,1,2,12],(()=>S.e(3426).then((()=>()=>S(1045))))),4218:()=>g("default","@next-core/utils/general",!1,[1,1,7,23],(()=>S.e(871).then((()=>()=>S(871))))),8610:()=>v("default","@next-core/react-element",!1,[1,1,0,31],(()=>Promise.all([S.e(4799),S.e(9435),S.e(7733)]).then((()=>()=>S(114))))),6477:()=>g("default","@next-core/theme",!1,[1,1,5,4],(()=>S.e(1889).then((()=>()=>S(1889))))),9435:()=>v("default","react-dom",!1,[6,0,0,0,,"experimental-ee8509801-20230117"],(()=>S.e(3144).then((()=>()=>S(3144))))),3204:()=>g("default","@next-core/runtime",!1,[1,1,54,16],(()=>Promise.all([S.e(7507),S.e(799),S.e(4218),S.e(1302),S.e(3241),S.e(3136),S.e(4946)]).then((()=>()=>S(799))))),564:()=>v("default","@next-core/react-runtime",!1,[1,1,6,39],(()=>S.e(7218).then((()=>()=>S(4837))))),3496:()=>g("default","@next-core/http",!1,[1,1,0,6],(()=>S.e(1370).then((()=>()=>S(8989))))),1204:()=>g("default","js-yaml",!1,[1,3,14,0],(()=>S.e(9515).then((()=>()=>S(9515))))),8297:()=>g("default","moment",!1,[1,2,27,0],(()=>Promise.all([S.e(7721),S.e(9844)]).then((()=>()=>S(9420))))),9654:()=>g("default","@babel/parser",!1,[1,7,25,4],(()=>S.e(6773).then((()=>()=>S(6773))))),3241:()=>g("default","@next-core/i18n",!1,[1,1,0,65],(()=>Promise.all([S.e(9755),S.e(3171)]).then((()=>()=>S(5552))))),2350:()=>g("default","i18next",!1,[1,22,5,1],(()=>S.e(7304).then((()=>()=>S(7304))))),7072:()=>g("default","i18next-browser-languagedetector",!1,[1,7,2,1],(()=>S.e(726).then((()=>()=>S(726))))),7106:()=>g("default","@next-core/pipes",!1,[1,2,0,25],(()=>S.e(6519).then((()=>()=>S(6519))))),161:()=>g("default","@easyops-cn/brick-next-pipes",!1,[2,0,6,0],(()=>Promise.all([S.e(4741),S.e(1030),S.e(6688)]).then((()=>()=>S(4741))))),1302:()=>g("default","moment",!1,[1,2,30,1],(()=>Promise.all([S.e(7721),S.e(9844)]).then((()=>()=>S(9420))))),3136:()=>g("default","@next-core/cook",!1,[1,2,4,9],(()=>Promise.all([S.e(1122),S.e(9654)]).then((()=>()=>S(1122))))),2890:()=>g("default","history",!1,[1,4,10,1],(()=>S.e(5384).then((()=>()=>S(5384))))),4130:()=>g("default","@next-core/utils/storyboard",!1,[1,1,7,23],(()=>S.e(6314).then((()=>()=>S(3933))))),5096:()=>g("default","@next-core/loader",!1,[1,1,6,8],(()=>S.e(5399).then((()=>()=>S(7780))))),6036:()=>g("default","moment/locale/zh-cn.js",!1,[1,2,30,1],(()=>Promise.all([S.e(7721),S.e(9844)]).then((()=>()=>S(1329))))),8255:()=>g("default","@next-core/http",!1,[1,1,2,7],(()=>S.e(3751).then((()=>()=>S(8989))))),8502:()=>g("default","@next-core/supply",!1,[1,2,1,21],(()=>Promise.all([S.e(7106),S.e(1940)]).then((()=>()=>S(9559))))),9080:()=>g("default","@next-core/inject",!1,[1,1,0,44],(()=>Promise.all([S.e(7106),S.e(4658)]).then((()=>()=>S(2277)))))},P={564:[564],1030:[1030],1302:[1302],3136:[3136],3204:[3204],3233:[3496],3241:[3241],4218:[4218],4799:[4799],4946:[2890,4130,5096,6036,8255,8502,9080],6477:[6477],6519:[161],6688:[1204,8297],7106:[7106],8610:[8610],8769:[8769],9435:[9435],9654:[9654],9755:[2350,7072]},k={},S.f.consumes=(e,t)=>{S.o(P,e)&&P[e].forEach((e=>{if(S.o(x,e))return t.push(x[e]);if(!k[e]){var r=t=>{x[e]=0,S.m[e]=r=>{delete S.c[e],r.exports=t()}};k[e]=!0;var n=t=>{delete x[e],S.m[e]=r=>{throw delete S.c[e],t}};try{var a=y[e]();a.then?t.push(x[e]=a.then(r).catch(n)):r(a)}catch(e){n(e)}}}))},(()=>{var e={8792:0};S.f.j=(t,r)=>{var n=S.o(e,t)?e[t]:void 0;if(0!==n)if(n)r.push(n[2]);else if(/^(3(136|204|241)|4(218|799|946)|9(435|654|755)|1030|1302|564|6477|6688|7106|8610|8769)$/.test(t))e[t]=0;else{var a=new Promise(((r,a)=>n=e[t]=[r,a]));r.push(n[2]=a);var o=S.p+S.u(t),l=new Error;S.l(o,(r=>{if(S.o(e,t)&&(0!==(n=e[t])&&(e[t]=void 0),n)){var a=r&&("load"===r.type?"missing":r.type),o=r&&r.target&&r.target.src;l.message="Loading chunk "+t+" failed.\n("+a+": "+o+")",l.name="ChunkLoadError",l.type=a,l.request=o,n[1](l)}}),"chunk-"+t,t)}};var t=(t,r)=>{var n,a,[o,l,i]=r,c=0;if(o.some((t=>0!==e[t]))){for(n in l)S.o(l,n)&&(S.m[n]=l[n]);i&&i(S)}for(t&&t(r);c<o.length;c++)a=o[c],S.o(e,a)&&e[a]&&e[a][0](),e[a]=0},r=globalThis.webpackChunk_next_bricks_diagram=globalThis.webpackChunk_next_bricks_diagram||[];r.forEach(t.bind(null,0)),r.push=t.bind(null,r.push.bind(r))})(),S.nc=void 0,S(7934)})();
|
|
2
|
+
//# sourceMappingURL=main.1a8affb8.js.map
|