@next-bricks/diagram 0.50.2 → 0.50.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (55) hide show
  1. package/dist/bricks.json +3 -3
  2. package/dist/chunks/3233.fd1ca80f.js +3 -0
  3. package/dist/chunks/3233.fd1ca80f.js.map +1 -0
  4. package/dist/chunks/4411.1ae59113.js +3 -0
  5. package/dist/chunks/4411.1ae59113.js.map +1 -0
  6. package/dist/chunks/{4837.70d6aed1.js → 4837.695bdc4f.js} +2 -2
  7. package/dist/chunks/{4837.70d6aed1.js.map → 4837.695bdc4f.js.map} +1 -1
  8. package/dist/chunks/5443.6617ae99.js +3 -0
  9. package/dist/chunks/5443.6617ae99.js.map +1 -0
  10. package/dist/chunks/{1124.b5167ef0.js → 5580.818fe55b.js} +2 -2
  11. package/dist/chunks/{1124.b5167ef0.js.map → 5580.818fe55b.js.map} +1 -1
  12. package/dist/chunks/{7218.46d7a966.js → 7218.acbb92c1.js} +2 -2
  13. package/dist/chunks/{7218.46d7a966.js.map → 7218.acbb92c1.js.map} +1 -1
  14. package/dist/chunks/9711.4e8396e8.js +2 -0
  15. package/dist/chunks/9711.4e8396e8.js.map +1 -0
  16. package/dist/chunks/9961.69103a14.js +2 -0
  17. package/dist/chunks/9961.69103a14.js.map +1 -0
  18. package/dist/chunks/editable-label.de9e2540.js +3 -0
  19. package/dist/chunks/editable-label.de9e2540.js.map +1 -0
  20. package/dist/chunks/eo-diagram.5f3935a9.js +2 -0
  21. package/dist/chunks/{eo-diagram.93f17e33.js.map → eo-diagram.5f3935a9.js.map} +1 -1
  22. package/dist/chunks/{eo-display-canvas.d9801bac.js → eo-display-canvas.b5206c2a.js} +2 -2
  23. package/dist/chunks/eo-display-canvas.b5206c2a.js.map +1 -0
  24. package/dist/chunks/eo-draw-canvas.bf162c54.js +2 -0
  25. package/dist/chunks/eo-draw-canvas.bf162c54.js.map +1 -0
  26. package/dist/chunks/main.9ec64d58.js +2 -0
  27. package/dist/chunks/{main.18a3db6f.js.map → main.9ec64d58.js.map} +1 -1
  28. package/dist/examples.json +3 -3
  29. package/dist/index.b191732d.js +2 -0
  30. package/dist/{index.c124d22e.js.map → index.b191732d.js.map} +1 -1
  31. package/dist/manifest.json +57 -57
  32. package/dist/types.json +67 -67
  33. package/package.json +2 -2
  34. package/dist/chunks/3233.19da547d.js +0 -3
  35. package/dist/chunks/3233.19da547d.js.map +0 -1
  36. package/dist/chunks/4766.f59e3f71.js +0 -3
  37. package/dist/chunks/4766.f59e3f71.js.map +0 -1
  38. package/dist/chunks/788.5a8dd377.js +0 -3
  39. package/dist/chunks/788.5a8dd377.js.map +0 -1
  40. package/dist/chunks/9711.97cc0d7a.js +0 -2
  41. package/dist/chunks/9711.97cc0d7a.js.map +0 -1
  42. package/dist/chunks/9961.b9465f07.js +0 -2
  43. package/dist/chunks/9961.b9465f07.js.map +0 -1
  44. package/dist/chunks/editable-label.224a6514.js +0 -3
  45. package/dist/chunks/editable-label.224a6514.js.map +0 -1
  46. package/dist/chunks/eo-diagram.93f17e33.js +0 -2
  47. package/dist/chunks/eo-display-canvas.d9801bac.js.map +0 -1
  48. package/dist/chunks/eo-draw-canvas.368890a9.js +0 -2
  49. package/dist/chunks/eo-draw-canvas.368890a9.js.map +0 -1
  50. package/dist/chunks/main.18a3db6f.js +0 -2
  51. package/dist/index.c124d22e.js +0 -2
  52. /package/dist/chunks/{3233.19da547d.js.LICENSE.txt → 3233.fd1ca80f.js.LICENSE.txt} +0 -0
  53. /package/dist/chunks/{4766.f59e3f71.js.LICENSE.txt → 4411.1ae59113.js.LICENSE.txt} +0 -0
  54. /package/dist/chunks/{788.5a8dd377.js.LICENSE.txt → 5443.6617ae99.js.LICENSE.txt} +0 -0
  55. /package/dist/chunks/{editable-label.224a6514.js.LICENSE.txt → editable-label.de9e2540.js.LICENSE.txt} +0 -0
@@ -0,0 +1,3 @@
1
+ /*! For license information please see editable-label.de9e2540.js.LICENSE.txt */
2
+ (globalThis.webpackChunk_next_bricks_diagram=globalThis.webpackChunk_next_bricks_diagram||[]).push([[6006,2052],{3328:(e,t,n)=>{"use strict";n.r(t),n.d(t,{EditableLabel:()=>_,EditableLabelComponent:()=>R,LegacyEditableLabelComponent:()=>Q});var r,i=n(4635),o=n(918),a=n(6902),l=n(5536),c=n(6121),s=n(829),u=n(2740),f=n(8769),h=n.n(f),d=n(300),p=n(4295),b=(n(6477),n(3373)),g=n.n(b),v=n(3971);let m,y,A,w,x,E,k,S,C,j,T,z,P,D;const{defineElement:L,property:M,event:O,method:W}=(0,d.createDecorators)(),R=(0,f.forwardRef)(Q);let _;var N=new WeakMap,I=new WeakMap,B=new WeakMap,H=new WeakSet,K=new WeakMap,q=new WeakMap,F=new WeakMap,G=new WeakMap;class J extends p.ReactNextElement{constructor(){super(...arguments),(0,i.A)(this,H),(0,o.A)(this,N,(m(this),A(this))),(0,o.A)(this,I,(w(this),x(this))),(0,o.A)(this,B,(E(this),k(this))),(0,o.A)(this,K,(j(this),e=>{(0,l.A)(H,this,S).emit(e)})),(0,o.A)(this,q,T(this)),(0,o.A)(this,F,(D(this),e=>{(0,l.A)(H,this,z).emit(e)})),(0,o.A)(this,G,(0,f.createRef)())}get label(){return(0,s.A)(N,this)}set label(e){(0,c.A)(N,this,e)}get type(){return(0,s.A)(I,this)}set type(e){(0,c.A)(I,this,e)}enableEditing(){var e;null===(e=(0,s.A)(G,this).current)||void 0===e||e.enableEditing()}render(){return h().createElement(R,{ref:(0,s.A)(G,this),label:this.label,onLabelEditingChange:(0,s.A)(K,this),onLabelChange:(0,s.A)(F,this)})}}function Q(e,t){let{label:n,onLabelChange:r,onLabelEditingChange:i}=e;const o=null!=n?n:"",[a,l]=(0,f.useState)(o),[c,s]=(0,f.useState)(!1),u=(0,f.useRef)(!1),[d,p]=(0,f.useState)(!1),b=(0,f.useRef)(null);(0,f.useImperativeHandle)(t,(()=>({enableEditing(){s(!0)}}))),(0,f.useEffect)((()=>{l(o)}),[o]);const v=(0,f.useCallback)((e=>{e.preventDefault(),e.stopPropagation(),s(!0)}),[]);(0,f.useEffect)((()=>{var e,t;c&&(null===(e=b.current)||void 0===e||e.focus({preventScroll:!0}),null===(t=b.current)||void 0===t||t.select())}),[c]),(0,f.useEffect)((()=>{u.current?null==i||i(c):u.current=!0}),[c,i]);const m=(0,f.useCallback)((e=>{l(e.target.value)}),[]),y=(0,f.useCallback)((e=>{const t=e.key||e.keyCode||e.which;var n;"Enter"!==t&&13!==t||null===(n=b.current)||void 0===n||n.blur()}),[]),A=(0,f.useCallback)((()=>{s(!1),p(!0)}),[]);(0,f.useEffect)((()=>{d&&(null==r||r(a),p(!1))}),[a,r,d]);const w=(0,f.useCallback)((e=>{e.stopPropagation()}),[]);return h().createElement("div",{className:g()("label",{editing:c,empty:!a}),onDoubleClick:w,onMouseDown:w},h().createElement("input",{className:"label-input",value:a,ref:b,onChange:m,onKeyDown:y,onBlur:A}),h().createElement("div",{className:"label-text",onDoubleClick:v},a))}r=J,({e:[A,w,x,E,k,S,C,j,T,z,P,D,m],c:[_,y]}=(0,u.A)(r,[L("diagram.editable-label",{styleTexts:[v.A]})],[[M(),1,"label"],[M({render:!1}),1,"type"],[O({type:"label.editing.change"}),1,"labelEditingChange",e=>(0,s.A)(B,e),(e,t)=>(0,c.A)(B,e,t)],[O({type:"label.change"}),1,"labelChange",e=>(0,s.A)(q,e),(e,t)=>(0,c.A)(q,e,t)],[W(),2,"enableEditing"]],0,(e=>G.has((0,a.A)(e))),p.ReactNextElement)),y()},3971:(e,t,n)=>{"use strict";n.d(t,{A:()=>l});var r=n(6758),i=n.n(r),o=n(935),a=n.n(o)()(i());a.push([e.id,':host{display:block;--local-label-line-height:inherit;--local-label-font-size:inherit;--local-label-color:inherit;--local-label-font-weight:inherit}:host([hidden]){display:none}:host([type="line"]){--local-label-line-height:18px;--local-label-font-size:11px;--local-label-color:var(--color-secondary-text);--local-label-font-weight:400}*{box-sizing:border-box}.label{max-width:168px;margin:-3px}.label-text,\n.label-input{width:100%;height:24px;padding:3px;border:none;line-height:var(--local-label-line-height);font-size:var(--local-label-font-size);color:var(--local-label-color);font-weight:var(--local-label-font-weight);text-align:center;font-family:inherit;cursor:text;-webkit-user-select:text;user-select:text}.label-text{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.label.editing .label-text,\n.label.empty:not(.editing) .label-text,\n.label:not(.editing) .label-input{display:none}',""]);const l=a.toString()},935:e=>{"use strict";e.exports=function(e){var t=[];return t.toString=function(){return this.map((function(t){var n="",r=void 0!==t[5];return t[4]&&(n+="@supports (".concat(t[4],") {")),t[2]&&(n+="@media ".concat(t[2]," {")),r&&(n+="@layer".concat(t[5].length>0?" ".concat(t[5]):""," {")),n+=e(t),r&&(n+="}"),t[2]&&(n+="}"),t[4]&&(n+="}"),n})).join("")},t.i=function(e,n,r,i,o){"string"==typeof e&&(e=[[null,e,void 0]]);var a={};if(r)for(var l=0;l<this.length;l++){var c=this[l][0];null!=c&&(a[c]=!0)}for(var s=0;s<e.length;s++){var u=[].concat(e[s]);r&&a[u[0]]||(void 0!==o&&(void 0===u[5]||(u[1]="@layer".concat(u[5].length>0?" ".concat(u[5]):""," {").concat(u[1],"}")),u[5]=o),n&&(u[2]?(u[1]="@media ".concat(u[2]," {").concat(u[1],"}"),u[2]=n):u[2]=n),i&&(u[4]?(u[1]="@supports (".concat(u[4],") {").concat(u[1],"}"),u[4]=i):u[4]="".concat(i)),t.push(u))}},t}},6758:e=>{"use strict";e.exports=function(e){return e[1]}},3373:(e,t)=>{var n;!function(){"use strict";var r={}.hasOwnProperty;function i(){for(var e="",t=0;t<arguments.length;t++){var n=arguments[t];n&&(e=a(e,o(n)))}return e}function o(e){if("string"==typeof e||"number"==typeof e)return e;if("object"!=typeof e)return"";if(Array.isArray(e))return i.apply(null,e);if(e.toString!==Object.prototype.toString&&!e.toString.toString().includes("[native code]"))return e.toString();var t="";for(var n in e)r.call(e,n)&&e[n]&&(t=a(t,n));return t}function a(e,t){return t?e?e+" "+t:e+t:e}e.exports?(i.default=i,e.exports=i):void 0===(n=function(){return i}.apply(t,[]))||(e.exports=n)}()},2740:(e,t,n)=>{"use strict";n.d(t,{A:()=>l});var r=n(7545),i=n(6902);function o(e,t,n){"symbol"==(0,r.A)(t)&&(t=(t=t.description)?"["+t+"]":"");try{Object.defineProperty(e,"name",{configurable:!0,value:n?n+" "+t:t})}catch(e){}return e}var a=n(1369);function l(e,t,n,l,c,s){var u,f,h,d,p,b,g,v=Symbol.metadata||Symbol.for("Symbol.metadata"),m=Object.defineProperty,y=Object.create,A=[y(null),y(null)],w=t.length;function x(t,n,r){return function(i,o){n&&(o=i,i=e);for(var a=0;a<t.length;a++)o=t[a].apply(i,r?[o]:[]);return r?o:i}}function E(e,t,n,r){if("function"!=typeof e&&(r||void 0!==e))throw new TypeError(t+" must "+(n||"be")+" a function"+(r?"":" or undefined"));return e}function k(e,t,n,i,a,l,c,s,h,d,p){function b(e){if(!p(e))throw new TypeError("Attempted to access private element on non-instance")}var g=[].concat(t[0]),v=t[3],y=!c,w=1===a,k=3===a,S=4===a,C=2===a;function j(t,n,r){return function(i,o){return n&&(o=i,i=e),r&&r(i),T[t].call(i,o)}}if(!y){var T={},z=[],P=k?"get":S||w?"set":"value";if(h?(d||w?T={get:o((function(){return v(this)}),i,"get"),set:function(e){t[4](this,e)}}:T[P]=v,d||o(T[P],i,C?"":P)):d||(T=Object.getOwnPropertyDescriptor(e,i)),!d&&!h){if((f=A[+s][i])&&7!=(f^a))throw Error("Decorating two elements with the same name ("+T[P].name+") is not supported yet");A[+s][i]=a<3?1:a}}for(var D=e,L=g.length-1;L>=0;L-=n?2:1){var M=E(g[L],"A decorator","be",!0),O=n?g[L-1]:void 0,W={},R={kind:["field","accessor","method","getter","setter","class"][a],name:i,metadata:u,addInitializer:function(e,t){if(e.v)throw Error("attempted to call addInitializer after decoration was finished");E(t,"An initializer","be",!0),l.push(t)}.bind(null,W)};if(y)f=M.call(O,D,R),W.v=1,E(f,"class decorators","return")&&(D=f);else if(R.static=s,R.private=h,f=R.access={has:h?p.bind():function(e){return i in e}},S||(f.get=h?C?function(e){return b(e),T.value}:j("get",0,b):function(e){return e[i]}),C||k||(f.set=h?j("set",0,b):function(e,t){e[i]=t}),D=M.call(O,w?{get:T.get,set:T.set}:T[P],R),W.v=1,w){if("object"==(0,r.A)(D)&&D)(f=E(D.get,"accessor.get"))&&(T.get=f),(f=E(D.set,"accessor.set"))&&(T.set=f),(f=E(D.init,"accessor.init"))&&z.unshift(f);else if(void 0!==D)throw new TypeError("accessor decorators must return an object with get, set, or init properties or undefined")}else E(D,(d?"field":"method")+" decorators","return")&&(d?z.unshift(D):T[P]=D)}return a<2&&c.push(x(z,s,1),x(l,s,0)),d||y||(h?w?c.splice(-1,0,j("get",s),j("set",s)):c.push(C?T[P]:E.call.bind(T[P])):m(e,i,T)),D}function S(e){return m(e,v,{configurable:!0,enumerable:!0,value:u})}return void 0!==s&&(u=s[v]),u=y(null==u?null:u),p=[],b=function(e){e&&p.push(x(e))},g=function(t,r){for(var o=0;o<n.length;o++){var l=n[o],s=l[1],u=7&s;if((8&s)==t&&!u==r){var f=l[2],b=!!l[3],g=16&s;k(t?e:e.prototype,l,g,b?"#"+f:(0,a.A)(f),u,u<2?[]:t?d=d||[]:h=h||[],p,!!t,b,r,t&&b?function(t){return(0,i.A)(t)===e}:c)}}},g(8,0),g(0,0),g(8,1),g(0,1),b(h),b(d),f=p,w||S(e),{e:f,get c(){var n=[];return w&&[S(e=k(e,[t],l,e.name,5,n)),x(n,1)]}}}},2559:(e,t,n)=>{"use strict";function r(e,t,n){if("function"==typeof e?e===t:e.has(t))return arguments.length<3?t:n;throw new TypeError("Private element is not present on this object")}n.d(t,{A:()=>r})},6902:(e,t,n)=>{"use strict";n.d(t,{A:()=>i});var r=n(7545);function i(e){if(Object(e)!==e)throw TypeError("right-hand side of 'in' should be an object, got "+(null!==e?(0,r.A)(e):"null"));return e}},2016:(e,t,n)=>{"use strict";function r(e,t){if(t.has(e))throw new TypeError("Cannot initialize the same private elements twice on an object")}n.d(t,{A:()=>r})},829:(e,t,n)=>{"use strict";n.d(t,{A:()=>i});var r=n(2559);function i(e,t){return e.get((0,r.A)(e,t))}},918:(e,t,n)=>{"use strict";n.d(t,{A:()=>i});var r=n(2016);function i(e,t,n){(0,r.A)(e,t),t.set(e,n)}},6121:(e,t,n)=>{"use strict";n.d(t,{A:()=>i});var r=n(2559);function i(e,t,n){return e.set((0,r.A)(e,t),n),n}},5536:(e,t,n)=>{"use strict";n.d(t,{A:()=>i});var r=n(2559);function i(e,t,n){return n((0,r.A)(e,t))}},4635:(e,t,n)=>{"use strict";n.d(t,{A:()=>i});var r=n(2016);function i(e,t){(0,r.A)(e,t),t.add(e)}},1369:(e,t,n)=>{"use strict";n.d(t,{A:()=>i});var r=n(7545);function i(e){var t=function(e,t){if("object"!=(0,r.A)(e)||!e)return e;var n=e[Symbol.toPrimitive];if(void 0!==n){var i=n.call(e,"string");if("object"!=(0,r.A)(i))return i;throw new TypeError("@@toPrimitive must return a primitive value.")}return String(e)}(e);return"symbol"==(0,r.A)(t)?t:t+""}},7545:(e,t,n)=>{"use strict";function r(e){return r="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},r(e)}n.d(t,{A:()=>r})}}]);
3
+ //# sourceMappingURL=editable-label.de9e2540.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"chunks/editable-label.de9e2540.js","mappings":"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","sources":["webpack:///./src/editable-label/index.tsx","webpack:///./src/editable-label/styles.shadow.css","webpack:///../../node_modules/css-loader/dist/runtime/api.js","webpack:///../../node_modules/css-loader/dist/runtime/noSourceMaps.js","webpack:///../../node_modules/classnames/index.js","webpack:///../../node_modules/@babel/runtime/helpers/esm/setFunctionName.js","webpack:///../../node_modules/@babel/runtime/helpers/esm/applyDecs2311.js","webpack:///../../node_modules/@babel/runtime/helpers/esm/assertClassBrand.js","webpack:///../../node_modules/@babel/runtime/helpers/esm/checkInRHS.js","webpack:///../../node_modules/@babel/runtime/helpers/esm/checkPrivateRedeclaration.js","webpack:///../../node_modules/@babel/runtime/helpers/esm/classPrivateFieldGet2.js","webpack:///../../node_modules/@babel/runtime/helpers/esm/classPrivateFieldInitSpec.js","webpack:///../../node_modules/@babel/runtime/helpers/esm/classPrivateFieldSet2.js","webpack:///../../node_modules/@babel/runtime/helpers/esm/classPrivateGetter.js","webpack:///../../node_modules/@babel/runtime/helpers/esm/classPrivateMethodInitSpec.js","webpack:///../../node_modules/@babel/runtime/helpers/esm/toPropertyKey.js","webpack:///../../node_modules/@babel/runtime/helpers/esm/toPrimitive.js","webpack:///../../node_modules/@babel/runtime/helpers/esm/typeof.js"],"sourcesContent":["import React, {\n createRef,\n forwardRef,\n useCallback,\n useEffect,\n useImperativeHandle,\n useRef,\n useState,\n} from \"react\";\nimport { EventEmitter, createDecorators } from \"@next-core/element\";\nimport { ReactNextElement } from \"@next-core/react-element\";\nimport \"@next-core/theme\";\nimport classNames from \"classnames\";\nimport styleText from \"./styles.shadow.css\";\n\nconst { defineElement, property, event, method } = createDecorators();\n\nexport interface EditableLabelProps {\n label?: string;\n type?: LabelType;\n}\n\nexport type LabelType = \"line\" | \"default\";\n\nexport interface EditableLabelRef {\n enableEditing(): void;\n}\n\nexport const EditableLabelComponent = forwardRef(LegacyEditableLabelComponent);\n\n/**\n * 构件 `diagram.editable-label`\n */\nexport\n@defineElement(\"diagram.editable-label\", {\n styleTexts: [styleText],\n})\nclass EditableLabel extends ReactNextElement implements EditableLabelProps {\n @property()\n accessor label: string | undefined;\n\n @property({ render: false })\n accessor type: LabelType | undefined;\n\n @event({ type: \"label.editing.change\" })\n accessor #labelEditingChange!: EventEmitter<boolean>;\n\n #handleLabelEditingChange = (value: boolean) => {\n this.#labelEditingChange.emit(value);\n };\n\n @event({ type: \"label.change\" })\n accessor #labelChange!: EventEmitter<string>;\n\n #handleLabelChange = (value: string) => {\n this.#labelChange.emit(value);\n };\n\n @method()\n enableEditing() {\n this.#editableLabelRef.current?.enableEditing();\n }\n\n #editableLabelRef = createRef<EditableLabelRef>();\n\n render() {\n return (\n <EditableLabelComponent\n ref={this.#editableLabelRef}\n label={this.label}\n onLabelEditingChange={this.#handleLabelEditingChange}\n onLabelChange={this.#handleLabelChange}\n />\n );\n }\n}\n\nexport interface EditableLabelComponentProps extends EditableLabelProps {\n onLabelEditingChange?(value: boolean): void;\n onLabelChange?(value: string): void;\n}\n\nexport function LegacyEditableLabelComponent(\n {\n label: _label,\n onLabelChange,\n onLabelEditingChange,\n }: EditableLabelComponentProps,\n ref: React.Ref<EditableLabelRef>\n) {\n const label = _label ?? \"\";\n const [currentLabel, setCurrentLabel] = useState<string>(label);\n const [editingLabel, setEditingLabel] = useState(false);\n const editingLabelInitialized = useRef(false);\n const [shouldEmitLabelChange, setShouldEmitLabelChange] = useState(false);\n const labelInputRef = useRef<HTMLInputElement>(null);\n\n useImperativeHandle(ref, () => ({\n enableEditing() {\n setEditingLabel(true);\n },\n }));\n\n useEffect(() => {\n setCurrentLabel(label);\n }, [label]);\n\n const handleEditLabel = useCallback((e: React.MouseEvent) => {\n e.preventDefault();\n e.stopPropagation();\n setEditingLabel(true);\n }, []);\n\n useEffect(() => {\n if (editingLabel) {\n // Prevent scroll when focusing.\n // Otherwise the diagram svg may be clipped in Chrome.\n labelInputRef.current?.focus({ preventScroll: true });\n labelInputRef.current?.select();\n }\n }, [editingLabel]);\n\n useEffect(() => {\n if (editingLabelInitialized.current) {\n onLabelEditingChange?.(editingLabel);\n } else {\n editingLabelInitialized.current = true;\n }\n }, [editingLabel, onLabelEditingChange]);\n\n const handleInputChange = useCallback(\n (event: React.ChangeEvent<HTMLInputElement>) => {\n setCurrentLabel(event.target.value);\n },\n []\n );\n\n const handleInputKeydown = useCallback((event: React.KeyboardEvent) => {\n const key =\n event.key ||\n /* istanbul ignore next: compatibility */ event.keyCode ||\n /* istanbul ignore next: compatibility */ event.which;\n if (key === \"Enter\" || key === 13) {\n labelInputRef.current?.blur();\n }\n }, []);\n\n const handleInputBlur = useCallback(() => {\n setEditingLabel(false);\n setShouldEmitLabelChange(true);\n }, []);\n\n useEffect(() => {\n if (shouldEmitLabelChange) {\n onLabelChange?.(currentLabel);\n setShouldEmitLabelChange(false);\n }\n }, [currentLabel, onLabelChange, shouldEmitLabelChange]);\n\n const stopPropagation = useCallback((e: React.MouseEvent) => {\n e.stopPropagation();\n }, []);\n\n return (\n <div\n className={classNames(\"label\", {\n editing: editingLabel,\n empty: !currentLabel,\n })}\n onDoubleClick={stopPropagation}\n onMouseDown={stopPropagation}\n >\n <input\n className=\"label-input\"\n value={currentLabel}\n ref={labelInputRef}\n onChange={handleInputChange}\n onKeyDown={handleInputKeydown}\n onBlur={handleInputBlur}\n />\n <div className=\"label-text\" onDoubleClick={handleEditLabel}>\n {currentLabel}\n </div>\n </div>\n );\n}\n","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `:host{display:block;--local-label-line-height:inherit;--local-label-font-size:inherit;--local-label-color:inherit;--local-label-font-weight:inherit}:host([hidden]){display:none}:host([type=\"line\"]){--local-label-line-height:18px;--local-label-font-size:11px;--local-label-color:var(--color-secondary-text);--local-label-font-weight:400}*{box-sizing:border-box}.label{max-width:168px;margin:-3px}.label-text,\n.label-input{width:100%;height:24px;padding:3px;border:none;line-height:var(--local-label-line-height);font-size:var(--local-label-font-size);color:var(--local-label-color);font-weight:var(--local-label-font-weight);text-align:center;font-family:inherit;cursor:text;-webkit-user-select:text;user-select:text}.label-text{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.label.editing .label-text,\n.label.empty:not(.editing) .label-text,\n.label:not(.editing) .label-input{display:none}`, \"\"]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___.toString();\n","\"use strict\";\n\n/*\n MIT License http://www.opensource.org/licenses/mit-license.php\n Author Tobias Koppers @sokra\n*/\nmodule.exports = function (cssWithMappingToString) {\n var list = [];\n\n // return the list of modules as css string\n list.toString = function toString() {\n return this.map(function (item) {\n var content = \"\";\n var needLayer = typeof item[5] !== \"undefined\";\n if (item[4]) {\n content += \"@supports (\".concat(item[4], \") {\");\n }\n if (item[2]) {\n content += \"@media \".concat(item[2], \" {\");\n }\n if (needLayer) {\n content += \"@layer\".concat(item[5].length > 0 ? \" \".concat(item[5]) : \"\", \" {\");\n }\n content += cssWithMappingToString(item);\n if (needLayer) {\n content += \"}\";\n }\n if (item[2]) {\n content += \"}\";\n }\n if (item[4]) {\n content += \"}\";\n }\n return content;\n }).join(\"\");\n };\n\n // import a list of modules into the list\n list.i = function i(modules, media, dedupe, supports, layer) {\n if (typeof modules === \"string\") {\n modules = [[null, modules, undefined]];\n }\n var alreadyImportedModules = {};\n if (dedupe) {\n for (var k = 0; k < this.length; k++) {\n var id = this[k][0];\n if (id != null) {\n alreadyImportedModules[id] = true;\n }\n }\n }\n for (var _k = 0; _k < modules.length; _k++) {\n var item = [].concat(modules[_k]);\n if (dedupe && alreadyImportedModules[item[0]]) {\n continue;\n }\n if (typeof layer !== \"undefined\") {\n if (typeof item[5] === \"undefined\") {\n item[5] = layer;\n } else {\n item[1] = \"@layer\".concat(item[5].length > 0 ? \" \".concat(item[5]) : \"\", \" {\").concat(item[1], \"}\");\n item[5] = layer;\n }\n }\n if (media) {\n if (!item[2]) {\n item[2] = media;\n } else {\n item[1] = \"@media \".concat(item[2], \" {\").concat(item[1], \"}\");\n item[2] = media;\n }\n }\n if (supports) {\n if (!item[4]) {\n item[4] = \"\".concat(supports);\n } else {\n item[1] = \"@supports (\".concat(item[4], \") {\").concat(item[1], \"}\");\n item[4] = supports;\n }\n }\n list.push(item);\n }\n };\n return list;\n};","\"use strict\";\n\nmodule.exports = function (i) {\n return i[1];\n};","/*!\n\tCopyright (c) 2018 Jed Watson.\n\tLicensed under the MIT License (MIT), see\n\thttp://jedwatson.github.io/classnames\n*/\n/* global define */\n\n(function () {\n\t'use strict';\n\n\tvar hasOwn = {}.hasOwnProperty;\n\n\tfunction classNames () {\n\t\tvar classes = '';\n\n\t\tfor (var i = 0; i < arguments.length; i++) {\n\t\t\tvar arg = arguments[i];\n\t\t\tif (arg) {\n\t\t\t\tclasses = appendClass(classes, parseValue(arg));\n\t\t\t}\n\t\t}\n\n\t\treturn classes;\n\t}\n\n\tfunction parseValue (arg) {\n\t\tif (typeof arg === 'string' || typeof arg === 'number') {\n\t\t\treturn arg;\n\t\t}\n\n\t\tif (typeof arg !== 'object') {\n\t\t\treturn '';\n\t\t}\n\n\t\tif (Array.isArray(arg)) {\n\t\t\treturn classNames.apply(null, arg);\n\t\t}\n\n\t\tif (arg.toString !== Object.prototype.toString && !arg.toString.toString().includes('[native code]')) {\n\t\t\treturn arg.toString();\n\t\t}\n\n\t\tvar classes = '';\n\n\t\tfor (var key in arg) {\n\t\t\tif (hasOwn.call(arg, key) && arg[key]) {\n\t\t\t\tclasses = appendClass(classes, key);\n\t\t\t}\n\t\t}\n\n\t\treturn classes;\n\t}\n\n\tfunction appendClass (value, newClass) {\n\t\tif (!newClass) {\n\t\t\treturn value;\n\t\t}\n\t\n\t\tif (value) {\n\t\t\treturn value + ' ' + newClass;\n\t\t}\n\t\n\t\treturn value + newClass;\n\t}\n\n\tif (typeof module !== 'undefined' && module.exports) {\n\t\tclassNames.default = classNames;\n\t\tmodule.exports = classNames;\n\t} else if (typeof define === 'function' && typeof define.amd === 'object' && define.amd) {\n\t\t// register as 'classnames', consistent with npm package name\n\t\tdefine('classnames', [], function () {\n\t\t\treturn classNames;\n\t\t});\n\t} else {\n\t\twindow.classNames = classNames;\n\t}\n}());\n","import _typeof from \"./typeof.js\";\nexport default function setFunctionName(e, t, n) {\n \"symbol\" == _typeof(t) && (t = (t = t.description) ? \"[\" + t + \"]\" : \"\");\n try {\n Object.defineProperty(e, \"name\", {\n configurable: !0,\n value: n ? n + \" \" + t : t\n });\n } catch (e) {}\n return e;\n}","import _typeof from \"./typeof.js\";\nimport checkInRHS from \"./checkInRHS.js\";\nimport setFunctionName from \"./setFunctionName.js\";\nimport toPropertyKey from \"./toPropertyKey.js\";\nexport default function applyDecs2311(e, t, n, r, o, i) {\n var a,\n c,\n u,\n s,\n f,\n l,\n p,\n d = Symbol.metadata || Symbol[\"for\"](\"Symbol.metadata\"),\n m = Object.defineProperty,\n h = Object.create,\n y = [h(null), h(null)],\n v = t.length;\n function g(t, n, r) {\n return function (o, i) {\n n && (i = o, o = e);\n for (var a = 0; a < t.length; a++) i = t[a].apply(o, r ? [i] : []);\n return r ? i : o;\n };\n }\n function b(e, t, n, r) {\n if (\"function\" != typeof e && (r || void 0 !== e)) throw new TypeError(t + \" must \" + (n || \"be\") + \" a function\" + (r ? \"\" : \" or undefined\"));\n return e;\n }\n function applyDec(e, t, n, r, o, i, u, s, f, l, p) {\n function d(e) {\n if (!p(e)) throw new TypeError(\"Attempted to access private element on non-instance\");\n }\n var h = [].concat(t[0]),\n v = t[3],\n w = !u,\n D = 1 === o,\n S = 3 === o,\n j = 4 === o,\n E = 2 === o;\n function I(t, n, r) {\n return function (o, i) {\n return n && (i = o, o = e), r && r(o), P[t].call(o, i);\n };\n }\n if (!w) {\n var P = {},\n k = [],\n F = S ? \"get\" : j || D ? \"set\" : \"value\";\n if (f ? (l || D ? P = {\n get: setFunctionName(function () {\n return v(this);\n }, r, \"get\"),\n set: function set(e) {\n t[4](this, e);\n }\n } : P[F] = v, l || setFunctionName(P[F], r, E ? \"\" : F)) : l || (P = Object.getOwnPropertyDescriptor(e, r)), !l && !f) {\n if ((c = y[+s][r]) && 7 != (c ^ o)) throw Error(\"Decorating two elements with the same name (\" + P[F].name + \") is not supported yet\");\n y[+s][r] = o < 3 ? 1 : o;\n }\n }\n for (var N = e, O = h.length - 1; O >= 0; O -= n ? 2 : 1) {\n var z = b(h[O], \"A decorator\", \"be\", !0),\n A = n ? h[O - 1] : void 0,\n H = {},\n K = {\n kind: [\"field\", \"accessor\", \"method\", \"getter\", \"setter\", \"class\"][o],\n name: r,\n metadata: a,\n addInitializer: function (e, t) {\n if (e.v) throw Error(\"attempted to call addInitializer after decoration was finished\");\n b(t, \"An initializer\", \"be\", !0), i.push(t);\n }.bind(null, H)\n };\n if (w) c = z.call(A, N, K), H.v = 1, b(c, \"class decorators\", \"return\") && (N = c);else if (K[\"static\"] = s, K[\"private\"] = f, c = K.access = {\n has: f ? p.bind() : function (e) {\n return r in e;\n }\n }, j || (c.get = f ? E ? function (e) {\n return d(e), P.value;\n } : I(\"get\", 0, d) : function (e) {\n return e[r];\n }), E || S || (c.set = f ? I(\"set\", 0, d) : function (e, t) {\n e[r] = t;\n }), N = z.call(A, D ? {\n get: P.get,\n set: P.set\n } : P[F], K), H.v = 1, D) {\n if (\"object\" == _typeof(N) && N) (c = b(N.get, \"accessor.get\")) && (P.get = c), (c = b(N.set, \"accessor.set\")) && (P.set = c), (c = b(N.init, \"accessor.init\")) && k.unshift(c);else if (void 0 !== N) throw new TypeError(\"accessor decorators must return an object with get, set, or init properties or undefined\");\n } else b(N, (l ? \"field\" : \"method\") + \" decorators\", \"return\") && (l ? k.unshift(N) : P[F] = N);\n }\n return o < 2 && u.push(g(k, s, 1), g(i, s, 0)), l || w || (f ? D ? u.splice(-1, 0, I(\"get\", s), I(\"set\", s)) : u.push(E ? P[F] : b.call.bind(P[F])) : m(e, r, P)), N;\n }\n function w(e) {\n return m(e, d, {\n configurable: !0,\n enumerable: !0,\n value: a\n });\n }\n return void 0 !== i && (a = i[d]), a = h(null == a ? null : a), f = [], l = function l(e) {\n e && f.push(g(e));\n }, p = function p(t, r) {\n for (var i = 0; i < n.length; i++) {\n var a = n[i],\n c = a[1],\n l = 7 & c;\n if ((8 & c) == t && !l == r) {\n var p = a[2],\n d = !!a[3],\n m = 16 & c;\n applyDec(t ? e : e.prototype, a, m, d ? \"#\" + p : toPropertyKey(p), l, l < 2 ? [] : t ? s = s || [] : u = u || [], f, !!t, d, r, t && d ? function (t) {\n return checkInRHS(t) === e;\n } : o);\n }\n }\n }, p(8, 0), p(0, 0), p(8, 1), p(0, 1), l(u), l(s), c = f, v || w(e), {\n e: c,\n get c() {\n var n = [];\n return v && [w(e = applyDec(e, [t], r, e.name, 5, n)), g(n, 1)];\n }\n };\n}","export default function _assertClassBrand(e, t, n) {\n if (\"function\" == typeof e ? e === t : e.has(t)) return arguments.length < 3 ? t : n;\n throw new TypeError(\"Private element is not present on this object\");\n}","import _typeof from \"./typeof.js\";\nexport default function _checkInRHS(e) {\n if (Object(e) !== e) throw TypeError(\"right-hand side of 'in' should be an object, got \" + (null !== e ? _typeof(e) : \"null\"));\n return e;\n}","export default function _checkPrivateRedeclaration(obj, privateCollection) {\n if (privateCollection.has(obj)) {\n throw new TypeError(\"Cannot initialize the same private elements twice on an object\");\n }\n}","import assertClassBrand from \"./assertClassBrand.js\";\nexport default function _classPrivateFieldGet2(s, a) {\n return s.get(assertClassBrand(s, a));\n}","import checkPrivateRedeclaration from \"./checkPrivateRedeclaration.js\";\nexport default function _classPrivateFieldInitSpec(obj, privateMap, value) {\n checkPrivateRedeclaration(obj, privateMap);\n privateMap.set(obj, value);\n}","import assertClassBrand from \"./assertClassBrand.js\";\nexport default function _classPrivateFieldSet2(s, a, r) {\n return s.set(assertClassBrand(s, a), r), r;\n}","import assertClassBrand from \"./assertClassBrand.js\";\nexport default function _classPrivateGetter(s, r, a) {\n return a(assertClassBrand(s, r));\n}","import checkPrivateRedeclaration from \"./checkPrivateRedeclaration.js\";\nexport default function _classPrivateMethodInitSpec(obj, privateSet) {\n checkPrivateRedeclaration(obj, privateSet);\n privateSet.add(obj);\n}","import _typeof from \"./typeof.js\";\nimport toPrimitive from \"./toPrimitive.js\";\nexport default function toPropertyKey(t) {\n var i = toPrimitive(t, \"string\");\n return \"symbol\" == _typeof(i) ? i : i + \"\";\n}","import _typeof from \"./typeof.js\";\nexport default function toPrimitive(t, r) {\n if (\"object\" != _typeof(t) || !t) return t;\n var e = t[Symbol.toPrimitive];\n if (void 0 !== e) {\n var i = e.call(t, r || \"default\");\n if (\"object\" != _typeof(i)) return i;\n throw new TypeError(\"@@toPrimitive must return a primitive value.\");\n }\n return (\"string\" === r ? String : Number)(t);\n}","export default function _typeof(o) {\n \"@babel/helpers - typeof\";\n\n return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (o) {\n return typeof o;\n } : function (o) {\n return o && \"function\" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? \"symbol\" : typeof o;\n }, _typeof(o);\n}"],"names":["defineElement","property","event","method","createDecorators","EditableLabelComponent","forwardRef","LegacyEditableLabelComponent","_EditableLabel","_A","WeakMap","_B","_C","_EditableLabel_brand","WeakSet","_handleLabelEditingChange","_D","_handleLabelChange","_editableLabelRef","EditableLabel","ReactNextElement","constructor","arguments","_classPrivateMethodInitSpec","_classPrivateFieldInitSpec","_initProto","_init_label","_init_extra_label","_init_type","_init_extra_type","_init_labelEditingChange","_init_extra_labelEditingChange","value","_classPrivateGetter","this","_get_labelEditingChange","emit","_init_labelChange","_init_extra_labelChange","_get_labelChange","createRef","label","_classPrivateFieldGet","v","_classPrivateFieldSet","type","enableEditing","_classPrivateFieldGet2","current","render","React","ref","onLabelEditingChange","onLabelChange","_ref","_label","currentLabel","setCurrentLabel","useState","editingLabel","setEditingLabel","editingLabelInitialized","useRef","shouldEmitLabelChange","setShouldEmitLabelChange","labelInputRef","useImperativeHandle","useEffect","handleEditLabel","useCallback","e","preventDefault","stopPropagation","_labelInputRef$curren","_labelInputRef$curren2","focus","preventScroll","select","handleInputChange","target","handleInputKeydown","key","keyCode","which","_labelInputRef$curren3","blur","handleInputBlur","className","classNames","editing","empty","onDoubleClick","onMouseDown","onChange","onKeyDown","onBlur","_EditableLabel2","_set_labelEditingChange","_set_labelChange","c","_initClass","_applyDecs","styleTexts","styleText","o","_","has","_checkInRHS","___CSS_LOADER_EXPORT___","push","module","id","toString","exports","cssWithMappingToString","list","map","item","content","needLayer","concat","length","join","i","modules","media","dedupe","supports","layer","undefined","alreadyImportedModules","k","_k","hasOwn","hasOwnProperty","classes","arg","appendClass","parseValue","Array","isArray","apply","Object","prototype","includes","call","newClass","default","setFunctionName","t","n","description","defineProperty","configurable","applyDecs2311","r","a","u","s","f","l","p","d","Symbol","metadata","m","h","create","y","g","b","TypeError","applyDec","w","D","S","j","E","I","P","F","get","set","getOwnPropertyDescriptor","Error","name","N","O","z","A","H","K","kind","addInitializer","bind","access","init","unshift","splice","enumerable","toPropertyKey","checkInRHS","_assertClassBrand","_checkPrivateRedeclaration","obj","privateCollection","privateMap","_classPrivateFieldSet2","privateSet","add","toPrimitive","String","_typeof","iterator"],"sourceRoot":""}
@@ -0,0 +1,2 @@
1
+ "use strict";(globalThis.webpackChunk_next_bricks_diagram=globalThis.webpackChunk_next_bricks_diagram||[]).push([[3039],{1508:(e,t,n)=>{n.r(t),n.d(t,{EoDiagram:()=>Ye,EoDiagramComponent:()=>je,LegacyEoDiagramComponent:()=>wt});var a,s=n(4635),i=n(918),o=n(6902),r=n(5536),l=n(6121),c=n(829),d=n(2740),u=n(8769),h=n.n(u),m=n(300),A=n(4295),p=(n(6477),n(7566)),g=n(9047),f=n(3373),y=n.n(f),k=n(1030),v=n(9126),b=n(8892),w=n(5157),M=n(8308),E=n(1518),W=n(9137),L=n(2547),S=n(1803),N=n(3739),R=n(9191),C=n(6671),x=n(8060),T=n(2448),z=n(8657),D=n(8069),$=n(1324),B=n(821),O=n(6753),P=n(2673),I=n(5987);let H,V,_,K,j,Y,X,Z,q,F,G,U,J,Q,ee,te,ne,ae,se,ie,oe,re,le,ce,de,ue,he,me,Ae,pe,ge,fe,ye,ke,ve,be,we,Me,Ee,We,Le,Se,Ne,Re,Ce,xe,Te,ze,De,$e,Be,Oe,Pe,Ie;const{defineElement:He,property:Ve,event:_e,method:Ke}=(0,m.createDecorators)(),je=(0,u.forwardRef)(wt);let Ye;var Xe=new WeakMap,Ze=new WeakMap,qe=new WeakMap,Fe=new WeakMap,Ge=new WeakMap,Ue=new WeakMap,Je=new WeakMap,Qe=new WeakMap,et=new WeakMap,tt=new WeakMap,nt=new WeakMap,at=new WeakMap,st=new WeakMap,it=new WeakMap,ot=new WeakMap,rt=new WeakSet,lt=new WeakMap,ct=new WeakMap,dt=new WeakMap,ut=new WeakMap,ht=new WeakMap,mt=new WeakMap,At=new WeakMap,pt=new WeakMap,gt=new WeakMap,ft=new WeakMap,yt=new WeakMap,kt=new WeakMap,vt=new WeakMap;class bt extends A.ReactNextElement{constructor(){super(...arguments),(0,s.A)(this,rt),(0,i.A)(this,Xe,(H(this),_(this))),(0,i.A)(this,Ze,(K(this),j(this))),(0,i.A)(this,qe,(Y(this),X(this))),(0,i.A)(this,Fe,(Z(this),q(this))),(0,i.A)(this,Ge,(F(this),G(this))),(0,i.A)(this,Ue,(U(this),J(this))),(0,i.A)(this,Je,(Q(this),ee(this))),(0,i.A)(this,Qe,(te(this),ne(this))),(0,i.A)(this,et,(ae(this),se(this))),(0,i.A)(this,tt,(ie(this),oe(this))),(0,i.A)(this,nt,(re(this),le(this,!0))),(0,i.A)(this,at,(ce(this),de(this,!0))),(0,i.A)(this,st,(ue(this),he(this,!0))),(0,i.A)(this,it,(me(this),Ae(this))),(0,i.A)(this,ot,(pe(this),ge(this))),(0,i.A)(this,lt,(ke(this),e=>{(0,r.A)(rt,this,fe).emit(e)})),(0,i.A)(this,ct,ve(this)),(0,i.A)(this,dt,(Me(this),e=>{(0,r.A)(rt,this,be).emit(e)})),(0,i.A)(this,ut,Ee(this)),(0,i.A)(this,ht,(Se(this),e=>{(0,r.A)(rt,this,We).emit(e)})),(0,i.A)(this,mt,Ne(this)),(0,i.A)(this,At,(xe(this),e=>{(0,r.A)(rt,this,Re).emit(e)})),(0,i.A)(this,pt,Te(this)),(0,i.A)(this,gt,($e(this),e=>{(0,r.A)(rt,this,ze).emit(e)})),(0,i.A)(this,ft,Be(this)),(0,i.A)(this,yt,(Ie(this),e=>{(0,r.A)(rt,this,Oe).emit(e)})),(0,i.A)(this,kt,(e=>{(0,P.c)(e,this.activeTarget)||(this.activeTarget=e)})),(0,i.A)(this,vt,(0,u.createRef)())}get layout(){return(0,c.A)(Xe,this)}set layout(e){(0,l.A)(Xe,this,e)}get nodes(){return(0,c.A)(Ze,this)}set nodes(e){(0,l.A)(Ze,this,e)}get edges(){return(0,c.A)(qe,this)}set edges(e){(0,l.A)(qe,this,e)}get nodeBricks(){return(0,c.A)(Fe,this)}set nodeBricks(e){(0,l.A)(Fe,this,e)}get lines(){return(0,c.A)(Ge,this)}set lines(e){(0,l.A)(Ge,this,e)}get layoutOptions(){return(0,c.A)(Ue,this)}set layoutOptions(e){(0,l.A)(Ue,this,e)}get activeTarget(){return(0,c.A)(Je,this)}set activeTarget(e){(0,l.A)(Je,this,e)}get disableKeyboardAction(){return(0,c.A)(Qe,this)}set disableKeyboardAction(e){(0,l.A)(Qe,this,e)}get connectNodes(){return(0,c.A)(et,this)}set connectNodes(e){(0,l.A)(et,this,e)}get dragNodes(){return(0,c.A)(tt,this)}set dragNodes(e){(0,l.A)(tt,this,e)}get zoomable(){return(0,c.A)(nt,this)}set zoomable(e){(0,l.A)(nt,this,e)}get scrollable(){return(0,c.A)(at,this)}set scrollable(e){(0,l.A)(at,this,e)}get pannable(){return(0,c.A)(st,this)}set pannable(e){(0,l.A)(st,this,e)}get scaleRange(){return(0,c.A)(it,this)}set scaleRange(e){(0,l.A)(it,this,e)}callOnLineLabel(e,t){for(var n,a=arguments.length,s=new Array(a>2?a-2:0),i=2;i<a;i++)s[i-2]=arguments[i];null===(n=(0,c.A)(vt,this).current)||void 0===n||n.callOnLineLabel(e,t,...s)}render(){return h().createElement(je,{ref:(0,c.A)(vt,this),layout:this.layout,nodes:this.nodes,edges:this.edges,nodeBricks:this.nodeBricks,lines:this.lines,layoutOptions:this.layoutOptions,connectNodes:this.connectNodes,dragNodes:this.dragNodes,activeTarget:this.activeTarget,disableKeyboardAction:this.disableKeyboardAction,zoomable:this.zoomable,scrollable:this.scrollable,pannable:this.pannable,scaleRange:this.scaleRange,onActiveTargetChange:(0,c.A)(lt,this),onSwitchActiveTarget:(0,c.A)(kt,this),onNodeDelete:(0,c.A)(dt,this),onEdgeDelete:(0,c.A)(ht,this),onLineClick:(0,c.A)(At,this),onLineDoubleClick:(0,c.A)(gt,this),onNodesConnect:(0,c.A)(yt,this)})}}function wt(e,t){let{layout:n,nodes:a,edges:s,nodeBricks:i,lines:o,layoutOptions:r,connectNodes:l,dragNodes:c,activeTarget:d,disableKeyboardAction:m,zoomable:A,scrollable:f,pannable:B,scaleRange:H,onActiveTargetChange:V,onSwitchActiveTarget:_,onNodeDelete:K,onEdgeDelete:j,onLineClick:Y,onLineDoubleClick:X,onNodesConnect:Z}=e;const[q,F]=(0,u.useState)(!1),[G,U]=(0,u.useState)(0),[J,Q]=(0,u.useState)(null),[ee,te]=(0,u.useState)(!1),[ne,ae]=(0,u.useState)(0),[se,ie]=(0,u.useState)(null),[oe,re]=(0,u.useState)([]),[le,ce]=(0,u.useState)(!1),[de,ue]=(0,u.useState)({k:1,x:0,y:0}),he=(0,u.useRef)(new Map),me=(0,u.useRef)(null),Ae=(0,u.useRef)(null),[pe,ge]=(0,u.useState)(!1),{userViewReady:fe,userViewNodesMap:ye,saveUserView:ke}=(0,O._)(null==c?void 0:c.save),[ve,be]=(0,u.useState)([0,0]),[we,Me]=(0,u.useState)(null),[Ee,We]=(0,u.useState)("initial"),[Le,Se]=(0,u.useState)(null);(0,u.useImperativeHandle)(t,(()=>({callOnLineLabel(e,t){for(var n,a=arguments.length,s=new Array(a>2?a-2:0),i=2;i<a;i++)s[i-2]=arguments[i];null==se||null===(n=se.get(e))||void 0===n||null===(n=n.firstElementChild)||void 0===n||n[t](...s)}}))),(0,u.useEffect)((()=>{const e=e=>{(0,T.P)(e,{nodes:a,nodesRefRepository:J,connectNodes:l,dragNodes:c,scale:de.k,setConnectLineState:Me,setConnectLineTo:be,setManualLayoutStatus:We,setNodeMovement:Se,onSwitchActiveTarget:_,onNodesConnect:Z})},t=Ae.current;return null==t||t.addEventListener("mousedown",e),()=>{null==t||t.removeEventListener("mousedown",e)}}),[a,l,c,de.k,J,Z,_]);const{normalizedLines:Ne,normalizedLinesMap:Re,markers:Ce}=(0,u.useMemo)((()=>(0,W.t)(s,o)),[s,o]),xe=(0,u.useMemo)((()=>Ne.flatMap((e=>{let t,n,{line:{text:a,label:s,$id:i},edge:o}=e;return a||s?(s?(t="label",n=[].concat(s)):(t="text",n=[].concat(a)),n.map((e=>{var n;return{[t]:e,id:`${i}-${null!==(n=e.placement)&&void 0!==n?n:"center"}`,edge:o}}))):[]}))),[Ne]),{nodes:Te,edges:ze}=(0,D.o)({layout:n,nodes:a,edges:s,manualLayoutStatus:Ee,userViewReady:fe,userViewNodesMap:ye,nodeMovement:Le,nodesRefRepository:J,lineLabelsRefRepository:se,normalizedLinesMap:Re,layoutOptions:r,nodesRenderId:G,lineLabelsRenderId:ne});(0,u.useEffect)((()=>{"finished"===Ee&&ke(Te.map((e=>({id:e.id,x:e.x,y:e.y}))))}),[Ee]);const De=(0,u.useMemo)((()=>(0,E.R)(ze,Te,Ne)),[Ne,Te,ze]),$e=null!=d?d:null,[Be,Oe]=(0,u.useState)($e);(0,u.useEffect)((()=>{Oe((e=>(0,P.c)(e,$e)?e:$e))}),[$e]);const Pe=(0,u.useRef)(!1);(0,u.useEffect)((()=>{Pe.current?null==V||V(Be):Pe.current=!0}),[Be,V]),(0,u.useEffect)((()=>{const e=me.current;if(!e||m)return;const t=e=>{const t=(0,w.a)(e,{renderedNodes:Te,activeTarget:Be});"delete-node"===(null==t?void 0:t.action)?null==K||K(t.node):"delete-edge"===(null==t?void 0:t.action)?null==j||j(t.edge):"switch-active-node"===(null==t?void 0:t.action)&&t.node&&(null==_||_({type:"node",nodeId:t.node.id}))};return e.addEventListener("keydown",t),()=>{e.removeEventListener("keydown",t)}}),[Be,Te,m,_,K,j]);const Ie=(0,u.useCallback)((e=>{e&&(U((e=>e+1)),Q(e)),F((t=>t||!!e))}),[]),He=(0,u.useCallback)((e=>{e&&(ae((e=>e+1)),ie(e)),te((t=>t||!!e))}),[]),Ve=(0,u.useMemo)((()=>null!=H?H:[z.sS,z.Yt]),[H]),_e=(0,u.useMemo)((()=>(0,g.s_)()),[]);(0,u.useEffect)((()=>{let e=!1;_e.scaleExtent(A?Ve:[1,1]).on("start",(()=>{e=!1,ce(!0)})).on("zoom",(t=>{e=!0,ue(t.transform)})).on("end",(()=>{ce(!1),e||null==_||_(null)}))}),[_,Ve,A,_e]),(0,u.useEffect)((()=>{const e=me.current;if(!e)return;const t=(0,p.A)(e),n=()=>{t.on(".zoom",null).on(".zoom.custom",null).on("wheel",null)};if(A||f||B)return(A||f)&&t.on("wheel.zoom.custom",(e=>{e.ctrlKey||(e.stopImmediatePropagation(),f&&(e.preventDefault(),_e.translateBy(t,e.wheelDeltaX/5,e.wheelDeltaY/5)))})),t.call(_e).on("wheel",(e=>e.preventDefault())).on("dblclick.zoom",null),B||t.on("mousedown.zoom",null).on("touchstart.zoom",null).on("touchmove.zoom",null).on("touchend.zoom",null),n;n()}),[B,f,A,_e]),(0,u.useEffect)((()=>{const e=me.current;if(0===Te.length||!e||pe)return;const{k:t,x:n,y:a}=(0,M.r)(Te,{canvasWidth:e.clientWidth,canvasHeight:e.clientHeight,scaleRange:A?Ve:void 0});_e.transform((0,p.A)(e),new g.uV(t,n,a)),ge(!0)}),[pe,Te,Ve,A,_e]);const Ke=(0,u.useMemo)((()=>`${(0,k.uniqueId)("diagram-")}-`),[]),je=`${Ke}line-arrow-`,Ye=`${Ke}mask-`,Xe=`${Ke}active-line-`;(0,u.useEffect)((()=>{re((e=>(0,x.z)(e,De,he.current)))}),[De]);const[Ze,qe]=h().useState(new Map);return(0,u.useEffect)((()=>{if(!se)return;(0,$.F)(oe,se);const e=new v.A((()=>{qe((0,I.G)(oe,se))}));for(const t of se.values())e.observe(t);return()=>{e.disconnect()}}),[ne,se,oe]),"dagre"!==n&&"force"!==n?h().createElement("div",null,`Diagram layout not supported: "${n}"`):h().createElement("div",{className:y()("diagram",{ready:q&&pe,grabbing:le,pannable:B}),tabIndex:-1,ref:me},h().createElement("svg",{width:"100%",height:"100%",className:"lines"},h().createElement("defs",null,Ce.map(((e,t)=>{let{type:n,strokeColor:a}=e;return h().createElement(N.c,{key:t,id:`${je}${t}`,type:n,strokeColor:a})})),[...Ze].map((e=>{let[t,n]=e;return h().createElement(R.y,{key:t,lineId:t,rects:n,maskPrefix:Ye,renderedLineLabels:oe})})),h().createElement("marker",{id:`${Xe}start`,viewBox:"0 0 8 8",refX:4,refY:4,markerWidth:8,markerHeight:8,orient:"auto"},h().createElement("path",{d:"M 0.5 0.5 H 7.5 V 7.5 H 0.5 Z",stroke:"var(--palette-gray-7)",strokeWidth:1,fill:"var(--palette-gray-1)"})),h().createElement("marker",{id:`${Xe}end`,viewBox:"0 0 14 8",refX:3,refY:4,markerWidth:14,markerHeight:8,orient:"auto"},h().createElement("path",{d:"M 0.5 1.5 L 5.5 4 L 0.5 6.5 z",stroke:"var(--palette-blue-3)",strokeWidth:1,fill:"var(--palette-blue-3)"}),h().createElement("path",{d:"M 6.5 0.5 H 13.5 V 7.5 H 6.5 Z",stroke:"var(--palette-gray-7)",strokeWidth:1,fill:"var(--palette-gray-1)"}))),h().createElement("g",{transform:`translate(${de.x} ${de.y}) scale(${de.k})`},De.map((e=>h().createElement(S.m,{key:e.line.$id,line:e,linePaths:he.current,lineMaskRects:Ze,maskPrefix:Ye,markerPrefix:je,activeLineMarkerPrefix:Xe,active:"edge"===(null==Be?void 0:Be.type)&&Be.edge.source===e.edge.source&&Be.edge.target===e.edge.target,activeRelated:"node"===(null==Be?void 0:Be.type)&&(e.edge.source===Be.nodeId||e.edge.target===Be.nodeId),onLineClick:Y,onLineDoubleClick:X}))))),h().createElement("div",{className:y()("line-labels",{ready:ee}),style:{left:de.x,top:de.y,transform:`scale(${de.k})`}},h().createElement(L.d2,{labels:xe,onRendered:He})),h().createElement("div",{className:"nodes",ref:Ae,style:{left:de.x,top:de.y,transform:`scale(${de.k})`}},h().createElement(b.p,{nodes:a,nodeBricks:i,onRendered:Ie})),h().createElement(C.w,{connectLineState:we,connectLineTo:ve,markerPrefix:je}))}a=bt,({e:[_,K,j,Y,X,Z,q,F,G,U,J,Q,ee,te,ne,ae,se,ie,oe,re,le,ce,de,ue,he,me,Ae,pe,ge,fe,ye,ke,ve,be,we,Me,Ee,We,Le,Se,Ne,Re,Ce,xe,Te,ze,De,$e,Be,Oe,Pe,Ie,H],c:[Ye,V]}=(0,d.A)(a,[He("eo-diagram",{styleTexts:[B.A]})],[[Ve({type:String}),1,"layout"],[Ve({attribute:!1}),1,"nodes"],[Ve({attribute:!1}),1,"edges"],[Ve({attribute:!1}),1,"nodeBricks"],[Ve({attribute:!1}),1,"lines"],[Ve({attribute:!1}),1,"layoutOptions"],[Ve({attribute:!1}),1,"activeTarget"],[Ve({type:Boolean}),1,"disableKeyboardAction"],[Ve({attribute:!1}),1,"connectNodes"],[Ve({attribute:!1}),1,"dragNodes"],[Ve({type:Boolean}),1,"zoomable"],[Ve({type:Boolean}),1,"scrollable"],[Ve({type:Boolean}),1,"pannable"],[Ve({attribute:!1}),1,"scaleRange"],[_e({type:"activeTarget.change"}),1,"activeTargetChangeEvent",e=>(0,c.A)(ot,e),(e,t)=>(0,l.A)(ot,e,t)],[_e({type:"node.delete"}),1,"nodeDelete",e=>(0,c.A)(ct,e),(e,t)=>(0,l.A)(ct,e,t)],[_e({type:"edge.delete"}),1,"edgeDelete",e=>(0,c.A)(ut,e),(e,t)=>(0,l.A)(ut,e,t)],[_e({type:"line.click"}),1,"lineClick",e=>(0,c.A)(mt,e),(e,t)=>(0,l.A)(mt,e,t)],[_e({type:"line.dblclick"}),1,"lineDoubleClick",e=>(0,c.A)(pt,e),(e,t)=>(0,l.A)(pt,e,t)],[_e({type:"nodes.connect"}),1,"connectNodes",e=>(0,c.A)(ft,e),(e,t)=>(0,l.A)(ft,e,t)],[Ke(),2,"callOnLineLabel"]],0,(e=>vt.has((0,o.A)(e))),A.ReactNextElement)),V()},2559:(e,t,n)=>{function a(e,t,n){if("function"==typeof e?e===t:e.has(t))return arguments.length<3?t:n;throw new TypeError("Private element is not present on this object")}n.d(t,{A:()=>a})},2016:(e,t,n)=>{function a(e,t){if(t.has(e))throw new TypeError("Cannot initialize the same private elements twice on an object")}n.d(t,{A:()=>a})},829:(e,t,n)=>{n.d(t,{A:()=>s});var a=n(2559);function s(e,t){return e.get((0,a.A)(e,t))}},918:(e,t,n)=>{n.d(t,{A:()=>s});var a=n(2016);function s(e,t,n){(0,a.A)(e,t),t.set(e,n)}},6121:(e,t,n)=>{n.d(t,{A:()=>s});var a=n(2559);function s(e,t,n){return e.set((0,a.A)(e,t),n),n}},4635:(e,t,n)=>{n.d(t,{A:()=>s});var a=n(2016);function s(e,t){(0,a.A)(e,t),t.add(e)}},1369:(e,t,n)=>{n.d(t,{A:()=>s});var a=n(7545);function s(e){var t=function(e,t){if("object"!=(0,a.A)(e)||!e)return e;var n=e[Symbol.toPrimitive];if(void 0!==n){var s=n.call(e,"string");if("object"!=(0,a.A)(s))return s;throw new TypeError("@@toPrimitive must return a primitive value.")}return String(e)}(e);return"symbol"==(0,a.A)(t)?t:t+""}},7545:(e,t,n)=>{function a(e){return a="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},a(e)}n.d(t,{A:()=>a})}}]);
2
+ //# sourceMappingURL=eo-diagram.5f3935a9.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"chunks/eo-diagram.93f17e33.js","mappings":"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","sources":["webpack:///./src/diagram/index.tsx","webpack:///../../node_modules/@babel/runtime/helpers/esm/assertClassBrand.js","webpack:///../../node_modules/@babel/runtime/helpers/esm/checkPrivateRedeclaration.js","webpack:///../../node_modules/@babel/runtime/helpers/esm/classPrivateFieldGet2.js","webpack:///../../node_modules/@babel/runtime/helpers/esm/classPrivateFieldInitSpec.js","webpack:///../../node_modules/@babel/runtime/helpers/esm/classPrivateFieldSet2.js","webpack:///../../node_modules/@babel/runtime/helpers/esm/classPrivateMethodInitSpec.js","webpack:///../../node_modules/@babel/runtime/helpers/esm/toPropertyKey.js","webpack:///../../node_modules/@babel/runtime/helpers/esm/toPrimitive.js","webpack:///../../node_modules/@babel/runtime/helpers/esm/typeof.js"],"sourcesContent":["import React, {\n createRef,\n forwardRef,\n useCallback,\n useEffect,\n useImperativeHandle,\n useMemo,\n useRef,\n useState,\n} from \"react\";\nimport { EventEmitter, createDecorators } from \"@next-core/element\";\nimport { ReactNextElement } from \"@next-core/react-element\";\nimport \"@next-core/theme\";\nimport { select } from \"d3-selection\";\nimport { ZoomTransform, zoom } from \"d3-zoom\";\nimport classNames from \"classnames\";\nimport { uniqueId } from \"lodash\";\nimport ResizeObserver from \"resize-observer-polyfill\";\nimport type {\n DiagramEdge,\n DiagramNode,\n LayoutOptions,\n LineConf,\n NodeBrickConf,\n PositionTuple,\n RefRepository,\n RenderedLineLabel,\n TransformLiteral,\n LineTarget,\n ConnectLineDetail,\n ConnectNodesOptions,\n ConnectLineState,\n ActiveTarget,\n RangeTuple,\n LineLabel,\n LineLabelConf,\n TextOptions,\n DragNodesOptions,\n NodeMovement,\n ManualLayoutStatus,\n LineMaskRects,\n} from \"./interfaces\";\nimport { NodeComponentGroup } from \"./NodeComponent\";\nimport { handleKeyboard } from \"./processors/handleKeyboard\";\nimport { transformToCenter } from \"./processors/transformToCenter\";\nimport { getRenderedLines } from \"./processors/getRenderedLines\";\nimport { normalizeLinesAndMarkers } from \"./processors/normalizeLinesAndMarkers\";\nimport { LineLabelComponentGroup } from \"./LineLabelComponent\";\nimport { LineComponent } from \"./LineComponent\";\nimport { MarkerComponent } from \"./MarkerComponent\";\nimport { LineMaskComponent } from \"./LineMaskComponent\";\nimport { ConnectLineComponent } from \"./ConnectLineComponent\";\nimport { getRenderedLineLabels } from \"./processors/getRenderedLineLabels\";\nimport { handleNodesMouseDown } from \"./processors/handleNodesMouseDown\";\nimport { DEFAULT_SCALE_RANGE_MAX, DEFAULT_SCALE_RANGE_MIN } from \"./constants\";\nimport { useRenderedDiagram } from \"./hooks/useRenderedDiagram\";\nimport { adjustLineLabels } from \"./processors/adjustLineLabels\";\nimport styleText from \"./styles.shadow.css\";\nimport { useUserView } from \"./hooks/useUserView\";\nimport { sameTarget } from \"./processors/sameTarget\";\nimport { getLineMaskRects } from \"./processors/getLineMaskRects\";\n\nconst { defineElement, property, event, method } = createDecorators();\n\nexport interface EoDiagramProps {\n layout?: \"dagre\" | \"force\";\n nodes?: DiagramNode[];\n edges?: DiagramEdge[];\n nodeBricks?: NodeBrickConf[];\n lines?: LineConf[];\n layoutOptions?: LayoutOptions;\n connectNodes?: ConnectNodesOptions;\n dragNodes?: DragNodesOptions;\n activeTarget?: ActiveTarget | null;\n disableKeyboardAction?: boolean;\n zoomable?: boolean;\n scrollable?: boolean;\n pannable?: boolean;\n scaleRange?: RangeTuple;\n}\n\nexport interface DiagramRef {\n callOnLineLabel(id: string, method: string, ...args: unknown[]): void;\n}\n\nexport const EoDiagramComponent = forwardRef(LegacyEoDiagramComponent);\n\n/**\n * 构件 `eo-diagram`\n */\nexport\n@defineElement(\"eo-diagram\", {\n styleTexts: [styleText],\n})\nclass EoDiagram extends ReactNextElement implements EoDiagramProps {\n /**\n * @required\n */\n @property({ type: String })\n accessor layout: \"dagre\" | \"force\" | undefined;\n\n @property({ attribute: false })\n accessor nodes: DiagramNode[] | undefined;\n\n @property({ attribute: false })\n accessor edges: DiagramEdge[] | undefined;\n\n @property({ attribute: false })\n accessor nodeBricks: NodeBrickConf[] | undefined;\n\n @property({ attribute: false })\n accessor lines: LineConf[] | undefined;\n\n @property({ attribute: false })\n accessor layoutOptions: LayoutOptions | undefined;\n\n @property({ attribute: false })\n accessor activeTarget: ActiveTarget | null | undefined;\n\n @property({ type: Boolean })\n accessor disableKeyboardAction: boolean | undefined;\n\n @property({ attribute: false })\n accessor connectNodes: ConnectNodesOptions | undefined;\n\n @property({ attribute: false })\n accessor dragNodes: DragNodesOptions | undefined;\n\n @property({ type: Boolean })\n accessor zoomable: boolean | undefined = true;\n\n @property({ type: Boolean })\n accessor scrollable: boolean | undefined = true;\n\n @property({ type: Boolean })\n accessor pannable: boolean | undefined = true;\n\n @property({ attribute: false })\n accessor scaleRange: RangeTuple | undefined;\n\n @event({ type: \"activeTarget.change\" })\n accessor #activeTargetChangeEvent!: EventEmitter<ActiveTarget | null>;\n\n #handleActiveTargetChange = (target: ActiveTarget | null) => {\n this.#activeTargetChangeEvent.emit(target);\n };\n\n @event({ type: \"node.delete\" })\n accessor #nodeDelete!: EventEmitter<DiagramNode>;\n\n #handleNodeDelete = (node: DiagramNode) => {\n this.#nodeDelete.emit(node);\n };\n\n @event({ type: \"edge.delete\" })\n accessor #edgeDelete!: EventEmitter<DiagramEdge>;\n\n #handleEdgeDelete = (edge: DiagramEdge) => {\n this.#edgeDelete.emit(edge);\n };\n\n @event({ type: \"line.click\" })\n accessor #lineClick!: EventEmitter<LineTarget>;\n\n #handleLineClick = (line: LineTarget) => {\n this.#lineClick.emit(line);\n };\n\n @event({ type: \"line.dblclick\" })\n accessor #lineDoubleClick!: EventEmitter<LineTarget>;\n\n #handleLineDoubleClick = (line: LineTarget) => {\n this.#lineDoubleClick.emit(line);\n };\n\n @event({ type: \"nodes.connect\" })\n accessor #connectNodes!: EventEmitter<ConnectLineDetail>;\n\n #handleNodesConnect = (detail: ConnectLineDetail) => {\n this.#connectNodes.emit(detail);\n };\n\n #handleSwitchActiveTarget = (target: ActiveTarget | null) => {\n if (!sameTarget(target, this.activeTarget)) {\n this.activeTarget = target;\n }\n };\n\n #diagramRef = createRef<DiagramRef>();\n\n @method()\n callOnLineLabel(id: string, method: string, ...args: unknown[]) {\n this.#diagramRef.current?.callOnLineLabel(id, method, ...args);\n }\n\n render() {\n return (\n <EoDiagramComponent\n ref={this.#diagramRef}\n layout={this.layout}\n nodes={this.nodes}\n edges={this.edges}\n nodeBricks={this.nodeBricks}\n lines={this.lines}\n layoutOptions={this.layoutOptions}\n connectNodes={this.connectNodes}\n dragNodes={this.dragNodes}\n activeTarget={this.activeTarget}\n disableKeyboardAction={this.disableKeyboardAction}\n zoomable={this.zoomable}\n scrollable={this.scrollable}\n pannable={this.pannable}\n scaleRange={this.scaleRange}\n onActiveTargetChange={this.#handleActiveTargetChange}\n onSwitchActiveTarget={this.#handleSwitchActiveTarget}\n onNodeDelete={this.#handleNodeDelete}\n onEdgeDelete={this.#handleEdgeDelete}\n onLineClick={this.#handleLineClick}\n onLineDoubleClick={this.#handleLineDoubleClick}\n onNodesConnect={this.#handleNodesConnect}\n />\n );\n }\n}\n\nexport interface EoDiagramComponentProps extends EoDiagramProps {\n onActiveTargetChange?(target: ActiveTarget | null): void;\n onSwitchActiveTarget?(target: ActiveTarget | null): void;\n onNodeDelete?(node: DiagramNode): void;\n onEdgeDelete?(edge: DiagramEdge): void;\n onLineClick?(line: LineTarget): void;\n onLineDoubleClick?(line: LineTarget): void;\n onNodesConnect?(detail: ConnectLineDetail): void;\n}\n\nexport function LegacyEoDiagramComponent(\n {\n layout,\n nodes,\n edges,\n nodeBricks,\n lines,\n layoutOptions,\n connectNodes,\n dragNodes,\n activeTarget: _activeTarget,\n disableKeyboardAction,\n zoomable,\n scrollable,\n pannable,\n scaleRange: _scaleRange,\n onActiveTargetChange,\n onSwitchActiveTarget,\n onNodeDelete,\n onEdgeDelete,\n onLineClick,\n onLineDoubleClick,\n onNodesConnect,\n }: EoDiagramComponentProps,\n ref: React.Ref<DiagramRef>\n) {\n const [nodesReady, setNodesReady] = useState(false);\n const [nodesRenderId, setNodesRenderId] = useState(0);\n const [nodesRefRepository, setNodesRefRepository] =\n useState<RefRepository | null>(null);\n const [lineLabelsReady, setLineLabelsReady] = useState(false);\n const [lineLabelsRenderId, setLineLabelsRenderId] = useState(0);\n const [lineLabelsRefRepository, setLineLabelsRefRepository] =\n useState<RefRepository | null>(null);\n const [renderedLineLabels, setRenderedLineLabels] = useState<\n RenderedLineLabel[]\n >([]);\n\n const [grabbing, setGrabbing] = useState(false);\n const [transform, setTransform] = useState<TransformLiteral>({\n k: 1,\n x: 0,\n y: 0,\n });\n\n const linePathsRef = useRef(new Map<string, SVGPathElement | null>());\n\n const rootRef = useRef<HTMLDivElement>(null);\n const nodesRef = useRef<HTMLDivElement>(null);\n const [centered, setCentered] = useState(false);\n\n const { userViewReady, userViewNodesMap, saveUserView } = useUserView(\n dragNodes?.save\n );\n\n const [connectLineTo, setConnectLineTo] = useState<PositionTuple>([0, 0]);\n const [connectLineState, setConnectLineState] =\n useState<ConnectLineState | null>(null);\n const [manualLayoutStatus, setManualLayoutStatus] =\n useState<ManualLayoutStatus>(\"initial\");\n const [nodeMovement, setNodeMovement] = useState<NodeMovement | null>(null);\n\n useImperativeHandle(ref, () => ({\n callOnLineLabel(id, method, ...args) {\n (\n lineLabelsRefRepository?.get(id)\n ?.firstElementChild as unknown as Record<string, Function>\n )?.[method](...args);\n },\n }));\n\n useEffect(() => {\n const onNodesMouseDown = (event: MouseEvent) => {\n handleNodesMouseDown(event, {\n nodes,\n nodesRefRepository,\n connectNodes,\n dragNodes,\n scale: transform.k,\n setConnectLineState,\n setConnectLineTo,\n setManualLayoutStatus,\n setNodeMovement,\n onSwitchActiveTarget,\n onNodesConnect,\n });\n };\n // Bind mousedown event manually, since the React event handler can't work with\n // d3-zoom inside shadow DOM.\n const nodesContainer = nodesRef.current;\n nodesContainer?.addEventListener(\"mousedown\", onNodesMouseDown);\n return () => {\n nodesContainer?.removeEventListener(\"mousedown\", onNodesMouseDown);\n };\n }, [\n nodes,\n connectNodes,\n dragNodes,\n transform.k,\n nodesRefRepository,\n onNodesConnect,\n onSwitchActiveTarget,\n ]);\n\n const { normalizedLines, normalizedLinesMap, markers } = useMemo(\n () => normalizeLinesAndMarkers(edges, lines),\n [edges, lines]\n );\n\n const lineLabels = useMemo(() => {\n return normalizedLines.flatMap(({ line: { text, label, $id }, edge }) => {\n if (!text && !label) {\n return [] as LineLabel[];\n }\n\n let key: \"label\" | \"text\";\n let list: LineLabelConf[] | TextOptions[];\n if (label) {\n key = \"label\";\n list = ([] as LineLabelConf[]).concat(label);\n } else {\n key = \"text\";\n list = ([] as TextOptions[]).concat(text!);\n }\n\n return list.map<LineLabel>((item) => ({\n [key as \"label\"]: item as LineLabelConf,\n id: `${$id}-${item.placement ?? \"center\"}`,\n edge,\n }));\n });\n }, [normalizedLines]);\n\n const { nodes: renderedNodes, edges: renderedEdges } = useRenderedDiagram({\n layout,\n nodes,\n edges,\n manualLayoutStatus,\n userViewReady,\n userViewNodesMap,\n nodeMovement,\n nodesRefRepository,\n lineLabelsRefRepository,\n normalizedLinesMap,\n layoutOptions,\n nodesRenderId,\n lineLabelsRenderId,\n });\n\n useEffect(\n () => {\n if (manualLayoutStatus === \"finished\") {\n saveUserView(\n renderedNodes.map((node) => ({\n id: node.id,\n x: node.x,\n y: node.y,\n }))\n );\n }\n },\n // Only save user view when manual layout is just finished.\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [manualLayoutStatus]\n );\n\n const renderedLines = useMemo(\n () => getRenderedLines(renderedEdges, renderedNodes, normalizedLines),\n [normalizedLines, renderedNodes, renderedEdges]\n );\n\n const newActiveTarget = _activeTarget ?? null;\n const [activeTarget, setActiveTarget] = useState<ActiveTarget | null>(\n newActiveTarget\n );\n\n useEffect(() => {\n setActiveTarget((previous) =>\n sameTarget(previous, newActiveTarget) ? previous : newActiveTarget\n );\n }, [newActiveTarget]);\n\n const activeTargetChangeInitialized = useRef(false);\n useEffect(() => {\n if (!activeTargetChangeInitialized.current) {\n activeTargetChangeInitialized.current = true;\n return;\n }\n onActiveTargetChange?.(activeTarget);\n }, [activeTarget, onActiveTargetChange]);\n\n useEffect(() => {\n const root = rootRef.current;\n if (!root || disableKeyboardAction) {\n return;\n }\n const onKeydown = (event: KeyboardEvent) => {\n const action = handleKeyboard(event, {\n renderedNodes,\n activeTarget,\n });\n\n if (action?.action === \"delete-node\") {\n onNodeDelete?.(action.node);\n } else if (action?.action === \"delete-edge\") {\n onEdgeDelete?.(action.edge);\n } else if (action?.action === \"switch-active-node\" && action.node) {\n onSwitchActiveTarget?.({ type: \"node\", nodeId: action.node.id });\n }\n };\n root.addEventListener(\"keydown\", onKeydown);\n return () => {\n root.removeEventListener(\"keydown\", onKeydown);\n };\n }, [\n activeTarget,\n renderedNodes,\n disableKeyboardAction,\n onSwitchActiveTarget,\n onNodeDelete,\n onEdgeDelete,\n ]);\n\n const handleNodesRendered = useCallback(\n (refRepository: RefRepository | null) => {\n if (refRepository) {\n setNodesRenderId((previous) => previous + 1);\n setNodesRefRepository(refRepository);\n }\n setNodesReady((previous) => previous || !!refRepository);\n },\n []\n );\n\n const handleLineLabelsRendered = useCallback(\n (refRepository: RefRepository | null) => {\n if (refRepository) {\n setLineLabelsRenderId((previous) => previous + 1);\n setLineLabelsRefRepository(refRepository);\n }\n setLineLabelsReady((previous) => previous || !!refRepository);\n },\n []\n );\n\n const scaleRange = useMemo(\n () =>\n _scaleRange ??\n ([DEFAULT_SCALE_RANGE_MIN, DEFAULT_SCALE_RANGE_MAX] as RangeTuple),\n [_scaleRange]\n );\n\n const zoomer = useMemo(() => zoom<HTMLDivElement, unknown>(), []);\n\n useEffect(() => {\n let moved = false;\n zoomer\n .scaleExtent(zoomable ? scaleRange : [1, 1])\n .on(\"start\", () => {\n moved = false;\n setGrabbing(true);\n })\n .on(\"zoom\", (e: { transform: TransformLiteral }) => {\n moved = true;\n setTransform(e.transform);\n })\n .on(\"end\", () => {\n setGrabbing(false);\n if (!moved) {\n onSwitchActiveTarget?.(null);\n }\n });\n }, [onSwitchActiveTarget, scaleRange, zoomable, zoomer]);\n\n useEffect(() => {\n const root = rootRef.current;\n if (!root) {\n return;\n }\n\n const rootSelection = select(root);\n\n const unsetZoom = () => {\n rootSelection\n .on(\".zoom\", null)\n .on(\".zoom.custom\", null)\n .on(\"wheel\", null);\n };\n\n if (!(zoomable || scrollable || pannable)) {\n unsetZoom();\n return;\n }\n\n if (zoomable || scrollable) {\n // Do not override default d3 zoom handler.\n // Only handles *panning*\n rootSelection.on(\n \"wheel.zoom.custom\",\n (e: WheelEvent & { wheelDeltaX: number; wheelDeltaY: number }) => {\n // Mac OS trackpad pinch event is emitted as a wheel.zoom and d3.event.ctrlKey set to true\n if (!e.ctrlKey) {\n // Stop immediate propagation for default d3 zoom handler\n e.stopImmediatePropagation();\n if (scrollable) {\n e.preventDefault();\n zoomer.translateBy(\n rootSelection,\n e.wheelDeltaX / 5,\n e.wheelDeltaY / 5\n );\n }\n }\n // zoomer.scaleBy(rootSelection, Math.pow(2, defaultWheelDelta(e)))\n }\n );\n }\n\n rootSelection\n .call(zoomer)\n .on(\"wheel\", (e: WheelEvent) => e.preventDefault())\n .on(\"dblclick.zoom\", null);\n\n if (!pannable) {\n rootSelection\n .on(\"mousedown.zoom\", null)\n .on(\"touchstart.zoom\", null)\n .on(\"touchmove.zoom\", null)\n .on(\"touchend.zoom\", null);\n }\n\n return unsetZoom;\n }, [pannable, scrollable, zoomable, zoomer]);\n\n useEffect(() => {\n const root = rootRef.current;\n if (renderedNodes.length === 0 || !root || centered) {\n return;\n }\n const { k, x, y } = transformToCenter(renderedNodes, {\n canvasWidth: root.clientWidth,\n canvasHeight: root.clientHeight,\n scaleRange: zoomable ? scaleRange : undefined,\n });\n zoomer.transform(select(root), new ZoomTransform(k, x, y));\n setCentered(true);\n }, [centered, renderedNodes, scaleRange, zoomable, zoomer]);\n\n const defPrefix = useMemo(() => `${uniqueId(\"diagram-\")}-`, []);\n const markerPrefix = `${defPrefix}line-arrow-`;\n const maskPrefix = `${defPrefix}mask-`;\n const activeLineMarkerPrefix = `${defPrefix}active-line-`;\n\n useEffect(() => {\n setRenderedLineLabels((previous) =>\n getRenderedLineLabels(previous, renderedLines, linePathsRef.current)\n );\n }, [renderedLines]);\n\n const [lineMaskRects, setLineMaskRects] = React.useState<LineMaskRects>(\n new Map()\n );\n\n useEffect(() => {\n if (!lineLabelsRefRepository) {\n return;\n }\n const updateLineMaskRects = () => {\n setLineMaskRects(\n getLineMaskRects(renderedLineLabels, lineLabelsRefRepository)\n );\n };\n\n adjustLineLabels(renderedLineLabels, lineLabelsRefRepository);\n\n const observer = new ResizeObserver(updateLineMaskRects);\n for (const lineLabel of lineLabelsRefRepository.values()) {\n observer.observe(lineLabel);\n }\n return () => {\n observer.disconnect();\n };\n }, [lineLabelsRenderId, lineLabelsRefRepository, renderedLineLabels]);\n\n if (layout !== \"dagre\" && layout !== \"force\") {\n return <div>{`Diagram layout not supported: \"${layout}\"`}</div>;\n }\n\n return (\n <div\n className={classNames(\"diagram\", {\n ready: nodesReady && centered,\n grabbing,\n pannable,\n })}\n tabIndex={-1}\n ref={rootRef}\n >\n <svg width=\"100%\" height=\"100%\" className=\"lines\">\n <defs>\n {markers.map(({ type, strokeColor }, index) => (\n <MarkerComponent\n key={index}\n id={`${markerPrefix}${index}`}\n type={type}\n strokeColor={strokeColor}\n />\n ))}\n {[...lineMaskRects].map(([lineId, rects]) => (\n <LineMaskComponent\n key={lineId}\n lineId={lineId}\n rects={rects}\n maskPrefix={maskPrefix}\n renderedLineLabels={renderedLineLabels}\n />\n ))}\n <marker\n id={`${activeLineMarkerPrefix}start`}\n viewBox=\"0 0 8 8\"\n refX={4}\n refY={4}\n markerWidth={8}\n markerHeight={8}\n orient=\"auto\"\n >\n <path\n d=\"M 0.5 0.5 H 7.5 V 7.5 H 0.5 Z\"\n stroke=\"var(--palette-gray-7)\"\n strokeWidth={1}\n fill=\"var(--palette-gray-1)\"\n />\n </marker>\n <marker\n id={`${activeLineMarkerPrefix}end`}\n viewBox=\"0 0 14 8\"\n refX={3}\n refY={4}\n markerWidth={14}\n markerHeight={8}\n orient=\"auto\"\n >\n <path\n d=\"M 0.5 1.5 L 5.5 4 L 0.5 6.5 z\"\n stroke=\"var(--palette-blue-3)\"\n strokeWidth={1}\n fill=\"var(--palette-blue-3)\"\n />\n <path\n d=\"M 6.5 0.5 H 13.5 V 7.5 H 6.5 Z\"\n stroke=\"var(--palette-gray-7)\"\n strokeWidth={1}\n fill=\"var(--palette-gray-1)\"\n />\n </marker>\n </defs>\n <g\n transform={`translate(${transform.x} ${transform.y}) scale(${transform.k})`}\n >\n {renderedLines.map((line) => (\n <LineComponent\n key={line.line.$id}\n line={line}\n linePaths={linePathsRef.current}\n lineMaskRects={lineMaskRects}\n maskPrefix={maskPrefix}\n markerPrefix={markerPrefix}\n activeLineMarkerPrefix={activeLineMarkerPrefix}\n active={\n activeTarget?.type === \"edge\" &&\n activeTarget.edge.source === line.edge.source &&\n activeTarget.edge.target === line.edge.target\n }\n activeRelated={\n activeTarget?.type === \"node\" &&\n (line.edge.source === activeTarget.nodeId ||\n line.edge.target === activeTarget.nodeId)\n }\n onLineClick={onLineClick}\n onLineDoubleClick={onLineDoubleClick}\n />\n ))}\n </g>\n </svg>\n <div\n className={classNames(\"line-labels\", { ready: lineLabelsReady })}\n style={{\n left: transform.x,\n top: transform.y,\n transform: `scale(${transform.k})`,\n }}\n >\n <LineLabelComponentGroup\n labels={lineLabels}\n onRendered={handleLineLabelsRendered}\n />\n </div>\n <div\n className=\"nodes\"\n ref={nodesRef}\n style={{\n left: transform.x,\n top: transform.y,\n transform: `scale(${transform.k})`,\n }}\n >\n <NodeComponentGroup\n nodes={nodes}\n nodeBricks={nodeBricks}\n // nodePositions={nodePositions}\n onRendered={handleNodesRendered}\n />\n </div>\n <ConnectLineComponent\n connectLineState={connectLineState}\n connectLineTo={connectLineTo}\n markerPrefix={markerPrefix}\n />\n </div>\n );\n}\n","export default function _assertClassBrand(e, t, n) {\n if (\"function\" == typeof e ? e === t : e.has(t)) return arguments.length < 3 ? t : n;\n throw new TypeError(\"Private element is not present on this object\");\n}","export default function _checkPrivateRedeclaration(obj, privateCollection) {\n if (privateCollection.has(obj)) {\n throw new TypeError(\"Cannot initialize the same private elements twice on an object\");\n }\n}","import assertClassBrand from \"./assertClassBrand.js\";\nexport default function _classPrivateFieldGet2(s, a) {\n return s.get(assertClassBrand(s, a));\n}","import checkPrivateRedeclaration from \"./checkPrivateRedeclaration.js\";\nexport default function _classPrivateFieldInitSpec(obj, privateMap, value) {\n checkPrivateRedeclaration(obj, privateMap);\n privateMap.set(obj, value);\n}","import assertClassBrand from \"./assertClassBrand.js\";\nexport default function _classPrivateFieldSet2(s, a, r) {\n return s.set(assertClassBrand(s, a), r), r;\n}","import checkPrivateRedeclaration from \"./checkPrivateRedeclaration.js\";\nexport default function _classPrivateMethodInitSpec(obj, privateSet) {\n checkPrivateRedeclaration(obj, privateSet);\n privateSet.add(obj);\n}","import _typeof from \"./typeof.js\";\nimport toPrimitive from \"./toPrimitive.js\";\nexport default function toPropertyKey(t) {\n var i = toPrimitive(t, \"string\");\n return \"symbol\" == _typeof(i) ? i : i + \"\";\n}","import _typeof from \"./typeof.js\";\nexport default function toPrimitive(t, r) {\n if (\"object\" != _typeof(t) || !t) return t;\n var e = t[Symbol.toPrimitive];\n if (void 0 !== e) {\n var i = e.call(t, r || \"default\");\n if (\"object\" != _typeof(i)) return i;\n throw new TypeError(\"@@toPrimitive must return a primitive value.\");\n }\n return (\"string\" === r ? String : Number)(t);\n}","export default function _typeof(o) {\n \"@babel/helpers - typeof\";\n\n return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (o) {\n return typeof o;\n } : function (o) {\n return o && \"function\" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? \"symbol\" : typeof o;\n }, _typeof(o);\n}"],"names":["defineElement","property","event","method","createDecorators","EoDiagramComponent","forwardRef","LegacyEoDiagramComponent","_EoDiagram","_A","WeakMap","_B","_C","_D","_E","_F","_G","_H","_I","_J","_K","_L","_M","_N","_O","_EoDiagram_brand","WeakSet","_handleActiveTargetChange","_P","_handleNodeDelete","_Q","_handleEdgeDelete","_R","_handleLineClick","_S","_handleLineDoubleClick","_T","_handleNodesConnect","_handleSwitchActiveTarget","_diagramRef","EoDiagram","ReactNextElement","constructor","arguments","_classPrivateMethodInitSpec","_classPrivateFieldInitSpec","_initProto","_init_layout","_init_extra_layout","_init_nodes","_init_extra_nodes","_init_edges","_init_extra_edges","_init_nodeBricks","_init_extra_nodeBricks","_init_lines","_init_extra_lines","_init_layoutOptions","_init_extra_layoutOptions","_init_activeTarget","_init_extra_activeTarget","_init_disableKeyboardAction","_init_extra_disableKeyboardAction","_init_connectNodes","_init_extra_connectNodes","_init_dragNodes","_init_extra_dragNodes","_init_zoomable","_init_extra_zoomable","_init_scrollable","_init_extra_scrollable","_init_pannable","_init_extra_pannable","_init_scaleRange","_init_extra_scaleRange","_init_activeTargetChangeEvent","_init_extra_activeTargetChangeEvent","target","_classPrivateGetter","this","_get_activeTargetChangeEvent","emit","_init_nodeDelete","_init_extra_nodeDelete","node","_get_nodeDelete","_init_edgeDelete","_init_extra_edgeDelete","edge","_get_edgeDelete","_init_lineClick","_init_extra_lineClick","line","_get_lineClick","_init_lineDoubleClick","_init_extra_lineDoubleClick","_get_lineDoubleClick","_init_connectNodes2","_init_extra_connectNodes2","detail","_get_connectNodes","sameTarget","activeTarget","createRef","layout","_classPrivateFieldGet","v","_classPrivateFieldSet","nodes","edges","nodeBricks","lines","layoutOptions","disableKeyboardAction","connectNodes","dragNodes","zoomable","scrollable","pannable","scaleRange","callOnLineLabel","id","_classPrivateFieldGet2","_len","length","args","Array","_key","current","render","React","ref","onActiveTargetChange","onSwitchActiveTarget","onNodeDelete","onEdgeDelete","onLineClick","onLineDoubleClick","onNodesConnect","_ref","_activeTarget","_scaleRange","nodesReady","setNodesReady","useState","nodesRenderId","setNodesRenderId","nodesRefRepository","setNodesRefRepository","lineLabelsReady","setLineLabelsReady","lineLabelsRenderId","setLineLabelsRenderId","lineLabelsRefRepository","setLineLabelsRefRepository","renderedLineLabels","setRenderedLineLabels","grabbing","setGrabbing","transform","setTransform","k","x","y","linePathsRef","useRef","Map","rootRef","nodesRef","centered","setCentered","userViewReady","userViewNodesMap","saveUserView","useUserView","save","connectLineTo","setConnectLineTo","connectLineState","setConnectLineState","manualLayoutStatus","setManualLayoutStatus","nodeMovement","setNodeMovement","useImperativeHandle","_lineLabelsRefReposit","_len2","_key2","get","firstElementChild","useEffect","onNodesMouseDown","handleNodesMouseDown","scale","nodesContainer","addEventListener","removeEventListener","normalizedLines","normalizedLinesMap","markers","useMemo","normalizeLinesAndMarkers","lineLabels","flatMap","_ref2","key","list","text","label","$id","concat","map","item","placement","renderedNodes","renderedEdges","useRenderedDiagram","renderedLines","getRenderedLines","newActiveTarget","setActiveTarget","previous","activeTargetChangeInitialized","root","onKeydown","action","handleKeyboard","type","nodeId","handleNodesRendered","useCallback","refRepository","handleLineLabelsRendered","DEFAULT_SCALE_RANGE_MIN","DEFAULT_SCALE_RANGE_MAX","zoomer","zoom","moved","scaleExtent","on","e","rootSelection","select","unsetZoom","ctrlKey","stopImmediatePropagation","preventDefault","translateBy","wheelDeltaX","wheelDeltaY","call","transformToCenter","canvasWidth","clientWidth","canvasHeight","clientHeight","undefined","ZoomTransform","defPrefix","uniqueId","markerPrefix","maskPrefix","activeLineMarkerPrefix","getRenderedLineLabels","lineMaskRects","setLineMaskRects","adjustLineLabels","observer","ResizeObserver","updateLineMaskRects","getLineMaskRects","lineLabel","values","observe","disconnect","className","classNames","ready","tabIndex","width","height","_ref3","index","strokeColor","MarkerComponent","_ref4","lineId","rects","LineMaskComponent","viewBox","refX","refY","markerWidth","markerHeight","orient","d","stroke","strokeWidth","fill","LineComponent","linePaths","active","source","activeRelated","style","left","top","LineLabelComponentGroup","labels","onRendered","NodeComponentGroup","ConnectLineComponent","_EoDiagram2","_set_activeTargetChangeEvent","_set_nodeDelete","_set_edgeDelete","_set_lineClick","_set_lineDoubleClick","_set_connectNodes","c","_initClass","_applyDecs","styleTexts","styleText","String","attribute","Boolean","o","_","has","_checkInRHS","_assertClassBrand","t","n","TypeError","_checkPrivateRedeclaration","obj","privateCollection","s","a","privateMap","value","set","_classPrivateFieldSet2","r","privateSet","add","toPropertyKey","i","Symbol","toPrimitive","_typeof","iterator","prototype"],"sourceRoot":""}
1
+ {"version":3,"file":"chunks/eo-diagram.5f3935a9.js","mappings":"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","sources":["webpack:///./src/diagram/index.tsx","webpack:///../../node_modules/@babel/runtime/helpers/esm/assertClassBrand.js","webpack:///../../node_modules/@babel/runtime/helpers/esm/checkPrivateRedeclaration.js","webpack:///../../node_modules/@babel/runtime/helpers/esm/classPrivateFieldGet2.js","webpack:///../../node_modules/@babel/runtime/helpers/esm/classPrivateFieldInitSpec.js","webpack:///../../node_modules/@babel/runtime/helpers/esm/classPrivateFieldSet2.js","webpack:///../../node_modules/@babel/runtime/helpers/esm/classPrivateMethodInitSpec.js","webpack:///../../node_modules/@babel/runtime/helpers/esm/toPropertyKey.js","webpack:///../../node_modules/@babel/runtime/helpers/esm/toPrimitive.js","webpack:///../../node_modules/@babel/runtime/helpers/esm/typeof.js"],"sourcesContent":["import React, {\n createRef,\n forwardRef,\n useCallback,\n useEffect,\n useImperativeHandle,\n useMemo,\n useRef,\n useState,\n} from \"react\";\nimport { EventEmitter, createDecorators } from \"@next-core/element\";\nimport { ReactNextElement } from \"@next-core/react-element\";\nimport \"@next-core/theme\";\nimport { select } from \"d3-selection\";\nimport { ZoomTransform, zoom } from \"d3-zoom\";\nimport classNames from \"classnames\";\nimport { uniqueId } from \"lodash\";\nimport ResizeObserver from \"resize-observer-polyfill\";\nimport type {\n DiagramEdge,\n DiagramNode,\n LayoutOptions,\n LineConf,\n NodeBrickConf,\n PositionTuple,\n RefRepository,\n RenderedLineLabel,\n TransformLiteral,\n LineTarget,\n ConnectLineDetail,\n ConnectNodesOptions,\n ConnectLineState,\n ActiveTarget,\n RangeTuple,\n LineLabel,\n LineLabelConf,\n TextOptions,\n DragNodesOptions,\n NodeMovement,\n ManualLayoutStatus,\n LineMaskRects,\n} from \"./interfaces\";\nimport { NodeComponentGroup } from \"./NodeComponent\";\nimport { handleKeyboard } from \"./processors/handleKeyboard\";\nimport { transformToCenter } from \"./processors/transformToCenter\";\nimport { getRenderedLines } from \"./processors/getRenderedLines\";\nimport { normalizeLinesAndMarkers } from \"./processors/normalizeLinesAndMarkers\";\nimport { LineLabelComponentGroup } from \"./LineLabelComponent\";\nimport { LineComponent } from \"./LineComponent\";\nimport { MarkerComponent } from \"./MarkerComponent\";\nimport { LineMaskComponent } from \"./LineMaskComponent\";\nimport { ConnectLineComponent } from \"./ConnectLineComponent\";\nimport { getRenderedLineLabels } from \"./processors/getRenderedLineLabels\";\nimport { handleNodesMouseDown } from \"./processors/handleNodesMouseDown\";\nimport { DEFAULT_SCALE_RANGE_MAX, DEFAULT_SCALE_RANGE_MIN } from \"./constants\";\nimport { useRenderedDiagram } from \"./hooks/useRenderedDiagram\";\nimport { adjustLineLabels } from \"./processors/adjustLineLabels\";\nimport styleText from \"./styles.shadow.css\";\nimport { useUserView } from \"./hooks/useUserView\";\nimport { sameTarget } from \"./processors/sameTarget\";\nimport { getLineMaskRects } from \"./processors/getLineMaskRects\";\n\nconst { defineElement, property, event, method } = createDecorators();\n\nexport interface EoDiagramProps {\n layout?: \"dagre\" | \"force\";\n nodes?: DiagramNode[];\n edges?: DiagramEdge[];\n nodeBricks?: NodeBrickConf[];\n lines?: LineConf[];\n layoutOptions?: LayoutOptions;\n connectNodes?: ConnectNodesOptions;\n dragNodes?: DragNodesOptions;\n activeTarget?: ActiveTarget | null;\n disableKeyboardAction?: boolean;\n zoomable?: boolean;\n scrollable?: boolean;\n pannable?: boolean;\n scaleRange?: RangeTuple;\n}\n\nexport interface DiagramRef {\n callOnLineLabel(id: string, method: string, ...args: unknown[]): void;\n}\n\nexport const EoDiagramComponent = forwardRef(LegacyEoDiagramComponent);\n\n/**\n * 构件 `eo-diagram`\n */\nexport\n@defineElement(\"eo-diagram\", {\n styleTexts: [styleText],\n})\nclass EoDiagram extends ReactNextElement implements EoDiagramProps {\n /**\n * @required\n */\n @property({ type: String })\n accessor layout: \"dagre\" | \"force\" | undefined;\n\n @property({ attribute: false })\n accessor nodes: DiagramNode[] | undefined;\n\n @property({ attribute: false })\n accessor edges: DiagramEdge[] | undefined;\n\n @property({ attribute: false })\n accessor nodeBricks: NodeBrickConf[] | undefined;\n\n @property({ attribute: false })\n accessor lines: LineConf[] | undefined;\n\n @property({ attribute: false })\n accessor layoutOptions: LayoutOptions | undefined;\n\n @property({ attribute: false })\n accessor activeTarget: ActiveTarget | null | undefined;\n\n @property({ type: Boolean })\n accessor disableKeyboardAction: boolean | undefined;\n\n @property({ attribute: false })\n accessor connectNodes: ConnectNodesOptions | undefined;\n\n @property({ attribute: false })\n accessor dragNodes: DragNodesOptions | undefined;\n\n @property({ type: Boolean })\n accessor zoomable: boolean | undefined = true;\n\n @property({ type: Boolean })\n accessor scrollable: boolean | undefined = true;\n\n @property({ type: Boolean })\n accessor pannable: boolean | undefined = true;\n\n @property({ attribute: false })\n accessor scaleRange: RangeTuple | undefined;\n\n @event({ type: \"activeTarget.change\" })\n accessor #activeTargetChangeEvent!: EventEmitter<ActiveTarget | null>;\n\n #handleActiveTargetChange = (target: ActiveTarget | null) => {\n this.#activeTargetChangeEvent.emit(target);\n };\n\n @event({ type: \"node.delete\" })\n accessor #nodeDelete!: EventEmitter<DiagramNode>;\n\n #handleNodeDelete = (node: DiagramNode) => {\n this.#nodeDelete.emit(node);\n };\n\n @event({ type: \"edge.delete\" })\n accessor #edgeDelete!: EventEmitter<DiagramEdge>;\n\n #handleEdgeDelete = (edge: DiagramEdge) => {\n this.#edgeDelete.emit(edge);\n };\n\n @event({ type: \"line.click\" })\n accessor #lineClick!: EventEmitter<LineTarget>;\n\n #handleLineClick = (line: LineTarget) => {\n this.#lineClick.emit(line);\n };\n\n @event({ type: \"line.dblclick\" })\n accessor #lineDoubleClick!: EventEmitter<LineTarget>;\n\n #handleLineDoubleClick = (line: LineTarget) => {\n this.#lineDoubleClick.emit(line);\n };\n\n @event({ type: \"nodes.connect\" })\n accessor #connectNodes!: EventEmitter<ConnectLineDetail>;\n\n #handleNodesConnect = (detail: ConnectLineDetail) => {\n this.#connectNodes.emit(detail);\n };\n\n #handleSwitchActiveTarget = (target: ActiveTarget | null) => {\n if (!sameTarget(target, this.activeTarget)) {\n this.activeTarget = target;\n }\n };\n\n #diagramRef = createRef<DiagramRef>();\n\n @method()\n callOnLineLabel(id: string, method: string, ...args: unknown[]) {\n this.#diagramRef.current?.callOnLineLabel(id, method, ...args);\n }\n\n render() {\n return (\n <EoDiagramComponent\n ref={this.#diagramRef}\n layout={this.layout}\n nodes={this.nodes}\n edges={this.edges}\n nodeBricks={this.nodeBricks}\n lines={this.lines}\n layoutOptions={this.layoutOptions}\n connectNodes={this.connectNodes}\n dragNodes={this.dragNodes}\n activeTarget={this.activeTarget}\n disableKeyboardAction={this.disableKeyboardAction}\n zoomable={this.zoomable}\n scrollable={this.scrollable}\n pannable={this.pannable}\n scaleRange={this.scaleRange}\n onActiveTargetChange={this.#handleActiveTargetChange}\n onSwitchActiveTarget={this.#handleSwitchActiveTarget}\n onNodeDelete={this.#handleNodeDelete}\n onEdgeDelete={this.#handleEdgeDelete}\n onLineClick={this.#handleLineClick}\n onLineDoubleClick={this.#handleLineDoubleClick}\n onNodesConnect={this.#handleNodesConnect}\n />\n );\n }\n}\n\nexport interface EoDiagramComponentProps extends EoDiagramProps {\n onActiveTargetChange?(target: ActiveTarget | null): void;\n onSwitchActiveTarget?(target: ActiveTarget | null): void;\n onNodeDelete?(node: DiagramNode): void;\n onEdgeDelete?(edge: DiagramEdge): void;\n onLineClick?(line: LineTarget): void;\n onLineDoubleClick?(line: LineTarget): void;\n onNodesConnect?(detail: ConnectLineDetail): void;\n}\n\nexport function LegacyEoDiagramComponent(\n {\n layout,\n nodes,\n edges,\n nodeBricks,\n lines,\n layoutOptions,\n connectNodes,\n dragNodes,\n activeTarget: _activeTarget,\n disableKeyboardAction,\n zoomable,\n scrollable,\n pannable,\n scaleRange: _scaleRange,\n onActiveTargetChange,\n onSwitchActiveTarget,\n onNodeDelete,\n onEdgeDelete,\n onLineClick,\n onLineDoubleClick,\n onNodesConnect,\n }: EoDiagramComponentProps,\n ref: React.Ref<DiagramRef>\n) {\n const [nodesReady, setNodesReady] = useState(false);\n const [nodesRenderId, setNodesRenderId] = useState(0);\n const [nodesRefRepository, setNodesRefRepository] =\n useState<RefRepository | null>(null);\n const [lineLabelsReady, setLineLabelsReady] = useState(false);\n const [lineLabelsRenderId, setLineLabelsRenderId] = useState(0);\n const [lineLabelsRefRepository, setLineLabelsRefRepository] =\n useState<RefRepository | null>(null);\n const [renderedLineLabels, setRenderedLineLabels] = useState<\n RenderedLineLabel[]\n >([]);\n\n const [grabbing, setGrabbing] = useState(false);\n const [transform, setTransform] = useState<TransformLiteral>({\n k: 1,\n x: 0,\n y: 0,\n });\n\n const linePathsRef = useRef(new Map<string, SVGPathElement | null>());\n\n const rootRef = useRef<HTMLDivElement>(null);\n const nodesRef = useRef<HTMLDivElement>(null);\n const [centered, setCentered] = useState(false);\n\n const { userViewReady, userViewNodesMap, saveUserView } = useUserView(\n dragNodes?.save\n );\n\n const [connectLineTo, setConnectLineTo] = useState<PositionTuple>([0, 0]);\n const [connectLineState, setConnectLineState] =\n useState<ConnectLineState | null>(null);\n const [manualLayoutStatus, setManualLayoutStatus] =\n useState<ManualLayoutStatus>(\"initial\");\n const [nodeMovement, setNodeMovement] = useState<NodeMovement | null>(null);\n\n useImperativeHandle(ref, () => ({\n callOnLineLabel(id, method, ...args) {\n (\n lineLabelsRefRepository?.get(id)\n ?.firstElementChild as unknown as Record<string, Function>\n )?.[method](...args);\n },\n }));\n\n useEffect(() => {\n const onNodesMouseDown = (event: MouseEvent) => {\n handleNodesMouseDown(event, {\n nodes,\n nodesRefRepository,\n connectNodes,\n dragNodes,\n scale: transform.k,\n setConnectLineState,\n setConnectLineTo,\n setManualLayoutStatus,\n setNodeMovement,\n onSwitchActiveTarget,\n onNodesConnect,\n });\n };\n // Bind mousedown event manually, since the React event handler can't work with\n // d3-zoom inside shadow DOM.\n const nodesContainer = nodesRef.current;\n nodesContainer?.addEventListener(\"mousedown\", onNodesMouseDown);\n return () => {\n nodesContainer?.removeEventListener(\"mousedown\", onNodesMouseDown);\n };\n }, [\n nodes,\n connectNodes,\n dragNodes,\n transform.k,\n nodesRefRepository,\n onNodesConnect,\n onSwitchActiveTarget,\n ]);\n\n const { normalizedLines, normalizedLinesMap, markers } = useMemo(\n () => normalizeLinesAndMarkers(edges, lines),\n [edges, lines]\n );\n\n const lineLabels = useMemo(() => {\n return normalizedLines.flatMap(({ line: { text, label, $id }, edge }) => {\n if (!text && !label) {\n return [] as LineLabel[];\n }\n\n let key: \"label\" | \"text\";\n let list: LineLabelConf[] | TextOptions[];\n if (label) {\n key = \"label\";\n list = ([] as LineLabelConf[]).concat(label);\n } else {\n key = \"text\";\n list = ([] as TextOptions[]).concat(text!);\n }\n\n return list.map<LineLabel>((item) => ({\n [key as \"label\"]: item as LineLabelConf,\n id: `${$id}-${item.placement ?? \"center\"}`,\n edge,\n }));\n });\n }, [normalizedLines]);\n\n const { nodes: renderedNodes, edges: renderedEdges } = useRenderedDiagram({\n layout,\n nodes,\n edges,\n manualLayoutStatus,\n userViewReady,\n userViewNodesMap,\n nodeMovement,\n nodesRefRepository,\n lineLabelsRefRepository,\n normalizedLinesMap,\n layoutOptions,\n nodesRenderId,\n lineLabelsRenderId,\n });\n\n useEffect(\n () => {\n if (manualLayoutStatus === \"finished\") {\n saveUserView(\n renderedNodes.map((node) => ({\n id: node.id,\n x: node.x,\n y: node.y,\n }))\n );\n }\n },\n // Only save user view when manual layout is just finished.\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [manualLayoutStatus]\n );\n\n const renderedLines = useMemo(\n () => getRenderedLines(renderedEdges, renderedNodes, normalizedLines),\n [normalizedLines, renderedNodes, renderedEdges]\n );\n\n const newActiveTarget = _activeTarget ?? null;\n const [activeTarget, setActiveTarget] = useState<ActiveTarget | null>(\n newActiveTarget\n );\n\n useEffect(() => {\n setActiveTarget((previous) =>\n sameTarget(previous, newActiveTarget) ? previous : newActiveTarget\n );\n }, [newActiveTarget]);\n\n const activeTargetChangeInitialized = useRef(false);\n useEffect(() => {\n if (!activeTargetChangeInitialized.current) {\n activeTargetChangeInitialized.current = true;\n return;\n }\n onActiveTargetChange?.(activeTarget);\n }, [activeTarget, onActiveTargetChange]);\n\n useEffect(() => {\n const root = rootRef.current;\n if (!root || disableKeyboardAction) {\n return;\n }\n const onKeydown = (event: KeyboardEvent) => {\n const action = handleKeyboard(event, {\n renderedNodes,\n activeTarget,\n });\n\n if (action?.action === \"delete-node\") {\n onNodeDelete?.(action.node);\n } else if (action?.action === \"delete-edge\") {\n onEdgeDelete?.(action.edge);\n } else if (action?.action === \"switch-active-node\" && action.node) {\n onSwitchActiveTarget?.({ type: \"node\", nodeId: action.node.id });\n }\n };\n root.addEventListener(\"keydown\", onKeydown);\n return () => {\n root.removeEventListener(\"keydown\", onKeydown);\n };\n }, [\n activeTarget,\n renderedNodes,\n disableKeyboardAction,\n onSwitchActiveTarget,\n onNodeDelete,\n onEdgeDelete,\n ]);\n\n const handleNodesRendered = useCallback(\n (refRepository: RefRepository | null) => {\n if (refRepository) {\n setNodesRenderId((previous) => previous + 1);\n setNodesRefRepository(refRepository);\n }\n setNodesReady((previous) => previous || !!refRepository);\n },\n []\n );\n\n const handleLineLabelsRendered = useCallback(\n (refRepository: RefRepository | null) => {\n if (refRepository) {\n setLineLabelsRenderId((previous) => previous + 1);\n setLineLabelsRefRepository(refRepository);\n }\n setLineLabelsReady((previous) => previous || !!refRepository);\n },\n []\n );\n\n const scaleRange = useMemo(\n () =>\n _scaleRange ??\n ([DEFAULT_SCALE_RANGE_MIN, DEFAULT_SCALE_RANGE_MAX] as RangeTuple),\n [_scaleRange]\n );\n\n const zoomer = useMemo(() => zoom<HTMLDivElement, unknown>(), []);\n\n useEffect(() => {\n let moved = false;\n zoomer\n .scaleExtent(zoomable ? scaleRange : [1, 1])\n .on(\"start\", () => {\n moved = false;\n setGrabbing(true);\n })\n .on(\"zoom\", (e: { transform: TransformLiteral }) => {\n moved = true;\n setTransform(e.transform);\n })\n .on(\"end\", () => {\n setGrabbing(false);\n if (!moved) {\n onSwitchActiveTarget?.(null);\n }\n });\n }, [onSwitchActiveTarget, scaleRange, zoomable, zoomer]);\n\n useEffect(() => {\n const root = rootRef.current;\n if (!root) {\n return;\n }\n\n const rootSelection = select(root);\n\n const unsetZoom = () => {\n rootSelection\n .on(\".zoom\", null)\n .on(\".zoom.custom\", null)\n .on(\"wheel\", null);\n };\n\n if (!(zoomable || scrollable || pannable)) {\n unsetZoom();\n return;\n }\n\n if (zoomable || scrollable) {\n // Do not override default d3 zoom handler.\n // Only handles *panning*\n rootSelection.on(\n \"wheel.zoom.custom\",\n (e: WheelEvent & { wheelDeltaX: number; wheelDeltaY: number }) => {\n // Mac OS trackpad pinch event is emitted as a wheel.zoom and d3.event.ctrlKey set to true\n if (!e.ctrlKey) {\n // Stop immediate propagation for default d3 zoom handler\n e.stopImmediatePropagation();\n if (scrollable) {\n e.preventDefault();\n zoomer.translateBy(\n rootSelection,\n e.wheelDeltaX / 5,\n e.wheelDeltaY / 5\n );\n }\n }\n // zoomer.scaleBy(rootSelection, Math.pow(2, defaultWheelDelta(e)))\n }\n );\n }\n\n rootSelection\n .call(zoomer)\n .on(\"wheel\", (e: WheelEvent) => e.preventDefault())\n .on(\"dblclick.zoom\", null);\n\n if (!pannable) {\n rootSelection\n .on(\"mousedown.zoom\", null)\n .on(\"touchstart.zoom\", null)\n .on(\"touchmove.zoom\", null)\n .on(\"touchend.zoom\", null);\n }\n\n return unsetZoom;\n }, [pannable, scrollable, zoomable, zoomer]);\n\n useEffect(() => {\n const root = rootRef.current;\n if (renderedNodes.length === 0 || !root || centered) {\n return;\n }\n const { k, x, y } = transformToCenter(renderedNodes, {\n canvasWidth: root.clientWidth,\n canvasHeight: root.clientHeight,\n scaleRange: zoomable ? scaleRange : undefined,\n });\n zoomer.transform(select(root), new ZoomTransform(k, x, y));\n setCentered(true);\n }, [centered, renderedNodes, scaleRange, zoomable, zoomer]);\n\n const defPrefix = useMemo(() => `${uniqueId(\"diagram-\")}-`, []);\n const markerPrefix = `${defPrefix}line-arrow-`;\n const maskPrefix = `${defPrefix}mask-`;\n const activeLineMarkerPrefix = `${defPrefix}active-line-`;\n\n useEffect(() => {\n setRenderedLineLabels((previous) =>\n getRenderedLineLabels(previous, renderedLines, linePathsRef.current)\n );\n }, [renderedLines]);\n\n const [lineMaskRects, setLineMaskRects] = React.useState<LineMaskRects>(\n new Map()\n );\n\n useEffect(() => {\n if (!lineLabelsRefRepository) {\n return;\n }\n const updateLineMaskRects = () => {\n setLineMaskRects(\n getLineMaskRects(renderedLineLabels, lineLabelsRefRepository)\n );\n };\n\n adjustLineLabels(renderedLineLabels, lineLabelsRefRepository);\n\n const observer = new ResizeObserver(updateLineMaskRects);\n for (const lineLabel of lineLabelsRefRepository.values()) {\n observer.observe(lineLabel);\n }\n return () => {\n observer.disconnect();\n };\n }, [lineLabelsRenderId, lineLabelsRefRepository, renderedLineLabels]);\n\n if (layout !== \"dagre\" && layout !== \"force\") {\n return <div>{`Diagram layout not supported: \"${layout}\"`}</div>;\n }\n\n return (\n <div\n className={classNames(\"diagram\", {\n ready: nodesReady && centered,\n grabbing,\n pannable,\n })}\n tabIndex={-1}\n ref={rootRef}\n >\n <svg width=\"100%\" height=\"100%\" className=\"lines\">\n <defs>\n {markers.map(({ type, strokeColor }, index) => (\n <MarkerComponent\n key={index}\n id={`${markerPrefix}${index}`}\n type={type}\n strokeColor={strokeColor}\n />\n ))}\n {[...lineMaskRects].map(([lineId, rects]) => (\n <LineMaskComponent\n key={lineId}\n lineId={lineId}\n rects={rects}\n maskPrefix={maskPrefix}\n renderedLineLabels={renderedLineLabels}\n />\n ))}\n <marker\n id={`${activeLineMarkerPrefix}start`}\n viewBox=\"0 0 8 8\"\n refX={4}\n refY={4}\n markerWidth={8}\n markerHeight={8}\n orient=\"auto\"\n >\n <path\n d=\"M 0.5 0.5 H 7.5 V 7.5 H 0.5 Z\"\n stroke=\"var(--palette-gray-7)\"\n strokeWidth={1}\n fill=\"var(--palette-gray-1)\"\n />\n </marker>\n <marker\n id={`${activeLineMarkerPrefix}end`}\n viewBox=\"0 0 14 8\"\n refX={3}\n refY={4}\n markerWidth={14}\n markerHeight={8}\n orient=\"auto\"\n >\n <path\n d=\"M 0.5 1.5 L 5.5 4 L 0.5 6.5 z\"\n stroke=\"var(--palette-blue-3)\"\n strokeWidth={1}\n fill=\"var(--palette-blue-3)\"\n />\n <path\n d=\"M 6.5 0.5 H 13.5 V 7.5 H 6.5 Z\"\n stroke=\"var(--palette-gray-7)\"\n strokeWidth={1}\n fill=\"var(--palette-gray-1)\"\n />\n </marker>\n </defs>\n <g\n transform={`translate(${transform.x} ${transform.y}) scale(${transform.k})`}\n >\n {renderedLines.map((line) => (\n <LineComponent\n key={line.line.$id}\n line={line}\n linePaths={linePathsRef.current}\n lineMaskRects={lineMaskRects}\n maskPrefix={maskPrefix}\n markerPrefix={markerPrefix}\n activeLineMarkerPrefix={activeLineMarkerPrefix}\n active={\n activeTarget?.type === \"edge\" &&\n activeTarget.edge.source === line.edge.source &&\n activeTarget.edge.target === line.edge.target\n }\n activeRelated={\n activeTarget?.type === \"node\" &&\n (line.edge.source === activeTarget.nodeId ||\n line.edge.target === activeTarget.nodeId)\n }\n onLineClick={onLineClick}\n onLineDoubleClick={onLineDoubleClick}\n />\n ))}\n </g>\n </svg>\n <div\n className={classNames(\"line-labels\", { ready: lineLabelsReady })}\n style={{\n left: transform.x,\n top: transform.y,\n transform: `scale(${transform.k})`,\n }}\n >\n <LineLabelComponentGroup\n labels={lineLabels}\n onRendered={handleLineLabelsRendered}\n />\n </div>\n <div\n className=\"nodes\"\n ref={nodesRef}\n style={{\n left: transform.x,\n top: transform.y,\n transform: `scale(${transform.k})`,\n }}\n >\n <NodeComponentGroup\n nodes={nodes}\n nodeBricks={nodeBricks}\n // nodePositions={nodePositions}\n onRendered={handleNodesRendered}\n />\n </div>\n <ConnectLineComponent\n connectLineState={connectLineState}\n connectLineTo={connectLineTo}\n markerPrefix={markerPrefix}\n />\n </div>\n );\n}\n","export default function _assertClassBrand(e, t, n) {\n if (\"function\" == typeof e ? e === t : e.has(t)) return arguments.length < 3 ? t : n;\n throw new TypeError(\"Private element is not present on this object\");\n}","export default function _checkPrivateRedeclaration(obj, privateCollection) {\n if (privateCollection.has(obj)) {\n throw new TypeError(\"Cannot initialize the same private elements twice on an object\");\n }\n}","import assertClassBrand from \"./assertClassBrand.js\";\nexport default function _classPrivateFieldGet2(s, a) {\n return s.get(assertClassBrand(s, a));\n}","import checkPrivateRedeclaration from \"./checkPrivateRedeclaration.js\";\nexport default function _classPrivateFieldInitSpec(obj, privateMap, value) {\n checkPrivateRedeclaration(obj, privateMap);\n privateMap.set(obj, value);\n}","import assertClassBrand from \"./assertClassBrand.js\";\nexport default function _classPrivateFieldSet2(s, a, r) {\n return s.set(assertClassBrand(s, a), r), r;\n}","import checkPrivateRedeclaration from \"./checkPrivateRedeclaration.js\";\nexport default function _classPrivateMethodInitSpec(obj, privateSet) {\n checkPrivateRedeclaration(obj, privateSet);\n privateSet.add(obj);\n}","import _typeof from \"./typeof.js\";\nimport toPrimitive from \"./toPrimitive.js\";\nexport default function toPropertyKey(t) {\n var i = toPrimitive(t, \"string\");\n return \"symbol\" == _typeof(i) ? i : i + \"\";\n}","import _typeof from \"./typeof.js\";\nexport default function toPrimitive(t, r) {\n if (\"object\" != _typeof(t) || !t) return t;\n var e = t[Symbol.toPrimitive];\n if (void 0 !== e) {\n var i = e.call(t, r || \"default\");\n if (\"object\" != _typeof(i)) return i;\n throw new TypeError(\"@@toPrimitive must return a primitive value.\");\n }\n return (\"string\" === r ? String : Number)(t);\n}","export default function _typeof(o) {\n \"@babel/helpers - typeof\";\n\n return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (o) {\n return typeof o;\n } : function (o) {\n return o && \"function\" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? \"symbol\" : typeof o;\n }, _typeof(o);\n}"],"names":["defineElement","property","event","method","createDecorators","EoDiagramComponent","forwardRef","LegacyEoDiagramComponent","_EoDiagram","_A","WeakMap","_B","_C","_D","_E","_F","_G","_H","_I","_J","_K","_L","_M","_N","_O","_EoDiagram_brand","WeakSet","_handleActiveTargetChange","_P","_handleNodeDelete","_Q","_handleEdgeDelete","_R","_handleLineClick","_S","_handleLineDoubleClick","_T","_handleNodesConnect","_handleSwitchActiveTarget","_diagramRef","EoDiagram","ReactNextElement","constructor","arguments","_classPrivateMethodInitSpec","_classPrivateFieldInitSpec","_initProto","_init_layout","_init_extra_layout","_init_nodes","_init_extra_nodes","_init_edges","_init_extra_edges","_init_nodeBricks","_init_extra_nodeBricks","_init_lines","_init_extra_lines","_init_layoutOptions","_init_extra_layoutOptions","_init_activeTarget","_init_extra_activeTarget","_init_disableKeyboardAction","_init_extra_disableKeyboardAction","_init_connectNodes","_init_extra_connectNodes","_init_dragNodes","_init_extra_dragNodes","_init_zoomable","_init_extra_zoomable","_init_scrollable","_init_extra_scrollable","_init_pannable","_init_extra_pannable","_init_scaleRange","_init_extra_scaleRange","_init_activeTargetChangeEvent","_init_extra_activeTargetChangeEvent","target","_classPrivateGetter","this","_get_activeTargetChangeEvent","emit","_init_nodeDelete","_init_extra_nodeDelete","node","_get_nodeDelete","_init_edgeDelete","_init_extra_edgeDelete","edge","_get_edgeDelete","_init_lineClick","_init_extra_lineClick","line","_get_lineClick","_init_lineDoubleClick","_init_extra_lineDoubleClick","_get_lineDoubleClick","_init_connectNodes2","_init_extra_connectNodes2","detail","_get_connectNodes","sameTarget","activeTarget","createRef","layout","_classPrivateFieldGet","v","_classPrivateFieldSet","nodes","edges","nodeBricks","lines","layoutOptions","disableKeyboardAction","connectNodes","dragNodes","zoomable","scrollable","pannable","scaleRange","callOnLineLabel","id","_classPrivateFieldGet2","_len","length","args","Array","_key","current","render","React","ref","onActiveTargetChange","onSwitchActiveTarget","onNodeDelete","onEdgeDelete","onLineClick","onLineDoubleClick","onNodesConnect","_ref","_activeTarget","_scaleRange","nodesReady","setNodesReady","useState","nodesRenderId","setNodesRenderId","nodesRefRepository","setNodesRefRepository","lineLabelsReady","setLineLabelsReady","lineLabelsRenderId","setLineLabelsRenderId","lineLabelsRefRepository","setLineLabelsRefRepository","renderedLineLabels","setRenderedLineLabels","grabbing","setGrabbing","transform","setTransform","k","x","y","linePathsRef","useRef","Map","rootRef","nodesRef","centered","setCentered","userViewReady","userViewNodesMap","saveUserView","useUserView","save","connectLineTo","setConnectLineTo","connectLineState","setConnectLineState","manualLayoutStatus","setManualLayoutStatus","nodeMovement","setNodeMovement","useImperativeHandle","_lineLabelsRefReposit","_len2","_key2","get","firstElementChild","useEffect","onNodesMouseDown","handleNodesMouseDown","scale","nodesContainer","addEventListener","removeEventListener","normalizedLines","normalizedLinesMap","markers","useMemo","normalizeLinesAndMarkers","lineLabels","flatMap","_ref2","key","list","text","label","$id","concat","map","item","_item$placement","placement","renderedNodes","renderedEdges","useRenderedDiagram","renderedLines","getRenderedLines","newActiveTarget","setActiveTarget","previous","activeTargetChangeInitialized","root","onKeydown","action","handleKeyboard","type","nodeId","handleNodesRendered","useCallback","refRepository","handleLineLabelsRendered","DEFAULT_SCALE_RANGE_MIN","DEFAULT_SCALE_RANGE_MAX","zoomer","zoom","moved","scaleExtent","on","e","rootSelection","select","unsetZoom","ctrlKey","stopImmediatePropagation","preventDefault","translateBy","wheelDeltaX","wheelDeltaY","call","transformToCenter","canvasWidth","clientWidth","canvasHeight","clientHeight","undefined","ZoomTransform","defPrefix","uniqueId","markerPrefix","maskPrefix","activeLineMarkerPrefix","getRenderedLineLabels","lineMaskRects","setLineMaskRects","adjustLineLabels","observer","ResizeObserver","updateLineMaskRects","getLineMaskRects","lineLabel","values","observe","disconnect","className","classNames","ready","tabIndex","width","height","_ref3","index","strokeColor","MarkerComponent","_ref4","lineId","rects","LineMaskComponent","viewBox","refX","refY","markerWidth","markerHeight","orient","d","stroke","strokeWidth","fill","LineComponent","linePaths","active","source","activeRelated","style","left","top","LineLabelComponentGroup","labels","onRendered","NodeComponentGroup","ConnectLineComponent","_EoDiagram2","_set_activeTargetChangeEvent","_set_nodeDelete","_set_edgeDelete","_set_lineClick","_set_lineDoubleClick","_set_connectNodes","c","_initClass","_applyDecs","styleTexts","styleText","String","attribute","Boolean","o","_","has","_checkInRHS","_assertClassBrand","t","n","TypeError","_checkPrivateRedeclaration","obj","privateCollection","s","a","privateMap","value","set","_classPrivateFieldSet2","r","privateSet","add","toPropertyKey","i","Symbol","toPrimitive","_typeof","iterator","prototype"],"sourceRoot":""}
@@ -1,2 +1,2 @@
1
- "use strict";(globalThis.webpackChunk_next_bricks_diagram=globalThis.webpackChunk_next_bricks_diagram||[]).push([[9823],{6094:(e,t,a)=>{a.r(t),a.d(t,{EoDisplayCanvas:()=>xe});var s,l=a(4635),i=a(918),o=a(6902),n=a(5536),r=a(6121),h=a(829),d=a(2740),c=a(8769),u=a.n(c),g=a(300),A=a(4295),p=(a(6477),a(1030)),C=a(3373),k=a.n(C),b=a(7566),y=a(3739),v=a(8185),m=a(4932),f=a(3783),N=a(3033),T=a(8091),R=a(1819),w=a(5748),W=a(227),M=a(531),E=a(7099),S=a(1484),z=a(8197),B=a(7531),L=a(2098),x=a(3012),O=a(6237);let $,F,Z,U,_,H,K,P,D,I,Y,q,J,j,G,Q,V,X,ee,te,ae,se,le,ie,oe,ne,re,he,de,ce,ue,ge,Ae,pe,Ce,ke,be,ye,ve,me,fe,Ne,Te,Re,we,We,Me,Ee,Se;const{defineElement:ze,property:Be,event:Le}=(0,g.createDecorators)();let xe;var Oe=new WeakMap,$e=new WeakMap,Fe=new WeakMap,Ze=new WeakMap,Ue=new WeakMap,_e=new WeakMap,He=new WeakMap,Ke=new WeakMap,Pe=new WeakMap,De=new WeakMap,Ie=new WeakMap,Ye=new WeakMap,qe=new WeakMap,Je=new WeakMap,je=new WeakMap,Ge=new WeakMap,Qe=new WeakMap,Ve=new WeakMap,Xe=new WeakMap,et=new WeakSet,tt=new WeakMap,at=new WeakMap,st=new WeakMap,lt=new WeakMap,it=new WeakMap,ot=new WeakMap;class nt extends A.ReactNextElement{constructor(){super(...arguments),(0,l.A)(this,et),(0,i.A)(this,Oe,F(this)),(0,i.A)(this,$e,(Z(this),U(this))),(0,i.A)(this,Fe,(_(this),H(this))),(0,i.A)(this,Ze,(K(this),P(this,[N.HP,N.HP]))),(0,i.A)(this,Ue,(D(this),I(this))),(0,i.A)(this,_e,(Y(this),q(this))),(0,i.A)(this,He,(J(this),j(this))),(0,i.A)(this,Ke,(G(this),Q(this))),(0,i.A)(this,Pe,(V(this),X(this))),(0,i.A)(this,De,(ee(this),te(this))),(0,i.A)(this,Ie,(ae(this),se(this,!0))),(0,i.A)(this,Ye,(le(this),ie(this,!0))),(0,i.A)(this,qe,(oe(this),ne(this,!0))),(0,i.A)(this,Je,(re(this),he(this))),(0,i.A)(this,je,(de(this),ce(this))),(0,i.A)(this,Ge,(ue(this),ge(this))),(0,i.A)(this,Qe,(Ae(this),pe(this))),(0,i.A)(this,Ve,(Ce(this),ke(this))),(0,i.A)(this,Xe,(be(this),ye(this))),(0,i.A)(this,tt,(fe(this),e=>{(0,n.A)(et,this,ve).emit(e)})),(0,i.A)(this,at,(e=>{(0,v.c)(e,this.activeTarget)||(this.activeTarget=e)})),(0,i.A)(this,st,Ne(this)),(0,i.A)(this,lt,(we(this),e=>{(0,n.A)(et,this,Te).emit(e)})),(0,i.A)(this,it,We(this)),(0,i.A)(this,ot,(Se(this),e=>{(0,n.A)(et,this,Me).emit(e)}))}get cells(){return(0,h.A)(Oe,this)}set cells(e){(0,r.A)(Oe,this,e)}get layout(){return(0,h.A)($e,this)}set layout(e){(0,r.A)($e,this,e)}get layoutOptions(){return(0,h.A)(Fe,this)}set layoutOptions(e){(0,r.A)(Fe,this,e)}get defaultNodeSize(){return(0,h.A)(Ze,this)}set defaultNodeSize(e){(0,r.A)(Ze,this,e)}get defaultNodeBricks(){return(0,h.A)(Ue,this)}set defaultNodeBricks(e){(0,r.A)(Ue,this,e)}get degradedThreshold(){return(0,h.A)(_e,this)}set degradedThreshold(e){(0,r.A)(_e,this,e)}get degradedNodeLabel(){return(0,h.A)(He,this)}set degradedNodeLabel(e){(0,r.A)(He,this,e)}get defaultEdgeLines(){return(0,h.A)(Ke,this)}set defaultEdgeLines(e){(0,r.A)(Ke,this,e)}get activeTarget(){return(0,h.A)(Pe,this)}set activeTarget(e){(0,r.A)(Pe,this,e)}get fadeUnrelatedCells(){return(0,h.A)(De,this)}set fadeUnrelatedCells(e){(0,r.A)(De,this,e)}get zoomable(){return(0,h.A)(Ie,this)}set zoomable(e){(0,r.A)(Ie,this,e)}get scrollable(){return(0,h.A)(Ye,this)}set scrollable(e){(0,r.A)(Ye,this,e)}get pannable(){return(0,h.A)(qe,this)}set pannable(e){(0,r.A)(qe,this,e)}get scaleRange(){return(0,h.A)(Je,this)}set scaleRange(e){(0,r.A)(Je,this,e)}get hideZoomBar(){return(0,h.A)(je,this)}set hideZoomBar(e){(0,r.A)(je,this,e)}get autoCenterWhenCellsChange(){return(0,h.A)(Ge,this)}set autoCenterWhenCellsChange(e){(0,r.A)(Ge,this,e)}get doNotResetActiveTargetForSelector(){return(0,h.A)(Qe,this)}set doNotResetActiveTargetForSelector(e){(0,r.A)(Qe,this,e)}get doNotResetActiveTargetOutsideCanvas(){return(0,h.A)(Ve,this)}set doNotResetActiveTargetOutsideCanvas(e){(0,r.A)(Ve,this,e)}render(){return u().createElement(rt,{shadowRoot:this.shadowRoot,cells:this.cells,layout:this.layout,layoutOptions:this.layoutOptions,defaultNodeSize:this.defaultNodeSize,defaultNodeBricks:this.defaultNodeBricks,defaultEdgeLines:this.defaultEdgeLines,degradedThreshold:this.degradedThreshold,degradedNodeLabel:this.degradedNodeLabel,activeTarget:this.activeTarget,fadeUnrelatedCells:this.fadeUnrelatedCells,zoomable:this.zoomable,scrollable:this.scrollable,pannable:this.pannable,scaleRange:this.scaleRange,hideZoomBar:this.hideZoomBar,doNotResetActiveTargetForSelector:this.doNotResetActiveTargetForSelector,doNotResetActiveTargetOutsideCanvas:this.doNotResetActiveTargetOutsideCanvas,autoCenterWhenCellsChange:this.autoCenterWhenCellsChange,onActiveTargetChange:(0,h.A)(tt,this),onSwitchActiveTarget:(0,h.A)(at,this),onCellContextMenu:(0,h.A)(lt,this),onCellClick:(0,h.A)(ot,this)})}}function rt(e){let{shadowRoot:t,cells:a,layout:s,layoutOptions:l,defaultNodeSize:i,defaultNodeBricks:o,defaultEdgeLines:n,degradedThreshold:r,degradedNodeLabel:h,activeTarget:d,fadeUnrelatedCells:g,zoomable:A,scrollable:C,pannable:v,scaleRange:x,hideZoomBar:O,autoCenterWhenCellsChange:$,doNotResetActiveTargetForSelector:F,doNotResetActiveTargetOutsideCanvas:Z,onActiveTargetChange:U,onSwitchActiveTarget:_,onCellContextMenu:H,onCellClick:K}=e;const[{cells:P,layoutKey:D},I]=(0,c.useReducer)(w.d,a,(e=>({cells:(0,f.C)(e,{defaultNodeSize:i}),layoutKey:1}))),Y=(0,c.useMemo)((()=>P.filter(M.N).length>=(r??N.pC)),[P,r]),q=(0,c.useRef)(null),{grabbing:J,transform:j,zoomer:G,scaleRange:Q}=(0,T.f)({rootRef:q,zoomable:A,scrollable:C,pannable:v,draggable:!0,scaleRange:x,onSwitchActiveTarget:_}),{centered:V,setCentered:X,getNextLayoutKey:ee}=(0,S.g)({layout:s,layoutOptions:l,rootRef:q,cells:P,zoomable:A,zoomer:G,scaleRange:Q,layoutKey:D,autoCenterWhenCellsChange:$,dispatch:I}),te=(0,c.useCallback)((()=>{X(!1)}),[X]),ae=(0,c.useRef)(a);(0,c.useEffect)((()=>{if(a!==ae.current){ae.current=a;const e=(0,L.L)({canvasWidth:t.host.clientWidth,canvasHeight:t.host.clientHeight,defaultNodeSize:i,layout:s,previousCells:P,cells:a,scaleRange:Q,transform:j});I({type:"update-cells",payload:e.cells})}}),[P,i,a,s,Q,t,j]);const se=(0,R.J)({rootRef:q,activeTarget:d,doNotResetActiveTargetForSelector:F,doNotResetActiveTargetOutsideCanvas:Z,onActiveTargetChange:U}),le=`${(0,c.useMemo)((()=>`${(0,p.uniqueId)("diagram-")}-`),[])}line-arrow-`,ie=(0,c.useCallback)(((e,t)=>{I({type:"update-node-size",payload:{id:e,size:t},layoutKey:ee()})}),[ee]),[oe,ne]=(0,c.useState)(null),re=(0,c.useCallback)((e=>{ne(e)}),[]),he=(0,c.useCallback)((e=>{ne((t=>t===e?null:t))}),[]),[de,ce]=(0,c.useState)([]);(0,c.useEffect)((()=>{const e=g?(0,W.Y)(P,null,oe):[];ce((t=>0===t.length&&0===e.length?t:e))}),[P,g,oe]);const ue=(0,c.useCallback)((e=>{G.scaleTo((0,b.A)(q.current),e/100)}),[G]),{lineConfMap:ge,markers:Ae}=(0,B.d)({cells:P,defaultEdgeLines:n,markerPrefix:le}),pe=(0,z.H)({cells:P,layout:s,centered:V});return u().createElement(u().Fragment,null,u().createElement("svg",{width:"100%",height:"100%",ref:q,className:k()("root",{grabbing:J,pannable:v,ready:pe}),tabIndex:-1},u().createElement("defs",null,Ae.map(((e,t)=>u().createElement(y.c,{key:t,id:`${le}${t}`,type:e.markerType,strokeColor:e.strokeColor})))),u().createElement("g",{transform:`translate(${j.x} ${j.y}) scale(${j.k})`},u().createElement("g",{className:"cells"},P.map((e=>u().createElement(m.m,{key:`${e.type}:${(0,M.WW)(e)?`${e.source}~${e.target}`:e.id}`,layout:s,cell:e,cells:P,degraded:Y,degradedNodeLabel:h,defaultNodeBricks:o,lineConfMap:ge,transform:j,activeTarget:se,readOnly:!0,unrelatedCells:de,onSwitchActiveTarget:_,onCellContextMenu:H,onCellClick:K,onNodeBrickResize:ie,onCellMouseEnter:g&&(0,M.N)(e)?re:void 0,onCellMouseLeave:g&&(0,M.N)(e)?he:void 0})))))),!O&&u().createElement(E.Y,{shadowRoot:t,scale:j.k,scaleRange:Q,onZoomChange:ue,onReCenter:te}))}s=nt,({e:[F,Z,U,_,H,K,P,D,I,Y,q,J,j,G,Q,V,X,ee,te,ae,se,le,ie,oe,ne,re,he,de,ce,ue,ge,Ae,pe,Ce,ke,be,ye,ve,me,fe,Ne,Te,Re,we,We,Me,Ee,Se],c:[xe,$]}=(0,d.A)(s,[ze("eo-display-canvas",{styleTexts:[x.A,O.A]})],[[Be({attribute:!1}),1,"cells"],[Be({type:String}),1,"layout"],[Be({attribute:!1}),1,"layoutOptions"],[Be({attribute:!1}),1,"defaultNodeSize"],[Be({attribute:!1}),1,"defaultNodeBricks"],[Be({type:Number}),1,"degradedThreshold"],[Be({attribute:!1}),1,"degradedNodeLabel"],[Be({attribute:!1}),1,"defaultEdgeLines"],[Be({attribute:!1}),1,"activeTarget"],[Be({type:Boolean}),1,"fadeUnrelatedCells"],[Be({type:Boolean}),1,"zoomable"],[Be({type:Boolean}),1,"scrollable"],[Be({type:Boolean}),1,"pannable"],[Be({attribute:!1}),1,"scaleRange"],[Be({type:Boolean}),1,"hideZoomBar"],[Be({type:Boolean}),1,"autoCenterWhenCellsChange"],[Be(),1,"doNotResetActiveTargetForSelector"],[Be({type:Boolean}),1,"doNotResetActiveTargetOutsideCanvas"],[Le({type:"activeTarget.change"}),1,"activeTargetChangeEvent",e=>(0,h.A)(Xe,e),(e,t)=>(0,r.A)(Xe,e,t)],[Le({type:"cell.contextmenu"}),1,"cellContextMenu",e=>(0,h.A)(st,e),(e,t)=>(0,r.A)(st,e,t)],[Le({type:"cell.click"}),1,"cellClick",e=>(0,h.A)(it,e),(e,t)=>(0,r.A)(it,e,t)]],0,(e=>ot.has((0,o.A)(e))),A.ReactNextElement)),$()}}]);
2
- //# sourceMappingURL=eo-display-canvas.d9801bac.js.map
1
+ "use strict";(globalThis.webpackChunk_next_bricks_diagram=globalThis.webpackChunk_next_bricks_diagram||[]).push([[9823],{6094:(e,t,a)=>{a.r(t),a.d(t,{EoDisplayCanvas:()=>xe});var s,l=a(4635),i=a(918),o=a(6902),n=a(5536),r=a(6121),h=a(829),d=a(2740),c=a(8769),u=a.n(c),g=a(300),A=a(4295),p=(a(6477),a(1030)),C=a(3373),k=a.n(C),b=a(7566),y=a(3739),v=a(8185),m=a(4932),f=a(3783),N=a(3033),T=a(8091),R=a(1819),w=a(5748),W=a(227),M=a(531),E=a(7099),S=a(1484),z=a(8197),B=a(7531),L=a(2098),x=a(3012),O=a(6237);let $,F,Z,U,_,H,K,P,D,I,Y,q,J,j,G,Q,V,X,ee,te,ae,se,le,ie,oe,ne,re,he,de,ce,ue,ge,Ae,pe,Ce,ke,be,ye,ve,me,fe,Ne,Te,Re,we,We,Me,Ee,Se;const{defineElement:ze,property:Be,event:Le}=(0,g.createDecorators)();let xe;var Oe=new WeakMap,$e=new WeakMap,Fe=new WeakMap,Ze=new WeakMap,Ue=new WeakMap,_e=new WeakMap,He=new WeakMap,Ke=new WeakMap,Pe=new WeakMap,De=new WeakMap,Ie=new WeakMap,Ye=new WeakMap,qe=new WeakMap,Je=new WeakMap,je=new WeakMap,Ge=new WeakMap,Qe=new WeakMap,Ve=new WeakMap,Xe=new WeakMap,et=new WeakSet,tt=new WeakMap,at=new WeakMap,st=new WeakMap,lt=new WeakMap,it=new WeakMap,ot=new WeakMap;class nt extends A.ReactNextElement{constructor(){super(...arguments),(0,l.A)(this,et),(0,i.A)(this,Oe,F(this)),(0,i.A)(this,$e,(Z(this),U(this))),(0,i.A)(this,Fe,(_(this),H(this))),(0,i.A)(this,Ze,(K(this),P(this,[N.HP,N.HP]))),(0,i.A)(this,Ue,(D(this),I(this))),(0,i.A)(this,_e,(Y(this),q(this))),(0,i.A)(this,He,(J(this),j(this))),(0,i.A)(this,Ke,(G(this),Q(this))),(0,i.A)(this,Pe,(V(this),X(this))),(0,i.A)(this,De,(ee(this),te(this))),(0,i.A)(this,Ie,(ae(this),se(this,!0))),(0,i.A)(this,Ye,(le(this),ie(this,!0))),(0,i.A)(this,qe,(oe(this),ne(this,!0))),(0,i.A)(this,Je,(re(this),he(this))),(0,i.A)(this,je,(de(this),ce(this))),(0,i.A)(this,Ge,(ue(this),ge(this))),(0,i.A)(this,Qe,(Ae(this),pe(this))),(0,i.A)(this,Ve,(Ce(this),ke(this))),(0,i.A)(this,Xe,(be(this),ye(this))),(0,i.A)(this,tt,(fe(this),e=>{(0,n.A)(et,this,ve).emit(e)})),(0,i.A)(this,at,(e=>{(0,v.c)(e,this.activeTarget)||(this.activeTarget=e)})),(0,i.A)(this,st,Ne(this)),(0,i.A)(this,lt,(we(this),e=>{(0,n.A)(et,this,Te).emit(e)})),(0,i.A)(this,it,We(this)),(0,i.A)(this,ot,(Se(this),e=>{(0,n.A)(et,this,Me).emit(e)}))}get cells(){return(0,h.A)(Oe,this)}set cells(e){(0,r.A)(Oe,this,e)}get layout(){return(0,h.A)($e,this)}set layout(e){(0,r.A)($e,this,e)}get layoutOptions(){return(0,h.A)(Fe,this)}set layoutOptions(e){(0,r.A)(Fe,this,e)}get defaultNodeSize(){return(0,h.A)(Ze,this)}set defaultNodeSize(e){(0,r.A)(Ze,this,e)}get defaultNodeBricks(){return(0,h.A)(Ue,this)}set defaultNodeBricks(e){(0,r.A)(Ue,this,e)}get degradedThreshold(){return(0,h.A)(_e,this)}set degradedThreshold(e){(0,r.A)(_e,this,e)}get degradedNodeLabel(){return(0,h.A)(He,this)}set degradedNodeLabel(e){(0,r.A)(He,this,e)}get defaultEdgeLines(){return(0,h.A)(Ke,this)}set defaultEdgeLines(e){(0,r.A)(Ke,this,e)}get activeTarget(){return(0,h.A)(Pe,this)}set activeTarget(e){(0,r.A)(Pe,this,e)}get fadeUnrelatedCells(){return(0,h.A)(De,this)}set fadeUnrelatedCells(e){(0,r.A)(De,this,e)}get zoomable(){return(0,h.A)(Ie,this)}set zoomable(e){(0,r.A)(Ie,this,e)}get scrollable(){return(0,h.A)(Ye,this)}set scrollable(e){(0,r.A)(Ye,this,e)}get pannable(){return(0,h.A)(qe,this)}set pannable(e){(0,r.A)(qe,this,e)}get scaleRange(){return(0,h.A)(Je,this)}set scaleRange(e){(0,r.A)(Je,this,e)}get hideZoomBar(){return(0,h.A)(je,this)}set hideZoomBar(e){(0,r.A)(je,this,e)}get autoCenterWhenCellsChange(){return(0,h.A)(Ge,this)}set autoCenterWhenCellsChange(e){(0,r.A)(Ge,this,e)}get doNotResetActiveTargetForSelector(){return(0,h.A)(Qe,this)}set doNotResetActiveTargetForSelector(e){(0,r.A)(Qe,this,e)}get doNotResetActiveTargetOutsideCanvas(){return(0,h.A)(Ve,this)}set doNotResetActiveTargetOutsideCanvas(e){(0,r.A)(Ve,this,e)}render(){return u().createElement(rt,{shadowRoot:this.shadowRoot,cells:this.cells,layout:this.layout,layoutOptions:this.layoutOptions,defaultNodeSize:this.defaultNodeSize,defaultNodeBricks:this.defaultNodeBricks,defaultEdgeLines:this.defaultEdgeLines,degradedThreshold:this.degradedThreshold,degradedNodeLabel:this.degradedNodeLabel,activeTarget:this.activeTarget,fadeUnrelatedCells:this.fadeUnrelatedCells,zoomable:this.zoomable,scrollable:this.scrollable,pannable:this.pannable,scaleRange:this.scaleRange,hideZoomBar:this.hideZoomBar,doNotResetActiveTargetForSelector:this.doNotResetActiveTargetForSelector,doNotResetActiveTargetOutsideCanvas:this.doNotResetActiveTargetOutsideCanvas,autoCenterWhenCellsChange:this.autoCenterWhenCellsChange,onActiveTargetChange:(0,h.A)(tt,this),onSwitchActiveTarget:(0,h.A)(at,this),onCellContextMenu:(0,h.A)(lt,this),onCellClick:(0,h.A)(ot,this)})}}function rt(e){let{shadowRoot:t,cells:a,layout:s,layoutOptions:l,defaultNodeSize:i,defaultNodeBricks:o,defaultEdgeLines:n,degradedThreshold:r,degradedNodeLabel:h,activeTarget:d,fadeUnrelatedCells:g,zoomable:A,scrollable:C,pannable:v,scaleRange:x,hideZoomBar:O,autoCenterWhenCellsChange:$,doNotResetActiveTargetForSelector:F,doNotResetActiveTargetOutsideCanvas:Z,onActiveTargetChange:U,onSwitchActiveTarget:_,onCellContextMenu:H,onCellClick:K}=e;const[{cells:P,layoutKey:D},I]=(0,c.useReducer)(w.d,a,(e=>({cells:(0,f.C)(e,{defaultNodeSize:i}),layoutKey:1}))),Y=(0,c.useMemo)((()=>P.filter(M.N).length>=(null!=r?r:N.pC)),[P,r]),q=(0,c.useRef)(null),{grabbing:J,transform:j,zoomer:G,scaleRange:Q}=(0,T.f)({rootRef:q,zoomable:A,scrollable:C,pannable:v,draggable:!0,scaleRange:x,onSwitchActiveTarget:_}),{centered:V,setCentered:X,getNextLayoutKey:ee}=(0,S.g)({layout:s,layoutOptions:l,rootRef:q,cells:P,zoomable:A,zoomer:G,scaleRange:Q,layoutKey:D,autoCenterWhenCellsChange:$,dispatch:I}),te=(0,c.useCallback)((()=>{X(!1)}),[X]),ae=(0,c.useRef)(a);(0,c.useEffect)((()=>{if(a!==ae.current){ae.current=a;const e=(0,L.L)({canvasWidth:t.host.clientWidth,canvasHeight:t.host.clientHeight,defaultNodeSize:i,layout:s,previousCells:P,cells:a,scaleRange:Q,transform:j});I({type:"update-cells",payload:e.cells})}}),[P,i,a,s,Q,t,j]);const se=(0,R.J)({rootRef:q,activeTarget:d,doNotResetActiveTargetForSelector:F,doNotResetActiveTargetOutsideCanvas:Z,onActiveTargetChange:U}),le=`${(0,c.useMemo)((()=>`${(0,p.uniqueId)("diagram-")}-`),[])}line-arrow-`,ie=(0,c.useCallback)(((e,t)=>{I({type:"update-node-size",payload:{id:e,size:t},layoutKey:ee()})}),[ee]),[oe,ne]=(0,c.useState)(null),re=(0,c.useCallback)((e=>{ne(e)}),[]),he=(0,c.useCallback)((e=>{ne((t=>t===e?null:t))}),[]),[de,ce]=(0,c.useState)([]);(0,c.useEffect)((()=>{const e=g?(0,W.Y)(P,null,oe):[];ce((t=>0===t.length&&0===e.length?t:e))}),[P,g,oe]);const ue=(0,c.useCallback)((e=>{G.scaleTo((0,b.A)(q.current),e/100)}),[G]),{lineConfMap:ge,markers:Ae}=(0,B.d)({cells:P,defaultEdgeLines:n,markerPrefix:le}),pe=(0,z.H)({cells:P,layout:s,centered:V});return u().createElement(u().Fragment,null,u().createElement("svg",{width:"100%",height:"100%",ref:q,className:k()("root",{grabbing:J,pannable:v,ready:pe}),tabIndex:-1},u().createElement("defs",null,Ae.map(((e,t)=>u().createElement(y.c,{key:t,id:`${le}${t}`,type:e.markerType,strokeColor:e.strokeColor})))),u().createElement("g",{transform:`translate(${j.x} ${j.y}) scale(${j.k})`},u().createElement("g",{className:"cells"},P.map((e=>u().createElement(m.m,{key:`${e.type}:${(0,M.WW)(e)?`${e.source}~${e.target}`:e.id}`,layout:s,cell:e,cells:P,degraded:Y,degradedNodeLabel:h,defaultNodeBricks:o,lineConfMap:ge,transform:j,activeTarget:se,readOnly:!0,unrelatedCells:de,onSwitchActiveTarget:_,onCellContextMenu:H,onCellClick:K,onNodeBrickResize:ie,onCellMouseEnter:g&&(0,M.N)(e)?re:void 0,onCellMouseLeave:g&&(0,M.N)(e)?he:void 0})))))),!O&&u().createElement(E.Y,{shadowRoot:t,scale:j.k,scaleRange:Q,onZoomChange:ue,onReCenter:te}))}s=nt,({e:[F,Z,U,_,H,K,P,D,I,Y,q,J,j,G,Q,V,X,ee,te,ae,se,le,ie,oe,ne,re,he,de,ce,ue,ge,Ae,pe,Ce,ke,be,ye,ve,me,fe,Ne,Te,Re,we,We,Me,Ee,Se],c:[xe,$]}=(0,d.A)(s,[ze("eo-display-canvas",{styleTexts:[x.A,O.A]})],[[Be({attribute:!1}),1,"cells"],[Be({type:String}),1,"layout"],[Be({attribute:!1}),1,"layoutOptions"],[Be({attribute:!1}),1,"defaultNodeSize"],[Be({attribute:!1}),1,"defaultNodeBricks"],[Be({type:Number}),1,"degradedThreshold"],[Be({attribute:!1}),1,"degradedNodeLabel"],[Be({attribute:!1}),1,"defaultEdgeLines"],[Be({attribute:!1}),1,"activeTarget"],[Be({type:Boolean}),1,"fadeUnrelatedCells"],[Be({type:Boolean}),1,"zoomable"],[Be({type:Boolean}),1,"scrollable"],[Be({type:Boolean}),1,"pannable"],[Be({attribute:!1}),1,"scaleRange"],[Be({type:Boolean}),1,"hideZoomBar"],[Be({type:Boolean}),1,"autoCenterWhenCellsChange"],[Be(),1,"doNotResetActiveTargetForSelector"],[Be({type:Boolean}),1,"doNotResetActiveTargetOutsideCanvas"],[Le({type:"activeTarget.change"}),1,"activeTargetChangeEvent",e=>(0,h.A)(Xe,e),(e,t)=>(0,r.A)(Xe,e,t)],[Le({type:"cell.contextmenu"}),1,"cellContextMenu",e=>(0,h.A)(st,e),(e,t)=>(0,r.A)(st,e,t)],[Le({type:"cell.click"}),1,"cellClick",e=>(0,h.A)(it,e),(e,t)=>(0,r.A)(it,e,t)]],0,(e=>ot.has((0,o.A)(e))),A.ReactNextElement)),$()}}]);
2
+ //# sourceMappingURL=eo-display-canvas.b5206c2a.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"chunks/eo-display-canvas.b5206c2a.js","mappings":"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","sources":["webpack:///./src/display-canvas/index.tsx"],"sourcesContent":["import React, {\n useCallback,\n useEffect,\n useMemo,\n useReducer,\n useRef,\n useState,\n} from \"react\";\nimport { createDecorators, type EventEmitter } from \"@next-core/element\";\nimport { ReactNextElement } from \"@next-core/react-element\";\nimport \"@next-core/theme\";\nimport { uniqueId } from \"lodash\";\nimport classNames from \"classnames\";\nimport { select } from \"d3-selection\";\nimport type { RangeTuple, SizeTuple } from \"../diagram/interfaces\";\nimport type {\n ActiveTarget,\n InitialCell,\n NodeBrickConf,\n CellContextMenuDetail,\n EdgeLineConf,\n Cell,\n LayoutType,\n LayoutOptions,\n} from \"../draw-canvas/interfaces\";\nimport { MarkerComponent } from \"../diagram/MarkerComponent\";\nimport { sameTarget } from \"../draw-canvas/processors/sameTarget\";\nimport { CellComponent } from \"../draw-canvas/CellComponent\";\nimport { initializeCells } from \"../draw-canvas/processors/initializeCells\";\nimport {\n DEFAULT_DEGRADED_THRESHOLD,\n DEFAULT_NODE_SIZE,\n} from \"../draw-canvas/constants\";\nimport { useZoom } from \"../shared/canvas/useZoom\";\nimport { useActiveTarget } from \"../shared/canvas/useActiveTarget\";\nimport { rootReducer } from \"../draw-canvas/reducers\";\nimport { getUnrelatedCells } from \"../draw-canvas/processors/getUnrelatedCells\";\nimport { isEdgeCell, isNodeCell } from \"../draw-canvas/processors/asserts\";\nimport { ZoomBarComponent } from \"../shared/canvas/ZoomBarComponent\";\nimport { useLayout } from \"../shared/canvas/useLayout\";\nimport { useReady } from \"../shared/canvas/useReady\";\nimport { useLineMarkers } from \"../shared/canvas/useLineMarkers\";\nimport { updateCells } from \"../draw-canvas/processors/updateCells\";\nimport styleText from \"../shared/canvas/styles.shadow.css\";\nimport zoomBarStyleText from \"../shared/canvas/ZoomBarComponent.shadow.css\";\n\nconst { defineElement, property, event } = createDecorators();\n\nexport interface EoDisplayCanvasProps {\n cells: InitialCell[] | undefined;\n layout: LayoutType;\n layoutOptions?: LayoutOptions;\n defaultNodeSize: SizeTuple;\n defaultNodeBricks?: NodeBrickConf[];\n defaultEdgeLines?: EdgeLineConf[];\n degradedThreshold?: number;\n degradedNodeLabel?: string;\n activeTarget?: ActiveTarget | null;\n fadeUnrelatedCells?: boolean;\n zoomable?: boolean;\n scrollable?: boolean;\n pannable?: boolean;\n scaleRange?: RangeTuple;\n hideZoomBar?: boolean;\n autoCenterWhenCellsChange?: boolean;\n doNotResetActiveTargetForSelector?: string;\n doNotResetActiveTargetOutsideCanvas?: boolean;\n}\n\n/**\n * 用于展示查看的画布。\n */\nexport\n@defineElement(\"eo-display-canvas\", {\n styleTexts: [styleText, zoomBarStyleText],\n})\nclass EoDisplayCanvas extends ReactNextElement implements EoDisplayCanvasProps {\n /**\n * 用于查看的画布可以更新 `cells` 属性。\n */\n @property({ attribute: false })\n accessor cells: InitialCell[] | undefined;\n\n @property({ type: String })\n accessor layout: LayoutType;\n\n @property({ attribute: false })\n accessor layoutOptions: LayoutOptions | undefined;\n\n @property({ attribute: false })\n accessor defaultNodeSize: SizeTuple = [DEFAULT_NODE_SIZE, DEFAULT_NODE_SIZE];\n\n @property({ attribute: false })\n accessor defaultNodeBricks: NodeBrickConf[] | undefined;\n\n /**\n * 当节点数量达到或超过 `degradedThreshold` 时,节点将被降级展示。\n *\n * @default 500\n */\n @property({ type: Number })\n accessor degradedThreshold: number | undefined;\n\n // Set `attribute` to `false` event if it accepts string value.\n // Because when passing like \"<% DATA.node.data.name %>\", it will be\n // evaluated as object temporarily.\n /**\n * 设置节点将降级展示时显示的名称。\n *\n * @default \"<% DATA.node.id %>\"\n */\n @property({ attribute: false })\n accessor degradedNodeLabel: string | undefined;\n\n /**\n * 使用条件判断设置默认的边对应的连线。在 `if` 表达式中 `DATA` 为 `{ edge }`,例如:\n *\n * ```yaml\n * defaultEdgeLines:\n * - if: <% DATA.edge.data?.virtual %>\n * dashed: true\n * ```\n */\n @property({ attribute: false })\n accessor defaultEdgeLines: EdgeLineConf[] | undefined;\n\n @property({ attribute: false })\n accessor activeTarget: ActiveTarget | null | undefined;\n\n /**\n * 当鼠标悬浮到某节点上时,隐藏其他跟该节点无关的元素。\n */\n @property({ type: Boolean })\n accessor fadeUnrelatedCells: boolean | undefined;\n\n @property({ type: Boolean })\n accessor zoomable: boolean | undefined = true;\n\n @property({ type: Boolean })\n accessor scrollable: boolean | undefined = true;\n\n @property({ type: Boolean })\n accessor pannable: boolean | undefined = true;\n\n @property({ attribute: false })\n accessor scaleRange: RangeTuple | undefined;\n\n /**\n * 隐藏右下角放大缩小的控制栏\n */\n @property({ type: Boolean })\n accessor hideZoomBar: boolean | undefined;\n\n /**\n * 每当 cells 改变时,重新自动居中\n */\n @property({ type: Boolean })\n accessor autoCenterWhenCellsChange: boolean | undefined;\n\n /**\n * 选择器,点击该选择器对应的元素时不重置 `activeTarget`。\n */\n @property()\n accessor doNotResetActiveTargetForSelector: string | undefined;\n\n /**\n * 在画布外点击时不重置 `activeTarget`。\n */\n @property({ type: Boolean })\n accessor doNotResetActiveTargetOutsideCanvas: boolean | undefined;\n\n @event({ type: \"activeTarget.change\" })\n accessor #activeTargetChangeEvent!: EventEmitter<ActiveTarget | null>;\n\n #handleActiveTargetChange = (target: ActiveTarget | null) => {\n this.#activeTargetChangeEvent.emit(target);\n };\n\n #handleSwitchActiveTarget = (target: ActiveTarget | null) => {\n if (!sameTarget(target, this.activeTarget)) {\n this.activeTarget = target;\n }\n };\n\n @event({ type: \"cell.contextmenu\" })\n accessor #cellContextMenu!: EventEmitter<CellContextMenuDetail>;\n\n #handleCellContextMenu = (detail: CellContextMenuDetail) => {\n this.#cellContextMenu.emit(detail);\n };\n\n @event({ type: \"cell.click\" })\n accessor #cellClick!: EventEmitter<CellContextMenuDetail>;\n\n #handleCellClick = (detail: CellContextMenuDetail) => {\n this.#cellClick.emit(detail);\n };\n\n render() {\n return (\n <EoDisplayCanvasComponent\n shadowRoot={this.shadowRoot!}\n cells={this.cells}\n layout={this.layout}\n layoutOptions={this.layoutOptions}\n defaultNodeSize={this.defaultNodeSize}\n defaultNodeBricks={this.defaultNodeBricks}\n defaultEdgeLines={this.defaultEdgeLines}\n degradedThreshold={this.degradedThreshold}\n degradedNodeLabel={this.degradedNodeLabel}\n activeTarget={this.activeTarget}\n fadeUnrelatedCells={this.fadeUnrelatedCells}\n zoomable={this.zoomable}\n scrollable={this.scrollable}\n pannable={this.pannable}\n scaleRange={this.scaleRange}\n hideZoomBar={this.hideZoomBar}\n doNotResetActiveTargetForSelector={\n this.doNotResetActiveTargetForSelector\n }\n doNotResetActiveTargetOutsideCanvas={\n this.doNotResetActiveTargetOutsideCanvas\n }\n autoCenterWhenCellsChange={this.autoCenterWhenCellsChange}\n onActiveTargetChange={this.#handleActiveTargetChange}\n onSwitchActiveTarget={this.#handleSwitchActiveTarget}\n onCellContextMenu={this.#handleCellContextMenu}\n onCellClick={this.#handleCellClick}\n />\n );\n }\n}\n\nexport interface EoDisplayCanvasComponentProps extends EoDisplayCanvasProps {\n shadowRoot: ShadowRoot;\n onActiveTargetChange(target: ActiveTarget | null): void;\n onSwitchActiveTarget(target: ActiveTarget | null): void;\n onCellContextMenu(detail: CellContextMenuDetail): void;\n onCellClick(detail: CellContextMenuDetail): void;\n}\n\nfunction EoDisplayCanvasComponent({\n shadowRoot,\n cells: initialCells,\n layout,\n layoutOptions,\n defaultNodeSize,\n defaultNodeBricks,\n defaultEdgeLines,\n degradedThreshold,\n degradedNodeLabel,\n activeTarget: _activeTarget,\n fadeUnrelatedCells,\n zoomable,\n scrollable,\n pannable,\n scaleRange: _scaleRange,\n hideZoomBar,\n autoCenterWhenCellsChange,\n doNotResetActiveTargetForSelector,\n doNotResetActiveTargetOutsideCanvas,\n onActiveTargetChange,\n onSwitchActiveTarget,\n onCellContextMenu,\n onCellClick,\n}: EoDisplayCanvasComponentProps) {\n const [{ cells, layoutKey }, dispatch] = useReducer(\n rootReducer,\n initialCells,\n (initialCells) => ({\n cells: initializeCells(initialCells, { defaultNodeSize }),\n layoutKey: 1,\n })\n );\n\n // When nodes are greater or equal to threshold, the diagram will be degraded.\n // Thus all nodes will be displayed as simple svg elements instead of bricks.\n const degraded = useMemo(\n () =>\n cells.filter(isNodeCell).length >=\n (degradedThreshold ?? DEFAULT_DEGRADED_THRESHOLD),\n [cells, degradedThreshold]\n );\n\n const rootRef = useRef<SVGSVGElement>(null);\n\n const { grabbing, transform, zoomer, scaleRange } = useZoom({\n rootRef,\n zoomable,\n scrollable,\n pannable,\n draggable: true,\n scaleRange: _scaleRange,\n onSwitchActiveTarget,\n });\n\n const { centered, setCentered, getNextLayoutKey } = useLayout({\n layout,\n layoutOptions,\n rootRef,\n cells,\n zoomable,\n zoomer,\n scaleRange,\n layoutKey,\n autoCenterWhenCellsChange,\n dispatch,\n });\n\n const reCenter = useCallback(() => {\n setCentered(false);\n }, [setCentered]);\n\n const previousCellsRef = useRef(initialCells);\n\n useEffect(() => {\n if (initialCells !== previousCellsRef.current) {\n previousCellsRef.current = initialCells;\n const result = updateCells({\n canvasWidth: shadowRoot.host.clientWidth,\n canvasHeight: shadowRoot.host.clientHeight,\n defaultNodeSize,\n layout,\n previousCells: cells,\n cells: initialCells,\n scaleRange,\n transform,\n });\n dispatch({ type: \"update-cells\", payload: result.cells });\n }\n }, [\n cells,\n defaultNodeSize,\n initialCells,\n layout,\n scaleRange,\n shadowRoot,\n transform,\n ]);\n\n const activeTarget = useActiveTarget({\n rootRef,\n activeTarget: _activeTarget,\n doNotResetActiveTargetForSelector,\n doNotResetActiveTargetOutsideCanvas,\n onActiveTargetChange,\n });\n\n const defPrefix = useMemo(() => `${uniqueId(\"diagram-\")}-`, []);\n const markerPrefix = `${defPrefix}line-arrow-`;\n\n const handleNodeBrickResize = useCallback(\n (id: string, size: SizeTuple | null) => {\n dispatch({\n type: \"update-node-size\",\n payload: { id, size },\n layoutKey: getNextLayoutKey(),\n });\n },\n [getNextLayoutKey]\n );\n\n const [hoverCell, setHoverCell] = useState<Cell | null>(null);\n const handleCellMouseEnter = useCallback((cell: Cell) => {\n setHoverCell(cell);\n }, []);\n const handleCellMouseLeave = useCallback((cell: Cell) => {\n setHoverCell((prev) => (prev === cell ? null : prev));\n }, []);\n\n const [unrelatedCells, setUnrelatedCells] = useState<Cell[]>([]);\n useEffect(() => {\n const nextUnrelated = fadeUnrelatedCells\n ? getUnrelatedCells(cells, null, hoverCell)\n : [];\n // Do not update the state when prev and next are both empty.\n setUnrelatedCells((prev) =>\n prev.length === 0 && nextUnrelated.length === 0 ? prev : nextUnrelated\n );\n }, [cells, fadeUnrelatedCells, hoverCell]);\n\n const handleZoomSlide = useCallback(\n (value: number) => {\n // istanbul ignore next\n if (process.env.NODE_ENV !== \"test\") {\n zoomer.scaleTo(select(rootRef.current!), value / 100);\n }\n },\n [zoomer]\n );\n\n const { lineConfMap, markers } = useLineMarkers({\n cells,\n defaultEdgeLines,\n markerPrefix,\n });\n\n const ready = useReady({ cells, layout, centered });\n\n return (\n <>\n <svg\n width=\"100%\"\n height=\"100%\"\n ref={rootRef}\n className={classNames(\"root\", { grabbing, pannable, ready })}\n tabIndex={-1}\n >\n <defs>\n {markers.map((marker, index) => (\n <MarkerComponent\n key={index}\n id={`${markerPrefix}${index}`}\n type={marker.markerType}\n strokeColor={marker.strokeColor}\n />\n ))}\n </defs>\n <g\n transform={`translate(${transform.x} ${transform.y}) scale(${transform.k})`}\n >\n <g className=\"cells\">\n {cells.map((cell) => (\n <CellComponent\n key={`${cell.type}:${isEdgeCell(cell) ? `${cell.source}~${cell.target}` : cell.id}`}\n layout={layout}\n cell={cell}\n cells={cells}\n degraded={degraded}\n degradedNodeLabel={degradedNodeLabel}\n defaultNodeBricks={defaultNodeBricks}\n lineConfMap={lineConfMap}\n transform={transform}\n activeTarget={activeTarget}\n readOnly\n unrelatedCells={unrelatedCells}\n onSwitchActiveTarget={onSwitchActiveTarget}\n onCellContextMenu={onCellContextMenu}\n onCellClick={onCellClick}\n onNodeBrickResize={handleNodeBrickResize}\n onCellMouseEnter={\n fadeUnrelatedCells && isNodeCell(cell)\n ? handleCellMouseEnter\n : undefined\n }\n onCellMouseLeave={\n fadeUnrelatedCells && isNodeCell(cell)\n ? handleCellMouseLeave\n : undefined\n }\n />\n ))}\n </g>\n </g>\n </svg>\n {!hideZoomBar && (\n <ZoomBarComponent\n shadowRoot={shadowRoot}\n scale={transform.k}\n scaleRange={scaleRange}\n onZoomChange={handleZoomSlide}\n onReCenter={reCenter}\n />\n )}\n </>\n );\n}\n"],"names":["defineElement","property","event","createDecorators","_EoDisplayCanvas","_A","WeakMap","_B","_C","_D","_E","_F","_G","_H","_I","_J","_K","_L","_M","_N","_O","_P","_Q","_R","_S","_EoDisplayCanvas_brand","WeakSet","_handleActiveTargetChange","_handleSwitchActiveTarget","_T","_handleCellContextMenu","_U","_handleCellClick","EoDisplayCanvas","ReactNextElement","constructor","arguments","_classPrivateMethodInitSpec","_classPrivateFieldInitSpec","_init_cells","_init_extra_cells","_init_layout","_init_extra_layout","_init_layoutOptions","_init_extra_layoutOptions","_init_defaultNodeSize","DEFAULT_NODE_SIZE","_init_extra_defaultNodeSize","_init_defaultNodeBricks","_init_extra_defaultNodeBricks","_init_degradedThreshold","_init_extra_degradedThreshold","_init_degradedNodeLabel","_init_extra_degradedNodeLabel","_init_defaultEdgeLines","_init_extra_defaultEdgeLines","_init_activeTarget","_init_extra_activeTarget","_init_fadeUnrelatedCells","_init_extra_fadeUnrelatedCells","_init_zoomable","_init_extra_zoomable","_init_scrollable","_init_extra_scrollable","_init_pannable","_init_extra_pannable","_init_scaleRange","_init_extra_scaleRange","_init_hideZoomBar","_init_extra_hideZoomBar","_init_autoCenterWhenCellsChange","_init_extra_autoCenterWhenCellsChange","_init_doNotResetActiveTargetForSelector","_init_extra_doNotResetActiveTargetForSelector","_init_doNotResetActiveTargetOutsideCanvas","_init_extra_doNotResetActiveTargetOutsideCanvas","_init_activeTargetChangeEvent","_init_extra_activeTargetChangeEvent","target","_classPrivateGetter","this","_get_activeTargetChangeEvent","emit","sameTarget","activeTarget","_init_cellContextMenu","_init_extra_cellContextMenu","detail","_get_cellContextMenu","_init_cellClick","_init_extra_cellClick","_get_cellClick","cells","_classPrivateFieldGet","v","_classPrivateFieldSet","layout","layoutOptions","defaultNodeSize","defaultNodeBricks","degradedThreshold","degradedNodeLabel","defaultEdgeLines","fadeUnrelatedCells","zoomable","scrollable","pannable","scaleRange","hideZoomBar","autoCenterWhenCellsChange","doNotResetActiveTargetForSelector","doNotResetActiveTargetOutsideCanvas","render","React","EoDisplayCanvasComponent","shadowRoot","onActiveTargetChange","onSwitchActiveTarget","onCellContextMenu","onCellClick","_ref","initialCells","_activeTarget","_scaleRange","layoutKey","dispatch","useReducer","rootReducer","initializeCells","degraded","useMemo","filter","isNodeCell","length","DEFAULT_DEGRADED_THRESHOLD","rootRef","useRef","grabbing","transform","zoomer","useZoom","draggable","centered","setCentered","getNextLayoutKey","useLayout","reCenter","useCallback","previousCellsRef","useEffect","current","result","updateCells","canvasWidth","host","clientWidth","canvasHeight","clientHeight","previousCells","type","payload","useActiveTarget","markerPrefix","uniqueId","handleNodeBrickResize","id","size","hoverCell","setHoverCell","useState","handleCellMouseEnter","cell","handleCellMouseLeave","prev","unrelatedCells","setUnrelatedCells","nextUnrelated","getUnrelatedCells","handleZoomSlide","value","scaleTo","select","lineConfMap","markers","useLineMarkers","ready","useReady","width","height","ref","className","classNames","tabIndex","map","marker","index","MarkerComponent","key","markerType","strokeColor","x","y","k","CellComponent","isEdgeCell","source","readOnly","onNodeBrickResize","onCellMouseEnter","undefined","onCellMouseLeave","ZoomBarComponent","scale","onZoomChange","onReCenter","_EoDisplayCanvas2","e","_set_activeTargetChangeEvent","_set_cellContextMenu","_set_cellClick","c","_initClass","_applyDecs","styleTexts","styleText","zoomBarStyleText","attribute","String","Number","Boolean","o","_","has","_checkInRHS"],"sourceRoot":""}
@@ -0,0 +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:()=>Xt,EoDrawCanvasComponent:()=>It,uuidV4:()=>Xa});var i,s=a(4635),n=a(918),l=a(6902),o=a(2559),r=a(5536),d=a(6121),h=a(829),c=a(2740),u=a(8769),g=a.n(u),A=a(300),p=a(4295),v=a(3078),y=(a(6477),a(1030)),w=a(3373),C=a.n(w),f=a(7566),m=a(5748),k=a(3739),b=a(531),E=a(8185),x=a(5114),M=a(4932),T=a(3639),N=a(3783),W=a(2098),S=a(227),R=a(3033),z=a(8091),B=a(1819),L=a(7099),D=a(1484),O=a(8197),P=a(7531),H=a(8875),$=a(2722),F=a(9978),_=a(2219),K=a(3012),U=a(6237),j=a(1103),V=a(9386),I=a(1991),X=a(2202),Y=a(1825);let q,G,J,Z,Q,ee,te,ae,ie,se,ne,le,oe,re,de,he,ce,ue,ge,Ae,pe,ve,ye,we,Ce,fe,me,ke,be,Ee,xe,Me,Te,Ne,We,Se,Re,ze,Be,Le,De,Oe,Pe,He,$e,Fe,_e,Ke,Ue,je,Ve,Ie,Xe,Ye,qe,Ge,Je,Ze,Qe,et,tt,at,it,st,nt,lt,ot,rt,dt,ht,ct,ut,gt,At,pt,vt,yt,wt,Ct,ft,mt,kt,bt,Et,xt,Mt,Tt,Nt,Wt,St,Rt,zt,Bt,Lt,Dt,Ot,Pt,Ht,$t,Ft;const _t=(0,v.unwrapProvider)("basic.lock-body-scroll"),{defineElement:Kt,property:Ut,method:jt,event:Vt}=(0,A.createDecorators)(),It=g().forwardRef(Ia);let Xt;var Yt=new WeakMap,qt=new WeakMap,Gt=new WeakMap,Jt=new WeakMap,Zt=new WeakMap,Qt=new WeakMap,ea=new WeakMap,ta=new WeakMap,aa=new WeakMap,ia=new WeakMap,sa=new WeakMap,na=new WeakMap,la=new WeakMap,oa=new WeakMap,ra=new WeakMap,da=new WeakMap,ha=new WeakMap,ca=new WeakMap,ua=new WeakMap,ga=new WeakMap,Aa=new WeakMap,pa=new WeakMap,va=new WeakSet,ya=new WeakMap,wa=new WeakMap,Ca=new WeakMap,fa=new WeakMap,ma=new WeakMap,ka=new WeakMap,ba=new WeakMap,Ea=new WeakMap,xa=new WeakMap,Ma=new WeakMap,Ta=new WeakMap,Na=new WeakMap,Wa=new WeakMap,Sa=new WeakMap,Ra=new WeakMap,za=new WeakMap,Ba=new WeakMap,La=new WeakMap,Da=new WeakMap,Oa=new WeakMap,Pa=new WeakMap,Ha=new WeakMap,$a=new WeakMap,Fa=new WeakMap,_a=new WeakMap,Ka=new WeakMap,Ua=new WeakMap;class ja extends p.ReactNextElement{constructor(){super(...arguments),(0,s.A)(this,va),(0,n.A)(this,Yt,(q(this),J(this))),(0,n.A)(this,qt,(Z(this),Q(this))),(0,n.A)(this,Gt,(ee(this),te(this))),(0,n.A)(this,Jt,(ae(this),ie(this,[R.HP,R.HP]))),(0,n.A)(this,Zt,(se(this),ne(this))),(0,n.A)(this,Qt,(le(this),oe(this))),(0,n.A)(this,ea,(re(this),de(this))),(0,n.A)(this,ta,(he(this),ce(this))),(0,n.A)(this,aa,(ue(this),ge(this))),(0,n.A)(this,ia,(Ae(this),pe(this))),(0,n.A)(this,sa,(ve(this),ye(this,!0))),(0,n.A)(this,na,(we(this),Ce(this,!0))),(0,n.A)(this,la,(fe(this),me(this,!0))),(0,n.A)(this,oa,(ke(this),be(this,!1))),(0,n.A)(this,ra,(Ee(this),xe(this))),(0,n.A)(this,da,(Me(this),Te(this))),(0,n.A)(this,ha,(Ne(this),We(this))),(0,n.A)(this,ca,(Se(this),Re(this))),(0,n.A)(this,ua,(ze(this),Be(this))),(0,n.A)(this,ga,(Le(this),De(this))),(0,n.A)(this,Aa,(Oe(this),Pe(this))),(0,n.A)(this,pa,(He(this),$e(this))),(0,n.A)(this,ya,(Ke(this),e=>{(0,r.A)(va,this,Fe).emit(e)})),(0,n.A)(this,wa,(e=>{(0,E.c)(e,this.activeTarget)||(this.activeTarget=e)})),(0,n.A)(this,Ca,Ue(this)),(0,n.A)(this,fa,(Ie(this),Xe(this))),(0,n.A)(this,ma,(Ge(this),e=>{(0,r.A)(va,this,Ye).emit(e),"node"===e.type&&(0,r.A)(va,this,je).emit(e)})),(0,n.A)(this,ka,Je(this)),(0,n.A)(this,ba,(et(this),e=>{(0,r.A)(va,this,Ze).emit(e)})),(0,n.A)(this,Ea,tt(this)),(0,n.A)(this,xa,(st(this),e=>{(0,r.A)(va,this,at).emit(e)})),(0,n.A)(this,Ma,nt(this)),(0,n.A)(this,Ta,(rt(this),dt(this))),(0,n.A)(this,Na,(ut(this),e=>{(0,r.A)(va,this,ht).emit(e),"node"===e.type&&(0,r.A)(va,this,lt).emit(e)})),(0,n.A)(this,Wa,gt(this)),(0,n.A)(this,Sa,(vt(this),e=>{(0,r.A)(va,this,At).emit(e)})),(0,n.A)(this,Ra,yt(this)),(0,n.A)(this,za,(ft(this),e=>{(0,r.A)(va,this,wt).emit(e)})),(0,n.A)(this,Ba,mt(this)),(0,n.A)(this,La,(Et(this),e=>{(0,r.A)(va,this,kt).emit(e)})),(0,n.A)(this,Da,xt(this)),(0,n.A)(this,Oa,(Nt(this),e=>{(0,r.A)(va,this,Mt).emit(e)})),(0,n.A)(this,Pa,Wt(this)),(0,n.A)(this,Ha,(zt(this),e=>{(0,r.A)(va,this,St).emit(e)})),(0,n.A)(this,$a,Bt(this)),(0,n.A)(this,Fa,(Ot(this),e=>{(0,r.A)(va,this,Lt).emit(e)})),(0,n.A)(this,_a,Pt(this)),(0,n.A)(this,Ka,(Ft(this),e=>{(0,r.A)(va,this,Ht).emit(e)})),(0,n.A)(this,Ua,(0,u.createRef)())}get cells(){return(0,h.A)(Yt,this)}set cells(e){(0,d.A)(Yt,this,e)}get layout(){return(0,h.A)(qt,this)}set layout(e){(0,d.A)(qt,this,e)}get layoutOptions(){return(0,h.A)(Gt,this)}set layoutOptions(e){(0,d.A)(Gt,this,e)}get defaultNodeSize(){return(0,h.A)(Jt,this)}set defaultNodeSize(e){(0,d.A)(Jt,this,e)}get defaultNodeBricks(){return(0,h.A)(Zt,this)}set defaultNodeBricks(e){(0,d.A)(Zt,this,e)}get degradedThreshold(){return(0,h.A)(Qt,this)}set degradedThreshold(e){(0,d.A)(Qt,this,e)}get degradedNodeLabel(){return(0,h.A)(ea,this)}set degradedNodeLabel(e){(0,d.A)(ea,this,e)}get defaultEdgeLines(){return(0,h.A)(ta,this)}set defaultEdgeLines(e){(0,d.A)(ta,this,e)}get activeTarget(){return(0,h.A)(aa,this)}set activeTarget(e){(0,d.A)(aa,this,e)}get fadeUnrelatedCells(){return(0,h.A)(ia,this)}set fadeUnrelatedCells(e){(0,d.A)(ia,this,e)}get zoomable(){return(0,h.A)(sa,this)}set zoomable(e){(0,d.A)(sa,this,e)}get scrollable(){return(0,h.A)(na,this)}set scrollable(e){(0,d.A)(na,this,e)}get pannable(){return(0,h.A)(la,this)}set pannable(e){(0,d.A)(la,this,e)}get allowEdgeToArea(){return(0,h.A)(oa,this)}set allowEdgeToArea(e){(0,d.A)(oa,this,e)}get dragBehavior(){return(0,h.A)(ra,this)}set dragBehavior(e){(0,d.A)(ra,this,e)}get ctrlDragBehavior(){return(0,h.A)(da,this)}set ctrlDragBehavior(e){(0,d.A)(da,this,e)}get scaleRange(){return(0,h.A)(ha,this)}set scaleRange(e){(0,d.A)(ha,this,e)}get lineSettings(){return(0,h.A)(ca,this)}set lineSettings(e){(0,d.A)(ca,this,e)}get lineConnector(){return(0,h.A)(ua,this)}set lineConnector(e){(0,d.A)(ua,this,e)}get doNotResetActiveTargetForSelector(){return(0,h.A)(ga,this)}set doNotResetActiveTargetForSelector(e){(0,d.A)(ga,this,e)}get doNotResetActiveTargetOutsideCanvas(){return(0,h.A)(Aa,this)}set doNotResetActiveTargetOutsideCanvas(e){(0,d.A)(Aa,this,e)}async dropNode(e){var t,a;let{id:i,position:s,size:n,data:l,useBrick:o}=e;if(null===(t=(a=document).elementsFromPoint)||void 0===t||null===(t=t.call(a,s[0],s[1]))||void 0===t?void 0:t.includes(this)){var r,d,c;const e=this.getBoundingClientRect(),t=(0,h.A)(Ua,this).current.getTransform(),a={type:"node",id:i,view:{..."force"===this.layout||"dagre"===this.layout?null:{x:(s[0]-e.left-t.x)/t.k,y:(s[1]-e.top-t.y)/t.k},width:null!==(r=null==n?void 0:n[0])&&void 0!==r?r:this.defaultNodeSize[0],height:null!==(d=null==n?void 0:n[1])&&void 0!==d?d:this.defaultNodeSize[0]},data:l,useBrick:o};return null===(c=(0,h.A)(Ua,this).current)||void 0===c||c.dropNode(a),a}return null}async dropDecorator(e){var t,a;let{position:i,decorator:s,text:n,direction:l}=e;if(null===(t=(a=document).elementsFromPoint)||void 0===t||null===(t=t.call(a,i[0],i[1]))||void 0===t?void 0:t.includes(this)){var o;const e=this.getBoundingClientRect(),t=(0,h.A)(Ua,this).current.getTransform(),a={type:"decorator",decorator:s,id:Xa(),view:{x:(i[0]-e.left-t.x)/t.k,y:(i[1]-e.top-t.y)/t.k,width:R.N8,height:R.w1,text:n,direction:l}};return null===(o=(0,h.A)(Ua,this).current)||void 0===o||o.dropDecorator(a),a}return null}async addNodes(e){if(0===e.length)return[];const t=e.map((e=>{var t,a;let{size:i,useBrick:s,id:n,data:l}=e;return{type:"node",id:n,data:l,view:{width:null!==(t=null==i?void 0:i[0])&&void 0!==t?t:this.defaultNodeSize[0],height:null!==(a=null==i?void 0:i[1])&&void 0!==a?a:this.defaultNodeSize[0]},useBrick:s}}));return(0,h.A)(Ua,this).current.addNodes(t,{defaultNodeSize:this.defaultNodeSize,canvasWidth:this.clientWidth,canvasHeight:this.clientHeight})}async addEdge(e){var t;let{source:a,target:i,data:s}=e;const n={type:"edge",source:a,target:i,data:s,view:this.lineSettings};return null===(t=(0,h.A)(Ua,this).current)||void 0===t||t.addEdge(n),n}manuallyConnectNodes(e){return(0,h.A)(Ua,this).current.manuallyConnectNodes(e)}async updateCells(e,t){await(0,o.A)(va,this,Va).call(this);const{updated:a}=(0,h.A)(Ua,this).current.updateCells(e,{...t,defaultNodeSize:this.defaultNodeSize,canvasWidth:this.clientWidth,canvasHeight:this.clientHeight});return{updated:a}}disconnectedCallback(){super.disconnectedCallback(),_t(this,!1)}render(){return g().createElement(It,{host:this,ref:(0,h.A)(Ua,this),layout:this.layout,layoutOptions:this.layoutOptions,cells:this.cells,defaultNodeSize:this.defaultNodeSize,defaultNodeBricks:this.defaultNodeBricks,defaultEdgeLines:this.defaultEdgeLines,degradedThreshold:this.degradedThreshold,degradedNodeLabel:this.degradedNodeLabel,activeTarget:this.activeTarget,fadeUnrelatedCells:this.fadeUnrelatedCells,zoomable:this.zoomable,scrollable:this.scrollable,pannable:this.pannable,dragBehavior:this.dragBehavior,ctrlDragBehavior:this.ctrlDragBehavior,scaleRange:this.scaleRange,lineSettings:this.lineSettings,lineConnector:this.lineConnector,allowEdgeToArea:this.allowEdgeToArea,doNotResetActiveTargetForSelector:this.doNotResetActiveTargetForSelector,doNotResetActiveTargetOutsideCanvas:this.doNotResetActiveTargetOutsideCanvas,onActiveTargetChange:(0,h.A)(ya,this),onSwitchActiveTarget:(0,h.A)(wa,this),onCellMove:(0,h.A)(ma,this),onCellsMove:(0,h.A)(ba,this),onCellResize:(0,h.A)(xa,this),onCellDelete:(0,h.A)(Na,this),onCellsDelete:(0,h.A)(Sa,this),onEdgeAdd:(0,h.A)(La,this),onCellContextMenu:(0,h.A)(za,this),onDecoratorTextChange:(0,h.A)(Ha,this),onContainerContainerChange:(0,h.A)(Fa,this),onScaleChange:(0,h.A)(Ka,this),onEdgeViewChange:(0,h.A)(Oa,this)})}}function Va(){return new Promise((e=>{const t=()=>{(0,h.A)(Ua,this).current?e():setTimeout(t,10)};t()}))}function Ia(e,t){let{host:a,layout:i,layoutOptions:s,cells:n,defaultNodeSize:l,defaultNodeBricks:o,defaultEdgeLines:r,degradedThreshold:d,degradedNodeLabel:h,activeTarget:c,fadeUnrelatedCells:A,zoomable:p,scrollable:v,pannable:w,dragBehavior:E,ctrlDragBehavior:K,scaleRange:U,lineSettings:q,lineConnector:G,allowEdgeToArea:J,doNotResetActiveTargetForSelector:Z,doNotResetActiveTargetOutsideCanvas:Q,onActiveTargetChange:ee,onSwitchActiveTarget:te,onCellMove:ae,onCellResize:ie,onCellDelete:se,onCellsMove:ne,onCellsDelete:le,onCellContextMenu:oe,onEdgeAdd:re,onDecoratorTextChange:de,onScaleChange:he,onContainerContainerChange:ce,onEdgeViewChange:ue}=e;const[{cells:ge,layoutKey:Ae},pe]=(0,u.useReducer)(m.d,n,(e=>({cells:(0,N.C)(e,{defaultNodeSize:l}),layoutKey:0}))),ve=(0,u.useMemo)((()=>ge.filter(b.N).length>=(null!=d?d:R.pC)),[ge,d]),ye=(0,u.useRef)(null),we=(0,u.useRef)(null),[Ce,fe]=(0,u.useState)([]),[me,ke]=(0,u.useState)([]),{grabbing:be,transform:Ee,zoomer:xe,scaleRange:Me}=(0,z.f)({rootRef:ye,zoomable:p,scrollable:v,pannable:w,draggable:"grab"===E,ctrlDraggable:"grab"===K,scaleRange:U,onSwitchActiveTarget:te});(0,u.useEffect)((()=>{he(Ee.k)}),[he,Ee.k]);const[Te,Ne]=(0,u.useState)(null),[We,Se]=(0,u.useState)(null),{centered:Re,setCentered:ze,getNextLayoutKey:Be}=(0,D.g)({layout:i,layoutOptions:s,rootRef:ye,cells:ge,zoomable:p,zoomer:xe,scaleRange:Me,layoutKey:Ae,allowEdgeToArea:J,dispatch:pe});(0,u.useImperativeHandle)(t,(()=>({dropNode(e){"dagre"!==i&&"force"!==i&&ze(!0),pe({type:"drop-node",payload:e})},dropDecorator(e){"dagre"!==i&&"force"!==i&&ze(!0),pe({type:"drop-decorator",payload:e})},addNodes(e,t){let{defaultNodeSize:a,canvasWidth:s,canvasHeight:n}=t;const l=ge.findLastIndex((e=>!("decorator"===e.type&&"text"===e.decorator)))+1,o=[...ge.slice(0,l),...e,...ge.slice(l)],{cells:r,updated:d,shouldReCenter:h}=(0,W.L)({cells:o,layout:i,previousCells:ge,defaultNodeSize:a,canvasWidth:s,canvasHeight:n,scaleRange:Me,transform:Ee,allowEdgeToArea:J});return h&&ze(!1),pe({type:"update-cells",payload:r}),d.filter((t=>e.includes(t)))},addEdge(e){pe({type:"add-edge",payload:e})},updateCells(e,t){const{shouldReCenter:a,...s}=(0,W.L)({...t,layout:i,previousCells:ge,cells:e,scaleRange:Me,transform:Ee,allowEdgeToArea:J});return a&&ze(!1),pe({type:"update-cells",payload:s.cells}),s},getTransform:()=>Ee,manuallyConnectNodes(e){const t=ge.find((t=>(0,b.bo)(t,J)&&t.id===e));if(t){const e=ye.current.getBoundingClientRect();return Se({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)=>{we.current={resolve:e,reject:t}}))}return Promise.reject(null)}})),[ge,i,Me,ze,Ee,J]);const Le=(0,u.useCallback)(((e,t)=>{var a;for(let a=ge.length-1;a>=0;a--){const s=ge[a];if((0,b.bo)(s,J)&&s.id!==e.source.id&&s.view.x<t[0]&&s.view.x+s.view.width>t[0]&&s.view.y<t[1]&&s.view.y+s.view.height>t[1]){var i;null===(i=we.current)||void 0===i||i.resolve({source:e.source,target:s});break}}null===(a=we.current)||void 0===a||a.reject(null),Se(null)}),[J,ge]),[De,Oe]=(0,u.useState)(null);(0,u.useEffect)((()=>{_t(a,!!(We||De||Te))}),[We,a,De,Te]);const Pe=(0,B.J)({rootRef:ye,activeTarget:c,doNotResetActiveTargetForSelector:Z,doNotResetActiveTargetOutsideCanvas:Q,onActiveTargetChange:ee}),[He,$e]=(0,u.useState)([]);(0,u.useEffect)((()=>{const e=A?(0,S.Y)(ge,We,Pe,J):[];$e((t=>0===t.length&&0===e.length?t:e))}),[Pe,ge,We,A,J]),(0,u.useEffect)((()=>{const e=ye.current;if(!e||Ce.length>0)return;const t=e=>{const t=(0,x.a)(e,{cells:ge,activeTarget:Pe});"delete-cells"===(null==t?void 0:t.action)&&(le(t.cells),1===t.cells.length&&se(t.cells[0]))};return e.addEventListener("keydown",t),()=>{e.removeEventListener("keydown",t)}}),[Pe,ge,Ce.length,se,le]);const Fe=`${(0,u.useMemo)((()=>`${(0,y.uniqueId)("diagram-")}-`),[])}line-arrow-`,[_e,Ke]=(0,u.useState)([]),Ue=(0,u.useCallback)((e=>{pe({type:"move-cells",payload:e});const t=[];(0,I._)(e,ge).forEach((e=>{var a,i;null!==(a=e.containerCell)&&void 0!==a&&a.id&&t.push(null===(i=e.containerCell)||void 0===i?void 0:i.id)})),ke(t),Ke(e.flatMap((e=>{var t;return null!==(t=e.guideLines)&&void 0!==t?t:[]})))}),[ge]),je=(0,u.useCallback)((e=>{pe({type:"move-cells",payload:e}),ne(e),1===e.length&&ae(e[0]),(0,I._)(e,ge,ce),ke([]),Ke([])}),[ae,ne,ge,ce]),Ve=(0,u.useCallback)((e=>{pe({type:"resize-cell",payload:e})}),[]),Ie=(0,u.useCallback)((e=>{pe({type:"resize-cell",payload:e}),ie(e)}),[ie]),Xe=(0,u.useCallback)((e=>{let{id:t,editing:a}=e;fe(a?e=>e.includes(t)?e:[...e,t]:e=>e.filter((e=>e!==t)))}),[]),Ye=(0,u.useCallback)(((e,t)=>{const a=Be();pe({type:"update-node-size",payload:{id:e,size:t},layoutKey:a})}),[Be]),qe=(0,u.useCallback)((e=>{xe.scaleTo((0,f.A)(ye.current),e/100)}),[xe]),Ge=(0,u.useCallback)((()=>{ze(!1)}),[ze]),{lineConfMap:Je,lineConnectorConf:Ze,markers:Qe}=(0,P.d)({cells:ge,defaultEdgeLines:r,lineConnector:G,markerPrefix:Fe}),et=(0,O.H)({cells:ge,layout:i,centered:Re}),[tt,at]=(0,u.useState)(null),it=(0,u.useRef)(null),[st,nt]=(0,u.useState)(null),[lt,ot]=(0,u.useState)(null),rt=(0,u.useCallback)((e=>{if(Ze&&(0,b.bo)(e,J)&&(!lt||"control"!==lt.type)){null!==it.current&&(clearTimeout(it.current),it.current=null);const t=(0,H.G)();at({cell:e,relativePoints:t,points:Ya(t,e.view)})}}),[J,Ze,lt]),dt=(0,u.useCallback)((e=>{Ze&&(0,b.N)(e)&&(it.current=setTimeout((()=>{at(null)})))}),[Ze]),ht=(0,u.useCallback)(((e,t,a,i)=>{const s={source:e.id,target:t.id,view:{...q,exitPosition:a,entryPosition:i,vertices:null}};if(ge.find((a=>"edge"===a.type&&a.source===e.id&&a.target===t.id)))pe({type:"change-edge-view",payload:s}),null==ue||ue(s);else{const a={type:"edge",...s};pe({type:"add-edge",payload:a}),re({source:e,target:t,view:a.view})}}),[ge,q,re,ue]),ct=(0,u.useCallback)(((e,t,a)=>{const i={source:e.id,target:t.id,view:a};pe({type:"change-edge-view",payload:i}),null==ue||ue(i)}),[ue]),ut=(0,u.useMemo)((()=>({rootRef:ye,smartConnectLineState:De,unsetHoverStateTimeoutRef:it,hoverState:tt,activeEditableLine:st,lineEditorState:lt,setLineEditorState:ot,setActiveEditableLine:nt,setHoverState:at,setSmartConnectLineState:Oe,onConnect:ht,onChangeEdgeView:ct})),[st,ct,ht,tt,lt,De]);return(0,u.useEffect)((()=>{const e=ye.current;if(!e||"lasso"!==E)return;const t=e.getBoundingClientRect(),a=e=>{(0,_.F)(e,{transform:Ee,offset:[t.left,t.top],onLassoing(e){Ne(e)},onLassoed(e){Ne(null);const t=[];for(const a of ge)if((0,b.t2)(a)||(0,b.o6)(a)||(0,b.Hs)(a)){const i=a.view.x,s=a.view.y;i>=e.x&&i+a.view.width<=e.x+e.width&&s>=e.y&&s+a.view.height<=e.y+e.height&&t.push(a)}null==te||te(t.length>1?{type:"multi",targets:t.map(V.P)}:1===t.length?(0,V.P)(t[0]):null)}})};return e.addEventListener("mousedown",a),()=>{e.removeEventListener("mousedown",a)}}),[Ee,ge,E,te]),g().createElement(F.H.Provider,{value:ut},g().createElement("svg",{width:"100%",height:"100%",ref:ye,className:C()("root",{grabbing:be,pannable:w,ready:et}),tabIndex:-1},g().createElement("defs",null,Qe.map(((e,t)=>g().createElement(k.c,{key:t,id:`${Fe}${t}`,type:e.markerType,strokeColor:e.strokeColor})))),g().createElement("g",{transform:`translate(${Ee.x} ${Ee.y}) scale(${Ee.k})`},g().createElement("g",{className:C()("cells",{allowEdgeToArea:J})},ge.map((e=>g().createElement(M.m,{key:`${e.type}:${(0,b.WW)(e)?`${e.source}~${e.target}`:e.id}`,dragNodeToContainerActive:!(0,b.WW)(e)&&me.includes(e.id),layout:i,layoutOptions:s,cell:e,cells:ge,degraded:ve,degradedNodeLabel:h,defaultNodeBricks:o,transform:Ee,lineConfMap:Je,activeTarget:Pe,unrelatedCells:He,allowEdgeToArea:J,onCellsMoving:Ue,onCellsMoved:je,onCellResizing:Ve,onCellResized:Ie,onSwitchActiveTarget:te,onCellContextMenu:oe,onDecoratorTextChange:de,onDecoratorTextEditing:Xe,onNodeBrickResize:Ye,onCellMouseEnter:rt,onCellMouseLeave:dt})))),g().createElement("g",null,g().createElement(T.w,{connectLineState:We,transform:Ee,markerEnd:`${Fe}0`,onConnect:Le})),Te&&g().createElement("rect",{x:Te.x,y:Te.y,width:Te.width,height:Te.height,fill:"var(--palette-gray-5)",fillOpacity:.3,stroke:"var(--palette-gray-5)",strokeDasharray:2}),Ze&&g().createElement("g",null,g().createElement(j.X,{transform:Ee,lineSettings:q,options:Ze}),g().createElement(Y.W,{transform:Ee,options:Ze})),g().createElement("g",null,_e.map(((e,t)=>g().createElement("path",{key:t,d:`M${e[0].join(" ")} L${e[1].join(" ")}`,stroke:"var(--palette-orange-5)",fill:"none",strokeWidth:1/Ee.k})))),g().createElement("g",null,Ze&&g().createElement(X.F,{scale:Ee.k})),Ze&&g().createElement($.T,{activeTarget:Pe,scale:Ee.k,disabled:!!We}))),g().createElement(L.Y,{shadowRoot:a.shadowRoot,scale:Ee.k,scaleRange:Me,onZoomChange:qe,onReCenter:Ge}))}function Xa(){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 Ya(e,t){let a=arguments.length>2&&void 0!==arguments[2]?arguments[2]:1;const i=R.XK,s=i/2,n=t.x+a/2-s,l=t.y+a/2-s,o=t.width-a+i,r=t.height-a+i;return e.map((e=>({x:n+e.x*o,y:l+e.y*r})))}i=ja,({e:[J,Z,Q,ee,te,ae,ie,se,ne,le,oe,re,de,he,ce,ue,ge,Ae,pe,ve,ye,we,Ce,fe,me,ke,be,Ee,xe,Me,Te,Ne,We,Se,Re,ze,Be,Le,De,Oe,Pe,He,$e,Fe,_e,Ke,Ue,je,Ve,Ie,Xe,Ye,qe,Ge,Je,Ze,Qe,et,tt,at,it,st,nt,lt,ot,rt,dt,ht,ct,ut,gt,At,pt,vt,yt,wt,Ct,ft,mt,kt,bt,Et,xt,Mt,Tt,Nt,Wt,St,Rt,zt,Bt,Lt,Dt,Ot,Pt,Ht,$t,Ft,q],c:[Xt,G]}=(0,c.A)(i,[Kt("eo-draw-canvas",{styleTexts:[K.A,U.A]})],[[Ut({attribute:!1}),1,"cells"],[Ut({type:String}),1,"layout"],[Ut({attribute:!1}),1,"layoutOptions"],[Ut({attribute:!1}),1,"defaultNodeSize"],[Ut({attribute:!1}),1,"defaultNodeBricks"],[Ut({type:Number}),1,"degradedThreshold"],[Ut({attribute:!1}),1,"degradedNodeLabel"],[Ut({attribute:!1}),1,"defaultEdgeLines"],[Ut({attribute:!1}),1,"activeTarget"],[Ut({type:Boolean}),1,"fadeUnrelatedCells"],[Ut({type:Boolean}),1,"zoomable"],[Ut({type:Boolean}),1,"scrollable"],[Ut({type:Boolean}),1,"pannable"],[Ut({type:Boolean}),1,"allowEdgeToArea"],[Ut(),1,"dragBehavior"],[Ut(),1,"ctrlDragBehavior"],[Ut({attribute:!1}),1,"scaleRange"],[Ut({attribute:!1}),1,"lineSettings"],[Ut({attribute:!1}),1,"lineConnector"],[Ut(),1,"doNotResetActiveTargetForSelector"],[Ut({type:Boolean}),1,"doNotResetActiveTargetOutsideCanvas"],[Vt({type:"activeTarget.change"}),1,"activeTargetChangeEvent",e=>(0,h.A)(pa,e),(e,t)=>(0,d.A)(pa,e,t)],[Vt({type:"node.move"}),1,"nodeMoveEvent",e=>(0,h.A)(Ca,e),(e,t)=>(0,d.A)(Ca,e,t)],[Vt({type:"cell.move"}),1,"cellMoveEvent",e=>(0,h.A)(fa,e),(e,t)=>(0,d.A)(fa,e,t)],[Vt({type:"cells.move"}),1,"cellsMoveEvent",e=>(0,h.A)(ka,e),(e,t)=>(0,d.A)(ka,e,t)],[Vt({type:"cell.resize"}),1,"cellResizeEvent",e=>(0,h.A)(Ea,e),(e,t)=>(0,d.A)(Ea,e,t)],[Vt({type:"node.delete"}),1,"nodeDelete",e=>(0,h.A)(Ma,e),(e,t)=>(0,d.A)(Ma,e,t)],[Vt({type:"cell.delete"}),1,"cellDelete",e=>(0,h.A)(Ta,e),(e,t)=>(0,d.A)(Ta,e,t)],[Vt({type:"cells.delete"}),1,"cellsDelete",e=>(0,h.A)(Wa,e),(e,t)=>(0,d.A)(Wa,e,t)],[Vt({type:"cell.contextmenu"}),1,"cellContextMenu",e=>(0,h.A)(Ra,e),(e,t)=>(0,d.A)(Ra,e,t)],[Vt({type:"edge.add"}),1,"edgeAdd",e=>(0,h.A)(Ba,e),(e,t)=>(0,d.A)(Ba,e,t)],[Vt({type:"edge.view.change"}),1,"edgeViewChange",e=>(0,h.A)(Da,e),(e,t)=>(0,d.A)(Da,e,t)],[Vt({type:"decorator.text.change"}),1,"decoratorTextChange",e=>(0,h.A)(Pa,e),(e,t)=>(0,d.A)(Pa,e,t)],[Vt({type:"node.container.change"}),1,"containerContainerChange",e=>(0,h.A)($a,e),(e,t)=>(0,d.A)($a,e,t)],[Vt({type:"scale.change"}),1,"scaleChange",e=>(0,h.A)(_a,e),(e,t)=>(0,d.A)(_a,e,t)],[jt(),2,"dropNode"],[jt(),2,"dropDecorator"],[jt(),2,"addNodes"],[jt(),2,"addEdge"],[jt(),2,"manuallyConnectNodes"],[jt(),2,"updateCells"]],0,(e=>Ua.has((0,l.A)(e))),p.ReactNextElement)),G()}}]);
2
+ //# sourceMappingURL=eo-draw-canvas.bf162c54.js.map