@next-bricks/diagram 0.25.1 → 0.26.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (189) hide show
  1. package/dist/bricks.json +4 -3
  2. package/dist/chunks/1045.b7c29853.js +2 -0
  3. package/dist/chunks/1045.b7c29853.js.map +1 -0
  4. package/dist/chunks/1122.ec5a28bd.js +2 -0
  5. package/dist/chunks/{1832.80a95bcd.js.map → 1122.ec5a28bd.js.map} +1 -1
  6. package/dist/chunks/114.ff6154a0.js +2 -0
  7. package/dist/chunks/114.ff6154a0.js.map +1 -0
  8. package/dist/chunks/1370.1b4ac3ac.js +2 -0
  9. package/dist/chunks/1370.1b4ac3ac.js.map +1 -0
  10. package/dist/chunks/1889.c14b28e6.js +2 -0
  11. package/dist/chunks/{8060.a4decb5e.js → 1889.c14b28e6.js.map} +1 -2
  12. package/dist/chunks/{8644.2e72c575.js → 1940.788d05b3.js} +2 -2
  13. package/dist/chunks/{8644.2e72c575.js.map → 1940.788d05b3.js.map} +1 -1
  14. package/dist/chunks/1972.3c3e1965.js +2 -0
  15. package/dist/chunks/1972.3c3e1965.js.map +1 -0
  16. package/dist/chunks/{856.8fe14637.js → 2052.fa66eafb.js} +2 -2
  17. package/dist/chunks/2052.fa66eafb.js.map +1 -0
  18. package/dist/chunks/{6064.62257333.js → 2277.9a1ded28.js} +2 -2
  19. package/dist/chunks/{3680.88310087.js.map → 2277.9a1ded28.js.map} +1 -1
  20. package/dist/chunks/2770.18b631cb.js +2 -0
  21. package/dist/chunks/2770.18b631cb.js.map +1 -0
  22. package/dist/chunks/{2356.69ab211e.js → 3144.712fb13e.js} +3 -3
  23. package/dist/chunks/{2356.69ab211e.js.map → 3144.712fb13e.js.map} +1 -1
  24. package/dist/chunks/3171.9f016ea3.js +2 -0
  25. package/dist/chunks/{8440.ce0da377.js.map → 3171.9f016ea3.js.map} +1 -1
  26. package/dist/chunks/3426.aed442e0.js +2 -0
  27. package/dist/chunks/3426.aed442e0.js.map +1 -0
  28. package/dist/chunks/3510.49d72504.js +3 -0
  29. package/dist/chunks/3510.49d72504.js.map +1 -0
  30. package/dist/chunks/3933.0342d0ab.js +2 -0
  31. package/dist/chunks/{5356.ec95af1d.js.map → 3933.0342d0ab.js.map} +1 -1
  32. package/dist/chunks/{5668.ff11ba54.js → 4041.58c8ed1f.js} +3 -3
  33. package/dist/chunks/{5668.ff11ba54.js.map → 4041.58c8ed1f.js.map} +1 -1
  34. package/dist/chunks/4456.f6066b87.js +2 -0
  35. package/dist/chunks/4456.f6066b87.js.map +1 -0
  36. package/dist/chunks/{3680.88310087.js → 4658.e875061a.js} +2 -2
  37. package/dist/chunks/{6064.62257333.js.map → 4658.e875061a.js.map} +1 -1
  38. package/dist/chunks/{8648.55f9fafb.js → 4741.b91ef9f1.js} +2 -2
  39. package/dist/chunks/{8648.55f9fafb.js.map → 4741.b91ef9f1.js.map} +1 -1
  40. package/dist/chunks/{7928.6eb9a99a.js → 5250.f7dfb399.js} +3 -3
  41. package/dist/chunks/{7928.6eb9a99a.js.map → 5250.f7dfb399.js.map} +1 -1
  42. package/dist/chunks/{1776.6541feaf.js → 5384.f1a69526.js} +2 -2
  43. package/dist/chunks/{1776.6541feaf.js.map → 5384.f1a69526.js.map} +1 -1
  44. package/dist/chunks/5399.d1706027.js +2 -0
  45. package/dist/chunks/{1372.ddfaca58.js.map → 5399.d1706027.js.map} +1 -1
  46. package/dist/chunks/5552.8099590c.js +2 -0
  47. package/dist/chunks/5552.8099590c.js.map +1 -0
  48. package/dist/chunks/6188.a80198d0.js +3 -0
  49. package/dist/chunks/6188.a80198d0.js.map +1 -0
  50. package/dist/chunks/6314.a17e6cef.js +2 -0
  51. package/dist/chunks/{2976.375fa83c.js.map → 6314.a17e6cef.js.map} +1 -1
  52. package/dist/chunks/6519.9c35628c.js +2 -0
  53. package/dist/chunks/{4524.801d1c14.js.map → 6519.9c35628c.js.map} +1 -1
  54. package/dist/chunks/6773.6ac391fe.js +2 -0
  55. package/dist/chunks/6773.6ac391fe.js.map +1 -0
  56. package/dist/chunks/726.efcf01a2.js +2 -0
  57. package/dist/chunks/726.efcf01a2.js.map +1 -0
  58. package/dist/chunks/7452.9d465fb5.js +2 -0
  59. package/dist/chunks/{6408.1aa0e97e.js.map → 7452.9d465fb5.js.map} +1 -1
  60. package/dist/chunks/7721.5bd46b7f.js +3 -0
  61. package/dist/chunks/{6736.1db5763e.js.map → 7721.5bd46b7f.js.map} +1 -1
  62. package/dist/chunks/7733.7a82300e.js +2 -0
  63. package/dist/chunks/7733.7a82300e.js.map +1 -0
  64. package/dist/chunks/7780.bbd9990e.js +2 -0
  65. package/dist/chunks/{3752.da97f490.js.map → 7780.bbd9990e.js.map} +1 -1
  66. package/dist/chunks/7918.9f7ec4d7.js +2 -0
  67. package/dist/chunks/7918.9f7ec4d7.js.map +1 -0
  68. package/dist/chunks/843.7444579f.js +2 -0
  69. package/dist/chunks/843.7444579f.js.map +1 -0
  70. package/dist/chunks/8989.55e6868c.js +2 -0
  71. package/dist/chunks/8989.55e6868c.js.map +1 -0
  72. package/dist/chunks/9407.1336c97c.js +2 -0
  73. package/dist/chunks/9407.1336c97c.js.map +1 -0
  74. package/dist/chunks/9515.405274b1.js +2 -0
  75. package/dist/chunks/9515.405274b1.js.map +1 -0
  76. package/dist/chunks/9559.7d625626.js +2 -0
  77. package/dist/chunks/{1024.b2fb4d97.js.map → 9559.7d625626.js.map} +1 -1
  78. package/dist/chunks/9591.e9a0ce2d.js +2 -0
  79. package/dist/chunks/9591.e9a0ce2d.js.map +1 -0
  80. package/dist/chunks/9740.fb9cd2a1.js +2 -0
  81. package/dist/chunks/9740.fb9cd2a1.js.map +1 -0
  82. package/dist/chunks/9844.db90776a.js +2 -0
  83. package/dist/chunks/9844.db90776a.js.map +1 -0
  84. package/dist/chunks/editable-label.8e6f528c.js +3 -0
  85. package/dist/chunks/editable-label.8e6f528c.js.map +1 -0
  86. package/dist/chunks/eo-diagram.58ca6b92.js +2 -0
  87. package/dist/chunks/eo-diagram.58ca6b92.js.map +1 -0
  88. package/dist/chunks/eo-display-canvas.77347940.js +2 -0
  89. package/dist/chunks/eo-display-canvas.77347940.js.map +1 -0
  90. package/dist/chunks/eo-draw-canvas.a7b522ea.js +2 -0
  91. package/dist/chunks/eo-draw-canvas.a7b522ea.js.map +1 -0
  92. package/dist/chunks/experimental-node.d03c0c20.js +2 -0
  93. package/dist/chunks/experimental-node.d03c0c20.js.map +1 -0
  94. package/dist/chunks/main.dd8b2330.js +2 -0
  95. package/dist/chunks/main.dd8b2330.js.map +1 -0
  96. package/dist/examples.json +6 -3
  97. package/dist/index.06ad2eaf.js +2 -0
  98. package/dist/index.06ad2eaf.js.map +1 -0
  99. package/dist/manifest.json +152 -77
  100. package/dist/types.json +2983 -1907
  101. package/dist-types/bootstrap.d.ts +1 -0
  102. package/dist-types/display-canvas/index.d.ts +51 -0
  103. package/dist-types/display-canvas/index.spec.d.ts +1 -0
  104. package/dist-types/draw-canvas/CellComponent.d.ts +8 -7
  105. package/dist-types/draw-canvas/decorators/DecoratorArea.d.ts +1 -1
  106. package/dist-types/draw-canvas/decorators/DecoratorText.d.ts +2 -2
  107. package/dist-types/draw-canvas/decorators/index.d.ts +1 -1
  108. package/dist-types/draw-canvas/interfaces.d.ts +6 -5
  109. package/dist-types/draw-canvas/processors/handleMouseDown.d.ts +1 -1
  110. package/dist-types/shared/canvas/useActiveTarget.d.ts +9 -0
  111. package/dist-types/shared/canvas/useAutoCenter.d.ts +16 -0
  112. package/dist-types/shared/canvas/useZoom.d.ts +19 -0
  113. package/docs/eo-display-canvas.md +9 -0
  114. package/package.json +4 -4
  115. package/dist/chunks/1024.b2fb4d97.js +0 -2
  116. package/dist/chunks/1372.ddfaca58.js +0 -2
  117. package/dist/chunks/1564.dad51f47.js +0 -2
  118. package/dist/chunks/1564.dad51f47.js.map +0 -1
  119. package/dist/chunks/1772.b9709e8a.js +0 -2
  120. package/dist/chunks/1772.b9709e8a.js.map +0 -1
  121. package/dist/chunks/1832.80a95bcd.js +0 -2
  122. package/dist/chunks/242.4bd90af0.js +0 -2
  123. package/dist/chunks/242.4bd90af0.js.map +0 -1
  124. package/dist/chunks/2976.375fa83c.js +0 -2
  125. package/dist/chunks/3322.63bf67fe.js +0 -2
  126. package/dist/chunks/3322.63bf67fe.js.map +0 -1
  127. package/dist/chunks/3752.da97f490.js +0 -2
  128. package/dist/chunks/3811.8484a1b6.js +0 -2
  129. package/dist/chunks/3811.8484a1b6.js.map +0 -1
  130. package/dist/chunks/3968.f63a8d5a.js +0 -2
  131. package/dist/chunks/3968.f63a8d5a.js.map +0 -1
  132. package/dist/chunks/4524.801d1c14.js +0 -2
  133. package/dist/chunks/4847.5cfb4368.js +0 -2
  134. package/dist/chunks/4847.5cfb4368.js.map +0 -1
  135. package/dist/chunks/5244.1437dfdf.js +0 -2
  136. package/dist/chunks/5244.1437dfdf.js.map +0 -1
  137. package/dist/chunks/5356.ec95af1d.js +0 -2
  138. package/dist/chunks/5676.e4df99d2.js +0 -2
  139. package/dist/chunks/5676.e4df99d2.js.map +0 -1
  140. package/dist/chunks/6192.e969705a.js +0 -2
  141. package/dist/chunks/6192.e969705a.js.map +0 -1
  142. package/dist/chunks/6228.1f4beffe.js +0 -2
  143. package/dist/chunks/6228.1f4beffe.js.map +0 -1
  144. package/dist/chunks/6352.a1d077df.js +0 -2
  145. package/dist/chunks/6352.a1d077df.js.map +0 -1
  146. package/dist/chunks/6408.1aa0e97e.js +0 -2
  147. package/dist/chunks/6736.1db5763e.js +0 -3
  148. package/dist/chunks/6796.bb543bb4.js +0 -3
  149. package/dist/chunks/6796.bb543bb4.js.map +0 -1
  150. package/dist/chunks/7228.fa4c35d3.js +0 -2
  151. package/dist/chunks/7228.fa4c35d3.js.map +0 -1
  152. package/dist/chunks/7476.2dcc0be8.js +0 -2
  153. package/dist/chunks/7476.2dcc0be8.js.map +0 -1
  154. package/dist/chunks/7861.a4c43abf.js +0 -2
  155. package/dist/chunks/7861.a4c43abf.js.map +0 -1
  156. package/dist/chunks/8020.2af7aa32.js +0 -2
  157. package/dist/chunks/8020.2af7aa32.js.map +0 -1
  158. package/dist/chunks/8060.a4decb5e.js.map +0 -1
  159. package/dist/chunks/820.83e05b04.js +0 -2
  160. package/dist/chunks/820.83e05b04.js.map +0 -1
  161. package/dist/chunks/8440.ce0da377.js +0 -2
  162. package/dist/chunks/856.8fe14637.js.map +0 -1
  163. package/dist/chunks/8732.9c55a3ea.js +0 -2
  164. package/dist/chunks/8732.9c55a3ea.js.map +0 -1
  165. package/dist/chunks/8944.952fed91.js +0 -2
  166. package/dist/chunks/8944.952fed91.js.map +0 -1
  167. package/dist/chunks/9260.c896737b.js +0 -3
  168. package/dist/chunks/9260.c896737b.js.map +0 -1
  169. package/dist/chunks/9560.315d614e.js +0 -2
  170. package/dist/chunks/9560.315d614e.js.map +0 -1
  171. package/dist/chunks/editable-label.128ef04e.js +0 -3
  172. package/dist/chunks/editable-label.128ef04e.js.map +0 -1
  173. package/dist/chunks/eo-diagram.2b8615e9.js +0 -2
  174. package/dist/chunks/eo-diagram.2b8615e9.js.map +0 -1
  175. package/dist/chunks/eo-draw-canvas.e4d56ade.js +0 -2
  176. package/dist/chunks/eo-draw-canvas.e4d56ade.js.map +0 -1
  177. package/dist/chunks/experimental-node.de4a18b6.js +0 -2
  178. package/dist/chunks/experimental-node.de4a18b6.js.map +0 -1
  179. package/dist/chunks/main.e36bc80a.js +0 -2
  180. package/dist/chunks/main.e36bc80a.js.map +0 -1
  181. package/dist/index.0204e63f.js +0 -2
  182. package/dist/index.0204e63f.js.map +0 -1
  183. /package/dist/chunks/{2356.69ab211e.js.LICENSE.txt → 3144.712fb13e.js.LICENSE.txt} +0 -0
  184. /package/dist/chunks/{6796.bb543bb4.js.LICENSE.txt → 3510.49d72504.js.LICENSE.txt} +0 -0
  185. /package/dist/chunks/{5668.ff11ba54.js.LICENSE.txt → 4041.58c8ed1f.js.LICENSE.txt} +0 -0
  186. /package/dist/chunks/{7928.6eb9a99a.js.LICENSE.txt → 5250.f7dfb399.js.LICENSE.txt} +0 -0
  187. /package/dist/chunks/{9260.c896737b.js.LICENSE.txt → 6188.a80198d0.js.LICENSE.txt} +0 -0
  188. /package/dist/chunks/{6736.1db5763e.js.LICENSE.txt → 7721.5bd46b7f.js.LICENSE.txt} +0 -0
  189. /package/dist/chunks/{editable-label.128ef04e.js.LICENSE.txt → editable-label.8e6f528c.js.LICENSE.txt} +0 -0
@@ -1,2 +0,0 @@
1
- "use strict";(self.webpackChunk_next_bricks_diagram=self.webpackChunk_next_bricks_diagram||[]).push([[9560],{5776:(e,t,r)=>{r.d(t,{s:()=>z});var n=r(5600),o=r.n(n),a=r(1252),i=r.n(a),c=r(7181),d=r(6960),l=r(960);function s(e,t){return e.find((e=>(0,c.G4)(e)&&e.id===t))}function v(e){var{edge:t,cells:r,markerEnd:a,defaultEdgeLines:c}=e,v=(0,n.useMemo)((()=>s(r,t.source)),[r,t.source]),f=(0,n.useMemo)((()=>s(r,t.target)),[r,t.target]),h=(0,n.useMemo)((()=>null==c?void 0:c.find((e=>(0,d.checkIfByTransform)(e,{edge:t})))),[c,t]),m=(0,n.useMemo)((()=>v&&f?(0,l.g)(u(v.view,5),u(f.view,5)):null),[v,f]);if(!m)return null;var w="M".concat(m[0].x," ").concat(m[0].y,"L").concat(m[1].x," ").concat(m[1].y);return o().createElement(o().Fragment,null,o().createElement("path",{d:w,fill:"none",stroke:"transparent",strokeWidth:16}),o().createElement("path",{className:i()("line",{dashed:null==h?void 0:h.dashed}),d:w,fill:"none",stroke:"gray",markerEnd:"url(#".concat(a,")")}),o().createElement("path",{className:"line-active-bg",d:w,fill:"none"}))}function u(e,t){return{x:e.x+e.width/2,y:e.y+e.height/2,width:e.width+t,height:e.height+t}}var f=r(6196),h=r(7568),m=r(2504);function w(e){var{node:t,defaultNodeBricks:r,onResize:a}=e,i=function(e){var[t,r]=(0,n.useState)(e);return(0,n.useEffect)((()=>{r((t=>(0,h.isEqual)(t,e)?t:e))}),[e]),t}({node:{id:t.id,data:t.data}}),c=t.useBrick,l=(0,n.useRef)(null),s=(0,n.useMemo)((()=>{var e;return null!=c?c:null==r||null===(e=r.find((e=>(0,d.checkIfByTransform)(e,i))))||void 0===e?void 0:e.useBrick}),[r,c,i]),v=(0,n.useCallback)((e=>{var r=l.current;r&&(r.disconnect(),l.current=null),e?setTimeout((()=>{var r=new m.c((()=>{a(t.id,[e.clientWidth,e.clientHeight])}));r.observe(e),l.current=r})):a(t.id,null)}),[t.id,a]);return s?o().createElement("foreignObject",{width:9999,height:9999,className:"node"},s&&o().createElement(f.ReactUseBrick,{useBrick:s,data:i,refCallback:v})):null}function p(e){return"edge"===e.type?(0,h.pick)(e,["type","source","target","data"]):(0,h.pick)(e,["type","id","data"])}function g(e,t){var{action:r,cell:n,scale:o,onCellMoving:a,onCellMoved:i,onCellResizing:c,onCellResized:d,onSwitchActiveTarget:l}=t;if(e.stopPropagation(),l(p(n)),"edge"!==n.type){var s=[e.clientX,e.clientY],v="move"===r?[n.view.x,n.view.y]:[n.view.width,n.view.height],u=!1,f=(e,t)=>{var l,f,h=function(e){return[(e.clientX-s[0])/o,(e.clientY-s[1])/o]}(e);u||(u=h[0]**2+h[1]**2>=9),u&&("move"===r?null===(l=t?i:a)||void 0===l||l({type:n.type,id:n.id,x:v[0]+h[0],y:v[1]+h[1]}):null===(f=t?d:c)||void 0===f||f({type:n.type,id:n.id,width:v[0]+h[0],height:v[1]+h[1]}))},h=e=>{f(e)},m=e=>{f(e,!0),u=!1,document.removeEventListener("mousemove",h),document.removeEventListener("mouseup",m)};document.addEventListener("mousemove",h),document.addEventListener("mouseup",m)}}function y(e){var{cell:t,transform:r,onCellResizing:a,onCellResized:i,onSwitchActiveTarget:c}=e,d=o().useRef(null);return(0,n.useEffect)((()=>{var e=d.current,n=e=>{g(e,{action:"resize",cell:t,scale:r.k,onCellResizing:a,onCellResized:i,onSwitchActiveTarget:c})};return null==e||e.addEventListener("mousedown",n),()=>{null==e||e.removeEventListener("mousedown",n)}}),[t,i,a,c,r.k]),o().createElement("g",{className:"decorator-area"},o().createElement("rect",{width:t.view.width,height:t.view.height,className:"area"}),o().createElement("g",{ref:d,className:"resize-handle",transform:"translate(".concat(t.view.width-20," ").concat(t.view.height-20,")")},o().createElement("rect",{width:20,height:20}),o().createElement("path",{d:"M10 18L18 10 M15 18L18 15"})))}var k=r(4412);function x(e){var t,{cell:r,onDecoratorTextEditing:a,onDecoratorTextChange:c}=e,d=null!==(t=r.view.text)&&void 0!==t?t:"",[l,s]=(0,n.useState)(d),[v,u]=(0,n.useState)(!1),f=(0,n.useRef)(!1),[h,m]=(0,n.useState)(!1),w=(0,n.useRef)(null),p=(0,n.useCallback)((e=>{e.preventDefault(),e.stopPropagation(),u(!0)}),[]);(0,n.useEffect)((()=>{var e=w.current;e&&e.textContent!==l&&(e.textContent=l)}),[l]),(0,n.useEffect)((()=>{v&&w.current&&(w.current.focus(),function(e){var t=document.createRange();t.selectNodeContents(e);var r=window.getSelection();r.removeAllRanges(),r.addRange(t)}(w.current)),a({id:r.id,editing:v})}),[r.id,v,a]),(0,n.useEffect)((()=>{f.current?null==a||a({id:r.id,editing:v}):f.current=!0}),[r.id,v,a]);var g=(0,n.useCallback)((e=>{s(e.target.textContent)}),[]),y=(0,n.useCallback)((()=>{u(!1),m(!0)}),[]);return(0,n.useEffect)((()=>{h&&(null==c||c({id:r.id,view:(0,k.c)((0,k.c)({},r.view),{},{text:l})}),m(!1))}),[r,l,c,h]),o().createElement("foreignObject",{className:"decorator-text"},o().createElement("div",{className:i()("text-container",{editing:v}),onDoubleClick:p},o().createElement("div",{className:"text",contentEditable:v,ref:w,onInput:g,onBlur:y})))}function E(e){var t,{cell:r,transform:n,onCellResizing:a,onCellResized:i,onSwitchActiveTarget:c,onDecoratorTextEditing:d,onDecoratorTextChange:l}=e;switch(r.decorator){case"area":t=y;break;case"text":t=x;break;default:return console.error("Unknown decorator: ".concat(r.decorator)),null}return o().createElement(t,{cell:r,transform:n,onCellResizing:a,onCellResized:i,onSwitchActiveTarget:c,onDecoratorTextEditing:d,onDecoratorTextChange:l})}var C=r(4552);function z(e){var{cell:t,cells:r,defaultNodeBricks:a,defaultEdgeLines:d,markerEnd:l,active:s,transform:u,unrelatedCells:f,onCellMoving:h,onCellMoved:m,onCellResizing:y,onCellResized:k,onSwitchActiveTarget:x,onCellContextMenu:z,onDecoratorTextEditing:M,onDecoratorTextChange:b,onNodeBrickResize:R}=e,S=(0,n.useRef)(null),L=(0,n.useMemo)((()=>f.some((e=>(0,C.M)(e,t)))),[t,f]);(0,n.useEffect)((()=>{var e=S.current,r=e=>{g(e,{action:"move",cell:t,scale:u.k,onCellMoving:h,onCellMoved:m,onSwitchActiveTarget:x})};return null==e||e.addEventListener("mousedown",r),()=>{null==e||e.removeEventListener("mousedown",r)}}),[t,m,h,x,u.k]);var T=(0,n.useCallback)((e=>{e.preventDefault(),x(p(t)),z({cell:t,clientX:e.clientX,clientY:e.clientY})}),[t,z,x]);return o().createElement("g",{className:i()("cell",{active:s,faded:L}),ref:S,transform:"edge"===t.type?void 0:"translate(".concat(t.view.x," ").concat(t.view.y,")"),onContextMenu:T},(0,c.G4)(t)?o().createElement(w,{node:t,defaultNodeBricks:a,onResize:R}):(0,c.Wk)(t)?o().createElement(v,{edge:t,defaultEdgeLines:d,cells:r,markerEnd:l}):(0,c.c1)(t)?o().createElement(E,{cell:t,transform:u,onCellResizing:y,onCellResized:k,onSwitchActiveTarget:x,onDecoratorTextEditing:M,onDecoratorTextChange:b}):null)}},8044:(e,t,r)=>{r.d(t,{E:()=>c});var n=r(5600),o=r.n(n),a=r(1252),i=r.n(a);function c(e){var{connectLineState:t,transform:r,markerEnd:a,onConnect:c}=e,[d,l]=(0,n.useState)(null);return(0,n.useEffect)((()=>{t&&l(t.from)}),[t]),(0,n.useEffect)((()=>{if(t){var e=e=>{l([(e.clientX-r.x-t.offset[0])/r.k,(e.clientY-r.y-t.offset[1])/r.k])},n=e=>{e.stopPropagation()},o=e=>{e.stopPropagation(),a(),c(t,[(e.clientX-r.x-t.offset[0])/r.k,(e.clientY-r.y-t.offset[1])/r.k])},a=()=>{document.removeEventListener("mousemove",e),document.removeEventListener("mousedown",n,{capture:!0}),document.removeEventListener("click",o,{capture:!0}),l(null)};return document.addEventListener("mousemove",e),document.addEventListener("mousedown",n,{capture:!0}),document.addEventListener("click",o,{capture:!0}),a}}),[t,c,r]),o().createElement("path",{className:i()("connect-line",{connecting:!!t&&d&&(d[0]-t.from[0])**2+(d[1]-t.from[1])**2>25}),d:t&&d?"M".concat(t.from.join(" "),"L").concat(d.join(" ")):"",fill:"none",stroke:"gray",strokeWidth:1,markerEnd:"url(#".concat(a,")")})}},3576:(e,t,r)=>{r.d(t,{Mf:()=>i,Oi:()=>l,WH:()=>d,eW:()=>o,iS:()=>c,m6:()=>n,my:()=>a});var n=Symbol.for("size-initialized"),o=20,a=36,i=100,c=60,d=.5,l=2},7181:(e,t,r)=>{function n(e){return"node"===e.type}function o(e){return"decorator"===e.type}function a(e){return"node"===e.type}function i(e){return"edge"===e.type}r.d(t,{Cy:()=>a,G4:()=>n,Wk:()=>i,c1:()=>o})},587:(e,t,r)=>{r.d(t,{Y:()=>o});var n=r(4552);function o(e,t,r){var o=[];if(t){var a=new Set;for(var i of e)"edge"===i.type&&i.source===t.source.id&&a.add(i.target);for(var c of e)"node"===c.type?a.has(c.id)&&o.push(c):o.push(c)}else switch(null==r?void 0:r.type){case"node":var d=new Map,l=new Set([r.id]);for(var s of e)"node"===s.type?d.set(s.id,s):"edge"===s.type?s.source===r.id?l.add(s.target):s.target===r.id?l.add(s.source):o.push(s):o.push(s);for(var[v,u]of d)l.has(v)||o.push(u);break;case"edge":for(var f of e)("edge"===f.type?(0,n.M)(f,r):"node"===f.type&&(f.id===r.source||f.id===r.target))||o.push(f);break;case"decorator":for(var h of e)"decorator"===h.type&&h.id===r.id||o.push(h)}return o}},6876:(e,t,r)=>{r.d(t,{Y:()=>o});var n=r(4552);function o(e,t){var{cells:r,activeTarget:o}=t,a=r.find((e=>(0,n.M)(e,o)));if(a)switch(e.key||e.keyCode||e.which){case"Backspace":case 8:case"Delete":case 46:return e.preventDefault(),e.stopPropagation(),{action:"delete-cell",cell:a}}}},7876:(e,t,r)=>{r.d(t,{S:()=>a});var n=r(4412),o=r(7181);function a(e,t){var{defaultNodeSize:r}=t;return(null!=e?e:[]).map((e=>{var t,a;return!(0,o.Cy)(e)||void 0!==(null===(t=e.view)||void 0===t?void 0:t.width)&&void 0!==(null===(a=e.view)||void 0===a?void 0:a.height)?e:(0,n.c)((0,n.c)({},e),{},{view:(0,n.c)({width:r[0],height:r[1]},e.view)})}))}},4552:(e,t,r)=>{function n(e,t){return e?!!t&&e.type===t.type&&("node"===e.type||"decorator"===e.type?e.id===t.id:e.source===t.source&&e.target===t.target):!t}r.d(t,{M:()=>n})},3788:(e,t,r)=>{r.d(t,{c:()=>o});var n=r(7181);function o(e,t){var{canvasWidth:r,canvasHeight:o,scaleRange:a}=t,i=1/0,c=1/0,d=-1/0,l=-1/0,s=!0;for(var v of e)if(!(0,n.Wk)(v)){s=!1;var{view:u}=v,f=u.x+u.width,h=u.y+u.height;u.x<i&&(i=u.x),f>d&&(d=f),u.y<c&&(c=u.y),h>l&&(l=h)}var m=d-i,w=l-c,p=a&&!s&&(m>r||w>o)?Math.max(Math.min(r/m,o/w,a[1]),a[0]):1;return{x:s?0:(r-m*p)/2-i*p,y:s?0:(o-w*p)/2-c*p,k:p}}},2872:(e,t,r)=>{r.d(t,{s:()=>i});var n=r(3576),o=r(7181),a=r(7876);function i(e){var{cells:t,previousCells:r,defaultNodeSize:i,canvasHeight:c,transform:d,reason:l,parent:s}=e,v=(0,a.S)(t,{defaultNodeSize:i}),u=[],f=new Map;for(var h of r)(0,o.G4)(h)&&h[n.m6]&&f.set(h.id,h);var m=new Map;for(var w of v)if((0,o.G4)(w)){m.set(w.id,w);var p=f.get(w.id);p&&(w.view.width=p.view.width,w.view.height=p.view.height,w[n.m6]=!0)}var g=!1;if("add-related-nodes"===l&&s){var y=new Set;for(var k of v)(0,o.Wk)(k)&&k.source===s&&k.target!==s&&y.add(k.target);var x=m.get(s);if(void 0!==(null==x?void 0:x.view.x)&&void 0!==x.view.y){g=!0;var E=[...y].map((e=>m.get(e))).filter(Boolean),C=void 0;for(var z of E)void 0!==z.view.x&&void 0!==z.view.y?(!C||z.view.x>C.view.x)&&z.view.y>x.view.y&&(C=z):u.push(z);if(u.length>0){var M,b;if(C)M=C.view.x+C.view.width+n.my,b=C.view.y;else{var R=u.reduce(((e,t)=>e+t.view.width+n.my),-n.my);M=x.view.x-R/2+x.view.width/2,b=x.view.y+x.view.height+n.my}for(var S of u)S.view.x=M,S.view.y=b,M+=S.view.width+n.my}}}if(!g){var L=i[0],T=i[1],N=[];for(var D of v)(0,o.G4)(D)&&(D.view.width>L&&(L=D.view.width),D.view.height>T&&(T=D.view.height),void 0===D.view.x||void 0===D.view.y?u.push(D):N.push(D.view));var B=L+n.my,W=T+n.my,A=new Set;for(var Y of N)for(var G=Math.floor((Y.x+d.x/d.k)/B),I=Math.floor((Y.y+d.y/d.k)/W),j=Math.floor((Y.x+d.x/d.k+Y.width)/B),X=Math.floor((Y.y+d.y/d.k+Y.height)/W),_=G;_<=j;_++)for(var O=I;O<=X;O++)A.add("".concat(_,",").concat(O));var P=B*d.k,H=W*d.k,U=Math.max(1,Math.floor(c/H)),q=0;for(var F of u){var J=void 0,K=void 0;do{J=Math.floor(q/U),K=q%U,q++}while(A.has("".concat(J,",").concat(K)));F.view.x=(J*P-d.x)/d.k+n.my/2,F.view.y=(K*H-d.y)/d.k+n.my/2}}return{cells:v,updated:u}}},3876:(e,t,r)=>{r.d(t,{M:()=>d});var n=r(4412),o=r(7181),a=r(3576);function i(e,t,r){var n=e.findLastIndex(r)+1;return[...e.slice(0,n),t,...e.slice(n)]}var c,d=(c={cells:(e,t)=>{switch(t.type){case"drop-node":return i(e,t.payload,(e=>!("decorator"===e.type&&"text"===e.decorator)));case"drop-decorator":return"text"===t.payload.decorator?[...e,t.payload]:i(e,t.payload,(e=>"decorator"===e.type&&"area"===e.decorator));case"add-nodes":var r=e.findLastIndex((e=>!("decorator"===e.type&&"text"===e.decorator)))+1;return[...e.slice(0,r),...t.payload,...e.slice(r)];case"add-edge":return i(e,t.payload,(e=>"edge"===e.type||"decorator"===e.type&&"area"===e.decorator));case"move-cell":var{type:c,id:d,x:l,y:s}=t.payload,v=e.findIndex((e=>e.type===c&&e.id===d));if(-1!==v){var u=e[v];return[...e.slice(0,v),(0,n.c)((0,n.c)({},u),{},{view:(0,n.c)((0,n.c)({},u.view),{},{x:l,y:s})}),...e.slice(v+1)]}return e;case"resize-cell":var{type:f,id:h,width:m,height:w}=t.payload,p=e.findIndex((e=>e.type===f&&e.id===h));if(-1!==p){var g=e[p];return[...e.slice(0,p),(0,n.c)((0,n.c)({},g),{},{view:(0,n.c)((0,n.c)({},g.view),{},{width:m,height:w})}),...e.slice(p+1)]}return e;case"update-cells":return t.payload;case"update-node-size":return e.map((e=>(0,o.G4)(e)&&e.id===t.payload.id?(0,n.c)((0,n.c)({},e),{},{[a.m6]:!0,view:t.payload.size?(0,n.c)((0,n.c)({},e.view),{},{width:t.payload.size[0],height:t.payload.size[1]}):e.view}):e))}return e}},(e,t)=>Object.fromEntries(Object.entries(c).map((r=>{var[n,o]=r;return[n,o(e[n],t)]}))))},7584:(e,t,r)=>{r.d(t,{c:()=>c});var n=r(8304),o=r.n(n),a=r(1849),i=r.n(a)()(o());i.push([e.id,"*{box-sizing:border-box}:host{display:block;position:relative;overflow:hidden}:host,\n.root{width:100%;height:100%}:host([hidden]){display:none}.root{opacity:0}.root.ready{opacity:1}.root:focus{outline:none}.decorator-area .area{fill:rgba(119,141,195,0.1);stroke:none;stroke-width:0}.node,\n.decorator-text{overflow:visible}.cell.active .decorator-area .area,\n.cell.active .line-active-bg{stroke:var(--palette-blue-5);stroke-dasharray:4;stroke-width:1}.cell{-webkit-user-select:none;-moz-user-select:none;user-select:none}.resize-handle{cursor:nwse-resize;opacity:0}.resize-handle rect{fill:transparent;stroke:none}.resize-handle path{fill:none;stroke:var(--palette-gray-5);stroke-width:1.5}.cell.active .decorator-area .resize-handle,\n.decorator-area:hover .resize-handle{opacity:1}.connect-line{pointer-events:none}.connect-line:not(.connecting){display:none}.line.dashed{stroke-dasharray:4}.cell.active .decorator-text .text-container{outline:1px dashed var(--palette-blue-5)}.decorator-text .text-container{width:-webkit-max-content;width:-moz-max-content;width:max-content;padding:0.5em}.decorator-text .text:focus{outline:none}.cell.faded{opacity:0.3}.cell .node{pointer-events:none}.cell .node > *{pointer-events:auto}",""]);const c=i.toString()}}]);
2
- //# sourceMappingURL=9560.315d614e.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"chunks/9560.315d614e.js","mappings":"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","sources":["webpack:///./src/draw-canvas/processors/findNode.ts","webpack:///./src/draw-canvas/EdgeComponent.tsx","webpack:///./src/draw-canvas/NodeComponent.tsx","webpack:///./src/draw-canvas/processors/cellToTarget.ts","webpack:///./src/draw-canvas/processors/handleMouseDown.ts","webpack:///./src/draw-canvas/decorators/DecoratorArea.tsx","webpack:///./src/draw-canvas/decorators/DecoratorText.tsx","webpack:///./src/draw-canvas/decorators/index.tsx","webpack:///./src/draw-canvas/CellComponent.tsx","webpack:///./src/draw-canvas/ConnectLineComponent.tsx","webpack:///./src/draw-canvas/constants.ts","webpack:///./src/draw-canvas/processors/asserts.ts","webpack:///./src/draw-canvas/processors/getUnrelatedCells.ts","webpack:///./src/draw-canvas/processors/handleKeyboard.ts","webpack:///./src/draw-canvas/processors/initializeCells.ts","webpack:///./src/draw-canvas/processors/sameTarget.ts","webpack:///./src/draw-canvas/processors/transformToCenter.ts","webpack:///./src/draw-canvas/processors/updateCells.ts","webpack:///./src/draw-canvas/reducers/cells.ts","webpack:///./src/draw-canvas/reducers/index.ts","webpack:///./src/draw-canvas/styles.shadow.css"],"sourcesContent":["import type { Cell, NodeCell, NodeId } from \"../interfaces\";\nimport { isNodeCell } from \"./asserts\";\n\nexport function findNode(cells: Cell[], id: NodeId): NodeCell | undefined {\n return cells.find((cell) => isNodeCell(cell) && cell.id === id) as\n | NodeCell\n | undefined;\n}\n","import React, { useMemo } from \"react\";\nimport { checkIfByTransform } from \"@next-core/runtime\";\nimport classNames from \"classnames\";\nimport type { Cell, EdgeCell, EdgeLineConf, NodeView } from \"./interfaces\";\nimport { getDirectLinePoints } from \"../diagram/lines/getDirectLinePoints\";\nimport type { NodeRect } from \"../diagram/interfaces\";\nimport { findNode } from \"./processors/findNode\";\n\nexport interface EdgeComponentProps {\n edge: EdgeCell;\n cells: Cell[];\n markerEnd: string;\n defaultEdgeLines?: EdgeLineConf[];\n}\n\nexport function EdgeComponent({\n edge,\n cells,\n markerEnd,\n defaultEdgeLines,\n}: EdgeComponentProps): JSX.Element | null {\n const sourceNode = useMemo(\n () => findNode(cells, edge.source),\n [cells, edge.source]\n );\n const targetNode = useMemo(\n () => findNode(cells, edge.target),\n [cells, edge.target]\n );\n const lineConf = useMemo(\n () => defaultEdgeLines?.find((item) => checkIfByTransform(item, { edge })),\n [defaultEdgeLines, edge]\n );\n\n const padding = 5;\n\n const line = useMemo(\n () =>\n sourceNode && targetNode\n ? getDirectLinePoints(\n nodeViewToNodeRect(sourceNode.view, padding),\n nodeViewToNodeRect(targetNode.view, padding)\n )\n : null,\n [sourceNode, targetNode]\n );\n\n if (!line) {\n // This happens when source or target is not found\n return null;\n }\n\n const d = `M${line[0].x} ${line[0].y}L${line[1].x} ${line[1].y}`;\n\n return (\n <>\n <path\n // This `path` is made for expanding interaction area of graph lines.\n d={d}\n fill=\"none\"\n stroke=\"transparent\"\n strokeWidth={16}\n />\n <path\n className={classNames(\"line\", { dashed: lineConf?.dashed })}\n d={d}\n fill=\"none\"\n stroke=\"gray\"\n markerEnd={`url(#${markerEnd})`}\n />\n <path className=\"line-active-bg\" d={d} fill=\"none\" />\n </>\n );\n}\n\nfunction nodeViewToNodeRect(view: NodeView, padding: number): NodeRect {\n return {\n x: view.x + view.width / 2,\n y: view.y + view.height / 2,\n width: view.width + padding,\n height: view.height + padding,\n };\n}\n","import React, {\n useCallback,\n useEffect,\n useMemo,\n useRef,\n useState,\n} from \"react\";\nimport { ReactUseBrick } from \"@next-core/react-runtime\";\nimport { checkIfByTransform } from \"@next-core/runtime\";\nimport { isEqual } from \"lodash\";\nimport ResizeObserver from \"resize-observer-polyfill\";\nimport type { NodeBrickCell, NodeBrickConf, NodeCell } from \"./interfaces\";\nimport type { SizeTuple } from \"../diagram/interfaces\";\n\nexport interface NodeComponentProps {\n node: NodeCell;\n defaultNodeBricks?: NodeBrickConf[];\n onResize(id: string, size: SizeTuple | null): void;\n}\n\nexport function NodeComponent({\n node,\n defaultNodeBricks,\n onResize,\n}: NodeComponentProps): JSX.Element | null {\n const memoizedData = useDeepMemo({ node: { id: node.id, data: node.data } });\n const specifiedUseBrick = (node as NodeBrickCell).useBrick;\n const observerRef = useRef<ResizeObserver | null>(null);\n\n const useBrick = useMemo(() => {\n return (\n specifiedUseBrick ??\n defaultNodeBricks?.find((item) => checkIfByTransform(item, memoizedData))\n ?.useBrick\n );\n }, [defaultNodeBricks, specifiedUseBrick, memoizedData]);\n\n const refCallback = useCallback(\n (element: HTMLElement | null) => {\n const prevObserver = observerRef.current;\n if (prevObserver) {\n prevObserver.disconnect();\n observerRef.current = null;\n }\n if (element) {\n // Todo: correctly wait for `useBrick` in v3 to be rendered (after layout)\n // Wait a macro task to let `useBrick` to be rendered.\n setTimeout(() => {\n const observer = new ResizeObserver(() => {\n onResize(node.id, [element.clientWidth, element.clientHeight]);\n });\n observer.observe(element);\n observerRef.current = observer;\n });\n } else {\n onResize(node.id, null);\n }\n },\n [node.id, onResize]\n );\n\n return useBrick ? (\n <foreignObject\n // Make a large size to avoid the brick inside to be clipped by the foreignObject.\n width={9999}\n height={9999}\n className=\"node\"\n >\n {useBrick && (\n <ReactUseBrick\n useBrick={useBrick}\n data={memoizedData}\n refCallback={refCallback}\n />\n )}\n </foreignObject>\n ) : null;\n}\n\nfunction useDeepMemo<T>(value: T): T {\n const [memoizedValue, setMemoizedValue] = useState(value);\n\n useEffect(() => {\n setMemoizedValue((prev) => (isEqual(prev, value) ? prev : value));\n }, [value]);\n\n return memoizedValue;\n}\n","import { pick } from \"lodash\";\nimport type { ActiveTarget, Cell } from \"../interfaces\";\n\nexport function cellToTarget(cell: Cell): ActiveTarget {\n return cell.type === \"edge\"\n ? pick(cell, [\"type\", \"source\", \"target\", \"data\"])\n : pick(cell, [\"type\", \"id\", \"data\"]);\n}\n","import type { PositionTuple } from \"../../diagram/interfaces\";\nimport type { ActiveTarget, Cell } from \"../interfaces\";\nimport type {\n MoveCellPayload,\n ResizeCellPayload,\n} from \"../reducers/interfaces\";\nimport { cellToTarget } from \"./cellToTarget\";\n\nexport function handleMouseDown(\n event: MouseEvent,\n {\n action,\n cell,\n scale,\n onCellMoving,\n onCellMoved,\n onCellResizing,\n onCellResized,\n onSwitchActiveTarget,\n }: {\n action: \"move\" | \"resize\";\n cell: Cell;\n scale: number;\n onCellMoving?(info: MoveCellPayload): void;\n onCellMoved?(info: MoveCellPayload): void;\n onCellResizing?(info: ResizeCellPayload): void;\n onCellResized?(info: ResizeCellPayload): void;\n onSwitchActiveTarget(activeTarget: ActiveTarget | null): void;\n }\n) {\n event.stopPropagation();\n // Drag node\n onSwitchActiveTarget(cellToTarget(cell));\n\n if (cell.type === \"edge\") {\n return;\n }\n\n const from: PositionTuple = [event.clientX, event.clientY];\n const original =\n action === \"move\"\n ? [cell.view.x, cell.view.y]\n : [cell.view.width, cell.view.height];\n\n function getMovement(e: MouseEvent): PositionTuple {\n return [(e.clientX - from[0]) / scale, (e.clientY - from[1]) / scale];\n }\n\n let moved = false;\n\n const handleMove = (e: MouseEvent, finished?: boolean) => {\n // Respect the scale\n const movement = getMovement(e);\n if (!moved) {\n moved = movement[0] ** 2 + movement[1] ** 2 >= 9;\n }\n // const [x, y] = getNewPosition(movement);\n // adjustCellPosition(x, y);\n if (moved) {\n if (action === \"move\") {\n (finished ? onCellMoved : onCellMoving)?.({\n type: cell.type,\n id: cell.id,\n x: original[0] + movement[0],\n y: original[1] + movement[1],\n });\n } else {\n (finished ? onCellResized : onCellResizing)?.({\n type: cell.type,\n id: cell.id,\n width: original[0] + movement[0],\n height: original[1] + movement[1],\n });\n }\n }\n };\n\n const onMouseMove = (e: MouseEvent) => {\n handleMove(e);\n };\n const onMouseUp = (e: MouseEvent) => {\n handleMove(e, true);\n moved = false;\n document.removeEventListener(\"mousemove\", onMouseMove);\n document.removeEventListener(\"mouseup\", onMouseUp);\n };\n document.addEventListener(\"mousemove\", onMouseMove);\n document.addEventListener(\"mouseup\", onMouseUp);\n}\n","import React, { useEffect } from \"react\";\nimport type { BasicDecoratorProps } from \"../interfaces\";\nimport { handleMouseDown } from \"../processors/handleMouseDown\";\n\nexport function DecoratorArea({\n cell,\n transform,\n onCellResizing,\n onCellResized,\n onSwitchActiveTarget,\n}: BasicDecoratorProps): JSX.Element {\n const resizeHandleRef = React.useRef<SVGGElement>(null);\n\n useEffect(() => {\n const resizeHandle = resizeHandleRef.current;\n const onMouseDown = (event: MouseEvent) => {\n handleMouseDown(event, {\n action: \"resize\",\n cell,\n scale: transform.k,\n onCellResizing,\n onCellResized,\n onSwitchActiveTarget,\n });\n };\n resizeHandle?.addEventListener(\"mousedown\", onMouseDown);\n return () => {\n resizeHandle?.removeEventListener(\"mousedown\", onMouseDown);\n };\n }, [cell, onCellResized, onCellResizing, onSwitchActiveTarget, transform.k]);\n\n return (\n <g className=\"decorator-area\">\n <rect\n // x={cell.view.x}\n // y={cell.view.y}\n width={cell.view.width}\n height={cell.view.height}\n className=\"area\"\n />\n <g\n ref={resizeHandleRef}\n className=\"resize-handle\"\n transform={`translate(${cell.view.width - 20} ${cell.view.height - 20})`}\n >\n <rect width={20} height={20} />\n <path d=\"M10 18L18 10 M15 18L18 15\" />\n </g>\n </g>\n );\n}\n","import React, { useCallback, useEffect, useRef, useState } from \"react\";\nimport type { BasicDecoratorProps } from \"../interfaces\";\nimport classNames from \"classnames\";\n\nexport type DecoratorTextProps = Pick<\n BasicDecoratorProps,\n \"cell\" | \"onDecoratorTextEditing\" | \"onDecoratorTextChange\"\n>;\n\nexport function DecoratorText({\n cell,\n onDecoratorTextEditing,\n onDecoratorTextChange,\n}: DecoratorTextProps): JSX.Element {\n const label = cell.view.text ?? \"\";\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 ref = useRef<HTMLDivElement>(null);\n\n const handleEnableEdit = useCallback((e: React.MouseEvent) => {\n e.preventDefault();\n e.stopPropagation();\n setEditingLabel(true);\n }, []);\n\n useEffect(() => {\n const element = ref.current;\n if (element && element.textContent !== currentLabel) {\n element.textContent = currentLabel;\n }\n }, [currentLabel]);\n\n useEffect(() => {\n if (editingLabel && ref.current) {\n ref.current.focus();\n selectAllText(ref.current);\n }\n onDecoratorTextEditing({ id: cell.id, editing: editingLabel });\n }, [cell.id, editingLabel, onDecoratorTextEditing]);\n\n useEffect(() => {\n if (editingLabelInitialized.current) {\n onDecoratorTextEditing?.({ id: cell.id, editing: editingLabel });\n } else {\n editingLabelInitialized.current = true;\n }\n }, [cell.id, editingLabel, onDecoratorTextEditing]);\n\n const handleInput = useCallback((event: React.FormEvent<HTMLDivElement>) => {\n setCurrentLabel((event.target as HTMLDivElement).textContent!);\n }, []);\n\n const handleBlur = useCallback(() => {\n setEditingLabel(false);\n setShouldEmitLabelChange(true);\n }, []);\n\n useEffect(() => {\n if (shouldEmitLabelChange) {\n onDecoratorTextChange?.({\n id: cell.id,\n view: { ...cell.view, text: currentLabel },\n });\n setShouldEmitLabelChange(false);\n }\n }, [cell, currentLabel, onDecoratorTextChange, shouldEmitLabelChange]);\n\n return (\n <foreignObject className=\"decorator-text\">\n <div\n className={classNames(\"text-container\", { editing: editingLabel })}\n onDoubleClick={handleEnableEdit}\n >\n <div\n className=\"text\"\n contentEditable={editingLabel}\n ref={ref}\n onInput={handleInput}\n onBlur={handleBlur}\n />\n </div>\n </foreignObject>\n );\n}\n\nfunction selectAllText(element: HTMLElement) {\n const range = document.createRange();\n range.selectNodeContents(element);\n const selection = window.getSelection()!;\n selection.removeAllRanges();\n selection.addRange(range);\n}\n","import React from \"react\";\nimport type { BasicDecoratorProps } from \"../interfaces\";\nimport { DecoratorArea } from \"./DecoratorArea\";\nimport { DecoratorText } from \"./DecoratorText\";\n\nexport function DecoratorComponent({\n cell,\n transform,\n onCellResizing,\n onCellResized,\n onSwitchActiveTarget,\n onDecoratorTextEditing,\n onDecoratorTextChange,\n}: BasicDecoratorProps): JSX.Element | null {\n let SpecifiedComponent: (props: BasicDecoratorProps) => JSX.Element | null;\n\n switch (cell.decorator) {\n case \"area\":\n SpecifiedComponent = DecoratorArea;\n break;\n case \"text\":\n SpecifiedComponent = DecoratorText;\n break;\n // istanbul ignore next\n default:\n // eslint-disable-next-line no-console\n console.error(`Unknown decorator: ${cell.decorator}`);\n return null;\n }\n\n return (\n <SpecifiedComponent\n cell={cell}\n transform={transform}\n onCellResizing={onCellResizing}\n onCellResized={onCellResized}\n onSwitchActiveTarget={onSwitchActiveTarget}\n onDecoratorTextEditing={onDecoratorTextEditing}\n onDecoratorTextChange={onDecoratorTextChange}\n />\n );\n}\n","import React, { useCallback, useEffect, useMemo, useRef } from \"react\";\nimport classNames from \"classnames\";\nimport type {\n ActiveTarget,\n Cell,\n CellContextMenuDetail,\n DecoratorTextChangeDetail,\n EdgeLineConf,\n NodeBrickConf,\n} from \"./interfaces\";\nimport { isDecoratorCell, isEdgeCell, isNodeCell } from \"./processors/asserts\";\nimport { EdgeComponent } from \"./EdgeComponent\";\nimport { NodeComponent } from \"./NodeComponent\";\nimport { handleMouseDown } from \"./processors/handleMouseDown\";\nimport type { MoveCellPayload, ResizeCellPayload } from \"./reducers/interfaces\";\nimport { DecoratorComponent } from \"./decorators\";\nimport { cellToTarget } from \"./processors/cellToTarget\";\nimport type { SizeTuple, TransformLiteral } from \"../diagram/interfaces\";\nimport { sameTarget } from \"./processors/sameTarget\";\n\nexport interface CellComponentProps {\n cell: Cell;\n cells: Cell[];\n defaultNodeBricks?: NodeBrickConf[];\n defaultEdgeLines?: EdgeLineConf[];\n transform: TransformLiteral;\n markerEnd: string;\n active: boolean;\n unrelatedCells: Cell[];\n onCellMoving(info: MoveCellPayload): void;\n onCellMoved(info: MoveCellPayload): void;\n onCellResizing(info: ResizeCellPayload): void;\n onCellResized(info: ResizeCellPayload): void;\n onSwitchActiveTarget(target: ActiveTarget | null): void;\n onCellContextMenu(detail: CellContextMenuDetail): void;\n onDecoratorTextEditing(detail: { id: string; editing: boolean }): void;\n onDecoratorTextChange(detail: DecoratorTextChangeDetail): void;\n onNodeBrickResize(id: string, size: SizeTuple | null): void;\n}\n\nexport function CellComponent({\n cell,\n cells,\n defaultNodeBricks,\n defaultEdgeLines,\n markerEnd,\n active,\n transform,\n unrelatedCells,\n onCellMoving,\n onCellMoved,\n onCellResizing,\n onCellResized,\n onSwitchActiveTarget,\n onCellContextMenu,\n onDecoratorTextEditing,\n onDecoratorTextChange,\n onNodeBrickResize,\n}: CellComponentProps): JSX.Element | null {\n const gRef = useRef<SVGGElement>(null);\n\n const unrelated = useMemo(\n () => unrelatedCells.some((item) => sameTarget(item, cell)),\n [cell, unrelatedCells]\n );\n\n useEffect(() => {\n const g = gRef.current;\n const onMouseDown = (event: MouseEvent) => {\n handleMouseDown(event, {\n action: \"move\",\n cell,\n scale: transform.k,\n onCellMoving,\n onCellMoved,\n onSwitchActiveTarget,\n });\n };\n g?.addEventListener(\"mousedown\", onMouseDown);\n return () => {\n g?.removeEventListener(\"mousedown\", onMouseDown);\n };\n }, [cell, onCellMoved, onCellMoving, onSwitchActiveTarget, transform.k]);\n\n const handleContextMenu = useCallback(\n (event: React.MouseEvent<SVGGElement>) => {\n event.preventDefault();\n onSwitchActiveTarget(cellToTarget(cell));\n onCellContextMenu({\n cell,\n clientX: event.clientX,\n clientY: event.clientY,\n });\n },\n [cell, onCellContextMenu, onSwitchActiveTarget]\n );\n\n return (\n <g\n className={classNames(\"cell\", { active, faded: unrelated })}\n ref={gRef}\n transform={\n cell.type === \"edge\"\n ? undefined\n : `translate(${cell.view.x} ${cell.view.y})`\n }\n onContextMenu={handleContextMenu}\n >\n {isNodeCell(cell) ? (\n <NodeComponent\n node={cell}\n defaultNodeBricks={defaultNodeBricks}\n onResize={onNodeBrickResize}\n />\n ) : isEdgeCell(cell) ? (\n <EdgeComponent\n edge={cell}\n defaultEdgeLines={defaultEdgeLines}\n cells={cells}\n markerEnd={markerEnd}\n />\n ) : isDecoratorCell(cell) ? (\n <DecoratorComponent\n cell={cell}\n transform={transform}\n onCellResizing={onCellResizing}\n onCellResized={onCellResized}\n onSwitchActiveTarget={onSwitchActiveTarget}\n onDecoratorTextEditing={onDecoratorTextEditing}\n onDecoratorTextChange={onDecoratorTextChange}\n />\n ) : null}\n </g>\n );\n}\n","import React, { useEffect, useState } from \"react\";\nimport classNames from \"classnames\";\nimport type { ConnectLineState } from \"./interfaces\";\nimport type { PositionTuple, TransformLiteral } from \"../diagram/interfaces\";\n\nexport interface ConnectLineComponentProps {\n connectLineState: ConnectLineState | null;\n transform: TransformLiteral;\n markerEnd: string;\n onConnect(state: ConnectLineState, to: PositionTuple): void;\n}\n\nexport function ConnectLineComponent({\n connectLineState,\n transform,\n markerEnd,\n onConnect,\n}: ConnectLineComponentProps): JSX.Element {\n const [connectLineTo, setConnectLineTo] = useState<PositionTuple | null>(\n null\n );\n\n useEffect(() => {\n if (connectLineState) {\n setConnectLineTo(connectLineState.from);\n }\n }, [connectLineState]);\n\n useEffect(() => {\n if (connectLineState) {\n const onMouseMove = (e: MouseEvent) => {\n // Set connect line to based on the mouse position and the transform\n setConnectLineTo([\n (e.clientX - transform.x - connectLineState.offset[0]) / transform.k,\n (e.clientY - transform.y - connectLineState.offset[1]) / transform.k,\n ]);\n };\n const onMouseDown = (e: MouseEvent) => {\n e.stopPropagation();\n };\n const onClick = (e: MouseEvent) => {\n e.stopPropagation();\n // eslint-disable-next-line @typescript-eslint/no-use-before-define\n reset();\n onConnect(connectLineState, [\n (e.clientX - transform.x - connectLineState.offset[0]) / transform.k,\n (e.clientY - transform.y - connectLineState.offset[1]) / transform.k,\n ]);\n };\n const reset = () => {\n document.removeEventListener(\"mousemove\", onMouseMove);\n document.removeEventListener(\"mousedown\", onMouseDown, {\n capture: true,\n });\n document.removeEventListener(\"click\", onClick, { capture: true });\n setConnectLineTo(null);\n };\n document.addEventListener(\"mousemove\", onMouseMove);\n document.addEventListener(\"mousedown\", onMouseDown, { capture: true });\n document.addEventListener(\"click\", onClick, { capture: true });\n\n return reset;\n }\n }, [connectLineState, onConnect, transform]);\n\n return (\n <path\n className={classNames(\"connect-line\", {\n connecting:\n !!connectLineState &&\n connectLineTo &&\n // Do not show when the distance of mouse move is less than 5px\n (connectLineTo[0] - connectLineState.from[0]) ** 2 +\n (connectLineTo[1] - connectLineState.from[1]) ** 2 >\n 25,\n })}\n d={\n connectLineState && connectLineTo\n ? `M${connectLineState.from.join(\" \")}L${connectLineTo.join(\" \")}`\n : \"\"\n }\n fill=\"none\"\n stroke=\"gray\"\n strokeWidth={1}\n markerEnd={`url(#${markerEnd})`}\n />\n );\n}\n","export const SYMBOL_FOR_SIZE_INITIALIZED = Symbol.for(\"size-initialized\");\nexport const DEFAULT_NODE_SIZE = 20;\nexport const DEFAULT_NODE_GAP = 36;\nexport const DEFAULT_AREA_WIDTH = 100;\nexport const DEFAULT_AREA_HEIGHT = 60;\nexport const DEFAULT_SCALE_RANGE_MIN = 0.5;\nexport const DEFAULT_SCALE_RANGE_MAX = 2;\n","import type {\n Cell,\n DecoratorCell,\n EdgeCell,\n InitialCell,\n InitialNodeCell,\n NodeCell,\n} from \"../interfaces\";\n\nexport function isNodeCell(cell: Cell): cell is NodeCell {\n return cell.type === \"node\";\n}\n\nexport function isDecoratorCell(cell: Cell): cell is DecoratorCell {\n return cell.type === \"decorator\";\n}\n\nexport function isInitialNodeCell(cell: InitialCell): cell is InitialNodeCell {\n return cell.type === \"node\";\n}\n\nexport function isEdgeCell(cell: Cell): cell is EdgeCell {\n return cell.type === \"edge\";\n}\n","import type { ActiveTarget, Cell, ConnectLineState } from \"../interfaces\";\nimport { sameTarget } from \"./sameTarget\";\n\nexport function getUnrelatedCells(\n cells: Cell[],\n connectLineState: ConnectLineState | null,\n activeTarget: ActiveTarget | null\n): Cell[] {\n const unrelated: Cell[] = [];\n\n if (connectLineState) {\n const existedTargets = new Set<string>();\n for (const cell of cells) {\n if (cell.type === \"edge\" && cell.source === connectLineState.source.id) {\n existedTargets.add(cell.target);\n }\n }\n for (const cell of cells) {\n switch (cell.type) {\n case \"node\":\n if (existedTargets.has(cell.id)) {\n unrelated.push(cell);\n }\n break;\n default:\n unrelated.push(cell);\n }\n }\n } else {\n switch (activeTarget?.type) {\n case \"node\": {\n const nodesMap = new Map<string, Cell>();\n const relatedNodeIds = new Set<string>([activeTarget.id]);\n for (const cell of cells) {\n if (cell.type === \"node\") {\n nodesMap.set(cell.id, cell);\n } else if (cell.type === \"edge\") {\n if (cell.source === activeTarget.id) {\n relatedNodeIds.add(cell.target);\n } else if (cell.target === activeTarget.id) {\n relatedNodeIds.add(cell.source);\n } else {\n unrelated.push(cell);\n }\n } else {\n unrelated.push(cell);\n }\n }\n for (const [id, cell] of nodesMap) {\n if (!relatedNodeIds.has(id)) {\n unrelated.push(cell);\n }\n }\n break;\n }\n\n case \"edge\":\n for (const cell of cells) {\n if (\n !(cell.type === \"edge\"\n ? sameTarget(cell, activeTarget)\n : cell.type === \"node\" &&\n (cell.id === activeTarget.source ||\n cell.id === activeTarget.target))\n ) {\n unrelated.push(cell);\n }\n }\n break;\n\n case \"decorator\":\n for (const cell of cells) {\n if (cell.type !== \"decorator\" || cell.id !== activeTarget.id) {\n unrelated.push(cell);\n }\n }\n break;\n }\n }\n\n return unrelated;\n}\n","import type { ActiveTarget, Cell } from \"../interfaces\";\nimport { sameTarget } from \"./sameTarget\";\n\nexport type KeyboardAction = KeyboardActionDeleteCell;\n\nexport interface KeyboardActionDeleteCell {\n action: \"delete-cell\";\n cell: Cell;\n}\n\nexport function handleKeyboard(\n event: KeyboardEvent,\n {\n cells,\n activeTarget,\n }: {\n cells: Cell[];\n activeTarget: ActiveTarget | null | undefined;\n }\n): KeyboardAction | undefined {\n const activeCell = cells.find((cell) => sameTarget(cell, activeTarget));\n\n if (!activeCell) {\n return;\n }\n\n const key =\n event.key ||\n /* istanbul ignore next: compatibility */ event.keyCode ||\n /* istanbul ignore next: compatibility */ event.which;\n\n switch (key) {\n case \"Backspace\":\n case 8:\n case \"Delete\":\n case 46: {\n event.preventDefault();\n event.stopPropagation();\n return {\n action: \"delete-cell\",\n cell: activeCell,\n };\n }\n }\n}\n","import type { SizeTuple } from \"../../diagram/interfaces\";\nimport type { Cell, InitialCell, NodeCell } from \"../interfaces\";\nimport { isInitialNodeCell } from \"./asserts\";\n\nexport function initializeCells(\n initialCells: InitialCell[] | undefined,\n {\n defaultNodeSize,\n }: {\n defaultNodeSize: SizeTuple;\n }\n): Cell[] {\n const originalCells = initialCells ?? [];\n const finalCells: Cell[] = originalCells.map<Cell>((cell) => {\n if (\n !isInitialNodeCell(cell) ||\n (cell.view?.width !== undefined && cell.view?.height !== undefined)\n ) {\n return cell as NodeCell;\n }\n return {\n ...cell,\n view: {\n width: defaultNodeSize[0],\n height: defaultNodeSize[1],\n ...cell.view,\n },\n } as NodeCell;\n });\n return finalCells;\n}\n","import type {\n ActiveTarget,\n ActiveTargetOfEdge,\n ActiveTargetOfNode,\n} from \"../interfaces\";\n\nexport function sameTarget(\n a: ActiveTarget | null | undefined,\n b: ActiveTarget | null | undefined\n): boolean {\n return a\n ? !!b &&\n a.type === b.type &&\n (a.type === \"node\" || a.type === \"decorator\"\n ? a.id === (b as ActiveTargetOfNode).id\n : a.source === (b as ActiveTargetOfEdge).source &&\n a.target === (b as ActiveTargetOfEdge).target)\n : !b;\n}\n","import type { TransformLiteral } from \"../../diagram/interfaces\";\nimport type { Cell } from \"../interfaces\";\nimport { isEdgeCell } from \"./asserts\";\n\nexport interface TransformToCenterOptions {\n canvasWidth: number;\n canvasHeight: number;\n scaleRange?: [min: number, max: number];\n}\n\nexport function transformToCenter(\n cells: Cell[],\n { canvasWidth, canvasHeight, scaleRange }: TransformToCenterOptions\n): TransformLiteral {\n let left = Infinity;\n let top = Infinity;\n let right = -Infinity;\n let bottom = -Infinity;\n let empty = true;\n for (const cell of cells) {\n if (!isEdgeCell(cell)) {\n empty = false;\n const { view } = cell;\n const r = view.x + view.width;\n const b = view.y + view.height;\n if (view.x < left) {\n left = view.x;\n }\n if (r > right) {\n right = r;\n }\n if (view.y < top) {\n top = view.y;\n }\n if (b > bottom) {\n bottom = b;\n }\n }\n }\n\n const width = right - left;\n const height = bottom - top;\n\n const scale =\n scaleRange && !empty && (width > canvasWidth || height > canvasHeight)\n ? Math.max(\n Math.min(canvasWidth / width, canvasHeight / height, scaleRange[1]),\n scaleRange[0]\n )\n : 1;\n\n const x = empty ? 0 : (canvasWidth - width * scale) / 2 - left * scale;\n const y = empty ? 0 : (canvasHeight - height * scale) / 2 - top * scale;\n\n return { x, y, k: scale };\n}\n","import type { SizeTuple, TransformLiteral } from \"../../diagram/interfaces\";\nimport { DEFAULT_NODE_GAP, SYMBOL_FOR_SIZE_INITIALIZED } from \"../constants\";\nimport type {\n Cell,\n InitialCell,\n NodeCell,\n NodeId,\n NodeView,\n} from \"../interfaces\";\nimport { isEdgeCell, isNodeCell } from \"./asserts\";\nimport { initializeCells } from \"./initializeCells\";\n\nexport function updateCells({\n cells,\n previousCells,\n defaultNodeSize,\n canvasHeight,\n transform,\n reason,\n parent,\n}: {\n cells: InitialCell[];\n previousCells: Cell[];\n defaultNodeSize: SizeTuple;\n canvasHeight: number;\n transform: TransformLiteral;\n reason?: \"add-related-nodes\";\n parent?: NodeId;\n}): {\n cells: Cell[];\n updated: Cell[];\n} {\n const newCells = initializeCells(cells, { defaultNodeSize });\n const updateCandidates: NodeCell[] = [];\n\n const previousSizeInitializedNodes = new Map<string, NodeCell>();\n for (const cell of previousCells) {\n if (isNodeCell(cell) && cell[SYMBOL_FOR_SIZE_INITIALIZED]) {\n previousSizeInitializedNodes.set(cell.id, cell);\n }\n }\n\n const nodesMap = new Map<string, NodeCell>();\n for (const cell of newCells) {\n if (isNodeCell(cell)) {\n nodesMap.set(cell.id, cell);\n const previousNode = previousSizeInitializedNodes.get(cell.id);\n if (previousNode) {\n cell.view.width = previousNode.view.width;\n cell.view.height = previousNode.view.height;\n cell[SYMBOL_FOR_SIZE_INITIALIZED] = true;\n }\n }\n }\n\n let handled = false;\n\n if (reason === \"add-related-nodes\" && parent) {\n // Place these unpositioned downstream nodes below the parent node, and\n // on the right side of the positioned siblings.\n const downstreamNodeIds = new Set<string>();\n for (const cell of newCells) {\n if (\n isEdgeCell(cell) &&\n cell.source === parent &&\n cell.target !== parent\n ) {\n downstreamNodeIds.add(cell.target);\n }\n }\n const parentNode = nodesMap.get(parent);\n if (parentNode?.view.x !== undefined && parentNode.view.y !== undefined) {\n handled = true;\n const downstreamNodes = [...downstreamNodeIds]\n .map((id) => nodesMap.get(id))\n .filter(Boolean) as NodeCell[];\n let rightMostNode: NodeCell | undefined = undefined;\n for (const node of downstreamNodes) {\n if (node.view.x !== undefined && node.view.y !== undefined) {\n // Find the rightmost node that is below the parent node.\n if (\n (!rightMostNode || node.view.x > rightMostNode.view.x) &&\n node.view.y > parentNode.view.y\n ) {\n rightMostNode = node;\n }\n } else {\n // Unpositioned nodes\n updateCandidates.push(node);\n }\n }\n if (updateCandidates.length > 0) {\n let nextX: number;\n let nextY: number;\n if (rightMostNode) {\n // Place unpositioned nodes on the right side of the rightmost positioned siblings.\n nextX =\n rightMostNode.view.x + rightMostNode.view.width + DEFAULT_NODE_GAP;\n nextY = rightMostNode.view.y;\n } else {\n // If there are no positioned siblings, just place them below the parent.\n const totalWidth = updateCandidates.reduce(\n (acc, node) => acc + node.view.width + DEFAULT_NODE_GAP,\n -DEFAULT_NODE_GAP\n );\n nextX =\n parentNode.view.x - totalWidth / 2 + parentNode.view.width / 2;\n nextY = parentNode.view.y + parentNode.view.height + DEFAULT_NODE_GAP;\n }\n for (const node of updateCandidates) {\n node.view.x = nextX;\n node.view.y = nextY;\n nextX += node.view.width + DEFAULT_NODE_GAP;\n }\n }\n }\n }\n\n if (!handled) {\n // By default, place unpositioned nodes in a grid.\n let maxWidth = defaultNodeSize[0];\n let maxHeight = defaultNodeSize[1];\n const occupiedViews: NodeView[] = [];\n for (const cell of newCells) {\n if (isNodeCell(cell)) {\n if (cell.view.width > maxWidth) {\n maxWidth = cell.view.width;\n }\n if (cell.view.height > maxHeight) {\n maxHeight = cell.view.height;\n }\n if (cell.view.x === undefined || cell.view.y === undefined) {\n updateCandidates.push(cell);\n } else {\n occupiedViews.push(cell.view);\n }\n }\n }\n\n const deltaX = maxWidth + DEFAULT_NODE_GAP;\n const deltaY = maxHeight + DEFAULT_NODE_GAP;\n\n const occupiedIndexes = new Set<string>();\n for (const view of occupiedViews) {\n const x0 = Math.floor((view.x + transform.x / transform.k) / deltaX);\n const y0 = Math.floor((view.y + transform.y / transform.k) / deltaY);\n const x1 = Math.floor(\n (view.x + transform.x / transform.k + view.width) / deltaX\n );\n const y1 = Math.floor(\n (view.y + transform.y / transform.k + view.height) / deltaY\n );\n\n for (let i = x0; i <= x1; i++) {\n for (let j = y0; j <= y1; j++) {\n occupiedIndexes.add(`${i},${j}`);\n }\n }\n }\n\n const scaledDeltaX = deltaX * transform.k;\n const scaledDeltaY = deltaY * transform.k;\n const rows = Math.max(1, Math.floor(canvasHeight / scaledDeltaY));\n let i = 0;\n for (const node of updateCandidates) {\n let xIndex: number;\n let yIndex: number;\n do {\n xIndex = Math.floor(i / rows);\n yIndex = i % rows;\n i++;\n } while (occupiedIndexes.has(`${xIndex},${yIndex}`));\n\n node.view.x =\n (xIndex * scaledDeltaX - transform.x) / transform.k +\n DEFAULT_NODE_GAP / 2;\n node.view.y =\n (yIndex * scaledDeltaY - transform.y) / transform.k +\n DEFAULT_NODE_GAP / 2;\n }\n }\n\n return { cells: newCells, updated: updateCandidates };\n}\n","import type { Reducer } from \"react\";\nimport type { DrawCanvasAction } from \"./interfaces\";\nimport type { Cell, NodeCell } from \"../interfaces\";\nimport { isNodeCell } from \"../processors/asserts\";\nimport { SYMBOL_FOR_SIZE_INITIALIZED } from \"../constants\";\n\nexport const cells: Reducer<Cell[], DrawCanvasAction> = (state, action) => {\n switch (action.type) {\n case \"drop-node\":\n return insertCellAfter(\n state,\n action.payload,\n (cell) => !(cell.type === \"decorator\" && cell.decorator === \"text\")\n );\n case \"drop-decorator\": {\n if (action.payload.decorator === \"text\") {\n return [...state, action.payload];\n }\n return insertCellAfter(\n state,\n action.payload,\n (cell) => cell.type === \"decorator\" && cell.decorator === \"area\"\n );\n }\n case \"add-nodes\": {\n const index =\n state.findLastIndex(\n (cell) => !(cell.type === \"decorator\" && cell.decorator === \"text\")\n ) + 1;\n return [\n ...state.slice(0, index),\n ...action.payload,\n ...state.slice(index),\n ];\n }\n case \"add-edge\":\n // Add the edge to just next to the previous last edge or area decorator.\n // If not found, append to the start.\n return insertCellAfter(\n state,\n action.payload,\n (cell) =>\n cell.type === \"edge\" ||\n (cell.type === \"decorator\" && cell.decorator === \"area\")\n );\n case \"move-cell\": {\n const { type, id, x, y } = action.payload;\n const index = state.findIndex(\n (cell) => cell.type === type && cell.id === id\n );\n if (index !== -1) {\n const node = state[index] as NodeCell;\n return [\n ...state.slice(0, index),\n { ...node, view: { ...node.view, x, y } },\n ...state.slice(index + 1),\n ];\n }\n return state;\n }\n case \"resize-cell\": {\n const { type, id, width, height } = action.payload;\n const index = state.findIndex(\n (cell) => cell.type === type && cell.id === id\n );\n if (index !== -1) {\n const node = state[index] as NodeCell;\n return [\n ...state.slice(0, index),\n { ...node, view: { ...node.view, width, height } },\n ...state.slice(index + 1),\n ];\n }\n return state;\n }\n case \"update-cells\":\n return action.payload;\n case \"update-node-size\":\n return state.map((cell) =>\n isNodeCell(cell) && cell.id === action.payload.id\n ? {\n ...cell,\n [SYMBOL_FOR_SIZE_INITIALIZED]: true,\n view: action.payload.size\n ? {\n ...cell.view,\n width: action.payload.size[0],\n height: action.payload.size[1],\n }\n : cell.view,\n }\n : cell\n );\n }\n return state;\n};\n\nfunction insertCellAfter(\n cells: Cell[],\n newCell: Cell,\n after: (cell: Cell) => boolean\n) {\n const index = cells.findLastIndex(after) + 1;\n return [...cells.slice(0, index), newCell, ...cells.slice(index)];\n}\n","import { Reducer } from \"react\";\nimport type { DrawCanvasAction, DrawCanvasState } from \"./interfaces\";\nimport { cells } from \"./cells\";\n\ntype ReducersMapObject<S, A> = {\n [K in keyof S]: Reducer<S[K], A>;\n};\n\nfunction combineReducers<S, A>(\n reducers: ReducersMapObject<S, A>\n): Reducer<S, A> {\n return ((state, action) =>\n Object.fromEntries(\n Object.entries<Reducer<any, A>>(reducers).map(([key, value]) => [\n key,\n value(state[key as keyof S], action),\n ])\n )) as Reducer<S, A>;\n}\n\nexport const rootReducer = combineReducers<DrawCanvasState, DrawCanvasAction>({\n cells,\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, `*{box-sizing:border-box}:host{display:block;position:relative;overflow:hidden}:host,\n.root{width:100%;height:100%}:host([hidden]){display:none}.root{opacity:0}.root.ready{opacity:1}.root:focus{outline:none}.decorator-area .area{fill:rgba(119,141,195,0.1);stroke:none;stroke-width:0}.node,\n.decorator-text{overflow:visible}.cell.active .decorator-area .area,\n.cell.active .line-active-bg{stroke:var(--palette-blue-5);stroke-dasharray:4;stroke-width:1}.cell{-webkit-user-select:none;-moz-user-select:none;user-select:none}.resize-handle{cursor:nwse-resize;opacity:0}.resize-handle rect{fill:transparent;stroke:none}.resize-handle path{fill:none;stroke:var(--palette-gray-5);stroke-width:1.5}.cell.active .decorator-area .resize-handle,\n.decorator-area:hover .resize-handle{opacity:1}.connect-line{pointer-events:none}.connect-line:not(.connecting){display:none}.line.dashed{stroke-dasharray:4}.cell.active .decorator-text .text-container{outline:1px dashed var(--palette-blue-5)}.decorator-text .text-container{width:-webkit-max-content;width:-moz-max-content;width:max-content;padding:0.5em}.decorator-text .text:focus{outline:none}.cell.faded{opacity:0.3}.cell .node{pointer-events:none}.cell .node > *{pointer-events:auto}`, \"\"]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___.toString();\n"],"names":["findNode","cells","id","find","cell","isNodeCell","EdgeComponent","_ref","edge","markerEnd","defaultEdgeLines","sourceNode","useMemo","source","targetNode","target","lineConf","item","checkIfByTransform","line","getDirectLinePoints","nodeViewToNodeRect","view","d","concat","x","y","React","fill","stroke","strokeWidth","className","classNames","dashed","padding","width","height","NodeComponent","node","defaultNodeBricks","onResize","memoizedData","value","memoizedValue","setMemoizedValue","useState","useEffect","prev","isEqual","useDeepMemo","data","specifiedUseBrick","useBrick","observerRef","useRef","_defaultNodeBricks$fi","refCallback","useCallback","element","prevObserver","current","disconnect","setTimeout","observer","ResizeObserver","clientWidth","clientHeight","observe","ReactUseBrick","cellToTarget","type","pick","handleMouseDown","event","action","scale","onCellMoving","onCellMoved","onCellResizing","onCellResized","onSwitchActiveTarget","stopPropagation","from","clientX","clientY","original","moved","handleMove","e","finished","_ref2","_ref3","movement","getMovement","onMouseMove","onMouseUp","document","removeEventListener","addEventListener","DecoratorArea","transform","resizeHandleRef","resizeHandle","onMouseDown","k","ref","DecoratorText","_cell$view$text","onDecoratorTextEditing","onDecoratorTextChange","label","text","currentLabel","setCurrentLabel","editingLabel","setEditingLabel","editingLabelInitialized","shouldEmitLabelChange","setShouldEmitLabelChange","handleEnableEdit","preventDefault","textContent","focus","range","createRange","selectNodeContents","selection","window","getSelection","removeAllRanges","addRange","selectAllText","editing","handleInput","handleBlur","_objectSpread","onDoubleClick","contentEditable","onInput","onBlur","DecoratorComponent","SpecifiedComponent","decorator","console","error","CellComponent","active","unrelatedCells","onCellContextMenu","onNodeBrickResize","gRef","unrelated","some","sameTarget","g","handleContextMenu","faded","undefined","onContextMenu","isEdgeCell","isDecoratorCell","ConnectLineComponent","connectLineState","onConnect","connectLineTo","setConnectLineTo","offset","onClick","reset","capture","connecting","join","SYMBOL_FOR_SIZE_INITIALIZED","Symbol","for","DEFAULT_NODE_SIZE","DEFAULT_NODE_GAP","DEFAULT_AREA_WIDTH","DEFAULT_AREA_HEIGHT","DEFAULT_SCALE_RANGE_MIN","DEFAULT_SCALE_RANGE_MAX","isInitialNodeCell","getUnrelatedCells","activeTarget","existedTargets","Set","add","has","push","nodesMap","Map","relatedNodeIds","set","handleKeyboard","activeCell","key","keyCode","which","initializeCells","initialCells","defaultNodeSize","map","_cell$view","_cell$view2","a","b","transformToCenter","canvasWidth","canvasHeight","scaleRange","left","Infinity","top","right","bottom","empty","r","Math","max","min","updateCells","previousCells","reason","parent","newCells","updateCandidates","previousSizeInitializedNodes","previousNode","get","handled","downstreamNodeIds","parentNode","downstreamNodes","filter","Boolean","rightMostNode","length","nextX","nextY","totalWidth","reduce","acc","maxWidth","maxHeight","occupiedViews","deltaX","deltaY","occupiedIndexes","x0","floor","y0","x1","y1","i","j","scaledDeltaX","scaledDeltaY","rows","xIndex","yIndex","updated","insertCellAfter","newCell","after","index","findLastIndex","slice","reducers","rootReducer","state","payload","findIndex","size","Object","fromEntries","entries","___CSS_LOADER_EXPORT___","module","toString"],"sourceRoot":""}
@@ -1,3 +0,0 @@
1
- /*! For license information please see editable-label.128ef04e.js.LICENSE.txt */
2
- (self.webpackChunk_next_bricks_diagram=self.webpackChunk_next_bricks_diagram||[]).push([[3716,856],{6268:(e,t,n)=>{"use strict";n.r(t),n.d(t,{EditableLabel:()=>w,EditableLabelComponent:()=>_,LegacyEditableLabelComponent:()=>Z});var r,a,i,l,o,c,s,u,f,h,p,b,d,v,g,y,m,w,x=n(123),E=n(592),k=n(5866),S=n(1412),C=n(8644),j=n(5600),M=n.n(j),z=n(7672),P=n(8160),T=(n(48),n(1252)),A=n.n(T),O=n(7518),{defineElement:W,property:L,event:D,method:R}=(0,z.createDecorators)(),_=(0,j.forwardRef)(Z);i=[W("diagram.editable-label",{styleTexts:[O.c]})],l=L(),c=L({render:!1}),u=D({type:"label.editing.change"}),b=D({type:"label.change"}),y=R();var N=new WeakMap,I=new WeakMap,B=new WeakMap,H=new WeakMap,K=new WeakMap,q=new WeakMap,F=new WeakMap,G=new WeakMap,J=new WeakMap;class Q extends P.ReactNextElement{constructor(){super(...arguments),(0,x.c)(this,F,{get:Y,set:X}),(0,x.c)(this,H,{get:V,set:U}),(0,x.c)(this,N,{writable:!0,value:(r(this),o(this))}),(0,x.c)(this,I,{writable:!0,value:s(this)}),(0,x.c)(this,B,{writable:!0,value:f(this)}),(0,x.c)(this,K,{writable:!0,value:e=>{(0,S.c)(this,H).emit(e)}}),(0,x.c)(this,q,{writable:!0,value:d(this)}),(0,x.c)(this,G,{writable:!0,value:e=>{(0,S.c)(this,F).emit(e)}}),(0,x.c)(this,J,{writable:!0,value:(0,j.createRef)()})}get label(){return(0,S.c)(this,N)}set label(e){(0,k.c)(this,N,e)}get type(){return(0,S.c)(this,I)}set type(e){(0,k.c)(this,I,e)}enableEditing(){var e;null===(e=(0,S.c)(this,J).current)||void 0===e||e.enableEditing()}render(){return M().createElement(_,{ref:(0,S.c)(this,J),label:this.label,onLabelEditingChange:(0,S.c)(this,K),onLabelChange:(0,S.c)(this,G)})}}function U(e){p(this,e)}function V(){return h(this)}function X(e){g(this,e)}function Y(){return v(this)}function Z(e,t){var{label:n,onLabelChange:r,onLabelEditingChange:a}=e,i=null!=n?n:"",[l,o]=(0,j.useState)(i),[c,s]=(0,j.useState)(!1),u=(0,j.useRef)(!1),[f,h]=(0,j.useState)(!1),p=(0,j.useRef)(null);(0,j.useImperativeHandle)(t,(()=>({enableEditing(){s(!0)}}))),(0,j.useEffect)((()=>{o(i)}),[i]);var b=(0,j.useCallback)((e=>{e.preventDefault(),e.stopPropagation(),s(!0)}),[]);(0,j.useEffect)((()=>{var e,t;c&&(null===(e=p.current)||void 0===e||e.focus({preventScroll:!0}),null===(t=p.current)||void 0===t||t.select())}),[c]),(0,j.useEffect)((()=>{u.current?null==a||a(c):u.current=!0}),[c,a]);var d=(0,j.useCallback)((e=>{o(e.target.value)}),[]),v=(0,j.useCallback)((e=>{var t,n=e.key||e.keyCode||e.which;"Enter"!==n&&13!==n||null===(t=p.current)||void 0===t||t.blur()}),[]),g=(0,j.useCallback)((()=>{s(!1),h(!0)}),[]);(0,j.useEffect)((()=>{f&&(null==r||r(l),h(!1))}),[l,r,f]);var y=(0,j.useCallback)((e=>{e.stopPropagation()}),[]);return M().createElement("div",{className:A()("label",{editing:c,empty:!l}),onDoubleClick:y,onMouseDown:y},M().createElement("input",{className:"label-input",value:l,ref:p,onChange:d,onKeyDown:v,onBlur:g}),M().createElement("div",{className:"label-text",onDoubleClick:b},l))}m=Q,({e:[o,s,f,h,p,d,v,g,r],c:[w,a]}=(0,C.c)(m,[[l,1,"label"],[c,1,"type"],[u,1,"labelEditingChange",e=>(0,S.c)(e,B),(e,t)=>(0,k.c)(e,B,t)],[b,1,"labelChange",e=>(0,S.c)(e,q),(e,t)=>(0,k.c)(e,q,t)],[y,2,"enableEditing"]],i,0,(e=>J.has((0,E.c)(e))),P.ReactNextElement)),a()},7518:(e,t,n)=>{"use strict";n.d(t,{c:()=>o});var r=n(8304),a=n.n(r),i=n(1849),l=n.n(i)()(a());l.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;-moz-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 o=l.toString()},1849: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,a,i){"string"==typeof e&&(e=[[null,e,void 0]]);var l={};if(r)for(var o=0;o<this.length;o++){var c=this[o][0];null!=c&&(l[c]=!0)}for(var s=0;s<e.length;s++){var u=[].concat(e[s]);r&&l[u[0]]||(void 0!==i&&(void 0===u[5]||(u[1]="@layer".concat(u[5].length>0?" ".concat(u[5]):""," {").concat(u[1],"}")),u[5]=i),n&&(u[2]?(u[1]="@media ".concat(u[2]," {").concat(u[1],"}"),u[2]=n):u[2]=n),a&&(u[4]?(u[1]="@supports (".concat(u[4],") {").concat(u[1],"}"),u[4]=a):u[4]="".concat(a)),t.push(u))}},t}},8304:e=>{"use strict";e.exports=function(e){return e[1]}},1252:(e,t)=>{var n;!function(){"use strict";var r={}.hasOwnProperty;function a(){for(var e="",t=0;t<arguments.length;t++){var n=arguments[t];n&&(e=l(e,i(n)))}return e}function i(e){if("string"==typeof e||"number"==typeof e)return e;if("object"!=typeof e)return"";if(Array.isArray(e))return a.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=l(t,n));return t}function l(e,t){return t?e?e+" "+t:e+t:e}e.exports?(a.default=a,e.exports=a):void 0===(n=function(){return a}.apply(t,[]))||(e.exports=n)}()},8644:(e,t,n)=>{"use strict";n.d(t,{c:()=>o});var r=n(5804),a=n(592);function i(e,t,n){"symbol"==(0,r.c)(t)&&(t=(t=t.description)?"["+t+"]":"");try{Object.defineProperty(e,"name",{configurable:!0,value:n?n+" "+t:t})}catch(e){}return e}var l=n(8404);function o(e,t,n,o,c,s){function u(e,t,n){return function(r,a){return n&&n(r),e[t].call(r,a)}}function f(e,t){for(var n=0;n<e.length;n++)e[n].call(t);return t}function h(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 p(e,t,n,a,l,o,c,s,f,p,b,d,v){function g(e){if(!v(e))throw new TypeError("Attempted to access private element on non-instance")}var y,m=t[0],w=t[3],x=!s;if(!x){n||Array.isArray(m)||(m=[m]);var E={},k=[],S=3===l?"get":4===l||d?"set":"value";p?(b||d?E={get:i((function(){return w(this)}),a,"get"),set:function(e){t[4](this,e)}}:E[S]=w,b||i(E[S],a,2===l?"":S)):b||(E=Object.getOwnPropertyDescriptor(e,a))}for(var C=e,j=m.length-1;j>=0;j-=n?2:1){var M=m[j],z=n?m[j-1]:void 0,P={},T={kind:["field","accessor","method","getter","setter","class"][l],name:a,metadata:o,addInitializer:function(e,t){if(e.v)throw new Error("attempted to call addInitializer after decoration was finished");h(t,"An initializer","be",!0),c.push(t)}.bind(null,P)};try{if(x)(y=h(M.call(z,C,T),"class decorators","return"))&&(C=y);else{var A,O;T.static=f,T.private=p,p?2===l?A=function(e){return g(e),E.value}:(l<4&&(A=u(E,"get",g)),3!==l&&(O=u(E,"set",g))):(A=function(e){return e[a]},(l<2||4===l)&&(O=function(e,t){e[a]=t}));var W=T.access={has:p?v.bind():function(e){return a in e}};if(A&&(W.get=A),O&&(W.set=O),C=M.call(z,d?{get:E.get,set:E.set}:E[S],T),d){if("object"==(0,r.c)(C)&&C)(y=h(C.get,"accessor.get"))&&(E.get=y),(y=h(C.set,"accessor.set"))&&(E.set=y),(y=h(C.init,"accessor.init"))&&k.push(y);else if(void 0!==C)throw new TypeError("accessor decorators must return an object with get, set, or init properties or void 0")}else h(C,(b?"field":"method")+" decorators","return")&&(b?k.push(C):E[S]=C)}}finally{P.v=!0}}return(b||d)&&s.push((function(e,t){for(var n=k.length-1;n>=0;n--)t=k[n].call(e,t);return t})),b||x||(p?d?s.push(u(E,"get"),u(E,"set")):s.push(2===l?E[S]:u.call.bind(E[S])):Object.defineProperty(e,a,E)),C}function b(e,t){return Object.defineProperty(e,Symbol.metadata||Symbol.for("Symbol.metadata"),{configurable:!0,enumerable:!0,value:t})}if(arguments.length>=6)var d=s[Symbol.metadata||Symbol.for("Symbol.metadata")];var v=Object.create(null==d?null:d),g=function(e,t,n,r){var i,o,c=[],s=function(t){return(0,a.c)(t)===e},u=new Map;function h(e){e&&c.push(f.bind(null,e))}for(var b=0;b<t.length;b++){var d=t[b];if(Array.isArray(d)){var v=d[1],g=d[2],y=d.length>3,m=16&v,w=!!(8&v),x=0==(v&=7),E=g+"/"+w;if(!x&&!y){var k=u.get(E);if(!0===k||3===k&&4!==v||4===k&&3!==v)throw new Error("Attempted to decorate a public method/accessor that has the same name as a previously decorated public method/accessor. This is not currently supported by the decorators plugin. Property name was: "+g);u.set(E,!(v>2)||v)}p(w?e:e.prototype,d,m,y?"#"+g:(0,l.c)(g),v,r,w?o=o||[]:i=i||[],c,w,y,x,1===v,w&&y?s:n)}}return h(i),h(o),c}(e,t,c,v);return n.length||b(e,v),{e:g,get c(){var t=[];return n.length&&[b(p(e,[n],o,e.name,5,v,t),v),f.bind(null,t,e)]}}}},592:(e,t,n)=>{"use strict";n.d(t,{c:()=>a});var r=n(5804);function a(e){if(Object(e)!==e)throw TypeError("right-hand side of 'in' should be an object, got "+(null!==e?(0,r.c)(e):"null"));return e}},9056:(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,{c:()=>r})},6672:(e,t,n)=>{"use strict";function r(e,t,n){if(!t.has(e))throw new TypeError("attempted to "+n+" private field on non-instance");return t.get(e)}n.d(t,{c:()=>r})},1412:(e,t,n)=>{"use strict";n.d(t,{c:()=>a});var r=n(6672);function a(e,t){return function(e,t){return t.get?t.get.call(e):t.value}(e,(0,r.c)(e,t,"get"))}},123:(e,t,n)=>{"use strict";n.d(t,{c:()=>a});var r=n(9056);function a(e,t,n){(0,r.c)(e,t),t.set(e,n)}},5866:(e,t,n)=>{"use strict";n.d(t,{c:()=>a});var r=n(6672);function a(e,t,n){return function(e,t,n){if(t.set)t.set.call(e,n);else{if(!t.writable)throw new TypeError("attempted to set read only private field");t.value=n}}(e,(0,r.c)(e,t,"set"),n),n}},8404:(e,t,n)=>{"use strict";n.d(t,{c:()=>a});var r=n(5804);function a(e){var t=function(e,t){if("object"!=(0,r.c)(e)||!e)return e;var n=e[Symbol.toPrimitive];if(void 0!==n){var a=n.call(e,"string");if("object"!=(0,r.c)(a))return a;throw new TypeError("@@toPrimitive must return a primitive value.")}return String(e)}(e);return"symbol"==(0,r.c)(t)?t:String(t)}},5804:(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,{c:()=>r})}}]);
3
- //# sourceMappingURL=editable-label.128ef04e.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"chunks/editable-label.128ef04e.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/applyDecs2305.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/classExtractFieldDescriptor.js","webpack:///../../node_modules/@babel/runtime/helpers/esm/classPrivateFieldGet.js","webpack:///../../node_modules/@babel/runtime/helpers/esm/classApplyDescriptorGet.js","webpack:///../../node_modules/@babel/runtime/helpers/esm/classPrivateFieldInitSpec.js","webpack:///../../node_modules/@babel/runtime/helpers/esm/classPrivateFieldSet.js","webpack:///../../node_modules/@babel/runtime/helpers/esm/classApplyDescriptorSet.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;-moz-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 applyDecs2305(e, t, r, n, o, a) {\n function i(e, t, r) {\n return function (n, o) {\n return r && r(n), e[t].call(n, o);\n };\n }\n function c(e, t) {\n for (var r = 0; r < e.length; r++) e[r].call(t);\n return t;\n }\n function s(e, t, r, n) {\n if (\"function\" != typeof e && (n || void 0 !== e)) throw new TypeError(t + \" must \" + (r || \"be\") + \" a function\" + (n ? \"\" : \" or undefined\"));\n return e;\n }\n function applyDec(e, t, r, n, o, a, c, u, l, f, p, d, h) {\n function m(e) {\n if (!h(e)) throw new TypeError(\"Attempted to access private element on non-instance\");\n }\n var y,\n v = t[0],\n g = t[3],\n b = !u;\n if (!b) {\n r || Array.isArray(v) || (v = [v]);\n var w = {},\n S = [],\n A = 3 === o ? \"get\" : 4 === o || d ? \"set\" : \"value\";\n f ? (p || d ? w = {\n get: setFunctionName(function () {\n return g(this);\n }, n, \"get\"),\n set: function set(e) {\n t[4](this, e);\n }\n } : w[A] = g, p || setFunctionName(w[A], n, 2 === o ? \"\" : A)) : p || (w = Object.getOwnPropertyDescriptor(e, n));\n }\n for (var P = e, j = v.length - 1; j >= 0; j -= r ? 2 : 1) {\n var D = v[j],\n E = r ? v[j - 1] : void 0,\n I = {},\n O = {\n kind: [\"field\", \"accessor\", \"method\", \"getter\", \"setter\", \"class\"][o],\n name: n,\n metadata: a,\n addInitializer: function (e, t) {\n if (e.v) throw new Error(\"attempted to call addInitializer after decoration was finished\");\n s(t, \"An initializer\", \"be\", !0), c.push(t);\n }.bind(null, I)\n };\n try {\n if (b) (y = s(D.call(E, P, O), \"class decorators\", \"return\")) && (P = y);else {\n var k, F;\n O[\"static\"] = l, O[\"private\"] = f, f ? 2 === o ? k = function k(e) {\n return m(e), w.value;\n } : (o < 4 && (k = i(w, \"get\", m)), 3 !== o && (F = i(w, \"set\", m))) : (k = function k(e) {\n return e[n];\n }, (o < 2 || 4 === o) && (F = function F(e, t) {\n e[n] = t;\n }));\n var N = O.access = {\n has: f ? h.bind() : function (e) {\n return n in e;\n }\n };\n if (k && (N.get = k), F && (N.set = F), P = D.call(E, d ? {\n get: w.get,\n set: w.set\n } : w[A], O), d) {\n if (\"object\" == _typeof(P) && P) (y = s(P.get, \"accessor.get\")) && (w.get = y), (y = s(P.set, \"accessor.set\")) && (w.set = y), (y = s(P.init, \"accessor.init\")) && S.push(y);else if (void 0 !== P) throw new TypeError(\"accessor decorators must return an object with get, set, or init properties or void 0\");\n } else s(P, (p ? \"field\" : \"method\") + \" decorators\", \"return\") && (p ? S.push(P) : w[A] = P);\n }\n } finally {\n I.v = !0;\n }\n }\n return (p || d) && u.push(function (e, t) {\n for (var r = S.length - 1; r >= 0; r--) t = S[r].call(e, t);\n return t;\n }), p || b || (f ? d ? u.push(i(w, \"get\"), i(w, \"set\")) : u.push(2 === o ? w[A] : i.call.bind(w[A])) : Object.defineProperty(e, n, w)), P;\n }\n function u(e, t) {\n return Object.defineProperty(e, Symbol.metadata || Symbol[\"for\"](\"Symbol.metadata\"), {\n configurable: !0,\n enumerable: !0,\n value: t\n });\n }\n if (arguments.length >= 6) var l = a[Symbol.metadata || Symbol[\"for\"](\"Symbol.metadata\")];\n var f = Object.create(null == l ? null : l),\n p = function (e, t, r, n) {\n var o,\n a,\n i = [],\n s = function s(t) {\n return checkInRHS(t) === e;\n },\n u = new Map();\n function l(e) {\n e && i.push(c.bind(null, e));\n }\n for (var f = 0; f < t.length; f++) {\n var p = t[f];\n if (Array.isArray(p)) {\n var d = p[1],\n h = p[2],\n m = p.length > 3,\n y = 16 & d,\n v = !!(8 & d),\n g = 0 == (d &= 7),\n b = h + \"/\" + v;\n if (!g && !m) {\n var w = u.get(b);\n if (!0 === w || 3 === w && 4 !== d || 4 === w && 3 !== d) throw new Error(\"Attempted to decorate a public method/accessor that has the same name as a previously decorated public method/accessor. This is not currently supported by the decorators plugin. Property name was: \" + h);\n u.set(b, !(d > 2) || d);\n }\n applyDec(v ? e : e.prototype, p, y, m ? \"#\" + h : toPropertyKey(h), d, n, v ? a = a || [] : o = o || [], i, v, m, g, 1 === d, v && m ? s : r);\n }\n }\n return l(o), l(a), i;\n }(e, t, o, f);\n return r.length || u(e, f), {\n e: p,\n get c() {\n var t = [];\n return r.length && [u(applyDec(e, [r], n, e.name, 5, f, t), f), c.bind(null, t, e)];\n }\n };\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}","export default function _classExtractFieldDescriptor(receiver, privateMap, action) {\n if (!privateMap.has(receiver)) {\n throw new TypeError(\"attempted to \" + action + \" private field on non-instance\");\n }\n return privateMap.get(receiver);\n}","import classApplyDescriptorGet from \"./classApplyDescriptorGet.js\";\nimport classExtractFieldDescriptor from \"./classExtractFieldDescriptor.js\";\nexport default function _classPrivateFieldGet(receiver, privateMap) {\n var descriptor = classExtractFieldDescriptor(receiver, privateMap, \"get\");\n return classApplyDescriptorGet(receiver, descriptor);\n}","export default function _classApplyDescriptorGet(receiver, descriptor) {\n if (descriptor.get) {\n return descriptor.get.call(receiver);\n }\n return descriptor.value;\n}","import checkPrivateRedeclaration from \"./checkPrivateRedeclaration.js\";\nexport default function _classPrivateFieldInitSpec(obj, privateMap, value) {\n checkPrivateRedeclaration(obj, privateMap);\n privateMap.set(obj, value);\n}","import classApplyDescriptorSet from \"./classApplyDescriptorSet.js\";\nimport classExtractFieldDescriptor from \"./classExtractFieldDescriptor.js\";\nexport default function _classPrivateFieldSet(receiver, privateMap, value) {\n var descriptor = classExtractFieldDescriptor(receiver, privateMap, \"set\");\n classApplyDescriptorSet(receiver, descriptor, value);\n return value;\n}","export default function _classApplyDescriptorSet(receiver, descriptor, value) {\n if (descriptor.set) {\n descriptor.set.call(receiver, value);\n } else {\n if (!descriptor.writable) {\n throw new TypeError(\"attempted to set read only private field\");\n }\n descriptor.value = value;\n }\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 : String(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":["_EditableLabel","defineElement","property","event","method","createDecorators","EditableLabelComponent","forwardRef","LegacyEditableLabelComponent","_classDecs","styleTexts","styleText","_dec","_dec2","render","_dec3","type","_dec4","_dec5","_A","WeakMap","_B","_C","_labelEditingChange","_handleLabelEditingChange","_D","_labelChange","_handleLabelChange","_editableLabelRef","EditableLabel","ReactNextElement","constructor","arguments","_classPrivateFieldInitSpec","get","_get_labelChange2","set","_set_labelChange2","_get_labelEditingChange2","_set_labelEditingChange2","writable","value","_initProto","_init_label","_init_type","_init_labelEditingChange","_classPrivateFieldGet","this","emit","_init_labelChange","createRef","label","v","_classPrivateFieldSet","enableEditing","_classPrivateFieldGet2","current","React","ref","onLabelEditingChange","onLabelChange","_set_labelEditingChange","_get_labelEditingChange","_set_labelChange","_get_labelChange","_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","_labelInputRef$curren3","key","keyCode","which","blur","handleInputBlur","className","classNames","editing","empty","onDoubleClick","onMouseDown","onChange","onKeyDown","onBlur","_EditableLabel2","c","_initClass","_applyDecs","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","applyDecs2305","r","a","s","TypeError","applyDec","u","l","f","p","d","h","m","y","g","b","w","S","A","getOwnPropertyDescriptor","P","j","D","E","I","O","kind","name","metadata","addInitializer","Error","bind","F","N","access","init","Symbol","enumerable","create","checkInRHS","Map","toPropertyKey","_checkPrivateRedeclaration","obj","privateCollection","_classExtractFieldDescriptor","receiver","privateMap","action","descriptor","classExtractFieldDescriptor","toPrimitive","String","_typeof","iterator"],"sourceRoot":""}
@@ -1,2 +0,0 @@
1
- "use strict";(self.webpackChunk_next_bricks_diagram=self.webpackChunk_next_bricks_diagram||[]).push([[5436],{4364:(e,t,a)=>{a.r(t),a.d(t,{EoDiagram:()=>le,EoDiagramComponent:()=>Ze,LegacyEoDiagramComponent:()=>Kt});var n,i,s,l,r,c,o,u,d,h,v,g,m,p,b,k,w,f,y,M,E,W,L,N,R,C,x,S,T,z,D,A,B,O,H,I,K,P,V,_,Y,X,Z,$,q,U,j,F,G,J,Q,ee,te,ae,ne,ie,se,le,re=a(123),ce=a(592),oe=a(5866),ue=a(1412),de=a(8644),he=a(5600),ve=a.n(he),ge=a(7672),me=a(8160),pe=(a(48),a(5248)),be=a(1920),ke=a(1252),we=a.n(ke),fe=a(7568),ye=a(2504),Me=a(8996),Ee=a(9140),We=a(3600),Le=a(3904),Ne=a(4378),Re=a(8276),Ce=a(2092),xe=a(8752),Se=a(4092),Te=a(3784),ze=a(3732),De=a(636),Ae=a(6932),Be=a(4580),Oe=a(9900),He=a(6152),Ie=a(3888),Ke=a(4588),Pe=a(3256),{defineElement:Ve,property:_e,event:Ye,method:Xe}=(0,ge.createDecorators)(),Ze=(0,he.forwardRef)(Kt);s=[Ve("eo-diagram",{styleTexts:[He.c]})],l=_e({type:String}),c=_e({attribute:!1}),u=_e({attribute:!1}),h=_e({attribute:!1}),g=_e({attribute:!1}),p=_e({attribute:!1}),k=_e({attribute:!1}),f=_e({type:Boolean}),M=_e({attribute:!1}),W=_e({attribute:!1}),N=_e({type:Boolean}),C=_e({type:Boolean}),S=_e({type:Boolean}),z=_e({attribute:!1}),A=Ye({type:"activeTarget.change"}),I=Ye({type:"node.delete"}),_=Ye({type:"edge.delete"}),$=Ye({type:"line.click"}),F=Ye({type:"line.dblclick"}),ee=Ye({type:"nodes.connect"}),ie=Xe();var $e=new WeakMap,qe=new WeakMap,Ue=new WeakMap,je=new WeakMap,Fe=new WeakMap,Ge=new WeakMap,Je=new WeakMap,Qe=new WeakMap,et=new WeakMap,tt=new WeakMap,at=new WeakMap,nt=new WeakMap,it=new WeakMap,st=new WeakMap,lt=new WeakMap,rt=new WeakMap,ct=new WeakMap,ot=new WeakMap,ut=new WeakMap,dt=new WeakMap,ht=new WeakMap,vt=new WeakMap,gt=new WeakMap,mt=new WeakMap,pt=new WeakMap,bt=new WeakMap,kt=new WeakMap,wt=new WeakMap,ft=new WeakMap,yt=new WeakMap,Mt=new WeakMap,Et=new WeakMap,Wt=new WeakMap,Lt=new WeakMap;class Nt extends me.ReactNextElement{constructor(){super(...arguments),(0,re.c)(this,Mt,{get:It,set:Ht}),(0,re.c)(this,wt,{get:Ot,set:Bt}),(0,re.c)(this,pt,{get:At,set:Dt}),(0,re.c)(this,vt,{get:zt,set:Tt}),(0,re.c)(this,ut,{get:St,set:xt}),(0,re.c)(this,rt,{get:Ct,set:Rt}),(0,re.c)(this,$e,{writable:!0,value:(n(this),r(this))}),(0,re.c)(this,qe,{writable:!0,value:o(this)}),(0,re.c)(this,Ue,{writable:!0,value:d(this)}),(0,re.c)(this,je,{writable:!0,value:v(this)}),(0,re.c)(this,Fe,{writable:!0,value:m(this)}),(0,re.c)(this,Ge,{writable:!0,value:b(this)}),(0,re.c)(this,Je,{writable:!0,value:w(this)}),(0,re.c)(this,Qe,{writable:!0,value:y(this)}),(0,re.c)(this,et,{writable:!0,value:E(this)}),(0,re.c)(this,tt,{writable:!0,value:L(this)}),(0,re.c)(this,at,{writable:!0,value:R(this,!0)}),(0,re.c)(this,nt,{writable:!0,value:x(this,!0)}),(0,re.c)(this,it,{writable:!0,value:T(this,!0)}),(0,re.c)(this,st,{writable:!0,value:D(this)}),(0,re.c)(this,lt,{writable:!0,value:B(this)}),(0,re.c)(this,ct,{writable:!0,value:e=>{(0,ue.c)(this,rt).emit(e)}}),(0,re.c)(this,ot,{writable:!0,value:K(this)}),(0,re.c)(this,dt,{writable:!0,value:e=>{(0,ue.c)(this,ut).emit(e)}}),(0,re.c)(this,ht,{writable:!0,value:Y(this)}),(0,re.c)(this,gt,{writable:!0,value:e=>{(0,ue.c)(this,vt).emit(e)}}),(0,re.c)(this,mt,{writable:!0,value:q(this)}),(0,re.c)(this,bt,{writable:!0,value:e=>{(0,ue.c)(this,pt).emit(e)}}),(0,re.c)(this,kt,{writable:!0,value:G(this)}),(0,re.c)(this,ft,{writable:!0,value:e=>{(0,ue.c)(this,wt).emit(e)}}),(0,re.c)(this,yt,{writable:!0,value:te(this)}),(0,re.c)(this,Et,{writable:!0,value:e=>{(0,ue.c)(this,Mt).emit(e)}}),(0,re.c)(this,Wt,{writable:!0,value:e=>{(0,Ke.M)(e,this.activeTarget)||(this.activeTarget=e)}}),(0,re.c)(this,Lt,{writable:!0,value:(0,he.createRef)()})}get layout(){return(0,ue.c)(this,$e)}set layout(e){(0,oe.c)(this,$e,e)}get nodes(){return(0,ue.c)(this,qe)}set nodes(e){(0,oe.c)(this,qe,e)}get edges(){return(0,ue.c)(this,Ue)}set edges(e){(0,oe.c)(this,Ue,e)}get nodeBricks(){return(0,ue.c)(this,je)}set nodeBricks(e){(0,oe.c)(this,je,e)}get lines(){return(0,ue.c)(this,Fe)}set lines(e){(0,oe.c)(this,Fe,e)}get layoutOptions(){return(0,ue.c)(this,Ge)}set layoutOptions(e){(0,oe.c)(this,Ge,e)}get activeTarget(){return(0,ue.c)(this,Je)}set activeTarget(e){(0,oe.c)(this,Je,e)}get disableKeyboardAction(){return(0,ue.c)(this,Qe)}set disableKeyboardAction(e){(0,oe.c)(this,Qe,e)}get connectNodes(){return(0,ue.c)(this,et)}set connectNodes(e){(0,oe.c)(this,et,e)}get dragNodes(){return(0,ue.c)(this,tt)}set dragNodes(e){(0,oe.c)(this,tt,e)}get zoomable(){return(0,ue.c)(this,at)}set zoomable(e){(0,oe.c)(this,at,e)}get scrollable(){return(0,ue.c)(this,nt)}set scrollable(e){(0,oe.c)(this,nt,e)}get pannable(){return(0,ue.c)(this,it)}set pannable(e){(0,oe.c)(this,it,e)}get scaleRange(){return(0,ue.c)(this,st)}set scaleRange(e){(0,oe.c)(this,st,e)}callOnLineLabel(e,t){for(var a,n=arguments.length,i=new Array(n>2?n-2:0),s=2;s<n;s++)i[s-2]=arguments[s];null===(a=(0,ue.c)(this,Lt).current)||void 0===a||a.callOnLineLabel(e,t,...i)}render(){return ve().createElement(Ze,{ref:(0,ue.c)(this,Lt),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,ue.c)(this,ct),onSwitchActiveTarget:(0,ue.c)(this,Wt),onNodeDelete:(0,ue.c)(this,dt),onEdgeDelete:(0,ue.c)(this,gt),onLineClick:(0,ue.c)(this,bt),onLineDoubleClick:(0,ue.c)(this,ft),onNodesConnect:(0,ue.c)(this,Et)})}}function Rt(e){H(this,e)}function Ct(){return O(this)}function xt(e){V(this,e)}function St(){return P(this)}function Tt(e){Z(this,e)}function zt(){return X(this)}function Dt(e){j(this,e)}function At(){return U(this)}function Bt(e){Q(this,e)}function Ot(){return J(this)}function Ht(e){ne(this,e)}function It(){return ae(this)}function Kt(e,t){var{layout:a,nodes:n,edges:i,nodeBricks:s,lines:l,layoutOptions:r,connectNodes:c,dragNodes:o,activeTarget:u,disableKeyboardAction:d,zoomable:h,scrollable:v,pannable:g,scaleRange:m,onActiveTargetChange:p,onSwitchActiveTarget:b,onNodeDelete:k,onEdgeDelete:w,onLineClick:f,onLineDoubleClick:y,onNodesConnect:M}=e,[E,W]=(0,he.useState)(!1),[L,N]=(0,he.useState)(0),[R,C]=(0,he.useState)(null),[x,S]=(0,he.useState)(!1),[T,z]=(0,he.useState)(0),[D,A]=(0,he.useState)(null),[B,O]=(0,he.useState)([]),[H,I]=(0,he.useState)(!1),[K,P]=(0,he.useState)({k:1,x:0,y:0}),V=(0,he.useRef)(new Map),_=(0,he.useRef)(null),Y=(0,he.useRef)(null),[X,Z]=(0,he.useState)(!1),{userViewReady:$,userViewNodesMap:q,saveUserView:U}=(0,Ie.y)(null==o?void 0:o.save),[j,F]=(0,he.useState)([0,0]),[G,J]=(0,he.useState)(null),[Q,ee]=(0,he.useState)("initial"),[te,ae]=(0,he.useState)(null);(0,he.useImperativeHandle)(t,(()=>({callOnLineLabel(e,t){for(var a,n=arguments.length,i=new Array(n>2?n-2:0),s=2;s<n;s++)i[s-2]=arguments[s];null==D||null===(a=D.get(e))||void 0===a||null===(a=a.firstElementChild)||void 0===a||a[t](...i)}}))),(0,he.useEffect)((()=>{var e=e=>{(0,De.w)(e,{nodes:n,nodesRefRepository:R,connectNodes:c,dragNodes:o,scale:K.k,setConnectLineState:J,setConnectLineTo:F,setManualLayoutStatus:ee,setNodeMovement:ae,onSwitchActiveTarget:b,onNodesConnect:M})},t=Y.current;return null==t||t.addEventListener("mousedown",e),()=>{null==t||t.removeEventListener("mousedown",e)}}),[n,c,o,K.k,R,M,b]);var{normalizedLines:ne,normalizedLinesMap:ie,markers:se}=(0,he.useMemo)((()=>(0,Ne.K)(i,l)),[i,l]),le=(0,he.useMemo)((()=>ne.flatMap((e=>{var t,a,{line:{text:n,label:i,$id:s},edge:l}=e;return n||i?(i?(t="label",a=[].concat(i)):(t="text",a=[].concat(n)),a.map((e=>{var a;return{[t]:e,id:"".concat(s,"-").concat(null!==(a=e.placement)&&void 0!==a?a:"center"),edge:l}}))):[]}))),[ne]),{nodes:re,edges:ce}=(0,Be.C)({layout:a,nodes:n,edges:i,manualLayoutStatus:Q,userViewReady:$,userViewNodesMap:q,nodeMovement:te,nodesRefRepository:R,lineLabelsRefRepository:D,normalizedLinesMap:ie,layoutOptions:r,nodesRenderId:L,lineLabelsRenderId:T});(0,he.useEffect)((()=>{"finished"===Q&&U(re.map((e=>({id:e.id,x:e.x,y:e.y}))))}),[Q]);var oe=(0,he.useMemo)((()=>(0,Le.e)(ce,re,ne)),[ne,re,ce]),ue=null!=u?u:null,[de,ge]=(0,he.useState)(ue);(0,he.useEffect)((()=>{ge((e=>(0,Ke.M)(e,ue)?e:ue))}),[ue]);var me=(0,he.useRef)(!1);(0,he.useEffect)((()=>{me.current?null==p||p(de):me.current=!0}),[de,p]),(0,he.useEffect)((()=>{var e=_.current;if(e&&!d){var t=e=>{var t=(0,Ee.Y)(e,{renderedNodes:re,activeTarget:de});"delete-node"===(null==t?void 0:t.action)?null==k||k(t.node):"delete-edge"===(null==t?void 0:t.action)?null==w||w(t.edge):"switch-active-node"===(null==t?void 0:t.action)&&t.node&&(null==b||b({type:"node",nodeId:t.node.id}))};return e.addEventListener("keydown",t),()=>{e.removeEventListener("keydown",t)}}}),[de,re,d,b,k,w]);var ke=(0,he.useCallback)((e=>{e&&(N((e=>e+1)),C(e)),W((t=>t||!!e))}),[]),He=(0,he.useCallback)((e=>{e&&(z((e=>e+1)),A(e)),S((t=>t||!!e))}),[]),Ve=(0,he.useMemo)((()=>null!=m?m:[Ae.WH,Ae.Oi]),[m]),_e=(0,he.useMemo)((()=>(0,be.AT)()),[]);(0,he.useEffect)((()=>{var e=!1;_e.scaleExtent(h?Ve:[1,1]).on("start",(()=>{e=!1,I(!0)})).on("zoom",(t=>{e=!0,P(t.transform)})).on("end",(()=>{I(!1),e||null==b||b(null)}))}),[b,Ve,h,_e]),(0,he.useEffect)((()=>{var e=_.current;if(e){var t=(0,pe.c)(e),a=()=>{t.on(".zoom",null).on(".zoom.custom",null).on("wheel",null)};if(h||v||g)return(h||v)&&t.on("wheel.zoom.custom",(e=>{e.ctrlKey||(e.stopImmediatePropagation(),v&&(e.preventDefault(),_e.translateBy(t,e.wheelDeltaX/5,e.wheelDeltaY/5)))})),t.call(_e).on("wheel",(e=>e.preventDefault())).on("dblclick.zoom",null),g||t.on("mousedown.zoom",null).on("touchstart.zoom",null).on("touchmove.zoom",null).on("touchend.zoom",null),a;a()}}),[g,v,h,_e]),(0,he.useEffect)((()=>{var e=_.current;if(0!==re.length&&e&&!X){var{k:t,x:a,y:n}=(0,We.c)(re,{canvasWidth:e.clientWidth,canvasHeight:e.clientHeight,scaleRange:h?Ve:void 0});_e.transform((0,pe.c)(e),new be.O(t,a,n)),Z(!0)}}),[X,re,Ve,h,_e]);var Ye=(0,he.useMemo)((()=>"".concat((0,fe.uniqueId)("diagram-"),"-")),[]),Xe="".concat(Ye,"line-arrow-"),Ze="".concat(Ye,"mask-"),$e="".concat(Ye,"active-line-");(0,he.useEffect)((()=>{O((e=>(0,ze.c)(e,oe,V.current)))}),[oe]);var[qe,Ue]=ve().useState(new Map);return(0,he.useEffect)((()=>{if(D){(0,Oe.c)(B,D);var e=new ye.c((()=>{Ue((0,Pe.E)(B,D))}));for(var t of D.values())e.observe(t);return()=>{e.disconnect()}}}),[T,D,B]),"dagre"!==a&&"force"!==a?ve().createElement("div",null,'Diagram layout not supported: "'.concat(a,'"')):ve().createElement("div",{className:we()("diagram",{ready:E&&X,grabbing:H,pannable:g}),tabIndex:-1,ref:_},ve().createElement("svg",{width:"100%",height:"100%",className:"lines"},ve().createElement("defs",null,se.map(((e,t)=>{var{type:a,strokeColor:n}=e;return ve().createElement(xe.y,{key:t,id:"".concat(Xe).concat(t),type:a,strokeColor:n})})),[...qe].map((e=>{var[t,a]=e;return ve().createElement(Se.g,{key:t,lineId:t,rects:a,maskPrefix:Ze,renderedLineLabels:B})})),ve().createElement("marker",{id:"".concat($e,"start"),viewBox:"0 0 8 8",refX:4,refY:4,markerWidth:8,markerHeight:8,orient:"auto"},ve().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)"})),ve().createElement("marker",{id:"".concat($e,"end"),viewBox:"0 0 14 8",refX:3,refY:4,markerWidth:14,markerHeight:8,orient:"auto"},ve().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)"}),ve().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)"}))),ve().createElement("g",{transform:"translate(".concat(K.x," ").concat(K.y,") scale(").concat(K.k,")")},oe.map((e=>ve().createElement(Ce.k,{key:e.line.$id,line:e,linePaths:V.current,lineMaskRects:qe,maskPrefix:Ze,markerPrefix:Xe,activeLineMarkerPrefix:$e,active:"edge"===(null==de?void 0:de.type)&&de.edge.source===e.edge.source&&de.edge.target===e.edge.target,activeRelated:"node"===(null==de?void 0:de.type)&&(e.edge.source===de.nodeId||e.edge.target===de.nodeId),onLineClick:f,onLineDoubleClick:y}))))),ve().createElement("div",{className:we()("line-labels",{ready:x}),style:{left:K.x,top:K.y,transform:"scale(".concat(K.k,")")}},ve().createElement(Re.Ar,{labels:le,onRendered:He})),ve().createElement("div",{className:"nodes",ref:Y,style:{left:K.x,top:K.y,transform:"scale(".concat(K.k,")")}},ve().createElement(Me._,{nodes:n,nodeBricks:s,onRendered:ke})),ve().createElement(Te.E,{connectLineState:G,connectLineTo:j,markerPrefix:Xe}))}se=Nt,({e:[r,o,d,v,m,b,w,y,E,L,R,x,T,D,B,O,H,K,P,V,Y,X,Z,q,U,j,G,J,Q,te,ae,ne,n],c:[le,i]}=(0,de.c)(se,[[l,1,"layout"],[c,1,"nodes"],[u,1,"edges"],[h,1,"nodeBricks"],[g,1,"lines"],[p,1,"layoutOptions"],[k,1,"activeTarget"],[f,1,"disableKeyboardAction"],[M,1,"connectNodes"],[W,1,"dragNodes"],[N,1,"zoomable"],[C,1,"scrollable"],[S,1,"pannable"],[z,1,"scaleRange"],[A,1,"activeTargetChangeEvent",e=>(0,ue.c)(e,lt),(e,t)=>(0,oe.c)(e,lt,t)],[I,1,"nodeDelete",e=>(0,ue.c)(e,ot),(e,t)=>(0,oe.c)(e,ot,t)],[_,1,"edgeDelete",e=>(0,ue.c)(e,ht),(e,t)=>(0,oe.c)(e,ht,t)],[$,1,"lineClick",e=>(0,ue.c)(e,mt),(e,t)=>(0,oe.c)(e,mt,t)],[F,1,"lineDoubleClick",e=>(0,ue.c)(e,kt),(e,t)=>(0,oe.c)(e,kt,t)],[ee,1,"connectNodes",e=>(0,ue.c)(e,yt),(e,t)=>(0,oe.c)(e,yt,t)],[ie,2,"callOnLineLabel"]],s,0,(e=>Lt.has((0,ce.c)(e))),me.ReactNextElement)),i()}}]);
2
- //# sourceMappingURL=eo-diagram.2b8615e9.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"chunks/eo-diagram.2b8615e9.js","mappings":"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","sources":["webpack:///./src/diagram/index.tsx"],"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"],"names":["_EoDiagram","defineElement","property","event","method","createDecorators","EoDiagramComponent","forwardRef","LegacyEoDiagramComponent","_classDecs","styleTexts","styleText","_dec","type","String","_dec2","attribute","_dec3","_dec4","_dec5","_dec6","_dec7","_dec8","Boolean","_dec9","_dec10","_dec11","_dec12","_dec13","_dec14","_dec15","_dec16","_dec17","_dec18","_dec19","_dec20","_dec21","_A","WeakMap","_B","_C","_D","_E","_F","_G","_H","_I","_J","_K","_L","_M","_N","_O","_activeTargetChangeEvent","_handleActiveTargetChange","_P","_nodeDelete","_handleNodeDelete","_Q","_edgeDelete","_handleEdgeDelete","_R","_lineClick","_handleLineClick","_S","_lineDoubleClick","_handleLineDoubleClick","_T","_connectNodes","_handleNodesConnect","_handleSwitchActiveTarget","_diagramRef","EoDiagram","ReactNextElement","constructor","arguments","_classPrivateFieldInitSpec","get","_get_connectNodes2","set","_set_connectNodes2","_get_lineDoubleClick2","_set_lineDoubleClick2","_get_lineClick2","_set_lineClick2","_get_edgeDelete2","_set_edgeDelete2","_get_nodeDelete2","_set_nodeDelete2","_get_activeTargetChangeEvent2","_set_activeTargetChangeEvent2","writable","value","_initProto","_init_layout","_init_nodes","_init_edges","_init_nodeBricks","_init_lines","_init_layoutOptions","_init_activeTarget","_init_disableKeyboardAction","_init_connectNodes","_init_dragNodes","_init_zoomable","_init_scrollable","_init_pannable","_init_scaleRange","_init_activeTargetChangeEvent","target","_classPrivateFieldGet","this","emit","_init_nodeDelete","node","_init_edgeDelete","edge","_init_lineClick","line","_init_lineDoubleClick","_init_connectNodes2","detail","sameTarget","activeTarget","createRef","layout","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","_set_activeTargetChangeEvent","_get_activeTargetChangeEvent","_set_nodeDelete","_get_nodeDelete","_set_edgeDelete","_get_edgeDelete","_set_lineClick","_get_lineClick","_set_lineDoubleClick","_get_lineDoubleClick","_set_connectNodes","_get_connectNodes","_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","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","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","c","_initClass","_applyDecs","o","_","has","_checkInRHS"],"sourceRoot":""}
@@ -1,2 +0,0 @@
1
- "use strict";(self.webpackChunk_next_bricks_diagram=self.webpackChunk_next_bricks_diagram||[]).push([[7364],{8752:(e,t,a)=>{a.d(t,{y:()=>i});var n=a(5600),r=a.n(n);function i(e){var t,{id:a,type:n,strokeColor:i}=e;switch(n){case"0..1":t=c;break;case"0..N":t=o;break;default:t=l}return r().createElement(t,{id:a,strokeColor:i})}function l(e){var{id:t,strokeColor:a}=e;return r().createElement("marker",{id:t,viewBox:"0 0 6 6",refX:5,refY:3,markerWidth:6,markerHeight:6,orient:"auto-start-reverse",strokeLinejoin:"round"},r().createElement("path",{d:"M 0.5 0.5 L 5.5 3 L 0.5 5.5 z",stroke:a,strokeWidth:1,fill:a}))}function c(e){var{id:t,strokeColor:a}=e;return r().createElement("marker",{id:t,viewBox:"0 0 21 11",refX:.5,refY:5.5,markerWidth:21,markerHeight:11,orient:"auto-start-reverse"},r().createElement("path",{d:"M 5.5 5.5 m 5 0 a 5 5 0 1 0 -10 0 a 5 5 0 1 0 10 0 M 15.5 0.5 V 10.5 M 10.5 5.5 H 20.5",stroke:a,strokeWidth:1,fill:"none"}))}function o(e){var{id:t,strokeColor:a}=e;return r().createElement("marker",{id:t,viewBox:"0 0 21 11",refX:.5,refY:5.5,markerWidth:21,markerHeight:11,orient:"auto-start-reverse"},r().createElement("path",{d:"M 5.5 5.5 m 5 0 a 5 5 0 1 0 -10 0 a 5 5 0 1 0 10 0 M 20.5 0.5 L 10.5 5.5 L 20.5 10.5 M 10.5 5.5 H 20.5",stroke:a,strokeWidth:1,fill:"none"}))}},960:(e,t,a)=>{a.d(t,{g:()=>r});var n=a(828);function r(e,t){if(e===t||(0,n.e)(e,t,0,0))return null;var a,r,i,l,c=t.x-e.x,o=t.y-e.y,s=c>0?1:-1;if(0!==o){var u=Math.abs(c/o),d=o>0?1:-1;u<e.width/e.height?(a=e.x+u*e.height/2*s,r=e.y+e.height/2*d):(a=e.x+e.width/2*s,r=e.y+e.width/2/u*d),u<t.width/t.height?(i=t.x-u*t.height/2*s,l=t.y-t.height/2*d):(i=t.x-t.width/2*s,l=t.y-t.width/2/u*d)}else a=e.x+e.width/2*s,i=t.x-t.width/2*s,r=l=e.y;return[{x:a,y:r},{x:i,y:l}]}},828:(e,t,a)=>{function n(e,t,a,n){var i=a?r(e,a):e,l=n?r(t,n):t,c=Math.min(i.x-i.width/2,l.x-l.width/2),o=Math.max(i.x+i.width/2,l.x+l.width/2),s=Math.min(i.y-i.height/2,l.y-l.height/2),u=Math.max(i.y+i.height/2,l.y+l.height/2);return o-c<i.width+l.width&&u-s<i.height+l.height}function r(e,t){return{x:e.x-e.width/2-t,y:e.y-e.height/2-t,width:e.width+2*t,height:e.height+2*t}}a.d(t,{e:()=>n})},3156:(e,t,a)=>{a.r(t),a.d(t,{EoDrawCanvas:()=>ge,EoDrawCanvasComponent:()=>Qe});var n,r,i,l,c,o,s,u,d,h,v,f,g,p,w,m,k,x,y,b,C,M,E,W,z,N,S,T,R,B,D,L,H,P,A,U,Y,_,G,I,j,X,O,F,q,K,V,J,Q,Z,$,ee,te,ae,ne,re,ie,le,ce,oe,se,ue,de,he,ve,fe,ge,pe=a(4412),we=a(8944),me=a(123),ke=a(592),xe=a(5866),ye=a(1412),be=a(8644),Ce=a(5600),Me=a.n(Ce),Ee=a(7672),We=a(8160),ze=a(4516),Ne=(a(48),a(7568)),Se=a(5248),Te=a(1920),Re=a(1252),Be=a.n(Re),De=a(3876),Le=a(8752),He=a(7181),Pe=a(4552),Ae=a(6876),Ue=a(5776),Ye=a(7584),_e=a(8044),Ge=a(7876),Ie=a(3788),je=a(2872),Xe=a(587),Oe=a(3576),Fe=(0,ze.unwrapProvider)("basic.lock-body-scroll"),{defineElement:qe,property:Ke,method:Ve,event:Je}=(0,Ee.createDecorators)(),Qe=Me().forwardRef(ea);i=[qe("eo-draw-canvas",{styleTexts:[Ye.c]})],l=Ke({attribute:!1}),o=Ke({attribute:!1}),u=Ke({attribute:!1}),h=Ke({attribute:!1}),f=Ke({attribute:!1}),p=Ke({type:Boolean}),m=Ke({type:Boolean}),x=Ke({type:Boolean}),b=Ke({type:Boolean}),M=Ke({attribute:!1}),W=Je({type:"activeTarget.change"}),T=Je({type:"node.move"}),L=Je({type:"cell.move"}),U=Je({type:"cell.resize"}),I=Je({type:"node.delete"}),F=Je({type:"cell.delete"}),J=Je({type:"cell.contextmenu"}),ee=Je({type:"decorator.text.change"}),re=Je({type:"scale.change"}),oe=Ve(),se=Ve(),ue=Ve(),de=Ve(),he=Ve(),ve=Ve();var Ze=new WeakMap,$e=new WeakMap,et=new WeakMap,tt=new WeakMap,at=new WeakMap,nt=new WeakMap,rt=new WeakMap,it=new WeakMap,lt=new WeakMap,ct=new WeakMap,ot=new WeakMap,st=new WeakMap,ut=new WeakMap,dt=new WeakMap,ht=new WeakMap,vt=new WeakMap,ft=new WeakMap,gt=new WeakMap,pt=new WeakMap,wt=new WeakMap,mt=new WeakMap,kt=new WeakMap,xt=new WeakMap,yt=new WeakMap,bt=new WeakMap,Ct=new WeakMap,Mt=new WeakMap,Et=new WeakMap,Wt=new WeakMap,zt=new WeakMap,Nt=new WeakMap,St=new WeakMap,Tt=new WeakMap,Rt=new WeakMap,Bt=new WeakMap,Dt=new WeakMap,Lt=new WeakMap;class Ht extends We.ReactNextElement{constructor(){super(...arguments),(0,me.c)(this,Bt,{get:$t,set:Zt}),(0,me.c)(this,St,{get:Qt,set:Jt}),(0,me.c)(this,Wt,{get:Vt,set:Kt}),(0,me.c)(this,Ct,{get:qt,set:Ft}),(0,me.c)(this,yt,{get:Ot,set:Xt}),(0,me.c)(this,mt,{get:jt,set:It}),(0,me.c)(this,gt,{get:Gt,set:_t}),(0,me.c)(this,vt,{get:Yt,set:Ut}),(0,me.c)(this,st,{get:At,set:Pt}),(0,me.c)(this,Ze,{writable:!0,value:(n(this),c(this))}),(0,me.c)(this,$e,{writable:!0,value:s(this,[Oe.eW,Oe.eW])}),(0,me.c)(this,et,{writable:!0,value:d(this)}),(0,me.c)(this,tt,{writable:!0,value:v(this)}),(0,me.c)(this,at,{writable:!0,value:g(this)}),(0,me.c)(this,nt,{writable:!0,value:w(this)}),(0,me.c)(this,rt,{writable:!0,value:k(this,!0)}),(0,me.c)(this,it,{writable:!0,value:y(this,!0)}),(0,me.c)(this,lt,{writable:!0,value:C(this,!0)}),(0,me.c)(this,ct,{writable:!0,value:E(this)}),(0,me.c)(this,ot,{writable:!0,value:z(this)}),(0,me.c)(this,ut,{writable:!0,value:e=>{(0,ye.c)(this,st).emit(e)}}),(0,me.c)(this,dt,{writable:!0,value:e=>{(0,Pe.M)(e,this.activeTarget)||(this.activeTarget=e)}}),(0,me.c)(this,ht,{writable:!0,value:R(this)}),(0,me.c)(this,ft,{writable:!0,value:H(this)}),(0,me.c)(this,pt,{writable:!0,value:e=>{(0,ye.c)(this,gt).emit(e),"node"===e.type&&(0,ye.c)(this,vt).emit(e)}}),(0,me.c)(this,wt,{writable:!0,value:Y(this)}),(0,me.c)(this,kt,{writable:!0,value:e=>{(0,ye.c)(this,mt).emit(e)}}),(0,me.c)(this,xt,{writable:!0,value:j(this)}),(0,me.c)(this,bt,{writable:!0,value:q(this)}),(0,me.c)(this,Mt,{writable:!0,value:e=>{(0,ye.c)(this,Ct).emit(e),"node"===e.type&&(0,ye.c)(this,yt).emit(e)}}),(0,me.c)(this,Et,{writable:!0,value:Q(this)}),(0,me.c)(this,zt,{writable:!0,value:e=>{(0,ye.c)(this,Wt).emit(e)}}),(0,me.c)(this,Nt,{writable:!0,value:te(this)}),(0,me.c)(this,Tt,{writable:!0,value:e=>{(0,ye.c)(this,St).emit(e)}}),(0,me.c)(this,Rt,{writable:!0,value:ie(this)}),(0,me.c)(this,Dt,{writable:!0,value:e=>{(0,ye.c)(this,Bt).emit(e)}}),(0,me.c)(this,Lt,{writable:!0,value:(0,Ce.createRef)()})}get cells(){return(0,ye.c)(this,Ze)}set cells(e){(0,xe.c)(this,Ze,e)}get defaultNodeSize(){return(0,ye.c)(this,$e)}set defaultNodeSize(e){(0,xe.c)(this,$e,e)}get defaultNodeBricks(){return(0,ye.c)(this,et)}set defaultNodeBricks(e){(0,xe.c)(this,et,e)}get defaultEdgeLines(){return(0,ye.c)(this,tt)}set defaultEdgeLines(e){(0,xe.c)(this,tt,e)}get activeTarget(){return(0,ye.c)(this,at)}set activeTarget(e){(0,xe.c)(this,at,e)}get fadeUnrelatedCells(){return(0,ye.c)(this,nt)}set fadeUnrelatedCells(e){(0,xe.c)(this,nt,e)}get zoomable(){return(0,ye.c)(this,rt)}set zoomable(e){(0,xe.c)(this,rt,e)}get scrollable(){return(0,ye.c)(this,it)}set scrollable(e){(0,xe.c)(this,it,e)}get pannable(){return(0,ye.c)(this,lt)}set pannable(e){(0,xe.c)(this,lt,e)}get scaleRange(){return(0,ye.c)(this,ct)}set scaleRange(e){(0,xe.c)(this,ct,e)}dropNode(e){var t=this;return(0,we.c)((function*(){var a,n,{id:r,position:i,size:l,data:c,useBrick:o}=e;if(null===(a=(n=document).elementsFromPoint)||void 0===a||null===(a=a.call(n,i[0],i[1]))||void 0===a?void 0:a.includes(t)){var s,u,d,h=t.getBoundingClientRect(),v=(0,ye.c)(t,Lt).current.getTransform(),f={type:"node",id:r,view:{x:(i[0]-h.left-v.x)/v.k,y:(i[1]-h.top-v.y)/v.k,width:null!==(s=null==l?void 0:l[0])&&void 0!==s?s:t.defaultNodeSize[0],height:null!==(u=null==l?void 0:l[1])&&void 0!==u?u:t.defaultNodeSize[0]},data:c,useBrick:o};return null===(d=(0,ye.c)(t,Lt).current)||void 0===d||d.dropNode(f),f}return null}))()}dropDecorator(e){var t=this;return(0,we.c)((function*(){var a,n,{position:r,decorator:i,text:l}=e;if(null===(a=(n=document).elementsFromPoint)||void 0===a||null===(a=a.call(n,r[0],r[1]))||void 0===a?void 0:a.includes(t)){var c,o=t.getBoundingClientRect(),s=(0,ye.c)(t,Lt).current.getTransform(),u={type:"decorator",decorator:i,id:"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g,(function(e){var t=16*Math.random()|0;return("x"==e?t:3&t|8).toString(16)})),view:{x:(r[0]-o.left-s.x)/s.k,y:(r[1]-o.top-s.y)/s.k,width:Oe.Mf,height:Oe.iS,text:l}};return null===(c=(0,ye.c)(t,Lt).current)||void 0===c||c.dropDecorator(u),u}return null}))()}addNodes(e){var t=this;return(0,we.c)((function*(){if(0===e.length)return[];var a=e.map((e=>{var a,n,{size:r,useBrick:i,id:l,data:c}=e;return{type:"node",id:l,data:c,view:{width:null!==(a=null==r?void 0:r[0])&&void 0!==a?a:t.defaultNodeSize[0],height:null!==(n=null==r?void 0:r[1])&&void 0!==n?n:t.defaultNodeSize[0]},useBrick:i}}));return(0,ye.c)(t,Lt).current.addNodes(a,{defaultNodeSize:t.defaultNodeSize,canvasHeight:t.clientHeight})}))()}addEdge(e){var t=this;return(0,we.c)((function*(){var a,{source:n,target:r,data:i}=e,l={type:"edge",source:n,target:r,data:i};return null===(a=(0,ye.c)(t,Lt).current)||void 0===a||a.addEdge(l),l}))()}manuallyConnectNodes(e){return(0,ye.c)(this,Lt).current.manuallyConnectNodes(e)}updateCells(e,t){var a=this;return(0,we.c)((function*(){var{updated:n}=(0,ye.c)(a,Lt).current.updateCells(e,(0,pe.c)((0,pe.c)({},t),{},{defaultNodeSize:a.defaultNodeSize,canvasHeight:a.clientHeight}));return{updated:n}}))()}disconnectedCallback(){super.disconnectedCallback(),Fe(this,!1)}render(){return Me().createElement(Qe,{host:this,ref:(0,ye.c)(this,Lt),cells:this.cells,defaultNodeSize:this.defaultNodeSize,defaultNodeBricks:this.defaultNodeBricks,defaultEdgeLines:this.defaultEdgeLines,activeTarget:this.activeTarget,fadeUnrelatedCells:this.fadeUnrelatedCells,zoomable:this.zoomable,scrollable:this.scrollable,pannable:this.pannable,scaleRange:this.scaleRange,onActiveTargetChange:(0,ye.c)(this,ut),onSwitchActiveTarget:(0,ye.c)(this,dt),onCellMove:(0,ye.c)(this,pt),onCellResize:(0,ye.c)(this,kt),onCellDelete:(0,ye.c)(this,Mt),onCellContextMenu:(0,ye.c)(this,zt),onDecoratorTextChange:(0,ye.c)(this,Tt),onScaleChange:(0,ye.c)(this,Dt)})}}function Pt(e){S(this,e)}function At(){return N(this)}function Ut(e){D(this,e)}function Yt(){return B(this)}function _t(e){A(this,e)}function Gt(){return P(this)}function It(e){G(this,e)}function jt(){return _(this)}function Xt(e){O(this,e)}function Ot(){return X(this)}function Ft(e){V(this,e)}function qt(){return K(this)}function Kt(e){$(this,e)}function Vt(){return Z(this)}function Jt(e){ne(this,e)}function Qt(){return ae(this)}function Zt(e){ce(this,e)}function $t(){return le(this)}function ea(e,t){var{host:a,cells:n,defaultNodeSize:r,defaultNodeBricks:i,defaultEdgeLines:l,activeTarget:c,fadeUnrelatedCells:o,zoomable:s,scrollable:u,pannable:d,scaleRange:h,onActiveTargetChange:v,onSwitchActiveTarget:f,onCellMove:g,onCellResize:p,onCellDelete:w,onCellContextMenu:m,onDecoratorTextChange:k,onScaleChange:x}=e,[{cells:y},b]=(0,Ce.useReducer)(De.M,n,(e=>({cells:(0,Ge.S)(e,{defaultNodeSize:r})}))),C=(0,Ce.useRef)(null),M=(0,Ce.useRef)(null),E=(0,Ce.useRef)(null),[W,z]=(0,Ce.useState)([]),[N,S]=(0,Ce.useState)(!1),[T,R]=(0,Ce.useState)({k:1,x:0,y:0}),[B,D]=(0,Ce.useState)(!1);(0,Ce.useEffect)((()=>{x(T.k)}),[x,T.k]);var[L,H]=(0,Ce.useState)(null),P=(0,Ce.useMemo)((()=>null!=h?h:[Oe.WH,Oe.Oi]),[h]),A=(0,Ce.useMemo)((()=>(0,Te.AT)()),[]);(0,Ce.useEffect)((()=>{var e=!1;A.scaleExtent(s?P:[1,1]).on("start",(()=>{e=!1,S(!0)})).on("zoom",(t=>{e=!0,R(t.transform)})).on("end",(()=>{S(!1),e||null==f||f(null)}))}),[f,P,s,A]),(0,Ce.useEffect)((()=>{var e=C.current;if(e){var t=(0,Se.c)(e),a=()=>{t.on(".zoom",null).on(".zoom.custom",null).on("wheel",null)};if(s||u||d)return(s||u)&&t.on("wheel.zoom.custom",(e=>{e.ctrlKey||(e.stopImmediatePropagation(),u&&(e.preventDefault(),A.translateBy(t,e.wheelDeltaX/5,e.wheelDeltaY/5)))})),t.call(A).on("wheel",(e=>e.preventDefault())).on("dblclick.zoom",null).on("mousedown.zoom",null),d||t.on("touchstart.zoom",null).on("touchmove.zoom",null).on("touchend.zoom",null),a;a()}}),[d,u,s,A]),(0,Ce.useEffect)((()=>{var e=C.current;if(e&&!B&&y.some((e=>(0,He.G4)(e)||(0,He.c1)(e)))&&!y.some((e=>(0,He.G4)(e)&&!e[Oe.m6]))){var{k:t,x:a,y:n}=(0,Ie.c)(y,{canvasWidth:e.clientWidth,canvasHeight:e.clientHeight,scaleRange:s?P:void 0});A.transform((0,Se.c)(e),new Te.O(t,a,n)),D(!0)}}),[y,B,P,s,A]),(0,Ce.useEffect)((()=>{y.some((e=>(0,He.G4)(e)||(0,He.c1)(e)))||D(!1)}),[y]),(0,Ce.useImperativeHandle)(t,(()=>({dropNode(e){D(!0),b({type:"drop-node",payload:e})},dropDecorator(e){D(!0),b({type:"drop-decorator",payload:e})},addNodes(e,t){var{defaultNodeSize:a,canvasHeight:n}=t,r=y.findLastIndex((e=>!("decorator"===e.type&&"text"===e.decorator)))+1,i=[...y.slice(0,r),...e,...y.slice(r)],{cells:l,updated:c}=(0,je.s)({cells:i,previousCells:y,defaultNodeSize:a,canvasHeight:n,transform:T});return b({type:"update-cells",payload:l}),c.filter((t=>e.includes(t)))},addEdge(e){b({type:"add-edge",payload:e})},updateCells(e,t){var a=(0,je.s)((0,pe.c)((0,pe.c)({},t),{},{previousCells:y,cells:e,transform:T}));return b({type:"update-cells",payload:a.cells}),a},getTransform:()=>T,manuallyConnectNodes(e){var t=y.find((t=>(0,He.G4)(t)&&t.id===e));if(t){var a=C.current.getBoundingClientRect();return H({source:t,from:[t.view.x+t.view.width/2,t.view.y+t.view.height/2],offset:[a.left,a.top]}),new Promise(((e,t)=>{E.current={resolve:e,reject:t}}))}return Promise.reject(null)}})),[y,T]);var U=(0,Ce.useCallback)(((e,t)=>{for(var a,n=0;n<y.length;n++){var r=y[n];if((0,He.G4)(r)&&r.id!==e.source.id&&r.view.x<t[0]&&r.view.x+r.view.width>t[0]&&r.view.y<t[1]&&r.view.y+r.view.height>t[1]){var i;null===(i=E.current)||void 0===i||i.resolve({source:e.source,target:r});break}}null===(a=E.current)||void 0===a||a.reject(null),H(null)}),[y]);(0,Ce.useEffect)((()=>{Fe(a,!!L)}),[L,a]);var Y=null!=c?c:null,[_,G]=(0,Ce.useState)(Y);(0,Ce.useEffect)((()=>{G((e=>(0,Pe.M)(e,Y)?e:Y))}),[Y]);var I=(0,Ce.useRef)(!1);(0,Ce.useEffect)((()=>{I.current?v(_):I.current=!0}),[_,v]);var[j,X]=(0,Ce.useState)([]);(0,Ce.useEffect)((()=>{var e=o?(0,Xe.Y)(y,L,_):[];X((t=>0===t.length&&0===e.length?t:e))}),[_,y,L,o]),(0,Ce.useEffect)((()=>{if(_){var e=e=>{e.composedPath().indexOf(M.current)<=0&&G(null)};return document.addEventListener("click",e),()=>{document.removeEventListener("click",e)}}}),[_]),(0,Ce.useEffect)((()=>{var e=C.current;if(e&&!(W.length>0)){var t=e=>{var t=(0,Ae.Y)(e,{cells:y,activeTarget:_});"delete-cell"===(null==t?void 0:t.action)&&w(t.cell)};return e.addEventListener("keydown",t),()=>{e.removeEventListener("keydown",t)}}}),[_,y,W.length,w]);var O=(0,Ce.useMemo)((()=>"".concat((0,Ne.uniqueId)("diagram-"),"-")),[]),F="".concat(O,"line-arrow-"),q="".concat(F,"1"),K=(0,Ce.useCallback)((e=>{b({type:"move-cell",payload:e})}),[]),V=(0,Ce.useCallback)((e=>{b({type:"move-cell",payload:e}),g(e)}),[g]),J=(0,Ce.useCallback)((e=>{b({type:"resize-cell",payload:e})}),[]),Q=(0,Ce.useCallback)((e=>{b({type:"resize-cell",payload:e}),p(e)}),[p]),Z=(0,Ce.useCallback)((e=>{var{id:t,editing:a}=e;z(a?e=>e.includes(t)?e:[...e,t]:e=>e.filter((e=>e!==t)))}),[]),$=(0,Ce.useCallback)(((e,t)=>{b({type:"update-node-size",payload:{id:e,size:t}})}),[]);return Me().createElement("svg",{width:"100%",height:"100%",ref:C,className:Be()("root",{grabbing:N,pannable:d,ready:B}),tabIndex:-1},Me().createElement("defs",null,Me().createElement(Le.y,{id:q,type:"arrow",strokeColor:"gray"})),Me().createElement("g",{transform:"translate(".concat(T.x," ").concat(T.y,") scale(").concat(T.k,")")},Me().createElement("g",{className:"cells",ref:M},y.map((e=>Me().createElement(Ue.s,{key:"".concat(e.type,":").concat("edge"===e.type?"".concat(e.source,"~").concat(e.target):e.id),cell:e,cells:y,defaultNodeBricks:i,defaultEdgeLines:l,transform:T,markerEnd:q,active:(0,Pe.M)(_,e),unrelatedCells:j,onCellMoving:K,onCellMoved:V,onCellResizing:J,onCellResized:Q,onSwitchActiveTarget:f,onCellContextMenu:m,onDecoratorTextChange:k,onDecoratorTextEditing:Z,onNodeBrickResize:$})))),Me().createElement(_e.E,{connectLineState:L,transform:T,markerEnd:q,onConnect:U})))}fe=Ht,({e:[c,s,d,v,g,w,k,y,C,E,z,N,S,R,B,D,H,P,A,Y,_,G,j,X,O,q,K,V,Q,Z,$,te,ae,ne,ie,le,ce,n],c:[ge,r]}=(0,be.c)(fe,[[l,1,"cells"],[o,1,"defaultNodeSize"],[u,1,"defaultNodeBricks"],[h,1,"defaultEdgeLines"],[f,1,"activeTarget"],[p,1,"fadeUnrelatedCells"],[m,1,"zoomable"],[x,1,"scrollable"],[b,1,"pannable"],[M,1,"scaleRange"],[W,1,"activeTargetChangeEvent",e=>(0,ye.c)(e,ot),(e,t)=>(0,xe.c)(e,ot,t)],[T,1,"nodeMoveEvent",e=>(0,ye.c)(e,ht),(e,t)=>(0,xe.c)(e,ht,t)],[L,1,"cellMoveEvent",e=>(0,ye.c)(e,ft),(e,t)=>(0,xe.c)(e,ft,t)],[U,1,"cellResizeEvent",e=>(0,ye.c)(e,wt),(e,t)=>(0,xe.c)(e,wt,t)],[I,1,"nodeDelete",e=>(0,ye.c)(e,xt),(e,t)=>(0,xe.c)(e,xt,t)],[F,1,"cellDelete",e=>(0,ye.c)(e,bt),(e,t)=>(0,xe.c)(e,bt,t)],[J,1,"cellContextMenu",e=>(0,ye.c)(e,Et),(e,t)=>(0,xe.c)(e,Et,t)],[ee,1,"decoratorTextChange",e=>(0,ye.c)(e,Nt),(e,t)=>(0,xe.c)(e,Nt,t)],[re,1,"scaleChange",e=>(0,ye.c)(e,Rt),(e,t)=>(0,xe.c)(e,Rt,t)],[oe,2,"dropNode"],[se,2,"dropDecorator"],[ue,2,"addNodes"],[de,2,"addEdge"],[he,2,"manuallyConnectNodes"],[ve,2,"updateCells"]],i,0,(e=>Lt.has((0,ke.c)(e))),We.ReactNextElement)),r()}}]);
2
- //# sourceMappingURL=eo-draw-canvas.e4d56ade.js.map