@plait/mind 0.2.0-next.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 (125) hide show
  1. package/README.md +24 -0
  2. package/constants/default.d.ts +12 -0
  3. package/constants/index.d.ts +2 -0
  4. package/constants/node.d.ts +17 -0
  5. package/draw/abstract.d.ts +4 -0
  6. package/draw/indented-link.d.ts +3 -0
  7. package/draw/link/abstract-link.d.ts +3 -0
  8. package/draw/link/logic-link.d.ts +3 -0
  9. package/draw/link.d.ts +3 -0
  10. package/draw/richtext.d.ts +14 -0
  11. package/draw/shape.d.ts +3 -0
  12. package/esm2020/constants/default.mjs +13 -0
  13. package/esm2020/constants/index.mjs +3 -0
  14. package/esm2020/constants/node.mjs +19 -0
  15. package/esm2020/draw/abstract.mjs +48 -0
  16. package/esm2020/draw/indented-link.mjs +44 -0
  17. package/esm2020/draw/link/abstract-link.mjs +42 -0
  18. package/esm2020/draw/link/logic-link.mjs +51 -0
  19. package/esm2020/draw/link.mjs +158 -0
  20. package/esm2020/draw/richtext.mjs +35 -0
  21. package/esm2020/draw/shape.mjs +18 -0
  22. package/esm2020/interfaces/abstract.mjs +6 -0
  23. package/esm2020/interfaces/element-data.mjs +2 -0
  24. package/esm2020/interfaces/element.mjs +59 -0
  25. package/esm2020/interfaces/index.mjs +6 -0
  26. package/esm2020/interfaces/layout.mjs +19 -0
  27. package/esm2020/interfaces/node.mjs +23 -0
  28. package/esm2020/interfaces/types.mjs +13 -0
  29. package/esm2020/layout-option.mjs +72 -0
  30. package/esm2020/mind.component.mjs +50 -0
  31. package/esm2020/mind.module.mjs +21 -0
  32. package/esm2020/node.component.mjs +742 -0
  33. package/esm2020/plait-mind.mjs +5 -0
  34. package/esm2020/plugins/emoji/emoji-base.component.mjs +21 -0
  35. package/esm2020/plugins/emoji/emoji.drawer.mjs +79 -0
  36. package/esm2020/plugins/emoji/emoji.mjs +15 -0
  37. package/esm2020/plugins/emoji/index.mjs +4 -0
  38. package/esm2020/plugins/emoji/with-mind-emoji.mjs +8 -0
  39. package/esm2020/plugins/with-abstract.mjs +92 -0
  40. package/esm2020/plugins/with-dnd.mjs +276 -0
  41. package/esm2020/plugins/with-mind.mjs +183 -0
  42. package/esm2020/public-api.mjs +14 -0
  43. package/esm2020/queries/get-available-sublayouts-by-element.mjs +29 -0
  44. package/esm2020/queries/get-branch-mindmap-layouts-by-element.mjs +18 -0
  45. package/esm2020/queries/get-correct-layout-by-element.mjs +50 -0
  46. package/esm2020/queries/get-layout-by-element.mjs +16 -0
  47. package/esm2020/queries/get-layout-parent-by-element.mjs +17 -0
  48. package/esm2020/queries/index.mjs +13 -0
  49. package/esm2020/transforms/index.mjs +10 -0
  50. package/esm2020/transforms/layout.mjs +23 -0
  51. package/esm2020/transforms/node.mjs +44 -0
  52. package/esm2020/utils/abstract/common.mjs +25 -0
  53. package/esm2020/utils/abstract/resize.mjs +169 -0
  54. package/esm2020/utils/clipboard.mjs +71 -0
  55. package/esm2020/utils/colors.mjs +41 -0
  56. package/esm2020/utils/direction-corrector.mjs +54 -0
  57. package/esm2020/utils/direction-detector.mjs +56 -0
  58. package/esm2020/utils/draw-placeholder.mjs +311 -0
  59. package/esm2020/utils/drop-target-corrector.mjs +86 -0
  60. package/esm2020/utils/graph.mjs +24 -0
  61. package/esm2020/utils/index.mjs +14 -0
  62. package/esm2020/utils/is-virtual-key.mjs +13 -0
  63. package/esm2020/utils/layout.mjs +105 -0
  64. package/esm2020/utils/mindmap.mjs +295 -0
  65. package/esm2020/utils/node-space.mjs +72 -0
  66. package/esm2020/utils/node.mjs +6 -0
  67. package/esm2020/utils/path.mjs +11 -0
  68. package/esm2020/utils/point-placement.mjs +99 -0
  69. package/esm2020/utils/shape.mjs +17 -0
  70. package/esm2020/utils/weak-maps.mjs +3 -0
  71. package/fesm2015/plait-mind.mjs +3583 -0
  72. package/fesm2015/plait-mind.mjs.map +1 -0
  73. package/fesm2020/plait-mind.mjs +3595 -0
  74. package/fesm2020/plait-mind.mjs.map +1 -0
  75. package/index.d.ts +5 -0
  76. package/interfaces/abstract.d.ts +4 -0
  77. package/interfaces/element-data.d.ts +11 -0
  78. package/interfaces/element.d.ts +39 -0
  79. package/interfaces/index.d.ts +5 -0
  80. package/interfaces/layout.d.ts +10 -0
  81. package/interfaces/node.d.ts +33 -0
  82. package/interfaces/types.d.ts +11 -0
  83. package/layout-option.d.ts +2 -0
  84. package/mind.component.d.ts +16 -0
  85. package/mind.module.d.ts +11 -0
  86. package/node.component.d.ts +60 -0
  87. package/package.json +31 -0
  88. package/plugins/emoji/emoji-base.component.d.ts +12 -0
  89. package/plugins/emoji/emoji.d.ts +6 -0
  90. package/plugins/emoji/emoji.drawer.d.ts +22 -0
  91. package/plugins/emoji/index.d.ts +3 -0
  92. package/plugins/emoji/with-mind-emoji.d.ts +8 -0
  93. package/plugins/with-abstract.d.ts +2 -0
  94. package/plugins/with-dnd.d.ts +11 -0
  95. package/plugins/with-mind.d.ts +2 -0
  96. package/public-api.d.ts +10 -0
  97. package/queries/get-available-sublayouts-by-element.d.ts +8 -0
  98. package/queries/get-branch-mindmap-layouts-by-element.d.ts +3 -0
  99. package/queries/get-correct-layout-by-element.d.ts +9 -0
  100. package/queries/get-layout-by-element.d.ts +3 -0
  101. package/queries/get-layout-parent-by-element.d.ts +8 -0
  102. package/queries/index.d.ts +7 -0
  103. package/styles/styles.scss +99 -0
  104. package/transforms/index.d.ts +7 -0
  105. package/transforms/layout.d.ts +3 -0
  106. package/transforms/node.d.ts +8 -0
  107. package/utils/abstract/common.d.ts +5 -0
  108. package/utils/abstract/resize.d.ts +21 -0
  109. package/utils/clipboard.d.ts +7 -0
  110. package/utils/colors.d.ts +4 -0
  111. package/utils/direction-corrector.d.ts +3 -0
  112. package/utils/direction-detector.d.ts +9 -0
  113. package/utils/draw-placeholder.d.ts +42 -0
  114. package/utils/drop-target-corrector.d.ts +8 -0
  115. package/utils/graph.d.ts +5 -0
  116. package/utils/index.d.ts +13 -0
  117. package/utils/is-virtual-key.d.ts +1 -0
  118. package/utils/layout.d.ts +12 -0
  119. package/utils/mindmap.d.ts +33 -0
  120. package/utils/node-space.d.ts +9 -0
  121. package/utils/node.d.ts +2 -0
  122. package/utils/path.d.ts +4 -0
  123. package/utils/point-placement.d.ts +8 -0
  124. package/utils/shape.d.ts +3 -0
  125. package/utils/weak-maps.d.ts +5 -0
@@ -0,0 +1,311 @@
1
+ import { BASE, PRIMARY_COLOR, STROKE_WIDTH } from '../constants';
2
+ import { drawLink } from '../draw/link';
3
+ import { getRectangleByNode } from './graph';
4
+ import { MINDMAP_ELEMENT_TO_COMPONENT } from './weak-maps';
5
+ import { drawRoundRectangle } from '@plait/core';
6
+ import { MindmapQueries } from '../queries';
7
+ import { isBottomLayout, isHorizontalLayout, isHorizontalLogicLayout, isIndentedLayout, isRightLayout, isVerticalLogicLayout } from '@plait/layouts';
8
+ import { drawIndentedLink } from '../draw/indented-link';
9
+ import { isLeftLayout, isTopLayout } from '@plait/layouts';
10
+ import { isStandardLayout } from '@plait/layouts';
11
+ import { isMixedLayout } from './layout';
12
+ export const drawPlaceholderDropNodeG = (dropTarget, roughSVG, fakeDropNodeG) => {
13
+ const targetComponent = MINDMAP_ELEMENT_TO_COMPONENT.get(dropTarget.target);
14
+ const targetRect = getRectangleByNode(targetComponent.node);
15
+ if (dropTarget.detectResult && ['right', 'left'].includes(dropTarget.detectResult)) {
16
+ drawStraightDropNodeG(targetRect, dropTarget.detectResult, targetComponent, roughSVG, fakeDropNodeG);
17
+ }
18
+ if (targetComponent.parent && dropTarget.detectResult && ['top', 'bottom'].includes(dropTarget.detectResult)) {
19
+ const parentComponent = MINDMAP_ELEMENT_TO_COMPONENT.get(targetComponent.parent.origin);
20
+ const targetIndex = parentComponent.node.origin.children.indexOf(targetComponent.node.origin);
21
+ drawCurvePlaceholderDropNodeG(targetRect, dropTarget.detectResult, targetIndex, targetComponent, roughSVG, parentComponent, fakeDropNodeG);
22
+ }
23
+ };
24
+ export const drawCurvePlaceholderDropNodeG = (targetRect, detectResult, targetIndex, targetComponent, roughSVG, parentComponent, fakeDropNodeG) => {
25
+ const parentNodeLayout = MindmapQueries.getCorrectLayoutByElement(parentComponent.node.origin);
26
+ const layout = MindmapQueries.getCorrectLayoutByElement(targetComponent.node.parent.origin);
27
+ const strokeWidth = targetComponent.node.origin.linkLineWidth ? targetComponent.node.origin.linkLineWidth : STROKE_WIDTH;
28
+ let fakeX = targetComponent.node.x, fakeY = targetRect.y - 30, fakeRectangleStartX = targetRect.x, fakeRectangleEndX = targetRect.x + 30, fakeRectangleStartY = fakeY, fakeRectangleEndY = fakeRectangleStartY + 12, width = 30;
29
+ if (isLeftLayout(layout)) {
30
+ fakeX = targetComponent.node.x + targetComponent.node.width - 30;
31
+ fakeRectangleStartX = targetRect.x + targetRect.width - 30;
32
+ fakeRectangleEndX = targetRect.x + targetRect.width;
33
+ }
34
+ if (isHorizontalLogicLayout(parentNodeLayout)) {
35
+ fakeY = getHorizontalFakeY(detectResult, targetIndex, parentComponent.node, targetRect, layout, fakeY);
36
+ if (isStandardLayout(parentNodeLayout)) {
37
+ const rightNodeCount = parentComponent.node.origin.rightNodeCount || 0;
38
+ const idx = parentComponent.node.children.findIndex(x => x === targetComponent.node);
39
+ const isLeft = idx >= rightNodeCount;
40
+ // 标准布局的左,需要调整 x
41
+ if (isLeft) {
42
+ fakeX = targetComponent.node.x + targetComponent.node.width - 30;
43
+ fakeRectangleStartX = targetRect.x + targetRect.width - 30;
44
+ fakeRectangleEndX = targetRect.x + targetRect.width;
45
+ }
46
+ const isLeftFirst = idx === rightNodeCount;
47
+ const isRightLast = idx === rightNodeCount - 1;
48
+ // 拖拽至左第一个节点的情况
49
+ if (detectResult === 'top' && isLeftFirst) {
50
+ fakeY = targetRect.y - targetRect.height;
51
+ }
52
+ if (detectResult === 'bottom' && isRightLast) {
53
+ fakeY = targetRect.y + targetRect.height + 30;
54
+ }
55
+ }
56
+ fakeRectangleStartY = fakeY;
57
+ fakeRectangleEndY = fakeRectangleStartY + 12;
58
+ }
59
+ if (isVerticalLogicLayout(layout)) {
60
+ parentComponent = targetComponent;
61
+ targetComponent = MINDMAP_ELEMENT_TO_COMPONENT.get(targetComponent.parent.origin);
62
+ fakeX = parentComponent.node.x;
63
+ width = parentComponent.node.width;
64
+ const vGap = BASE * 6 + strokeWidth;
65
+ if (isTopLayout(layout) && detectResult === 'top') {
66
+ fakeY = targetRect.y - vGap;
67
+ fakeRectangleStartY = fakeY - vGap + strokeWidth;
68
+ }
69
+ if (isBottomLayout(layout) && detectResult === 'bottom') {
70
+ fakeY = targetRect.y + targetRect.height + vGap;
71
+ fakeRectangleStartY = fakeY + vGap - strokeWidth;
72
+ }
73
+ fakeRectangleStartX = fakeX + Math.ceil(parentComponent.node.width / 2) - parentComponent.node.hGap - Math.ceil(strokeWidth / 2);
74
+ fakeRectangleEndX = fakeRectangleStartX + 30;
75
+ fakeRectangleEndY = fakeRectangleStartY + 12;
76
+ }
77
+ if (isIndentedLayout(layout)) {
78
+ // 偏移一个 Gap
79
+ if (isLeftLayout(layout)) {
80
+ fakeX -= BASE * 4;
81
+ }
82
+ if (isRightLayout(layout)) {
83
+ fakeX += BASE * 4;
84
+ }
85
+ if (isTopLayout(layout)) {
86
+ if (detectResult === 'top') {
87
+ const isLastNode = targetIndex === parentComponent.node.origin.children.length - 1;
88
+ if (isLastNode) {
89
+ fakeY = targetRect.y - targetRect.height - BASE;
90
+ }
91
+ else {
92
+ const nextComponent = MINDMAP_ELEMENT_TO_COMPONENT.get(parentComponent.node.origin.children[targetIndex + 1]);
93
+ const nextRect = getRectangleByNode(nextComponent.node);
94
+ fakeY = targetRect.y - Math.abs((nextRect.y + nextRect.height - targetRect.y) / 2);
95
+ }
96
+ }
97
+ if (detectResult === 'bottom') {
98
+ const isFirstNode = targetIndex === 0;
99
+ if (isFirstNode) {
100
+ const parentRect = getRectangleByNode(parentComponent.node);
101
+ fakeY = parentRect.y - parentRect.height / 2 - BASE;
102
+ }
103
+ else {
104
+ const previousComponent = MINDMAP_ELEMENT_TO_COMPONENT.get(parentComponent.node.origin.children[targetIndex - 1]);
105
+ const previousRect = getRectangleByNode(previousComponent.node);
106
+ fakeY = previousRect.y - Math.abs((targetRect.y + targetRect.height - previousRect.y) / 2);
107
+ }
108
+ }
109
+ }
110
+ fakeRectangleStartX = fakeX;
111
+ fakeRectangleEndX = fakeRectangleStartX + 30;
112
+ fakeRectangleStartY = fakeY;
113
+ fakeRectangleEndY = fakeRectangleStartY + 12;
114
+ }
115
+ // 构造一条曲线
116
+ const fakeNode = { ...targetComponent.node, x: fakeX, y: fakeY, width, height: 12 };
117
+ const linkSVGG = isIndentedLayout(layout)
118
+ ? drawIndentedLink(roughSVG, parentComponent.node, fakeNode, PRIMARY_COLOR, false)
119
+ : drawLink(roughSVG, parentComponent.node, fakeNode, PRIMARY_COLOR, isHorizontalLayout(layout), false);
120
+ // 构造一个矩形框坐标
121
+ const fakeRectangleG = drawRoundRectangle(roughSVG, fakeRectangleStartX, fakeRectangleStartY, fakeRectangleEndX, fakeRectangleEndY, {
122
+ stroke: PRIMARY_COLOR,
123
+ strokeWidth: 2,
124
+ fill: PRIMARY_COLOR,
125
+ fillStyle: 'solid'
126
+ });
127
+ fakeDropNodeG?.appendChild(linkSVGG);
128
+ fakeDropNodeG?.appendChild(fakeRectangleG);
129
+ };
130
+ export const drawStraightDropNodeG = (targetRect, detectResult, targetComponent, roughSVG, fakeDropNodeG) => {
131
+ const { x, y, width, height } = targetRect;
132
+ const lineLength = 40;
133
+ let startLinePoint = x + width;
134
+ let endLinePoint = x + width + lineLength;
135
+ let startRectanglePointX = x + width + lineLength;
136
+ let endRectanglePointX = x + lineLength + width + 30;
137
+ let startRectanglePointY = y + height / 2 - 6;
138
+ let endRectanglePointY = y + height / 2 - 6 + 12;
139
+ if (detectResult === 'left') {
140
+ startLinePoint = x - lineLength;
141
+ endLinePoint = x;
142
+ startRectanglePointX = x - lineLength - 30;
143
+ endRectanglePointX = x - lineLength;
144
+ }
145
+ let fakeY = targetComponent.node.y;
146
+ let fakeX = targetRect.x;
147
+ const strokeWidth = targetComponent.node.origin.linkLineWidth ? targetComponent.node.origin.linkLineWidth : STROKE_WIDTH;
148
+ const pointOptions = {
149
+ fakeX,
150
+ fakeY,
151
+ x,
152
+ y,
153
+ width,
154
+ height,
155
+ strokeWidth
156
+ };
157
+ const parentLayout = MindmapQueries.getCorrectLayoutByElement(targetComponent.node.origin.isRoot ? targetComponent.node.origin : targetComponent.node.parent.origin);
158
+ const layout = MindmapQueries.getCorrectLayoutByElement(targetComponent.node.origin);
159
+ if (!isMixedLayout(parentLayout, layout)) {
160
+ // 构造一条直线
161
+ let linePoints = [
162
+ [startLinePoint, y + height / 2],
163
+ [endLinePoint, y + height / 2]
164
+ ];
165
+ if (isIndentedLayout(parentLayout)) {
166
+ const fakePoint = getIndentedFakePoint(parentLayout, pointOptions);
167
+ drawIndentNodeG(fakeDropNodeG, roughSVG, fakePoint, targetComponent.node);
168
+ return;
169
+ }
170
+ else if (isVerticalLogicLayout(parentLayout)) {
171
+ if (!targetComponent.node.origin.isRoot) {
172
+ /**
173
+ * 计算逻辑:
174
+ * 1. 移动到左侧:当前节点 startX - 偏移值,偏移值计算如下:
175
+ * a. 第一个节点: 固定值(来源于 getMainAxle,第二级节点:BASE * 8,其他 BASE * 3 + strokeWidth / 2);
176
+ * b. 第二个节点到最后一个节点之间:上一个节点到当前节点间距的一半((当前节点 startX - 上一个节点的 endX) / 2),endX = 当前节点的 startX + width;
177
+ * 2. 移动到右侧:当前节点 x + width + 偏移值,偏移值计算如下:
178
+ * a. 第二个节点到最后一个节点之间的右侧:当前节点到下一个节点间距的一半((下一个节点 startX - 当前节点的 endX) / 2),endX = 当前节点的 startX + width;
179
+ * b. 最后一个节点的右侧:固定值(来源于 getMainAxle,第二级节点:BASE * 8,其他 BASE * 3 + strokeWidth / 2);
180
+ */
181
+ fakeY = targetComponent.node.y;
182
+ const parentComponent = MINDMAP_ELEMENT_TO_COMPONENT.get(targetComponent.parent.origin);
183
+ const targetIndex = parentComponent.node.origin.children.indexOf(targetComponent.node.origin);
184
+ if (detectResult === 'left') {
185
+ let offsetX = 0;
186
+ const isFirstNode = targetIndex === 0;
187
+ if (isFirstNode) {
188
+ offsetX = parentComponent.node.origin.isRoot ? BASE * 8 : BASE * 3 + strokeWidth / 2;
189
+ }
190
+ else {
191
+ const previousComponent = MINDMAP_ELEMENT_TO_COMPONENT.get(parentComponent.node.origin.children[targetIndex - 1]);
192
+ const previousRect = getRectangleByNode(previousComponent.node);
193
+ const space = targetRect.x - (previousRect.x + previousRect.width);
194
+ offsetX = space / 2;
195
+ }
196
+ fakeX = targetRect.x - offsetX - width / 2 - Math.ceil(strokeWidth / 2);
197
+ }
198
+ if (detectResult === 'right') {
199
+ let offsetX = 0;
200
+ const isLastNode = targetIndex === parentComponent.node.origin.children.length - 1;
201
+ if (isLastNode) {
202
+ offsetX = parentComponent.node.origin.isRoot ? BASE * 8 : BASE * 3 + strokeWidth / 2;
203
+ }
204
+ else {
205
+ const nextComponent = MINDMAP_ELEMENT_TO_COMPONENT.get(parentComponent.node.origin.children[targetIndex + 1]);
206
+ const nextRect = getRectangleByNode(nextComponent.node);
207
+ const space = nextRect.x - (targetRect.x + targetRect.width);
208
+ offsetX = space / 2;
209
+ }
210
+ fakeX = targetRect.x + width + offsetX - width / 2 - Math.ceil(strokeWidth / 2);
211
+ }
212
+ startRectanglePointX = fakeX;
213
+ if (isTopLayout(parentLayout)) {
214
+ // 因为矩形是从左上角为起点向下画的,所以需要向上偏移一个矩形的高度(-12)
215
+ startRectanglePointY = fakeY + height + targetComponent.node.vGap - 12;
216
+ }
217
+ if (isBottomLayout(parentLayout)) {
218
+ startRectanglePointY = fakeY + targetComponent.node.vGap;
219
+ }
220
+ endRectanglePointX = startRectanglePointX + 30;
221
+ endRectanglePointY = startRectanglePointY + 12;
222
+ const fakeNode = { ...targetComponent.node, x: fakeX, y: fakeY, width: 30 };
223
+ const linkSVGG = drawLink(roughSVG, parentComponent.node, fakeNode, PRIMARY_COLOR, false, false);
224
+ fakeDropNodeG?.appendChild(linkSVGG);
225
+ }
226
+ }
227
+ else {
228
+ let linkSVGG = roughSVG.linearPath(linePoints, { stroke: PRIMARY_COLOR, strokeWidth });
229
+ fakeDropNodeG?.appendChild(linkSVGG);
230
+ }
231
+ // 构造一个矩形框坐标
232
+ let fakeRectangleG = drawRoundRectangle(roughSVG, startRectanglePointX, startRectanglePointY, endRectanglePointX, endRectanglePointY, {
233
+ stroke: PRIMARY_COLOR,
234
+ strokeWidth: 2,
235
+ fill: PRIMARY_COLOR,
236
+ fillStyle: 'solid'
237
+ });
238
+ fakeDropNodeG?.appendChild(fakeRectangleG);
239
+ }
240
+ else {
241
+ // 混合布局画线逻辑
242
+ if (isHorizontalLogicLayout(parentLayout)) {
243
+ if (isIndentedLayout(layout)) {
244
+ const fakePoint = getIndentedFakePoint(layout, pointOptions);
245
+ drawIndentNodeG(fakeDropNodeG, roughSVG, fakePoint, targetComponent.node);
246
+ return;
247
+ }
248
+ }
249
+ }
250
+ };
251
+ export const getHorizontalFakeY = (detectResult, targetIndex, parentNode, targetRect, layout, fakeY) => {
252
+ if (detectResult === 'top') {
253
+ if (targetIndex === 0 && isTopLayout(layout)) {
254
+ fakeY = targetRect.y + targetRect.height;
255
+ }
256
+ if (targetIndex > 0) {
257
+ const previousComponent = MINDMAP_ELEMENT_TO_COMPONENT.get(parentNode.origin.children[targetIndex - 1]);
258
+ const previousRect = getRectangleByNode(previousComponent.node);
259
+ const topY = previousRect.y + previousRect.height;
260
+ fakeY = topY + (targetRect.y - topY) / 5;
261
+ }
262
+ }
263
+ if (detectResult === 'bottom') {
264
+ fakeY = targetRect.y + targetRect.height + 30;
265
+ if (targetIndex < parentNode.origin.children.length - 1) {
266
+ const nextComponent = MINDMAP_ELEMENT_TO_COMPONENT.get(parentNode.origin.children[targetIndex + 1]);
267
+ const nextRect = getRectangleByNode(nextComponent.node);
268
+ const topY = targetRect.y + targetRect.height;
269
+ fakeY = topY + (nextRect.y - topY) / 5;
270
+ }
271
+ if (targetIndex === parentNode.origin.children.length - 1) {
272
+ fakeY = targetRect.y + targetRect.height + 30;
273
+ }
274
+ }
275
+ return fakeY;
276
+ };
277
+ export const getIndentedFakePoint = (layout, pointOptions) => {
278
+ let { fakeX, fakeY, x, y, width, height, strokeWidth } = pointOptions;
279
+ const hGap = BASE * 4;
280
+ const vGap = BASE * 6;
281
+ const offsetX = hGap + width / 2 + strokeWidth;
282
+ const offsetY = vGap + height / 2 + strokeWidth;
283
+ if (isLeftLayout(layout)) {
284
+ fakeX = x - offsetX;
285
+ }
286
+ if (isRightLayout(layout)) {
287
+ fakeX = x + offsetX;
288
+ }
289
+ if (isTopLayout(layout)) {
290
+ fakeY = y - offsetY;
291
+ }
292
+ if (isBottomLayout(layout)) {
293
+ fakeY = y + height + offsetY;
294
+ }
295
+ return { fakeX, fakeY };
296
+ };
297
+ export const drawIndentNodeG = (fakeDropNodeG, roughSVG, fakePoint, node) => {
298
+ const { fakeX, fakeY } = fakePoint;
299
+ const fakeNode = { ...node, x: fakeX, y: fakeY, width: 30, height: 12 };
300
+ const linkSVGG = drawIndentedLink(roughSVG, node, fakeNode, PRIMARY_COLOR, false);
301
+ const startRectanglePointX = fakeX, startRectanglePointY = fakeY, endRectanglePointX = fakeX + 30, endRectanglePointY = fakeY + 12;
302
+ const fakeRectangleG = drawRoundRectangle(roughSVG, startRectanglePointX, startRectanglePointY, endRectanglePointX, endRectanglePointY, {
303
+ stroke: PRIMARY_COLOR,
304
+ strokeWidth: 2,
305
+ fill: PRIMARY_COLOR,
306
+ fillStyle: 'solid'
307
+ });
308
+ fakeDropNodeG?.appendChild(linkSVGG);
309
+ fakeDropNodeG?.appendChild(fakeRectangleG);
310
+ };
311
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"draw-placeholder.js","sourceRoot":"","sources":["../../../../packages/mind/src/utils/draw-placeholder.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,IAAI,EAAE,aAAa,EAAE,YAAY,EAAE,MAAM,cAAc,CAAC;AACjE,OAAO,EAAE,QAAQ,EAAE,MAAM,cAAc,CAAC;AAGxC,OAAO,EAAE,kBAAkB,EAAE,MAAM,SAAS,CAAC;AAC7C,OAAO,EAAE,4BAA4B,EAAE,MAAM,aAAa,CAAC;AAC3D,OAAO,EAAS,kBAAkB,EAAE,MAAM,aAAa,CAAC;AACxD,OAAO,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;AAC5C,OAAO,EACH,cAAc,EACd,kBAAkB,EAClB,uBAAuB,EACvB,gBAAgB,EAChB,aAAa,EACb,qBAAqB,EAExB,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,gBAAgB,EAAE,MAAM,uBAAuB,CAAC;AACzD,OAAO,EAAE,YAAY,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAC3D,OAAO,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AAClD,OAAO,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AAEzC,MAAM,CAAC,MAAM,wBAAwB,GAAG,CACpC,UAA+D,EAC/D,QAAkB,EAClB,aAAsC,EACxC,EAAE;IACA,MAAM,eAAe,GAAG,4BAA4B,CAAC,GAAG,CAAC,UAAU,CAAC,MAAM,CAAsB,CAAC;IACjG,MAAM,UAAU,GAAG,kBAAkB,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;IAC5D,IAAI,UAAU,CAAC,YAAY,IAAI,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC,QAAQ,CAAC,UAAU,CAAC,YAAY,CAAC,EAAE;QAChF,qBAAqB,CAAC,UAAU,EAAE,UAAU,CAAC,YAAY,EAAE,eAAe,EAAE,QAAQ,EAAE,aAAa,CAAC,CAAC;KACxG;IAED,IAAI,eAAe,CAAC,MAAM,IAAI,UAAU,CAAC,YAAY,IAAI,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC,QAAQ,CAAC,UAAU,CAAC,YAAY,CAAC,EAAE;QAC1G,MAAM,eAAe,GAAG,4BAA4B,CAAC,GAAG,CAAC,eAAe,CAAC,MAAM,CAAC,MAAM,CAAsB,CAAC;QAC7G,MAAM,WAAW,GAAG,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,OAAO,CAAC,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAC9F,6BAA6B,CACzB,UAAU,EACV,UAAU,CAAC,YAAY,EACvB,WAAW,EACX,eAAe,EACf,QAAQ,EACR,eAAe,EACf,aAAa,CAChB,CAAC;KACL;AACL,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,6BAA6B,GAAG,CACzC,UAKC,EACD,YAA0B,EAC1B,WAAmB,EACnB,eAAkC,EAClC,QAAkB,EAClB,eAAkC,EAClC,aAAsC,EACxC,EAAE;IACA,MAAM,gBAAgB,GAAG,cAAc,CAAC,yBAAyB,CAAC,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAC/F,MAAM,MAAM,GAAG,cAAc,CAAC,yBAAyB,CAAC,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;IAC5F,MAAM,WAAW,GAAG,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC,CAAC,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC,CAAC,YAAY,CAAC;IACzH,IAAI,KAAK,GAAG,eAAe,CAAC,IAAI,CAAC,CAAC,EAC9B,KAAK,GAAG,UAAU,CAAC,CAAC,GAAG,EAAE,EACzB,mBAAmB,GAAG,UAAU,CAAC,CAAC,EAClC,iBAAiB,GAAG,UAAU,CAAC,CAAC,GAAG,EAAE,EACrC,mBAAmB,GAAG,KAAK,EAC3B,iBAAiB,GAAG,mBAAmB,GAAG,EAAE,EAC5C,KAAK,GAAG,EAAE,CAAC;IAEf,IAAI,YAAY,CAAC,MAAM,CAAC,EAAE;QACtB,KAAK,GAAG,eAAe,CAAC,IAAI,CAAC,CAAC,GAAG,eAAe,CAAC,IAAI,CAAC,KAAK,GAAG,EAAE,CAAC;QACjE,mBAAmB,GAAG,UAAU,CAAC,CAAC,GAAG,UAAU,CAAC,KAAK,GAAG,EAAE,CAAC;QAC3D,iBAAiB,GAAG,UAAU,CAAC,CAAC,GAAG,UAAU,CAAC,KAAK,CAAC;KACvD;IACD,IAAI,uBAAuB,CAAC,gBAAgB,CAAC,EAAE;QAC3C,KAAK,GAAG,kBAAkB,CAAC,YAAgC,EAAE,WAAW,EAAE,eAAe,CAAC,IAAI,EAAE,UAAU,EAAE,MAAM,EAAE,KAAK,CAAC,CAAC;QAC3H,IAAI,gBAAgB,CAAC,gBAAgB,CAAC,EAAE;YACpC,MAAM,cAAc,GAAG,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,cAAc,IAAI,CAAC,CAAC;YACvE,MAAM,GAAG,GAAG,eAAe,CAAC,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,eAAe,CAAC,IAAI,CAAC,CAAC;YACrF,MAAM,MAAM,GAAG,GAAG,IAAI,cAAc,CAAC;YACrC,gBAAgB;YAChB,IAAI,MAAM,EAAE;gBACR,KAAK,GAAG,eAAe,CAAC,IAAI,CAAC,CAAC,GAAG,eAAe,CAAC,IAAI,CAAC,KAAK,GAAG,EAAE,CAAC;gBACjE,mBAAmB,GAAG,UAAU,CAAC,CAAC,GAAG,UAAU,CAAC,KAAK,GAAG,EAAE,CAAC;gBAC3D,iBAAiB,GAAG,UAAU,CAAC,CAAC,GAAG,UAAU,CAAC,KAAK,CAAC;aACvD;YACD,MAAM,WAAW,GAAG,GAAG,KAAK,cAAc,CAAC;YAC3C,MAAM,WAAW,GAAG,GAAG,KAAK,cAAc,GAAG,CAAC,CAAC;YAC/C,eAAe;YACf,IAAI,YAAY,KAAK,KAAK,IAAI,WAAW,EAAE;gBACvC,KAAK,GAAG,UAAU,CAAC,CAAC,GAAG,UAAU,CAAC,MAAM,CAAC;aAC5C;YACD,IAAI,YAAY,KAAK,QAAQ,IAAI,WAAW,EAAE;gBAC1C,KAAK,GAAG,UAAU,CAAC,CAAC,GAAG,UAAU,CAAC,MAAM,GAAG,EAAE,CAAC;aACjD;SACJ;QACD,mBAAmB,GAAG,KAAK,CAAC;QAC5B,iBAAiB,GAAG,mBAAmB,GAAG,EAAE,CAAC;KAChD;IAED,IAAI,qBAAqB,CAAC,MAAM,CAAC,EAAE;QAC/B,eAAe,GAAG,eAAe,CAAC;QAClC,eAAe,GAAG,4BAA4B,CAAC,GAAG,CAAC,eAAe,CAAC,MAAM,CAAC,MAAM,CAAsB,CAAC;QACvG,KAAK,GAAG,eAAe,CAAC,IAAI,CAAC,CAAC,CAAC;QAC/B,KAAK,GAAG,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC;QACnC,MAAM,IAAI,GAAG,IAAI,GAAG,CAAC,GAAG,WAAW,CAAC;QACpC,IAAI,WAAW,CAAC,MAAM,CAAC,IAAI,YAAY,KAAK,KAAK,EAAE;YAC/C,KAAK,GAAG,UAAU,CAAC,CAAC,GAAG,IAAI,CAAC;YAC5B,mBAAmB,GAAG,KAAK,GAAG,IAAI,GAAG,WAAW,CAAC;SACpD;QACD,IAAI,cAAc,CAAC,MAAM,CAAC,IAAI,YAAY,KAAK,QAAQ,EAAE;YACrD,KAAK,GAAG,UAAU,CAAC,CAAC,GAAG,UAAU,CAAC,MAAM,GAAG,IAAI,CAAC;YAChD,mBAAmB,GAAG,KAAK,GAAG,IAAI,GAAG,WAAW,CAAC;SACpD;QACD,mBAAmB,GAAG,KAAK,GAAG,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC,GAAG,eAAe,CAAC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC,WAAW,GAAG,CAAC,CAAC,CAAC;QACjI,iBAAiB,GAAG,mBAAmB,GAAG,EAAE,CAAC;QAC7C,iBAAiB,GAAG,mBAAmB,GAAG,EAAE,CAAC;KAChD;IACD,IAAI,gBAAgB,CAAC,MAAM,CAAC,EAAE;QAC1B,WAAW;QACX,IAAI,YAAY,CAAC,MAAM,CAAC,EAAE;YACtB,KAAK,IAAI,IAAI,GAAG,CAAC,CAAC;SACrB;QACD,IAAI,aAAa,CAAC,MAAM,CAAC,EAAE;YACvB,KAAK,IAAI,IAAI,GAAG,CAAC,CAAC;SACrB;QACD,IAAI,WAAW,CAAC,MAAM,CAAC,EAAE;YACrB,IAAI,YAAY,KAAK,KAAK,EAAE;gBACxB,MAAM,UAAU,GAAG,WAAW,KAAK,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,CAAC;gBACnF,IAAI,UAAU,EAAE;oBACZ,KAAK,GAAG,UAAU,CAAC,CAAC,GAAG,UAAU,CAAC,MAAM,GAAG,IAAI,CAAC;iBACnD;qBAAM;oBACH,MAAM,aAAa,GAAG,4BAA4B,CAAC,GAAG,CAClD,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,WAAW,GAAG,CAAC,CAAC,CACnC,CAAC;oBACvB,MAAM,QAAQ,GAAG,kBAAkB,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;oBACxD,KAAK,GAAG,UAAU,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,QAAQ,CAAC,CAAC,GAAG,QAAQ,CAAC,MAAM,GAAG,UAAU,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;iBACtF;aACJ;YACD,IAAI,YAAY,KAAK,QAAQ,EAAE;gBAC3B,MAAM,WAAW,GAAG,WAAW,KAAK,CAAC,CAAC;gBACtC,IAAI,WAAW,EAAE;oBACb,MAAM,UAAU,GAAG,kBAAkB,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;oBAC5D,KAAK,GAAG,UAAU,CAAC,CAAC,GAAG,UAAU,CAAC,MAAM,GAAG,CAAC,GAAG,IAAI,CAAC;iBACvD;qBAAM;oBACH,MAAM,iBAAiB,GAAG,4BAA4B,CAAC,GAAG,CACtD,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,WAAW,GAAG,CAAC,CAAC,CACnC,CAAC;oBACvB,MAAM,YAAY,GAAG,kBAAkB,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;oBAChE,KAAK,GAAG,YAAY,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,UAAU,CAAC,CAAC,GAAG,UAAU,CAAC,MAAM,GAAG,YAAY,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;iBAC9F;aACJ;SACJ;QACD,mBAAmB,GAAG,KAAK,CAAC;QAC5B,iBAAiB,GAAG,mBAAmB,GAAG,EAAE,CAAC;QAC7C,mBAAmB,GAAG,KAAK,CAAC;QAC5B,iBAAiB,GAAG,mBAAmB,GAAG,EAAE,CAAC;KAChD;IAED,SAAS;IACT,MAAM,QAAQ,GAAgB,EAAE,GAAG,eAAe,CAAC,IAAI,EAAE,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,EAAE,EAAE,CAAC;IACjG,MAAM,QAAQ,GAAG,gBAAgB,CAAC,MAAM,CAAC;QACrC,CAAC,CAAC,gBAAgB,CAAC,QAAQ,EAAE,eAAe,CAAC,IAAI,EAAE,QAAQ,EAAE,aAAa,EAAE,KAAK,CAAC;QAClF,CAAC,CAAC,QAAQ,CAAC,QAAQ,EAAE,eAAe,CAAC,IAAI,EAAE,QAAQ,EAAE,aAAa,EAAE,kBAAkB,CAAC,MAAM,CAAC,EAAE,KAAK,CAAC,CAAC;IAC3G,YAAY;IACZ,MAAM,cAAc,GAAG,kBAAkB,CAAC,QAAQ,EAAE,mBAAmB,EAAE,mBAAmB,EAAE,iBAAiB,EAAE,iBAAiB,EAAE;QAChI,MAAM,EAAE,aAAa;QACrB,WAAW,EAAE,CAAC;QACd,IAAI,EAAE,aAAa;QACnB,SAAS,EAAE,OAAO;KACrB,CAAC,CAAC;IACH,aAAa,EAAE,WAAW,CAAC,QAAQ,CAAC,CAAC;IACrC,aAAa,EAAE,WAAW,CAAC,cAAc,CAAC,CAAC;AAC/C,CAAC,CAAC;AACF,MAAM,CAAC,MAAM,qBAAqB,GAAG,CACjC,UAKC,EACD,YAA0B,EAC1B,eAAkC,EAClC,QAAkB,EAClB,aAAsC,EACxC,EAAE;IACA,MAAM,EAAE,CAAC,EAAE,CAAC,EAAE,KAAK,EAAE,MAAM,EAAE,GAAG,UAAU,CAAC;IAC3C,MAAM,UAAU,GAAG,EAAE,CAAC;IACtB,IAAI,cAAc,GAAG,CAAC,GAAG,KAAK,CAAC;IAC/B,IAAI,YAAY,GAAG,CAAC,GAAG,KAAK,GAAG,UAAU,CAAC;IAC1C,IAAI,oBAAoB,GAAG,CAAC,GAAG,KAAK,GAAG,UAAU,CAAC;IAClD,IAAI,kBAAkB,GAAG,CAAC,GAAG,UAAU,GAAG,KAAK,GAAG,EAAE,CAAC;IACrD,IAAI,oBAAoB,GAAG,CAAC,GAAG,MAAM,GAAG,CAAC,GAAG,CAAC,CAAC;IAC9C,IAAI,kBAAkB,GAAG,CAAC,GAAG,MAAM,GAAG,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC;IAEjD,IAAI,YAAY,KAAK,MAAM,EAAE;QACzB,cAAc,GAAG,CAAC,GAAG,UAAU,CAAC;QAChC,YAAY,GAAG,CAAC,CAAC;QACjB,oBAAoB,GAAG,CAAC,GAAG,UAAU,GAAG,EAAE,CAAC;QAC3C,kBAAkB,GAAG,CAAC,GAAG,UAAU,CAAC;KACvC;IACD,IAAI,KAAK,GAAG,eAAe,CAAC,IAAI,CAAC,CAAC,CAAC;IACnC,IAAI,KAAK,GAAG,UAAU,CAAC,CAAC,CAAC;IACzB,MAAM,WAAW,GAAG,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC,CAAC,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC,CAAC,YAAY,CAAC;IACzH,MAAM,YAAY,GAAG;QACjB,KAAK;QACL,KAAK;QACL,CAAC;QACD,CAAC;QACD,KAAK;QACL,MAAM;QACN,WAAW;KACd,CAAC;IACF,MAAM,YAAY,GAAG,cAAc,CAAC,yBAAyB,CACzD,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CACxG,CAAC;IACF,MAAM,MAAM,GAAG,cAAc,CAAC,yBAAyB,CAAC,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IACrF,IAAI,CAAC,aAAa,CAAC,YAAY,EAAE,MAAM,CAAC,EAAE;QACtC,SAAS;QACT,IAAI,UAAU,GAAG;YACb,CAAC,cAAc,EAAE,CAAC,GAAG,MAAM,GAAG,CAAC,CAAC;YAChC,CAAC,YAAY,EAAE,CAAC,GAAG,MAAM,GAAG,CAAC,CAAC;SACtB,CAAC;QACb,IAAI,gBAAgB,CAAC,YAAY,CAAC,EAAE;YAChC,MAAM,SAAS,GAAG,oBAAoB,CAAC,YAAY,EAAE,YAAY,CAAC,CAAC;YACnE,eAAe,CAAC,aAA4B,EAAE,QAAQ,EAAE,SAAS,EAAE,eAAe,CAAC,IAAI,CAAC,CAAC;YACzF,OAAO;SACV;aAAM,IAAI,qBAAqB,CAAC,YAAY,CAAC,EAAE;YAC5C,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE;gBACrC;;;;;;;;mBAQG;gBACH,KAAK,GAAG,eAAe,CAAC,IAAI,CAAC,CAAC,CAAC;gBAC/B,MAAM,eAAe,GAAG,4BAA4B,CAAC,GAAG,CAAC,eAAe,CAAC,MAAM,CAAC,MAAM,CAAsB,CAAC;gBAC7G,MAAM,WAAW,GAAG,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,OAAO,CAAC,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;gBAE9F,IAAI,YAAY,KAAK,MAAM,EAAE;oBACzB,IAAI,OAAO,GAAG,CAAC,CAAC;oBAChB,MAAM,WAAW,GAAG,WAAW,KAAK,CAAC,CAAC;oBACtC,IAAI,WAAW,EAAE;wBACb,OAAO,GAAG,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,GAAG,CAAC,GAAG,WAAW,GAAG,CAAC,CAAC;qBACxF;yBAAM;wBACH,MAAM,iBAAiB,GAAG,4BAA4B,CAAC,GAAG,CACtD,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,WAAW,GAAG,CAAC,CAAC,CACnC,CAAC;wBACvB,MAAM,YAAY,GAAG,kBAAkB,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;wBAChE,MAAM,KAAK,GAAG,UAAU,CAAC,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC,GAAG,YAAY,CAAC,KAAK,CAAC,CAAC;wBACnE,OAAO,GAAG,KAAK,GAAG,CAAC,CAAC;qBACvB;oBACD,KAAK,GAAG,UAAU,CAAC,CAAC,GAAG,OAAO,GAAG,KAAK,GAAG,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,WAAW,GAAG,CAAC,CAAC,CAAC;iBAC3E;gBACD,IAAI,YAAY,KAAK,OAAO,EAAE;oBAC1B,IAAI,OAAO,GAAG,CAAC,CAAC;oBAChB,MAAM,UAAU,GAAG,WAAW,KAAK,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,CAAC;oBACnF,IAAI,UAAU,EAAE;wBACZ,OAAO,GAAG,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,GAAG,CAAC,GAAG,WAAW,GAAG,CAAC,CAAC;qBACxF;yBAAM;wBACH,MAAM,aAAa,GAAG,4BAA4B,CAAC,GAAG,CAClD,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,WAAW,GAAG,CAAC,CAAC,CACnC,CAAC;wBACvB,MAAM,QAAQ,GAAG,kBAAkB,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;wBACxD,MAAM,KAAK,GAAG,QAAQ,CAAC,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,GAAG,UAAU,CAAC,KAAK,CAAC,CAAC;wBAC7D,OAAO,GAAG,KAAK,GAAG,CAAC,CAAC;qBACvB;oBACD,KAAK,GAAG,UAAU,CAAC,CAAC,GAAG,KAAK,GAAG,OAAO,GAAG,KAAK,GAAG,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,WAAW,GAAG,CAAC,CAAC,CAAC;iBACnF;gBACD,oBAAoB,GAAG,KAAK,CAAC;gBAC7B,IAAI,WAAW,CAAC,YAAY,CAAC,EAAE;oBAC3B,wCAAwC;oBACxC,oBAAoB,GAAG,KAAK,GAAG,MAAM,GAAG,eAAe,CAAC,IAAI,CAAC,IAAI,GAAG,EAAE,CAAC;iBAC1E;gBACD,IAAI,cAAc,CAAC,YAAY,CAAC,EAAE;oBAC9B,oBAAoB,GAAG,KAAK,GAAG,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC;iBAC5D;gBACD,kBAAkB,GAAG,oBAAoB,GAAG,EAAE,CAAC;gBAC/C,kBAAkB,GAAG,oBAAoB,GAAG,EAAE,CAAC;gBAC/C,MAAM,QAAQ,GAAgB,EAAE,GAAG,eAAe,CAAC,IAAI,EAAE,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC;gBACzF,MAAM,QAAQ,GAAG,QAAQ,CAAC,QAAQ,EAAE,eAAe,CAAC,IAAI,EAAE,QAAQ,EAAE,aAAa,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC;gBACjG,aAAa,EAAE,WAAW,CAAC,QAAQ,CAAC,CAAC;aACxC;SACJ;aAAM;YACH,IAAI,QAAQ,GAAG,QAAQ,CAAC,UAAU,CAAC,UAAU,EAAE,EAAE,MAAM,EAAE,aAAa,EAAE,WAAW,EAAE,CAAC,CAAC;YACvF,aAAa,EAAE,WAAW,CAAC,QAAQ,CAAC,CAAC;SACxC;QACD,YAAY;QACZ,IAAI,cAAc,GAAG,kBAAkB,CACnC,QAAQ,EACR,oBAAoB,EACpB,oBAAoB,EACpB,kBAAkB,EAClB,kBAAkB,EAClB;YACI,MAAM,EAAE,aAAa;YACrB,WAAW,EAAE,CAAC;YACd,IAAI,EAAE,aAAa;YACnB,SAAS,EAAE,OAAO;SACrB,CACJ,CAAC;QAEF,aAAa,EAAE,WAAW,CAAC,cAAc,CAAC,CAAC;KAC9C;SAAM;QACH,WAAW;QACX,IAAI,uBAAuB,CAAC,YAAY,CAAC,EAAE;YACvC,IAAI,gBAAgB,CAAC,MAAM,CAAC,EAAE;gBAC1B,MAAM,SAAS,GAAG,oBAAoB,CAAC,MAAM,EAAE,YAAY,CAAC,CAAC;gBAC7D,eAAe,CAAC,aAA4B,EAAE,QAAQ,EAAE,SAAS,EAAE,eAAe,CAAC,IAAI,CAAC,CAAC;gBACzF,OAAO;aACV;SACJ;KACJ;AACL,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,kBAAkB,GAAG,CAC9B,YAA8B,EAC9B,WAAmB,EACnB,UAAuB,EACvB,UAKC,EACD,MAAyB,EACzB,KAAa,EACf,EAAE;IACA,IAAI,YAAY,KAAK,KAAK,EAAE;QACxB,IAAI,WAAW,KAAK,CAAC,IAAI,WAAW,CAAC,MAAM,CAAC,EAAE;YAC1C,KAAK,GAAG,UAAU,CAAC,CAAC,GAAG,UAAU,CAAC,MAAM,CAAC;SAC5C;QACD,IAAI,WAAW,GAAG,CAAC,EAAE;YACjB,MAAM,iBAAiB,GAAG,4BAA4B,CAAC,GAAG,CAAC,UAAU,CAAC,MAAM,CAAC,QAAQ,CAAC,WAAW,GAAG,CAAC,CAAC,CAAsB,CAAC;YAC7H,MAAM,YAAY,GAAG,kBAAkB,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;YAChE,MAAM,IAAI,GAAG,YAAY,CAAC,CAAC,GAAG,YAAY,CAAC,MAAM,CAAC;YAClD,KAAK,GAAG,IAAI,GAAG,CAAC,UAAU,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC;SAC5C;KACJ;IACD,IAAI,YAAY,KAAK,QAAQ,EAAE;QAC3B,KAAK,GAAG,UAAU,CAAC,CAAC,GAAG,UAAU,CAAC,MAAM,GAAG,EAAE,CAAC;QAC9C,IAAI,WAAW,GAAG,UAAU,CAAC,MAAM,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE;YACrD,MAAM,aAAa,GAAG,4BAA4B,CAAC,GAAG,CAAC,UAAU,CAAC,MAAM,CAAC,QAAQ,CAAC,WAAW,GAAG,CAAC,CAAC,CAAsB,CAAC;YACzH,MAAM,QAAQ,GAAG,kBAAkB,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;YACxD,MAAM,IAAI,GAAG,UAAU,CAAC,CAAC,GAAG,UAAU,CAAC,MAAM,CAAC;YAC9C,KAAK,GAAG,IAAI,GAAG,CAAC,QAAQ,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC;SAC1C;QACD,IAAI,WAAW,KAAK,UAAU,CAAC,MAAM,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE;YACvD,KAAK,GAAG,UAAU,CAAC,CAAC,GAAG,UAAU,CAAC,MAAM,GAAG,EAAE,CAAC;SACjD;KACJ;IACD,OAAO,KAAK,CAAC;AACjB,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,oBAAoB,GAAG,CAChC,MAAyB,EACzB,YAQC,EACH,EAAE;IACA,IAAI,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC,EAAE,CAAC,EAAE,KAAK,EAAE,MAAM,EAAE,WAAW,EAAE,GAAG,YAAY,CAAC;IACtE,MAAM,IAAI,GAAG,IAAI,GAAG,CAAC,CAAC;IACtB,MAAM,IAAI,GAAG,IAAI,GAAG,CAAC,CAAC;IACtB,MAAM,OAAO,GAAG,IAAI,GAAG,KAAK,GAAG,CAAC,GAAG,WAAW,CAAC;IAC/C,MAAM,OAAO,GAAG,IAAI,GAAG,MAAM,GAAG,CAAC,GAAG,WAAW,CAAC;IAChD,IAAI,YAAY,CAAC,MAAM,CAAC,EAAE;QACtB,KAAK,GAAG,CAAC,GAAG,OAAO,CAAC;KACvB;IACD,IAAI,aAAa,CAAC,MAAM,CAAC,EAAE;QACvB,KAAK,GAAG,CAAC,GAAG,OAAO,CAAC;KACvB;IACD,IAAI,WAAW,CAAC,MAAM,CAAC,EAAE;QACrB,KAAK,GAAG,CAAC,GAAG,OAAO,CAAC;KACvB;IACD,IAAI,cAAc,CAAC,MAAM,CAAC,EAAE;QACxB,KAAK,GAAG,CAAC,GAAG,MAAM,GAAG,OAAO,CAAC;KAChC;IACD,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC;AAC5B,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,eAAe,GAAG,CAC3B,aAA0B,EAC1B,QAAkB,EAClB,SAA2C,EAC3C,IAAiB,EACnB,EAAE;IACA,MAAM,EAAE,KAAK,EAAE,KAAK,EAAE,GAAG,SAAS,CAAC;IACnC,MAAM,QAAQ,GAAgB,EAAE,GAAG,IAAI,EAAE,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,CAAC;IACrF,MAAM,QAAQ,GAAG,gBAAgB,CAAC,QAAQ,EAAE,IAAI,EAAE,QAAQ,EAAE,aAAa,EAAE,KAAK,CAAC,CAAC;IAElF,MAAM,oBAAoB,GAAG,KAAK,EAC9B,oBAAoB,GAAG,KAAK,EAC5B,kBAAkB,GAAG,KAAK,GAAG,EAAE,EAC/B,kBAAkB,GAAG,KAAK,GAAG,EAAE,CAAC;IACpC,MAAM,cAAc,GAAG,kBAAkB,CACrC,QAAQ,EACR,oBAAoB,EACpB,oBAAoB,EACpB,kBAAkB,EAClB,kBAAkB,EAClB;QACI,MAAM,EAAE,aAAa;QACrB,WAAW,EAAE,CAAC;QACd,IAAI,EAAE,aAAa;QACnB,SAAS,EAAE,OAAO;KACrB,CACJ,CAAC;IACF,aAAa,EAAE,WAAW,CAAC,QAAQ,CAAC,CAAC;IACrC,aAAa,EAAE,WAAW,CAAC,cAAc,CAAC,CAAC;AAC/C,CAAC,CAAC","sourcesContent":["import { RoughSVG } from 'roughjs/bin/svg';\nimport { BASE, PRIMARY_COLOR, STROKE_WIDTH } from '../constants';\nimport { drawLink } from '../draw/link';\nimport { DetectResult, MindElement, MindmapNode } from '../interfaces';\nimport { MindNodeComponent } from '../node.component';\nimport { getRectangleByNode } from './graph';\nimport { MINDMAP_ELEMENT_TO_COMPONENT } from './weak-maps';\nimport { Point, drawRoundRectangle } from '@plait/core';\nimport { MindmapQueries } from '../queries';\nimport {\n    isBottomLayout,\n    isHorizontalLayout,\n    isHorizontalLogicLayout,\n    isIndentedLayout,\n    isRightLayout,\n    isVerticalLogicLayout,\n    MindmapLayoutType\n} from '@plait/layouts';\nimport { drawIndentedLink } from '../draw/indented-link';\nimport { isLeftLayout, isTopLayout } from '@plait/layouts';\nimport { isStandardLayout } from '@plait/layouts';\nimport { isMixedLayout } from './layout';\n\nexport const drawPlaceholderDropNodeG = (\n    dropTarget: { target: MindElement; detectResult: DetectResult },\n    roughSVG: RoughSVG,\n    fakeDropNodeG: SVGGElement | undefined\n) => {\n    const targetComponent = MINDMAP_ELEMENT_TO_COMPONENT.get(dropTarget.target) as MindNodeComponent;\n    const targetRect = getRectangleByNode(targetComponent.node);\n    if (dropTarget.detectResult && ['right', 'left'].includes(dropTarget.detectResult)) {\n        drawStraightDropNodeG(targetRect, dropTarget.detectResult, targetComponent, roughSVG, fakeDropNodeG);\n    }\n\n    if (targetComponent.parent && dropTarget.detectResult && ['top', 'bottom'].includes(dropTarget.detectResult)) {\n        const parentComponent = MINDMAP_ELEMENT_TO_COMPONENT.get(targetComponent.parent.origin) as MindNodeComponent;\n        const targetIndex = parentComponent.node.origin.children.indexOf(targetComponent.node.origin);\n        drawCurvePlaceholderDropNodeG(\n            targetRect,\n            dropTarget.detectResult,\n            targetIndex,\n            targetComponent,\n            roughSVG,\n            parentComponent,\n            fakeDropNodeG\n        );\n    }\n};\n\nexport const drawCurvePlaceholderDropNodeG = (\n    targetRect: {\n        x: number;\n        y: number;\n        width: number;\n        height: number;\n    },\n    detectResult: DetectResult,\n    targetIndex: number,\n    targetComponent: MindNodeComponent,\n    roughSVG: RoughSVG,\n    parentComponent: MindNodeComponent,\n    fakeDropNodeG: SVGGElement | undefined\n) => {\n    const parentNodeLayout = MindmapQueries.getCorrectLayoutByElement(parentComponent.node.origin);\n    const layout = MindmapQueries.getCorrectLayoutByElement(targetComponent.node.parent.origin);\n    const strokeWidth = targetComponent.node.origin.linkLineWidth ? targetComponent.node.origin.linkLineWidth : STROKE_WIDTH;\n    let fakeX = targetComponent.node.x,\n        fakeY = targetRect.y - 30,\n        fakeRectangleStartX = targetRect.x,\n        fakeRectangleEndX = targetRect.x + 30,\n        fakeRectangleStartY = fakeY,\n        fakeRectangleEndY = fakeRectangleStartY + 12,\n        width = 30;\n\n    if (isLeftLayout(layout)) {\n        fakeX = targetComponent.node.x + targetComponent.node.width - 30;\n        fakeRectangleStartX = targetRect.x + targetRect.width - 30;\n        fakeRectangleEndX = targetRect.x + targetRect.width;\n    }\n    if (isHorizontalLogicLayout(parentNodeLayout)) {\n        fakeY = getHorizontalFakeY(detectResult as 'top' | 'bottom', targetIndex, parentComponent.node, targetRect, layout, fakeY);\n        if (isStandardLayout(parentNodeLayout)) {\n            const rightNodeCount = parentComponent.node.origin.rightNodeCount || 0;\n            const idx = parentComponent.node.children.findIndex(x => x === targetComponent.node);\n            const isLeft = idx >= rightNodeCount;\n            // 标准布局的左，需要调整 x\n            if (isLeft) {\n                fakeX = targetComponent.node.x + targetComponent.node.width - 30;\n                fakeRectangleStartX = targetRect.x + targetRect.width - 30;\n                fakeRectangleEndX = targetRect.x + targetRect.width;\n            }\n            const isLeftFirst = idx === rightNodeCount;\n            const isRightLast = idx === rightNodeCount - 1;\n            // 拖拽至左第一个节点的情况\n            if (detectResult === 'top' && isLeftFirst) {\n                fakeY = targetRect.y - targetRect.height;\n            }\n            if (detectResult === 'bottom' && isRightLast) {\n                fakeY = targetRect.y + targetRect.height + 30;\n            }\n        }\n        fakeRectangleStartY = fakeY;\n        fakeRectangleEndY = fakeRectangleStartY + 12;\n    }\n\n    if (isVerticalLogicLayout(layout)) {\n        parentComponent = targetComponent;\n        targetComponent = MINDMAP_ELEMENT_TO_COMPONENT.get(targetComponent.parent.origin) as MindNodeComponent;\n        fakeX = parentComponent.node.x;\n        width = parentComponent.node.width;\n        const vGap = BASE * 6 + strokeWidth;\n        if (isTopLayout(layout) && detectResult === 'top') {\n            fakeY = targetRect.y - vGap;\n            fakeRectangleStartY = fakeY - vGap + strokeWidth;\n        }\n        if (isBottomLayout(layout) && detectResult === 'bottom') {\n            fakeY = targetRect.y + targetRect.height + vGap;\n            fakeRectangleStartY = fakeY + vGap - strokeWidth;\n        }\n        fakeRectangleStartX = fakeX + Math.ceil(parentComponent.node.width / 2) - parentComponent.node.hGap - Math.ceil(strokeWidth / 2);\n        fakeRectangleEndX = fakeRectangleStartX + 30;\n        fakeRectangleEndY = fakeRectangleStartY + 12;\n    }\n    if (isIndentedLayout(layout)) {\n        // 偏移一个 Gap\n        if (isLeftLayout(layout)) {\n            fakeX -= BASE * 4;\n        }\n        if (isRightLayout(layout)) {\n            fakeX += BASE * 4;\n        }\n        if (isTopLayout(layout)) {\n            if (detectResult === 'top') {\n                const isLastNode = targetIndex === parentComponent.node.origin.children.length - 1;\n                if (isLastNode) {\n                    fakeY = targetRect.y - targetRect.height - BASE;\n                } else {\n                    const nextComponent = MINDMAP_ELEMENT_TO_COMPONENT.get(\n                        parentComponent.node.origin.children[targetIndex + 1]\n                    ) as MindNodeComponent;\n                    const nextRect = getRectangleByNode(nextComponent.node);\n                    fakeY = targetRect.y - Math.abs((nextRect.y + nextRect.height - targetRect.y) / 2);\n                }\n            }\n            if (detectResult === 'bottom') {\n                const isFirstNode = targetIndex === 0;\n                if (isFirstNode) {\n                    const parentRect = getRectangleByNode(parentComponent.node);\n                    fakeY = parentRect.y - parentRect.height / 2 - BASE;\n                } else {\n                    const previousComponent = MINDMAP_ELEMENT_TO_COMPONENT.get(\n                        parentComponent.node.origin.children[targetIndex - 1]\n                    ) as MindNodeComponent;\n                    const previousRect = getRectangleByNode(previousComponent.node);\n                    fakeY = previousRect.y - Math.abs((targetRect.y + targetRect.height - previousRect.y) / 2);\n                }\n            }\n        }\n        fakeRectangleStartX = fakeX;\n        fakeRectangleEndX = fakeRectangleStartX + 30;\n        fakeRectangleStartY = fakeY;\n        fakeRectangleEndY = fakeRectangleStartY + 12;\n    }\n\n    // 构造一条曲线\n    const fakeNode: MindmapNode = { ...targetComponent.node, x: fakeX, y: fakeY, width, height: 12 };\n    const linkSVGG = isIndentedLayout(layout)\n        ? drawIndentedLink(roughSVG, parentComponent.node, fakeNode, PRIMARY_COLOR, false)\n        : drawLink(roughSVG, parentComponent.node, fakeNode, PRIMARY_COLOR, isHorizontalLayout(layout), false);\n    // 构造一个矩形框坐标\n    const fakeRectangleG = drawRoundRectangle(roughSVG, fakeRectangleStartX, fakeRectangleStartY, fakeRectangleEndX, fakeRectangleEndY, {\n        stroke: PRIMARY_COLOR,\n        strokeWidth: 2,\n        fill: PRIMARY_COLOR,\n        fillStyle: 'solid'\n    });\n    fakeDropNodeG?.appendChild(linkSVGG);\n    fakeDropNodeG?.appendChild(fakeRectangleG);\n};\nexport const drawStraightDropNodeG = (\n    targetRect: {\n        x: number;\n        y: number;\n        width: number;\n        height: number;\n    },\n    detectResult: DetectResult,\n    targetComponent: MindNodeComponent,\n    roughSVG: RoughSVG,\n    fakeDropNodeG: SVGGElement | undefined\n) => {\n    const { x, y, width, height } = targetRect;\n    const lineLength = 40;\n    let startLinePoint = x + width;\n    let endLinePoint = x + width + lineLength;\n    let startRectanglePointX = x + width + lineLength;\n    let endRectanglePointX = x + lineLength + width + 30;\n    let startRectanglePointY = y + height / 2 - 6;\n    let endRectanglePointY = y + height / 2 - 6 + 12;\n\n    if (detectResult === 'left') {\n        startLinePoint = x - lineLength;\n        endLinePoint = x;\n        startRectanglePointX = x - lineLength - 30;\n        endRectanglePointX = x - lineLength;\n    }\n    let fakeY = targetComponent.node.y;\n    let fakeX = targetRect.x;\n    const strokeWidth = targetComponent.node.origin.linkLineWidth ? targetComponent.node.origin.linkLineWidth : STROKE_WIDTH;\n    const pointOptions = {\n        fakeX,\n        fakeY,\n        x,\n        y,\n        width,\n        height,\n        strokeWidth\n    };\n    const parentLayout = MindmapQueries.getCorrectLayoutByElement(\n        targetComponent.node.origin.isRoot ? targetComponent.node.origin : targetComponent.node.parent.origin\n    );\n    const layout = MindmapQueries.getCorrectLayoutByElement(targetComponent.node.origin);\n    if (!isMixedLayout(parentLayout, layout)) {\n        // 构造一条直线\n        let linePoints = [\n            [startLinePoint, y + height / 2],\n            [endLinePoint, y + height / 2]\n        ] as Point[];\n        if (isIndentedLayout(parentLayout)) {\n            const fakePoint = getIndentedFakePoint(parentLayout, pointOptions);\n            drawIndentNodeG(fakeDropNodeG as SVGGElement, roughSVG, fakePoint, targetComponent.node);\n            return;\n        } else if (isVerticalLogicLayout(parentLayout)) {\n            if (!targetComponent.node.origin.isRoot) {\n                /**\n                 * 计算逻辑：\n                 *  1. 移动到左侧：当前节点 startX - 偏移值，偏移值计算如下：\n                 *      a. 第一个节点： 固定值（来源于 getMainAxle，第二级节点：BASE * 8，其他 BASE * 3 + strokeWidth / 2）；\n                 *      b. 第二个节点到最后一个节点之间：上一个节点到当前节点间距的一半（(当前节点 startX - 上一个节点的 endX) / 2)，endX = 当前节点的 startX + width;\n                 *  2. 移动到右侧：当前节点 x + width + 偏移值，偏移值计算如下：\n                 *      a. 第二个节点到最后一个节点之间的右侧：当前节点到下一个节点间距的一半（(下一个节点 startX - 当前节点的 endX) / 2)，endX = 当前节点的 startX + width;\n                 *      b. 最后一个节点的右侧：固定值（来源于 getMainAxle，第二级节点：BASE * 8，其他 BASE * 3 + strokeWidth / 2）；\n                 */\n                fakeY = targetComponent.node.y;\n                const parentComponent = MINDMAP_ELEMENT_TO_COMPONENT.get(targetComponent.parent.origin) as MindNodeComponent;\n                const targetIndex = parentComponent.node.origin.children.indexOf(targetComponent.node.origin);\n\n                if (detectResult === 'left') {\n                    let offsetX = 0;\n                    const isFirstNode = targetIndex === 0;\n                    if (isFirstNode) {\n                        offsetX = parentComponent.node.origin.isRoot ? BASE * 8 : BASE * 3 + strokeWidth / 2;\n                    } else {\n                        const previousComponent = MINDMAP_ELEMENT_TO_COMPONENT.get(\n                            parentComponent.node.origin.children[targetIndex - 1]\n                        ) as MindNodeComponent;\n                        const previousRect = getRectangleByNode(previousComponent.node);\n                        const space = targetRect.x - (previousRect.x + previousRect.width);\n                        offsetX = space / 2;\n                    }\n                    fakeX = targetRect.x - offsetX - width / 2 - Math.ceil(strokeWidth / 2);\n                }\n                if (detectResult === 'right') {\n                    let offsetX = 0;\n                    const isLastNode = targetIndex === parentComponent.node.origin.children.length - 1;\n                    if (isLastNode) {\n                        offsetX = parentComponent.node.origin.isRoot ? BASE * 8 : BASE * 3 + strokeWidth / 2;\n                    } else {\n                        const nextComponent = MINDMAP_ELEMENT_TO_COMPONENT.get(\n                            parentComponent.node.origin.children[targetIndex + 1]\n                        ) as MindNodeComponent;\n                        const nextRect = getRectangleByNode(nextComponent.node);\n                        const space = nextRect.x - (targetRect.x + targetRect.width);\n                        offsetX = space / 2;\n                    }\n                    fakeX = targetRect.x + width + offsetX - width / 2 - Math.ceil(strokeWidth / 2);\n                }\n                startRectanglePointX = fakeX;\n                if (isTopLayout(parentLayout)) {\n                    // 因为矩形是从左上角为起点向下画的，所以需要向上偏移一个矩形的高度（-12）\n                    startRectanglePointY = fakeY + height + targetComponent.node.vGap - 12;\n                }\n                if (isBottomLayout(parentLayout)) {\n                    startRectanglePointY = fakeY + targetComponent.node.vGap;\n                }\n                endRectanglePointX = startRectanglePointX + 30;\n                endRectanglePointY = startRectanglePointY + 12;\n                const fakeNode: MindmapNode = { ...targetComponent.node, x: fakeX, y: fakeY, width: 30 };\n                const linkSVGG = drawLink(roughSVG, parentComponent.node, fakeNode, PRIMARY_COLOR, false, false);\n                fakeDropNodeG?.appendChild(linkSVGG);\n            }\n        } else {\n            let linkSVGG = roughSVG.linearPath(linePoints, { stroke: PRIMARY_COLOR, strokeWidth });\n            fakeDropNodeG?.appendChild(linkSVGG);\n        }\n        // 构造一个矩形框坐标\n        let fakeRectangleG = drawRoundRectangle(\n            roughSVG,\n            startRectanglePointX,\n            startRectanglePointY,\n            endRectanglePointX,\n            endRectanglePointY,\n            {\n                stroke: PRIMARY_COLOR,\n                strokeWidth: 2,\n                fill: PRIMARY_COLOR,\n                fillStyle: 'solid'\n            }\n        );\n\n        fakeDropNodeG?.appendChild(fakeRectangleG);\n    } else {\n        // 混合布局画线逻辑\n        if (isHorizontalLogicLayout(parentLayout)) {\n            if (isIndentedLayout(layout)) {\n                const fakePoint = getIndentedFakePoint(layout, pointOptions);\n                drawIndentNodeG(fakeDropNodeG as SVGGElement, roughSVG, fakePoint, targetComponent.node);\n                return;\n            }\n        }\n    }\n};\n\nexport const getHorizontalFakeY = (\n    detectResult: 'top' | 'bottom',\n    targetIndex: number,\n    parentNode: MindmapNode,\n    targetRect: {\n        x: number;\n        y: number;\n        width: number;\n        height: number;\n    },\n    layout: MindmapLayoutType,\n    fakeY: number\n) => {\n    if (detectResult === 'top') {\n        if (targetIndex === 0 && isTopLayout(layout)) {\n            fakeY = targetRect.y + targetRect.height;\n        }\n        if (targetIndex > 0) {\n            const previousComponent = MINDMAP_ELEMENT_TO_COMPONENT.get(parentNode.origin.children[targetIndex - 1]) as MindNodeComponent;\n            const previousRect = getRectangleByNode(previousComponent.node);\n            const topY = previousRect.y + previousRect.height;\n            fakeY = topY + (targetRect.y - topY) / 5;\n        }\n    }\n    if (detectResult === 'bottom') {\n        fakeY = targetRect.y + targetRect.height + 30;\n        if (targetIndex < parentNode.origin.children.length - 1) {\n            const nextComponent = MINDMAP_ELEMENT_TO_COMPONENT.get(parentNode.origin.children[targetIndex + 1]) as MindNodeComponent;\n            const nextRect = getRectangleByNode(nextComponent.node);\n            const topY = targetRect.y + targetRect.height;\n            fakeY = topY + (nextRect.y - topY) / 5;\n        }\n        if (targetIndex === parentNode.origin.children.length - 1) {\n            fakeY = targetRect.y + targetRect.height + 30;\n        }\n    }\n    return fakeY;\n};\n\nexport const getIndentedFakePoint = (\n    layout: MindmapLayoutType,\n    pointOptions: {\n        fakeX: number;\n        fakeY: number;\n        x: number;\n        y: number;\n        width: number;\n        height: number;\n        strokeWidth: number;\n    }\n) => {\n    let { fakeX, fakeY, x, y, width, height, strokeWidth } = pointOptions;\n    const hGap = BASE * 4;\n    const vGap = BASE * 6;\n    const offsetX = hGap + width / 2 + strokeWidth;\n    const offsetY = vGap + height / 2 + strokeWidth;\n    if (isLeftLayout(layout)) {\n        fakeX = x - offsetX;\n    }\n    if (isRightLayout(layout)) {\n        fakeX = x + offsetX;\n    }\n    if (isTopLayout(layout)) {\n        fakeY = y - offsetY;\n    }\n    if (isBottomLayout(layout)) {\n        fakeY = y + height + offsetY;\n    }\n    return { fakeX, fakeY };\n};\n\nexport const drawIndentNodeG = (\n    fakeDropNodeG: SVGGElement,\n    roughSVG: RoughSVG,\n    fakePoint: { fakeX: number; fakeY: number },\n    node: MindmapNode\n) => {\n    const { fakeX, fakeY } = fakePoint;\n    const fakeNode: MindmapNode = { ...node, x: fakeX, y: fakeY, width: 30, height: 12 };\n    const linkSVGG = drawIndentedLink(roughSVG, node, fakeNode, PRIMARY_COLOR, false);\n\n    const startRectanglePointX = fakeX,\n        startRectanglePointY = fakeY,\n        endRectanglePointX = fakeX + 30,\n        endRectanglePointY = fakeY + 12;\n    const fakeRectangleG = drawRoundRectangle(\n        roughSVG,\n        startRectanglePointX,\n        startRectanglePointY,\n        endRectanglePointX,\n        endRectanglePointY,\n        {\n            stroke: PRIMARY_COLOR,\n            strokeWidth: 2,\n            fill: PRIMARY_COLOR,\n            fillStyle: 'solid'\n        }\n    );\n    fakeDropNodeG?.appendChild(linkSVGG);\n    fakeDropNodeG?.appendChild(fakeRectangleG);\n};\n"]}
@@ -0,0 +1,86 @@
1
+ import { isStandardLayout, isIndentedLayout, isVerticalLogicLayout, isTopLayout, MindmapLayoutType } from '@plait/layouts';
2
+ import { MINDMAP_ELEMENT_TO_COMPONENT } from './weak-maps';
3
+ import { MindmapQueries } from '../queries';
4
+ import { isMixedLayout } from './layout';
5
+ /* 根据布局调整 target 以及 direction */
6
+ export const readjustmentDropTarget = (dropTarget) => {
7
+ const { target, detectResult } = dropTarget;
8
+ const newDropTarget = { target, detectResult };
9
+ const targetComponent = MINDMAP_ELEMENT_TO_COMPONENT.get(target);
10
+ if (targetComponent.node.children.length > 0 && dropTarget.detectResult) {
11
+ const layout = MindmapQueries.getCorrectLayoutByElement(targetComponent.node.origin);
12
+ const parentLayout = MindmapQueries.getCorrectLayoutByElement(targetComponent.node.origin.isRoot ? targetComponent.node.origin : targetComponent.node.parent.origin);
13
+ if (['right', 'left'].includes(dropTarget.detectResult)) {
14
+ if (!isMixedLayout(parentLayout, layout)) {
15
+ if (targetComponent.node.origin.isRoot) {
16
+ const layout = MindmapQueries.getCorrectLayoutByElement(targetComponent.node.origin);
17
+ // 标准布局,根节点
18
+ if (isStandardLayout(layout)) {
19
+ const rightNodeCount = targetComponent.node.origin.rightNodeCount;
20
+ if (detectResult === 'left') {
21
+ // 作为左的第一个节点
22
+ if (targetComponent.node.children.length === rightNodeCount) {
23
+ return newDropTarget;
24
+ }
25
+ }
26
+ else {
27
+ // 作为右的第一个节点或最后一个节点
28
+ if (rightNodeCount === 0) {
29
+ newDropTarget.target = target;
30
+ }
31
+ else {
32
+ newDropTarget.target = targetComponent.node.children[rightNodeCount - 1].origin;
33
+ newDropTarget.detectResult = 'bottom';
34
+ }
35
+ return newDropTarget;
36
+ }
37
+ }
38
+ }
39
+ // 缩进布局探测到第一个子节点
40
+ if (isIndentedLayout(parentLayout)) {
41
+ newDropTarget.target = targetComponent.node.children[0].origin;
42
+ newDropTarget.detectResult = isTopLayout(parentLayout) ? 'bottom' : 'top';
43
+ return newDropTarget;
44
+ }
45
+ // 上下布局的根节点只可以探测到上或者下,子节点的左右探测不处理,跳过。
46
+ if (isVerticalLogicLayout(parentLayout)) {
47
+ return newDropTarget;
48
+ }
49
+ // 剩下是水平布局的默认情况:插入最后一个子节点的下方
50
+ const lastChildNodeIndex = targetComponent.node.children.length - 1;
51
+ newDropTarget.target = targetComponent.node.children[lastChildNodeIndex].origin;
52
+ newDropTarget.detectResult = 'bottom';
53
+ }
54
+ else {
55
+ // 处理左右布局下的混合布局
56
+ if ([MindmapLayoutType.left, MindmapLayoutType.right].includes(parentLayout)) {
57
+ const layout = MindmapQueries.getCorrectLayoutByElement(targetComponent.node.origin);
58
+ if (isIndentedLayout(layout)) {
59
+ newDropTarget.target = targetComponent.node.children[0].origin;
60
+ newDropTarget.detectResult = isTopLayout(layout) ? 'bottom' : 'top';
61
+ return newDropTarget;
62
+ }
63
+ }
64
+ }
65
+ }
66
+ if (['top', 'bottom'].includes(dropTarget.detectResult)) {
67
+ // 缩进布局移动至第一个节点
68
+ if (targetComponent.node.origin.isRoot && isIndentedLayout(layout)) {
69
+ newDropTarget.target = targetComponent.node.children[0].origin;
70
+ newDropTarget.detectResult = isTopLayout(layout) ? 'bottom' : 'top';
71
+ return newDropTarget;
72
+ }
73
+ // 上下布局,插到右边
74
+ const parentLayout = MindmapQueries.getCorrectLayoutByElement(targetComponent.node.origin.isRoot ? targetComponent.node.origin : targetComponent.node.parent.origin);
75
+ if (isVerticalLogicLayout(parentLayout)) {
76
+ const lastChildNodeIndex = targetComponent.node.children.length - 1;
77
+ newDropTarget.target = targetComponent.node.children[lastChildNodeIndex].origin;
78
+ newDropTarget.detectResult = 'right';
79
+ return newDropTarget;
80
+ }
81
+ }
82
+ return newDropTarget;
83
+ }
84
+ return dropTarget;
85
+ };
86
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"drop-target-corrector.js","sourceRoot":"","sources":["../../../../packages/mind/src/utils/drop-target-corrector.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,gBAAgB,EAAE,qBAAqB,EAAE,WAAW,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AAG3H,OAAO,EAAE,4BAA4B,EAAE,MAAM,aAAa,CAAC;AAC3D,OAAO,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;AAC5C,OAAO,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AAEzC,gCAAgC;AAChC,MAAM,CAAC,MAAM,sBAAsB,GAAG,CAAC,UAGtC,EAAuD,EAAE;IACtD,MAAM,EAAE,MAAM,EAAE,YAAY,EAAE,GAAG,UAAU,CAAC;IAC5C,MAAM,aAAa,GAAG,EAAE,MAAM,EAAE,YAAY,EAAE,CAAC;IAC/C,MAAM,eAAe,GAAG,4BAA4B,CAAC,GAAG,CAAC,MAAM,CAAsB,CAAC;IACtF,IAAI,eAAe,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,IAAI,UAAU,CAAC,YAAY,EAAE;QACrE,MAAM,MAAM,GAAG,cAAc,CAAC,yBAAyB,CAAC,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACrF,MAAM,YAAY,GAAG,cAAc,CAAC,yBAAyB,CACzD,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CACxG,CAAC;QACF,IAAI,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC,QAAQ,CAAC,UAAU,CAAC,YAAY,CAAC,EAAE;YACrD,IAAI,CAAC,aAAa,CAAC,YAAY,EAAE,MAAM,CAAC,EAAE;gBACtC,IAAI,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE;oBACpC,MAAM,MAAM,GAAG,cAAc,CAAC,yBAAyB,CAAC,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;oBACrF,WAAW;oBACX,IAAI,gBAAgB,CAAC,MAAM,CAAC,EAAE;wBAC1B,MAAM,cAAc,GAAG,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,cAAwB,CAAC;wBAC5E,IAAI,YAAY,KAAK,MAAM,EAAE;4BACzB,YAAY;4BACZ,IAAI,eAAe,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,KAAK,cAAc,EAAE;gCACzD,OAAO,aAAa,CAAC;6BACxB;yBACJ;6BAAM;4BACH,mBAAmB;4BACnB,IAAI,cAAc,KAAK,CAAC,EAAE;gCACtB,aAAa,CAAC,MAAM,GAAG,MAAM,CAAC;6BACjC;iCAAM;gCACH,aAAa,CAAC,MAAM,GAAG,eAAe,CAAC,IAAI,CAAC,QAAQ,CAAC,cAAc,GAAG,CAAC,CAAC,CAAC,MAAM,CAAC;gCAChF,aAAa,CAAC,YAAY,GAAG,QAAQ,CAAC;6BACzC;4BACD,OAAO,aAAa,CAAC;yBACxB;qBACJ;iBACJ;gBAED,gBAAgB;gBAChB,IAAI,gBAAgB,CAAC,YAAY,CAAC,EAAE;oBAChC,aAAa,CAAC,MAAM,GAAG,eAAe,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC;oBAC/D,aAAa,CAAC,YAAY,GAAG,WAAW,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC;oBAC1E,OAAO,aAAa,CAAC;iBACxB;gBACD,qCAAqC;gBACrC,IAAI,qBAAqB,CAAC,YAAY,CAAC,EAAE;oBACrC,OAAO,aAAa,CAAC;iBACxB;gBACD,4BAA4B;gBAC5B,MAAM,kBAAkB,GAAG,eAAe,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,CAAC;gBACpE,aAAa,CAAC,MAAM,GAAG,eAAe,CAAC,IAAI,CAAC,QAAQ,CAAC,kBAAkB,CAAC,CAAC,MAAM,CAAC;gBAChF,aAAa,CAAC,YAAY,GAAG,QAAQ,CAAC;aACzC;iBAAM;gBACH,eAAe;gBACf,IAAI,CAAC,iBAAiB,CAAC,IAAI,EAAE,iBAAiB,CAAC,KAAK,CAAC,CAAC,QAAQ,CAAC,YAAY,CAAC,EAAE;oBAC1E,MAAM,MAAM,GAAG,cAAc,CAAC,yBAAyB,CAAC,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;oBACrF,IAAI,gBAAgB,CAAC,MAAM,CAAC,EAAE;wBAC1B,aAAa,CAAC,MAAM,GAAG,eAAe,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC;wBAC/D,aAAa,CAAC,YAAY,GAAG,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC;wBACpE,OAAO,aAAa,CAAC;qBACxB;iBACJ;aACJ;SACJ;QACD,IAAI,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC,QAAQ,CAAC,UAAU,CAAC,YAAY,CAAC,EAAE;YACrD,eAAe;YACf,IAAI,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,IAAI,gBAAgB,CAAC,MAAM,CAAC,EAAE;gBAChE,aAAa,CAAC,MAAM,GAAG,eAAe,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC;gBAC/D,aAAa,CAAC,YAAY,GAAG,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC;gBACpE,OAAO,aAAa,CAAC;aACxB;YACD,YAAY;YACZ,MAAM,YAAY,GAAG,cAAc,CAAC,yBAAyB,CACzD,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CACxG,CAAC;YACF,IAAI,qBAAqB,CAAC,YAAY,CAAC,EAAE;gBACrC,MAAM,kBAAkB,GAAG,eAAe,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,CAAC;gBACpE,aAAa,CAAC,MAAM,GAAG,eAAe,CAAC,IAAI,CAAC,QAAQ,CAAC,kBAAkB,CAAC,CAAC,MAAM,CAAC;gBAChF,aAAa,CAAC,YAAY,GAAG,OAAO,CAAC;gBACrC,OAAO,aAAa,CAAC;aACxB;SACJ;QACD,OAAO,aAAa,CAAC;KACxB;IACD,OAAO,UAAU,CAAC;AACtB,CAAC,CAAC","sourcesContent":["import { isStandardLayout, isIndentedLayout, isVerticalLogicLayout, isTopLayout, MindmapLayoutType } from '@plait/layouts';\nimport { DetectResult, MindElement } from '../interfaces';\nimport { MindNodeComponent } from '../node.component';\nimport { MINDMAP_ELEMENT_TO_COMPONENT } from './weak-maps';\nimport { MindmapQueries } from '../queries';\nimport { isMixedLayout } from './layout';\n\n/* 根据布局调整 target 以及 direction */\nexport const readjustmentDropTarget = (dropTarget: {\n    target: MindElement;\n    detectResult: DetectResult;\n}): { target: MindElement; detectResult: DetectResult } => {\n    const { target, detectResult } = dropTarget;\n    const newDropTarget = { target, detectResult };\n    const targetComponent = MINDMAP_ELEMENT_TO_COMPONENT.get(target) as MindNodeComponent;\n    if (targetComponent.node.children.length > 0 && dropTarget.detectResult) {\n        const layout = MindmapQueries.getCorrectLayoutByElement(targetComponent.node.origin);\n        const parentLayout = MindmapQueries.getCorrectLayoutByElement(\n            targetComponent.node.origin.isRoot ? targetComponent.node.origin : targetComponent.node.parent.origin\n        );\n        if (['right', 'left'].includes(dropTarget.detectResult)) {\n            if (!isMixedLayout(parentLayout, layout)) {\n                if (targetComponent.node.origin.isRoot) {\n                    const layout = MindmapQueries.getCorrectLayoutByElement(targetComponent.node.origin);\n                    // 标准布局，根节点\n                    if (isStandardLayout(layout)) {\n                        const rightNodeCount = targetComponent.node.origin.rightNodeCount as number;\n                        if (detectResult === 'left') {\n                            // 作为左的第一个节点\n                            if (targetComponent.node.children.length === rightNodeCount) {\n                                return newDropTarget;\n                            }\n                        } else {\n                            // 作为右的第一个节点或最后一个节点\n                            if (rightNodeCount === 0) {\n                                newDropTarget.target = target;\n                            } else {\n                                newDropTarget.target = targetComponent.node.children[rightNodeCount - 1].origin;\n                                newDropTarget.detectResult = 'bottom';\n                            }\n                            return newDropTarget;\n                        }\n                    }\n                }\n\n                // 缩进布局探测到第一个子节点\n                if (isIndentedLayout(parentLayout)) {\n                    newDropTarget.target = targetComponent.node.children[0].origin;\n                    newDropTarget.detectResult = isTopLayout(parentLayout) ? 'bottom' : 'top';\n                    return newDropTarget;\n                }\n                // 上下布局的根节点只可以探测到上或者下，子节点的左右探测不处理，跳过。\n                if (isVerticalLogicLayout(parentLayout)) {\n                    return newDropTarget;\n                }\n                // 剩下是水平布局的默认情况：插入最后一个子节点的下方\n                const lastChildNodeIndex = targetComponent.node.children.length - 1;\n                newDropTarget.target = targetComponent.node.children[lastChildNodeIndex].origin;\n                newDropTarget.detectResult = 'bottom';\n            } else {\n                // 处理左右布局下的混合布局\n                if ([MindmapLayoutType.left, MindmapLayoutType.right].includes(parentLayout)) {\n                    const layout = MindmapQueries.getCorrectLayoutByElement(targetComponent.node.origin);\n                    if (isIndentedLayout(layout)) {\n                        newDropTarget.target = targetComponent.node.children[0].origin;\n                        newDropTarget.detectResult = isTopLayout(layout) ? 'bottom' : 'top';\n                        return newDropTarget;\n                    }\n                }\n            }\n        }\n        if (['top', 'bottom'].includes(dropTarget.detectResult)) {\n            // 缩进布局移动至第一个节点\n            if (targetComponent.node.origin.isRoot && isIndentedLayout(layout)) {\n                newDropTarget.target = targetComponent.node.children[0].origin;\n                newDropTarget.detectResult = isTopLayout(layout) ? 'bottom' : 'top';\n                return newDropTarget;\n            }\n            // 上下布局，插到右边\n            const parentLayout = MindmapQueries.getCorrectLayoutByElement(\n                targetComponent.node.origin.isRoot ? targetComponent.node.origin : targetComponent.node.parent.origin\n            );\n            if (isVerticalLogicLayout(parentLayout)) {\n                const lastChildNodeIndex = targetComponent.node.children.length - 1;\n                newDropTarget.target = targetComponent.node.children[lastChildNodeIndex].origin;\n                newDropTarget.detectResult = 'right';\n                return newDropTarget;\n            }\n        }\n        return newDropTarget;\n    }\n    return dropTarget;\n};\n"]}
@@ -0,0 +1,24 @@
1
+ import { distanceBetweenPointAndRectangle } from '@plait/core';
2
+ import { ELEMENT_TO_NODE } from './weak-maps';
3
+ export function getRectangleByNode(node) {
4
+ const x = node.x + node.hGap;
5
+ let y = node.y + node.vGap;
6
+ const width = node.width - node.hGap * 2;
7
+ const height = node.height - node.vGap * 2;
8
+ return {
9
+ x,
10
+ y,
11
+ width,
12
+ height
13
+ };
14
+ }
15
+ export function hitMindmapElement(board, point, element) {
16
+ const node = ELEMENT_TO_NODE.get(element);
17
+ if (node && distanceBetweenPointAndRectangle(point[0], point[1], getRectangleByNode(node)) === 0) {
18
+ return true;
19
+ }
20
+ else {
21
+ return false;
22
+ }
23
+ }
24
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3JhcGguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9taW5kL3NyYy91dGlscy9ncmFwaC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQXNDLGdDQUFnQyxFQUFFLE1BQU0sYUFBYSxDQUFDO0FBRW5HLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFFOUMsTUFBTSxVQUFVLGtCQUFrQixDQUFDLElBQWlCO0lBQ2hELE1BQU0sQ0FBQyxHQUFHLElBQUksQ0FBQyxDQUFDLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQztJQUM3QixJQUFJLENBQUMsR0FBRyxJQUFJLENBQUMsQ0FBQyxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUM7SUFDM0IsTUFBTSxLQUFLLEdBQUcsSUFBSSxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUMsSUFBSSxHQUFHLENBQUMsQ0FBQztJQUN6QyxNQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsTUFBTSxHQUFHLElBQUksQ0FBQyxJQUFJLEdBQUcsQ0FBQyxDQUFDO0lBQzNDLE9BQU87UUFDSCxDQUFDO1FBQ0QsQ0FBQztRQUNELEtBQUs7UUFDTCxNQUFNO0tBQ1QsQ0FBQztBQUNOLENBQUM7QUFFRCxNQUFNLFVBQVUsaUJBQWlCLENBQUMsS0FBaUIsRUFBRSxLQUFZLEVBQUUsT0FBb0I7SUFDbkYsTUFBTSxJQUFJLEdBQUcsZUFBZSxDQUFDLEdBQUcsQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUMxQyxJQUFJLElBQUksSUFBSSxnQ0FBZ0MsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLEVBQUUsS0FBSyxDQUFDLENBQUMsQ0FBQyxFQUFFLGtCQUFrQixDQUFDLElBQUksQ0FBQyxDQUFDLEtBQUssQ0FBQyxFQUFFO1FBQzlGLE9BQU8sSUFBSSxDQUFDO0tBQ2Y7U0FBTTtRQUNILE9BQU8sS0FBSyxDQUFDO0tBQ2hCO0FBQ0wsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE1pbmRtYXBOb2RlIH0gZnJvbSAnLi4vaW50ZXJmYWNlcy9ub2RlJztcbmltcG9ydCB7IFBsYWl0Qm9hcmQsIFBvaW50LCBSZWN0YW5nbGVDbGllbnQsIGRpc3RhbmNlQmV0d2VlblBvaW50QW5kUmVjdGFuZ2xlIH0gZnJvbSAnQHBsYWl0L2NvcmUnO1xuaW1wb3J0IHsgTWluZEVsZW1lbnQgfSBmcm9tICcuLi9pbnRlcmZhY2VzJztcbmltcG9ydCB7IEVMRU1FTlRfVE9fTk9ERSB9IGZyb20gJy4vd2Vhay1tYXBzJztcblxuZXhwb3J0IGZ1bmN0aW9uIGdldFJlY3RhbmdsZUJ5Tm9kZShub2RlOiBNaW5kbWFwTm9kZSk6IFJlY3RhbmdsZUNsaWVudCB7XG4gICAgY29uc3QgeCA9IG5vZGUueCArIG5vZGUuaEdhcDtcbiAgICBsZXQgeSA9IG5vZGUueSArIG5vZGUudkdhcDtcbiAgICBjb25zdCB3aWR0aCA9IG5vZGUud2lkdGggLSBub2RlLmhHYXAgKiAyO1xuICAgIGNvbnN0IGhlaWdodCA9IG5vZGUuaGVpZ2h0IC0gbm9kZS52R2FwICogMjtcbiAgICByZXR1cm4ge1xuICAgICAgICB4LFxuICAgICAgICB5LFxuICAgICAgICB3aWR0aCxcbiAgICAgICAgaGVpZ2h0XG4gICAgfTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGhpdE1pbmRtYXBFbGVtZW50KGJvYXJkOiBQbGFpdEJvYXJkLCBwb2ludDogUG9pbnQsIGVsZW1lbnQ6IE1pbmRFbGVtZW50KSB7XG4gICAgY29uc3Qgbm9kZSA9IEVMRU1FTlRfVE9fTk9ERS5nZXQoZWxlbWVudCk7XG4gICAgaWYgKG5vZGUgJiYgZGlzdGFuY2VCZXR3ZWVuUG9pbnRBbmRSZWN0YW5nbGUocG9pbnRbMF0sIHBvaW50WzFdLCBnZXRSZWN0YW5nbGVCeU5vZGUobm9kZSkpID09PSAwKSB7XG4gICAgICAgIHJldHVybiB0cnVlO1xuICAgIH0gZWxzZSB7XG4gICAgICAgIHJldHVybiBmYWxzZTtcbiAgICB9XG59XG4iXX0=
@@ -0,0 +1,14 @@
1
+ export * from './graph';
2
+ export * from './weak-maps';
3
+ export * from './mindmap';
4
+ export * from './layout';
5
+ export * from './shape';
6
+ export * from './colors';
7
+ export * from './is-virtual-key';
8
+ export * from './draw-placeholder';
9
+ export * from './direction-detector';
10
+ export * from './direction-corrector';
11
+ export * from './drop-target-corrector';
12
+ export * from './abstract/common';
13
+ export * from './abstract/resize';
14
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9taW5kL3NyYy91dGlscy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLFNBQVMsQ0FBQztBQUN4QixjQUFjLGFBQWEsQ0FBQztBQUM1QixjQUFjLFdBQVcsQ0FBQztBQUMxQixjQUFjLFVBQVUsQ0FBQztBQUN6QixjQUFjLFNBQVMsQ0FBQztBQUN4QixjQUFjLFVBQVUsQ0FBQztBQUN6QixjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsb0JBQW9CLENBQUM7QUFDbkMsY0FBYyxzQkFBc0IsQ0FBQztBQUNyQyxjQUFjLHVCQUF1QixDQUFDO0FBQ3RDLGNBQWMseUJBQXlCLENBQUM7QUFDeEMsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLG1CQUFtQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9ncmFwaCc7XG5leHBvcnQgKiBmcm9tICcuL3dlYWstbWFwcyc7XG5leHBvcnQgKiBmcm9tICcuL21pbmRtYXAnO1xuZXhwb3J0ICogZnJvbSAnLi9sYXlvdXQnO1xuZXhwb3J0ICogZnJvbSAnLi9zaGFwZSc7XG5leHBvcnQgKiBmcm9tICcuL2NvbG9ycyc7XG5leHBvcnQgKiBmcm9tICcuL2lzLXZpcnR1YWwta2V5JztcbmV4cG9ydCAqIGZyb20gJy4vZHJhdy1wbGFjZWhvbGRlcic7XG5leHBvcnQgKiBmcm9tICcuL2RpcmVjdGlvbi1kZXRlY3Rvcic7XG5leHBvcnQgKiBmcm9tICcuL2RpcmVjdGlvbi1jb3JyZWN0b3InO1xuZXhwb3J0ICogZnJvbSAnLi9kcm9wLXRhcmdldC1jb3JyZWN0b3InO1xuZXhwb3J0ICogZnJvbSAnLi9hYnN0cmFjdC9jb21tb24nO1xuZXhwb3J0ICogZnJvbSAnLi9hYnN0cmFjdC9yZXNpemUnO1xuIl19
@@ -0,0 +1,13 @@
1
+ import { isKeyHotkey } from 'is-hotkey';
2
+ export function isVirtualKey(e) {
3
+ const isMod = e.ctrlKey || e.metaKey;
4
+ const isAlt = isKeyHotkey('alt', e);
5
+ const isShift = isKeyHotkey('shift', e);
6
+ const isCapsLock = e.key.includes('CapsLock');
7
+ const isTab = e.key.includes('Tab');
8
+ const isEsc = e.key.includes('Escape');
9
+ const isF = e.key.startsWith('F');
10
+ const isArrow = e.key.includes('Arrow') ? true : false;
11
+ return isCapsLock || isMod || isAlt || isArrow || isShift || isTab || isEsc || isF;
12
+ }
13
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaXMtdmlydHVhbC1rZXkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9taW5kL3NyYy91dGlscy9pcy12aXJ0dWFsLWtleS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sV0FBVyxDQUFDO0FBRXhDLE1BQU0sVUFBVSxZQUFZLENBQUMsQ0FBZ0I7SUFDekMsTUFBTSxLQUFLLEdBQUcsQ0FBQyxDQUFDLE9BQU8sSUFBSSxDQUFDLENBQUMsT0FBTyxDQUFDO0lBQ3JDLE1BQU0sS0FBSyxHQUFHLFdBQVcsQ0FBQyxLQUFLLEVBQUUsQ0FBQyxDQUFDLENBQUM7SUFDcEMsTUFBTSxPQUFPLEdBQUcsV0FBVyxDQUFDLE9BQU8sRUFBRSxDQUFDLENBQUMsQ0FBQztJQUN4QyxNQUFNLFVBQVUsR0FBRyxDQUFDLENBQUMsR0FBRyxDQUFDLFFBQVEsQ0FBQyxVQUFVLENBQUMsQ0FBQztJQUM5QyxNQUFNLEtBQUssR0FBRyxDQUFDLENBQUMsR0FBRyxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUNwQyxNQUFNLEtBQUssR0FBRyxDQUFDLENBQUMsR0FBRyxDQUFDLFFBQVEsQ0FBQyxRQUFRLENBQUMsQ0FBQztJQUN2QyxNQUFNLEdBQUcsR0FBRyxDQUFDLENBQUMsR0FBRyxDQUFDLFVBQVUsQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUNsQyxNQUFNLE9BQU8sR0FBRyxDQUFDLENBQUMsR0FBRyxDQUFDLFFBQVEsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUM7SUFDdkQsT0FBTyxVQUFVLElBQUksS0FBSyxJQUFJLEtBQUssSUFBSSxPQUFPLElBQUksT0FBTyxJQUFJLEtBQUssSUFBSSxLQUFLLElBQUksR0FBRyxDQUFDO0FBQ3ZGLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBpc0tleUhvdGtleSB9IGZyb20gJ2lzLWhvdGtleSc7XG5cbmV4cG9ydCBmdW5jdGlvbiBpc1ZpcnR1YWxLZXkoZTogS2V5Ym9hcmRFdmVudCkge1xuICAgIGNvbnN0IGlzTW9kID0gZS5jdHJsS2V5IHx8IGUubWV0YUtleTtcbiAgICBjb25zdCBpc0FsdCA9IGlzS2V5SG90a2V5KCdhbHQnLCBlKTtcbiAgICBjb25zdCBpc1NoaWZ0ID0gaXNLZXlIb3RrZXkoJ3NoaWZ0JywgZSk7XG4gICAgY29uc3QgaXNDYXBzTG9jayA9IGUua2V5LmluY2x1ZGVzKCdDYXBzTG9jaycpO1xuICAgIGNvbnN0IGlzVGFiID0gZS5rZXkuaW5jbHVkZXMoJ1RhYicpO1xuICAgIGNvbnN0IGlzRXNjID0gZS5rZXkuaW5jbHVkZXMoJ0VzY2FwZScpO1xuICAgIGNvbnN0IGlzRiA9IGUua2V5LnN0YXJ0c1dpdGgoJ0YnKTtcbiAgICBjb25zdCBpc0Fycm93ID0gZS5rZXkuaW5jbHVkZXMoJ0Fycm93JykgPyB0cnVlIDogZmFsc2U7XG4gICAgcmV0dXJuIGlzQ2Fwc0xvY2sgfHwgaXNNb2QgfHwgaXNBbHQgfHwgaXNBcnJvdyB8fCBpc1NoaWZ0IHx8IGlzVGFiIHx8IGlzRXNjIHx8IGlzRjtcbn1cbiJdfQ==