aldehyde 0.2.473 → 0.2.475

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 (203) 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 +3 -2
  8. package/lib/controls/entry-control.js.map +1 -1
  9. package/lib/controls/icon-selector/icon/phonenode-menu-icon/iconfont.css +47 -3
  10. package/lib/controls/icon-selector/icon/phonenode-menu-icon/iconfont.js +12 -12
  11. package/lib/controls/icon-selector/icon/phonenode-menu-icon/iconfont.js.map +1 -1
  12. package/lib/controls/icon-selector/icon/phonenode-menu-icon/iconfont.json +77 -0
  13. package/lib/controls/icon-selector/icon/phonenode-menu-icon/iconfont.ttf +0 -0
  14. package/lib/controls/icon-selector/icon/phonenode-menu-icon/iconfont.woff +0 -0
  15. package/lib/controls/icon-selector/icon/phonenode-menu-icon/iconfont.woff2 +0 -0
  16. package/lib/controls/select/index.d.ts.map +1 -1
  17. package/lib/controls/select/index.js +13 -7
  18. package/lib/controls/select/index.js.map +1 -1
  19. package/lib/controls/text/index.less +1 -0
  20. package/lib/controls/view-control.d.ts.map +1 -1
  21. package/lib/controls/view-control.js +1 -0
  22. package/lib/controls/view-control.js.map +1 -1
  23. package/lib/detail/button/edit-button.d.ts.map +1 -1
  24. package/lib/detail/button/edit-button.js +23 -11
  25. package/lib/detail/button/edit-button.js.map +1 -1
  26. package/lib/detail/button/view-button.d.ts.map +1 -1
  27. package/lib/detail/button/view-button.js +21 -10
  28. package/lib/detail/button/view-button.js.map +1 -1
  29. package/lib/draw-canvas/edit/components/asset-bar/index.d.ts +5 -0
  30. package/lib/draw-canvas/edit/components/asset-bar/index.d.ts.map +1 -0
  31. package/lib/draw-canvas/edit/components/asset-bar/index.js +79 -0
  32. package/lib/draw-canvas/edit/components/asset-bar/index.js.map +1 -0
  33. package/lib/draw-canvas/edit/components/asset-bar/index.less +36 -0
  34. package/lib/draw-canvas/edit/components/main-header/index.d.ts +19 -0
  35. package/lib/draw-canvas/edit/components/main-header/index.d.ts.map +1 -0
  36. package/lib/draw-canvas/edit/components/main-header/index.js +203 -0
  37. package/lib/draw-canvas/edit/components/main-header/index.js.map +1 -0
  38. package/lib/draw-canvas/edit/components/main-header/index.less +21 -0
  39. package/lib/draw-canvas/edit/components/render/index.d.ts +90 -0
  40. package/lib/draw-canvas/edit/components/render/index.d.ts.map +1 -0
  41. package/lib/draw-canvas/edit/components/render/index.js +692 -0
  42. package/lib/draw-canvas/edit/components/render/index.js.map +1 -0
  43. package/lib/draw-canvas/edit/components/render/types.d.ts +247 -0
  44. package/lib/draw-canvas/edit/components/render/types.d.ts.map +1 -0
  45. package/lib/draw-canvas/edit/components/render/types.js +66 -0
  46. package/lib/draw-canvas/edit/components/render/types.js.map +1 -0
  47. package/lib/draw-canvas/edit/components/setting-form/imag-upload.d.ts +26 -0
  48. package/lib/draw-canvas/edit/components/setting-form/imag-upload.d.ts.map +1 -0
  49. package/lib/draw-canvas/edit/components/setting-form/imag-upload.js +83 -0
  50. package/lib/draw-canvas/edit/components/setting-form/imag-upload.js.map +1 -0
  51. package/lib/draw-canvas/edit/components/setting-form/index.d.ts +17 -0
  52. package/lib/draw-canvas/edit/components/setting-form/index.d.ts.map +1 -0
  53. package/lib/draw-canvas/edit/components/setting-form/index.js +243 -0
  54. package/lib/draw-canvas/edit/components/setting-form/index.js.map +1 -0
  55. package/lib/draw-canvas/edit/constant.d.ts +7 -0
  56. package/lib/draw-canvas/edit/constant.d.ts.map +1 -0
  57. package/lib/draw-canvas/edit/constant.js +7 -0
  58. package/lib/draw-canvas/edit/constant.js.map +1 -0
  59. package/lib/draw-canvas/edit/index.d.ts +8 -0
  60. package/lib/draw-canvas/edit/index.d.ts.map +1 -0
  61. package/lib/draw-canvas/edit/index.js +165 -0
  62. package/lib/draw-canvas/edit/index.js.map +1 -0
  63. package/lib/draw-canvas/edit/index.less +49 -0
  64. package/lib/draw-canvas/view/index.d.ts +8 -0
  65. package/lib/draw-canvas/view/index.d.ts.map +1 -0
  66. package/lib/draw-canvas/view/index.js +50 -0
  67. package/lib/draw-canvas/view/index.js.map +1 -0
  68. package/lib/draw-canvas/view/index.less +60 -0
  69. package/lib/draw-canvas/view/view.d.ts +10 -0
  70. package/lib/draw-canvas/view/view.d.ts.map +1 -0
  71. package/lib/draw-canvas/view/view.js +104 -0
  72. package/lib/draw-canvas/view/view.js.map +1 -0
  73. package/lib/form/form-Item-group.d.ts.map +1 -1
  74. package/lib/form/form-Item-group.js +4 -4
  75. package/lib/form/form-Item-group.js.map +1 -1
  76. package/lib/icon/local-aliIcon/iconfont.js +5 -5
  77. package/lib/icon/local-aliIcon/iconfont.js.map +1 -1
  78. package/lib/lowcode-components/index.d.ts +2 -0
  79. package/lib/lowcode-components/index.d.ts.map +1 -1
  80. package/lib/lowcode-components/index.js +2 -1
  81. package/lib/lowcode-components/index.js.map +1 -1
  82. package/lib/lowcode-components/lowcode-view/component/assets.d.ts.map +1 -1
  83. package/lib/lowcode-components/lowcode-view/component/assets.js +8 -0
  84. package/lib/lowcode-components/lowcode-view/component/assets.js.map +1 -1
  85. package/lib/lowcode-components/radar-chart/index.d.ts +51 -0
  86. package/lib/lowcode-components/radar-chart/index.d.ts.map +1 -0
  87. package/lib/lowcode-components/radar-chart/index.js +276 -0
  88. package/lib/lowcode-components/radar-chart/index.js.map +1 -0
  89. package/lib/module/dtmpl-edit-card.d.ts.map +1 -1
  90. package/lib/module/dtmpl-edit-card.js +18 -1
  91. package/lib/module/dtmpl-edit-card.js.map +1 -1
  92. package/lib/module/dtmpl-edit-page.d.ts.map +1 -1
  93. package/lib/module/dtmpl-edit-page.js +19 -2
  94. package/lib/module/dtmpl-edit-page.js.map +1 -1
  95. package/lib/routable/ltmpl-route.d.ts +2 -0
  96. package/lib/routable/ltmpl-route.d.ts.map +1 -1
  97. package/lib/routable/ltmpl-route.js +20 -4
  98. package/lib/routable/ltmpl-route.js.map +1 -1
  99. package/lib/table/act-table.d.ts +2 -0
  100. package/lib/table/act-table.d.ts.map +1 -1
  101. package/lib/table/act-table.js +4 -4
  102. package/lib/table/act-table.js.map +1 -1
  103. package/lib/table/column/column-builder.d.ts.map +1 -1
  104. package/lib/table/column/column-builder.js +23 -8
  105. package/lib/table/column/column-builder.js.map +1 -1
  106. package/lib/table/relation-table.d.ts +7 -0
  107. package/lib/table/relation-table.d.ts.map +1 -1
  108. package/lib/tmpl/control-type-supportor.d.ts.map +1 -1
  109. package/lib/tmpl/control-type-supportor.js +1 -0
  110. package/lib/tmpl/control-type-supportor.js.map +1 -1
  111. package/lib/tmpl/hcservice-v3.d.ts +3 -0
  112. package/lib/tmpl/hcservice-v3.d.ts.map +1 -1
  113. package/lib/tmpl/hcservice-v3.js +61 -0
  114. package/lib/tmpl/hcservice-v3.js.map +1 -1
  115. package/lib/tmpl/interface.d.ts +17 -1
  116. package/lib/tmpl/interface.d.ts.map +1 -1
  117. package/lib/tmpl/interface.js.map +1 -1
  118. package/lib/tmpl/tmpl-config-analysis.js +1 -1
  119. package/lib/tmpl/tmpl-config-analysis.js.map +1 -1
  120. package/lib/units/index.d.ts +3 -1
  121. package/lib/units/index.d.ts.map +1 -1
  122. package/lib/units/index.js +33 -3
  123. package/lib/units/index.js.map +1 -1
  124. package/package.json +4 -1
  125. package/src/aldehyde/controls/entity-select/entity-select.tsx +18 -8
  126. package/src/aldehyde/controls/entry-control.tsx +3 -2
  127. package/src/aldehyde/controls/icon-selector/icon/phonenode-menu-icon/iconfont.css +47 -3
  128. package/src/aldehyde/controls/icon-selector/icon/phonenode-menu-icon/iconfont.js +1 -1
  129. package/src/aldehyde/controls/icon-selector/icon/phonenode-menu-icon/iconfont.json +77 -0
  130. package/src/aldehyde/controls/icon-selector/icon/phonenode-menu-icon/iconfont.ttf +0 -0
  131. package/src/aldehyde/controls/icon-selector/icon/phonenode-menu-icon/iconfont.woff +0 -0
  132. package/src/aldehyde/controls/icon-selector/icon/phonenode-menu-icon/iconfont.woff2 +0 -0
  133. package/src/aldehyde/controls/select/index.tsx +7 -6
  134. package/src/aldehyde/controls/text/index.less +1 -0
  135. package/src/aldehyde/controls/view-control.tsx +1 -0
  136. package/src/aldehyde/detail/button/edit-button.tsx +21 -22
  137. package/src/aldehyde/detail/button/view-button.tsx +23 -21
  138. package/src/aldehyde/draw-canvas/edit/components/asset-bar/index.less +36 -0
  139. package/src/aldehyde/draw-canvas/edit/components/asset-bar/index.tsx +95 -0
  140. package/src/aldehyde/draw-canvas/edit/components/main-header/index.less +21 -0
  141. package/src/aldehyde/draw-canvas/edit/components/main-header/index.tsx +233 -0
  142. package/src/aldehyde/draw-canvas/edit/components/render/draws/bg-draw.ts +163 -0
  143. package/src/aldehyde/draw-canvas/edit/components/render/draws/contextmenu-draw.ts +307 -0
  144. package/src/aldehyde/draw-canvas/edit/components/render/draws/graph-draw.ts +251 -0
  145. package/src/aldehyde/draw-canvas/edit/components/render/draws/index.ts +7 -0
  146. package/src/aldehyde/draw-canvas/edit/components/render/draws/link-draw.ts +1416 -0
  147. package/src/aldehyde/draw-canvas/edit/components/render/draws/preview-draw.ts +275 -0
  148. package/src/aldehyde/draw-canvas/edit/components/render/draws/ref-line-draw.ts +72 -0
  149. package/src/aldehyde/draw-canvas/edit/components/render/draws/ruler-draw.ts +167 -0
  150. package/src/aldehyde/draw-canvas/edit/components/render/graphs/base-graph.ts +241 -0
  151. package/src/aldehyde/draw-canvas/edit/components/render/graphs/bezier.ts +542 -0
  152. package/src/aldehyde/draw-canvas/edit/components/render/graphs/circle.ts +700 -0
  153. package/src/aldehyde/draw-canvas/edit/components/render/graphs/curve.ts +501 -0
  154. package/src/aldehyde/draw-canvas/edit/components/render/graphs/index.ts +6 -0
  155. package/src/aldehyde/draw-canvas/edit/components/render/graphs/line.ts +494 -0
  156. package/src/aldehyde/draw-canvas/edit/components/render/graphs/rect.ts +681 -0
  157. package/src/aldehyde/draw-canvas/edit/components/render/handlers/drag-handlers.ts +69 -0
  158. package/src/aldehyde/draw-canvas/edit/components/render/handlers/drag-outside-handlers.ts +159 -0
  159. package/src/aldehyde/draw-canvas/edit/components/render/handlers/graph-handlers.ts +108 -0
  160. package/src/aldehyde/draw-canvas/edit/components/render/handlers/index.ts +9 -0
  161. package/src/aldehyde/draw-canvas/edit/components/render/handlers/key-move-handlers.ts +50 -0
  162. package/src/aldehyde/draw-canvas/edit/components/render/handlers/link-handlers.ts +46 -0
  163. package/src/aldehyde/draw-canvas/edit/components/render/handlers/selection-handlers.ts +393 -0
  164. package/src/aldehyde/draw-canvas/edit/components/render/handlers/shutcut-handlers.ts +46 -0
  165. package/src/aldehyde/draw-canvas/edit/components/render/handlers/text-handlers.ts +82 -0
  166. package/src/aldehyde/draw-canvas/edit/components/render/handlers/zoom-handlers.ts +60 -0
  167. package/src/aldehyde/draw-canvas/edit/components/render/index.ts +776 -0
  168. package/src/aldehyde/draw-canvas/edit/components/render/tools/align-tool.ts +91 -0
  169. package/src/aldehyde/draw-canvas/edit/components/render/tools/asset-tool.ts +142 -0
  170. package/src/aldehyde/draw-canvas/edit/components/render/tools/attract-tool.ts +440 -0
  171. package/src/aldehyde/draw-canvas/edit/components/render/tools/copy-tool.ts +269 -0
  172. package/src/aldehyde/draw-canvas/edit/components/render/tools/import-export-tool.ts +603 -0
  173. package/src/aldehyde/draw-canvas/edit/components/render/tools/index.ts +9 -0
  174. package/src/aldehyde/draw-canvas/edit/components/render/tools/link-tool.ts +225 -0
  175. package/src/aldehyde/draw-canvas/edit/components/render/tools/position-tool.ts +194 -0
  176. package/src/aldehyde/draw-canvas/edit/components/render/tools/selection-tool.ts +132 -0
  177. package/src/aldehyde/draw-canvas/edit/components/render/tools/z-index-tool.ts +227 -0
  178. package/src/aldehyde/draw-canvas/edit/components/render/types.ts +291 -0
  179. package/src/aldehyde/draw-canvas/edit/components/render/utils/a-star.ts +116 -0
  180. package/src/aldehyde/draw-canvas/edit/components/render/utils/bezier-scene-func.ts +73 -0
  181. package/src/aldehyde/draw-canvas/edit/components/setting-form/imag-upload.tsx +118 -0
  182. package/src/aldehyde/draw-canvas/edit/components/setting-form/index.tsx +295 -0
  183. package/src/aldehyde/draw-canvas/edit/constant.ts +6 -0
  184. package/src/aldehyde/draw-canvas/edit/index.less +49 -0
  185. package/src/aldehyde/draw-canvas/edit/index.tsx +197 -0
  186. package/src/aldehyde/draw-canvas/view/index.less +60 -0
  187. package/src/aldehyde/draw-canvas/view/index.tsx +48 -0
  188. package/src/aldehyde/draw-canvas/view/view.tsx +114 -0
  189. package/src/aldehyde/form/form-Item-group.tsx +5 -5
  190. package/src/aldehyde/icon/local-aliIcon/iconfont.js +1 -1
  191. package/src/aldehyde/lowcode-components/index.ts +4 -2
  192. package/src/aldehyde/lowcode-components/lowcode-view/component/assets.ts +8 -0
  193. package/src/aldehyde/lowcode-components/radar-chart/index.tsx +323 -0
  194. package/src/aldehyde/module/dtmpl-edit-card.tsx +18 -1
  195. package/src/aldehyde/module/dtmpl-edit-page.tsx +19 -2
  196. package/src/aldehyde/routable/ltmpl-route.tsx +39 -3
  197. package/src/aldehyde/table/act-table.tsx +7 -4
  198. package/src/aldehyde/table/column/column-builder.tsx +29 -9
  199. package/src/aldehyde/tmpl/control-type-supportor.tsx +1 -0
  200. package/src/aldehyde/tmpl/hcservice-v3.tsx +44 -0
  201. package/src/aldehyde/tmpl/interface.tsx +15 -1
  202. package/src/aldehyde/tmpl/tmpl-config-analysis.tsx +1 -1
  203. package/src/aldehyde/units/index.tsx +31 -3
@@ -0,0 +1,494 @@
1
+ import Konva from 'konva';
2
+ import { GraphAnchor, Render, AssetInfoPoint, LineManualPoint } from '../types';
3
+ import { GraphDraw, LinkDraw, PreviewDraw } from '../draws';
4
+ import { BaseGraph } from './base-graph';
5
+
6
+ /**
7
+ * 直线、折线
8
+ */
9
+ export class Line extends BaseGraph {
10
+ // 实现:更新 图形 的 调整点 的 锚点位置
11
+ static override updateAnchorShadows(graph: Konva.Group, anchorShadows: Konva.Circle[], shape?: Konva.Line): void {
12
+ if (shape) {
13
+ const points = shape.points();
14
+ for (const shadow of anchorShadows) {
15
+ switch (shadow.attrs.adjustType) {
16
+ case 'start':
17
+ shadow.position({ x: points[0], y: points[1] });
18
+ break;
19
+ case 'end':
20
+ shadow.position({ x: points[points.length - 2], y: points[points.length - 1] });
21
+ break;
22
+ }
23
+ }
24
+ }
25
+ }
26
+
27
+ // 实现:更新 图形 的 连接点 的 锚点位置
28
+ static override updateLinkAnchorShadows(graph: Konva.Group, linkAnchorShadows: Konva.Circle[], shape?: Konva.Line): void {
29
+ if (shape) {
30
+ const points = shape.points();
31
+ for (const shadow of linkAnchorShadows) {
32
+ switch (shadow.attrs.alias) {
33
+ case 'start':
34
+ shadow.position({ x: points[0], y: points[1] });
35
+ break;
36
+ case 'end':
37
+ shadow.position({ x: points[points.length - 2], y: points[points.length - 1] });
38
+ break;
39
+ }
40
+ }
41
+ }
42
+ }
43
+
44
+ static calculateAngle(sideA: number, sideB: number) {
45
+ if (!isNaN(sideA) && !isNaN(sideB)) {
46
+ const angleInRadians = Math.atan2(sideA, sideB);
47
+ const angleInDegrees = angleInRadians * (180 / Math.PI);
48
+ return angleInDegrees;
49
+ }
50
+ return 0;
51
+ }
52
+
53
+ // 实现:生成 调整点
54
+ static override createAnchorShapes(
55
+ render: Render,
56
+ graph: Konva.Group,
57
+ anchorAndShadows: {
58
+ anchor: GraphAnchor;
59
+ anchorShadow: Konva.Circle;
60
+ shape?: Konva.Shape;
61
+ }[],
62
+ // eslint-disable-next-line
63
+ adjustAnchor?: GraphAnchor
64
+ ): {
65
+ anchorAndShadows: {
66
+ anchor: GraphAnchor;
67
+ anchorShadow: Konva.Circle;
68
+ shape?: Konva.Shape | undefined;
69
+ }[]
70
+ } {
71
+ const stageState = render.getStageState();
72
+ const graphShape = graph.findOne('.graph') as Konva.Line;
73
+ if (graphShape) {
74
+ const points = graphShape.points();
75
+ for (const anchorAndShadow of anchorAndShadows) {
76
+ let rotate = 0;
77
+ const { anchor, anchorShadow } = anchorAndShadow;
78
+ const x = render.toStageValue(anchorShadow.getAbsolutePosition().x - stageState.x),
79
+ y = render.toStageValue(anchorShadow.getAbsolutePosition().y - stageState.y);
80
+ if (anchor.adjustType === 'manual') {
81
+ const anchorShape = new Konva.Circle({
82
+ name: 'anchor',
83
+ anchor: anchor,
84
+ fill: anchor.adjusted ? `rgba(0,0,0,0.4)` : `rgba(0,0,255,0.4)`,
85
+ radius: render.toStageValue(5),
86
+ strokeWidth: 0,
87
+ x: x,
88
+ y: y,
89
+ rotation: graph.getAbsoluteRotation(),
90
+ visible: graph.attrs.adjusting || graph.attrs.hover === true
91
+ });
92
+ anchorShape.on('mouseenter', () => {
93
+ document.body.style.cursor = 'move';
94
+ graph.setAttr('hover', true);
95
+ graph.setAttr('hoverAnchor', true);
96
+ });
97
+ anchorShape.on('mouseleave', () => {
98
+ document.body.style.cursor = anchorShape.attrs.adjusting ? 'move' : 'default';
99
+ graph.setAttr('hover', false);
100
+ graph.setAttr('hoverAnchor', false);
101
+ render.redraw([GraphDraw.name]);
102
+ });
103
+ anchorAndShadow.shape = anchorShape;
104
+ } else {
105
+ if (anchor.adjustType === 'start') {
106
+ rotate = Line.calculateAngle(points[2] - points[0], points[3] - points[1]);
107
+ } else if (anchor.adjustType === 'end') {
108
+ rotate = Line.calculateAngle(points[points.length - 2] - points[points.length - 4], points[points.length - 1] - points[points.length - 3]);
109
+ }
110
+ const cos = Math.cos((rotate * Math.PI) / 180);
111
+ const sin = Math.sin((rotate * Math.PI) / 180);
112
+ const offset = render.toStageValue(render.pointSize - 20);
113
+ const offsetX = offset * sin;
114
+ const offsetY = offset * cos;
115
+ const anchorShape = new Konva.Circle({
116
+ name: 'anchor',
117
+ anchor: anchor,
118
+ fill: `rgba(0,0,255,0.4)`,
119
+ radius: render.toStageValue(5),
120
+ strokeWidth: 0,
121
+ x: x,
122
+ y: y,
123
+ offsetX: anchor.adjustType === 'start' ? offsetX : anchor.adjustType === 'end' ? -offsetX : 0,
124
+ offsetY: anchor.adjustType === 'start' ? offsetY : anchor.adjustType === 'end' ? -offsetY : 0,
125
+ rotation: graph.getAbsoluteRotation(),
126
+ visible: graph.attrs.adjusting || graph.attrs.hover === true
127
+ });
128
+ anchorShape.on('mouseenter', () => {
129
+ document.body.style.cursor = 'move';
130
+ graph.setAttr('hover', true);
131
+ graph.setAttr('hoverAnchor', true);
132
+ });
133
+ anchorShape.on('mouseleave', () => {
134
+ document.body.style.cursor = anchorShape.attrs.adjusting ? 'move' : 'default';
135
+ graph.setAttr('hover', false);
136
+ graph.setAttr('hoverAnchor', false);
137
+ render.redraw([GraphDraw.name]);
138
+ });
139
+ anchorAndShadow.shape = anchorShape;
140
+ }
141
+ }
142
+ }
143
+ return { anchorAndShadows };
144
+ }
145
+
146
+ /**
147
+ * 矩阵变换:坐标系中的一个点,围绕着另外一个点进行旋转
148
+ * - - - - - - - -
149
+ * |x`| |cos -sin| |x-a| |a|
150
+ * | | = | | | | +
151
+ * |y`| |sin cos| |y-b| |b|
152
+ * - - - - - - - -
153
+ * @param x 目标节点坐标 x
154
+ * @param y 目标节点坐标 y
155
+ * @param centerX 围绕的点坐标 x
156
+ * @param centerY 围绕的点坐标 y
157
+ * @param angle 旋转角度
158
+ * @returns
159
+ */
160
+ static rotatePoint(x: number, y: number, centerX: number, centerY: number, angle: number) {
161
+ const radians = (angle * Math.PI) / 180;
162
+ const newX = Math.cos(radians) * (x - centerX) - Math.sin(radians) * (y - centerY) + centerX;
163
+ const newY = Math.sin(radians) * (x - centerX) + Math.cos(radians) * (y - centerY) + centerY;
164
+ return { x: newX, y: newY };
165
+ }
166
+
167
+ // 实现:调整 图形
168
+ static override adjust(
169
+ render: Render,
170
+ graph: Konva.Group,
171
+ graphSnap: Konva.Group,
172
+ adjustShape: Konva.Shape,
173
+ anchorAndShadows: {
174
+ anchor: GraphAnchor;
175
+ anchorShadow: Konva.Circle;
176
+ shape?: Konva.Shape | undefined;
177
+ }[],
178
+ startPoint: Konva.Vector2d,
179
+ endPoint: Konva.Vector2d,
180
+ hoverRect?: Konva.Rect
181
+ ) {
182
+ // 目标 直线、折线
183
+ const line = graph.findOne('.graph') as Konva.Line;
184
+ const lineSnap = graphSnap.findOne('.graph') as Konva.Line;
185
+ const anchors = (graph.find('.anchor') ?? []) as Konva.Circle[];
186
+ const anchorsSnap = (graphSnap.find('.anchor') ?? []) as Konva.Circle[];
187
+ const linkAnchors = (graph.find('.link-anchor') ?? []) as Konva.Circle[];
188
+ if (line && lineSnap) {
189
+ const stageState = render.getStageState();
190
+ {
191
+ const [graphRotation, adjustType, ex, ey] = [
192
+ Math.round(graph.rotation()),
193
+ adjustShape.attrs.anchor?.adjustType,
194
+ endPoint.x,
195
+ endPoint.y
196
+ ];
197
+ const { x: cx, y: cy, width: cw, height: ch } = graphSnap.getClientRect();
198
+ const { x, y } = graph.position();
199
+ const [centerX, centerY] = [cx + cw / 2, cy + ch / 2];
200
+ const { x: sx, y: sy } = Line.rotatePoint(ex, ey, centerX, centerY, -graphRotation);
201
+ const { x: rx, y: ry } = Line.rotatePoint(x, y, centerX, centerY, -graphRotation);
202
+ const points = line.points();
203
+ const manualPoints = (line.attrs.manualPoints ?? []) as LineManualPoint[];
204
+ if (adjustType === 'manual') {
205
+ if (adjustShape.attrs.anchor?.manualIndex !== void 0) {
206
+ const index = adjustShape.attrs.anchor?.adjusted ? adjustShape.attrs.anchor?.manualIndex : adjustShape.attrs.anchor?.manualIndex + 1;
207
+ const manualPointIndex = manualPoints.findIndex((o) => o.index === index);
208
+ if (manualPointIndex > -1) {
209
+ manualPoints[manualPointIndex].x = (sx - rx) / graph.scaleX();
210
+ manualPoints[manualPointIndex].y = (sy - ry) / graph.scaleY();
211
+ }
212
+ const linkPoints = [
213
+ [points[0], points[1]],
214
+ ...manualPoints.sort((a, b) => a.index - b.index).map((o) => [o.x, o.y]),
215
+ [points[points.length - 2], points[points.length - 1]]
216
+ ];
217
+ line.setAttr('manualPoints', manualPoints);
218
+ line.points(linkPoints.flat());
219
+ const adjustAnchorShadow = anchors.find((o) => o.attrs.adjustType === 'manual' && o.attrs.manualIndex === index);
220
+ if (adjustAnchorShadow) {
221
+ adjustAnchorShadow.position({
222
+ x: (sx - rx) / graph.scaleX(),
223
+ y: (sy - ry) / graph.scaleY()
224
+ });
225
+ }
226
+ }
227
+ } else {
228
+ const anchor = anchors.find((o) => o.attrs.adjustType === adjustType);
229
+ const anchorShadow = anchorsSnap.find((o) => o.attrs.adjustType === adjustType);
230
+ if (anchor && anchorShadow) {
231
+ const linkPoints = [
232
+ [points[0], points[1]],
233
+ ...manualPoints.sort((a, b) => a.index - b.index).map((o) => [o.x, o.y]),
234
+ [points[points.length - 2], points[points.length - 1]]
235
+ ];
236
+ switch (adjustType) {
237
+ case 'start':
238
+ linkPoints[0] = [(sx - rx) / graph.scaleX(), (sy - ry) / graph.scaleY()];
239
+ line.points(linkPoints.flat());
240
+ break;
241
+ case 'end':
242
+ linkPoints[linkPoints.length - 1] = [(sx - rx) / graph.scaleX(), (sy - ry) / graph.scaleY()];
243
+ line.points(linkPoints.flat());
244
+ break;
245
+ }
246
+ }
247
+ }
248
+ }
249
+ Line.updateAnchor(render, graph); // 更新 调整点(拐点)
250
+ Line.updateAnchorShadows(graph, anchors, line); // 更新 调整点 的 锚点 位置
251
+ Line.updateLinkAnchorShadows(graph, linkAnchors, line); // 更新 图形 的 连接点 的 锚点位置
252
+ for (const anchor of anchors) {
253
+ for (const { shape } of anchorAndShadows) {
254
+ if (shape) {
255
+ if (shape.attrs.anchor?.adjustType === anchor.attrs.adjustType) {
256
+ const anchorShadow = graph.find(`.anchor`).find((o) => o.attrs.adjustType === anchor.attrs.adjustType);
257
+ if (anchorShadow) {
258
+ shape.position({
259
+ x: render.toStageValue(anchorShadow.getAbsolutePosition().x - stageState.x),
260
+ y: render.toStageValue(anchorShadow.getAbsolutePosition().y - stageState.y)
261
+ });
262
+ shape.rotation(graph.getAbsoluteRotation());
263
+ }
264
+ }
265
+ }
266
+ }
267
+ }
268
+ render.redraw([GraphDraw.name, LinkDraw.name, PreviewDraw.name]);
269
+ }
270
+ BaseGraph.adjust(
271
+ render,
272
+ graph,
273
+ graphSnap,
274
+ adjustShape,
275
+ anchorAndShadows,
276
+ startPoint,
277
+ endPoint,
278
+ hoverRect,
279
+ line.size(),
280
+ {
281
+ x: Math.min(...line.points().reduce((arr, item, idx) => {
282
+ if (idx % 2 === 0) arr.push(item);
283
+ return arr;
284
+ }, [] as number[])),
285
+ y: Math.min(...line.points().reduce((arr, item, idx) => {
286
+ if (idx % 2 === 1) arr.push(item);
287
+ return arr;
288
+ }, [] as number[]))
289
+ }
290
+ );
291
+ }
292
+
293
+ /**
294
+ * 提供给 GraphDraw draw 使用
295
+ */
296
+ static override draw(graph: Konva.Group, render: Render, adjustAnchor?: GraphAnchor) {
297
+ const anchors = (graph.attrs.anchors ?? []) as (GraphAnchor & { manualIndex?: number; adjusted?: boolean })[];
298
+ const anchorShapes = graph.find(`.anchor`);
299
+ const anchorAndShadows = anchors
300
+ .map((anchor) => ({
301
+ anchor,
302
+ anchorShadow: anchorShapes.find((shape) => shape.attrs.adjustType === anchor.adjustType && shape.attrs.manualIndex === anchor.manualIndex) as Konva.Circle
303
+ }))
304
+ .filter((o) => o.anchorShadow !== void 0);
305
+ return Line.createAnchorShapes(render, graph, anchorAndShadows, adjustAnchor);
306
+ }
307
+
308
+ /**
309
+ * 默认图形大小
310
+ */
311
+ static size = 100;
312
+
313
+ /**
314
+ * 直线、折线 对应的 Konva 实例
315
+ */
316
+ private line: Konva.Line;
317
+
318
+ constructor(render: Render, dropPoint: Konva.Vector2d) {
319
+ super(render, dropPoint, {
320
+ type: "Line",
321
+ anchors: [{ adjustType: 'start' }, { adjustType: 'end' }].map((o) => ({ adjustType: o.adjustType })),
322
+ linkAnchors: [
323
+ { x: 0, y: 0, alias: 'start' },
324
+ { x: 0, y: 0, alias: 'end' }
325
+ ] as AssetInfoPoint[]
326
+ });
327
+ this.line = new Konva.Arrow({
328
+ name: 'graph',
329
+ x: 0,
330
+ y: 0,
331
+ stroke: this.render.getPageSettings().stroke,
332
+ strokeWidth: this.render.getPageSettings().strokeWidth,
333
+ fill: this.render.getPageSettings().stroke,
334
+ points: [],
335
+ pointerAtBeginning: false,
336
+ pointerAtEnding: false
337
+ });
338
+ // 给予 1 像素,防止导出图片 toDataURL 失败
339
+ this.group.size({ width: 1, height: 1 });
340
+ this.group.add(this.line);
341
+ this.group.position(this.dropPoint);
342
+ }
343
+
344
+ // 实现:拖动进行时
345
+ override drawMove(point: Konva.Vector2d): void {
346
+ const offsetX = point.x - this.dropPoint.x,
347
+ offsetY = point.y - this.dropPoint.y;
348
+ const linkPoints = [ // 起点、终点
349
+ [this.line.x(), this.line.y()],
350
+ [this.line.x() + offsetX, this.line.y() + offsetY]
351
+ ];
352
+ // 直线、折线 路径
353
+ this.line.points(linkPoints.flat());
354
+ // 更新 图形 的 调整点 的 锚点位置
355
+ Line.updateAnchorShadows(this.group, this.anchorShadows, this.line);
356
+ // 更新 图形 的 连接点 的 锚点位置
357
+ Line.updateLinkAnchorShadows(this.group, this.linkAnchorShadows, this.line);
358
+ this.render.redraw([GraphDraw.name, LinkDraw.name, PreviewDraw.name]);
359
+ }
360
+
361
+ // 实现:拖动结束
362
+ override drawEnd(): void {
363
+ if (this.line.width() <= 10 && this.line.height() <= 10) {
364
+ const width = Line.size, height = width;
365
+ const linkPoints = [
366
+ [this.line.x(), this.line.y()],
367
+ [this.line.x() + width, this.line.y() + height]
368
+ ];
369
+ this.line.points(linkPoints.flat());
370
+ }
371
+ Line.updateAnchor(this.render, this.group);
372
+ Line.updateAnchorShadows(this.group, this.anchorShadows, this.line);
373
+ Line.updateLinkAnchorShadows(this.group, this.linkAnchorShadows, this.line);
374
+ const size = {
375
+ width: this.line.size().width - 10,
376
+ height: this.line.size().height - 10
377
+ };
378
+ this.group.size(size);
379
+ this.render.attractTool.alignLinesClear();
380
+ this.render.updateHistory();
381
+ this.render.redraw([GraphDraw.name, LinkDraw.name, PreviewDraw.name]);
382
+ super.drawEnd(size, {
383
+ x: Math.min(...this.line.points().reduce((arr, item, idx) => {
384
+ if (idx % 2 === 0) arr.push(item);
385
+ return arr;
386
+ }, [] as number[])),
387
+ y: Math.min(...this.line.points().reduce((arr, item, idx) => {
388
+ if (idx % 2 === 1) arr.push(item);
389
+ return arr;
390
+ }, [] as number[]))
391
+ });
392
+ }
393
+
394
+ /**
395
+ * 更新 调整点(拐点)
396
+ * @param render
397
+ * @param graph
398
+ */
399
+ static updateAnchor(render: Render, graph: Konva.Group) {
400
+ const anchors = graph.attrs.anchors ?? [];
401
+ const anchorShadows = graph.find('.anchor') ?? [];
402
+ const shape = graph.findOne('.graph') as Konva.Line;
403
+ if (shape) {
404
+ let manualPoints = (shape.attrs.manualPoints ?? []) as LineManualPoint[];
405
+ const points = shape.points();
406
+ const linkPoints = [
407
+ [points[0], points[1]],
408
+ ...manualPoints.sort((a, b) => a.index - b.index).map((o) => [o.x, o.y]),
409
+ [points[points.length - 2], points[points.length - 1]]
410
+ ];
411
+ // 清空 调整点(拐点),保留 start end
412
+ anchors.splice(2);
413
+ const shadows = anchorShadows.splice(2);
414
+ for (const shadow of shadows) {
415
+ shadow.remove();
416
+ shadow.destroy();
417
+ }
418
+ manualPoints = [];
419
+ for (let i = linkPoints.length - 1; i > 0; i--) {
420
+ linkPoints.splice(i, 0, []);
421
+ }
422
+ for (let i = 1; i < linkPoints.length - 1; i++) {
423
+ const anchor = {
424
+ type: graph.attrs.graphType,
425
+ adjustType: 'manual',
426
+ name: 'anchor',
427
+ groupId: graph.id(),
428
+ manualIndex: i,
429
+ adjusted: false
430
+ };
431
+ if (linkPoints[i].length === 0) {
432
+ anchor.adjusted = false;
433
+ const prev = linkPoints[i - 1];
434
+ const next = linkPoints[i + 1];
435
+ const circle = new Konva.Circle({
436
+ adjustType: anchor.adjustType,
437
+ anchorType: anchor.type,
438
+ name: anchor.name,
439
+ manualIndex: anchor.manualIndex,
440
+ radius: 0,
441
+ x: (prev[0] + next[0]) / 2,
442
+ y: (prev[1] + next[1]) / 2,
443
+ anchor
444
+ });
445
+ graph.add(circle);
446
+ } else {
447
+ anchor.adjusted = true;
448
+ const circle = new Konva.Circle({
449
+ adjustType: anchor.adjustType,
450
+ anchorType: anchor.type,
451
+ name: anchor.name,
452
+ manualIndex: anchor.manualIndex,
453
+ adjusted: true,
454
+ radius: 0,
455
+ x: linkPoints[i][0],
456
+ y: linkPoints[i][1],
457
+ anchor
458
+ });
459
+ graph.add(circle);
460
+ manualPoints.push({ x: linkPoints[i][0], y: linkPoints[i][1], index: anchor.manualIndex });
461
+ }
462
+ anchors.push(anchor);
463
+ }
464
+ shape.setAttr('manualPoints', manualPoints);
465
+ graph.setAttr('anchors', anchors);
466
+ }
467
+ }
468
+
469
+ /**
470
+ * 调整之前
471
+ */
472
+ static adjustStart(
473
+ render: Render,
474
+ graph: Konva.Group,
475
+ adjustAnchor: GraphAnchor & { manualIndex?: number; adjusted?: boolean },
476
+ endPoint: Konva.Vector2d
477
+ ) {
478
+ const { x: gx, y: gy } = graph.position();
479
+ const shape = graph.findOne('.graph') as Konva.Line;
480
+ if (shape && typeof adjustAnchor.manualIndex === 'number') {
481
+ const manualPoints = (shape.attrs.manualPoints ?? []) as LineManualPoint[];
482
+ if (adjustAnchor.adjusted) {
483
+ } else {
484
+ manualPoints.push({
485
+ x: endPoint.x - gx,
486
+ y: endPoint.y - gy,
487
+ index: adjustAnchor.manualIndex
488
+ });
489
+ shape.setAttr('manualPoints', manualPoints);
490
+ }
491
+ Line.updateAnchor(render, graph);
492
+ }
493
+ }
494
+ }