@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,742 @@
1
+ import { ChangeDetectionStrategy, Component } from '@angular/core';
2
+ import { PlaitPointerType, createG, createText, IS_TEXT_EDITABLE, MERGING, PlaitBoard, toPoint, transformPoint, Transforms, drawRoundRectangle, PlaitPluginElementComponent, PlaitElement, NODE_TO_INDEX } from '@plait/core';
3
+ import { isBottomLayout, isHorizontalLayout, isIndentedLayout, isLeftLayout, AbstractNode, isRightLayout, isStandardLayout, isTopLayout, MindmapLayoutType } from '@plait/layouts';
4
+ import { hasEditableTarget, setFullSelectionAndFocus, updateRichText } from '@plait/richtext';
5
+ import { fromEvent, Subject, timer } from 'rxjs';
6
+ import { debounceTime, filter, take, takeUntil } from 'rxjs/operators';
7
+ import { Editor, Operation } from 'slate';
8
+ import { EXTEND_OFFSET, EXTEND_RADIUS, MindmapNodeShape, NODE_MIN_WIDTH, PRIMARY_COLOR, QUICK_INSERT_CIRCLE_COLOR, QUICK_INSERT_CIRCLE_OFFSET, QUICK_INSERT_INNER_CROSS_COLOR, STROKE_WIDTH } from './constants';
9
+ import { drawIndentedLink } from './draw/indented-link';
10
+ import { drawLogicLink } from './draw/link/logic-link';
11
+ import { drawMindmapNodeRichtext, updateMindNodeTopicSize } from './draw/richtext';
12
+ import { drawRectangleNode } from './draw/shape';
13
+ import { MindElement, PlaitMind } from './interfaces/element';
14
+ import { MindmapNode } from './interfaces/node';
15
+ import { MindmapQueries } from './queries';
16
+ import { getLinkLineColorByMindmapElement, getRootLinkLineColorByMindmapElement } from './utils/colors';
17
+ import { getRectangleByNode, hitMindmapElement } from './utils/graph';
18
+ import { insertMindElement, getChildrenCount } from './utils/mindmap';
19
+ import { getNodeShapeByElement } from './utils/shape';
20
+ import { ELEMENT_TO_NODE, MINDMAP_ELEMENT_TO_COMPONENT } from './utils/weak-maps';
21
+ import { getRichtextContentSize } from '@plait/richtext';
22
+ import { drawAbstractLink } from './draw/link/abstract-link';
23
+ import { EmojisDrawer } from './plugins/emoji/emoji.drawer';
24
+ import { MindTransforms } from './transforms';
25
+ import { drawAbstractIncludedOutline } from './draw/abstract';
26
+ import * as i0 from "@angular/core";
27
+ import * as i1 from "@angular/common";
28
+ import * as i2 from "@plait/core";
29
+ export class MindNodeComponent extends PlaitPluginElementComponent {
30
+ get handActive() {
31
+ return this.board.pointer === PlaitPointerType.hand;
32
+ }
33
+ constructor(viewContainerRef, cdr, render2) {
34
+ super(cdr);
35
+ this.viewContainerRef = viewContainerRef;
36
+ this.cdr = cdr;
37
+ this.render2 = render2;
38
+ this.isEditable = false;
39
+ this.activeG = [];
40
+ this.shapeG = null;
41
+ this.destroy$ = new Subject();
42
+ this.trackBy = (index, node) => {
43
+ return node.origin.id;
44
+ };
45
+ }
46
+ ngOnInit() {
47
+ this.emojisDrawer = new EmojisDrawer(this.board, this.viewContainerRef);
48
+ MINDMAP_ELEMENT_TO_COMPONENT.set(this.element, this);
49
+ super.ngOnInit();
50
+ this.node = ELEMENT_TO_NODE.get(this.element);
51
+ if (!PlaitMind.isMind(this.element)) {
52
+ this.parent = MindElement.getNode(MindElement.getParent(this.element));
53
+ }
54
+ this.index = NODE_TO_INDEX.get(this.element) || 0;
55
+ this.roughSVG = PlaitBoard.getRoughSVG(this.board);
56
+ this.parentG = PlaitElement.getComponent(MindElement.getRoot(this.board, this.element)).rootG;
57
+ this.drawShape();
58
+ this.drawLink();
59
+ this.drawRichtext();
60
+ this.drawEmojis();
61
+ this.drawActiveG();
62
+ this.updateActiveClass();
63
+ this.drawMaskG();
64
+ this.drawExtend();
65
+ }
66
+ onContextChanged(value, previous) {
67
+ const newNode = ELEMENT_TO_NODE.get(this.element);
68
+ if (!PlaitMind.isMind(this.element)) {
69
+ this.parent = MindElement.getNode(MindElement.getParent(this.element));
70
+ }
71
+ MINDMAP_ELEMENT_TO_COMPONENT.set(this.element, this);
72
+ // resolve move node richtext lose issue
73
+ if (this.node !== newNode) {
74
+ if (this.foreignObject && this.foreignObject.children.length <= 0) {
75
+ this.foreignObject?.appendChild(this.richtextComponentRef?.instance.editable);
76
+ }
77
+ }
78
+ const isEquals = MindmapNode.isEquals(this.node, newNode);
79
+ this.node = newNode;
80
+ this.drawActiveG();
81
+ this.updateActiveClass();
82
+ if (!isEquals) {
83
+ this.drawShape();
84
+ this.drawLink();
85
+ this.updateRichtext();
86
+ this.drawMaskG();
87
+ this.drawExtend();
88
+ this.drawEmojis();
89
+ }
90
+ }
91
+ drawShape() {
92
+ this.destroyShape();
93
+ const shape = getNodeShapeByElement(this.node.origin);
94
+ switch (shape) {
95
+ case MindmapNodeShape.roundRectangle:
96
+ this.shapeG = drawRectangleNode(this.board, this.node);
97
+ this.g.prepend(this.shapeG);
98
+ break;
99
+ default:
100
+ break;
101
+ }
102
+ }
103
+ drawEmojis() {
104
+ const g = this.emojisDrawer.drawEmojis(this.element);
105
+ if (g) {
106
+ this.g.append(g);
107
+ }
108
+ }
109
+ destroyShape() {
110
+ if (this.shapeG) {
111
+ this.shapeG.remove();
112
+ this.shapeG = null;
113
+ }
114
+ }
115
+ drawLink() {
116
+ if (!this.parent) {
117
+ return;
118
+ }
119
+ if (this.linkG) {
120
+ this.linkG.remove();
121
+ }
122
+ const layout = MindmapQueries.getLayoutByElement(this.parent.origin);
123
+ if (AbstractNode.isAbstract(this.node.origin)) {
124
+ this.linkG = drawAbstractLink(this.board, this.node, isHorizontalLayout(layout));
125
+ }
126
+ else if (MindElement.isIndentedLayout(this.parent.origin)) {
127
+ this.linkG = drawIndentedLink(this.roughSVG, this.parent, this.node);
128
+ }
129
+ else {
130
+ this.linkG = drawLogicLink(this.roughSVG, this.node, this.parent, isHorizontalLayout(layout));
131
+ }
132
+ this.g.append(this.linkG);
133
+ }
134
+ destroyLine() {
135
+ if (this.parent) {
136
+ if (this.linkG) {
137
+ this.linkG.remove();
138
+ }
139
+ }
140
+ }
141
+ drawMaskG() {
142
+ this.destroyMaskG();
143
+ const lineWidthOffset = 2;
144
+ const extendOffset = 15;
145
+ const nodeLayout = MindmapQueries.getLayoutByElement(this.node.origin);
146
+ const isTop = isTopLayout(nodeLayout);
147
+ const isRight = isRightLayout(nodeLayout);
148
+ const isBottom = isBottomLayout(nodeLayout);
149
+ const isLeft = isLeftLayout(nodeLayout);
150
+ const { x, y, width, height } = getRectangleByNode(this.node);
151
+ let drawX = x;
152
+ let drawY = y;
153
+ let drawWidth = x + width;
154
+ let drawHeight = y + height;
155
+ switch (true) {
156
+ case isTop:
157
+ drawX = x - lineWidthOffset;
158
+ drawY = y - extendOffset;
159
+ drawWidth = x + width + lineWidthOffset;
160
+ drawHeight = y + height + lineWidthOffset;
161
+ break;
162
+ case isBottom:
163
+ drawX = x - lineWidthOffset;
164
+ drawY = y - lineWidthOffset;
165
+ drawWidth = x + width + lineWidthOffset;
166
+ drawHeight = y + height + extendOffset;
167
+ break;
168
+ case isLeft:
169
+ drawX = x - extendOffset;
170
+ drawY = y - lineWidthOffset;
171
+ drawWidth = x + width + lineWidthOffset;
172
+ drawHeight = y + height + lineWidthOffset;
173
+ break;
174
+ case isRight:
175
+ drawX = x - lineWidthOffset;
176
+ drawY = y - lineWidthOffset;
177
+ drawWidth = x + width + extendOffset;
178
+ drawHeight = y + height + lineWidthOffset;
179
+ break;
180
+ }
181
+ this.maskG = drawRoundRectangle(this.roughSVG, drawX, drawY, drawWidth, drawHeight, { stroke: 'none', fill: 'rgba(255,255,255,0)', fillStyle: 'solid' }, true);
182
+ this.maskG.classList.add('mask');
183
+ this.maskG.setAttribute('visibility', 'visible');
184
+ this.g.append(this.maskG);
185
+ if (this.isEditable) {
186
+ this.disabledMaskG();
187
+ }
188
+ fromEvent(this.maskG, 'mouseenter')
189
+ .pipe(takeUntil(this.destroy$), filter(() => {
190
+ return PlaitBoard.isFocus(this.board) && !this.element.isCollapsed && !this.handActive;
191
+ }))
192
+ .subscribe(() => {
193
+ this.g.classList.add('hovered');
194
+ });
195
+ fromEvent(this.maskG, 'mouseleave')
196
+ .pipe(takeUntil(this.destroy$), filter(() => {
197
+ return PlaitBoard.isFocus(this.board) && !this.element.isCollapsed;
198
+ }))
199
+ .subscribe(() => {
200
+ this.g.classList.remove('hovered');
201
+ });
202
+ }
203
+ destroyMaskG() {
204
+ if (this.maskG) {
205
+ this.maskG.remove();
206
+ this.g.classList.remove('hovered');
207
+ }
208
+ }
209
+ enableMaskG() {
210
+ if (this.maskG) {
211
+ this.maskG.setAttribute('visibility', 'visible');
212
+ }
213
+ }
214
+ disabledMaskG() {
215
+ if (this.maskG) {
216
+ this.maskG.setAttribute('visibility', 'hidden');
217
+ }
218
+ }
219
+ drawActiveG() {
220
+ this.destroyActiveG();
221
+ this.abstractIncludedOutlineG?.remove();
222
+ if (this.selected) {
223
+ if (AbstractNode.isAbstract(this.element)) {
224
+ this.updateAbstractIncludedOutline();
225
+ }
226
+ let { x, y, width, height } = getRectangleByNode(this.node);
227
+ const selectedStrokeG = drawRoundRectangle(this.roughSVG, x - 2, y - 2, x + width + 2, y + height + 2, { stroke: PRIMARY_COLOR, strokeWidth: 2, fill: '' }, true);
228
+ // 影响 mask 移入移出事件
229
+ selectedStrokeG.style.pointerEvents = 'none';
230
+ this.g.appendChild(selectedStrokeG);
231
+ this.activeG.push(selectedStrokeG);
232
+ if (this.richtextComponentRef?.instance.plaitReadonly === true) {
233
+ const selectedBackgroundG = drawRoundRectangle(this.roughSVG, x - 2, y - 2, x + width + 2, y + height + 2, { stroke: PRIMARY_COLOR, fill: PRIMARY_COLOR, fillStyle: 'solid' }, true);
234
+ selectedBackgroundG.style.opacity = '0.15';
235
+ // 影响双击事件
236
+ selectedBackgroundG.style.pointerEvents = 'none';
237
+ this.g.appendChild(selectedBackgroundG);
238
+ this.activeG.push(selectedBackgroundG, selectedStrokeG);
239
+ }
240
+ }
241
+ }
242
+ destroyActiveG() {
243
+ this.activeG.forEach(g => g.remove());
244
+ this.activeG = [];
245
+ }
246
+ updateActiveClass() {
247
+ if (!this.g) {
248
+ return;
249
+ }
250
+ if (this.selected) {
251
+ this.render2.addClass(this.g, 'active');
252
+ }
253
+ else {
254
+ this.render2.removeClass(this.g, 'active');
255
+ }
256
+ }
257
+ drawRichtext() {
258
+ const { richtextG, richtextComponentRef, foreignObject } = drawMindmapNodeRichtext(this.node, this.viewContainerRef);
259
+ this.richtextComponentRef = richtextComponentRef;
260
+ this.richtextG = richtextG;
261
+ this.foreignObject = foreignObject;
262
+ this.render2.addClass(richtextG, 'richtext');
263
+ this.g.append(richtextG);
264
+ }
265
+ drawQuickInsert(offset = 0) {
266
+ if (this.board.options.readonly) {
267
+ return;
268
+ }
269
+ const quickInsertG = createG();
270
+ quickInsertG.classList.add('quick-insert');
271
+ this.extendG?.append(quickInsertG);
272
+ const { x, y, width, height } = getRectangleByNode(this.node);
273
+ /**
274
+ * 方位:
275
+ * 1. 左、左上、左下
276
+ * 2. 右、右上、右下
277
+ * 3. 上、上左、上右
278
+ * 4. 下、下左、下右
279
+ */
280
+ const shape = getNodeShapeByElement(this.node.origin);
281
+ // 形状是矩形要偏移边框的线宽
282
+ const strokeWidth = this.node.origin.linkLineWidth ? this.node.origin.linkLineWidth : STROKE_WIDTH;
283
+ let offsetBorderLineWidth = 0;
284
+ if (shape === MindmapNodeShape.roundRectangle && offset === 0) {
285
+ offsetBorderLineWidth = strokeWidth;
286
+ }
287
+ let offsetRootBorderLineWidth = 0;
288
+ if (this.node.origin.isRoot) {
289
+ offsetRootBorderLineWidth = strokeWidth;
290
+ }
291
+ // 当没有子节点时,需要缩小的偏移量
292
+ const extraOffset = 3;
293
+ const underlineCoordinates = {
294
+ // 画线方向:右向左 <--
295
+ [MindmapLayoutType.left]: {
296
+ // EXTEND_RADIUS * 0.5 是 左方向,折叠/收起的偏移量
297
+ startX: x - (offset > 0 ? offset + EXTEND_RADIUS * 0.5 : 0) - offsetRootBorderLineWidth,
298
+ startY: y + height,
299
+ endX: x -
300
+ offsetBorderLineWidth -
301
+ offsetRootBorderLineWidth -
302
+ (offset > 0 ? offset + QUICK_INSERT_CIRCLE_OFFSET - extraOffset : 0) -
303
+ EXTEND_RADIUS,
304
+ endY: y + height
305
+ },
306
+ // 画线方向:左向右 -->
307
+ [MindmapLayoutType.right]: {
308
+ startX: x + width + (offset > 0 ? offset + QUICK_INSERT_CIRCLE_OFFSET : 0) + offsetRootBorderLineWidth,
309
+ startY: y + height,
310
+ endX: x +
311
+ width +
312
+ offsetBorderLineWidth +
313
+ (offset > 0 ? offset + QUICK_INSERT_CIRCLE_OFFSET - extraOffset : 0) +
314
+ EXTEND_RADIUS +
315
+ offsetRootBorderLineWidth,
316
+ endY: y + height
317
+ },
318
+ // 画线方向:下向上 -->
319
+ [MindmapLayoutType.upward]: {
320
+ startX: x + width * 0.5,
321
+ startY: y - offsetBorderLineWidth - (offset > 0 ? offset + QUICK_INSERT_CIRCLE_OFFSET : 0) - offsetRootBorderLineWidth,
322
+ endX: x + width * 0.5,
323
+ endY: y -
324
+ offsetBorderLineWidth -
325
+ (offset > 0 ? offset + QUICK_INSERT_CIRCLE_OFFSET - extraOffset : 0) -
326
+ EXTEND_RADIUS -
327
+ offsetRootBorderLineWidth
328
+ },
329
+ // 画线方向:上向下 -->
330
+ [MindmapLayoutType.downward]: {
331
+ startX: x + width * 0.5,
332
+ startY: y + height + offsetBorderLineWidth + (offset > 0 ? offset + QUICK_INSERT_CIRCLE_OFFSET : 0) + offsetRootBorderLineWidth,
333
+ endX: x + width * 0.5,
334
+ endY: y +
335
+ height +
336
+ offsetBorderLineWidth +
337
+ (offset > 0 ? offset + QUICK_INSERT_CIRCLE_OFFSET - extraOffset : 0) +
338
+ EXTEND_RADIUS +
339
+ offsetRootBorderLineWidth
340
+ },
341
+ [MindmapLayoutType.leftBottomIndented]: {
342
+ startX: x + width * 0.5,
343
+ startY: y + height + offsetBorderLineWidth + (offset > 0 ? offset + QUICK_INSERT_CIRCLE_OFFSET : 0) + offsetRootBorderLineWidth,
344
+ endX: x + width * 0.5,
345
+ endY: y +
346
+ height +
347
+ offsetBorderLineWidth +
348
+ (offset > 0 ? offset + QUICK_INSERT_CIRCLE_OFFSET - extraOffset : 0) +
349
+ EXTEND_RADIUS +
350
+ offsetRootBorderLineWidth
351
+ },
352
+ [MindmapLayoutType.leftTopIndented]: {
353
+ startX: x + width * 0.5,
354
+ startY: y - offsetBorderLineWidth - (offset > 0 ? offset + QUICK_INSERT_CIRCLE_OFFSET : 0) - offsetRootBorderLineWidth,
355
+ endX: x + width * 0.5,
356
+ endY: y -
357
+ offsetBorderLineWidth -
358
+ (offset > 0 ? offset + QUICK_INSERT_CIRCLE_OFFSET : 0) -
359
+ EXTEND_RADIUS -
360
+ offsetRootBorderLineWidth
361
+ },
362
+ [MindmapLayoutType.rightBottomIndented]: {
363
+ startX: x + width * 0.5,
364
+ startY: y + height + offsetBorderLineWidth + (offset > 0 ? offset + QUICK_INSERT_CIRCLE_OFFSET : 0) + offsetRootBorderLineWidth,
365
+ endX: x + width * 0.5,
366
+ endY: y +
367
+ height +
368
+ offsetBorderLineWidth +
369
+ (offset > 0 ? offset + QUICK_INSERT_CIRCLE_OFFSET - extraOffset : 0) +
370
+ EXTEND_RADIUS +
371
+ offsetRootBorderLineWidth
372
+ },
373
+ [MindmapLayoutType.rightTopIndented]: {
374
+ startX: x + width * 0.5,
375
+ startY: y - offsetBorderLineWidth - (offset > 0 ? offset + QUICK_INSERT_CIRCLE_OFFSET : 0) - offsetRootBorderLineWidth,
376
+ endX: x + width * 0.5,
377
+ endY: y -
378
+ offsetBorderLineWidth -
379
+ (offset > 0 ? offset + QUICK_INSERT_CIRCLE_OFFSET : 0) -
380
+ EXTEND_RADIUS -
381
+ offsetRootBorderLineWidth
382
+ }
383
+ };
384
+ if (shape === MindmapNodeShape.roundRectangle || this.node.origin.isRoot) {
385
+ underlineCoordinates[MindmapLayoutType.left].startY -= height * 0.5;
386
+ underlineCoordinates[MindmapLayoutType.left].endY -= height * 0.5;
387
+ underlineCoordinates[MindmapLayoutType.right].startY -= height * 0.5;
388
+ underlineCoordinates[MindmapLayoutType.right].endY -= height * 0.5;
389
+ }
390
+ const stroke = this.node.origin.isRoot
391
+ ? getRootLinkLineColorByMindmapElement(this.element)
392
+ : getLinkLineColorByMindmapElement(this.element);
393
+ let nodeLayout = MindmapQueries.getCorrectLayoutByElement(this.node.origin);
394
+ if (this.node.origin.isRoot && isStandardLayout(nodeLayout)) {
395
+ const root = this.node.origin;
396
+ nodeLayout = root.children.length >= root.rightNodeCount ? MindmapLayoutType.left : MindmapLayoutType.right;
397
+ }
398
+ const underlineCoordinate = underlineCoordinates[nodeLayout];
399
+ if (underlineCoordinate) {
400
+ const underline = this.roughSVG.line(underlineCoordinate.startX, underlineCoordinate.startY, underlineCoordinate.endX, underlineCoordinate.endY, { stroke, strokeWidth });
401
+ const circleCoordinates = {
402
+ startX: underlineCoordinate.endX,
403
+ startY: underlineCoordinate.endY
404
+ };
405
+ const circle = this.roughSVG.circle(circleCoordinates.startX, circleCoordinates.startY, EXTEND_RADIUS, {
406
+ fill: QUICK_INSERT_CIRCLE_COLOR,
407
+ stroke: QUICK_INSERT_CIRCLE_COLOR,
408
+ fillStyle: 'solid'
409
+ });
410
+ const innerCrossCoordinates = {
411
+ horizontal: {
412
+ startX: circleCoordinates.startX - EXTEND_RADIUS * 0.5 + 3,
413
+ startY: circleCoordinates.startY,
414
+ endX: circleCoordinates.startX + EXTEND_RADIUS * 0.5 - 3,
415
+ endY: circleCoordinates.startY
416
+ },
417
+ vertical: {
418
+ startX: circleCoordinates.startX,
419
+ startY: circleCoordinates.startY - EXTEND_RADIUS * 0.5 + 3,
420
+ endX: circleCoordinates.startX,
421
+ endY: circleCoordinates.startY + EXTEND_RADIUS * 0.5 - 3
422
+ }
423
+ };
424
+ const innerCrossHLine = this.roughSVG.line(innerCrossCoordinates.horizontal.startX, innerCrossCoordinates.horizontal.startY, innerCrossCoordinates.horizontal.endX, innerCrossCoordinates.horizontal.endY, {
425
+ stroke: QUICK_INSERT_INNER_CROSS_COLOR,
426
+ strokeWidth: 2
427
+ });
428
+ const innerRingVLine = this.roughSVG.line(innerCrossCoordinates.vertical.startX, innerCrossCoordinates.vertical.startY, innerCrossCoordinates.vertical.endX, innerCrossCoordinates.vertical.endY, {
429
+ stroke: QUICK_INSERT_INNER_CROSS_COLOR,
430
+ strokeWidth: 2
431
+ });
432
+ quickInsertG.appendChild(underline);
433
+ quickInsertG.appendChild(circle);
434
+ quickInsertG.appendChild(innerCrossHLine);
435
+ quickInsertG.appendChild(innerRingVLine);
436
+ }
437
+ fromEvent(quickInsertG, 'mouseup')
438
+ .pipe(take(1))
439
+ .subscribe(() => {
440
+ const path = PlaitBoard.findPath(this.board, this.element).concat(this.element.children.filter(child => !AbstractNode.isAbstract(child)).length);
441
+ insertMindElement(this.board, this.node.origin, path);
442
+ });
443
+ }
444
+ drawExtend() {
445
+ // destroy
446
+ this.destroyExtend();
447
+ // create extend
448
+ this.extendG = createG();
449
+ const collapseG = createG();
450
+ this.extendG.classList.add('extend');
451
+ collapseG.classList.add('collapse-container');
452
+ this.g.append(this.extendG);
453
+ this.extendG.append(collapseG);
454
+ if (this.node.origin.isRoot) {
455
+ this.drawQuickInsert();
456
+ return;
457
+ }
458
+ // interactive
459
+ fromEvent(collapseG, 'mouseup')
460
+ .pipe(filter(() => !this.handActive || this.board.options.readonly), take(1))
461
+ .subscribe(() => {
462
+ const isCollapsed = !this.node.origin.isCollapsed;
463
+ const newElement = { isCollapsed };
464
+ const path = PlaitBoard.findPath(this.board, this.element);
465
+ Transforms.setNode(this.board, newElement, path);
466
+ });
467
+ const { x, y, width, height } = getRectangleByNode(this.node);
468
+ const stroke = getLinkLineColorByMindmapElement(this.element);
469
+ const strokeWidth = this.node.origin.linkLineWidth ? this.node.origin.linkLineWidth : STROKE_WIDTH;
470
+ const extendY = y + height / 2;
471
+ const nodeLayout = MindmapQueries.getCorrectLayoutByElement(this.element);
472
+ let extendLineXY = [
473
+ [x + width, extendY],
474
+ [x + width + EXTEND_OFFSET, extendY]
475
+ ];
476
+ let arrowYOffset = [-4, 1, -0.6, 4];
477
+ let arrowXOffset = [10, 5.5, 5.5, 10];
478
+ let extendLineXOffset = [0, 0];
479
+ let extendLineYOffset = [0, 0];
480
+ let circleOffset = [EXTEND_RADIUS / 2, 0];
481
+ if (isHorizontalLayout(nodeLayout) && !isIndentedLayout(nodeLayout)) {
482
+ extendLineYOffset =
483
+ getNodeShapeByElement(this.node.origin) === MindmapNodeShape.roundRectangle
484
+ ? [0, 0]
485
+ : [height / 2, height / 2];
486
+ if (isLeftLayout(nodeLayout)) {
487
+ //左
488
+ extendLineXOffset = [-width, -width - EXTEND_OFFSET * 2];
489
+ circleOffset = [-EXTEND_RADIUS / 2, 0];
490
+ arrowXOffset = [-10, -5.5, -5.5, -10];
491
+ }
492
+ }
493
+ else {
494
+ arrowXOffset = [-4, 0.6, -1, 4];
495
+ if (isTopLayout(nodeLayout)) {
496
+ //上
497
+ extendLineXOffset = [-width / 2, -width / 2 - EXTEND_OFFSET];
498
+ extendLineYOffset = [-height / 2, -height / 2 - EXTEND_OFFSET];
499
+ arrowYOffset = [-10, -5.5, -5.5, -10];
500
+ circleOffset = [0, -EXTEND_RADIUS / 2];
501
+ }
502
+ else {
503
+ //下
504
+ extendLineXOffset = [-width / 2, -width / 2 - EXTEND_OFFSET];
505
+ extendLineYOffset = [height / 2, height / 2 + EXTEND_OFFSET];
506
+ arrowYOffset = [10, 5.5, 5.5, 10];
507
+ circleOffset = [0, EXTEND_RADIUS / 2];
508
+ }
509
+ }
510
+ extendLineXY = [
511
+ [extendLineXY[0][0] + extendLineXOffset[0], extendLineXY[0][1] + extendLineYOffset[0]],
512
+ [extendLineXY[1][0] + extendLineXOffset[1], extendLineXY[1][1] + extendLineYOffset[1]]
513
+ ];
514
+ const extendLine = this.roughSVG.line(extendLineXY[0][0], extendLineXY[0][1], extendLineXY[1][0], extendLineXY[1][1], {
515
+ strokeWidth,
516
+ stroke
517
+ });
518
+ //绘制箭头
519
+ const hideArrowTopLine = this.roughSVG.line(extendLineXY[1][0] + arrowXOffset[0], extendLineXY[1][1] + arrowYOffset[0], extendLineXY[1][0] + arrowXOffset[1], extendLineXY[1][1] + arrowYOffset[1], {
520
+ stroke,
521
+ strokeWidth: 2
522
+ });
523
+ const hideArrowBottomLine = this.roughSVG.line(extendLineXY[1][0] + arrowXOffset[2], extendLineXY[1][1] + arrowYOffset[2], extendLineXY[1][0] + arrowXOffset[3], extendLineXY[1][1] + arrowYOffset[3], {
524
+ stroke,
525
+ strokeWidth: 2
526
+ });
527
+ if (this.node.origin.isCollapsed) {
528
+ const badge = this.roughSVG.circle(extendLineXY[1][0] + circleOffset[0], extendLineXY[1][1] + circleOffset[1], EXTEND_RADIUS, {
529
+ fill: stroke,
530
+ stroke,
531
+ fillStyle: 'solid'
532
+ });
533
+ let numberOffset = 0;
534
+ if (getChildrenCount(this.node.origin) >= 10)
535
+ numberOffset = -2;
536
+ if (getChildrenCount(this.node.origin) === 1)
537
+ numberOffset = 1;
538
+ const badgeText = createText(extendLineXY[1][0] + circleOffset[0] - 4 + numberOffset, extendLineXY[1][1] + circleOffset[1] + 4, stroke, `${getChildrenCount(this.node.origin)}`);
539
+ this.g.classList.add('collapsed');
540
+ badge.setAttribute('style', 'opacity: 0.15');
541
+ badgeText.setAttribute('style', 'font-size: 12px');
542
+ collapseG.appendChild(badge);
543
+ collapseG.appendChild(badgeText);
544
+ collapseG.appendChild(extendLine);
545
+ }
546
+ else {
547
+ this.g.classList.remove('collapsed');
548
+ if (this.node.origin.children.length > 0) {
549
+ const hideCircleG = this.roughSVG.circle(extendLineXY[1][0] + circleOffset[0], extendLineXY[1][1] + circleOffset[1], EXTEND_RADIUS - 1, {
550
+ fill: '#fff',
551
+ stroke,
552
+ strokeWidth,
553
+ fillStyle: 'solid'
554
+ });
555
+ collapseG.appendChild(hideCircleG);
556
+ collapseG.appendChild(hideArrowTopLine);
557
+ collapseG.appendChild(hideArrowBottomLine);
558
+ this.drawQuickInsert(EXTEND_RADIUS);
559
+ }
560
+ else {
561
+ this.drawQuickInsert();
562
+ }
563
+ }
564
+ }
565
+ destroyExtend() {
566
+ if (this.extendG) {
567
+ this.extendG.remove();
568
+ }
569
+ }
570
+ destroyRichtext() {
571
+ if (this.richtextG) {
572
+ this.richtextG.remove();
573
+ }
574
+ if (this.richtextComponentRef) {
575
+ this.richtextComponentRef.destroy();
576
+ }
577
+ }
578
+ updateAbstractIncludedOutline(resizingLocation, handlePosition) {
579
+ this.abstractIncludedOutlineG?.remove();
580
+ this.abstractIncludedOutlineG = drawAbstractIncludedOutline(this.board, this.roughSVG, this.element, handlePosition, resizingLocation);
581
+ PlaitBoard.getHost(this.board).append(this.abstractIncludedOutlineG);
582
+ }
583
+ updateRichtext() {
584
+ updateRichText(this.node.origin.data.topic, this.richtextComponentRef);
585
+ updateMindNodeTopicSize(this.node, this.richtextG, this.isEditable);
586
+ }
587
+ startEditText(isEnd, isClear) {
588
+ if (!this.richtextComponentRef) {
589
+ throw new Error('undefined richtextComponentRef');
590
+ }
591
+ const richtextInstance = this.richtextComponentRef.instance;
592
+ this.isEditable = true;
593
+ IS_TEXT_EDITABLE.set(this.board, true);
594
+ this.disabledMaskG();
595
+ updateMindNodeTopicSize(this.node, this.richtextG, this.isEditable);
596
+ if (richtextInstance.plaitReadonly) {
597
+ richtextInstance.plaitReadonly = false;
598
+ this.richtextComponentRef.changeDetectorRef.detectChanges();
599
+ this.drawActiveG();
600
+ const location = isEnd ? Editor.end(richtextInstance.editor, [0]) : [0];
601
+ setFullSelectionAndFocus(richtextInstance.editor, location);
602
+ if (isClear) {
603
+ Editor.deleteBackward(richtextInstance.editor);
604
+ }
605
+ // handle invalid width and height (old data)
606
+ let { width, height } = getRichtextContentSize(richtextInstance.editable);
607
+ if (width !== this.element.width || height !== this.element.height) {
608
+ MindTransforms.setTopicSize(this.board, this.element, width, height);
609
+ }
610
+ }
611
+ let richtext = richtextInstance.plaitValue;
612
+ // use debounceTime to wait DOM render complete
613
+ const valueChange$ = richtextInstance.plaitChange
614
+ .pipe(debounceTime(0), filter(event => {
615
+ // 过滤掉 operations 中全是 set_selection 的操作
616
+ return !event.operations.every(op => Operation.isSelectionOperation(op));
617
+ }))
618
+ .subscribe(event => {
619
+ if (richtext === event.value) {
620
+ return;
621
+ }
622
+ this.updateRichtext();
623
+ // 更新富文本、更新宽高
624
+ let { width, height } = getRichtextContentSize(richtextInstance.editable);
625
+ MindTransforms.setTopic(this.board, this.element, event.value, width, height);
626
+ MERGING.set(this.board, true);
627
+ });
628
+ const composition$ = richtextInstance.plaitComposition.pipe(debounceTime(0)).subscribe(event => {
629
+ let { width, height } = getRichtextContentSize(richtextInstance.editable);
630
+ if (width < NODE_MIN_WIDTH) {
631
+ width = NODE_MIN_WIDTH;
632
+ }
633
+ if (event.isComposing && (width !== this.node.origin.width || height !== this.node.origin.height)) {
634
+ const newElement = {
635
+ width: width / this.board.viewport.zoom,
636
+ height: height / this.board.viewport.zoom
637
+ };
638
+ const path = PlaitBoard.findPath(this.board, this.element);
639
+ Transforms.setNode(this.board, newElement, path);
640
+ MERGING.set(this.board, true);
641
+ }
642
+ });
643
+ const mousedown$ = fromEvent(document, 'mousedown').subscribe((event) => {
644
+ const point = transformPoint(this.board, toPoint(event.x, event.y, PlaitBoard.getHost(this.board)));
645
+ const clickInNode = hitMindmapElement(this.board, point, this.element);
646
+ if (clickInNode && !hasEditableTarget(richtextInstance.editor, event.target)) {
647
+ event.preventDefault();
648
+ }
649
+ else if (!clickInNode) {
650
+ // handle composition input state, like: Chinese IME Composition Input
651
+ timer(0).subscribe(() => {
652
+ exitHandle();
653
+ this.enableMaskG();
654
+ });
655
+ }
656
+ });
657
+ const editor = richtextInstance.editor;
658
+ const { keydown } = editor;
659
+ editor.keydown = (event) => {
660
+ if (event.isComposing) {
661
+ return;
662
+ }
663
+ if (event.key === 'Escape') {
664
+ event.preventDefault();
665
+ event.stopPropagation();
666
+ exitHandle();
667
+ this.drawActiveG();
668
+ this.enableMaskG();
669
+ return;
670
+ }
671
+ if (event.key === 'Enter' && !event.shiftKey) {
672
+ event.preventDefault();
673
+ event.stopPropagation();
674
+ exitHandle();
675
+ this.drawActiveG();
676
+ this.enableMaskG();
677
+ return;
678
+ }
679
+ if (event.key === 'Tab') {
680
+ event.preventDefault();
681
+ event.stopPropagation();
682
+ exitHandle();
683
+ this.drawActiveG();
684
+ this.drawMaskG();
685
+ }
686
+ };
687
+ const exitHandle = () => {
688
+ // unsubscribe
689
+ valueChange$.unsubscribe();
690
+ composition$.unsubscribe();
691
+ mousedown$.unsubscribe();
692
+ editor.keydown = keydown; // reset keydown
693
+ // editable status
694
+ MERGING.set(this.board, false);
695
+ richtextInstance.plaitReadonly = true;
696
+ this.richtextComponentRef?.changeDetectorRef.markForCheck();
697
+ this.isEditable = false;
698
+ updateMindNodeTopicSize(this.node, this.richtextG, this.isEditable);
699
+ IS_TEXT_EDITABLE.set(this.board, false);
700
+ };
701
+ }
702
+ ngOnDestroy() {
703
+ super.ngOnDestroy();
704
+ this.abstractIncludedOutlineG?.remove();
705
+ this.destroyRichtext();
706
+ this.destroy$.next();
707
+ this.destroy$.complete();
708
+ if (ELEMENT_TO_NODE.get(this.element) === this.node) {
709
+ ELEMENT_TO_NODE.delete(this.element);
710
+ }
711
+ if (MINDMAP_ELEMENT_TO_COMPONENT.get(this.element) === this) {
712
+ MINDMAP_ELEMENT_TO_COMPONENT.delete(this.element);
713
+ }
714
+ }
715
+ }
716
+ MindNodeComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.5", ngImport: i0, type: MindNodeComponent, deps: [{ token: i0.ViewContainerRef }, { token: i0.ChangeDetectorRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component });
717
+ MindNodeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.5", type: MindNodeComponent, selector: "plait-mindmap-node", usesInheritance: true, ngImport: i0, template: `
718
+ <plait-children
719
+ *ngIf="!element.isCollapsed"
720
+ [board]="board"
721
+ [parent]="element"
722
+ [effect]="effect"
723
+ [parentG]="parentG"
724
+ ></plait-children>
725
+ `, isInline: true, dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.PlaitChildrenElement, selector: "plait-children", inputs: ["board", "parent", "effect", "parentG"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
726
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.5", ngImport: i0, type: MindNodeComponent, decorators: [{
727
+ type: Component,
728
+ args: [{
729
+ selector: 'plait-mindmap-node',
730
+ template: `
731
+ <plait-children
732
+ *ngIf="!element.isCollapsed"
733
+ [board]="board"
734
+ [parent]="element"
735
+ [effect]="effect"
736
+ [parentG]="parentG"
737
+ ></plait-children>
738
+ `,
739
+ changeDetection: ChangeDetectionStrategy.OnPush
740
+ }]
741
+ }], ctorParameters: function () { return [{ type: i0.ViewContainerRef }, { type: i0.ChangeDetectorRef }, { type: i0.Renderer2 }]; } });
742
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node.component.js","sourceRoot":"","sources":["../../../packages/mind/src/node.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ComponentRef,\n    OnDestroy,\n    OnInit,\n    Renderer2,\n    ViewContainerRef\n} from '@angular/core';\nimport {\n    PlaitPointerType,\n    createG,\n    createText,\n    IS_TEXT_EDITABLE,\n    MERGING,\n    PlaitBoard,\n    toPoint,\n    transformPoint,\n    Transforms,\n    drawRoundRectangle,\n    PlaitPluginElementComponent,\n    PlaitElement,\n    NODE_TO_INDEX,\n    PlaitPluginElementContext,\n    OnContextChanged,\n    Point\n} from '@plait/core';\nimport {\n    isBottomLayout,\n    isHorizontalLayout,\n    isIndentedLayout,\n    isLeftLayout,\n    AbstractNode,\n    isRightLayout,\n    isStandardLayout,\n    isTopLayout,\n    MindmapLayoutType,\n    OriginNode\n} from '@plait/layouts';\nimport { hasEditableTarget, PlaitRichtextComponent, setFullSelectionAndFocus, updateRichText } from '@plait/richtext';\nimport { RoughSVG } from 'roughjs/bin/svg';\nimport { fromEvent, Subject, timer } from 'rxjs';\nimport { debounceTime, filter, take, takeUntil } from 'rxjs/operators';\nimport { Editor, Operation } from 'slate';\nimport {\n    EXTEND_OFFSET,\n    EXTEND_RADIUS,\n    MindmapNodeShape,\n    NODE_MIN_WIDTH,\n    PRIMARY_COLOR,\n    QUICK_INSERT_CIRCLE_COLOR,\n    QUICK_INSERT_CIRCLE_OFFSET,\n    QUICK_INSERT_INNER_CROSS_COLOR,\n    STROKE_WIDTH\n} from './constants';\nimport { drawIndentedLink } from './draw/indented-link';\nimport { drawLogicLink } from './draw/link/logic-link';\nimport { drawMindmapNodeRichtext, updateMindNodeTopicSize } from './draw/richtext';\nimport { drawRectangleNode } from './draw/shape';\nimport { MindElement, PlaitMind } from './interfaces/element';\nimport { ExtendLayoutType, ExtendUnderlineCoordinateType, MindmapNode } from './interfaces/node';\nimport { MindmapQueries } from './queries';\nimport { getLinkLineColorByMindmapElement, getRootLinkLineColorByMindmapElement } from './utils/colors';\nimport { getRectangleByNode, hitMindmapElement } from './utils/graph';\nimport { insertMindElement, getChildrenCount } from './utils/mindmap';\nimport { getNodeShapeByElement } from './utils/shape';\nimport { ELEMENT_TO_NODE, MINDMAP_ELEMENT_TO_COMPONENT } from './utils/weak-maps';\nimport { getRichtextContentSize } from '@plait/richtext';\nimport { drawAbstractLink } from './draw/link/abstract-link';\nimport { EmojisDrawer } from './plugins/emoji/emoji.drawer';\nimport { PlaitMindEmojiBoard } from './plugins/emoji/with-mind-emoji';\nimport { MindTransforms } from './transforms';\nimport { drawAbstractIncludedOutline } from './draw/abstract';\nimport { AbstractHandlePosition } from './interfaces';\n\n@Component({\n    selector: 'plait-mindmap-node',\n    template: `\n        <plait-children\n            *ngIf=\"!element.isCollapsed\"\n            [board]=\"board\"\n            [parent]=\"element\"\n            [effect]=\"effect\"\n            [parentG]=\"parentG\"\n        ></plait-children>\n    `,\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class MindNodeComponent<T extends MindElement = MindElement> extends PlaitPluginElementComponent<T>\n    implements OnInit, OnDestroy, OnContextChanged<T> {\n    isEditable = false;\n\n    roughSVG!: RoughSVG;\n\n    node!: MindmapNode;\n\n    parent!: MindmapNode;\n\n    index!: number;\n\n    abstractIncludedOutlineG?: SVGGElement;\n\n    parentG!: SVGGElement;\n\n    activeG: SVGGElement[] = [];\n\n    shapeG: SVGGElement | null = null;\n\n    linkG?: SVGGElement;\n\n    richtextG?: SVGGElement;\n\n    foreignObject?: SVGForeignObjectElement;\n\n    extendG?: SVGGElement;\n\n    maskG!: SVGGElement;\n\n    richtextComponentRef?: ComponentRef<PlaitRichtextComponent>;\n\n    destroy$ = new Subject<void>();\n\n    emojisDrawer!: EmojisDrawer;\n\n    public get handActive(): boolean {\n        return this.board.pointer === PlaitPointerType.hand;\n    }\n\n    constructor(private viewContainerRef: ViewContainerRef, protected cdr: ChangeDetectorRef, private render2: Renderer2) {\n        super(cdr);\n    }\n\n    ngOnInit(): void {\n        this.emojisDrawer = new EmojisDrawer(this.board as PlaitMindEmojiBoard, this.viewContainerRef);\n        MINDMAP_ELEMENT_TO_COMPONENT.set(this.element, this);\n        super.ngOnInit();\n        this.node = ELEMENT_TO_NODE.get(this.element) as MindmapNode;\n        if (!PlaitMind.isMind(this.element)) {\n            this.parent = MindElement.getNode(MindElement.getParent(this.element));\n        }\n        this.index = NODE_TO_INDEX.get(this.element) || 0;\n        this.roughSVG = PlaitBoard.getRoughSVG(this.board);\n        this.parentG = PlaitElement.getComponent(MindElement.getRoot(this.board, this.element)).rootG as SVGGElement;\n        this.drawShape();\n        this.drawLink();\n        this.drawRichtext();\n        this.drawEmojis();\n        this.drawActiveG();\n        this.updateActiveClass();\n        this.drawMaskG();\n        this.drawExtend();\n    }\n\n    onContextChanged(value: PlaitPluginElementContext<T>, previous: PlaitPluginElementContext<T>) {\n        const newNode = ELEMENT_TO_NODE.get(this.element) as MindmapNode;\n        if (!PlaitMind.isMind(this.element)) {\n            this.parent = MindElement.getNode(MindElement.getParent(this.element));\n        }\n\n        MINDMAP_ELEMENT_TO_COMPONENT.set(this.element, this);\n\n        // resolve move node richtext lose issue\n        if (this.node !== newNode) {\n            if (this.foreignObject && this.foreignObject.children.length <= 0) {\n                this.foreignObject?.appendChild(this.richtextComponentRef?.instance.editable as HTMLElement);\n            }\n        }\n\n        const isEquals = MindmapNode.isEquals(this.node, newNode);\n        this.node = newNode;\n        this.drawActiveG();\n        this.updateActiveClass();\n        if (!isEquals) {\n            this.drawShape();\n            this.drawLink();\n            this.updateRichtext();\n            this.drawMaskG();\n            this.drawExtend();\n            this.drawEmojis();\n        }\n    }\n\n    drawShape() {\n        this.destroyShape();\n        const shape = getNodeShapeByElement(this.node.origin) as MindmapNodeShape;\n        switch (shape) {\n            case MindmapNodeShape.roundRectangle:\n                this.shapeG = drawRectangleNode(this.board, this.node as MindmapNode);\n                this.g.prepend(this.shapeG);\n                break;\n            default:\n                break;\n        }\n    }\n\n    drawEmojis() {\n        const g = this.emojisDrawer.drawEmojis(this.element);\n        if (g) {\n            this.g.append(g);\n        }\n    }\n\n    destroyShape() {\n        if (this.shapeG) {\n            this.shapeG.remove();\n            this.shapeG = null;\n        }\n    }\n\n    drawLink() {\n        if (!this.parent) {\n            return;\n        }\n\n        if (this.linkG) {\n            this.linkG.remove();\n        }\n\n        const layout = MindmapQueries.getLayoutByElement(this.parent.origin) as MindmapLayoutType;\n        if (AbstractNode.isAbstract(this.node.origin)) {\n            this.linkG = drawAbstractLink(this.board, this.node, isHorizontalLayout(layout));\n        } else if (MindElement.isIndentedLayout(this.parent.origin)) {\n            this.linkG = drawIndentedLink(this.roughSVG, this.parent, this.node);\n        } else {\n            this.linkG = drawLogicLink(this.roughSVG, this.node, this.parent, isHorizontalLayout(layout));\n        }\n        this.g.append(this.linkG);\n    }\n\n    destroyLine() {\n        if (this.parent) {\n            if (this.linkG) {\n                this.linkG.remove();\n            }\n        }\n    }\n\n    drawMaskG() {\n        this.destroyMaskG();\n        const lineWidthOffset = 2;\n        const extendOffset = 15;\n        const nodeLayout = MindmapQueries.getLayoutByElement(this.node.origin) as MindmapLayoutType;\n        const isTop = isTopLayout(nodeLayout);\n        const isRight = isRightLayout(nodeLayout);\n        const isBottom = isBottomLayout(nodeLayout);\n        const isLeft = isLeftLayout(nodeLayout);\n        const { x, y, width, height } = getRectangleByNode(this.node as MindmapNode);\n\n        let drawX = x;\n        let drawY = y;\n        let drawWidth = x + width;\n        let drawHeight = y + height;\n\n        switch (true) {\n            case isTop:\n                drawX = x - lineWidthOffset;\n                drawY = y - extendOffset;\n                drawWidth = x + width + lineWidthOffset;\n                drawHeight = y + height + lineWidthOffset;\n                break;\n            case isBottom:\n                drawX = x - lineWidthOffset;\n                drawY = y - lineWidthOffset;\n                drawWidth = x + width + lineWidthOffset;\n                drawHeight = y + height + extendOffset;\n                break;\n            case isLeft:\n                drawX = x - extendOffset;\n                drawY = y - lineWidthOffset;\n                drawWidth = x + width + lineWidthOffset;\n                drawHeight = y + height + lineWidthOffset;\n                break;\n            case isRight:\n                drawX = x - lineWidthOffset;\n                drawY = y - lineWidthOffset;\n                drawWidth = x + width + extendOffset;\n                drawHeight = y + height + lineWidthOffset;\n                break;\n        }\n        this.maskG = drawRoundRectangle(\n            this.roughSVG as RoughSVG,\n            drawX,\n            drawY,\n            drawWidth,\n            drawHeight,\n            { stroke: 'none', fill: 'rgba(255,255,255,0)', fillStyle: 'solid' },\n            true\n        );\n        this.maskG.classList.add('mask');\n        this.maskG.setAttribute('visibility', 'visible');\n        this.g.append(this.maskG);\n\n        if (this.isEditable) {\n            this.disabledMaskG();\n        }\n\n        fromEvent<MouseEvent>(this.maskG, 'mouseenter')\n            .pipe(\n                takeUntil(this.destroy$),\n                filter(() => {\n                    return PlaitBoard.isFocus(this.board) && !this.element.isCollapsed && !this.handActive;\n                })\n            )\n            .subscribe(() => {\n                this.g.classList.add('hovered');\n            });\n        fromEvent<MouseEvent>(this.maskG, 'mouseleave')\n            .pipe(\n                takeUntil(this.destroy$),\n                filter(() => {\n                    return PlaitBoard.isFocus(this.board) && !this.element.isCollapsed;\n                })\n            )\n            .subscribe(() => {\n                this.g.classList.remove('hovered');\n            });\n    }\n\n    destroyMaskG() {\n        if (this.maskG) {\n            this.maskG.remove();\n            this.g.classList.remove('hovered');\n        }\n    }\n\n    enableMaskG() {\n        if (this.maskG) {\n            this.maskG.setAttribute('visibility', 'visible');\n        }\n    }\n\n    disabledMaskG() {\n        if (this.maskG) {\n            this.maskG.setAttribute('visibility', 'hidden');\n        }\n    }\n\n    drawActiveG() {\n        this.destroyActiveG();\n        this.abstractIncludedOutlineG?.remove();\n        if (this.selected) {\n            if (AbstractNode.isAbstract(this.element)) {\n                this.updateAbstractIncludedOutline();\n            }\n            let { x, y, width, height } = getRectangleByNode(this.node as MindmapNode);\n            const selectedStrokeG = drawRoundRectangle(\n                this.roughSVG as RoughSVG,\n                x - 2,\n                y - 2,\n                x + width + 2,\n                y + height + 2,\n                { stroke: PRIMARY_COLOR, strokeWidth: 2, fill: '' },\n                true\n            );\n            // 影响 mask 移入移出事件\n            selectedStrokeG.style.pointerEvents = 'none';\n            this.g.appendChild(selectedStrokeG);\n            this.activeG.push(selectedStrokeG);\n            if (this.richtextComponentRef?.instance.plaitReadonly === true) {\n                const selectedBackgroundG = drawRoundRectangle(\n                    this.roughSVG as RoughSVG,\n                    x - 2,\n                    y - 2,\n                    x + width + 2,\n                    y + height + 2,\n                    { stroke: PRIMARY_COLOR, fill: PRIMARY_COLOR, fillStyle: 'solid' },\n                    true\n                );\n                selectedBackgroundG.style.opacity = '0.15';\n                // 影响双击事件\n                selectedBackgroundG.style.pointerEvents = 'none';\n                this.g.appendChild(selectedBackgroundG);\n                this.activeG.push(selectedBackgroundG, selectedStrokeG);\n            }\n        }\n    }\n\n    destroyActiveG() {\n        this.activeG.forEach(g => g.remove());\n        this.activeG = [];\n    }\n\n    updateActiveClass() {\n        if (!this.g) {\n            return;\n        }\n        if (this.selected) {\n            this.render2.addClass(this.g, 'active');\n        } else {\n            this.render2.removeClass(this.g, 'active');\n        }\n    }\n\n    drawRichtext() {\n        const { richtextG, richtextComponentRef, foreignObject } = drawMindmapNodeRichtext(this.node as MindmapNode, this.viewContainerRef);\n        this.richtextComponentRef = richtextComponentRef;\n        this.richtextG = richtextG;\n        this.foreignObject = foreignObject;\n        this.render2.addClass(richtextG, 'richtext');\n        this.g.append(richtextG);\n    }\n\n    private drawQuickInsert(offset = 0) {\n        if (this.board.options.readonly) {\n            return;\n        }\n        const quickInsertG = createG();\n        quickInsertG.classList.add('quick-insert');\n        this.extendG?.append(quickInsertG);\n        const { x, y, width, height } = getRectangleByNode(this.node);\n\n        /**\n         * 方位：\n         *    1. 左、左上、左下\n         *    2. 右、右上、右下\n         *    3. 上、上左、上右\n         *    4. 下、下左、下右\n         */\n        const shape = getNodeShapeByElement(this.node.origin);\n        // 形状是矩形要偏移边框的线宽\n        const strokeWidth = this.node.origin.linkLineWidth ? this.node.origin.linkLineWidth : STROKE_WIDTH;\n        let offsetBorderLineWidth = 0;\n        if (shape === MindmapNodeShape.roundRectangle && offset === 0) {\n            offsetBorderLineWidth = strokeWidth;\n        }\n        let offsetRootBorderLineWidth = 0;\n        if (this.node.origin.isRoot) {\n            offsetRootBorderLineWidth = strokeWidth;\n        }\n        // 当没有子节点时，需要缩小的偏移量\n        const extraOffset = 3;\n        const underlineCoordinates: ExtendUnderlineCoordinateType = {\n            // 画线方向：右向左 <--\n            [MindmapLayoutType.left]: {\n                // EXTEND_RADIUS * 0.5 是 左方向，折叠/收起的偏移量\n                startX: x - (offset > 0 ? offset + EXTEND_RADIUS * 0.5 : 0) - offsetRootBorderLineWidth,\n                startY: y + height,\n                endX:\n                    x -\n                    offsetBorderLineWidth -\n                    offsetRootBorderLineWidth -\n                    (offset > 0 ? offset + QUICK_INSERT_CIRCLE_OFFSET - extraOffset : 0) -\n                    EXTEND_RADIUS,\n                endY: y + height\n            },\n            // 画线方向：左向右 -->\n            [MindmapLayoutType.right]: {\n                startX: x + width + (offset > 0 ? offset + QUICK_INSERT_CIRCLE_OFFSET : 0) + offsetRootBorderLineWidth,\n                startY: y + height,\n                endX:\n                    x +\n                    width +\n                    offsetBorderLineWidth +\n                    (offset > 0 ? offset + QUICK_INSERT_CIRCLE_OFFSET - extraOffset : 0) +\n                    EXTEND_RADIUS +\n                    offsetRootBorderLineWidth,\n                endY: y + height\n            },\n            // 画线方向：下向上 -->\n            [MindmapLayoutType.upward]: {\n                startX: x + width * 0.5,\n                startY: y - offsetBorderLineWidth - (offset > 0 ? offset + QUICK_INSERT_CIRCLE_OFFSET : 0) - offsetRootBorderLineWidth,\n                endX: x + width * 0.5,\n                endY:\n                    y -\n                    offsetBorderLineWidth -\n                    (offset > 0 ? offset + QUICK_INSERT_CIRCLE_OFFSET - extraOffset : 0) -\n                    EXTEND_RADIUS -\n                    offsetRootBorderLineWidth\n            },\n            // 画线方向：上向下 -->\n            [MindmapLayoutType.downward]: {\n                startX: x + width * 0.5,\n                startY:\n                    y + height + offsetBorderLineWidth + (offset > 0 ? offset + QUICK_INSERT_CIRCLE_OFFSET : 0) + offsetRootBorderLineWidth,\n                endX: x + width * 0.5,\n                endY:\n                    y +\n                    height +\n                    offsetBorderLineWidth +\n                    (offset > 0 ? offset + QUICK_INSERT_CIRCLE_OFFSET - extraOffset : 0) +\n                    EXTEND_RADIUS +\n                    offsetRootBorderLineWidth\n            },\n            [MindmapLayoutType.leftBottomIndented]: {\n                startX: x + width * 0.5,\n                startY:\n                    y + height + offsetBorderLineWidth + (offset > 0 ? offset + QUICK_INSERT_CIRCLE_OFFSET : 0) + offsetRootBorderLineWidth,\n                endX: x + width * 0.5,\n                endY:\n                    y +\n                    height +\n                    offsetBorderLineWidth +\n                    (offset > 0 ? offset + QUICK_INSERT_CIRCLE_OFFSET - extraOffset : 0) +\n                    EXTEND_RADIUS +\n                    offsetRootBorderLineWidth\n            },\n            [MindmapLayoutType.leftTopIndented]: {\n                startX: x + width * 0.5,\n                startY: y - offsetBorderLineWidth - (offset > 0 ? offset + QUICK_INSERT_CIRCLE_OFFSET : 0) - offsetRootBorderLineWidth,\n                endX: x + width * 0.5,\n                endY:\n                    y -\n                    offsetBorderLineWidth -\n                    (offset > 0 ? offset + QUICK_INSERT_CIRCLE_OFFSET : 0) -\n                    EXTEND_RADIUS -\n                    offsetRootBorderLineWidth\n            },\n            [MindmapLayoutType.rightBottomIndented]: {\n                startX: x + width * 0.5,\n                startY:\n                    y + height + offsetBorderLineWidth + (offset > 0 ? offset + QUICK_INSERT_CIRCLE_OFFSET : 0) + offsetRootBorderLineWidth,\n                endX: x + width * 0.5,\n                endY:\n                    y +\n                    height +\n                    offsetBorderLineWidth +\n                    (offset > 0 ? offset + QUICK_INSERT_CIRCLE_OFFSET - extraOffset : 0) +\n                    EXTEND_RADIUS +\n                    offsetRootBorderLineWidth\n            },\n            [MindmapLayoutType.rightTopIndented]: {\n                startX: x + width * 0.5,\n                startY: y - offsetBorderLineWidth - (offset > 0 ? offset + QUICK_INSERT_CIRCLE_OFFSET : 0) - offsetRootBorderLineWidth,\n                endX: x + width * 0.5,\n                endY:\n                    y -\n                    offsetBorderLineWidth -\n                    (offset > 0 ? offset + QUICK_INSERT_CIRCLE_OFFSET : 0) -\n                    EXTEND_RADIUS -\n                    offsetRootBorderLineWidth\n            }\n        };\n        if (shape === MindmapNodeShape.roundRectangle || this.node.origin.isRoot) {\n            underlineCoordinates[MindmapLayoutType.left].startY -= height * 0.5;\n            underlineCoordinates[MindmapLayoutType.left].endY -= height * 0.5;\n            underlineCoordinates[MindmapLayoutType.right].startY -= height * 0.5;\n            underlineCoordinates[MindmapLayoutType.right].endY -= height * 0.5;\n        }\n        const stroke = this.node.origin.isRoot\n            ? getRootLinkLineColorByMindmapElement(this.element)\n            : getLinkLineColorByMindmapElement(this.element);\n        let nodeLayout = MindmapQueries.getCorrectLayoutByElement(this.node.origin) as ExtendLayoutType;\n        if (this.node.origin.isRoot && isStandardLayout(nodeLayout)) {\n            const root = this.node.origin as OriginNode;\n            nodeLayout = root.children.length >= root.rightNodeCount ? MindmapLayoutType.left : MindmapLayoutType.right;\n        }\n        const underlineCoordinate = underlineCoordinates[nodeLayout];\n        if (underlineCoordinate) {\n            const underline = this.roughSVG.line(\n                underlineCoordinate.startX,\n                underlineCoordinate.startY,\n                underlineCoordinate.endX,\n                underlineCoordinate.endY,\n                { stroke, strokeWidth }\n            );\n            const circleCoordinates = {\n                startX: underlineCoordinate.endX,\n                startY: underlineCoordinate.endY\n            };\n            const circle = this.roughSVG.circle(circleCoordinates.startX, circleCoordinates.startY, EXTEND_RADIUS, {\n                fill: QUICK_INSERT_CIRCLE_COLOR,\n                stroke: QUICK_INSERT_CIRCLE_COLOR,\n                fillStyle: 'solid'\n            });\n            const innerCrossCoordinates = {\n                horizontal: {\n                    startX: circleCoordinates.startX - EXTEND_RADIUS * 0.5 + 3,\n                    startY: circleCoordinates.startY,\n                    endX: circleCoordinates.startX + EXTEND_RADIUS * 0.5 - 3,\n                    endY: circleCoordinates.startY\n                },\n                vertical: {\n                    startX: circleCoordinates.startX,\n                    startY: circleCoordinates.startY - EXTEND_RADIUS * 0.5 + 3,\n                    endX: circleCoordinates.startX,\n                    endY: circleCoordinates.startY + EXTEND_RADIUS * 0.5 - 3\n                }\n            };\n            const innerCrossHLine = this.roughSVG.line(\n                innerCrossCoordinates.horizontal.startX,\n                innerCrossCoordinates.horizontal.startY,\n                innerCrossCoordinates.horizontal.endX,\n                innerCrossCoordinates.horizontal.endY,\n                {\n                    stroke: QUICK_INSERT_INNER_CROSS_COLOR,\n                    strokeWidth: 2\n                }\n            );\n            const innerRingVLine = this.roughSVG.line(\n                innerCrossCoordinates.vertical.startX,\n                innerCrossCoordinates.vertical.startY,\n                innerCrossCoordinates.vertical.endX,\n                innerCrossCoordinates.vertical.endY,\n                {\n                    stroke: QUICK_INSERT_INNER_CROSS_COLOR,\n                    strokeWidth: 2\n                }\n            );\n            quickInsertG.appendChild(underline);\n            quickInsertG.appendChild(circle);\n            quickInsertG.appendChild(innerCrossHLine);\n            quickInsertG.appendChild(innerRingVLine);\n        }\n\n        fromEvent(quickInsertG, 'mouseup')\n            .pipe(take(1))\n            .subscribe(() => {\n                const path = PlaitBoard.findPath(this.board, this.element).concat(\n                    this.element.children.filter(child => !AbstractNode.isAbstract(child)).length\n                );\n                insertMindElement(this.board, this.node.origin, path);\n            });\n    }\n\n    drawExtend() {\n        // destroy\n        this.destroyExtend();\n        // create extend\n        this.extendG = createG();\n        const collapseG = createG();\n        this.extendG.classList.add('extend');\n        collapseG.classList.add('collapse-container');\n        this.g.append(this.extendG);\n        this.extendG.append(collapseG);\n        if (this.node.origin.isRoot) {\n            this.drawQuickInsert();\n            return;\n        }\n        // interactive\n        fromEvent(collapseG, 'mouseup')\n            .pipe(\n                filter(() => !this.handActive || this.board.options.readonly),\n                take(1)\n            )\n            .subscribe(() => {\n                const isCollapsed = !this.node.origin.isCollapsed;\n                const newElement: Partial<MindElement> = { isCollapsed };\n                const path = PlaitBoard.findPath(this.board, this.element);\n                Transforms.setNode(this.board, newElement, path);\n            });\n\n        const { x, y, width, height } = getRectangleByNode(this.node);\n        const stroke = getLinkLineColorByMindmapElement(this.element);\n        const strokeWidth = this.node.origin.linkLineWidth ? this.node.origin.linkLineWidth : STROKE_WIDTH;\n        const extendY = y + height / 2;\n        const nodeLayout = MindmapQueries.getCorrectLayoutByElement(this.element) as MindmapLayoutType;\n\n        let extendLineXY = [\n            [x + width, extendY],\n            [x + width + EXTEND_OFFSET, extendY]\n        ];\n\n        let arrowYOffset = [-4, 1, -0.6, 4];\n        let arrowXOffset = [10, 5.5, 5.5, 10];\n\n        let extendLineXOffset = [0, 0];\n        let extendLineYOffset = [0, 0];\n\n        let circleOffset = [EXTEND_RADIUS / 2, 0];\n\n        if (isHorizontalLayout(nodeLayout) && !isIndentedLayout(nodeLayout)) {\n            extendLineYOffset =\n                (getNodeShapeByElement(this.node.origin) as MindmapNodeShape) === MindmapNodeShape.roundRectangle\n                    ? [0, 0]\n                    : [height / 2, height / 2];\n            if (isLeftLayout(nodeLayout)) {\n                //左\n                extendLineXOffset = [-width, -width - EXTEND_OFFSET * 2];\n                circleOffset = [-EXTEND_RADIUS / 2, 0];\n                arrowXOffset = [-10, -5.5, -5.5, -10];\n            }\n        } else {\n            arrowXOffset = [-4, 0.6, -1, 4];\n            if (isTopLayout(nodeLayout)) {\n                //上\n                extendLineXOffset = [-width / 2, -width / 2 - EXTEND_OFFSET];\n                extendLineYOffset = [-height / 2, -height / 2 - EXTEND_OFFSET];\n                arrowYOffset = [-10, -5.5, -5.5, -10];\n                circleOffset = [0, -EXTEND_RADIUS / 2];\n            } else {\n                //下\n                extendLineXOffset = [-width / 2, -width / 2 - EXTEND_OFFSET];\n                extendLineYOffset = [height / 2, height / 2 + EXTEND_OFFSET];\n                arrowYOffset = [10, 5.5, 5.5, 10];\n                circleOffset = [0, EXTEND_RADIUS / 2];\n            }\n        }\n\n        extendLineXY = [\n            [extendLineXY[0][0] + extendLineXOffset[0], extendLineXY[0][1] + extendLineYOffset[0]],\n            [extendLineXY[1][0] + extendLineXOffset[1], extendLineXY[1][1] + extendLineYOffset[1]]\n        ];\n\n        const extendLine = this.roughSVG.line(extendLineXY[0][0], extendLineXY[0][1], extendLineXY[1][0], extendLineXY[1][1], {\n            strokeWidth,\n            stroke\n        });\n\n        //绘制箭头\n        const hideArrowTopLine = this.roughSVG.line(\n            extendLineXY[1][0] + arrowXOffset[0],\n            extendLineXY[1][1] + arrowYOffset[0],\n            extendLineXY[1][0] + arrowXOffset[1],\n            extendLineXY[1][1] + arrowYOffset[1],\n            {\n                stroke,\n                strokeWidth: 2\n            }\n        );\n        const hideArrowBottomLine = this.roughSVG.line(\n            extendLineXY[1][0] + arrowXOffset[2],\n            extendLineXY[1][1] + arrowYOffset[2],\n            extendLineXY[1][0] + arrowXOffset[3],\n            extendLineXY[1][1] + arrowYOffset[3],\n            {\n                stroke,\n                strokeWidth: 2\n            }\n        );\n\n        if (this.node.origin.isCollapsed) {\n            const badge = this.roughSVG.circle(extendLineXY[1][0] + circleOffset[0], extendLineXY[1][1] + circleOffset[1], EXTEND_RADIUS, {\n                fill: stroke,\n                stroke,\n                fillStyle: 'solid'\n            });\n\n            let numberOffset = 0;\n            if (getChildrenCount(this.node.origin) >= 10) numberOffset = -2;\n            if (getChildrenCount(this.node.origin) === 1) numberOffset = 1;\n\n            const badgeText = createText(\n                extendLineXY[1][0] + circleOffset[0] - 4 + numberOffset,\n                extendLineXY[1][1] + circleOffset[1] + 4,\n                stroke,\n                `${getChildrenCount(this.node.origin)}`\n            );\n\n            this.g.classList.add('collapsed');\n            badge.setAttribute('style', 'opacity: 0.15');\n            badgeText.setAttribute('style', 'font-size: 12px');\n            collapseG.appendChild(badge);\n            collapseG.appendChild(badgeText);\n            collapseG.appendChild(extendLine);\n        } else {\n            this.g.classList.remove('collapsed');\n\n            if (this.node.origin.children.length > 0) {\n                const hideCircleG = this.roughSVG.circle(\n                    extendLineXY[1][0] + circleOffset[0],\n                    extendLineXY[1][1] + circleOffset[1],\n                    EXTEND_RADIUS - 1,\n                    {\n                        fill: '#fff',\n                        stroke,\n                        strokeWidth,\n                        fillStyle: 'solid'\n                    }\n                );\n                collapseG.appendChild(hideCircleG);\n                collapseG.appendChild(hideArrowTopLine);\n                collapseG.appendChild(hideArrowBottomLine);\n                this.drawQuickInsert(EXTEND_RADIUS);\n            } else {\n                this.drawQuickInsert();\n            }\n        }\n    }\n\n    destroyExtend() {\n        if (this.extendG) {\n            this.extendG.remove();\n        }\n    }\n\n    destroyRichtext() {\n        if (this.richtextG) {\n            this.richtextG.remove();\n        }\n        if (this.richtextComponentRef) {\n            this.richtextComponentRef.destroy();\n        }\n    }\n\n    updateAbstractIncludedOutline(resizingLocation?: number, handlePosition?: AbstractHandlePosition) {\n        this.abstractIncludedOutlineG?.remove();\n        this.abstractIncludedOutlineG = drawAbstractIncludedOutline(\n            this.board,\n            this.roughSVG,\n            this.element,\n            handlePosition,\n            resizingLocation\n        );\n        PlaitBoard.getHost(this.board).append(this.abstractIncludedOutlineG);\n    }\n\n    updateRichtext() {\n        updateRichText(this.node.origin.data.topic, this.richtextComponentRef!);\n        updateMindNodeTopicSize(this.node, this.richtextG as SVGGElement, this.isEditable);\n    }\n\n    startEditText(isEnd: boolean, isClear: boolean) {\n        if (!this.richtextComponentRef) {\n            throw new Error('undefined richtextComponentRef');\n        }\n        const richtextInstance = this.richtextComponentRef.instance;\n\n        this.isEditable = true;\n        IS_TEXT_EDITABLE.set(this.board, true);\n        this.disabledMaskG();\n        updateMindNodeTopicSize(this.node, this.richtextG as SVGGElement, this.isEditable);\n        if (richtextInstance.plaitReadonly) {\n            richtextInstance.plaitReadonly = false;\n            this.richtextComponentRef.changeDetectorRef.detectChanges();\n            this.drawActiveG();\n            const location = isEnd ? Editor.end(richtextInstance.editor, [0]) : [0];\n            setFullSelectionAndFocus(richtextInstance.editor, location);\n            if (isClear) {\n                Editor.deleteBackward(richtextInstance.editor);\n            }\n            // handle invalid width and height (old data)\n            let { width, height } = getRichtextContentSize(richtextInstance.editable);\n            if (width !== this.element.width || height !== this.element.height) {\n                MindTransforms.setTopicSize(this.board, this.element, width, height);\n            }\n        }\n        let richtext = richtextInstance.plaitValue;\n        // use debounceTime to wait DOM render complete\n        const valueChange$ = richtextInstance.plaitChange\n            .pipe(\n                debounceTime(0),\n                filter(event => {\n                    // 过滤掉 operations 中全是 set_selection 的操作\n                    return !event.operations.every(op => Operation.isSelectionOperation(op));\n                })\n            )\n            .subscribe(event => {\n                if (richtext === event.value) {\n                    return;\n                }\n                this.updateRichtext();\n                // 更新富文本、更新宽高\n                let { width, height } = getRichtextContentSize(richtextInstance.editable);\n                MindTransforms.setTopic(this.board, this.element, event.value, width, height);\n                MERGING.set(this.board, true);\n            });\n        const composition$ = richtextInstance.plaitComposition.pipe(debounceTime(0)).subscribe(event => {\n            let { width, height } = getRichtextContentSize(richtextInstance.editable);\n            if (width < NODE_MIN_WIDTH) {\n                width = NODE_MIN_WIDTH;\n            }\n            if (event.isComposing && (width !== this.node.origin.width || height !== this.node.origin.height)) {\n                const newElement: Partial<MindElement> = {\n                    width: width / this.board.viewport.zoom,\n                    height: height / this.board.viewport.zoom\n                };\n                const path = PlaitBoard.findPath(this.board, this.element);\n                Transforms.setNode(this.board, newElement, path);\n                MERGING.set(this.board, true);\n            }\n        });\n        const mousedown$ = fromEvent<MouseEvent>(document, 'mousedown').subscribe((event: MouseEvent) => {\n            const point = transformPoint(this.board, toPoint(event.x, event.y, PlaitBoard.getHost(this.board)));\n            const clickInNode = hitMindmapElement(this.board, point, this.element);\n            if (clickInNode && !hasEditableTarget(richtextInstance.editor, event.target)) {\n                event.preventDefault();\n            } else if (!clickInNode) {\n                // handle composition input state, like: Chinese IME Composition Input\n                timer(0).subscribe(() => {\n                    exitHandle();\n                    this.enableMaskG();\n                });\n            }\n        });\n        const editor = richtextInstance.editor;\n        const { keydown } = editor;\n        editor.keydown = (event: KeyboardEvent) => {\n            if (event.isComposing) {\n                return;\n            }\n            if (event.key === 'Escape') {\n                event.preventDefault();\n                event.stopPropagation();\n                exitHandle();\n                this.drawActiveG();\n                this.enableMaskG();\n                return;\n            }\n            if (event.key === 'Enter' && !event.shiftKey) {\n                event.preventDefault();\n                event.stopPropagation();\n                exitHandle();\n                this.drawActiveG();\n                this.enableMaskG();\n                return;\n            }\n            if (event.key === 'Tab') {\n                event.preventDefault();\n                event.stopPropagation();\n                exitHandle();\n                this.drawActiveG();\n                this.drawMaskG();\n            }\n        };\n        const exitHandle = () => {\n            // unsubscribe\n            valueChange$.unsubscribe();\n            composition$.unsubscribe();\n            mousedown$.unsubscribe();\n            editor.keydown = keydown; // reset keydown\n            // editable status\n            MERGING.set(this.board, false);\n            richtextInstance.plaitReadonly = true;\n            this.richtextComponentRef?.changeDetectorRef.markForCheck();\n            this.isEditable = false;\n            updateMindNodeTopicSize(this.node, this.richtextG as SVGGElement, this.isEditable);\n            IS_TEXT_EDITABLE.set(this.board, false);\n        };\n    }\n\n    trackBy = (index: number, node: MindmapNode) => {\n        return node.origin.id;\n    };\n\n    ngOnDestroy(): void {\n        super.ngOnDestroy();\n        this.abstractIncludedOutlineG?.remove();\n        this.destroyRichtext();\n        this.destroy$.next();\n        this.destroy$.complete();\n        if (ELEMENT_TO_NODE.get(this.element) === this.node) {\n            ELEMENT_TO_NODE.delete(this.element);\n        }\n        if (MINDMAP_ELEMENT_TO_COMPONENT.get(this.element) === this) {\n            MINDMAP_ELEMENT_TO_COMPONENT.delete(this.element);\n        }\n    }\n}\n"]}