@plait/mind 0.27.0-next.3 → 0.27.0-next.5

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 (36) hide show
  1. package/base/emoji-base.component.d.ts +1 -1
  2. package/esm2022/base/emoji-base.component.mjs +5 -5
  3. package/esm2022/interfaces/element.mjs +1 -1
  4. package/esm2022/interfaces/options.mjs +1 -1
  5. package/esm2022/mind-node.component.mjs +234 -0
  6. package/esm2022/mind.component.mjs +2 -2
  7. package/esm2022/mind.module.mjs +2 -2
  8. package/esm2022/plugins/with-mind-fragment.mjs +90 -0
  9. package/esm2022/plugins/with-mind-hotkey.mjs +13 -55
  10. package/esm2022/plugins/with-mind.mjs +7 -36
  11. package/esm2022/plugins/with-node-dnd.mjs +3 -3
  12. package/esm2022/plugins/with-node-resize.mjs +2 -2
  13. package/esm2022/public-api.mjs +2 -2
  14. package/esm2022/transforms/index.mjs +2 -3
  15. package/esm2022/transforms/node.mjs +2 -18
  16. package/esm2022/utils/abstract/resize.mjs +1 -1
  17. package/esm2022/utils/dnd/common.mjs +1 -1
  18. package/esm2022/utils/draw/node-dnd.mjs +1 -1
  19. package/esm2022/utils/node/common.mjs +1 -1
  20. package/esm2022/utils/node/dynamic-width.mjs +2 -5
  21. package/esm2022/utils/node/image.mjs +1 -1
  22. package/esm2022/utils/position/topic.mjs +2 -3
  23. package/fesm2022/plait-mind.mjs +208 -234
  24. package/fesm2022/plait-mind.mjs.map +1 -1
  25. package/interfaces/options.d.ts +0 -2
  26. package/mind.component.d.ts +1 -1
  27. package/mind.module.d.ts +1 -1
  28. package/package.json +1 -1
  29. package/plugins/with-mind-fragment.d.ts +5 -0
  30. package/plugins/with-mind-hotkey.d.ts +0 -2
  31. package/public-api.d.ts +1 -1
  32. package/styles/styles.scss +0 -3
  33. package/transforms/index.d.ts +0 -1
  34. package/transforms/node.d.ts +0 -1
  35. package/esm2022/node.component.mjs +0 -251
  36. /package/{node.component.d.ts → mind-node.component.d.ts} +0 -0
@@ -1,9 +1,7 @@
1
1
  import { ComponentType, WithPluginOptions } from '@plait/core';
2
- import { TextPlugin } from '@plait/text';
3
2
  import { MindImageBaseComponent } from '../base';
4
3
  export interface WithMindOptions extends WithPluginOptions {
5
4
  emojiPadding: number;
6
5
  spaceBetweenEmojis: number;
7
- textPlugins?: TextPlugin[];
8
6
  imageComponentType?: ComponentType<MindImageBaseComponent>;
9
7
  }
@@ -2,7 +2,7 @@ import { OnInit } from '@angular/core';
2
2
  import { PlaitMind } from './interfaces/element';
3
3
  import { MindNode } from './interfaces/node';
4
4
  import { BeforeContextChange, PlaitPluginElementContext } from '@plait/core';
5
- import { MindNodeComponent } from './node.component';
5
+ import { MindNodeComponent } from './mind-node.component';
6
6
  import * as i0 from "@angular/core";
7
7
  export declare class PlaitMindComponent extends MindNodeComponent implements OnInit, BeforeContextChange<PlaitMind> {
8
8
  root: MindNode;
package/mind.module.d.ts CHANGED
@@ -1,6 +1,6 @@
1
1
  import * as i0 from "@angular/core";
2
2
  import * as i1 from "./mind.component";
3
- import * as i2 from "./node.component";
3
+ import * as i2 from "./mind-node.component";
4
4
  import * as i3 from "@angular/common";
5
5
  import * as i4 from "@plait/text";
6
6
  import * as i5 from "@plait/core";
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@plait/mind",
3
- "version": "0.27.0-next.3",
3
+ "version": "0.27.0-next.5",
4
4
  "peerDependencies": {
5
5
  "@angular/common": "^16.0.0",
6
6
  "@angular/core": "^16.0.0"
@@ -0,0 +1,5 @@
1
+ import { PlaitBoard } from '@plait/core';
2
+ import { MindElement } from '../interfaces';
3
+ import { PlaitMindBoard } from './with-mind.board';
4
+ export declare const withMindFragment: (baseBoard: PlaitBoard) => PlaitBoard & PlaitMindBoard;
5
+ export declare const getNextSelectedElement: (board: PlaitBoard, firstLevelElements: MindElement[]) => MindElement<import("../interfaces").BaseData> | undefined;
@@ -1,5 +1,3 @@
1
1
  import { PlaitBoard } from '@plait/core';
2
- import { MindElement } from '../interfaces';
3
2
  import { PlaitMindBoard } from './with-mind.board';
4
3
  export declare const withMindHotkey: (baseBoard: PlaitBoard) => PlaitBoard & PlaitMindBoard;
5
- export declare const getNextSelectedElement: (board: PlaitBoard, firstLevelElements: MindElement[]) => MindElement<import("../interfaces").BaseData> | undefined;
package/public-api.d.ts CHANGED
@@ -1,5 +1,5 @@
1
1
  export * from './mind.component';
2
- export * from './node.component';
2
+ export * from './mind-node.component';
3
3
  export * from './mind.module';
4
4
  export * from './utils';
5
5
  export * from './interfaces';
@@ -22,9 +22,6 @@ $primary: #4e8afa;
22
22
  }
23
23
  .slate-editable-container {
24
24
  min-width: 5px;
25
- &.editing {
26
- max-width: 34em;
27
- }
28
25
  }
29
26
 
30
27
  .extend {
@@ -9,7 +9,6 @@ export declare const MindTransforms: {
9
9
  insertAbstract: (board: import("@plait/core").PlaitBoard, elements: import("@plait/core").PlaitElement[]) => void;
10
10
  setAbstractsByRefs: (board: import("@plait/core").PlaitBoard, abstractRefs: import("@plait/mind").AbstractRefs) => void;
11
11
  setAbstractByStandardLayout: (board: import("@plait/core").PlaitBoard, element: import("@plait/mind").MindElement<import("@plait/mind").BaseData>) => void;
12
- removeElements: (board: import("@plait/core").PlaitBoard, elements: import("@plait/mind").MindElement<import("@plait/mind").BaseData>[]) => void;
13
12
  insertNodes: (board: import("@plait/core").PlaitBoard, elements: import("@plait/mind").MindElement<import("@plait/mind").BaseData>[], path: import("slate").Path) => void;
14
13
  insertAbstractNodes: (board: import("@plait/core").PlaitBoard, validAbstractRefs: import("@plait/mind").AbstractRef[], elements: import("@plait/mind").MindElement<import("@plait/mind").BaseData>[], path: import("slate").Path) => void;
15
14
  setRightNodeCountByRefs: (board: import("@plait/core").PlaitBoard, refs: import("@plait/mind").RightNodeCountRef[]) => void;
@@ -7,7 +7,6 @@ import { PlaitMindBoard } from '../plugins/with-mind.board';
7
7
  export declare const setTopic: (board: PlaitMindBoard, element: MindElement, topic: Element, width: number, height: number) => void;
8
8
  export declare const setNodeManualWidth: (board: PlaitMindBoard, element: MindElement, width: number, height: number) => void;
9
9
  export declare const setTopicSize: (board: PlaitMindBoard, element: MindElement, width: number, height: number) => void;
10
- export declare const removeElements: (board: PlaitBoard, elements: MindElement[]) => void;
11
10
  export declare const insertNodes: (board: PlaitBoard, elements: MindElement[], path: Path) => void;
12
11
  export declare const insertAbstractNodes: (board: PlaitBoard, validAbstractRefs: AbstractRef[], elements: MindElement[], path: Path) => void;
13
12
  export declare const setRightNodeCountByRefs: (board: PlaitBoard, refs: RightNodeCountRef[]) => void;
@@ -1,251 +0,0 @@
1
- import { ChangeDetectionStrategy, Component } from '@angular/core';
2
- import { createG, PlaitBoard, PlaitPluginElementComponent, PlaitElement, NODE_TO_INDEX, RectangleClient } from '@plait/core';
3
- import { isHorizontalLayout, AbstractNode } from '@plait/layouts';
4
- import { TextManage, ExitOrigin } from '@plait/text';
5
- import { Subject } from 'rxjs';
6
- import { drawRoundRectangleByNode } from './utils/draw/node-shape';
7
- import { MindElement, PlaitMind } from './interfaces/element';
8
- import { MindQueries } from './queries';
9
- import { getShapeByElement } from './utils/node-style/shape';
10
- import { ELEMENT_TO_NODE } from './utils/weak-maps';
11
- import { drawAbstractLink } from './utils/draw/node-link/abstract-link';
12
- import { NodeEmojisDrawer } from './drawer/node-emojis.drawer';
13
- import { MindTransforms } from './transforms';
14
- import { MindElementShape } from './interfaces';
15
- import { NodeInsertDrawer } from './drawer/node-insert.drawer';
16
- import { drawLink } from './utils/draw/node-link/draw-link';
17
- import { getTopicRectangleByNode } from './utils/position/topic';
18
- import { NodeActiveDrawer } from './drawer/node-active.drawer';
19
- import { CollapseDrawer } from './drawer/node-collapse.drawer';
20
- import { WithMindPluginKey } from './constants/default';
21
- import { NodeImageDrawer } from './drawer/node-image.drawer';
22
- import { NodeSpace } from './utils/space/node-space';
23
- import { NodeTopicThreshold, ROOT_TOPIC_FONT_SIZE, TOPIC_DEFAULT_MAX_WORD_COUNT, TOPIC_FONT_SIZE } from './constants/node-topic-style';
24
- import * as i0 from "@angular/core";
25
- import * as i1 from "@angular/common";
26
- import * as i2 from "@plait/core";
27
- // 1. When the text at the end has an italic attribute, the text is partially covered
28
- // 2. There will be some differences in the width measured by different browsers
29
- const WIDTH_BUFFER = 4;
30
- export class MindNodeComponent extends PlaitPluginElementComponent {
31
- constructor(viewContainerRef, cdr) {
32
- super(cdr);
33
- this.viewContainerRef = viewContainerRef;
34
- this.cdr = cdr;
35
- this.shapeG = null;
36
- this.destroy$ = new Subject();
37
- this.trackBy = (index, node) => {
38
- return node.origin.id;
39
- };
40
- }
41
- initializeDrawer() {
42
- this.nodeEmojisDrawer = new NodeEmojisDrawer(this.board, this.viewContainerRef);
43
- this.nodeInsertDrawer = new NodeInsertDrawer(this.board);
44
- this.activeDrawer = new NodeActiveDrawer(this.board);
45
- this.collapseDrawer = new CollapseDrawer(this.board);
46
- this.imageDrawer = new NodeImageDrawer(this.board, this.viewContainerRef);
47
- const plugins = this.board.getPluginOptions(WithMindPluginKey).textPlugins;
48
- this.textManage = new TextManage(this.board, this.viewContainerRef, {
49
- getRectangle: () => {
50
- const rect = getTopicRectangleByNode(this.board, this.node);
51
- return rect;
52
- },
53
- onValueChangeHandle: (textManageRef) => {
54
- const width = textManageRef.width;
55
- const height = textManageRef.height;
56
- if (textManageRef.newValue) {
57
- MindTransforms.setTopic(this.board, this.element, textManageRef.newValue, width, height);
58
- }
59
- else {
60
- MindTransforms.setTopicSize(this.board, this.element, width, height);
61
- }
62
- },
63
- textPlugins: plugins,
64
- getMaxWidth: () => {
65
- return NodeTopicThreshold.defaultTextMaxWidth;
66
- }
67
- });
68
- }
69
- ngOnInit() {
70
- super.ngOnInit();
71
- this.initializeDrawer();
72
- this.node = MindElement.getNode(this.element);
73
- this.index = NODE_TO_INDEX.get(this.element) || 0;
74
- this.roughSVG = PlaitBoard.getRoughSVG(this.board);
75
- this.parentG = PlaitElement.getComponent(MindElement.getRoot(this.board, this.element)).rootG;
76
- this.drawShape();
77
- this.drawLink();
78
- this.drawTopic();
79
- this.activeDrawer.draw(this.element, this.g, { selected: this.selected, isEditing: this.textManage.isEditing });
80
- this.drawEmojis();
81
- this.drawExtend();
82
- this.imageDrawer.drawImage(this.g, this.element);
83
- if (PlaitMind.isMind(this.context.parent)) {
84
- this.g.classList.add('branch');
85
- }
86
- }
87
- onContextChanged(value, previous) {
88
- const newNode = MindElement.getNode(value.element);
89
- const isEqualNode = RectangleClient.isEqual(this.node, newNode);
90
- this.node = newNode;
91
- const isChangeTheme = this.board.operations.find(op => op.type === 'set_theme');
92
- if (!isEqualNode || value.element !== previous.element || isChangeTheme) {
93
- this.activeDrawer.draw(this.element, this.g, { selected: this.selected, isEditing: this.textManage.isEditing });
94
- this.drawShape();
95
- this.drawLink();
96
- this.drawEmojis();
97
- this.drawExtend();
98
- this.imageDrawer.updateImage(this.g, previous.element, value.element);
99
- this.updateTopic();
100
- }
101
- else {
102
- const hasSameSelected = value.selected === previous.selected;
103
- const hasSameParent = value.parent === previous.parent;
104
- if (!hasSameSelected) {
105
- this.activeDrawer.draw(this.element, this.g, { selected: this.selected, isEditing: this.textManage.isEditing });
106
- }
107
- if (!hasSameParent) {
108
- this.drawLink();
109
- }
110
- }
111
- }
112
- drawEmojis() {
113
- const g = this.nodeEmojisDrawer.drawEmojis(this.element);
114
- if (g) {
115
- this.g.append(g);
116
- }
117
- }
118
- drawShape() {
119
- this.destroyShape();
120
- const shape = getShapeByElement(this.board, this.node.origin);
121
- switch (shape) {
122
- case MindElementShape.roundRectangle:
123
- this.shapeG = drawRoundRectangleByNode(this.board, this.node);
124
- this.g.prepend(this.shapeG);
125
- break;
126
- default:
127
- break;
128
- }
129
- }
130
- destroyShape() {
131
- if (this.shapeG) {
132
- this.shapeG.remove();
133
- this.shapeG = null;
134
- }
135
- }
136
- drawLink() {
137
- if (PlaitMind.isMind(this.element)) {
138
- return;
139
- }
140
- const parent = MindElement.getParent(this.element);
141
- const parentNode = MindElement.getNode(parent);
142
- if (this.linkG) {
143
- this.linkG.remove();
144
- }
145
- const layout = MindQueries.getLayoutByElement(parent);
146
- if (AbstractNode.isAbstract(this.node.origin)) {
147
- this.linkG = drawAbstractLink(this.board, this.node, isHorizontalLayout(layout));
148
- }
149
- else {
150
- this.linkG = drawLink(this.board, parentNode, this.node, isHorizontalLayout(layout));
151
- }
152
- this.g.append(this.linkG);
153
- }
154
- destroyLine() {
155
- if (this.linkG) {
156
- this.linkG.remove();
157
- }
158
- }
159
- drawExtend() {
160
- this.destroyExtend();
161
- this.extendG = createG();
162
- this.extendG.classList.add('extend');
163
- this.g.append(this.extendG);
164
- if (this.element.isCollapsed) {
165
- this.g.classList.add('collapsed');
166
- }
167
- else {
168
- this.g.classList.remove('collapsed');
169
- }
170
- this.nodeInsertDrawer.draw(this.element, this.extendG);
171
- this.collapseDrawer.draw(this.element, this.extendG);
172
- }
173
- destroyExtend() {
174
- if (this.extendG) {
175
- this.extendG.remove();
176
- }
177
- }
178
- drawTopic() {
179
- this.textManage.draw(this.element.data.topic);
180
- this.g.append(this.textManage.g);
181
- if (this.element.manualWidth) {
182
- const width = NodeSpace.getNodeDynamicWidth(this.board, this.element);
183
- this.textManage.updateWidth(width);
184
- }
185
- }
186
- updateTopic() {
187
- this.textManage.updateText(this.element.data.topic);
188
- this.textManage.updateRectangle();
189
- if (this.element.manualWidth) {
190
- const width = NodeSpace.getNodeDynamicWidth(this.board, this.element);
191
- this.textManage.updateWidth(width);
192
- }
193
- }
194
- editTopic() {
195
- this.activeDrawer.draw(this.element, this.g, { selected: this.selected, isEditing: true });
196
- // update text max-width when image width greater than topic default max width to cover node topic default max width style
197
- const defaultMaxWidth = TOPIC_DEFAULT_MAX_WORD_COUNT * (PlaitMind.isMind(this.element) ? ROOT_TOPIC_FONT_SIZE : TOPIC_FONT_SIZE);
198
- let hasMaxWidth = false;
199
- if (!this.element.manualWidth && MindElement.hasImage(this.element) && this.element.data.image.width > defaultMaxWidth) {
200
- const width = NodeSpace.getNodeDynamicWidth(this.board, this.element);
201
- this.textManage.updateWidth(width);
202
- hasMaxWidth = true;
203
- }
204
- this.textManage.edit((origin) => {
205
- if (origin === ExitOrigin.default) {
206
- this.activeDrawer.draw(this.element, this.g, { selected: this.selected, isEditing: false });
207
- }
208
- if (hasMaxWidth) {
209
- this.textManage.updateWidth(0);
210
- }
211
- });
212
- }
213
- ngOnDestroy() {
214
- super.ngOnDestroy();
215
- this.textManage.destroy();
216
- this.nodeEmojisDrawer.destroy();
217
- this.imageDrawer.destroy();
218
- this.destroy$.next();
219
- this.destroy$.complete();
220
- if (ELEMENT_TO_NODE.get(this.element) === this.node) {
221
- ELEMENT_TO_NODE.delete(this.element);
222
- }
223
- }
224
- 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 }); }
225
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.3", type: MindNodeComponent, selector: "plait-mind-node", usesInheritance: true, ngImport: i0, template: `
226
- <plait-children
227
- *ngIf="!element.isCollapsed"
228
- [board]="board"
229
- [parent]="element"
230
- [effect]="effect"
231
- [parentG]="parentG"
232
- ></plait-children>
233
- `, 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 }); }
234
- }
235
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: MindNodeComponent, decorators: [{
236
- type: Component,
237
- args: [{
238
- selector: 'plait-mind-node',
239
- template: `
240
- <plait-children
241
- *ngIf="!element.isCollapsed"
242
- [board]="board"
243
- [parent]="element"
244
- [effect]="effect"
245
- [parentG]="parentG"
246
- ></plait-children>
247
- `,
248
- changeDetection: ChangeDetectionStrategy.OnPush
249
- }]
250
- }], ctorParameters: function () { return [{ type: i0.ViewContainerRef }, { type: i0.ChangeDetectorRef }]; } });
251
- //# 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 { ChangeDetectionStrategy, ChangeDetectorRef, Component, OnDestroy, OnInit, ViewContainerRef } from '@angular/core';\nimport {\n    createG,\n    PlaitBoard,\n    PlaitPluginElementComponent,\n    PlaitElement,\n    NODE_TO_INDEX,\n    PlaitPluginElementContext,\n    OnContextChanged,\n    RectangleClient,\n    Point\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 { drawRoundRectangleByNode } from './utils/draw/node-shape';\nimport { MindElement, PlaitMind } from './interfaces/element';\nimport { MindNode } from './interfaces/node';\nimport { MindQueries } from './queries';\nimport { isHitMindElement } from './utils/position/node';\nimport { getShapeByElement } from './utils/node-style/shape';\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 { MindElementShape } from './interfaces';\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 { NodeActiveDrawer } from './drawer/node-active.drawer';\nimport { CollapseDrawer } from './drawer/node-collapse.drawer';\nimport { WithMindOptions } from './interfaces/options';\nimport { WithMindPluginKey } from './constants/default';\nimport { NodeImageDrawer } from './drawer/node-image.drawer';\nimport { NodeSpace } from './utils/space/node-space';\nimport { NodeTopicThreshold, ROOT_TOPIC_FONT_SIZE, TOPIC_DEFAULT_MAX_WORD_COUNT, TOPIC_FONT_SIZE } from './constants/node-topic-style';\n\n// 1. When the text at the end has an italic attribute, the text is partially covered\n// 2. There will be some differences in the width measured by different browsers\nconst WIDTH_BUFFER = 4;\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})\nexport class MindNodeComponent extends PlaitPluginElementComponent<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    nodeInsertDrawer!: NodeInsertDrawer;\n\n    imageDrawer!: NodeImageDrawer;\n\n    textManage!: TextManage;\n\n    activeDrawer!: NodeActiveDrawer;\n\n    collapseDrawer!: CollapseDrawer;\n\n    constructor(private viewContainerRef: ViewContainerRef, protected cdr: ChangeDetectorRef) {\n        super(cdr);\n    }\n\n    initializeDrawer() {\n        this.nodeEmojisDrawer = new NodeEmojisDrawer(this.board, this.viewContainerRef);\n        this.nodeInsertDrawer = new NodeInsertDrawer(this.board);\n        this.activeDrawer = new NodeActiveDrawer(this.board);\n        this.collapseDrawer = new CollapseDrawer(this.board);\n        this.imageDrawer = new NodeImageDrawer(this.board, this.viewContainerRef);\n        const plugins = this.board.getPluginOptions<WithMindOptions>(WithMindPluginKey).textPlugins;\n\n        this.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                return NodeTopicThreshold.defaultTextMaxWidth;\n            }\n        });\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.drawShape();\n        this.drawLink();\n        this.drawTopic();\n        this.activeDrawer.draw(this.element, this.g, { selected: this.selected, isEditing: this.textManage.isEditing });\n        this.drawEmojis();\n        this.drawExtend();\n        this.imageDrawer.drawImage(this.g, this.element);\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\n        const isChangeTheme = this.board.operations.find(op => op.type === 'set_theme');\n\n        if (!isEqualNode || value.element !== previous.element || isChangeTheme) {\n            this.activeDrawer.draw(this.element, this.g, { selected: this.selected, isEditing: this.textManage.isEditing });\n            this.drawShape();\n            this.drawLink();\n            this.drawEmojis();\n            this.drawExtend();\n            this.imageDrawer.updateImage(this.g, previous.element, value.element);\n            this.updateTopic();\n        } else {\n            const hasSameSelected = value.selected === previous.selected;\n            const hasSameParent = value.parent === previous.parent;\n            if (!hasSameSelected) {\n                this.activeDrawer.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    drawShape() {\n        this.destroyShape();\n        const shape = getShapeByElement(this.board, this.node.origin) as MindElementShape;\n        switch (shape) {\n            case MindElementShape.roundRectangle:\n                this.shapeG = drawRoundRectangleByNode(this.board, this.node as MindNode);\n                this.g.prepend(this.shapeG);\n                break;\n            default:\n                break;\n        }\n    }\n\n    destroyShape() {\n        if (this.shapeG) {\n            this.shapeG.remove();\n            this.shapeG = null;\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        if (this.element.manualWidth) {\n            const width = NodeSpace.getNodeDynamicWidth(this.board, this.element);\n            this.textManage.updateWidth(width);\n        }\n    }\n\n    updateTopic() {\n        this.textManage.updateText(this.element.data.topic);\n        this.textManage.updateRectangle();\n        if (this.element.manualWidth) {\n            const width = NodeSpace.getNodeDynamicWidth(this.board, this.element);\n            this.textManage.updateWidth(width);\n        }\n    }\n\n    editTopic() {\n        this.activeDrawer.draw(this.element, this.g, { selected: this.selected, isEditing: true });\n        // update text max-width when image width greater than topic default max width to cover node topic default max width style\n        const defaultMaxWidth = TOPIC_DEFAULT_MAX_WORD_COUNT * (PlaitMind.isMind(this.element) ? ROOT_TOPIC_FONT_SIZE : TOPIC_FONT_SIZE);\n        let hasMaxWidth = false;\n        if (!this.element.manualWidth && MindElement.hasImage(this.element) && this.element.data.image.width > defaultMaxWidth) {\n            const width = NodeSpace.getNodeDynamicWidth(this.board, this.element);\n            this.textManage.updateWidth(width);\n            hasMaxWidth = true;\n        }\n        this.textManage.edit((origin: ExitOrigin) => {\n            if (origin === ExitOrigin.default) {\n                this.activeDrawer.draw(this.element, this.g, { selected: this.selected, isEditing: false });\n            }\n            if (hasMaxWidth) {\n                this.textManage.updateWidth(0);\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.imageDrawer.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"]}