aldehyde 0.2.474 → 0.2.476

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 (349) hide show
  1. package/lib/controls/action/utils.d.ts +1 -1
  2. package/lib/controls/entity-select/entity-select.d.ts +2 -2
  3. package/lib/controls/entity-select/entity-select.d.ts.map +1 -1
  4. package/lib/controls/entity-select/entity-select.js +16 -7
  5. package/lib/controls/entity-select/entity-select.js.map +1 -1
  6. package/lib/controls/entry-control.d.ts.map +1 -1
  7. package/lib/controls/entry-control.js +1 -0
  8. package/lib/controls/entry-control.js.map +1 -1
  9. package/lib/controls/select/index.d.ts.map +1 -1
  10. package/lib/controls/select/index.js +13 -7
  11. package/lib/controls/select/index.js.map +1 -1
  12. package/lib/controls/text/index.less +1 -0
  13. package/lib/controls/view-control.d.ts.map +1 -1
  14. package/lib/controls/view-control.js +1 -0
  15. package/lib/controls/view-control.js.map +1 -1
  16. package/lib/detail/button/edit-button.d.ts.map +1 -1
  17. package/lib/detail/button/edit-button.js +23 -11
  18. package/lib/detail/button/edit-button.js.map +1 -1
  19. package/lib/detail/button/view-button.d.ts.map +1 -1
  20. package/lib/detail/button/view-button.js +21 -10
  21. package/lib/detail/button/view-button.js.map +1 -1
  22. package/lib/draw-canvas-edit/components/asset-bar/index.d.ts.map +1 -0
  23. package/lib/{draw-canvas/edit → draw-canvas-edit}/components/asset-bar/index.js +2 -1
  24. package/lib/draw-canvas-edit/components/asset-bar/index.js.map +1 -0
  25. package/lib/{draw-canvas/edit → draw-canvas-edit}/components/main-header/index.d.ts +5 -0
  26. package/lib/draw-canvas-edit/components/main-header/index.d.ts.map +1 -0
  27. package/lib/{draw-canvas/edit → draw-canvas-edit}/components/main-header/index.js +55 -15
  28. package/lib/draw-canvas-edit/components/main-header/index.js.map +1 -0
  29. package/lib/draw-canvas-edit/components/render/draws/bg-draw.d.ts +26 -0
  30. package/lib/draw-canvas-edit/components/render/draws/bg-draw.d.ts.map +1 -0
  31. package/lib/draw-canvas-edit/components/render/draws/bg-draw.js +135 -0
  32. package/lib/draw-canvas-edit/components/render/draws/bg-draw.js.map +1 -0
  33. package/lib/draw-canvas-edit/components/render/draws/contextmenu-draw.d.ts +26 -0
  34. package/lib/draw-canvas-edit/components/render/draws/contextmenu-draw.d.ts.map +1 -0
  35. package/lib/draw-canvas-edit/components/render/draws/contextmenu-draw.js +293 -0
  36. package/lib/draw-canvas-edit/components/render/draws/contextmenu-draw.js.map +1 -0
  37. package/lib/draw-canvas-edit/components/render/draws/graph-draw.d.ts +30 -0
  38. package/lib/draw-canvas-edit/components/render/draws/graph-draw.d.ts.map +1 -0
  39. package/lib/draw-canvas-edit/components/render/draws/graph-draw.js +182 -0
  40. package/lib/draw-canvas-edit/components/render/draws/graph-draw.js.map +1 -0
  41. package/lib/draw-canvas-edit/components/render/draws/index.d.ts +8 -0
  42. package/lib/draw-canvas-edit/components/render/draws/index.d.ts.map +1 -0
  43. package/lib/draw-canvas-edit/components/render/draws/index.js +8 -0
  44. package/lib/draw-canvas-edit/components/render/draws/index.js.map +1 -0
  45. package/lib/draw-canvas-edit/components/render/draws/link-draw.d.ts +42 -0
  46. package/lib/draw-canvas-edit/components/render/draws/link-draw.d.ts.map +1 -0
  47. package/lib/draw-canvas-edit/components/render/draws/link-draw.js +1376 -0
  48. package/lib/draw-canvas-edit/components/render/draws/link-draw.js.map +1 -0
  49. package/lib/draw-canvas-edit/components/render/draws/preview-draw.d.ts +15 -0
  50. package/lib/draw-canvas-edit/components/render/draws/preview-draw.d.ts.map +1 -0
  51. package/lib/draw-canvas-edit/components/render/draws/preview-draw.js +245 -0
  52. package/lib/draw-canvas-edit/components/render/draws/preview-draw.js.map +1 -0
  53. package/lib/draw-canvas-edit/components/render/draws/ref-line-draw.d.ts +18 -0
  54. package/lib/draw-canvas-edit/components/render/draws/ref-line-draw.d.ts.map +1 -0
  55. package/lib/draw-canvas-edit/components/render/draws/ref-line-draw.js +59 -0
  56. package/lib/draw-canvas-edit/components/render/draws/ref-line-draw.js.map +1 -0
  57. package/lib/draw-canvas-edit/components/render/draws/ruler-draw.d.ts +12 -0
  58. package/lib/draw-canvas-edit/components/render/draws/ruler-draw.d.ts.map +1 -0
  59. package/lib/draw-canvas-edit/components/render/draws/ruler-draw.js +151 -0
  60. package/lib/draw-canvas-edit/components/render/draws/ruler-draw.js.map +1 -0
  61. package/lib/draw-canvas-edit/components/render/graphs/base-graph.d.ts +112 -0
  62. package/lib/draw-canvas-edit/components/render/graphs/base-graph.d.ts.map +1 -0
  63. package/lib/draw-canvas-edit/components/render/graphs/base-graph.js +199 -0
  64. package/lib/draw-canvas-edit/components/render/graphs/base-graph.js.map +1 -0
  65. package/lib/draw-canvas-edit/components/render/graphs/bezier.d.ts +80 -0
  66. package/lib/draw-canvas-edit/components/render/graphs/bezier.d.ts.map +1 -0
  67. package/lib/draw-canvas-edit/components/render/graphs/bezier.js +485 -0
  68. package/lib/draw-canvas-edit/components/render/graphs/bezier.js.map +1 -0
  69. package/lib/draw-canvas-edit/components/render/graphs/circle.d.ts +48 -0
  70. package/lib/draw-canvas-edit/components/render/graphs/circle.d.ts.map +1 -0
  71. package/lib/draw-canvas-edit/components/render/graphs/circle.js +735 -0
  72. package/lib/draw-canvas-edit/components/render/graphs/circle.js.map +1 -0
  73. package/lib/draw-canvas-edit/components/render/graphs/curve.d.ts +80 -0
  74. package/lib/draw-canvas-edit/components/render/graphs/curve.d.ts.map +1 -0
  75. package/lib/draw-canvas-edit/components/render/graphs/curve.js +451 -0
  76. package/lib/draw-canvas-edit/components/render/graphs/curve.js.map +1 -0
  77. package/lib/draw-canvas-edit/components/render/graphs/index.d.ts +7 -0
  78. package/lib/draw-canvas-edit/components/render/graphs/index.d.ts.map +1 -0
  79. package/lib/draw-canvas-edit/components/render/graphs/index.js +7 -0
  80. package/lib/draw-canvas-edit/components/render/graphs/index.js.map +1 -0
  81. package/lib/draw-canvas-edit/components/render/graphs/line.d.ts +80 -0
  82. package/lib/draw-canvas-edit/components/render/graphs/line.d.ts.map +1 -0
  83. package/lib/draw-canvas-edit/components/render/graphs/line.js +444 -0
  84. package/lib/draw-canvas-edit/components/render/graphs/line.js.map +1 -0
  85. package/lib/draw-canvas-edit/components/render/graphs/rect.d.ts +48 -0
  86. package/lib/draw-canvas-edit/components/render/graphs/rect.d.ts.map +1 -0
  87. package/lib/draw-canvas-edit/components/render/graphs/rect.js +716 -0
  88. package/lib/draw-canvas-edit/components/render/graphs/rect.js.map +1 -0
  89. package/lib/draw-canvas-edit/components/render/handlers/drag-handlers.d.ts +25 -0
  90. package/lib/draw-canvas-edit/components/render/handlers/drag-handlers.d.ts.map +1 -0
  91. package/lib/draw-canvas-edit/components/render/handlers/drag-handlers.js +67 -0
  92. package/lib/draw-canvas-edit/components/render/handlers/drag-handlers.js.map +1 -0
  93. package/lib/draw-canvas-edit/components/render/handlers/drag-outside-handlers.d.ts +15 -0
  94. package/lib/draw-canvas-edit/components/render/handlers/drag-outside-handlers.d.ts.map +1 -0
  95. package/lib/draw-canvas-edit/components/render/handlers/drag-outside-handlers.js +146 -0
  96. package/lib/draw-canvas-edit/components/render/handlers/drag-outside-handlers.js.map +1 -0
  97. package/lib/draw-canvas-edit/components/render/handlers/graph-handlers.d.ts +28 -0
  98. package/lib/draw-canvas-edit/components/render/handlers/graph-handlers.d.ts.map +1 -0
  99. package/lib/draw-canvas-edit/components/render/handlers/graph-handlers.js +97 -0
  100. package/lib/draw-canvas-edit/components/render/handlers/graph-handlers.js.map +1 -0
  101. package/lib/draw-canvas-edit/components/render/handlers/index.d.ts +10 -0
  102. package/lib/draw-canvas-edit/components/render/handlers/index.d.ts.map +1 -0
  103. package/lib/draw-canvas-edit/components/render/handlers/index.js +10 -0
  104. package/lib/draw-canvas-edit/components/render/handlers/index.js.map +1 -0
  105. package/lib/draw-canvas-edit/components/render/handlers/key-move-handlers.d.ts +18 -0
  106. package/lib/draw-canvas-edit/components/render/handlers/key-move-handlers.d.ts.map +1 -0
  107. package/lib/draw-canvas-edit/components/render/handlers/key-move-handlers.js +51 -0
  108. package/lib/draw-canvas-edit/components/render/handlers/key-move-handlers.js.map +1 -0
  109. package/lib/draw-canvas-edit/components/render/handlers/link-handlers.d.ts +14 -0
  110. package/lib/draw-canvas-edit/components/render/handlers/link-handlers.d.ts.map +1 -0
  111. package/lib/draw-canvas-edit/components/render/handlers/link-handlers.js +42 -0
  112. package/lib/draw-canvas-edit/components/render/handlers/link-handlers.js.map +1 -0
  113. package/lib/draw-canvas-edit/components/render/handlers/selection-handlers.d.ts +62 -0
  114. package/lib/draw-canvas-edit/components/render/handlers/selection-handlers.d.ts.map +1 -0
  115. package/lib/draw-canvas-edit/components/render/handlers/selection-handlers.js +396 -0
  116. package/lib/draw-canvas-edit/components/render/handlers/selection-handlers.js.map +1 -0
  117. package/lib/draw-canvas-edit/components/render/handlers/shutcut-handlers.d.ts +13 -0
  118. package/lib/draw-canvas-edit/components/render/handlers/shutcut-handlers.d.ts.map +1 -0
  119. package/lib/draw-canvas-edit/components/render/handlers/shutcut-handlers.js +50 -0
  120. package/lib/draw-canvas-edit/components/render/handlers/shutcut-handlers.js.map +1 -0
  121. package/lib/draw-canvas-edit/components/render/handlers/text-handlers.d.ts +24 -0
  122. package/lib/draw-canvas-edit/components/render/handlers/text-handlers.d.ts.map +1 -0
  123. package/lib/draw-canvas-edit/components/render/handlers/text-handlers.js +82 -0
  124. package/lib/draw-canvas-edit/components/render/handlers/text-handlers.js.map +1 -0
  125. package/lib/draw-canvas-edit/components/render/handlers/zoom-handlers.d.ts +17 -0
  126. package/lib/draw-canvas-edit/components/render/handlers/zoom-handlers.d.ts.map +1 -0
  127. package/lib/draw-canvas-edit/components/render/handlers/zoom-handlers.js +55 -0
  128. package/lib/draw-canvas-edit/components/render/handlers/zoom-handlers.js.map +1 -0
  129. package/lib/{draw-canvas/edit → draw-canvas-edit}/components/render/index.d.ts +11 -1
  130. package/lib/draw-canvas-edit/components/render/index.d.ts.map +1 -0
  131. package/lib/{draw-canvas/edit → draw-canvas-edit}/components/render/index.js +42 -14
  132. package/lib/draw-canvas-edit/components/render/index.js.map +1 -0
  133. package/lib/draw-canvas-edit/components/render/tools/align-tool.d.ts +19 -0
  134. package/lib/draw-canvas-edit/components/render/tools/align-tool.d.ts.map +1 -0
  135. package/lib/draw-canvas-edit/components/render/tools/align-tool.js +84 -0
  136. package/lib/draw-canvas-edit/components/render/tools/align-tool.js.map +1 -0
  137. package/lib/draw-canvas-edit/components/render/tools/asset-tool.d.ts +12 -0
  138. package/lib/draw-canvas-edit/components/render/tools/asset-tool.d.ts.map +1 -0
  139. package/lib/draw-canvas-edit/components/render/tools/asset-tool.js +152 -0
  140. package/lib/draw-canvas-edit/components/render/tools/asset-tool.js.map +1 -0
  141. package/lib/draw-canvas-edit/components/render/tools/attract-tool.d.ts +36 -0
  142. package/lib/draw-canvas-edit/components/render/tools/attract-tool.d.ts.map +1 -0
  143. package/lib/draw-canvas-edit/components/render/tools/attract-tool.js +419 -0
  144. package/lib/draw-canvas-edit/components/render/tools/attract-tool.js.map +1 -0
  145. package/lib/draw-canvas-edit/components/render/tools/copy-tool.d.ts +20 -0
  146. package/lib/draw-canvas-edit/components/render/tools/copy-tool.d.ts.map +1 -0
  147. package/lib/draw-canvas-edit/components/render/tools/copy-tool.js +237 -0
  148. package/lib/draw-canvas-edit/components/render/tools/copy-tool.js.map +1 -0
  149. package/lib/draw-canvas-edit/components/render/tools/import-export-tool.d.ts +43 -0
  150. package/lib/draw-canvas-edit/components/render/tools/import-export-tool.d.ts.map +1 -0
  151. package/lib/draw-canvas-edit/components/render/tools/import-export-tool.js +559 -0
  152. package/lib/draw-canvas-edit/components/render/tools/import-export-tool.js.map +1 -0
  153. package/lib/draw-canvas-edit/components/render/tools/index.d.ts +10 -0
  154. package/lib/draw-canvas-edit/components/render/tools/index.d.ts.map +1 -0
  155. package/lib/draw-canvas-edit/components/render/tools/index.js +10 -0
  156. package/lib/draw-canvas-edit/components/render/tools/index.js.map +1 -0
  157. package/lib/draw-canvas-edit/components/render/tools/link-tool.d.ts +15 -0
  158. package/lib/draw-canvas-edit/components/render/tools/link-tool.d.ts.map +1 -0
  159. package/lib/draw-canvas-edit/components/render/tools/link-tool.js +202 -0
  160. package/lib/draw-canvas-edit/components/render/tools/link-tool.js.map +1 -0
  161. package/lib/draw-canvas-edit/components/render/tools/position-tool.d.ts +11 -0
  162. package/lib/draw-canvas-edit/components/render/tools/position-tool.d.ts.map +1 -0
  163. package/lib/draw-canvas-edit/components/render/tools/position-tool.js +183 -0
  164. package/lib/draw-canvas-edit/components/render/tools/position-tool.js.map +1 -0
  165. package/lib/draw-canvas-edit/components/render/tools/selection-tool.d.ts +13 -0
  166. package/lib/draw-canvas-edit/components/render/tools/selection-tool.d.ts.map +1 -0
  167. package/lib/draw-canvas-edit/components/render/tools/selection-tool.js +116 -0
  168. package/lib/draw-canvas-edit/components/render/tools/selection-tool.js.map +1 -0
  169. package/lib/draw-canvas-edit/components/render/tools/z-index-tool.d.ts +18 -0
  170. package/lib/draw-canvas-edit/components/render/tools/z-index-tool.d.ts.map +1 -0
  171. package/lib/draw-canvas-edit/components/render/tools/z-index-tool.js +203 -0
  172. package/lib/draw-canvas-edit/components/render/tools/z-index-tool.js.map +1 -0
  173. package/lib/{draw-canvas/edit → draw-canvas-edit}/components/render/types.d.ts +5 -1
  174. package/lib/draw-canvas-edit/components/render/types.d.ts.map +1 -0
  175. package/lib/draw-canvas-edit/components/render/types.js.map +1 -0
  176. package/lib/draw-canvas-edit/components/render/utils/a-star.d.ts +13 -0
  177. package/lib/draw-canvas-edit/components/render/utils/a-star.d.ts.map +1 -0
  178. package/lib/draw-canvas-edit/components/render/utils/a-star.js +101 -0
  179. package/lib/draw-canvas-edit/components/render/utils/a-star.js.map +1 -0
  180. package/lib/draw-canvas-edit/components/render/utils/bezier-scene-func.d.ts +3 -0
  181. package/lib/draw-canvas-edit/components/render/utils/bezier-scene-func.d.ts.map +1 -0
  182. package/lib/draw-canvas-edit/components/render/utils/bezier-scene-func.js +69 -0
  183. package/lib/draw-canvas-edit/components/render/utils/bezier-scene-func.js.map +1 -0
  184. package/lib/draw-canvas-edit/components/setting-form/imag-upload.d.ts +26 -0
  185. package/lib/draw-canvas-edit/components/setting-form/imag-upload.d.ts.map +1 -0
  186. package/lib/draw-canvas-edit/components/setting-form/imag-upload.js +83 -0
  187. package/lib/draw-canvas-edit/components/setting-form/imag-upload.js.map +1 -0
  188. package/lib/{draw-canvas/edit → draw-canvas-edit}/components/setting-form/index.d.ts +1 -3
  189. package/lib/draw-canvas-edit/components/setting-form/index.d.ts.map +1 -0
  190. package/lib/{draw-canvas/edit → draw-canvas-edit}/components/setting-form/index.js +94 -16
  191. package/lib/draw-canvas-edit/components/setting-form/index.js.map +1 -0
  192. package/lib/draw-canvas-edit/constant.d.ts +7 -0
  193. package/lib/draw-canvas-edit/constant.d.ts.map +1 -0
  194. package/lib/draw-canvas-edit/constant.js +7 -0
  195. package/lib/draw-canvas-edit/constant.js.map +1 -0
  196. package/lib/draw-canvas-edit/index.d.ts +8 -0
  197. package/lib/draw-canvas-edit/index.d.ts.map +1 -0
  198. package/lib/{draw-canvas/edit → draw-canvas-edit}/index.js +63 -10
  199. package/lib/draw-canvas-edit/index.js.map +1 -0
  200. package/{src/aldehyde/draw-canvas/edit → lib/draw-canvas-edit}/index.less +17 -2
  201. package/lib/draw-canvas-view/index.d.ts +8 -0
  202. package/lib/draw-canvas-view/index.d.ts.map +1 -0
  203. package/lib/draw-canvas-view/index.js +50 -0
  204. package/lib/draw-canvas-view/index.js.map +1 -0
  205. package/lib/draw-canvas-view/index.less +60 -0
  206. package/lib/draw-canvas-view/view.d.ts +13 -0
  207. package/lib/draw-canvas-view/view.d.ts.map +1 -0
  208. package/lib/draw-canvas-view/view.js +208 -0
  209. package/lib/draw-canvas-view/view.js.map +1 -0
  210. package/lib/form/form-Item-group.d.ts.map +1 -1
  211. package/lib/form/form-Item-group.js +4 -4
  212. package/lib/form/form-Item-group.js.map +1 -1
  213. package/lib/lowcode-components/index.d.ts +2 -0
  214. package/lib/lowcode-components/index.d.ts.map +1 -1
  215. package/lib/lowcode-components/index.js +2 -1
  216. package/lib/lowcode-components/index.js.map +1 -1
  217. package/lib/lowcode-components/lowcode-view/component/assets.d.ts.map +1 -1
  218. package/lib/lowcode-components/lowcode-view/component/assets.js +8 -0
  219. package/lib/lowcode-components/lowcode-view/component/assets.js.map +1 -1
  220. package/lib/lowcode-components/radar-chart/index.d.ts +51 -0
  221. package/lib/lowcode-components/radar-chart/index.d.ts.map +1 -0
  222. package/lib/lowcode-components/radar-chart/index.js +276 -0
  223. package/lib/lowcode-components/radar-chart/index.js.map +1 -0
  224. package/lib/module/dtmpl-edit-card.d.ts.map +1 -1
  225. package/lib/module/dtmpl-edit-card.js +18 -1
  226. package/lib/module/dtmpl-edit-card.js.map +1 -1
  227. package/lib/module/dtmpl-edit-page.d.ts.map +1 -1
  228. package/lib/module/dtmpl-edit-page.js +19 -2
  229. package/lib/module/dtmpl-edit-page.js.map +1 -1
  230. package/lib/routable/ltmpl-route.d.ts +2 -0
  231. package/lib/routable/ltmpl-route.d.ts.map +1 -1
  232. package/lib/routable/ltmpl-route.js +20 -4
  233. package/lib/routable/ltmpl-route.js.map +1 -1
  234. package/lib/table/act-table.d.ts +2 -0
  235. package/lib/table/act-table.d.ts.map +1 -1
  236. package/lib/table/act-table.js +4 -4
  237. package/lib/table/act-table.js.map +1 -1
  238. package/lib/table/column/column-builder.d.ts.map +1 -1
  239. package/lib/table/column/column-builder.js +23 -8
  240. package/lib/table/column/column-builder.js.map +1 -1
  241. package/lib/table/relation-table.d.ts +3 -0
  242. package/lib/table/relation-table.d.ts.map +1 -1
  243. package/lib/tmpl/control-type-supportor.d.ts.map +1 -1
  244. package/lib/tmpl/control-type-supportor.js +1 -0
  245. package/lib/tmpl/control-type-supportor.js.map +1 -1
  246. package/lib/tmpl/hcservice-v3.d.ts +2 -0
  247. package/lib/tmpl/hcservice-v3.d.ts.map +1 -1
  248. package/lib/tmpl/hcservice-v3.js +34 -0
  249. package/lib/tmpl/hcservice-v3.js.map +1 -1
  250. package/lib/tmpl/interface.d.ts +13 -1
  251. package/lib/tmpl/interface.d.ts.map +1 -1
  252. package/lib/tmpl/interface.js.map +1 -1
  253. package/lib/tmpl/tmpl-config-analysis.js +1 -1
  254. package/lib/tmpl/tmpl-config-analysis.js.map +1 -1
  255. package/lib/units/index.d.ts +2 -1
  256. package/lib/units/index.d.ts.map +1 -1
  257. package/lib/units/index.js +17 -3
  258. package/lib/units/index.js.map +1 -1
  259. package/package.json +4 -1
  260. package/src/aldehyde/controls/entity-select/entity-select.tsx +18 -8
  261. package/src/aldehyde/controls/entry-control.tsx +1 -0
  262. package/src/aldehyde/controls/select/index.tsx +7 -6
  263. package/src/aldehyde/controls/text/index.less +1 -0
  264. package/src/aldehyde/controls/view-control.tsx +1 -0
  265. package/src/aldehyde/detail/button/edit-button.tsx +21 -22
  266. package/src/aldehyde/detail/button/view-button.tsx +23 -21
  267. package/src/aldehyde/{draw-canvas/edit → draw-canvas-edit}/components/asset-bar/index.tsx +4 -2
  268. package/src/aldehyde/{draw-canvas/edit → draw-canvas-edit}/components/main-header/index.tsx +60 -14
  269. package/src/aldehyde/draw-canvas-edit/components/render/draws/bg-draw.ts +163 -0
  270. package/src/aldehyde/{draw-canvas/edit → draw-canvas-edit}/components/render/draws/preview-draw.ts +33 -15
  271. package/src/aldehyde/{draw-canvas/edit → draw-canvas-edit}/components/render/handlers/drag-outside-handlers.ts +19 -22
  272. package/src/aldehyde/{draw-canvas/edit → draw-canvas-edit}/components/render/handlers/selection-handlers.ts +38 -30
  273. package/src/aldehyde/{draw-canvas/edit → draw-canvas-edit}/components/render/index.ts +41 -9
  274. package/src/aldehyde/{draw-canvas/edit → draw-canvas-edit}/components/render/tools/position-tool.ts +40 -58
  275. package/src/aldehyde/{draw-canvas/edit → draw-canvas-edit}/components/render/types.ts +5 -1
  276. package/src/aldehyde/draw-canvas-edit/components/setting-form/imag-upload.tsx +118 -0
  277. package/src/aldehyde/{draw-canvas/edit → draw-canvas-edit}/components/setting-form/index.tsx +111 -17
  278. package/src/aldehyde/draw-canvas-edit/constant.ts +6 -0
  279. package/{lib/draw-canvas/edit → src/aldehyde/draw-canvas-edit}/index.less +17 -2
  280. package/src/aldehyde/{draw-canvas/edit → draw-canvas-edit}/index.tsx +84 -25
  281. package/src/aldehyde/draw-canvas-view/index.less +60 -0
  282. package/src/aldehyde/draw-canvas-view/index.tsx +48 -0
  283. package/src/aldehyde/draw-canvas-view/view.tsx +212 -0
  284. package/src/aldehyde/form/form-Item-group.tsx +4 -5
  285. package/src/aldehyde/lowcode-components/index.ts +4 -2
  286. package/src/aldehyde/lowcode-components/lowcode-view/component/assets.ts +8 -0
  287. package/src/aldehyde/lowcode-components/radar-chart/index.tsx +323 -0
  288. package/src/aldehyde/module/dtmpl-edit-card.tsx +18 -1
  289. package/src/aldehyde/module/dtmpl-edit-page.tsx +19 -2
  290. package/src/aldehyde/routable/ltmpl-route.tsx +39 -3
  291. package/src/aldehyde/table/act-table.tsx +7 -4
  292. package/src/aldehyde/table/column/column-builder.tsx +29 -9
  293. package/src/aldehyde/tmpl/control-type-supportor.tsx +1 -0
  294. package/src/aldehyde/tmpl/hcservice-v3.tsx +30 -0
  295. package/src/aldehyde/tmpl/interface.tsx +13 -1
  296. package/src/aldehyde/tmpl/tmpl-config-analysis.tsx +1 -1
  297. package/src/aldehyde/units/index.tsx +17 -4
  298. package/lib/draw-canvas/edit/components/asset-bar/index.d.ts.map +0 -1
  299. package/lib/draw-canvas/edit/components/asset-bar/index.js.map +0 -1
  300. package/lib/draw-canvas/edit/components/main-header/index.d.ts.map +0 -1
  301. package/lib/draw-canvas/edit/components/main-header/index.js.map +0 -1
  302. package/lib/draw-canvas/edit/components/render/index.d.ts.map +0 -1
  303. package/lib/draw-canvas/edit/components/render/index.js.map +0 -1
  304. package/lib/draw-canvas/edit/components/render/types.d.ts.map +0 -1
  305. package/lib/draw-canvas/edit/components/render/types.js.map +0 -1
  306. package/lib/draw-canvas/edit/components/setting-form/index.d.ts.map +0 -1
  307. package/lib/draw-canvas/edit/components/setting-form/index.js.map +0 -1
  308. package/lib/draw-canvas/edit/index.d.ts +0 -5
  309. package/lib/draw-canvas/edit/index.d.ts.map +0 -1
  310. package/lib/draw-canvas/edit/index.js.map +0 -1
  311. package/src/aldehyde/draw-canvas/edit/components/render/draws/bg-draw.ts +0 -98
  312. /package/lib/{draw-canvas/edit → draw-canvas-edit}/components/asset-bar/index.d.ts +0 -0
  313. /package/lib/{draw-canvas/edit → draw-canvas-edit}/components/asset-bar/index.less +0 -0
  314. /package/lib/{draw-canvas/edit → draw-canvas-edit}/components/main-header/index.less +0 -0
  315. /package/lib/{draw-canvas/edit → draw-canvas-edit}/components/render/types.js +0 -0
  316. /package/src/aldehyde/{draw-canvas/edit → draw-canvas-edit}/components/asset-bar/index.less +0 -0
  317. /package/src/aldehyde/{draw-canvas/edit → draw-canvas-edit}/components/main-header/index.less +0 -0
  318. /package/src/aldehyde/{draw-canvas/edit → draw-canvas-edit}/components/render/draws/contextmenu-draw.ts +0 -0
  319. /package/src/aldehyde/{draw-canvas/edit → draw-canvas-edit}/components/render/draws/graph-draw.ts +0 -0
  320. /package/src/aldehyde/{draw-canvas/edit → draw-canvas-edit}/components/render/draws/index.ts +0 -0
  321. /package/src/aldehyde/{draw-canvas/edit → draw-canvas-edit}/components/render/draws/link-draw.ts +0 -0
  322. /package/src/aldehyde/{draw-canvas/edit → draw-canvas-edit}/components/render/draws/ref-line-draw.ts +0 -0
  323. /package/src/aldehyde/{draw-canvas/edit → draw-canvas-edit}/components/render/draws/ruler-draw.ts +0 -0
  324. /package/src/aldehyde/{draw-canvas/edit → draw-canvas-edit}/components/render/graphs/base-graph.ts +0 -0
  325. /package/src/aldehyde/{draw-canvas/edit → draw-canvas-edit}/components/render/graphs/bezier.ts +0 -0
  326. /package/src/aldehyde/{draw-canvas/edit → draw-canvas-edit}/components/render/graphs/circle.ts +0 -0
  327. /package/src/aldehyde/{draw-canvas/edit → draw-canvas-edit}/components/render/graphs/curve.ts +0 -0
  328. /package/src/aldehyde/{draw-canvas/edit → draw-canvas-edit}/components/render/graphs/index.ts +0 -0
  329. /package/src/aldehyde/{draw-canvas/edit → draw-canvas-edit}/components/render/graphs/line.ts +0 -0
  330. /package/src/aldehyde/{draw-canvas/edit → draw-canvas-edit}/components/render/graphs/rect.ts +0 -0
  331. /package/src/aldehyde/{draw-canvas/edit → draw-canvas-edit}/components/render/handlers/drag-handlers.ts +0 -0
  332. /package/src/aldehyde/{draw-canvas/edit → draw-canvas-edit}/components/render/handlers/graph-handlers.ts +0 -0
  333. /package/src/aldehyde/{draw-canvas/edit → draw-canvas-edit}/components/render/handlers/index.ts +0 -0
  334. /package/src/aldehyde/{draw-canvas/edit → draw-canvas-edit}/components/render/handlers/key-move-handlers.ts +0 -0
  335. /package/src/aldehyde/{draw-canvas/edit → draw-canvas-edit}/components/render/handlers/link-handlers.ts +0 -0
  336. /package/src/aldehyde/{draw-canvas/edit → draw-canvas-edit}/components/render/handlers/shutcut-handlers.ts +0 -0
  337. /package/src/aldehyde/{draw-canvas/edit → draw-canvas-edit}/components/render/handlers/text-handlers.ts +0 -0
  338. /package/src/aldehyde/{draw-canvas/edit → draw-canvas-edit}/components/render/handlers/zoom-handlers.ts +0 -0
  339. /package/src/aldehyde/{draw-canvas/edit → draw-canvas-edit}/components/render/tools/align-tool.ts +0 -0
  340. /package/src/aldehyde/{draw-canvas/edit → draw-canvas-edit}/components/render/tools/asset-tool.ts +0 -0
  341. /package/src/aldehyde/{draw-canvas/edit → draw-canvas-edit}/components/render/tools/attract-tool.ts +0 -0
  342. /package/src/aldehyde/{draw-canvas/edit → draw-canvas-edit}/components/render/tools/copy-tool.ts +0 -0
  343. /package/src/aldehyde/{draw-canvas/edit → draw-canvas-edit}/components/render/tools/import-export-tool.ts +0 -0
  344. /package/src/aldehyde/{draw-canvas/edit → draw-canvas-edit}/components/render/tools/index.ts +0 -0
  345. /package/src/aldehyde/{draw-canvas/edit → draw-canvas-edit}/components/render/tools/link-tool.ts +0 -0
  346. /package/src/aldehyde/{draw-canvas/edit → draw-canvas-edit}/components/render/tools/selection-tool.ts +0 -0
  347. /package/src/aldehyde/{draw-canvas/edit → draw-canvas-edit}/components/render/tools/z-index-tool.ts +0 -0
  348. /package/src/aldehyde/{draw-canvas/edit → draw-canvas-edit}/components/render/utils/a-star.ts +0 -0
  349. /package/src/aldehyde/{draw-canvas/edit → draw-canvas-edit}/components/render/utils/bezier-scene-func.ts +0 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../../src/aldehyde/draw-canvas-edit/components/main-header/index.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAoD,MAAM,OAAO,CAAC;AAOzE,OAAO,EAAE,MAAM,EAAE,MAAM,WAAW,CAAC;AACnC,OAAO,EAAE,SAAS,EAAuB,MAAM,iBAAiB,CAAC;AAEjE,OAAO,cAAc,CAAC;AA2BtB,UAAU,eAAe;IACvB,MAAM,EAAE,MAAM,GAAG,IAAI,CAAC;IACtB,SAAS,CAAC,EAAE,SAAS,CAAC;IACtB,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,iBAAiB,EAAE,CAAC,IAAI,EAAE,SAAS,GAAG,SAAS,KAAK,IAAI,CAAC;IACzD,SAAS,EAAE,CAAC,OAAO,EAAE,OAAO,KAAK,IAAI,CAAC;IACtC,WAAW,CAAC,EAAE,CAAC,IAAI,EAAE,OAAO,KAAK,IAAI,CAAC;IACtC,cAAc,CAAC,EAAE,CAAC,IAAI,EAAE,OAAO,KAAK,IAAI,CAAC;IACzC,UAAU,EAAE,MAAM,CAAC;CACpB;AAED,QAAA,MAAM,UAAU,GAAI,OAAO,eAAe,sBAoLzC,CAAA;AAED,eAAe,UAAU,CAAC"}
@@ -9,7 +9,11 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
9
9
  };
10
10
  import React, { useState, useEffect, useCallback, useMemo } from 'react';
11
11
  import { Dropdown, Modal, Space, Button, Divider, Tooltip } from 'antd';
12
- import IconFont from "../../../../icon/aliIcon";
12
+ import { ImportOutlined, ExportOutlined, SaveOutlined, QuestionCircleOutlined, MergeCellsOutlined, NumberOutlined } from '@ant-design/icons';
13
+ import { gzipSync, strToU8 } from 'fflate';
14
+ import { uint8ArrayToHex } from 'uint8array-extras';
15
+ import HcserviceV3 from "../../../tmpl/hcservice-v3";
16
+ import IconFont from "../../../icon/aliIcon";
13
17
  import * as Draws from '../render/draws';
14
18
  import './index.less';
15
19
  // 布局类型
@@ -35,7 +39,7 @@ const graphTypes = [
35
39
  { label: '圆', value: 'Circle', icon: 'icon-circle' },
36
40
  ];
37
41
  const MainHeader = (props) => {
38
- const { render, graphType, onGraphTypeChange, onTexting, texting } = props;
42
+ const { render, graphType, onGraphTypeChange, onTexting, texting, recordCode, showGrid, setShowGrid, showAttract, setShowAttract } = props;
39
43
  const [scale, setScale] = useState(100); // 缩放
40
44
  const [history, setHistory] = useState([]); // 历史记录
41
45
  const [historyIndex, setHistoryIndex] = useState(-1); // 当前历史记录标签
@@ -64,18 +68,38 @@ const MainHeader = (props) => {
64
68
  };
65
69
  input.click();
66
70
  }, [render]);
71
+ // 保存
72
+ const handleSave = () => __awaiter(void 0, void 0, void 0, function* () {
73
+ if (!recordCode) {
74
+ return;
75
+ }
76
+ setLoading(true);
77
+ const data = render.importExportTool.save();
78
+ // 1. 将普通字符串转换为 Uint8Array
79
+ const dataBuffer = strToU8(data);
80
+ // 2. 压缩为 ByteArray
81
+ const content = gzipSync(dataBuffer, { level: 9 });
82
+ // 3. 将 Uint8Array 转为 16进制字符串
83
+ const hexString = uint8ArrayToHex(content);
84
+ yield HcserviceV3.postDiagram2DConfig(recordCode, hexString);
85
+ setLoading(false);
86
+ });
67
87
  // 数据导出
68
- const handleSave = useCallback((type) => {
88
+ const handleExport = useCallback((type, action) => {
69
89
  if (!render)
70
90
  return;
71
- const data = [];
72
91
  switch (type) {
73
92
  case 'json':
74
- data.push({ name: 'data.json', content: render.importExportTool.save() });
75
- break;
93
+ if (action === "save") {
94
+ handleSave();
95
+ }
96
+ else {
97
+ download("data.json", render.importExportTool.save());
98
+ }
99
+ return;
76
100
  case 'asset':
77
- data.push({ name: 'asset.json', content: render.importExportTool.getAsset() });
78
- break;
101
+ download("asset.json", render.importExportTool.getAsset());
102
+ return;
79
103
  case 'png':
80
104
  download('image.png', render.importExportTool.getAssetImage(2));
81
105
  return;
@@ -83,9 +107,6 @@ const MainHeader = (props) => {
83
107
  download('image.png', render.importExportTool.getAssetImage());
84
108
  return;
85
109
  }
86
- if (data.length) {
87
- data.forEach(({ name, content }) => download(name, content));
88
- }
89
110
  }, [render]);
90
111
  // 下载辅助函数
91
112
  const download = (name, content) => {
@@ -129,8 +150,8 @@ const MainHeader = (props) => {
129
150
  const isSelects = useMemo(() => selection.length <= 1, [selection]);
130
151
  // 缩放菜单选项
131
152
  const scaleMenu = [
132
- { key: "fit", label: React.createElement("a", { onClick: () => handleScale('fit') }, "\u81EA\u9002\u5E94\u5927\u5C0F") },
133
- { key: "reset", label: React.createElement("a", { onClick: () => handleScale('reset') }, "\u91CD\u7F6E\u4F4D\u7F6E\u5927\u5C0F") },
153
+ { key: "fit", label: React.createElement("a", { onClick: () => handleScale('fit') }, "\u81EA\u9002\u5E94") },
154
+ { key: "reset", label: React.createElement("a", { onClick: () => handleScale('reset') }, "\u91CD\u7F6E\u4F4D\u7F6E\u53CA\u7F29\u653E") },
134
155
  { key: "position", label: React.createElement("a", { onClick: () => handleScale('position') }, "\u4EC5\u91CD\u7F6E\u4F4D\u7F6E") }
135
156
  ];
136
157
  return (React.createElement("div", { className: "main-header" },
@@ -152,9 +173,28 @@ const MainHeader = (props) => {
152
173
  React.createElement(IconFont, { type: type.icon }))))),
153
174
  React.createElement(Tooltip, { title: "\u63D2\u5165\u6587\u5B57" },
154
175
  React.createElement(Button, { type: "text", onClick: () => onTexting(true), className: texting ? "active" : "" },
155
- React.createElement(IconFont, { type: "icon-wenben" })))),
176
+ React.createElement(IconFont, { type: "icon-wenben" }))),
177
+ React.createElement(Tooltip, { title: "\u7F51\u683C" },
178
+ React.createElement(Button, { type: "text", onClick: () => setShowGrid(!showGrid), className: showGrid ? "active" : "" },
179
+ React.createElement(NumberOutlined, null))),
180
+ React.createElement(Tooltip, { title: "\u78C1\u5438" },
181
+ React.createElement(Button, { type: "text", onClick: () => setShowAttract(!showAttract), className: showAttract ? "active" : "" },
182
+ React.createElement(MergeCellsOutlined, null)))),
183
+ React.createElement(Space, { size: 4, separator: React.createElement(Divider, { vertical: true, styles: { root: { margin: "0 4px" } } }) },
184
+ React.createElement(Tooltip, { title: "\u5FEB\u6377\u952E" },
185
+ React.createElement(Button, { type: "text", onClick: () => setShowShortCut(true) },
186
+ React.createElement(QuestionCircleOutlined, null))),
187
+ React.createElement(Tooltip, { title: "\u5BFC\u5165" },
188
+ React.createElement(Button, { type: "text", onClick: handleRestore },
189
+ React.createElement(ImportOutlined, null))),
190
+ React.createElement(Tooltip, { title: "\u5BFC\u51FA" },
191
+ React.createElement(Button, { type: "text", onClick: () => handleExport("json") },
192
+ React.createElement(ExportOutlined, null))),
193
+ React.createElement(Tooltip, { title: "\u4FDD\u5B58" },
194
+ React.createElement(Button, { loading: loading, type: "text", onClick: () => handleExport("json", "save") },
195
+ React.createElement(SaveOutlined, null)))),
156
196
  showShortCut &&
157
- React.createElement(Modal, { title: "\u5FEB\u6377\u952E", open: showShortCut, onCancel: () => setShowShortCut(false) },
197
+ React.createElement(Modal, { title: "\u5FEB\u6377\u952E", width: 600, footer: null, open: showShortCut, onCancel: () => setShowShortCut(false) },
158
198
  React.createElement("p", null, "1\u3001\u590D\u5236\u3001\u7C98\u8D34\u3001\u591A\u9009\u3001\u5168\u9009\u3001\u5220\u9664\u3001\u4E0A\u4E00\u6B65\u3001\u4E0B\u4E00\u6B65\u7B49\u5FEB\u6377\u952E\u4E0E\u4E00\u822C\u6587\u6863\u7F16\u8F91\u5668\u7C7B\u4F3C\uFF1B"),
159
199
  React.createElement("p", null, "2\u3001\u653E\u5927\u7F29\u5C0F\uFF0C\u3010Win\u3011\u9F20\u6807\u4E0A\u6EDA\u52A8\u4E0B\u6EDA\u52A8\uFF0C\u3010Mac\u3011\u89E6\u63A7\u677F\u53CC\u6307\u653E\u5927\u3001\u7F29\u5C0F\uFF1B"),
160
200
  React.createElement("p", null, "3\u3001\u753B\u5E03\u62D6\u52A8\uFF0C\u5728\u7A7A\u767D\u5904\uFF0C\u3010Win\u3011\u53F3\u952E\u6309\u4E0B\u79FB\u52A8\uFF0C\u3010Mac\u3011control + \u89E6\u63A7\u677F\u4E09\u6307\u79FB\u52A8\uFF1B"))));
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../src/aldehyde/draw-canvas-edit/components/main-header/index.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,26 @@
1
+ import Konva from 'konva';
2
+ import { Draw, BaseDraw, Render } from '../types';
3
+ export interface BgDrawOption {
4
+ size: number;
5
+ readonly?: boolean;
6
+ showGrid?: boolean;
7
+ }
8
+ export declare class BgDraw extends BaseDraw implements Draw {
9
+ static readonly name = "bg";
10
+ option: BgDrawOption;
11
+ private staticGroup;
12
+ private gridGroup;
13
+ private isStaticInitialized;
14
+ constructor(render: Render, layer: Konva.Layer, option: BgDrawOption);
15
+ updateOption(newOption: Partial<BgDrawOption>): void;
16
+ draw(): void;
17
+ /**
18
+ * 渲染静态元素(仅在初始化或配置改变时执行)
19
+ */
20
+ private renderStaticElements;
21
+ /**
22
+ * 渲染网格(每次拖拽/缩放时调用)
23
+ */
24
+ private renderGrid;
25
+ }
26
+ //# sourceMappingURL=bg-draw.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"bg-draw.d.ts","sourceRoot":"","sources":["../../../../../../../src/aldehyde/draw-canvas-edit/components/render/draws/bg-draw.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,IAAI,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAIlD,MAAM,WAAW,YAAY;IAC3B,IAAI,EAAE,MAAM,CAAC;IACb,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB;AAED,qBAAa,MAAO,SAAQ,QAAS,YAAW,IAAI;IAElD,gBAAyB,IAAI,QAAQ;IACrC,MAAM,EAAE,YAAY,CAAC;IAGrB,OAAO,CAAC,WAAW,CAAc;IAEjC,OAAO,CAAC,SAAS,CAAc;IAE/B,OAAO,CAAC,mBAAmB,CAAkB;gBAEjC,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,KAAK,CAAC,KAAK,EAAE,MAAM,EAAE,YAAY;IAsB7D,YAAY,CAAC,SAAS,EAAE,OAAO,CAAC,YAAY,CAAC;IAK3C,IAAI;IAcb;;OAEG;IACH,OAAO,CAAC,oBAAoB;IAoD5B;;OAEG;IACH,OAAO,CAAC,UAAU;CAwCnB"}
@@ -0,0 +1,135 @@
1
+ import Konva from 'konva';
2
+ import { BaseDraw } from '../types';
3
+ export class BgDraw extends BaseDraw {
4
+ constructor(render, layer, option) {
5
+ super(render, layer);
6
+ // 标记静态元素是否需要重绘
7
+ this.isStaticInitialized = false;
8
+ this.option = option;
9
+ this.group.listening(false);
10
+ // 预先创建好两个独立的 Group
11
+ this.staticGroup = new Konva.Group({ name: 'bg-static', listening: false });
12
+ this.gridGroup = new Konva.Group({ name: 'bg-grid', listening: false });
13
+ // 注意添加顺序:静态在下,网格在上
14
+ this.group.add(this.staticGroup);
15
+ this.group.add(this.gridGroup);
16
+ // 监听页面配置变化,当配置改变时,重置静态层初始化状态
17
+ this.render.on('page-settings-change', () => {
18
+ this.isStaticInitialized = false;
19
+ // 触发整体重绘,让 draw 方法重新执行
20
+ this.draw();
21
+ });
22
+ }
23
+ // 更新配置项,触发重绘
24
+ updateOption(newOption) {
25
+ this.option = Object.assign(Object.assign({}, this.option), newOption);
26
+ this.draw();
27
+ }
28
+ draw() {
29
+ // 1. 如果静态元素未初始化,或者配置发生变化导致标记被重置,则重新绘制
30
+ if (!this.isStaticInitialized) {
31
+ this.renderStaticElements();
32
+ this.isStaticInitialized = true;
33
+ }
34
+ // 2. 仅重绘网格部分(拖拽/缩放时高频调用)
35
+ if (!this.option.readonly && this.option.showGrid) { // 只读页面不显示网格
36
+ this.renderGrid();
37
+ }
38
+ else { // 清除已渲染网格
39
+ this.gridGroup.destroyChildren();
40
+ }
41
+ }
42
+ /**
43
+ * 渲染静态元素(仅在初始化或配置改变时执行)
44
+ */
45
+ renderStaticElements() {
46
+ // 清除旧的静态元素
47
+ this.staticGroup.destroyChildren();
48
+ const { width, height, x, y } = this.render.getStageState();
49
+ const { pageWidth, pageHeight, background, backgroundImg } = this.render.getPageSettings();
50
+ // 背景层(填满整个 stage)
51
+ const bgRect = new Konva.Rect({
52
+ name: `${this.constructor.name}__background`,
53
+ x: this.render.toStageValue(-x + this.render.rulerSize),
54
+ y: this.render.toStageValue(-y + this.render.rulerSize),
55
+ width: this.render.toStageValue(width),
56
+ height: this.render.toStageValue(height),
57
+ listening: false,
58
+ fill: 'transparent'
59
+ });
60
+ // 画布边框
61
+ const canvas = new Konva.Rect({
62
+ name: this.constructor.name,
63
+ x: 0,
64
+ y: 0,
65
+ width: pageWidth,
66
+ height: pageHeight,
67
+ stroke: this.option.readonly ? "transparent" : 'rgba(255,0,0,0.3)',
68
+ strokeWidth: this.render.toStageValue(2),
69
+ listening: false,
70
+ dash: [this.render.toStageValue(6), this.render.toStageValue(6)],
71
+ fill: background || 'transparent',
72
+ });
73
+ this.staticGroup.add(bgRect);
74
+ this.staticGroup.add(canvas);
75
+ // 处理背景图(异步)
76
+ if (backgroundImg === null || backgroundImg === void 0 ? void 0 : backgroundImg.src) {
77
+ const img = new Image();
78
+ img.crossOrigin = 'anonymous'; // 如果图片在 CDN 上,必须加上此属性防止跨域问题
79
+ img.src = backgroundImg.src;
80
+ img.onload = () => {
81
+ canvas.fill(null);
82
+ canvas.fillPatternImage(img);
83
+ canvas.fillPatternRepeat('no-repeat');
84
+ // 让图片自适应填满矩形(等比缩放裁剪效果)
85
+ const scaleX = pageWidth / img.width;
86
+ const scaleY = pageHeight / img.height;
87
+ canvas.fillPatternScaleX(scaleX);
88
+ canvas.fillPatternScaleY(scaleY);
89
+ };
90
+ }
91
+ }
92
+ /**
93
+ * 渲染网格(每次拖拽/缩放时调用)
94
+ */
95
+ renderGrid() {
96
+ // 仅清空网格 Group,不影响静态层
97
+ this.gridGroup.destroyChildren();
98
+ const { width, height, x, y } = this.render.getStageState();
99
+ const cellSize = this.option.size;
100
+ const lenX = Math.ceil(this.render.toStageValue(width + this.render.rulerSize) / cellSize);
101
+ const lenY = Math.ceil(this.render.toStageValue(height + this.render.rulerSize) / cellSize);
102
+ const startX = -Math.ceil(this.render.toStageValue(x) / cellSize);
103
+ const startY = -Math.ceil(this.render.toStageValue(y) / cellSize);
104
+ const lines = [];
105
+ // 生成竖线
106
+ for (let i = startX; i < lenX + startX + 2; i++) {
107
+ lines.push(new Konva.Line({
108
+ points: [
109
+ cellSize * i, this.render.toStageValue(-y + this.render.rulerSize),
110
+ cellSize * i, this.render.toStageValue(height - y + this.render.rulerSize)
111
+ ],
112
+ stroke: '#ddd',
113
+ strokeWidth: this.render.toStageValue(1),
114
+ listening: false
115
+ }));
116
+ }
117
+ // 生成横线
118
+ for (let j = startY; j < lenY + startY + 2; j++) {
119
+ lines.push(new Konva.Line({
120
+ points: [
121
+ this.render.toStageValue(-x + this.render.rulerSize), cellSize * j,
122
+ this.render.toStageValue(width - x + this.render.rulerSize), cellSize * j
123
+ ],
124
+ stroke: '#ddd',
125
+ strokeWidth: this.render.toStageValue(1),
126
+ listening: false
127
+ }));
128
+ }
129
+ // 批量添加线条到网格 Group
130
+ this.gridGroup.add(...lines);
131
+ }
132
+ }
133
+ // @ts-ignore
134
+ BgDraw.name = 'bg';
135
+ //# sourceMappingURL=bg-draw.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"bg-draw.js","sourceRoot":"","sources":["../../../../../../../src/aldehyde/draw-canvas-edit/components/render/draws/bg-draw.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,26 @@
1
+ import Konva from 'konva';
2
+ import { BaseDraw, Draw, Render } from '../types';
3
+ export interface ContextmenuDrawOption {
4
+ }
5
+ export declare class ContextmenuDraw extends BaseDraw implements Draw {
6
+ static readonly name = "contextmenu";
7
+ option: ContextmenuDrawOption;
8
+ state: {
9
+ target: Konva.Node | null;
10
+ menuIsMousedown: boolean;
11
+ lastPos: Konva.Vector2d | null;
12
+ right: boolean;
13
+ };
14
+ constructor(render: Render, layer: Konva.Layer, option: ContextmenuDrawOption);
15
+ draw(): void;
16
+ handlers: {
17
+ stage: {
18
+ mousedown: (e: Konva.KonvaEventObject<GlobalEventHandlersEventMap["mousedown"]>) => void;
19
+ mousemove: () => void;
20
+ mouseup: () => void;
21
+ contextmenu: (e: Konva.KonvaEventObject<GlobalEventHandlersEventMap["contextmenu"]>) => void;
22
+ wheel: () => void;
23
+ };
24
+ };
25
+ }
26
+ //# sourceMappingURL=contextmenu-draw.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"contextmenu-draw.d.ts","sourceRoot":"","sources":["../../../../../../../src/aldehyde/draw-canvas-edit/components/render/draws/contextmenu-draw.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,QAAQ,EAAE,IAAI,EAAE,MAAM,EAAe,MAAM,UAAU,CAAC;AAK/D,MAAM,WAAW,qBAAqB;CAAI;AAE1C,qBAAa,eAAgB,SAAQ,QAAS,YAAW,IAAI;IAE3D,gBAAyB,IAAI,iBAAiB;IAC9C,MAAM,EAAE,qBAAqB,CAAC;IAC9B,KAAK,EAAE;QACL,MAAM,EAAE,KAAK,CAAC,IAAI,GAAG,IAAI,CAAC;QAC1B,eAAe,EAAE,OAAO,CAAC;QACzB,OAAO,EAAE,KAAK,CAAC,QAAQ,GAAG,IAAI,CAAC;QAC/B,KAAK,EAAE,OAAO,CAAC;KAChB,CAAA;gBAEW,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,KAAK,CAAC,KAAK,EAAE,MAAM,EAAE,qBAAqB;IAMpE,IAAI;IA4Nb,QAAQ;;2BAEW,KAAK,CAAC,gBAAgB,CAAC,2BAA2B,CAAC,WAAW,CAAC,CAAC;;;6BAwB9D,KAAK,CAAC,gBAAgB,CAAC,2BAA2B,CAAC,aAAa,CAAC,CAAC;;;MAkCtF;CACF"}
@@ -0,0 +1,293 @@
1
+ import Konva from 'konva';
2
+ import { BaseDraw, MouseButton } from '../types';
3
+ import { LinkDraw } from '../draws';
4
+ export class ContextmenuDraw extends BaseDraw {
5
+ constructor(render, layer, option) {
6
+ super(render, layer);
7
+ this.handlers = {
8
+ stage: {
9
+ mousedown: (e) => {
10
+ this.state.lastPos = this.render.stage.getPointerPosition();
11
+ if (e.evt.button === MouseButton.左键) {
12
+ if (!this.state.menuIsMousedown) {
13
+ // 没有按下菜单,清除菜单
14
+ this.state.target = null;
15
+ this.draw();
16
+ }
17
+ }
18
+ else if (e.evt.button === MouseButton.右键 && !e.evt.ctrlKey) {
19
+ // (判断 ctrlKey 为了排查 mac 拖动快捷键)
20
+ // 右键按下
21
+ this.state.right = true;
22
+ }
23
+ },
24
+ mousemove: () => {
25
+ if (this.state.target && this.state.right) {
26
+ // 拖动画布时(右键),清除菜单
27
+ this.state.target = null;
28
+ this.draw();
29
+ }
30
+ },
31
+ mouseup: () => {
32
+ this.state.right = false;
33
+ },
34
+ contextmenu: (e) => {
35
+ // (判断 ctrlKey 为了排查 mac 拖动快捷键)
36
+ if (!e.evt.ctrlKey) {
37
+ const pos = this.render.stage.getPointerPosition();
38
+ if (pos && this.state.lastPos) {
39
+ const linkGroup = this.render.layerCover.find(`.${LinkDraw.name}`)[0];
40
+ // 右键目标可能为 连接线
41
+ let lineSelection = null;
42
+ if (linkGroup) {
43
+ const linkLines = linkGroup.find('.link-line');
44
+ for (const line of linkLines) {
45
+ if (Konva.Util.haveIntersection(Object.assign(Object.assign({}, pos), { width: 1, height: 1 }), line.getClientRect())) {
46
+ // 右键目标为 连接线
47
+ lineSelection = line;
48
+ break;
49
+ }
50
+ }
51
+ }
52
+ if (pos.x === this.state.lastPos.x || pos.y === this.state.lastPos.y) {
53
+ // 右键 连接线/其它目标
54
+ this.state.target = lineSelection !== null && lineSelection !== void 0 ? lineSelection : e.target;
55
+ }
56
+ else {
57
+ this.state.target = null;
58
+ }
59
+ this.draw();
60
+ }
61
+ }
62
+ },
63
+ wheel: () => {
64
+ // 画布缩放时,清除菜单
65
+ this.state.target = null;
66
+ this.draw();
67
+ }
68
+ }
69
+ };
70
+ this.option = option;
71
+ this.state = { target: null, menuIsMousedown: false, lastPos: null, right: false };
72
+ }
73
+ draw() {
74
+ this.clear();
75
+ if (this.state.target) {
76
+ // 菜单数组
77
+ const menus = [];
78
+ if (this.state.target === this.render.stage) {
79
+ // 空白处
80
+ menus.push({
81
+ name: '自适应大小',
82
+ action: () => this.render.positionTool.positionFit()
83
+ });
84
+ menus.push({
85
+ name: '恢复位置',
86
+ action: () => this.render.positionTool.positionReset()
87
+ });
88
+ menus.push({
89
+ name: '恢复大小位置',
90
+ action: () => this.render.positionTool.positionZoomReset()
91
+ });
92
+ }
93
+ else if (!this.render.config.readonly) {
94
+ if (this.state.target.name() === 'link-line') {
95
+ menus.push({
96
+ name: '删除', // 删除连接线
97
+ action: () => this.render.linkTool.remove(this.state.target)
98
+ });
99
+ }
100
+ else {
101
+ // 未选择:真实节点,即素材的容器 group
102
+ // 已选择:transformer
103
+ const target = this.state.target.parent;
104
+ // 目标
105
+ menus.push({
106
+ name: '复制',
107
+ action: () => {
108
+ if (target) {
109
+ this.render.copyTool.copy([target]);
110
+ }
111
+ }
112
+ });
113
+ menus.push({
114
+ name: '删除',
115
+ action: () => {
116
+ if (target) {
117
+ this.render.remove([target]);
118
+ }
119
+ }
120
+ });
121
+ menus.push({
122
+ name: '上移',
123
+ action: () => {
124
+ if (target) {
125
+ this.render.zIndexTool.up([target]);
126
+ }
127
+ }
128
+ });
129
+ menus.push({
130
+ name: '下移',
131
+ action: () => {
132
+ if (target) {
133
+ this.render.zIndexTool.down([target]);
134
+ }
135
+ }
136
+ });
137
+ menus.push({
138
+ name: '置顶',
139
+ action: () => {
140
+ if (target) {
141
+ this.render.zIndexTool.top([target]);
142
+ }
143
+ }
144
+ });
145
+ menus.push({
146
+ name: '置底',
147
+ action: () => {
148
+ if (target) {
149
+ this.render.zIndexTool.bottom([target]);
150
+ }
151
+ }
152
+ });
153
+ if (target instanceof Konva.Transformer) {
154
+ const pos = this.render.stage.getPointerPosition();
155
+ if (pos) {
156
+ // 获取所有图形
157
+ const shapes = target.nodes();
158
+ if (shapes.length > 1) {
159
+ // zIndex 倒序(大的优先)
160
+ shapes.sort((a, b) => b.zIndex() - a.zIndex());
161
+ // 提取重叠目标
162
+ const selected = shapes.find((shape) =>
163
+ // 关键 api
164
+ Konva.Util.haveIntersection(Object.assign(Object.assign({}, pos), { width: 1, height: 1 }), shape.getClientRect()));
165
+ // 对齐菜单
166
+ menus.push({
167
+ name: '垂直居中' + (selected ? '于目标' : ''),
168
+ action: () => this.render.alignTool.align("Middle", selected)
169
+ });
170
+ menus.push({
171
+ name: '左对齐' + (selected ? '于目标' : ''),
172
+ action: () => this.render.alignTool.align("Left", selected)
173
+ });
174
+ menus.push({
175
+ name: '右对齐' + (selected ? '于目标' : ''),
176
+ action: () => this.render.alignTool.align("Right", selected)
177
+ });
178
+ menus.push({
179
+ name: '水平居中' + (selected ? '于目标' : ''),
180
+ action: () => this.render.alignTool.align("Center", selected)
181
+ });
182
+ menus.push({
183
+ name: '上对齐' + (selected ? '于目标' : ''),
184
+ action: () => this.render.alignTool.align("Top", selected)
185
+ });
186
+ menus.push({
187
+ name: '下对齐' + (selected ? '于目标' : ''),
188
+ action: () => this.render.alignTool.align("Bottom", selected)
189
+ });
190
+ }
191
+ }
192
+ }
193
+ }
194
+ }
195
+ // stage 状态
196
+ const stageState = this.render.getStageState();
197
+ // 绘制右键菜单
198
+ const group = new Konva.Group({
199
+ name: 'contextmenu',
200
+ width: stageState.width,
201
+ height: stageState.height
202
+ });
203
+ let top = 0;
204
+ // 菜单每项高度
205
+ const lineHeight = 30;
206
+ const pos = this.render.stage.getPointerPosition();
207
+ if (pos) {
208
+ for (const menu of menus) {
209
+ // 框
210
+ const rect = new Konva.Rect({
211
+ x: this.render.toStageValue(pos.x - stageState.x),
212
+ y: this.render.toStageValue(pos.y + top - stageState.y),
213
+ width: this.render.toStageValue(150),
214
+ height: this.render.toStageValue(lineHeight),
215
+ fill: '#fff',
216
+ stroke: '#999',
217
+ strokeWidth: this.render.toStageValue(1),
218
+ name: 'contextmenu'
219
+ });
220
+ // 标题
221
+ const text = new Konva.Text({
222
+ x: this.render.toStageValue(pos.x - stageState.x),
223
+ y: this.render.toStageValue(pos.y + top - stageState.y),
224
+ text: menu.name,
225
+ name: 'contextmenu',
226
+ listening: false,
227
+ fontSize: this.render.toStageValue(16),
228
+ fill: '#333',
229
+ width: this.render.toStageValue(150),
230
+ height: this.render.toStageValue(lineHeight),
231
+ align: 'center',
232
+ verticalAlign: 'middle'
233
+ });
234
+ group.add(rect);
235
+ group.add(text);
236
+ // 菜单事件
237
+ rect.on('pointerclick', (e) => {
238
+ if (e.evt.button === MouseButton.左键) {
239
+ // 触发事件
240
+ menu.action(e);
241
+ // 移除菜单
242
+ this.group.getChildren().forEach((o) => {
243
+ o.destroy();
244
+ });
245
+ this.group.removeChildren();
246
+ this.state.target = null;
247
+ }
248
+ e.evt.preventDefault();
249
+ e.evt.stopPropagation();
250
+ });
251
+ rect.on('mousedown', (e) => {
252
+ if (e.evt.button === MouseButton.左键) {
253
+ this.state.menuIsMousedown = true;
254
+ // 按下效果
255
+ rect.fill('#dfdfdf');
256
+ }
257
+ e.evt.preventDefault();
258
+ e.evt.stopPropagation();
259
+ });
260
+ rect.on('mouseup', (e) => {
261
+ if (e.evt.button === MouseButton.左键) {
262
+ this.state.menuIsMousedown = false;
263
+ }
264
+ });
265
+ rect.on('mouseenter', (e) => {
266
+ if (this.state.menuIsMousedown) {
267
+ rect.fill('#dfdfdf');
268
+ }
269
+ else {
270
+ // hover in
271
+ rect.fill('#efefef');
272
+ }
273
+ e.evt.preventDefault();
274
+ e.evt.stopPropagation();
275
+ });
276
+ rect.on('mouseout', () => {
277
+ // hover out
278
+ rect.fill('#fff');
279
+ });
280
+ rect.on('contextmenu', (e) => {
281
+ e.evt.preventDefault();
282
+ e.evt.stopPropagation();
283
+ });
284
+ top += lineHeight - 1;
285
+ }
286
+ }
287
+ this.group.add(group);
288
+ }
289
+ }
290
+ }
291
+ // @ts-ignore
292
+ ContextmenuDraw.name = 'contextmenu';
293
+ //# sourceMappingURL=contextmenu-draw.js.map