@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.
- package/base/emoji-base.component.d.ts +1 -1
- package/esm2022/base/emoji-base.component.mjs +5 -5
- package/esm2022/interfaces/element.mjs +1 -1
- package/esm2022/interfaces/options.mjs +1 -1
- package/esm2022/mind-node.component.mjs +234 -0
- package/esm2022/mind.component.mjs +2 -2
- package/esm2022/mind.module.mjs +2 -2
- package/esm2022/plugins/with-mind-fragment.mjs +90 -0
- package/esm2022/plugins/with-mind-hotkey.mjs +13 -55
- package/esm2022/plugins/with-mind.mjs +7 -36
- package/esm2022/plugins/with-node-dnd.mjs +3 -3
- package/esm2022/plugins/with-node-resize.mjs +2 -2
- package/esm2022/public-api.mjs +2 -2
- package/esm2022/transforms/index.mjs +2 -3
- package/esm2022/transforms/node.mjs +2 -18
- package/esm2022/utils/abstract/resize.mjs +1 -1
- package/esm2022/utils/dnd/common.mjs +1 -1
- package/esm2022/utils/draw/node-dnd.mjs +1 -1
- package/esm2022/utils/node/common.mjs +1 -1
- package/esm2022/utils/node/dynamic-width.mjs +2 -5
- package/esm2022/utils/node/image.mjs +1 -1
- package/esm2022/utils/position/topic.mjs +2 -3
- package/fesm2022/plait-mind.mjs +208 -234
- package/fesm2022/plait-mind.mjs.map +1 -1
- package/interfaces/options.d.ts +0 -2
- package/mind.component.d.ts +1 -1
- package/mind.module.d.ts +1 -1
- package/package.json +1 -1
- package/plugins/with-mind-fragment.d.ts +5 -0
- package/plugins/with-mind-hotkey.d.ts +0 -2
- package/public-api.d.ts +1 -1
- package/styles/styles.scss +0 -3
- package/transforms/index.d.ts +0 -1
- package/transforms/node.d.ts +0 -1
- package/esm2022/node.component.mjs +0 -251
- /package/{node.component.d.ts → mind-node.component.d.ts} +0 -0
package/interfaces/options.d.ts
CHANGED
|
@@ -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
|
}
|
package/mind.component.d.ts
CHANGED
|
@@ -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
|
@@ -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
package/styles/styles.scss
CHANGED
package/transforms/index.d.ts
CHANGED
|
@@ -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;
|
package/transforms/node.d.ts
CHANGED
|
@@ -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"]}
|
|
File without changes
|