@plait/mind 0.2.0 → 0.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/{drawer/base/base.d.ts → base/base.drawer.d.ts} +1 -1
- package/{plugins/emoji → base}/emoji-base.component.d.ts +2 -2
- package/{plugins/emoji → base}/index.d.ts +1 -1
- package/draw/abstract.d.ts +2 -1
- package/draw/indented-link.d.ts +1 -1
- package/draw/link/logic-link.d.ts +1 -1
- package/draw/node.d.ts +5 -0
- package/draw/topic.d.ts +16 -0
- package/{plugins/emoji → drawer}/emoji.drawer.d.ts +3 -3
- package/drawer/quick-insert.drawer.d.ts +1 -1
- package/esm2020/base/base.drawer.mjs +17 -0
- package/esm2020/base/emoji-base.component.mjs +33 -0
- package/esm2020/base/index.mjs +3 -0
- package/esm2020/draw/abstract.mjs +8 -7
- package/esm2020/draw/indented-link.mjs +3 -3
- package/esm2020/draw/link/abstract-link.mjs +9 -15
- package/esm2020/draw/link/logic-link.mjs +9 -9
- package/esm2020/draw/node.mjs +21 -0
- package/esm2020/draw/topic.mjs +32 -0
- package/esm2020/drawer/emoji.drawer.mjs +73 -0
- package/esm2020/drawer/quick-insert.drawer.mjs +3 -3
- package/esm2020/interfaces/index.mjs +2 -2
- package/esm2020/interfaces/pointer.mjs +5 -0
- package/esm2020/mind.component.mjs +5 -5
- package/esm2020/mind.module.mjs +7 -7
- package/esm2020/node.component.mjs +36 -35
- package/esm2020/plugins/with-abstract-resize.board.mjs +12 -0
- package/esm2020/plugins/with-abstract-resize.mjs +107 -0
- package/esm2020/plugins/with-mind-create.mjs +85 -0
- package/esm2020/plugins/with-mind-extend.mjs +11 -0
- package/esm2020/plugins/with-mind.board.mjs +2 -0
- package/esm2020/plugins/with-mind.mjs +29 -15
- package/esm2020/plugins/with-node-dnd.mjs +162 -0
- package/esm2020/public-api.mjs +5 -3
- package/esm2020/transforms/abstract-node.mjs +3 -2
- package/esm2020/transforms/emoji.mjs +37 -0
- package/esm2020/transforms/index.mjs +7 -3
- package/esm2020/transforms/node.mjs +40 -33
- package/esm2020/utils/abstract/common.mjs +64 -31
- package/esm2020/utils/abstract/resize.mjs +3 -2
- package/esm2020/utils/clipboard.mjs +16 -18
- package/esm2020/utils/dnd/common.mjs +35 -0
- package/esm2020/utils/dnd/detector.mjs +268 -0
- package/esm2020/utils/dnd/draw.mjs +161 -0
- package/esm2020/utils/index.mjs +5 -6
- package/esm2020/utils/mind.mjs +5 -128
- package/esm2020/utils/node/adjust-node.mjs +49 -0
- package/esm2020/utils/node/create-node.mjs +61 -0
- package/esm2020/utils/point-placement.mjs +22 -2
- package/esm2020/utils/position/emoji.mjs +31 -0
- package/esm2020/utils/position/index.mjs +4 -0
- package/esm2020/utils/position/node.mjs +34 -0
- package/esm2020/utils/position/topic.mjs +14 -0
- package/esm2020/utils/space/emoji.mjs +19 -0
- package/esm2020/utils/space/layout-options.mjs +72 -0
- package/esm2020/utils/space/node-space.mjs +77 -0
- package/fesm2015/plait-mind.mjs +1476 -1643
- package/fesm2015/plait-mind.mjs.map +1 -1
- package/fesm2020/plait-mind.mjs +1518 -1674
- package/fesm2020/plait-mind.mjs.map +1 -1
- package/interfaces/index.d.ts +1 -1
- package/interfaces/pointer.d.ts +3 -0
- package/mind.module.d.ts +2 -2
- package/node.component.d.ts +6 -5
- package/package.json +3 -3
- package/{interfaces/abstract.d.ts → plugins/with-abstract-resize.board.d.ts} +2 -2
- package/plugins/with-mind-create.d.ts +11 -0
- package/plugins/with-mind-extend.d.ts +3 -0
- package/plugins/{with-extend-mind.d.ts → with-mind.board.d.ts} +4 -4
- package/plugins/with-mind.d.ts +1 -1
- package/public-api.d.ts +4 -2
- package/styles/styles.scss +5 -2
- package/transforms/abstract-node.d.ts +1 -1
- package/transforms/emoji.d.ts +6 -0
- package/transforms/index.d.ts +3 -0
- package/transforms/node.d.ts +5 -5
- package/utils/abstract/common.d.ts +19 -4
- package/utils/abstract/resize.d.ts +2 -1
- package/utils/dnd/common.d.ts +7 -0
- package/utils/dnd/detector.d.ts +31 -0
- package/utils/dnd/draw.d.ts +9 -0
- package/utils/index.d.ts +4 -5
- package/utils/mind.d.ts +3 -22
- package/utils/node/adjust-node.d.ts +5 -0
- package/utils/node/create-node.d.ts +14 -0
- package/utils/point-placement.d.ts +8 -1
- package/utils/position/emoji.d.ts +7 -0
- package/utils/position/index.d.ts +3 -0
- package/utils/position/node.d.ts +12 -0
- package/utils/position/topic.d.ts +16 -0
- package/utils/space/emoji.d.ts +7 -0
- package/{layout-option.d.ts → utils/space/layout-options.d.ts} +1 -1
- package/utils/{node-space.d.ts → space/node-space.d.ts} +4 -4
- package/draw/link.d.ts +0 -3
- package/draw/richtext.d.ts +0 -15
- package/draw/shape.d.ts +0 -3
- package/esm2020/draw/link.mjs +0 -160
- package/esm2020/draw/richtext.mjs +0 -39
- package/esm2020/draw/shape.mjs +0 -18
- package/esm2020/drawer/base/base.mjs +0 -17
- package/esm2020/interfaces/abstract.mjs +0 -12
- package/esm2020/layout-option.mjs +0 -72
- package/esm2020/plugins/emoji/emoji-base.component.mjs +0 -33
- package/esm2020/plugins/emoji/emoji.drawer.mjs +0 -72
- package/esm2020/plugins/emoji/emoji.mjs +0 -47
- package/esm2020/plugins/emoji/index.mjs +0 -3
- package/esm2020/plugins/with-abstract.mjs +0 -106
- package/esm2020/plugins/with-dnd.mjs +0 -179
- package/esm2020/plugins/with-extend-mind.mjs +0 -11
- package/esm2020/utils/direction-corrector.mjs +0 -54
- package/esm2020/utils/direction-detector.mjs +0 -56
- package/esm2020/utils/dnd.mjs +0 -122
- package/esm2020/utils/draw-placeholder.mjs +0 -313
- package/esm2020/utils/drop-target-corrector.mjs +0 -87
- package/esm2020/utils/graph.mjs +0 -24
- package/esm2020/utils/node-space.mjs +0 -77
- package/plugins/emoji/emoji.d.ts +0 -11
- package/utils/direction-corrector.d.ts +0 -4
- package/utils/direction-detector.d.ts +0 -9
- package/utils/dnd.d.ts +0 -16
- package/utils/draw-placeholder.d.ts +0 -42
- package/utils/drop-target-corrector.d.ts +0 -9
- package/utils/graph.d.ts +0 -5
- /package/plugins/{with-abstract.d.ts → with-abstract-resize.d.ts} +0 -0
- /package/plugins/{with-dnd.d.ts → with-node-dnd.d.ts} +0 -0
|
@@ -0,0 +1,162 @@
|
|
|
1
|
+
import { distanceBetweenPointAndPoint, IS_TEXT_EDITABLE, Path, PlaitBoard, PlaitElement, toPoint, transformPoint, Transforms, getSelectedElements, depthFirstRecursion, createG, PlaitNode } from '@plait/core';
|
|
2
|
+
import { AbstractNode, getNonAbstractChildren } from '@plait/layouts';
|
|
3
|
+
import { MindElement, PlaitMind } from '../interfaces/element';
|
|
4
|
+
import { changeRightNodeCount, deleteElementHandleAbstract, getFirstLevelElement, getOverallAbstracts, getValidAbstractRefs, insertElementHandleAbstract, isInRightBranchOfStandardLayout } from '../utils';
|
|
5
|
+
import { isHitMindElement } from '../utils/position/node';
|
|
6
|
+
import { addActiveOnDragOrigin, isDragging, removeActiveOnDragOrigin, setIsDragging } from '../utils/dnd/common';
|
|
7
|
+
import { detectDropTarget, getPathByDropTarget } from '../utils/dnd/detector';
|
|
8
|
+
import { drawFakeDragNode, drawFakeDropNodeByPath } from '../utils/dnd/draw';
|
|
9
|
+
import { MindTransforms } from '../transforms';
|
|
10
|
+
import { adjustAbstractToNode, adjustRootToNode } from '../utils/node/adjust-node';
|
|
11
|
+
const DRAG_MOVE_BUFFER = 5;
|
|
12
|
+
export const withDnd = (board) => {
|
|
13
|
+
const { mousedown, mousemove, globalMouseup } = board;
|
|
14
|
+
let activeElements = [];
|
|
15
|
+
let correspondingElements = [];
|
|
16
|
+
let startPoint;
|
|
17
|
+
let dragFakeNodeG;
|
|
18
|
+
let fakeDropNodeG;
|
|
19
|
+
let dropTarget = null;
|
|
20
|
+
let targetPath;
|
|
21
|
+
board.mousedown = (event) => {
|
|
22
|
+
if (board.options.readonly || IS_TEXT_EDITABLE.get(board) || event.button === 2) {
|
|
23
|
+
mousedown(event);
|
|
24
|
+
return;
|
|
25
|
+
}
|
|
26
|
+
// 确认是否 hit 节点
|
|
27
|
+
const point = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));
|
|
28
|
+
const selectedElements = getSelectedElements(board);
|
|
29
|
+
depthFirstRecursion(board, element => {
|
|
30
|
+
if (activeElements.length || !MindElement.isMindElement(board, element)) {
|
|
31
|
+
return;
|
|
32
|
+
}
|
|
33
|
+
const isHitElement = isHitMindElement(board, point, element) && !element.isRoot && !AbstractNode.isAbstract(element);
|
|
34
|
+
const isAllMindElement = selectedElements.every(element => MindElement.isMindElement(board, element));
|
|
35
|
+
const isMultiple = isHitElement && selectedElements.length > 1 && selectedElements.includes(element) && isAllMindElement;
|
|
36
|
+
const isSingle = isHitElement && !(selectedElements.length > 1 && selectedElements.includes(element));
|
|
37
|
+
if (isSingle) {
|
|
38
|
+
activeElements = [element];
|
|
39
|
+
startPoint = point;
|
|
40
|
+
}
|
|
41
|
+
else if (isMultiple) {
|
|
42
|
+
activeElements = getFirstLevelElement(selectedElements);
|
|
43
|
+
startPoint = point;
|
|
44
|
+
}
|
|
45
|
+
}, node => {
|
|
46
|
+
if (PlaitBoard.isBoard(node) || board.isRecursion(node)) {
|
|
47
|
+
return true;
|
|
48
|
+
}
|
|
49
|
+
else {
|
|
50
|
+
return false;
|
|
51
|
+
}
|
|
52
|
+
});
|
|
53
|
+
if (activeElements.length) {
|
|
54
|
+
correspondingElements = getOverallAbstracts(board, activeElements);
|
|
55
|
+
}
|
|
56
|
+
mousedown(event);
|
|
57
|
+
};
|
|
58
|
+
board.mousemove = (event) => {
|
|
59
|
+
if (!board.options.readonly && activeElements?.length && startPoint) {
|
|
60
|
+
const endPoint = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));
|
|
61
|
+
const distance = distanceBetweenPointAndPoint(startPoint[0], startPoint[1], endPoint[0], endPoint[1]);
|
|
62
|
+
if (distance < DRAG_MOVE_BUFFER) {
|
|
63
|
+
return;
|
|
64
|
+
}
|
|
65
|
+
setIsDragging(board, true);
|
|
66
|
+
fakeDropNodeG?.remove();
|
|
67
|
+
const detectPoint = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));
|
|
68
|
+
dropTarget = detectDropTarget(board, detectPoint, dropTarget, [...activeElements, ...correspondingElements]);
|
|
69
|
+
if (dropTarget?.target) {
|
|
70
|
+
targetPath = getPathByDropTarget(board, dropTarget);
|
|
71
|
+
fakeDropNodeG = drawFakeDropNodeByPath(board, dropTarget.target, targetPath);
|
|
72
|
+
PlaitBoard.getHost(board).appendChild(fakeDropNodeG);
|
|
73
|
+
}
|
|
74
|
+
const offsetX = endPoint[0] - startPoint[0];
|
|
75
|
+
const offsetY = endPoint[1] - startPoint[1];
|
|
76
|
+
dragFakeNodeG?.remove();
|
|
77
|
+
dragFakeNodeG = createG();
|
|
78
|
+
[...activeElements, ...correspondingElements].forEach(element => {
|
|
79
|
+
addActiveOnDragOrigin(element);
|
|
80
|
+
if (activeElements.includes(element)) {
|
|
81
|
+
const activeComponent = PlaitElement.getComponent(element);
|
|
82
|
+
const nodeG = drawFakeDragNode(board, activeComponent, offsetX, offsetY);
|
|
83
|
+
dragFakeNodeG?.appendChild(nodeG);
|
|
84
|
+
}
|
|
85
|
+
});
|
|
86
|
+
PlaitBoard.getHost(board).appendChild(dragFakeNodeG);
|
|
87
|
+
}
|
|
88
|
+
mousemove(event);
|
|
89
|
+
};
|
|
90
|
+
board.globalMouseup = (event) => {
|
|
91
|
+
if (!board.options.readonly && activeElements?.length) {
|
|
92
|
+
const elements = [...activeElements, ...correspondingElements];
|
|
93
|
+
if (isDragging(board)) {
|
|
94
|
+
elements.forEach(element => removeActiveOnDragOrigin(element));
|
|
95
|
+
}
|
|
96
|
+
if (dropTarget) {
|
|
97
|
+
const targetPathRef = board.pathRef(targetPath);
|
|
98
|
+
const targetElementPathRef = board.pathRef(PlaitBoard.findPath(board, dropTarget.target));
|
|
99
|
+
const abstractRefs = getValidAbstractRefs(board, elements);
|
|
100
|
+
const normalElements = elements
|
|
101
|
+
.filter(element => !abstractRefs.some(refs => refs.abstract === element))
|
|
102
|
+
.map(element => {
|
|
103
|
+
if (AbstractNode.isAbstract(element)) {
|
|
104
|
+
return adjustAbstractToNode(element);
|
|
105
|
+
}
|
|
106
|
+
if (PlaitMind.isMind(element)) {
|
|
107
|
+
return adjustRootToNode(board, element);
|
|
108
|
+
}
|
|
109
|
+
return element;
|
|
110
|
+
});
|
|
111
|
+
const effectedAbstracts = deleteElementHandleAbstract(board, elements);
|
|
112
|
+
insertElementHandleAbstract(board, targetPath, normalElements.length, false, effectedAbstracts);
|
|
113
|
+
MindTransforms.setAbstractsByRefs(board, effectedAbstracts);
|
|
114
|
+
MindTransforms.removeElements(board, elements);
|
|
115
|
+
let insertPath = targetPathRef.current;
|
|
116
|
+
const parentPath = Path.parent(targetPathRef.current || targetPath);
|
|
117
|
+
if (!insertPath) {
|
|
118
|
+
const parent = PlaitNode.get(board, parentPath);
|
|
119
|
+
const children = getNonAbstractChildren(parent);
|
|
120
|
+
insertPath = [...parentPath, children.length || 0];
|
|
121
|
+
}
|
|
122
|
+
MindTransforms.insertNodes(board, normalElements, insertPath);
|
|
123
|
+
if (abstractRefs.length) {
|
|
124
|
+
MindTransforms.insertAbstractNodes(board, abstractRefs, normalElements, insertPath);
|
|
125
|
+
}
|
|
126
|
+
const shouldChangeRoot = isInRightBranchOfStandardLayout(dropTarget?.target) &&
|
|
127
|
+
targetElementPathRef.current &&
|
|
128
|
+
(Path.isSibling(targetPath, targetElementPathRef.current) || Path.equals(targetPath, targetElementPathRef.current));
|
|
129
|
+
if (shouldChangeRoot && targetElementPathRef.current) {
|
|
130
|
+
changeRightNodeCount(board, targetElementPathRef.current.slice(0, 1), normalElements.length);
|
|
131
|
+
}
|
|
132
|
+
if (targetElementPathRef.current &&
|
|
133
|
+
targetPathRef.current &&
|
|
134
|
+
Path.isAncestor(targetElementPathRef.current, targetPathRef.current) &&
|
|
135
|
+
dropTarget.target.isCollapsed) {
|
|
136
|
+
Transforms.setNode(board, { isCollapsed: false }, targetElementPathRef.current);
|
|
137
|
+
}
|
|
138
|
+
targetElementPathRef.unref();
|
|
139
|
+
targetPathRef.unref();
|
|
140
|
+
const selectedElements = getSelectedElements(board);
|
|
141
|
+
let setActiveElements = [];
|
|
142
|
+
depthFirstRecursion(board, node => {
|
|
143
|
+
const isSelected = selectedElements.some(element => element.id === node.id);
|
|
144
|
+
if (isSelected) {
|
|
145
|
+
setActiveElements.push(node);
|
|
146
|
+
}
|
|
147
|
+
});
|
|
148
|
+
Transforms.setSelectionWithTemporaryElements(board, setActiveElements);
|
|
149
|
+
}
|
|
150
|
+
setIsDragging(board, false);
|
|
151
|
+
activeElements = [];
|
|
152
|
+
dragFakeNodeG?.remove();
|
|
153
|
+
dragFakeNodeG = undefined;
|
|
154
|
+
fakeDropNodeG?.remove();
|
|
155
|
+
fakeDropNodeG = undefined;
|
|
156
|
+
dropTarget = null;
|
|
157
|
+
}
|
|
158
|
+
globalMouseup(event);
|
|
159
|
+
};
|
|
160
|
+
return board;
|
|
161
|
+
};
|
|
162
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-node-dnd.js","sourceRoot":"","sources":["../../../../packages/mind/src/plugins/with-node-dnd.ts"],"names":[],"mappings":"AAAA,OAAO,EACH,4BAA4B,EAC5B,gBAAgB,EAChB,IAAI,EACJ,UAAU,EACV,YAAY,EAEZ,OAAO,EACP,cAAc,EACd,UAAU,EACV,mBAAmB,EACnB,mBAAmB,EACnB,OAAO,EACP,SAAS,EACZ,MAAM,aAAa,CAAC;AACrB,OAAO,EAAE,YAAY,EAAE,sBAAsB,EAAE,MAAM,gBAAgB,CAAC;AACtE,OAAO,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,uBAAuB,CAAC;AAG/D,OAAO,EACH,oBAAoB,EACpB,2BAA2B,EAC3B,oBAAoB,EACpB,mBAAmB,EACnB,oBAAoB,EACpB,2BAA2B,EAC3B,+BAA+B,EAClC,MAAM,UAAU,CAAC;AAClB,OAAO,EAAE,gBAAgB,EAAE,MAAM,wBAAwB,CAAC;AAC1D,OAAO,EAAE,qBAAqB,EAAE,UAAU,EAAE,wBAAwB,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AACjH,OAAO,EAAE,gBAAgB,EAAE,mBAAmB,EAAE,MAAM,uBAAuB,CAAC;AAC9E,OAAO,EAAE,gBAAgB,EAAE,sBAAsB,EAAE,MAAM,mBAAmB,CAAC;AAC7E,OAAO,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAC/C,OAAO,EAAE,oBAAoB,EAAE,gBAAgB,EAAE,MAAM,2BAA2B,CAAC;AAEnF,MAAM,gBAAgB,GAAG,CAAC,CAAC;AAE3B,MAAM,CAAC,MAAM,OAAO,GAAG,CAAC,KAAiB,EAAE,EAAE;IACzC,MAAM,EAAE,SAAS,EAAE,SAAS,EAAE,aAAa,EAAE,GAAG,KAAK,CAAC;IAEtD,IAAI,cAAc,GAAkB,EAAE,CAAC;IACvC,IAAI,qBAAqB,GAAkB,EAAE,CAAC;IAC9C,IAAI,UAAiB,CAAC;IACtB,IAAI,aAAsC,CAAC;IAC3C,IAAI,aAAsC,CAAC;IAC3C,IAAI,UAAU,GAA+D,IAAI,CAAC;IAClF,IAAI,UAAgB,CAAC;IAErB,KAAK,CAAC,SAAS,GAAG,CAAC,KAAiB,EAAE,EAAE;QACpC,IAAI,KAAK,CAAC,OAAO,CAAC,QAAQ,IAAI,gBAAgB,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE;YAC7E,SAAS,CAAC,KAAK,CAAC,CAAC;YACjB,OAAO;SACV;QAED,cAAc;QACd,MAAM,KAAK,GAAG,cAAc,CAAC,KAAK,EAAE,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,EAAE,UAAU,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QAC1F,MAAM,gBAAgB,GAAG,mBAAmB,CAAC,KAAK,CAAC,CAAC;QACpD,mBAAmB,CACd,KAAgC,EACjC,OAAO,CAAC,EAAE;YACN,IAAI,cAAc,CAAC,MAAM,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,KAAK,EAAE,OAAO,CAAC,EAAE;gBACrE,OAAO;aACV;YACD,MAAM,YAAY,GAAG,gBAAgB,CAAC,KAAK,EAAE,KAAK,EAAE,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;YACrH,MAAM,gBAAgB,GAAG,gBAAgB,CAAC,KAAK,CAAC,OAAO,CAAC,EAAE,CAAC,WAAW,CAAC,aAAa,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC,CAAC;YACtG,MAAM,UAAU,GAAG,YAAY,IAAI,gBAAgB,CAAC,MAAM,GAAG,CAAC,IAAI,gBAAgB,CAAC,QAAQ,CAAC,OAAO,CAAC,IAAI,gBAAgB,CAAC;YACzH,MAAM,QAAQ,GAAG,YAAY,IAAI,CAAC,CAAC,gBAAgB,CAAC,MAAM,GAAG,CAAC,IAAI,gBAAgB,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC;YAEtG,IAAI,QAAQ,EAAE;gBACV,cAAc,GAAG,CAAC,OAAO,CAAC,CAAC;gBAC3B,UAAU,GAAG,KAAK,CAAC;aACtB;iBAAM,IAAI,UAAU,EAAE;gBACnB,cAAc,GAAG,oBAAoB,CAAC,gBAAiC,CAAC,CAAC;gBACzE,UAAU,GAAG,KAAK,CAAC;aACtB;QACL,CAAC,EACD,IAAI,CAAC,EAAE;YACH,IAAI,UAAU,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,KAAK,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE;gBACrD,OAAO,IAAI,CAAC;aACf;iBAAM;gBACH,OAAO,KAAK,CAAC;aAChB;QACL,CAAC,CACJ,CAAC;QAEF,IAAI,cAAc,CAAC,MAAM,EAAE;YACvB,qBAAqB,GAAG,mBAAmB,CAAC,KAAK,EAAE,cAAc,CAAC,CAAC;SACtE;QAED,SAAS,CAAC,KAAK,CAAC,CAAC;IACrB,CAAC,CAAC;IAEF,KAAK,CAAC,SAAS,GAAG,CAAC,KAAiB,EAAE,EAAE;QACpC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,QAAQ,IAAI,cAAc,EAAE,MAAM,IAAI,UAAU,EAAE;YACjE,MAAM,QAAQ,GAAG,cAAc,CAAC,KAAK,EAAE,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,EAAE,UAAU,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;YAC7F,MAAM,QAAQ,GAAG,4BAA4B,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,UAAU,CAAC,CAAC,CAAC,EAAE,QAAQ,CAAC,CAAC,CAAC,EAAE,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC;YACtG,IAAI,QAAQ,GAAG,gBAAgB,EAAE;gBAC7B,OAAO;aACV;YAED,aAAa,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;YAE3B,aAAa,EAAE,MAAM,EAAE,CAAC;YACxB,MAAM,WAAW,GAAG,cAAc,CAAC,KAAK,EAAE,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,EAAE,UAAU,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;YAChG,UAAU,GAAG,gBAAgB,CAAC,KAAK,EAAE,WAAW,EAAE,UAAU,EAAE,CAAC,GAAG,cAAc,EAAE,GAAG,qBAAqB,CAAC,CAAC,CAAC;YAC7G,IAAI,UAAU,EAAE,MAAM,EAAE;gBACpB,UAAU,GAAG,mBAAmB,CAAC,KAAK,EAAE,UAAU,CAAC,CAAC;gBAEpD,aAAa,GAAG,sBAAsB,CAAC,KAAK,EAAE,UAAU,CAAC,MAAM,EAAE,UAAU,CAAC,CAAC;gBAC7E,UAAU,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,WAAW,CAAC,aAAa,CAAC,CAAC;aACxD;YAED,MAAM,OAAO,GAAG,QAAQ,CAAC,CAAC,CAAC,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC;YAC5C,MAAM,OAAO,GAAG,QAAQ,CAAC,CAAC,CAAC,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC;YAC5C,aAAa,EAAE,MAAM,EAAE,CAAC;YACxB,aAAa,GAAG,OAAO,EAAE,CAAC;YAC1B,CAAC,GAAG,cAAc,EAAE,GAAG,qBAAqB,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE;gBAC5D,qBAAqB,CAAC,OAAO,CAAC,CAAC;gBAC/B,IAAI,cAAc,CAAC,QAAQ,CAAC,OAAO,CAAC,EAAE;oBAClC,MAAM,eAAe,GAAG,YAAY,CAAC,YAAY,CAAC,OAAO,CAAsB,CAAC;oBAChF,MAAM,KAAK,GAAG,gBAAgB,CAAC,KAAK,EAAE,eAAe,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC;oBACzE,aAAa,EAAE,WAAW,CAAC,KAAK,CAAC,CAAC;iBACrC;YACL,CAAC,CAAC,CAAC;YAEH,UAAU,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,WAAW,CAAC,aAAa,CAAC,CAAC;SACxD;QAED,SAAS,CAAC,KAAK,CAAC,CAAC;IACrB,CAAC,CAAC;IAEF,KAAK,CAAC,aAAa,GAAG,CAAC,KAAiB,EAAE,EAAE;QACxC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,QAAQ,IAAI,cAAc,EAAE,MAAM,EAAE;YACnD,MAAM,QAAQ,GAAG,CAAC,GAAG,cAAc,EAAE,GAAG,qBAAqB,CAAC,CAAC;YAC/D,IAAI,UAAU,CAAC,KAAK,CAAC,EAAE;gBACnB,QAAQ,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC,wBAAwB,CAAC,OAAO,CAAC,CAAC,CAAC;aAClE;YACD,IAAI,UAAU,EAAE;gBACZ,MAAM,aAAa,GAAG,KAAK,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;gBAChD,MAAM,oBAAoB,GAAG,KAAK,CAAC,OAAO,CAAC,UAAU,CAAC,QAAQ,CAAC,KAAK,EAAE,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC;gBAC1F,MAAM,YAAY,GAAG,oBAAoB,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC;gBAC3D,MAAM,cAAc,GAAG,QAAQ;qBAC1B,MAAM,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,QAAQ,KAAK,OAAO,CAAC,CAAC;qBACxE,GAAG,CAAC,OAAO,CAAC,EAAE;oBACX,IAAI,YAAY,CAAC,UAAU,CAAC,OAAO,CAAC,EAAE;wBAClC,OAAO,oBAAoB,CAAC,OAAO,CAAC,CAAC;qBACxC;oBACD,IAAI,SAAS,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE;wBAC3B,OAAO,gBAAgB,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC;qBAC3C;oBACD,OAAO,OAAO,CAAC;gBACnB,CAAC,CAAC,CAAC;gBAEP,MAAM,iBAAiB,GAAG,2BAA2B,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC;gBACvE,2BAA2B,CAAC,KAAK,EAAE,UAAU,EAAE,cAAc,CAAC,MAAM,EAAE,KAAK,EAAE,iBAAiB,CAAC,CAAC;gBAChG,cAAc,CAAC,kBAAkB,CAAC,KAAK,EAAE,iBAAiB,CAAC,CAAC;gBAE5D,cAAc,CAAC,cAAc,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC;gBAE/C,IAAI,UAAU,GAAG,aAAa,CAAC,OAAO,CAAC;gBACvC,MAAM,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,OAAO,IAAI,UAAU,CAAC,CAAC;gBACpE,IAAI,CAAC,UAAU,EAAE;oBACb,MAAM,MAAM,GAAG,SAAS,CAAC,GAAG,CAAC,KAAK,EAAE,UAAU,CAAC,CAAC;oBAChD,MAAM,QAAQ,GAAG,sBAAsB,CAAC,MAAM,CAAC,CAAC;oBAChD,UAAU,GAAG,CAAC,GAAG,UAAU,EAAE,QAAQ,CAAC,MAAM,IAAI,CAAC,CAAC,CAAC;iBACtD;gBAED,cAAc,CAAC,WAAW,CAAC,KAAK,EAAE,cAAc,EAAE,UAAU,CAAC,CAAC;gBAE9D,IAAI,YAAY,CAAC,MAAM,EAAE;oBACrB,cAAc,CAAC,mBAAmB,CAAC,KAAK,EAAE,YAAY,EAAE,cAAc,EAAE,UAAU,CAAC,CAAC;iBACvF;gBAED,MAAM,gBAAgB,GAClB,+BAA+B,CAAC,UAAU,EAAE,MAAM,CAAC;oBACnD,oBAAoB,CAAC,OAAO;oBAC5B,CAAC,IAAI,CAAC,SAAS,CAAC,UAAU,EAAE,oBAAoB,CAAC,OAAO,CAAC,IAAI,IAAI,CAAC,MAAM,CAAC,UAAU,EAAE,oBAAoB,CAAC,OAAO,CAAC,CAAC,CAAC;gBACxH,IAAI,gBAAgB,IAAI,oBAAoB,CAAC,OAAO,EAAE;oBAClD,oBAAoB,CAAC,KAAK,EAAE,oBAAoB,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,cAAc,CAAC,MAAM,CAAC,CAAC;iBAChG;gBAED,IACI,oBAAoB,CAAC,OAAO;oBAC5B,aAAa,CAAC,OAAO;oBACrB,IAAI,CAAC,UAAU,CAAC,oBAAoB,CAAC,OAAO,EAAE,aAAa,CAAC,OAAO,CAAC;oBACpE,UAAU,CAAC,MAAM,CAAC,WAAW,EAC/B;oBACE,UAAU,CAAC,OAAO,CAAC,KAAK,EAAE,EAAE,WAAW,EAAE,KAAK,EAAE,EAAE,oBAAoB,CAAC,OAAO,CAAC,CAAC;iBACnF;gBACD,oBAAoB,CAAC,KAAK,EAAE,CAAC;gBAC7B,aAAa,CAAC,KAAK,EAAE,CAAC;gBAEtB,MAAM,gBAAgB,GAAG,mBAAmB,CAAC,KAAK,CAAC,CAAC;gBACpD,IAAI,iBAAiB,GAAkB,EAAE,CAAC;gBAC1C,mBAAmB,CAAE,KAAgC,EAAE,IAAI,CAAC,EAAE;oBAC1D,MAAM,UAAU,GAAG,gBAAgB,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,OAAO,CAAC,EAAE,KAAK,IAAI,CAAC,EAAE,CAAC,CAAC;oBAC5E,IAAI,UAAU,EAAE;wBACZ,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;qBAChC;gBACL,CAAC,CAAC,CAAC;gBAEH,UAAU,CAAC,iCAAiC,CAAC,KAAK,EAAE,iBAAiB,CAAC,CAAC;aAC1E;YAED,aAAa,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;YAC5B,cAAc,GAAG,EAAE,CAAC;YACpB,aAAa,EAAE,MAAM,EAAE,CAAC;YACxB,aAAa,GAAG,SAAS,CAAC;YAC1B,aAAa,EAAE,MAAM,EAAE,CAAC;YACxB,aAAa,GAAG,SAAS,CAAC;YAC1B,UAAU,GAAG,IAAI,CAAC;SACrB;QACD,aAAa,CAAC,KAAK,CAAC,CAAC;IACzB,CAAC,CAAC;IAEF,OAAO,KAAK,CAAC;AACjB,CAAC,CAAC","sourcesContent":["import {\n    distanceBetweenPointAndPoint,\n    IS_TEXT_EDITABLE,\n    Path,\n    PlaitBoard,\n    PlaitElement,\n    Point,\n    toPoint,\n    transformPoint,\n    Transforms,\n    getSelectedElements,\n    depthFirstRecursion,\n    createG,\n    PlaitNode\n} from '@plait/core';\nimport { AbstractNode, getNonAbstractChildren } from '@plait/layouts';\nimport { MindElement, PlaitMind } from '../interfaces/element';\nimport { DetectResult } from '../interfaces/node';\nimport { MindNodeComponent } from '../node.component';\nimport {\n    changeRightNodeCount,\n    deleteElementHandleAbstract,\n    getFirstLevelElement,\n    getOverallAbstracts,\n    getValidAbstractRefs,\n    insertElementHandleAbstract,\n    isInRightBranchOfStandardLayout\n} from '../utils';\nimport { isHitMindElement } from '../utils/position/node';\nimport { addActiveOnDragOrigin, isDragging, removeActiveOnDragOrigin, setIsDragging } from '../utils/dnd/common';\nimport { detectDropTarget, getPathByDropTarget } from '../utils/dnd/detector';\nimport { drawFakeDragNode, drawFakeDropNodeByPath } from '../utils/dnd/draw';\nimport { MindTransforms } from '../transforms';\nimport { adjustAbstractToNode, adjustRootToNode } from '../utils/node/adjust-node';\n\nconst DRAG_MOVE_BUFFER = 5;\n\nexport const withDnd = (board: PlaitBoard) => {\n    const { mousedown, mousemove, globalMouseup } = board;\n\n    let activeElements: MindElement[] = [];\n    let correspondingElements: MindElement[] = [];\n    let startPoint: Point;\n    let dragFakeNodeG: SVGGElement | undefined;\n    let fakeDropNodeG: SVGGElement | undefined;\n    let dropTarget: { target: MindElement; detectResult: DetectResult } | null = null;\n    let targetPath: Path;\n\n    board.mousedown = (event: MouseEvent) => {\n        if (board.options.readonly || IS_TEXT_EDITABLE.get(board) || event.button === 2) {\n            mousedown(event);\n            return;\n        }\n\n        // 确认是否 hit 节点\n        const point = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));\n        const selectedElements = getSelectedElements(board);\n        depthFirstRecursion(\n            (board as unknown) as MindElement,\n            element => {\n                if (activeElements.length || !MindElement.isMindElement(board, element)) {\n                    return;\n                }\n                const isHitElement = isHitMindElement(board, point, element) && !element.isRoot && !AbstractNode.isAbstract(element);\n                const isAllMindElement = selectedElements.every(element => MindElement.isMindElement(board, element));\n                const isMultiple = isHitElement && selectedElements.length > 1 && selectedElements.includes(element) && isAllMindElement;\n                const isSingle = isHitElement && !(selectedElements.length > 1 && selectedElements.includes(element));\n\n                if (isSingle) {\n                    activeElements = [element];\n                    startPoint = point;\n                } else if (isMultiple) {\n                    activeElements = getFirstLevelElement(selectedElements as MindElement[]);\n                    startPoint = point;\n                }\n            },\n            node => {\n                if (PlaitBoard.isBoard(node) || board.isRecursion(node)) {\n                    return true;\n                } else {\n                    return false;\n                }\n            }\n        );\n\n        if (activeElements.length) {\n            correspondingElements = getOverallAbstracts(board, activeElements);\n        }\n\n        mousedown(event);\n    };\n\n    board.mousemove = (event: MouseEvent) => {\n        if (!board.options.readonly && activeElements?.length && startPoint) {\n            const endPoint = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));\n            const distance = distanceBetweenPointAndPoint(startPoint[0], startPoint[1], endPoint[0], endPoint[1]);\n            if (distance < DRAG_MOVE_BUFFER) {\n                return;\n            }\n\n            setIsDragging(board, true);\n\n            fakeDropNodeG?.remove();\n            const detectPoint = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));\n            dropTarget = detectDropTarget(board, detectPoint, dropTarget, [...activeElements, ...correspondingElements]);\n            if (dropTarget?.target) {\n                targetPath = getPathByDropTarget(board, dropTarget);\n\n                fakeDropNodeG = drawFakeDropNodeByPath(board, dropTarget.target, targetPath);\n                PlaitBoard.getHost(board).appendChild(fakeDropNodeG);\n            }\n\n            const offsetX = endPoint[0] - startPoint[0];\n            const offsetY = endPoint[1] - startPoint[1];\n            dragFakeNodeG?.remove();\n            dragFakeNodeG = createG();\n            [...activeElements, ...correspondingElements].forEach(element => {\n                addActiveOnDragOrigin(element);\n                if (activeElements.includes(element)) {\n                    const activeComponent = PlaitElement.getComponent(element) as MindNodeComponent;\n                    const nodeG = drawFakeDragNode(board, activeComponent, offsetX, offsetY);\n                    dragFakeNodeG?.appendChild(nodeG);\n                }\n            });\n\n            PlaitBoard.getHost(board).appendChild(dragFakeNodeG);\n        }\n\n        mousemove(event);\n    };\n\n    board.globalMouseup = (event: MouseEvent) => {\n        if (!board.options.readonly && activeElements?.length) {\n            const elements = [...activeElements, ...correspondingElements];\n            if (isDragging(board)) {\n                elements.forEach(element => removeActiveOnDragOrigin(element));\n            }\n            if (dropTarget) {\n                const targetPathRef = board.pathRef(targetPath);\n                const targetElementPathRef = board.pathRef(PlaitBoard.findPath(board, dropTarget.target));\n                const abstractRefs = getValidAbstractRefs(board, elements);\n                const normalElements = elements\n                    .filter(element => !abstractRefs.some(refs => refs.abstract === element))\n                    .map(element => {\n                        if (AbstractNode.isAbstract(element)) {\n                            return adjustAbstractToNode(element);\n                        }\n                        if (PlaitMind.isMind(element)) {\n                            return adjustRootToNode(board, element);\n                        }\n                        return element;\n                    });\n\n                const effectedAbstracts = deleteElementHandleAbstract(board, elements);\n                insertElementHandleAbstract(board, targetPath, normalElements.length, false, effectedAbstracts);\n                MindTransforms.setAbstractsByRefs(board, effectedAbstracts);\n\n                MindTransforms.removeElements(board, elements);\n\n                let insertPath = targetPathRef.current;\n                const parentPath = Path.parent(targetPathRef.current || targetPath);\n                if (!insertPath) {\n                    const parent = PlaitNode.get(board, parentPath);\n                    const children = getNonAbstractChildren(parent);\n                    insertPath = [...parentPath, children.length || 0];\n                }\n\n                MindTransforms.insertNodes(board, normalElements, insertPath);\n\n                if (abstractRefs.length) {\n                    MindTransforms.insertAbstractNodes(board, abstractRefs, normalElements, insertPath);\n                }\n\n                const shouldChangeRoot =\n                    isInRightBranchOfStandardLayout(dropTarget?.target) &&\n                    targetElementPathRef.current &&\n                    (Path.isSibling(targetPath, targetElementPathRef.current) || Path.equals(targetPath, targetElementPathRef.current));\n                if (shouldChangeRoot && targetElementPathRef.current) {\n                    changeRightNodeCount(board, targetElementPathRef.current.slice(0, 1), normalElements.length);\n                }\n\n                if (\n                    targetElementPathRef.current &&\n                    targetPathRef.current &&\n                    Path.isAncestor(targetElementPathRef.current, targetPathRef.current) &&\n                    dropTarget.target.isCollapsed\n                ) {\n                    Transforms.setNode(board, { isCollapsed: false }, targetElementPathRef.current);\n                }\n                targetElementPathRef.unref();\n                targetPathRef.unref();\n\n                const selectedElements = getSelectedElements(board);\n                let setActiveElements: MindElement[] = [];\n                depthFirstRecursion((board as unknown) as MindElement, node => {\n                    const isSelected = selectedElements.some(element => element.id === node.id);\n                    if (isSelected) {\n                        setActiveElements.push(node);\n                    }\n                });\n\n                Transforms.setSelectionWithTemporaryElements(board, setActiveElements);\n            }\n\n            setIsDragging(board, false);\n            activeElements = [];\n            dragFakeNodeG?.remove();\n            dragFakeNodeG = undefined;\n            fakeDropNodeG?.remove();\n            fakeDropNodeG = undefined;\n            dropTarget = null;\n        }\n        globalMouseup(event);\n    };\n\n    return board;\n};\n"]}
|
package/esm2020/public-api.mjs
CHANGED
|
@@ -7,9 +7,11 @@ export * from './mind.module';
|
|
|
7
7
|
export * from './utils';
|
|
8
8
|
export * from './interfaces';
|
|
9
9
|
export * from './plugins/with-mind';
|
|
10
|
-
export * from './plugins/with-extend
|
|
10
|
+
export * from './plugins/with-mind-extend';
|
|
11
11
|
export * from './constants';
|
|
12
12
|
export * from './queries/index';
|
|
13
13
|
export * from './transforms/index';
|
|
14
|
-
export * from './
|
|
15
|
-
|
|
14
|
+
export * from './base';
|
|
15
|
+
export * from './plugins/with-mind.board';
|
|
16
|
+
export * from './plugins/with-abstract-resize.board';
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3BhY2thZ2VzL21pbmQvc3JjL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsa0JBQWtCLENBQUM7QUFDakMsY0FBYyxlQUFlLENBQUM7QUFDOUIsY0FBYyxTQUFTLENBQUM7QUFDeEIsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyxxQkFBcUIsQ0FBQztBQUNwQyxjQUFjLDRCQUE0QixDQUFDO0FBQzNDLGNBQWMsYUFBYSxDQUFDO0FBQzVCLGNBQWMsaUJBQWlCLENBQUM7QUFDaEMsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLFFBQVEsQ0FBQztBQUN2QixjQUFjLDJCQUEyQixDQUFDO0FBQzFDLGNBQWMsc0NBQXNDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogUHVibGljIEFQSSBTdXJmYWNlIG9mIG1pbmRcbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL21pbmQuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbm9kZS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9taW5kLm1vZHVsZSc7XG5leHBvcnQgKiBmcm9tICcuL3V0aWxzJztcbmV4cG9ydCAqIGZyb20gJy4vaW50ZXJmYWNlcyc7XG5leHBvcnQgKiBmcm9tICcuL3BsdWdpbnMvd2l0aC1taW5kJztcbmV4cG9ydCAqIGZyb20gJy4vcGx1Z2lucy93aXRoLW1pbmQtZXh0ZW5kJztcbmV4cG9ydCAqIGZyb20gJy4vY29uc3RhbnRzJztcbmV4cG9ydCAqIGZyb20gJy4vcXVlcmllcy9pbmRleCc7XG5leHBvcnQgKiBmcm9tICcuL3RyYW5zZm9ybXMvaW5kZXgnO1xuZXhwb3J0ICogZnJvbSAnLi9iYXNlJztcbmV4cG9ydCAqIGZyb20gJy4vcGx1Z2lucy93aXRoLW1pbmQuYm9hcmQnO1xuZXhwb3J0ICogZnJvbSAnLi9wbHVnaW5zL3dpdGgtYWJzdHJhY3QtcmVzaXplLmJvYXJkJztcbiJdfQ==
|
|
@@ -1,8 +1,9 @@
|
|
|
1
1
|
import { Path, PlaitBoard, Transforms } from '@plait/core';
|
|
2
2
|
import { AbstractNode, isStandardLayout } from '@plait/layouts';
|
|
3
|
-
import {
|
|
3
|
+
import { divideElementByParent, getFirstLevelElement } from '../utils/mind';
|
|
4
4
|
import { MindQueries } from '../queries';
|
|
5
5
|
import { DefaultAbstractNodeStyle } from '../constants/node-style';
|
|
6
|
+
import { createMindElement } from '../utils/node/create-node';
|
|
6
7
|
export const setAbstractsByRefs = (board, abstractRefs) => {
|
|
7
8
|
abstractRefs.forEach((newProperty, element) => {
|
|
8
9
|
const start = element.start + newProperty.start;
|
|
@@ -65,4 +66,4 @@ const insertAbstractNode = (board, path, start, end) => {
|
|
|
65
66
|
mindElement.end = end;
|
|
66
67
|
Transforms.insertNode(board, mindElement, path);
|
|
67
68
|
};
|
|
68
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
69
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstract-node.js","sourceRoot":"","sources":["../../../../packages/mind/src/transforms/abstract-node.ts"],"names":[],"mappings":"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","sourcesContent":["import { Path, PlaitBoard, PlaitElement, Transforms } from '@plait/core';\nimport { AbstractRefs } from '../plugins/with-abstract-resize.board';\nimport { MindElement } from '../interfaces/element';\nimport { AbstractNode, isStandardLayout } from '@plait/layouts';\nimport { divideElementByParent, getFirstLevelElement } from '../utils/mind';\nimport { MindQueries } from '../queries';\nimport { DefaultAbstractNodeStyle } from '../constants/node-style';\nimport { createMindElement } from '../utils/node/create-node';\n\nexport const setAbstractsByRefs = (board: PlaitBoard, abstractRefs: AbstractRefs) => {\n    abstractRefs.forEach((newProperty, element) => {\n        const start = element.start! + newProperty.start;\n        const end = element.end! + newProperty.end;\n        const path = PlaitBoard.findPath(board, element as MindElement);\n\n        if (start > end) {\n            Transforms.removeNode(board, path);\n        } else {\n            Transforms.setNode(board, { start, end }, path);\n        }\n    });\n};\n\nexport const setAbstractByStandardLayout = (board: PlaitBoard, element: MindElement) => {\n    const rightNodeCount = element.rightNodeCount!;\n    const abstract = element.children.find(child => {\n        return AbstractNode.isAbstract(child) && child.end >= rightNodeCount && child.start < rightNodeCount;\n    });\n\n    if (abstract) {\n        const path = PlaitBoard.findPath(board, abstract);\n        Transforms.setNode(board, { end: rightNodeCount - 1 }, path);\n    }\n};\n\nexport const insertAbstract = (board: PlaitBoard, elements: PlaitElement[]) => {\n    let elementGroup = getFirstLevelElement(elements as MindElement[]);\n    const { parentElements, abstractIncludedGroups } = divideElementByParent(elementGroup);\n\n    abstractIncludedGroups.forEach((group, index) => {\n        const groupParent = parentElements[index];\n        setAbstractByElements(board, groupParent, group);\n    });\n};\n\nconst setAbstractByElements = (board: PlaitBoard, groupParent: MindElement, group: MindElement[]) => {\n    const indexArray = group.map(child => groupParent!.children.indexOf(child)).sort((a, b) => a - b);\n    const rightNodeCount = groupParent?.rightNodeCount;\n    const start = indexArray[0],\n        end = indexArray[indexArray.length - 1];\n\n    if (\n        isStandardLayout(MindQueries.getLayoutByElement(groupParent)) &&\n        rightNodeCount &&\n        start < rightNodeCount &&\n        end >= rightNodeCount\n    ) {\n        const childrenLength = groupParent.children.length;\n        const path = [...PlaitBoard.findPath(board, groupParent), childrenLength];\n        const leftChildren = indexArray.filter(index => index >= rightNodeCount);\n        const rightChildren = indexArray.filter(index => index < rightNodeCount);\n        insertAbstractNode(board, path, rightChildren[0], rightChildren[rightChildren.length - 1]);\n        insertAbstractNode(board, Path.next(path), leftChildren[0], leftChildren[leftChildren.length - 1]);\n    } else {\n        const path = [...PlaitBoard.findPath(board, groupParent), groupParent.children.length];\n        insertAbstractNode(board, path, start, end);\n    }\n};\n\nconst insertAbstractNode = (board: PlaitBoard, path: Path, start: number, end: number) => {\n    const mindElement = createMindElement('概要', 28, 20, {\n        strokeColor: DefaultAbstractNodeStyle.strokeColor,\n        strokeWidth: DefaultAbstractNodeStyle.branchWidth,\n        branchColor: DefaultAbstractNodeStyle.branchColor,\n        branchWidth: DefaultAbstractNodeStyle.branchWidth\n    });\n\n    mindElement.start = start;\n    mindElement.end = end;\n\n    Transforms.insertNode(board, mindElement, path);\n};\n"]}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { PlaitBoard, Transforms } from '@plait/core';
|
|
2
|
+
export const addEmoji = (board, element, emojiItem) => {
|
|
3
|
+
const emojis = element.data.emojis || [];
|
|
4
|
+
const newEmojis = [...emojis];
|
|
5
|
+
newEmojis.push(emojiItem);
|
|
6
|
+
const newElement = {
|
|
7
|
+
data: { topic: element.data.topic, emojis: newEmojis }
|
|
8
|
+
};
|
|
9
|
+
const path = PlaitBoard.findPath(board, element);
|
|
10
|
+
Transforms.setNode(board, newElement, path);
|
|
11
|
+
};
|
|
12
|
+
export const removeEmoji = (board, element, emojiItem) => {
|
|
13
|
+
const emojis = element.data.emojis.filter(value => value !== emojiItem);
|
|
14
|
+
const newElement = {
|
|
15
|
+
data: { topic: element.data.topic }
|
|
16
|
+
};
|
|
17
|
+
if (emojis.length > 0) {
|
|
18
|
+
newElement.data.emojis = emojis;
|
|
19
|
+
}
|
|
20
|
+
const path = PlaitBoard.findPath(board, element);
|
|
21
|
+
Transforms.setNode(board, newElement, path);
|
|
22
|
+
};
|
|
23
|
+
export const replaceEmoji = (board, element, oldEmoji, newEmoji) => {
|
|
24
|
+
const newElement = {
|
|
25
|
+
data: { topic: element.data.topic }
|
|
26
|
+
};
|
|
27
|
+
const newEmojis = element.data.emojis.map(value => {
|
|
28
|
+
if (value === oldEmoji) {
|
|
29
|
+
return newEmoji;
|
|
30
|
+
}
|
|
31
|
+
return value;
|
|
32
|
+
});
|
|
33
|
+
newElement.data.emojis = newEmojis;
|
|
34
|
+
const path = PlaitBoard.findPath(board, element);
|
|
35
|
+
Transforms.setNode(board, newElement, path);
|
|
36
|
+
};
|
|
37
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW1vamkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9taW5kL3NyYy90cmFuc2Zvcm1zL2Vtb2ppLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxVQUFVLEVBQUUsVUFBVSxFQUFFLE1BQU0sYUFBYSxDQUFDO0FBR3JELE1BQU0sQ0FBQyxNQUFNLFFBQVEsR0FBRyxDQUFDLEtBQWlCLEVBQUUsT0FBb0IsRUFBRSxTQUFvQixFQUFFLEVBQUU7SUFDdEYsTUFBTSxNQUFNLEdBQUcsT0FBTyxDQUFDLElBQUksQ0FBQyxNQUFNLElBQUksRUFBRSxDQUFDO0lBQ3pDLE1BQU0sU0FBUyxHQUFHLENBQUMsR0FBRyxNQUFNLENBQUMsQ0FBQztJQUM5QixTQUFTLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDO0lBQzFCLE1BQU0sVUFBVSxHQUFHO1FBQ2YsSUFBSSxFQUFFLEVBQUUsS0FBSyxFQUFFLE9BQU8sQ0FBQyxJQUFJLENBQUMsS0FBSyxFQUFFLE1BQU0sRUFBRSxTQUFTLEVBQUU7S0FDMUMsQ0FBQztJQUNqQixNQUFNLElBQUksR0FBRyxVQUFVLENBQUMsUUFBUSxDQUFDLEtBQUssRUFBRSxPQUFPLENBQUMsQ0FBQztJQUNqRCxVQUFVLENBQUMsT0FBTyxDQUFDLEtBQUssRUFBRSxVQUFVLEVBQUUsSUFBSSxDQUFDLENBQUM7QUFDaEQsQ0FBQyxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sV0FBVyxHQUFHLENBQUMsS0FBaUIsRUFBRSxPQUErQixFQUFFLFNBQW9CLEVBQUUsRUFBRTtJQUNwRyxNQUFNLE1BQU0sR0FBRyxPQUFPLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxLQUFLLEtBQUssU0FBUyxDQUFDLENBQUM7SUFDeEUsTUFBTSxVQUFVLEdBQUc7UUFDZixJQUFJLEVBQUUsRUFBRSxLQUFLLEVBQUUsT0FBTyxDQUFDLElBQUksQ0FBQyxLQUFLLEVBQUU7S0FDdkIsQ0FBQztJQUNqQixJQUFJLE1BQU0sQ0FBQyxNQUFNLEdBQUcsQ0FBQyxFQUFFO1FBQ25CLFVBQVUsQ0FBQyxJQUFJLENBQUMsTUFBTSxHQUFHLE1BQU0sQ0FBQztLQUNuQztJQUNELE1BQU0sSUFBSSxHQUFHLFVBQVUsQ0FBQyxRQUFRLENBQUMsS0FBSyxFQUFFLE9BQU8sQ0FBQyxDQUFDO0lBQ2pELFVBQVUsQ0FBQyxPQUFPLENBQUMsS0FBSyxFQUFFLFVBQVUsRUFBRSxJQUFJLENBQUMsQ0FBQztBQUNoRCxDQUFDLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxZQUFZLEdBQUcsQ0FBQyxLQUFpQixFQUFFLE9BQStCLEVBQUUsUUFBbUIsRUFBRSxRQUFtQixFQUFFLEVBQUU7SUFDekgsTUFBTSxVQUFVLEdBQUc7UUFDZixJQUFJLEVBQUUsRUFBRSxLQUFLLEVBQUUsT0FBTyxDQUFDLElBQUksQ0FBQyxLQUFLLEVBQUU7S0FDdkIsQ0FBQztJQUNqQixNQUFNLFNBQVMsR0FBRyxPQUFPLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLEVBQUU7UUFDOUMsSUFBSSxLQUFLLEtBQUssUUFBUSxFQUFFO1lBQ3BCLE9BQU8sUUFBUSxDQUFDO1NBQ25CO1FBQ0QsT0FBTyxLQUFLLENBQUM7SUFDakIsQ0FBQyxDQUFDLENBQUM7SUFDSCxVQUFVLENBQUMsSUFBSSxDQUFDLE1BQU0sR0FBRyxTQUFTLENBQUM7SUFDbkMsTUFBTSxJQUFJLEdBQUcsVUFBVSxDQUFDLFFBQVEsQ0FBQyxLQUFLLEVBQUUsT0FBTyxDQUFDLENBQUM7SUFDakQsVUFBVSxDQUFDLE9BQU8sQ0FBQyxLQUFLLEVBQUUsVUFBVSxFQUFFLElBQUksQ0FBQyxDQUFDO0FBQ2hELENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE1pbmRFbGVtZW50IH0gZnJvbSAnLi4vaW50ZXJmYWNlcy9lbGVtZW50JztcbmltcG9ydCB7IFBsYWl0Qm9hcmQsIFRyYW5zZm9ybXMgfSBmcm9tICdAcGxhaXQvY29yZSc7XG5pbXBvcnQgeyBFbW9qaURhdGEsIEVtb2ppSXRlbSB9IGZyb20gJy4uL2ludGVyZmFjZXMvZWxlbWVudC1kYXRhJztcblxuZXhwb3J0IGNvbnN0IGFkZEVtb2ppID0gKGJvYXJkOiBQbGFpdEJvYXJkLCBlbGVtZW50OiBNaW5kRWxlbWVudCwgZW1vamlJdGVtOiBFbW9qaUl0ZW0pID0+IHtcbiAgICBjb25zdCBlbW9qaXMgPSBlbGVtZW50LmRhdGEuZW1vamlzIHx8IFtdO1xuICAgIGNvbnN0IG5ld0Vtb2ppcyA9IFsuLi5lbW9qaXNdO1xuICAgIG5ld0Vtb2ppcy5wdXNoKGVtb2ppSXRlbSk7XG4gICAgY29uc3QgbmV3RWxlbWVudCA9IHtcbiAgICAgICAgZGF0YTogeyB0b3BpYzogZWxlbWVudC5kYXRhLnRvcGljLCBlbW9qaXM6IG5ld0Vtb2ppcyB9XG4gICAgfSBhcyBNaW5kRWxlbWVudDtcbiAgICBjb25zdCBwYXRoID0gUGxhaXRCb2FyZC5maW5kUGF0aChib2FyZCwgZWxlbWVudCk7XG4gICAgVHJhbnNmb3Jtcy5zZXROb2RlKGJvYXJkLCBuZXdFbGVtZW50LCBwYXRoKTtcbn07XG5cbmV4cG9ydCBjb25zdCByZW1vdmVFbW9qaSA9IChib2FyZDogUGxhaXRCb2FyZCwgZWxlbWVudDogTWluZEVsZW1lbnQ8RW1vamlEYXRhPiwgZW1vamlJdGVtOiBFbW9qaUl0ZW0pID0+IHtcbiAgICBjb25zdCBlbW9qaXMgPSBlbGVtZW50LmRhdGEuZW1vamlzLmZpbHRlcih2YWx1ZSA9PiB2YWx1ZSAhPT0gZW1vamlJdGVtKTtcbiAgICBjb25zdCBuZXdFbGVtZW50ID0ge1xuICAgICAgICBkYXRhOiB7IHRvcGljOiBlbGVtZW50LmRhdGEudG9waWMgfVxuICAgIH0gYXMgTWluZEVsZW1lbnQ7XG4gICAgaWYgKGVtb2ppcy5sZW5ndGggPiAwKSB7XG4gICAgICAgIG5ld0VsZW1lbnQuZGF0YS5lbW9qaXMgPSBlbW9qaXM7XG4gICAgfVxuICAgIGNvbnN0IHBhdGggPSBQbGFpdEJvYXJkLmZpbmRQYXRoKGJvYXJkLCBlbGVtZW50KTtcbiAgICBUcmFuc2Zvcm1zLnNldE5vZGUoYm9hcmQsIG5ld0VsZW1lbnQsIHBhdGgpO1xufTtcblxuZXhwb3J0IGNvbnN0IHJlcGxhY2VFbW9qaSA9IChib2FyZDogUGxhaXRCb2FyZCwgZWxlbWVudDogTWluZEVsZW1lbnQ8RW1vamlEYXRhPiwgb2xkRW1vamk6IEVtb2ppSXRlbSwgbmV3RW1vamk6IEVtb2ppSXRlbSkgPT4ge1xuICAgIGNvbnN0IG5ld0VsZW1lbnQgPSB7XG4gICAgICAgIGRhdGE6IHsgdG9waWM6IGVsZW1lbnQuZGF0YS50b3BpYyB9XG4gICAgfSBhcyBNaW5kRWxlbWVudDtcbiAgICBjb25zdCBuZXdFbW9qaXMgPSBlbGVtZW50LmRhdGEuZW1vamlzLm1hcCh2YWx1ZSA9PiB7XG4gICAgICAgIGlmICh2YWx1ZSA9PT0gb2xkRW1vamkpIHtcbiAgICAgICAgICAgIHJldHVybiBuZXdFbW9qaTtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gdmFsdWU7XG4gICAgfSk7XG4gICAgbmV3RWxlbWVudC5kYXRhLmVtb2ppcyA9IG5ld0Vtb2ppcztcbiAgICBjb25zdCBwYXRoID0gUGxhaXRCb2FyZC5maW5kUGF0aChib2FyZCwgZWxlbWVudCk7XG4gICAgVHJhbnNmb3Jtcy5zZXROb2RlKGJvYXJkLCBuZXdFbGVtZW50LCBwYXRoKTtcbn07XG4iXX0=
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { insertAbstract, setAbstractsByRefs, setAbstractByStandardLayout } from './abstract-node';
|
|
2
2
|
import { setLayout } from './layout';
|
|
3
|
-
import {
|
|
3
|
+
import { setTopic, setTopicSize, removeElements, insertNodes, insertAbstractNodes } from './node';
|
|
4
|
+
import { addEmoji, removeEmoji, replaceEmoji } from './emoji';
|
|
4
5
|
export const MindTransforms = {
|
|
5
6
|
setLayout,
|
|
6
7
|
setTopic,
|
|
@@ -10,6 +11,9 @@ export const MindTransforms = {
|
|
|
10
11
|
replaceEmoji,
|
|
11
12
|
insertAbstract,
|
|
12
13
|
setAbstractsByRefs,
|
|
13
|
-
setAbstractByStandardLayout
|
|
14
|
+
setAbstractByStandardLayout,
|
|
15
|
+
removeElements,
|
|
16
|
+
insertNodes,
|
|
17
|
+
insertAbstractNodes
|
|
14
18
|
};
|
|
15
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9taW5kL3NyYy90cmFuc2Zvcm1zL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxjQUFjLEVBQUUsa0JBQWtCLEVBQUUsMkJBQTJCLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUNsRyxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sVUFBVSxDQUFDO0FBQ3JDLE9BQU8sRUFBRSxRQUFRLEVBQUUsWUFBWSxFQUFFLGNBQWMsRUFBRSxXQUFXLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxRQUFRLENBQUM7QUFDbEcsT0FBTyxFQUFFLFFBQVEsRUFBRSxXQUFXLEVBQUUsWUFBWSxFQUFFLE1BQU0sU0FBUyxDQUFDO0FBRTlELE1BQU0sQ0FBQyxNQUFNLGNBQWMsR0FBRztJQUMxQixTQUFTO0lBQ1QsUUFBUTtJQUNSLFlBQVk7SUFDWixRQUFRO0lBQ1IsV0FBVztJQUNYLFlBQVk7SUFDWixjQUFjO0lBQ2Qsa0JBQWtCO0lBQ2xCLDJCQUEyQjtJQUMzQixjQUFjO0lBQ2QsV0FBVztJQUNYLG1CQUFtQjtDQUN0QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgaW5zZXJ0QWJzdHJhY3QsIHNldEFic3RyYWN0c0J5UmVmcywgc2V0QWJzdHJhY3RCeVN0YW5kYXJkTGF5b3V0IH0gZnJvbSAnLi9hYnN0cmFjdC1ub2RlJztcbmltcG9ydCB7IHNldExheW91dCB9IGZyb20gJy4vbGF5b3V0JztcbmltcG9ydCB7IHNldFRvcGljLCBzZXRUb3BpY1NpemUsIHJlbW92ZUVsZW1lbnRzLCBpbnNlcnROb2RlcywgaW5zZXJ0QWJzdHJhY3ROb2RlcyB9IGZyb20gJy4vbm9kZSc7XG5pbXBvcnQgeyBhZGRFbW9qaSwgcmVtb3ZlRW1vamksIHJlcGxhY2VFbW9qaSB9IGZyb20gJy4vZW1vamknO1xuXG5leHBvcnQgY29uc3QgTWluZFRyYW5zZm9ybXMgPSB7XG4gICAgc2V0TGF5b3V0LFxuICAgIHNldFRvcGljLFxuICAgIHNldFRvcGljU2l6ZSxcbiAgICBhZGRFbW9qaSxcbiAgICByZW1vdmVFbW9qaSxcbiAgICByZXBsYWNlRW1vamksXG4gICAgaW5zZXJ0QWJzdHJhY3QsXG4gICAgc2V0QWJzdHJhY3RzQnlSZWZzLFxuICAgIHNldEFic3RyYWN0QnlTdGFuZGFyZExheW91dCxcbiAgICByZW1vdmVFbGVtZW50cyxcbiAgICBpbnNlcnROb2RlcyxcbiAgICBpbnNlcnRBYnN0cmFjdE5vZGVzXG59O1xuIl19
|
|
@@ -1,6 +1,9 @@
|
|
|
1
|
+
import { Path } from 'slate';
|
|
1
2
|
import { MindElement } from '../interfaces/element';
|
|
2
3
|
import { NODE_MIN_WIDTH } from '../constants/node-rule';
|
|
3
|
-
import { PlaitBoard, Transforms } from '@plait/core';
|
|
4
|
+
import { PlaitBoard, PlaitNode, Transforms } from '@plait/core';
|
|
5
|
+
import { changeRightNodeCount, getFirstLevelElement, isInRightBranchOfStandardLayout } from '../utils/mind';
|
|
6
|
+
import { getRelativeStartEndByAbstractRef } from '../utils/abstract/common';
|
|
4
7
|
export const setTopic = (board, element, topic, width, height) => {
|
|
5
8
|
const newElement = {
|
|
6
9
|
data: { topic },
|
|
@@ -21,39 +24,43 @@ export const setTopicSize = (board, element, width, height) => {
|
|
|
21
24
|
const path = PlaitBoard.findPath(board, element);
|
|
22
25
|
Transforms.setNode(board, newElement, path);
|
|
23
26
|
};
|
|
24
|
-
export const
|
|
25
|
-
const
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
}
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
newElement.data.emojis = emojis;
|
|
41
|
-
}
|
|
42
|
-
const path = PlaitBoard.findPath(board, element);
|
|
43
|
-
Transforms.setNode(board, newElement, path);
|
|
27
|
+
export const removeElements = (board, elements) => {
|
|
28
|
+
const deletableElements = getFirstLevelElement(elements).reverse();
|
|
29
|
+
//翻转,从下到上修改,防止找不到 path
|
|
30
|
+
deletableElements
|
|
31
|
+
.map(element => {
|
|
32
|
+
const path = PlaitBoard.findPath(board, element);
|
|
33
|
+
return () => {
|
|
34
|
+
if (isInRightBranchOfStandardLayout(element)) {
|
|
35
|
+
changeRightNodeCount(board, path.slice(0, 1), -1);
|
|
36
|
+
}
|
|
37
|
+
Transforms.removeNode(board, path);
|
|
38
|
+
};
|
|
39
|
+
})
|
|
40
|
+
.forEach(action => {
|
|
41
|
+
action();
|
|
42
|
+
});
|
|
44
43
|
};
|
|
45
|
-
export const
|
|
46
|
-
const
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
if (value === oldEmoji) {
|
|
51
|
-
return newEmoji;
|
|
44
|
+
export const insertNodes = (board, elements, path) => {
|
|
45
|
+
const pathRef = board.pathRef(path);
|
|
46
|
+
elements.forEach(element => {
|
|
47
|
+
if (pathRef.current) {
|
|
48
|
+
Transforms.insertNode(board, element, pathRef.current);
|
|
52
49
|
}
|
|
53
|
-
return value;
|
|
54
50
|
});
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
51
|
+
pathRef.unref();
|
|
52
|
+
};
|
|
53
|
+
export const insertAbstractNodes = (board, validAbstractRefs, elements, path) => {
|
|
54
|
+
const parent = PlaitNode.get(board, Path.parent(path));
|
|
55
|
+
const abstractPath = [...Path.parent(path), parent.children?.length];
|
|
56
|
+
const abstracts = validAbstractRefs.map(refs => {
|
|
57
|
+
const { start, end } = getRelativeStartEndByAbstractRef(refs, elements);
|
|
58
|
+
return {
|
|
59
|
+
...refs.abstract,
|
|
60
|
+
start: start + path[path.length - 1],
|
|
61
|
+
end: end + path[path.length - 1]
|
|
62
|
+
};
|
|
63
|
+
});
|
|
64
|
+
insertNodes(board, abstracts, abstractPath);
|
|
58
65
|
};
|
|
59
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
66
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node.js","sourceRoot":"","sources":["../../../../packages/mind/src/transforms/node.ts"],"names":[],"mappings":"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","sourcesContent":["import { Element, Path } from 'slate';\nimport { MindElement } from '../interfaces/element';\nimport { NODE_MIN_WIDTH } from '../constants/node-rule';\nimport { PlaitBoard, PlaitNode, Transforms } from '@plait/core';\nimport { changeRightNodeCount, getFirstLevelElement, isInRightBranchOfStandardLayout } from '../utils/mind';\nimport { AbstractRef, getRelativeStartEndByAbstractRef } from '../utils/abstract/common';\n\nexport const setTopic = (board: PlaitBoard, element: MindElement, topic: Element, width: number, height: number) => {\n    const newElement = {\n        data: { topic },\n        width: width < NODE_MIN_WIDTH * board.viewport.zoom ? NODE_MIN_WIDTH : width / board.viewport.zoom,\n        height: height / board.viewport.zoom\n    } as MindElement;\n    if (MindElement.hasEmojis(element)) {\n        newElement.data.emojis = element.data.emojis;\n    }\n    const path = PlaitBoard.findPath(board, element);\n    Transforms.setNode(board, newElement, path);\n};\n\nexport const setTopicSize = (board: PlaitBoard, element: MindElement, width: number, height: number) => {\n    const newElement = {\n        width: width < NODE_MIN_WIDTH * board.viewport.zoom ? NODE_MIN_WIDTH : width / board.viewport.zoom,\n        height: height / board.viewport.zoom\n    };\n    const path = PlaitBoard.findPath(board, element);\n    Transforms.setNode(board, newElement, path);\n};\n\nexport const removeElements = (board: PlaitBoard, elements: MindElement[]) => {\n    const deletableElements = getFirstLevelElement(elements).reverse();\n\n    //翻转，从下到上修改，防止找不到 path\n    deletableElements\n        .map(element => {\n            const path = PlaitBoard.findPath(board, element);\n            return () => {\n                if (isInRightBranchOfStandardLayout(element)) {\n                    changeRightNodeCount(board, path.slice(0, 1), -1);\n                }\n                Transforms.removeNode(board, path);\n            };\n        })\n        .forEach(action => {\n            action();\n        });\n};\n\nexport const insertNodes = (board: PlaitBoard, elements: MindElement[], path: Path) => {\n    const pathRef = board.pathRef(path);\n    elements.forEach(element => {\n        if (pathRef.current) {\n            Transforms.insertNode(board, element, pathRef.current);\n        }\n    });\n    pathRef.unref();\n};\n\nexport const insertAbstractNodes = (board: PlaitBoard, validAbstractRefs: AbstractRef[], elements: MindElement[], path: Path) => {\n    const parent = PlaitNode.get(board, Path.parent(path));\n    const abstractPath = [...Path.parent(path), parent.children?.length!];\n    const abstracts = validAbstractRefs.map(refs => {\n        const { start, end } = getRelativeStartEndByAbstractRef(refs, elements);\n        return {\n            ...refs.abstract,\n            start: start + path[path.length - 1],\n            end: end + path[path.length - 1]\n        };\n    });\n\n    insertNodes(board, abstracts, abstractPath);\n};\n"]}
|