@plait/mind 0.27.0-next.0 → 0.27.0-next.10

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 (162) hide show
  1. package/base/emoji-base.component.d.ts +2 -2
  2. package/base/index.d.ts +0 -1
  3. package/constants/default.d.ts +1 -0
  4. package/constants/node-topic-style.d.ts +4 -0
  5. package/drawer/{node-active.drawer.d.ts → node-active.generator.d.ts} +2 -2
  6. package/drawer/node-shape.generator.d.ts +10 -0
  7. package/esm2022/base/emoji-base.component.mjs +46 -0
  8. package/{esm2020 → esm2022}/base/index.mjs +1 -2
  9. package/{esm2020 → esm2022}/constants/abstract-node.mjs +1 -1
  10. package/{esm2020 → esm2022}/constants/default.mjs +2 -1
  11. package/{esm2020 → esm2022}/constants/index.mjs +1 -1
  12. package/esm2022/constants/node-topic-style.mjs +12 -0
  13. package/esm2022/drawer/node-active.generator.mjs +42 -0
  14. package/esm2022/drawer/node-shape.generator.mjs +19 -0
  15. package/esm2022/interfaces/element-data.mjs +2 -0
  16. package/esm2022/interfaces/element.mjs +118 -0
  17. package/{esm2020 → esm2022}/interfaces/index.mjs +2 -1
  18. package/esm2022/interfaces/options.mjs +2 -0
  19. package/{esm2020 → esm2022}/interfaces/theme-color.mjs +1 -1
  20. package/esm2022/mind-node.component.mjs +235 -0
  21. package/esm2022/mind.component.mjs +52 -0
  22. package/esm2022/plugins/with-abstract-resize.mjs +112 -0
  23. package/esm2022/plugins/with-mind-create.mjs +112 -0
  24. package/esm2022/plugins/with-mind-fragment.mjs +90 -0
  25. package/esm2022/plugins/with-mind-hotkey.mjs +67 -0
  26. package/esm2022/plugins/with-mind.mjs +91 -0
  27. package/esm2022/plugins/with-node-dnd.mjs +180 -0
  28. package/esm2022/plugins/with-node-image-resize.mjs +48 -0
  29. package/esm2022/plugins/with-node-image.mjs +98 -0
  30. package/esm2022/plugins/with-node-resize.mjs +133 -0
  31. package/{esm2020 → esm2022}/public-api.mjs +2 -3
  32. package/{esm2020 → esm2022}/transforms/image.mjs +1 -1
  33. package/esm2022/transforms/index.mjs +23 -0
  34. package/esm2022/transforms/node.mjs +66 -0
  35. package/{esm2020 → esm2022}/utils/abstract/common.mjs +2 -2
  36. package/{esm2020 → esm2022}/utils/abstract/resize.mjs +3 -3
  37. package/{esm2020 → esm2022}/utils/clipboard.mjs +3 -3
  38. package/{esm2020 → esm2022}/utils/dnd/common.mjs +1 -1
  39. package/esm2022/utils/draw/abstract-outline.mjs +117 -0
  40. package/esm2022/utils/draw/node-dnd.mjs +159 -0
  41. package/{esm2020 → esm2022}/utils/draw/node-shape.mjs +4 -3
  42. package/esm2022/utils/index.mjs +15 -0
  43. package/{esm2020 → esm2022}/utils/node/common.mjs +1 -1
  44. package/esm2022/utils/node/create-node.mjs +55 -0
  45. package/esm2022/utils/node/dynamic-width.mjs +19 -0
  46. package/esm2022/utils/node/image.mjs +23 -0
  47. package/esm2022/utils/position/image.mjs +36 -0
  48. package/esm2022/utils/position/node.mjs +36 -0
  49. package/esm2022/utils/position/topic.mjs +16 -0
  50. package/{esm2020 → esm2022}/utils/space/index.mjs +1 -1
  51. package/esm2022/utils/space/layout-options.mjs +69 -0
  52. package/esm2022/utils/space/node-space.mjs +137 -0
  53. package/{fesm2020 → fesm2022}/plait-mind.mjs +1383 -1569
  54. package/fesm2022/plait-mind.mjs.map +1 -0
  55. package/interfaces/element-data.d.ts +5 -9
  56. package/interfaces/element.d.ts +1 -0
  57. package/interfaces/index.d.ts +1 -0
  58. package/interfaces/options.d.ts +2 -4
  59. package/{node.component.d.ts → mind-node.component.d.ts} +11 -10
  60. package/mind.component.d.ts +2 -2
  61. package/package.json +7 -13
  62. package/plugins/with-mind-fragment.d.ts +5 -0
  63. package/plugins/with-mind-hotkey.d.ts +0 -6
  64. package/public-api.d.ts +1 -2
  65. package/styles/styles.scss +7 -3
  66. package/transforms/image.d.ts +3 -2
  67. package/transforms/index.d.ts +1 -2
  68. package/transforms/node.d.ts +0 -1
  69. package/utils/abstract/common.d.ts +2 -2
  70. package/utils/index.d.ts +0 -1
  71. package/utils/node/create-node.d.ts +2 -2
  72. package/utils/node/image.d.ts +0 -2
  73. package/utils/position/image.d.ts +1 -1
  74. package/utils/position/node.d.ts +1 -1
  75. package/utils/space/layout-options.d.ts +2 -2
  76. package/utils/space/node-space.d.ts +1 -5
  77. package/base/image-base.component.d.ts +0 -27
  78. package/constants/image.d.ts +0 -3
  79. package/drawer/node-image.drawer.d.ts +0 -15
  80. package/esm2020/base/emoji-base.component.mjs +0 -46
  81. package/esm2020/base/image-base.component.mjs +0 -67
  82. package/esm2020/constants/image.mjs +0 -4
  83. package/esm2020/constants/node-topic-style.mjs +0 -8
  84. package/esm2020/drawer/node-active.drawer.mjs +0 -44
  85. package/esm2020/drawer/node-image.drawer.mjs +0 -59
  86. package/esm2020/interfaces/element-data.mjs +0 -2
  87. package/esm2020/interfaces/element.mjs +0 -111
  88. package/esm2020/interfaces/options.mjs +0 -2
  89. package/esm2020/mind.component.mjs +0 -51
  90. package/esm2020/mind.module.mjs +0 -21
  91. package/esm2020/node.component.mjs +0 -248
  92. package/esm2020/plugins/with-abstract-resize.mjs +0 -112
  93. package/esm2020/plugins/with-mind-create.mjs +0 -109
  94. package/esm2020/plugins/with-mind-hotkey.mjs +0 -122
  95. package/esm2020/plugins/with-mind.mjs +0 -114
  96. package/esm2020/plugins/with-node-dnd.mjs +0 -180
  97. package/esm2020/plugins/with-node-image-resize.mjs +0 -48
  98. package/esm2020/plugins/with-node-image.mjs +0 -96
  99. package/esm2020/plugins/with-node-resize.mjs +0 -133
  100. package/esm2020/transforms/index.mjs +0 -24
  101. package/esm2020/transforms/node.mjs +0 -82
  102. package/esm2020/utils/draw/abstract-outline.mjs +0 -117
  103. package/esm2020/utils/draw/node-dnd.mjs +0 -159
  104. package/esm2020/utils/index.mjs +0 -16
  105. package/esm2020/utils/is-virtual-key.mjs +0 -13
  106. package/esm2020/utils/node/create-node.mjs +0 -52
  107. package/esm2020/utils/node/dynamic-width.mjs +0 -22
  108. package/esm2020/utils/node/image.mjs +0 -63
  109. package/esm2020/utils/position/image.mjs +0 -36
  110. package/esm2020/utils/position/node.mjs +0 -34
  111. package/esm2020/utils/position/topic.mjs +0 -17
  112. package/esm2020/utils/space/layout-options.mjs +0 -72
  113. package/esm2020/utils/space/node-space.mjs +0 -142
  114. package/fesm2015/plait-mind.mjs +0 -4402
  115. package/fesm2015/plait-mind.mjs.map +0 -1
  116. package/fesm2020/plait-mind.mjs.map +0 -1
  117. package/mind.module.d.ts +0 -11
  118. package/utils/is-virtual-key.d.ts +0 -1
  119. /package/{esm2020 → esm2022}/base/base.drawer.mjs +0 -0
  120. /package/{esm2020 → esm2022}/constants/node-style.mjs +0 -0
  121. /package/{esm2020 → esm2022}/constants/theme.mjs +0 -0
  122. /package/{esm2020 → esm2022}/drawer/node-collapse.drawer.mjs +0 -0
  123. /package/{esm2020 → esm2022}/drawer/node-emojis.drawer.mjs +0 -0
  124. /package/{esm2020 → esm2022}/drawer/node-insert.drawer.mjs +0 -0
  125. /package/{esm2020 → esm2022}/interfaces/layout.mjs +0 -0
  126. /package/{esm2020 → esm2022}/interfaces/node.mjs +0 -0
  127. /package/{esm2020 → esm2022}/interfaces/pointer.mjs +0 -0
  128. /package/{esm2020 → esm2022}/interfaces/types.mjs +0 -0
  129. /package/{esm2020 → esm2022}/plait-mind.mjs +0 -0
  130. /package/{esm2020 → esm2022}/plugins/with-abstract-resize.board.mjs +0 -0
  131. /package/{esm2020 → esm2022}/plugins/with-mind-extend.mjs +0 -0
  132. /package/{esm2020 → esm2022}/plugins/with-mind.board.mjs +0 -0
  133. /package/{esm2020 → esm2022}/plugins/with-node-hover-detect.mjs +0 -0
  134. /package/{esm2020 → esm2022}/queries/get-available-sublayouts-by-element.mjs +0 -0
  135. /package/{esm2020 → esm2022}/queries/get-branch-layouts.mjs +0 -0
  136. /package/{esm2020 → esm2022}/queries/get-correct-layout-by-element.mjs +0 -0
  137. /package/{esm2020 → esm2022}/queries/get-layout-by-element.mjs +0 -0
  138. /package/{esm2020 → esm2022}/queries/index.mjs +0 -0
  139. /package/{esm2020 → esm2022}/transforms/abstract-node.mjs +0 -0
  140. /package/{esm2020 → esm2022}/transforms/emoji.mjs +0 -0
  141. /package/{esm2020 → esm2022}/transforms/layout.mjs +0 -0
  142. /package/{esm2020 → esm2022}/utils/dnd/detector.mjs +0 -0
  143. /package/{esm2020 → esm2022}/utils/draw/node-link/abstract-link.mjs +0 -0
  144. /package/{esm2020 → esm2022}/utils/draw/node-link/draw-link.mjs +0 -0
  145. /package/{esm2020 → esm2022}/utils/draw/node-link/indented-link.mjs +0 -0
  146. /package/{esm2020 → esm2022}/utils/draw/node-link/logic-link.mjs +0 -0
  147. /package/{esm2020 → esm2022}/utils/layout.mjs +0 -0
  148. /package/{esm2020 → esm2022}/utils/mind.mjs +0 -0
  149. /package/{esm2020 → esm2022}/utils/node/adjust-node.mjs +0 -0
  150. /package/{esm2020 → esm2022}/utils/node/index.mjs +0 -0
  151. /package/{esm2020 → esm2022}/utils/node/right-node-count.mjs +0 -0
  152. /package/{esm2020 → esm2022}/utils/node-hover/extend.mjs +0 -0
  153. /package/{esm2020 → esm2022}/utils/node-style/branch.mjs +0 -0
  154. /package/{esm2020 → esm2022}/utils/node-style/common.mjs +0 -0
  155. /package/{esm2020 → esm2022}/utils/node-style/index.mjs +0 -0
  156. /package/{esm2020 → esm2022}/utils/node-style/shape.mjs +0 -0
  157. /package/{esm2020 → esm2022}/utils/path.mjs +0 -0
  158. /package/{esm2020 → esm2022}/utils/point-placement.mjs +0 -0
  159. /package/{esm2020 → esm2022}/utils/position/emoji.mjs +0 -0
  160. /package/{esm2020 → esm2022}/utils/position/index.mjs +0 -0
  161. /package/{esm2020 → esm2022}/utils/space/emoji.mjs +0 -0
  162. /package/{esm2020 → esm2022}/utils/weak-maps.mjs +0 -0
@@ -0,0 +1,235 @@
1
+ import { ChangeDetectionStrategy, Component } from '@angular/core';
2
+ import { createG, PlaitBoard, PlaitElement, NODE_TO_INDEX, RectangleClient, PlaitChildrenElementComponent } from '@plait/core';
3
+ import { isHorizontalLayout, AbstractNode } from '@plait/layouts';
4
+ import { TextManage, ExitOrigin } from '@plait/text';
5
+ import { Subject } from 'rxjs';
6
+ import { MindElement, PlaitMind } from './interfaces/element';
7
+ import { MindQueries } from './queries';
8
+ import { ELEMENT_TO_NODE } from './utils/weak-maps';
9
+ import { drawAbstractLink } from './utils/draw/node-link/abstract-link';
10
+ import { NodeEmojisDrawer } from './drawer/node-emojis.drawer';
11
+ import { MindTransforms } from './transforms';
12
+ import { NodeInsertDrawer } from './drawer/node-insert.drawer';
13
+ import { drawLink } from './utils/draw/node-link/draw-link';
14
+ import { getTopicRectangleByNode } from './utils/position/topic';
15
+ import { NodeActiveGenerator } from './drawer/node-active.generator';
16
+ import { CollapseDrawer } from './drawer/node-collapse.drawer';
17
+ import { NodeSpace } from './utils/space/node-space';
18
+ import { NodeTopicThreshold } from './constants/node-topic-style';
19
+ import { CommonPluginElement, ImageGenerator, WithTextPluginKey } from '@plait/common';
20
+ import { NodeShapeGenerator } from './drawer/node-shape.generator';
21
+ import { NgIf } from '@angular/common';
22
+ import { getImageForeignRectangle } from './utils';
23
+ import * as i0 from "@angular/core";
24
+ export class MindNodeComponent extends CommonPluginElement {
25
+ get textManage() {
26
+ return this.getTextManages()[0];
27
+ }
28
+ constructor(viewContainerRef, cdr) {
29
+ super(cdr);
30
+ this.viewContainerRef = viewContainerRef;
31
+ this.cdr = cdr;
32
+ this.shapeG = null;
33
+ this.destroy$ = new Subject();
34
+ this.trackBy = (index, node) => {
35
+ return node.origin.id;
36
+ };
37
+ }
38
+ initializeDrawer() {
39
+ this.nodeShapeGenerator = new NodeShapeGenerator(this.board);
40
+ this.nodeEmojisDrawer = new NodeEmojisDrawer(this.board, this.viewContainerRef);
41
+ this.nodeInsertDrawer = new NodeInsertDrawer(this.board);
42
+ this.activeGenerator = new NodeActiveGenerator(this.board);
43
+ this.collapseDrawer = new CollapseDrawer(this.board);
44
+ this.imageGenerator = new ImageGenerator(this.board, {
45
+ getRectangle: (element) => {
46
+ return getImageForeignRectangle(this.board, element);
47
+ },
48
+ getImageItem: (element) => {
49
+ return element.data.image;
50
+ }
51
+ });
52
+ const plugins = this.board.getPluginOptions(WithTextPluginKey).textPlugins;
53
+ const textManage = new TextManage(this.board, this.viewContainerRef, {
54
+ getRectangle: () => {
55
+ const rect = getTopicRectangleByNode(this.board, this.node);
56
+ return rect;
57
+ },
58
+ onValueChangeHandle: (textManageRef) => {
59
+ const width = textManageRef.width;
60
+ const height = textManageRef.height;
61
+ if (textManageRef.newValue) {
62
+ MindTransforms.setTopic(this.board, this.element, textManageRef.newValue, width, height);
63
+ }
64
+ else {
65
+ MindTransforms.setTopicSize(this.board, this.element, width, height);
66
+ }
67
+ },
68
+ textPlugins: plugins,
69
+ getMaxWidth: () => {
70
+ if (this.element.manualWidth) {
71
+ return NodeSpace.getNodeDynamicWidth(this.board, this.element);
72
+ }
73
+ else {
74
+ return Math.max(NodeSpace.getNodeDynamicWidth(this.board, this.element), NodeTopicThreshold.defaultTextMaxWidth);
75
+ }
76
+ }
77
+ });
78
+ this.initializeTextManages([textManage]);
79
+ }
80
+ ngOnInit() {
81
+ super.ngOnInit();
82
+ this.initializeDrawer();
83
+ this.node = MindElement.getNode(this.element);
84
+ this.index = NODE_TO_INDEX.get(this.element) || 0;
85
+ this.roughSVG = PlaitBoard.getRoughSVG(this.board);
86
+ this.parentG = PlaitElement.getComponent(MindElement.getRoot(this.board, this.element)).rootG;
87
+ this.nodeShapeGenerator.draw(this.element, this.g, { node: this.node });
88
+ this.drawLink();
89
+ this.drawTopic();
90
+ this.activeGenerator.draw(this.element, this.g, { selected: this.selected, isEditing: this.textManage.isEditing });
91
+ this.drawEmojis();
92
+ this.drawExtend();
93
+ this.imageGenerator.draw(this.element, this.g, this.viewContainerRef);
94
+ if (PlaitMind.isMind(this.context.parent)) {
95
+ this.g.classList.add('branch');
96
+ }
97
+ }
98
+ onContextChanged(value, previous) {
99
+ const newNode = MindElement.getNode(value.element);
100
+ const isEqualNode = RectangleClient.isEqual(this.node, newNode);
101
+ this.node = newNode;
102
+ const isChangeTheme = this.board.operations.find(op => op.type === 'set_theme');
103
+ if (!isEqualNode || value.element !== previous.element || isChangeTheme) {
104
+ this.activeGenerator.draw(this.element, this.g, { selected: this.selected, isEditing: this.textManage.isEditing });
105
+ this.nodeShapeGenerator.draw(this.element, this.g, { node: this.node });
106
+ this.drawLink();
107
+ this.drawEmojis();
108
+ this.drawExtend();
109
+ if (!MindElement.hasImage(previous.element) && MindElement.hasImage(this.element)) {
110
+ this.imageGenerator.draw(this.element, this.g, this.viewContainerRef);
111
+ }
112
+ if (MindElement.hasImage(previous.element) && MindElement.hasImage(this.element)) {
113
+ this.imageGenerator.updateImage(this.g, previous.element, value.element);
114
+ }
115
+ if (MindElement.hasImage(previous.element) && !MindElement.hasImage(this.element)) {
116
+ this.imageGenerator.destroy();
117
+ }
118
+ this.updateTopic();
119
+ }
120
+ else {
121
+ const hasSameSelected = value.selected === previous.selected;
122
+ const hasSameParent = value.parent === previous.parent;
123
+ if (!hasSameSelected) {
124
+ this.activeGenerator.draw(this.element, this.g, { selected: this.selected, isEditing: this.textManage.isEditing });
125
+ }
126
+ if (!hasSameParent) {
127
+ this.drawLink();
128
+ }
129
+ }
130
+ }
131
+ drawEmojis() {
132
+ const g = this.nodeEmojisDrawer.drawEmojis(this.element);
133
+ if (g) {
134
+ this.g.append(g);
135
+ }
136
+ }
137
+ drawLink() {
138
+ if (PlaitMind.isMind(this.element)) {
139
+ return;
140
+ }
141
+ const parent = MindElement.getParent(this.element);
142
+ const parentNode = MindElement.getNode(parent);
143
+ if (this.linkG) {
144
+ this.linkG.remove();
145
+ }
146
+ const layout = MindQueries.getLayoutByElement(parent);
147
+ if (AbstractNode.isAbstract(this.node.origin)) {
148
+ this.linkG = drawAbstractLink(this.board, this.node, isHorizontalLayout(layout));
149
+ }
150
+ else {
151
+ this.linkG = drawLink(this.board, parentNode, this.node, isHorizontalLayout(layout));
152
+ }
153
+ this.g.append(this.linkG);
154
+ }
155
+ destroyLine() {
156
+ if (this.linkG) {
157
+ this.linkG.remove();
158
+ }
159
+ }
160
+ drawExtend() {
161
+ this.destroyExtend();
162
+ this.extendG = createG();
163
+ this.extendG.classList.add('extend');
164
+ this.g.append(this.extendG);
165
+ if (this.element.isCollapsed) {
166
+ this.g.classList.add('collapsed');
167
+ }
168
+ else {
169
+ this.g.classList.remove('collapsed');
170
+ }
171
+ this.nodeInsertDrawer.draw(this.element, this.extendG);
172
+ this.collapseDrawer.draw(this.element, this.extendG);
173
+ }
174
+ destroyExtend() {
175
+ if (this.extendG) {
176
+ this.extendG.remove();
177
+ }
178
+ }
179
+ drawTopic() {
180
+ this.textManage.draw(this.element.data.topic);
181
+ this.g.append(this.textManage.g);
182
+ }
183
+ updateTopic() {
184
+ this.textManage.updateText(this.element.data.topic);
185
+ this.textManage.updateRectangle();
186
+ }
187
+ editTopic() {
188
+ this.activeGenerator.draw(this.element, this.g, { selected: this.selected, isEditing: true });
189
+ this.textManage.edit((origin) => {
190
+ if (origin === ExitOrigin.default) {
191
+ this.activeGenerator.draw(this.element, this.g, { selected: this.selected, isEditing: false });
192
+ }
193
+ });
194
+ }
195
+ ngOnDestroy() {
196
+ super.ngOnDestroy();
197
+ this.textManage.destroy();
198
+ this.nodeEmojisDrawer.destroy();
199
+ this.imageGenerator.destroy();
200
+ this.destroy$.next();
201
+ this.destroy$.complete();
202
+ if (ELEMENT_TO_NODE.get(this.element) === this.node) {
203
+ ELEMENT_TO_NODE.delete(this.element);
204
+ }
205
+ }
206
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: MindNodeComponent, deps: [{ token: i0.ViewContainerRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
207
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.3", type: MindNodeComponent, isStandalone: true, selector: "plait-mind-node", usesInheritance: true, ngImport: i0, template: `
208
+ <plait-children
209
+ *ngIf="!element.isCollapsed"
210
+ [board]="board"
211
+ [parent]="element"
212
+ [effect]="effect"
213
+ [parentG]="parentG"
214
+ ></plait-children>
215
+ `, isInline: true, dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: PlaitChildrenElementComponent, selector: "plait-children", inputs: ["board", "parent", "effect", "parentG"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
216
+ }
217
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: MindNodeComponent, decorators: [{
218
+ type: Component,
219
+ args: [{
220
+ selector: 'plait-mind-node',
221
+ template: `
222
+ <plait-children
223
+ *ngIf="!element.isCollapsed"
224
+ [board]="board"
225
+ [parent]="element"
226
+ [effect]="effect"
227
+ [parentG]="parentG"
228
+ ></plait-children>
229
+ `,
230
+ changeDetection: ChangeDetectionStrategy.OnPush,
231
+ standalone: true,
232
+ imports: [NgIf, PlaitChildrenElementComponent]
233
+ }]
234
+ }], ctorParameters: function () { return [{ type: i0.ViewContainerRef }, { type: i0.ChangeDetectorRef }]; } });
235
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mind-node.component.js","sourceRoot":"","sources":["../../../packages/mind/src/mind-node.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, ChangeDetectorRef, Component, OnDestroy, OnInit, ViewContainerRef } from '@angular/core';\nimport {\n    createG,\n    PlaitBoard,\n    PlaitElement,\n    NODE_TO_INDEX,\n    PlaitPluginElementContext,\n    OnContextChanged,\n    RectangleClient,\n    PlaitChildrenElementComponent\n} from '@plait/core';\nimport { isHorizontalLayout, AbstractNode, MindLayoutType } from '@plait/layouts';\nimport { TextManageRef, TextManage, ExitOrigin } from '@plait/text';\nimport { RoughSVG } from 'roughjs/bin/svg';\nimport { Subject } from 'rxjs';\nimport { MindElement, PlaitMind } from './interfaces/element';\nimport { MindNode } from './interfaces/node';\nimport { MindQueries } from './queries';\nimport { ELEMENT_TO_NODE } from './utils/weak-maps';\nimport { drawAbstractLink } from './utils/draw/node-link/abstract-link';\nimport { NodeEmojisDrawer } from './drawer/node-emojis.drawer';\nimport { MindTransforms } from './transforms';\nimport { NodeInsertDrawer } from './drawer/node-insert.drawer';\nimport { PlaitMindBoard } from './plugins/with-mind.board';\nimport { drawLink } from './utils/draw/node-link/draw-link';\nimport { getTopicRectangleByNode } from './utils/position/topic';\nimport { NodeActiveGenerator } from './drawer/node-active.generator';\nimport { CollapseDrawer } from './drawer/node-collapse.drawer';\nimport { NodeSpace } from './utils/space/node-space';\nimport { NodeTopicThreshold } from './constants/node-topic-style';\nimport { CommonPluginElement, ImageGenerator, WithTextOptions, WithTextPluginKey } from '@plait/common';\nimport { NodeShapeGenerator } from './drawer/node-shape.generator';\nimport { NgIf } from '@angular/common';\nimport { getImageForeignRectangle } from './utils';\nimport { ImageData } from './interfaces';\n\n@Component({\n    selector: 'plait-mind-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    standalone: true,\n    imports: [NgIf, PlaitChildrenElementComponent]\n})\nexport class MindNodeComponent extends CommonPluginElement<MindElement, PlaitMindBoard>\n    implements OnInit, OnDestroy, OnContextChanged<MindElement, PlaitMindBoard> {\n    roughSVG!: RoughSVG;\n\n    node!: MindNode;\n\n    index!: number;\n\n    parentG!: SVGGElement;\n\n    shapeG: SVGGElement | null = null;\n\n    linkG?: SVGGElement;\n\n    extendG?: SVGGElement;\n\n    destroy$ = new Subject<void>();\n\n    nodeEmojisDrawer!: NodeEmojisDrawer;\n\n    nodeShapeGenerator!: NodeShapeGenerator;\n\n    nodeInsertDrawer!: NodeInsertDrawer;\n\n    imageGenerator!: ImageGenerator<MindElement<ImageData>>;\n\n    activeGenerator!: NodeActiveGenerator;\n\n    collapseDrawer!: CollapseDrawer;\n\n    get textManage() {\n        return this.getTextManages()[0];\n    }\n\n    constructor(private viewContainerRef: ViewContainerRef, protected cdr: ChangeDetectorRef) {\n        super(cdr);\n    }\n\n    initializeDrawer() {\n        this.nodeShapeGenerator = new NodeShapeGenerator(this.board);\n        this.nodeEmojisDrawer = new NodeEmojisDrawer(this.board, this.viewContainerRef);\n        this.nodeInsertDrawer = new NodeInsertDrawer(this.board);\n        this.activeGenerator = new NodeActiveGenerator(this.board);\n        this.collapseDrawer = new CollapseDrawer(this.board);\n        this.imageGenerator = new ImageGenerator<MindElement<ImageData>>(this.board, {\n            getRectangle: (element: MindElement<ImageData>) => {\n                return getImageForeignRectangle(this.board as PlaitMindBoard, element);\n            },\n            getImageItem: (element: MindElement<ImageData>) => {\n                return element.data.image;\n            }\n        });\n        const plugins = this.board.getPluginOptions<WithTextOptions>(WithTextPluginKey).textPlugins;\n        const textManage = new TextManage(this.board, this.viewContainerRef, {\n            getRectangle: () => {\n                const rect = getTopicRectangleByNode(this.board, this.node);\n                return rect;\n            },\n            onValueChangeHandle: (textManageRef: TextManageRef) => {\n                const width = textManageRef.width;\n                const height = textManageRef.height;\n                if (textManageRef.newValue) {\n                    MindTransforms.setTopic(this.board, this.element, textManageRef.newValue as MindElement, width, height);\n                } else {\n                    MindTransforms.setTopicSize(this.board, this.element, width, height);\n                }\n            },\n            textPlugins: plugins,\n            getMaxWidth: () => {\n                if (this.element.manualWidth) {\n                    return NodeSpace.getNodeDynamicWidth(this.board, this.element);\n                } else {\n                    return Math.max(NodeSpace.getNodeDynamicWidth(this.board, this.element), NodeTopicThreshold.defaultTextMaxWidth);\n                }\n            }\n        });\n        this.initializeTextManages([textManage]);\n    }\n\n    ngOnInit(): void {\n        super.ngOnInit();\n        this.initializeDrawer();\n        this.node = MindElement.getNode(this.element);\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.nodeShapeGenerator.draw(this.element, this.g, { node: this.node });\n        this.drawLink();\n        this.drawTopic();\n        this.activeGenerator.draw(this.element, this.g, { selected: this.selected, isEditing: this.textManage.isEditing });\n        this.drawEmojis();\n        this.drawExtend();\n        this.imageGenerator.draw(this.element as MindElement<ImageData>, this.g, this.viewContainerRef);\n        if (PlaitMind.isMind(this.context.parent)) {\n            this.g.classList.add('branch');\n        }\n    }\n\n    onContextChanged(\n        value: PlaitPluginElementContext<MindElement, PlaitMindBoard>,\n        previous: PlaitPluginElementContext<MindElement, PlaitMindBoard>\n    ) {\n        const newNode = MindElement.getNode(value.element);\n        const isEqualNode = RectangleClient.isEqual(this.node, newNode);\n        this.node = newNode;\n        const isChangeTheme = this.board.operations.find(op => op.type === 'set_theme');\n        if (!isEqualNode || value.element !== previous.element || isChangeTheme) {\n            this.activeGenerator.draw(this.element, this.g, { selected: this.selected, isEditing: this.textManage.isEditing });\n            this.nodeShapeGenerator.draw(this.element, this.g, { node: this.node });\n            this.drawLink();\n            this.drawEmojis();\n            this.drawExtend();\n            if (!MindElement.hasImage(previous.element) && MindElement.hasImage(this.element)) {\n                this.imageGenerator.draw(this.element, this.g, this.viewContainerRef);\n            }\n            if (MindElement.hasImage(previous.element) && MindElement.hasImage(this.element)) {\n                this.imageGenerator.updateImage(\n                    this.g,\n                    previous.element as MindElement<ImageData>,\n                    value.element as MindElement<ImageData>\n                );\n            }\n            if (MindElement.hasImage(previous.element) && !MindElement.hasImage(this.element)) {\n                this.imageGenerator.destroy();\n            }\n            this.updateTopic();\n        } else {\n            const hasSameSelected = value.selected === previous.selected;\n            const hasSameParent = value.parent === previous.parent;\n            if (!hasSameSelected) {\n                this.activeGenerator.draw(this.element, this.g, { selected: this.selected, isEditing: this.textManage.isEditing });\n            }\n            if (!hasSameParent) {\n                this.drawLink();\n            }\n        }\n    }\n\n    drawEmojis() {\n        const g = this.nodeEmojisDrawer.drawEmojis(this.element);\n        if (g) {\n            this.g.append(g);\n        }\n    }\n\n    drawLink() {\n        if (PlaitMind.isMind(this.element)) {\n            return;\n        }\n\n        const parent = MindElement.getParent(this.element);\n        const parentNode = MindElement.getNode(parent);\n\n        if (this.linkG) {\n            this.linkG.remove();\n        }\n\n        const layout = MindQueries.getLayoutByElement(parent) as MindLayoutType;\n        if (AbstractNode.isAbstract(this.node.origin)) {\n            this.linkG = drawAbstractLink(this.board, this.node, isHorizontalLayout(layout));\n        } else {\n            this.linkG = drawLink(this.board, parentNode, this.node, isHorizontalLayout(layout));\n        }\n        this.g.append(this.linkG);\n    }\n\n    destroyLine() {\n        if (this.linkG) {\n            this.linkG.remove();\n        }\n    }\n\n    drawExtend() {\n        this.destroyExtend();\n\n        this.extendG = createG();\n        this.extendG.classList.add('extend');\n        this.g.append(this.extendG);\n\n        if (this.element.isCollapsed) {\n            this.g.classList.add('collapsed');\n        } else {\n            this.g.classList.remove('collapsed');\n        }\n\n        this.nodeInsertDrawer.draw(this.element, this.extendG!);\n        this.collapseDrawer.draw(this.element, this.extendG!);\n    }\n\n    destroyExtend() {\n        if (this.extendG) {\n            this.extendG.remove();\n        }\n    }\n\n    drawTopic() {\n        this.textManage.draw(this.element.data.topic);\n        this.g.append(this.textManage.g);\n    }\n\n    updateTopic() {\n        this.textManage.updateText(this.element.data.topic);\n        this.textManage.updateRectangle();\n    }\n\n    editTopic() {\n        this.activeGenerator.draw(this.element, this.g, { selected: this.selected, isEditing: true });\n        this.textManage.edit((origin: ExitOrigin) => {\n            if (origin === ExitOrigin.default) {\n                this.activeGenerator.draw(this.element, this.g, { selected: this.selected, isEditing: false });\n            }\n        });\n    }\n\n    trackBy = (index: number, node: MindNode) => {\n        return node.origin.id;\n    };\n\n    ngOnDestroy(): void {\n        super.ngOnDestroy();\n        this.textManage.destroy();\n        this.nodeEmojisDrawer.destroy();\n        this.imageGenerator.destroy();\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    }\n}\n"]}
@@ -0,0 +1,52 @@
1
+ import { ChangeDetectionStrategy, Component } from '@angular/core';
2
+ import { PlaitChildrenElementComponent, depthFirstRecursion } from '@plait/core';
3
+ import { GlobalLayout } from '@plait/layouts';
4
+ import { ELEMENT_TO_NODE } from './utils/weak-maps';
5
+ import { MindNodeComponent } from './mind-node.component';
6
+ import { getLayoutOptions } from './utils/space/layout-options';
7
+ import { getDefaultLayout } from './utils/layout';
8
+ import * as i0 from "@angular/core";
9
+ export class PlaitMindComponent extends MindNodeComponent {
10
+ ngOnInit() {
11
+ this.updateMindLayout();
12
+ super.ngOnInit();
13
+ this.g.classList.add('root');
14
+ }
15
+ beforeContextChange(value) {
16
+ if (value.element !== this.element && this.initialized) {
17
+ this.updateMindLayout(value.element);
18
+ }
19
+ }
20
+ updateMindLayout(element = this.element) {
21
+ const mindLayoutType = element.layout || getDefaultLayout();
22
+ this.root = GlobalLayout.layout(element, getLayoutOptions(this.board), mindLayoutType);
23
+ this.updateMindNodeLocation(element);
24
+ }
25
+ updateMindNodeLocation(element) {
26
+ const { x, y, hGap, vGap } = this.root;
27
+ const offsetX = x + hGap;
28
+ const offsetY = y + vGap;
29
+ depthFirstRecursion(this.root, node => {
30
+ node.x = node.x - offsetX + element.points[0][0];
31
+ node.y = node.y - offsetY + element.points[0][1];
32
+ ELEMENT_TO_NODE.set(node.origin, node);
33
+ });
34
+ }
35
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: PlaitMindComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
36
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.3", type: PlaitMindComponent, isStandalone: true, selector: "plait-mind", usesInheritance: true, ngImport: i0, template: `
37
+ <plait-children [board]="board" [parent]="element" [effect]="effect" [parentG]="rootG"></plait-children>
38
+ `, isInline: true, dependencies: [{ kind: "component", type: PlaitChildrenElementComponent, selector: "plait-children", inputs: ["board", "parent", "effect", "parentG"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
39
+ }
40
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: PlaitMindComponent, decorators: [{
41
+ type: Component,
42
+ args: [{
43
+ selector: 'plait-mind',
44
+ template: `
45
+ <plait-children [board]="board" [parent]="element" [effect]="effect" [parentG]="rootG"></plait-children>
46
+ `,
47
+ changeDetection: ChangeDetectionStrategy.OnPush,
48
+ standalone: true,
49
+ imports: [PlaitChildrenElementComponent, MindNodeComponent]
50
+ }]
51
+ }] });
52
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWluZC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9wYWNrYWdlcy9taW5kL3NyYy9taW5kLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFVLE1BQU0sZUFBZSxDQUFDO0FBRzNFLE9BQU8sRUFBdUIsNkJBQTZCLEVBQTZCLG1CQUFtQixFQUFFLE1BQU0sYUFBYSxDQUFDO0FBQ2pJLE9BQU8sRUFBRSxZQUFZLEVBQWMsTUFBTSxnQkFBZ0IsQ0FBQztBQUMxRCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFDcEQsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFDMUQsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFDaEUsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7O0FBV2xELE1BQU0sT0FBTyxrQkFBbUIsU0FBUSxpQkFBaUI7SUFLckQsUUFBUTtRQUNKLElBQUksQ0FBQyxnQkFBZ0IsRUFBRSxDQUFDO1FBQ3hCLEtBQUssQ0FBQyxRQUFRLEVBQUUsQ0FBQztRQUNqQixJQUFJLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDakMsQ0FBQztJQUVELG1CQUFtQixDQUFDLEtBQTJDO1FBQzNELElBQUksS0FBSyxDQUFDLE9BQU8sS0FBSyxJQUFJLENBQUMsT0FBTyxJQUFJLElBQUksQ0FBQyxXQUFXLEVBQUU7WUFDcEQsSUFBSSxDQUFDLGdCQUFnQixDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQztTQUN4QztJQUNMLENBQUM7SUFFRCxnQkFBZ0IsQ0FBQyxPQUFPLEdBQUcsSUFBSSxDQUFDLE9BQU87UUFDbkMsTUFBTSxjQUFjLEdBQUcsT0FBTyxDQUFDLE1BQU0sSUFBSSxnQkFBZ0IsRUFBRSxDQUFDO1FBQzVELElBQUksQ0FBQyxJQUFJLEdBQUksWUFBWSxDQUFDLE1BQU0sQ0FDM0IsT0FBaUMsRUFDbEMsZ0JBQWdCLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxFQUM1QixjQUFjLENBQ08sQ0FBQztRQUMxQixJQUFJLENBQUMsc0JBQXNCLENBQUMsT0FBb0IsQ0FBQyxDQUFDO0lBQ3RELENBQUM7SUFFRCxzQkFBc0IsQ0FBQyxPQUFrQjtRQUNyQyxNQUFNLEVBQUUsQ0FBQyxFQUFFLENBQUMsRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQztRQUN2QyxNQUFNLE9BQU8sR0FBRyxDQUFDLEdBQUcsSUFBSSxDQUFDO1FBQ3pCLE1BQU0sT0FBTyxHQUFHLENBQUMsR0FBRyxJQUFJLENBQUM7UUFDekIsbUJBQW1CLENBQVcsSUFBSSxDQUFDLElBQUksRUFBRSxJQUFJLENBQUMsRUFBRTtZQUM1QyxJQUFJLENBQUMsQ0FBQyxHQUFHLElBQUksQ0FBQyxDQUFDLEdBQUcsT0FBTyxHQUFHLE9BQU8sQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDakQsSUFBSSxDQUFDLENBQUMsR0FBRyxJQUFJLENBQUMsQ0FBQyxHQUFHLE9BQU8sR0FBRyxPQUFPLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBQ2pELGVBQWUsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLE1BQU0sRUFBRSxJQUFJLENBQUMsQ0FBQztRQUMzQyxDQUFDLENBQUMsQ0FBQztJQUNQLENBQUM7OEdBcENRLGtCQUFrQjtrR0FBbEIsa0JBQWtCLDZGQVBqQjs7S0FFVCw0REFHUyw2QkFBNkI7OzJGQUU5QixrQkFBa0I7a0JBVDlCLFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLFlBQVk7b0JBQ3RCLFFBQVEsRUFBRTs7S0FFVDtvQkFDRCxlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTtvQkFDL0MsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLE9BQU8sRUFBRSxDQUFDLDZCQUE2QixFQUFFLGlCQUFpQixDQUFDO2lCQUM5RCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgUGxhaXRNaW5kIH0gZnJvbSAnLi9pbnRlcmZhY2VzL2VsZW1lbnQnO1xuaW1wb3J0IHsgTWluZE5vZGUgfSBmcm9tICcuL2ludGVyZmFjZXMvbm9kZSc7XG5pbXBvcnQgeyBCZWZvcmVDb250ZXh0Q2hhbmdlLCBQbGFpdENoaWxkcmVuRWxlbWVudENvbXBvbmVudCwgUGxhaXRQbHVnaW5FbGVtZW50Q29udGV4dCwgZGVwdGhGaXJzdFJlY3Vyc2lvbiB9IGZyb20gJ0BwbGFpdC9jb3JlJztcbmltcG9ydCB7IEdsb2JhbExheW91dCwgT3JpZ2luTm9kZSB9IGZyb20gJ0BwbGFpdC9sYXlvdXRzJztcbmltcG9ydCB7IEVMRU1FTlRfVE9fTk9ERSB9IGZyb20gJy4vdXRpbHMvd2Vhay1tYXBzJztcbmltcG9ydCB7IE1pbmROb2RlQ29tcG9uZW50IH0gZnJvbSAnLi9taW5kLW5vZGUuY29tcG9uZW50JztcbmltcG9ydCB7IGdldExheW91dE9wdGlvbnMgfSBmcm9tICcuL3V0aWxzL3NwYWNlL2xheW91dC1vcHRpb25zJztcbmltcG9ydCB7IGdldERlZmF1bHRMYXlvdXQgfSBmcm9tICcuL3V0aWxzL2xheW91dCc7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAncGxhaXQtbWluZCcsXG4gICAgdGVtcGxhdGU6IGBcbiAgICAgICAgPHBsYWl0LWNoaWxkcmVuIFtib2FyZF09XCJib2FyZFwiIFtwYXJlbnRdPVwiZWxlbWVudFwiIFtlZmZlY3RdPVwiZWZmZWN0XCIgW3BhcmVudEddPVwicm9vdEdcIj48L3BsYWl0LWNoaWxkcmVuPlxuICAgIGAsXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICBpbXBvcnRzOiBbUGxhaXRDaGlsZHJlbkVsZW1lbnRDb21wb25lbnQsIE1pbmROb2RlQ29tcG9uZW50XVxufSlcbmV4cG9ydCBjbGFzcyBQbGFpdE1pbmRDb21wb25lbnQgZXh0ZW5kcyBNaW5kTm9kZUNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCwgQmVmb3JlQ29udGV4dENoYW5nZTxQbGFpdE1pbmQ+IHtcbiAgICByb290ITogTWluZE5vZGU7XG5cbiAgICByb290RyE6IFNWR0dFbGVtZW50O1xuXG4gICAgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgICAgIHRoaXMudXBkYXRlTWluZExheW91dCgpO1xuICAgICAgICBzdXBlci5uZ09uSW5pdCgpO1xuICAgICAgICB0aGlzLmcuY2xhc3NMaXN0LmFkZCgncm9vdCcpO1xuICAgIH1cblxuICAgIGJlZm9yZUNvbnRleHRDaGFuZ2UodmFsdWU6IFBsYWl0UGx1Z2luRWxlbWVudENvbnRleHQ8UGxhaXRNaW5kPikge1xuICAgICAgICBpZiAodmFsdWUuZWxlbWVudCAhPT0gdGhpcy5lbGVtZW50ICYmIHRoaXMuaW5pdGlhbGl6ZWQpIHtcbiAgICAgICAgICAgIHRoaXMudXBkYXRlTWluZExheW91dCh2YWx1ZS5lbGVtZW50KTtcbiAgICAgICAgfVxuICAgIH1cblxuICAgIHVwZGF0ZU1pbmRMYXlvdXQoZWxlbWVudCA9IHRoaXMuZWxlbWVudCkge1xuICAgICAgICBjb25zdCBtaW5kTGF5b3V0VHlwZSA9IGVsZW1lbnQubGF5b3V0IHx8IGdldERlZmF1bHRMYXlvdXQoKTtcbiAgICAgICAgdGhpcy5yb290ID0gKEdsb2JhbExheW91dC5sYXlvdXQoXG4gICAgICAgICAgICAoZWxlbWVudCBhcyB1bmtub3duKSBhcyBPcmlnaW5Ob2RlLFxuICAgICAgICAgICAgZ2V0TGF5b3V0T3B0aW9ucyh0aGlzLmJvYXJkKSxcbiAgICAgICAgICAgIG1pbmRMYXlvdXRUeXBlXG4gICAgICAgICkgYXMgdW5rbm93bikgYXMgTWluZE5vZGU7XG4gICAgICAgIHRoaXMudXBkYXRlTWluZE5vZGVMb2NhdGlvbihlbGVtZW50IGFzIFBsYWl0TWluZCk7XG4gICAgfVxuXG4gICAgdXBkYXRlTWluZE5vZGVMb2NhdGlvbihlbGVtZW50OiBQbGFpdE1pbmQpIHtcbiAgICAgICAgY29uc3QgeyB4LCB5LCBoR2FwLCB2R2FwIH0gPSB0aGlzLnJvb3Q7XG4gICAgICAgIGNvbnN0IG9mZnNldFggPSB4ICsgaEdhcDtcbiAgICAgICAgY29uc3Qgb2Zmc2V0WSA9IHkgKyB2R2FwO1xuICAgICAgICBkZXB0aEZpcnN0UmVjdXJzaW9uPE1pbmROb2RlPih0aGlzLnJvb3QsIG5vZGUgPT4ge1xuICAgICAgICAgICAgbm9kZS54ID0gbm9kZS54IC0gb2Zmc2V0WCArIGVsZW1lbnQucG9pbnRzWzBdWzBdO1xuICAgICAgICAgICAgbm9kZS55ID0gbm9kZS55IC0gb2Zmc2V0WSArIGVsZW1lbnQucG9pbnRzWzBdWzFdO1xuICAgICAgICAgICAgRUxFTUVOVF9UT19OT0RFLnNldChub2RlLm9yaWdpbiwgbm9kZSk7XG4gICAgICAgIH0pO1xuICAgIH1cbn1cbiJdfQ==
@@ -0,0 +1,112 @@
1
+ import { BOARD_TO_HOST, PlaitBoard, PlaitElement, Transforms, getSelectedElements, isMainPointer, toPoint, transformPoint } from '@plait/core';
2
+ import { AbstractNode, isHorizontalLayout, isStandardLayout } from '@plait/layouts';
3
+ import { MindElement } from '../interfaces';
4
+ import { findLocationLeftIndex, getHitAbstractHandle, getLocationScope, handleTouchedAbstract } from '../utils/abstract/resize';
5
+ import { separateChildren } from '../utils/abstract/common';
6
+ import { AbstractHandlePosition, AbstractResizeState } from './with-abstract-resize.board';
7
+ import { MindQueries } from '../queries';
8
+ export const withAbstract = (board) => {
9
+ const newBoard = board;
10
+ const { mousedown, mousemove, mouseup } = board;
11
+ let activeAbstractElement;
12
+ let abstractHandlePosition;
13
+ let touchedAbstract;
14
+ let startPoint;
15
+ let newProperty;
16
+ board.mousedown = (event) => {
17
+ if (!isMainPointer(event)) {
18
+ mousedown(event);
19
+ return;
20
+ }
21
+ const activeAbstractElements = getSelectedElements(board).filter(element => AbstractNode.isAbstract(element));
22
+ const host = BOARD_TO_HOST.get(board);
23
+ const point = transformPoint(board, toPoint(event.x, event.y, host));
24
+ activeAbstractElement = activeAbstractElements.find(element => {
25
+ abstractHandlePosition = getHitAbstractHandle(board, element, point);
26
+ return abstractHandlePosition;
27
+ });
28
+ if (activeAbstractElement) {
29
+ if (newBoard?.onAbstractResize) {
30
+ newBoard.onAbstractResize(AbstractResizeState.start);
31
+ }
32
+ startPoint = point;
33
+ return;
34
+ }
35
+ mousedown(event);
36
+ };
37
+ board.mousemove = (event) => {
38
+ getSelectedElements(board);
39
+ const host = BOARD_TO_HOST.get(board);
40
+ const endPoint = transformPoint(board, toPoint(event.x, event.y, host));
41
+ touchedAbstract = handleTouchedAbstract(board, touchedAbstract, endPoint);
42
+ if (abstractHandlePosition && activeAbstractElement) {
43
+ // prevent text from being selected
44
+ event.preventDefault();
45
+ const abstractComponent = PlaitElement.getComponent(activeAbstractElement);
46
+ const element = abstractComponent.element;
47
+ const nodeLayout = MindQueries.getCorrectLayoutByElement(board, activeAbstractElement);
48
+ const isHorizontal = isHorizontalLayout(nodeLayout);
49
+ const parentElement = MindElement.getParent(element);
50
+ let children = parentElement.children;
51
+ const parentLayout = MindQueries.getLayoutByElement(parentElement);
52
+ if (isStandardLayout(parentLayout)) {
53
+ const rightNodeCount = parentElement.rightNodeCount;
54
+ const { leftChildren, rightChildren } = separateChildren(parentElement);
55
+ if (activeAbstractElement.end < rightNodeCount) {
56
+ children = rightChildren;
57
+ }
58
+ if (activeAbstractElement.start >= rightNodeCount) {
59
+ children = leftChildren;
60
+ }
61
+ }
62
+ if (newBoard?.onAbstractResize) {
63
+ newBoard.onAbstractResize(AbstractResizeState.resizing);
64
+ }
65
+ const resizingLocation = isHorizontal ? endPoint[1] : endPoint[0];
66
+ const parent = MindElement.getNode(parentElement);
67
+ const scope = getLocationScope(board, abstractHandlePosition, children, element, parent, isHorizontal);
68
+ const location = Math.min(scope.max, Math.max(scope.min, resizingLocation));
69
+ let locationIndex = findLocationLeftIndex(board, children, location, isHorizontal);
70
+ const isPropertyUnchanged = (abstractHandlePosition === AbstractHandlePosition.start &&
71
+ locationIndex + 1 === activeAbstractElement.start) ||
72
+ (abstractHandlePosition === AbstractHandlePosition.end && locationIndex === activeAbstractElement.end);
73
+ if (isPropertyUnchanged) {
74
+ newProperty = undefined;
75
+ }
76
+ else {
77
+ if (isStandardLayout(parent.layout)) {
78
+ const rightNodeCount = parent.origin.rightNodeCount;
79
+ let start = element.start;
80
+ if (start >= rightNodeCount) {
81
+ locationIndex += rightNodeCount;
82
+ }
83
+ }
84
+ newProperty =
85
+ abstractHandlePosition === AbstractHandlePosition.start ? { start: locationIndex + 1 } : { end: locationIndex };
86
+ }
87
+ abstractComponent.activeGenerator.updateAbstractOutline(activeAbstractElement, abstractHandlePosition, location);
88
+ }
89
+ mousemove(event);
90
+ };
91
+ board.mouseup = (event) => {
92
+ startPoint = undefined;
93
+ abstractHandlePosition = undefined;
94
+ if (activeAbstractElement) {
95
+ if (newBoard?.onAbstractResize) {
96
+ newBoard.onAbstractResize(AbstractResizeState.end);
97
+ }
98
+ if (newProperty) {
99
+ const path = PlaitBoard.findPath(board, activeAbstractElement);
100
+ Transforms.setNode(board, newProperty, path);
101
+ }
102
+ else {
103
+ const abstractComponent = PlaitElement.getComponent(activeAbstractElement);
104
+ abstractComponent.activeGenerator.updateAbstractOutline(activeAbstractElement);
105
+ }
106
+ activeAbstractElement = undefined;
107
+ }
108
+ mouseup(event);
109
+ };
110
+ return board;
111
+ };
112
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-abstract-resize.js","sourceRoot":"","sources":["../../../../packages/mind/src/plugins/with-abstract-resize.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    BOARD_TO_HOST,\n    PlaitBoard,\n    PlaitElement,\n    PlaitPlugin,\n    Point,\n    Transforms,\n    getSelectedElements,\n    isMainPointer,\n    toPoint,\n    transformPoint\n} from '@plait/core';\nimport { AbstractNode, LayoutNode, MindLayoutType, isHorizontalLayout, isStandardLayout } from '@plait/layouts';\nimport { MindElement } from '../interfaces';\nimport { findLocationLeftIndex, getHitAbstractHandle, getLocationScope, handleTouchedAbstract } from '../utils/abstract/resize';\nimport { separateChildren } from '../utils/abstract/common';\nimport { AbstractHandlePosition, AbstractResizeState, PlaitAbstractBoard } from './with-abstract-resize.board';\nimport { MindQueries } from '../queries';\nimport { MindNodeComponent } from '../mind-node.component';\n\nexport const withAbstract: PlaitPlugin = (board: PlaitBoard) => {\n    const newBoard = board as PlaitBoard & PlaitAbstractBoard;\n\n    const { mousedown, mousemove, mouseup } = board;\n    let activeAbstractElement: MindElement | undefined;\n    let abstractHandlePosition: AbstractHandlePosition | undefined;\n    let touchedAbstract: MindElement | undefined;\n    let startPoint: Point | undefined;\n    let newProperty: { end: number } | { start: number } | undefined;\n\n    board.mousedown = (event: MouseEvent) => {\n        if (!isMainPointer(event)) {\n            mousedown(event);\n            return;\n        }\n\n        const activeAbstractElements = getSelectedElements(board).filter(element => AbstractNode.isAbstract(element)) as MindElement[];\n        const host = BOARD_TO_HOST.get(board);\n        const point = transformPoint(board, toPoint(event.x, event.y, host!));\n\n        activeAbstractElement = activeAbstractElements.find(element => {\n            abstractHandlePosition = getHitAbstractHandle(board, element as MindElement, point);\n            return abstractHandlePosition;\n        });\n\n        if (activeAbstractElement) {\n            if (newBoard?.onAbstractResize) {\n                newBoard.onAbstractResize(AbstractResizeState.start);\n            }\n            startPoint = point;\n            return;\n        }\n\n        mousedown(event);\n    };\n\n    board.mousemove = (event: MouseEvent) => {\n        getSelectedElements(board);\n        const host = BOARD_TO_HOST.get(board);\n        const endPoint = transformPoint(board, toPoint(event.x, event.y, host!));\n\n        touchedAbstract = handleTouchedAbstract(board, touchedAbstract, endPoint);\n\n        if (abstractHandlePosition && activeAbstractElement) {\n            // prevent text from being selected\n            event.preventDefault();\n            const abstractComponent = PlaitElement.getComponent(activeAbstractElement) as MindNodeComponent;\n            const element = abstractComponent.element;\n            const nodeLayout = MindQueries.getCorrectLayoutByElement(board, activeAbstractElement as MindElement) as MindLayoutType;\n            const isHorizontal = isHorizontalLayout(nodeLayout);\n            const parentElement = MindElement.getParent(element);\n\n            let children = parentElement.children;\n\n            const parentLayout = MindQueries.getLayoutByElement(parentElement);\n            if (isStandardLayout(parentLayout)) {\n                const rightNodeCount = parentElement.rightNodeCount!;\n                const { leftChildren, rightChildren } = separateChildren(parentElement);\n                if ((activeAbstractElement as MindElement).end! < rightNodeCount) {\n                    children = rightChildren;\n                }\n                if ((activeAbstractElement as MindElement).start! >= rightNodeCount) {\n                    children = leftChildren;\n                }\n            }\n\n            if (newBoard?.onAbstractResize) {\n                newBoard.onAbstractResize(AbstractResizeState.resizing);\n            }\n\n            const resizingLocation = isHorizontal ? endPoint[1] : endPoint[0];\n            const parent = (MindElement.getNode(parentElement) as unknown) as LayoutNode;\n            const scope = getLocationScope(board, abstractHandlePosition, children, element, parent, isHorizontal);\n            const location = Math.min(scope.max, Math.max(scope.min, resizingLocation));\n\n            let locationIndex = findLocationLeftIndex(board, children, location, isHorizontal);\n\n            const isPropertyUnchanged =\n                (abstractHandlePosition === AbstractHandlePosition.start &&\n                    locationIndex + 1 === (activeAbstractElement as MindElement).start!) ||\n                (abstractHandlePosition === AbstractHandlePosition.end && locationIndex === (activeAbstractElement as MindElement).end!);\n\n            if (isPropertyUnchanged) {\n                newProperty = undefined;\n            } else {\n                if (isStandardLayout(parent.layout)) {\n                    const rightNodeCount = parent.origin.rightNodeCount;\n                    let start = element.start!;\n                    if (start >= rightNodeCount) {\n                        locationIndex += rightNodeCount;\n                    }\n                }\n\n                newProperty =\n                    abstractHandlePosition === AbstractHandlePosition.start ? { start: locationIndex + 1 } : { end: locationIndex };\n            }\n\n            abstractComponent!.activeGenerator.updateAbstractOutline(activeAbstractElement, abstractHandlePosition, location);\n        }\n        mousemove(event);\n    };\n\n    board.mouseup = (event: MouseEvent) => {\n        startPoint = undefined;\n        abstractHandlePosition = undefined;\n        if (activeAbstractElement) {\n            if (newBoard?.onAbstractResize) {\n                newBoard.onAbstractResize(AbstractResizeState.end);\n            }\n\n            if (newProperty) {\n                const path = PlaitBoard.findPath(board, activeAbstractElement);\n                Transforms.setNode(board, newProperty, path);\n            } else {\n                const abstractComponent = PlaitElement.getComponent(activeAbstractElement) as MindNodeComponent;\n                abstractComponent!.activeGenerator.updateAbstractOutline(activeAbstractElement);\n            }\n            activeAbstractElement = undefined;\n        }\n        mouseup(event);\n    };\n    return board;\n};\n"]}
@@ -0,0 +1,112 @@
1
+ import { BoardTransforms, PlaitBoard, PlaitPointerType, Transforms, addSelectedElement, clearSelectedElement, createG, getSelectedElements, throttleRAF, toPoint, transformPoint } from '@plait/core';
2
+ import { MindPointerType } from '../interfaces/pointer';
3
+ import { getRectangleByElement, getTopicRectangleByElement } from '../utils';
4
+ import { drawRoundRectangleByElement } from '../utils/draw/node-shape';
5
+ import { NgZone } from '@angular/core';
6
+ import { TextManage } from '@plait/text';
7
+ import { createEmptyMind } from '../utils/node/create-node';
8
+ import { BoardCreationMode, isDndMode, isDrawingMode, setCreationMode } from '@plait/common';
9
+ const DefaultHotkey = 'm';
10
+ export const withCreateMind = (board) => {
11
+ const newBoard = board;
12
+ const { keydown, mousedown, mousemove, mouseup } = board;
13
+ let fakeCreateNodeRef = null;
14
+ let emptyMind = null;
15
+ newBoard.mousedown = (event) => {
16
+ const isMindPointer = PlaitBoard.isPointer(board, MindPointerType.mind);
17
+ let movingPoint = PlaitBoard.getMovingPointInBoard(board);
18
+ if (movingPoint && isDrawingMode(board) && isMindPointer) {
19
+ movingPoint = transformPoint(board, toPoint(movingPoint[0], movingPoint[1], PlaitBoard.getHost(board)));
20
+ const emptyMind = createEmptyMind(newBoard, movingPoint);
21
+ Transforms.insertNode(board, emptyMind, [board.children.length]);
22
+ clearSelectedElement(board);
23
+ addSelectedElement(board, emptyMind);
24
+ BoardTransforms.updatePointerType(board, PlaitPointerType.selection);
25
+ }
26
+ mousedown(event);
27
+ };
28
+ newBoard.mousemove = (event) => {
29
+ if (PlaitBoard.isReadonly(board)) {
30
+ mousemove(event);
31
+ return;
32
+ }
33
+ const isMindPointer = PlaitBoard.isPointer(board, MindPointerType.mind);
34
+ if (isDndMode(board) && isMindPointer) {
35
+ throttleRAF(() => {
36
+ let movingPoint = PlaitBoard.getMovingPointInBoard(board);
37
+ if (movingPoint) {
38
+ movingPoint = transformPoint(newBoard, toPoint(movingPoint[0], movingPoint[1], PlaitBoard.getHost(board)));
39
+ emptyMind = createEmptyMind(newBoard, movingPoint);
40
+ const nodeRectangle = getRectangleByElement(newBoard, emptyMind);
41
+ const nodeG = drawRoundRectangleByElement(board, nodeRectangle, emptyMind);
42
+ const topicRectangle = getTopicRectangleByElement(newBoard, nodeRectangle, emptyMind);
43
+ if (!fakeCreateNodeRef) {
44
+ const textManage = new TextManage(board, PlaitBoard.getComponent(board).viewContainerRef, {
45
+ getRectangle: () => {
46
+ return topicRectangle;
47
+ }
48
+ });
49
+ PlaitBoard.getComponent(board)
50
+ .viewContainerRef.injector.get(NgZone)
51
+ .run(() => {
52
+ textManage.draw(emptyMind.data.topic);
53
+ });
54
+ fakeCreateNodeRef = {
55
+ g: createG(),
56
+ nodeG,
57
+ textManage
58
+ };
59
+ fakeCreateNodeRef.g.classList.add('root');
60
+ fakeCreateNodeRef.g.setAttribute('plait-mind-temporary', 'true');
61
+ PlaitBoard.getHost(board).append(fakeCreateNodeRef.g);
62
+ fakeCreateNodeRef.g.append(...[fakeCreateNodeRef.nodeG, textManage.g]);
63
+ }
64
+ else {
65
+ fakeCreateNodeRef.textManage.updateRectangle(topicRectangle);
66
+ fakeCreateNodeRef.nodeG.remove();
67
+ fakeCreateNodeRef.nodeG = nodeG;
68
+ fakeCreateNodeRef.g.append(nodeG);
69
+ fakeCreateNodeRef.g.append(fakeCreateNodeRef.textManage.g);
70
+ }
71
+ }
72
+ });
73
+ }
74
+ else {
75
+ destroy();
76
+ }
77
+ mousemove(event);
78
+ };
79
+ newBoard.mouseup = (event) => {
80
+ if (emptyMind) {
81
+ Transforms.insertNode(board, emptyMind, [board.children.length]);
82
+ clearSelectedElement(board);
83
+ addSelectedElement(board, emptyMind);
84
+ BoardTransforms.updatePointerType(board, PlaitPointerType.selection);
85
+ emptyMind = null;
86
+ }
87
+ destroy();
88
+ mouseup(event);
89
+ };
90
+ board.keydown = (event) => {
91
+ if (PlaitBoard.isReadonly(board) || getSelectedElements(board).length > 0) {
92
+ keydown(event);
93
+ return;
94
+ }
95
+ if (event.key === DefaultHotkey && !PlaitBoard.isPointer(board, MindPointerType.mind)) {
96
+ BoardTransforms.updatePointerType(board, MindPointerType.mind);
97
+ setCreationMode(board, BoardCreationMode.drawing);
98
+ event.preventDefault();
99
+ return;
100
+ }
101
+ keydown(event);
102
+ };
103
+ function destroy() {
104
+ if (fakeCreateNodeRef) {
105
+ fakeCreateNodeRef.textManage.destroy();
106
+ fakeCreateNodeRef.g.remove();
107
+ fakeCreateNodeRef = null;
108
+ }
109
+ }
110
+ return newBoard;
111
+ };
112
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-mind-create.js","sourceRoot":"","sources":["../../../../packages/mind/src/plugins/with-mind-create.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    BoardTransforms,\n    PlaitBoard,\n    PlaitPointerType,\n    Transforms,\n    addSelectedElement,\n    clearSelectedElement,\n    createG,\n    getSelectedElements,\n    throttleRAF,\n    toPoint,\n    transformPoint\n} from '@plait/core';\nimport { PlaitMindBoard } from './with-mind.board';\nimport { MindPointerType } from '../interfaces/pointer';\nimport { getRectangleByElement, getTopicRectangleByElement } from '../utils';\nimport { drawRoundRectangleByElement } from '../utils/draw/node-shape';\nimport { NgZone } from '@angular/core';\nimport { TextManage } from '@plait/text';\nimport { createEmptyMind } from '../utils/node/create-node';\nimport { MindElement } from '../interfaces';\nimport { BoardCreationMode, isDndMode, isDrawingMode, setCreationMode } from '@plait/common';\n\nconst DefaultHotkey = 'm';\n\nexport interface FakeCreateNodeRef {\n    g: SVGGElement;\n    nodeG: SVGGElement;\n    textManage: TextManage;\n}\n\nexport const withCreateMind = (board: PlaitBoard) => {\n    const newBoard = board as PlaitBoard & PlaitMindBoard;\n    const { keydown, mousedown, mousemove, mouseup } = board;\n    let fakeCreateNodeRef: FakeCreateNodeRef | null = null;\n    let emptyMind: MindElement | null = null;\n\n    newBoard.mousedown = (event: MouseEvent) => {\n        const isMindPointer = PlaitBoard.isPointer<MindPointerType | PlaitPointerType>(board, MindPointerType.mind);\n        let movingPoint = PlaitBoard.getMovingPointInBoard(board);\n        if (movingPoint && isDrawingMode(board) && isMindPointer) {\n            movingPoint = transformPoint(board, toPoint(movingPoint[0], movingPoint[1], PlaitBoard.getHost(board)));\n            const emptyMind = createEmptyMind(newBoard, movingPoint);\n            Transforms.insertNode(board, emptyMind, [board.children.length]);\n            clearSelectedElement(board);\n            addSelectedElement(board, emptyMind);\n            BoardTransforms.updatePointerType(board, PlaitPointerType.selection);\n        }\n        mousedown(event);\n    };\n\n    newBoard.mousemove = (event: MouseEvent) => {\n        if (PlaitBoard.isReadonly(board)) {\n            mousemove(event);\n            return;\n        }\n        const isMindPointer = PlaitBoard.isPointer<MindPointerType | PlaitPointerType>(board, MindPointerType.mind);\n        if (isDndMode(board) && isMindPointer) {\n            throttleRAF(() => {\n                let movingPoint = PlaitBoard.getMovingPointInBoard(board);\n\n                if (movingPoint) {\n                    movingPoint = transformPoint(newBoard, toPoint(movingPoint[0], movingPoint[1], PlaitBoard.getHost(board)));\n                    emptyMind = createEmptyMind(newBoard, movingPoint);\n                    const nodeRectangle = getRectangleByElement(newBoard, emptyMind);\n                    const nodeG = drawRoundRectangleByElement(board, nodeRectangle, emptyMind);\n                    const topicRectangle = getTopicRectangleByElement(newBoard, nodeRectangle, emptyMind);\n                    if (!fakeCreateNodeRef) {\n                        const textManage = new TextManage(board, PlaitBoard.getComponent(board).viewContainerRef, {\n                            getRectangle: () => {\n                                return topicRectangle;\n                            }\n                        });\n                        PlaitBoard.getComponent(board)\n                            .viewContainerRef.injector.get(NgZone)\n                            .run(() => {\n                                textManage.draw(emptyMind!.data.topic);\n                            });\n                        fakeCreateNodeRef = {\n                            g: createG(),\n                            nodeG,\n                            textManage\n                        };\n                        fakeCreateNodeRef.g.classList.add('root');\n                        fakeCreateNodeRef.g.setAttribute('plait-mind-temporary', 'true');\n                        PlaitBoard.getHost(board).append(fakeCreateNodeRef.g);\n                        fakeCreateNodeRef.g.append(...[fakeCreateNodeRef.nodeG, textManage.g]);\n                    } else {\n                        fakeCreateNodeRef.textManage.updateRectangle(topicRectangle);\n                        fakeCreateNodeRef.nodeG.remove();\n                        fakeCreateNodeRef.nodeG = nodeG;\n                        fakeCreateNodeRef.g.append(nodeG);\n                        fakeCreateNodeRef.g.append(fakeCreateNodeRef.textManage.g);\n                    }\n                }\n            });\n        } else {\n            destroy();\n        }\n        mousemove(event);\n    };\n\n    newBoard.mouseup = (event: MouseEvent) => {\n        if (emptyMind) {\n            Transforms.insertNode(board, emptyMind, [board.children.length]);\n            clearSelectedElement(board);\n            addSelectedElement(board, emptyMind);\n            BoardTransforms.updatePointerType(board, PlaitPointerType.selection);\n            emptyMind = null;\n        }\n        destroy();\n        mouseup(event);\n    };\n\n    board.keydown = (event: KeyboardEvent) => {\n        if (PlaitBoard.isReadonly(board) || getSelectedElements(board).length > 0) {\n            keydown(event);\n            return;\n        }\n        if (event.key === DefaultHotkey && !PlaitBoard.isPointer(board, MindPointerType.mind)) {\n            BoardTransforms.updatePointerType(board, MindPointerType.mind);\n            setCreationMode(board, BoardCreationMode.drawing);\n            event.preventDefault();\n            return;\n        }\n        keydown(event);\n    };\n\n    function destroy() {\n        if (fakeCreateNodeRef) {\n            fakeCreateNodeRef.textManage.destroy();\n            fakeCreateNodeRef.g.remove();\n            fakeCreateNodeRef = null;\n        }\n    }\n\n    return newBoard;\n};\n"]}