@plait/mind 0.27.0-next.1 → 0.27.0-next.10
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/base/emoji-base.component.d.ts +2 -2
- package/base/index.d.ts +0 -1
- package/constants/default.d.ts +1 -0
- package/constants/node-topic-style.d.ts +4 -0
- package/drawer/{node-active.drawer.d.ts → node-active.generator.d.ts} +2 -2
- package/drawer/node-shape.generator.d.ts +10 -0
- package/esm2022/base/emoji-base.component.mjs +46 -0
- package/{esm2020 → esm2022}/base/index.mjs +1 -2
- package/{esm2020 → esm2022}/constants/abstract-node.mjs +1 -1
- package/{esm2020 → esm2022}/constants/default.mjs +2 -1
- package/{esm2020 → esm2022}/constants/index.mjs +1 -1
- package/esm2022/constants/node-topic-style.mjs +12 -0
- package/esm2022/drawer/node-active.generator.mjs +42 -0
- package/esm2022/drawer/node-shape.generator.mjs +19 -0
- package/esm2022/interfaces/element-data.mjs +2 -0
- package/esm2022/interfaces/element.mjs +118 -0
- package/{esm2020 → esm2022}/interfaces/index.mjs +2 -1
- package/esm2022/interfaces/options.mjs +2 -0
- package/{esm2020 → esm2022}/interfaces/theme-color.mjs +1 -1
- package/esm2022/mind-node.component.mjs +235 -0
- package/esm2022/mind.component.mjs +52 -0
- package/esm2022/plugins/with-abstract-resize.mjs +112 -0
- package/esm2022/plugins/with-mind-create.mjs +112 -0
- package/esm2022/plugins/with-mind-fragment.mjs +90 -0
- package/esm2022/plugins/with-mind-hotkey.mjs +67 -0
- package/esm2022/plugins/with-mind.mjs +91 -0
- package/esm2022/plugins/with-node-dnd.mjs +180 -0
- package/esm2022/plugins/with-node-image.mjs +98 -0
- package/esm2022/plugins/with-node-resize.mjs +133 -0
- package/{esm2020 → esm2022}/public-api.mjs +2 -3
- package/{esm2020 → esm2022}/transforms/image.mjs +1 -1
- package/esm2022/transforms/index.mjs +23 -0
- package/esm2022/transforms/node.mjs +66 -0
- package/{esm2020 → esm2022}/utils/abstract/common.mjs +2 -2
- package/{esm2020 → esm2022}/utils/abstract/resize.mjs +3 -3
- package/{esm2020 → esm2022}/utils/clipboard.mjs +3 -3
- package/{esm2020 → esm2022}/utils/dnd/common.mjs +1 -1
- package/esm2022/utils/draw/abstract-outline.mjs +117 -0
- package/esm2022/utils/draw/node-dnd.mjs +159 -0
- package/{esm2020 → esm2022}/utils/draw/node-shape.mjs +4 -3
- package/{esm2020 → esm2022}/utils/node/common.mjs +1 -1
- package/esm2022/utils/node/create-node.mjs +55 -0
- package/esm2022/utils/node/dynamic-width.mjs +19 -0
- package/esm2022/utils/node/image.mjs +23 -0
- package/esm2022/utils/position/node.mjs +36 -0
- package/esm2022/utils/position/topic.mjs +16 -0
- package/{esm2020 → esm2022}/utils/space/index.mjs +1 -1
- package/esm2022/utils/space/layout-options.mjs +69 -0
- package/esm2022/utils/space/node-space.mjs +137 -0
- package/{fesm2020 → fesm2022}/plait-mind.mjs +1384 -1550
- package/fesm2022/plait-mind.mjs.map +1 -0
- package/interfaces/element-data.d.ts +5 -9
- package/interfaces/element.d.ts +1 -0
- package/interfaces/index.d.ts +1 -0
- package/interfaces/options.d.ts +2 -4
- package/{node.component.d.ts → mind-node.component.d.ts} +11 -10
- package/mind.component.d.ts +2 -2
- package/package.json +7 -13
- package/plugins/with-mind-fragment.d.ts +5 -0
- package/plugins/with-mind-hotkey.d.ts +0 -2
- package/public-api.d.ts +1 -2
- package/styles/styles.scss +7 -3
- package/transforms/image.d.ts +3 -2
- package/transforms/index.d.ts +1 -2
- package/transforms/node.d.ts +0 -1
- package/utils/abstract/common.d.ts +2 -2
- package/utils/node/create-node.d.ts +2 -2
- package/utils/node/image.d.ts +0 -2
- package/utils/position/node.d.ts +1 -1
- package/utils/space/layout-options.d.ts +2 -2
- package/utils/space/node-space.d.ts +1 -5
- package/base/image-base.component.d.ts +0 -28
- package/constants/image.d.ts +0 -3
- package/drawer/node-image.drawer.d.ts +0 -15
- package/esm2020/base/emoji-base.component.mjs +0 -46
- package/esm2020/base/image-base.component.mjs +0 -72
- package/esm2020/constants/image.mjs +0 -4
- package/esm2020/constants/node-topic-style.mjs +0 -8
- package/esm2020/drawer/node-active.drawer.mjs +0 -44
- package/esm2020/drawer/node-image.drawer.mjs +0 -59
- package/esm2020/interfaces/element-data.mjs +0 -2
- package/esm2020/interfaces/element.mjs +0 -111
- package/esm2020/interfaces/options.mjs +0 -2
- package/esm2020/mind.component.mjs +0 -51
- package/esm2020/mind.module.mjs +0 -21
- package/esm2020/node.component.mjs +0 -248
- package/esm2020/plugins/with-abstract-resize.mjs +0 -112
- package/esm2020/plugins/with-mind-create.mjs +0 -109
- package/esm2020/plugins/with-mind-hotkey.mjs +0 -109
- package/esm2020/plugins/with-mind.mjs +0 -114
- package/esm2020/plugins/with-node-dnd.mjs +0 -180
- package/esm2020/plugins/with-node-image.mjs +0 -96
- package/esm2020/plugins/with-node-resize.mjs +0 -133
- package/esm2020/transforms/index.mjs +0 -24
- package/esm2020/transforms/node.mjs +0 -82
- package/esm2020/utils/draw/abstract-outline.mjs +0 -117
- package/esm2020/utils/draw/node-dnd.mjs +0 -159
- package/esm2020/utils/node/create-node.mjs +0 -52
- package/esm2020/utils/node/dynamic-width.mjs +0 -22
- package/esm2020/utils/node/image.mjs +0 -63
- package/esm2020/utils/position/node.mjs +0 -34
- package/esm2020/utils/position/topic.mjs +0 -17
- package/esm2020/utils/space/layout-options.mjs +0 -72
- package/esm2020/utils/space/node-space.mjs +0 -142
- package/fesm2015/plait-mind.mjs +0 -4382
- package/fesm2015/plait-mind.mjs.map +0 -1
- package/fesm2020/plait-mind.mjs.map +0 -1
- package/mind.module.d.ts +0 -11
- /package/{esm2020 → esm2022}/base/base.drawer.mjs +0 -0
- /package/{esm2020 → esm2022}/constants/node-style.mjs +0 -0
- /package/{esm2020 → esm2022}/constants/theme.mjs +0 -0
- /package/{esm2020 → esm2022}/drawer/node-collapse.drawer.mjs +0 -0
- /package/{esm2020 → esm2022}/drawer/node-emojis.drawer.mjs +0 -0
- /package/{esm2020 → esm2022}/drawer/node-insert.drawer.mjs +0 -0
- /package/{esm2020 → esm2022}/interfaces/layout.mjs +0 -0
- /package/{esm2020 → esm2022}/interfaces/node.mjs +0 -0
- /package/{esm2020 → esm2022}/interfaces/pointer.mjs +0 -0
- /package/{esm2020 → esm2022}/interfaces/types.mjs +0 -0
- /package/{esm2020 → esm2022}/plait-mind.mjs +0 -0
- /package/{esm2020 → esm2022}/plugins/with-abstract-resize.board.mjs +0 -0
- /package/{esm2020 → esm2022}/plugins/with-mind-extend.mjs +0 -0
- /package/{esm2020 → esm2022}/plugins/with-mind.board.mjs +0 -0
- /package/{esm2020 → esm2022}/plugins/with-node-hover-detect.mjs +0 -0
- /package/{esm2020 → esm2022}/plugins/with-node-image-resize.mjs +0 -0
- /package/{esm2020 → esm2022}/queries/get-available-sublayouts-by-element.mjs +0 -0
- /package/{esm2020 → esm2022}/queries/get-branch-layouts.mjs +0 -0
- /package/{esm2020 → esm2022}/queries/get-correct-layout-by-element.mjs +0 -0
- /package/{esm2020 → esm2022}/queries/get-layout-by-element.mjs +0 -0
- /package/{esm2020 → esm2022}/queries/index.mjs +0 -0
- /package/{esm2020 → esm2022}/transforms/abstract-node.mjs +0 -0
- /package/{esm2020 → esm2022}/transforms/emoji.mjs +0 -0
- /package/{esm2020 → esm2022}/transforms/layout.mjs +0 -0
- /package/{esm2020 → esm2022}/utils/dnd/detector.mjs +0 -0
- /package/{esm2020 → esm2022}/utils/draw/node-link/abstract-link.mjs +0 -0
- /package/{esm2020 → esm2022}/utils/draw/node-link/draw-link.mjs +0 -0
- /package/{esm2020 → esm2022}/utils/draw/node-link/indented-link.mjs +0 -0
- /package/{esm2020 → esm2022}/utils/draw/node-link/logic-link.mjs +0 -0
- /package/{esm2020 → esm2022}/utils/index.mjs +0 -0
- /package/{esm2020 → esm2022}/utils/layout.mjs +0 -0
- /package/{esm2020 → esm2022}/utils/mind.mjs +0 -0
- /package/{esm2020 → esm2022}/utils/node/adjust-node.mjs +0 -0
- /package/{esm2020 → esm2022}/utils/node/index.mjs +0 -0
- /package/{esm2020 → esm2022}/utils/node/right-node-count.mjs +0 -0
- /package/{esm2020 → esm2022}/utils/node-hover/extend.mjs +0 -0
- /package/{esm2020 → esm2022}/utils/node-style/branch.mjs +0 -0
- /package/{esm2020 → esm2022}/utils/node-style/common.mjs +0 -0
- /package/{esm2020 → esm2022}/utils/node-style/index.mjs +0 -0
- /package/{esm2020 → esm2022}/utils/node-style/shape.mjs +0 -0
- /package/{esm2020 → esm2022}/utils/path.mjs +0 -0
- /package/{esm2020 → esm2022}/utils/point-placement.mjs +0 -0
- /package/{esm2020 → esm2022}/utils/position/emoji.mjs +0 -0
- /package/{esm2020 → esm2022}/utils/position/image.mjs +0 -0
- /package/{esm2020 → esm2022}/utils/position/index.mjs +0 -0
- /package/{esm2020 → esm2022}/utils/space/emoji.mjs +0 -0
- /package/{esm2020 → esm2022}/utils/weak-maps.mjs +0 -0
|
@@ -1,180 +0,0 @@
|
|
|
1
|
-
import { distanceBetweenPointAndPoint, Path, PlaitBoard, toPoint, transformPoint, Transforms, getSelectedElements, depthFirstRecursion, createG, PlaitNode, PlaitPointerType, getHitElements, isMainPointer } from '@plait/core';
|
|
2
|
-
import { AbstractNode, getNonAbstractChildren } from '@plait/layouts';
|
|
3
|
-
import { MindElement } from '../interfaces/element';
|
|
4
|
-
import { deleteElementHandleAbstract, deleteElementsHandleRightNodeCount, getCorrespondingAbstract, getFirstLevelElement, getOverallAbstracts, getValidAbstractRefs, insertElementHandleAbstract, insertElementHandleRightNodeCount } from '../utils';
|
|
5
|
-
import { addActiveOnDragOrigin, isDragging, isDropStandardRight, removeActiveOnDragOrigin, setIsDragging } from '../utils/dnd/common';
|
|
6
|
-
import { detectDropTarget, getPathByDropTarget } from '../utils/dnd/detector';
|
|
7
|
-
import { drawFakeDragNode, drawFakeDropNode } from '../utils/draw/node-dnd';
|
|
8
|
-
import { MindTransforms } from '../transforms';
|
|
9
|
-
import { adjustAbstractToNode } from '../utils/node/adjust-node';
|
|
10
|
-
const DRAG_MOVE_BUFFER = 5;
|
|
11
|
-
export const withNodeDnd = (board) => {
|
|
12
|
-
const { pointerDown, pointerMove, globalPointerUp } = board;
|
|
13
|
-
let activeElements = [];
|
|
14
|
-
let correspondingElements = [];
|
|
15
|
-
let startPoint;
|
|
16
|
-
let dragFakeNodeG;
|
|
17
|
-
let fakeDropNodeG;
|
|
18
|
-
let dropTarget = null;
|
|
19
|
-
let targetPath;
|
|
20
|
-
board.pointerDown = (event) => {
|
|
21
|
-
if (PlaitBoard.isReadonly(board) ||
|
|
22
|
-
PlaitBoard.hasBeenTextEditing(board) ||
|
|
23
|
-
!PlaitBoard.isPointer(board, PlaitPointerType.selection) ||
|
|
24
|
-
!isMainPointer(event)) {
|
|
25
|
-
pointerDown(event);
|
|
26
|
-
return;
|
|
27
|
-
}
|
|
28
|
-
const point = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));
|
|
29
|
-
const selectedElements = getSelectedElements(board);
|
|
30
|
-
const hitTarget = getHitElements(board, { ranges: [{ anchor: point, focus: point }] }, (element) => {
|
|
31
|
-
return MindElement.isMindElement(board, element);
|
|
32
|
-
});
|
|
33
|
-
const targetElement = hitTarget && hitTarget.length === 1 ? hitTarget[0] : null;
|
|
34
|
-
if (targetElement &&
|
|
35
|
-
MindElement.isMindElement(board, targetElement) &&
|
|
36
|
-
!targetElement.isRoot &&
|
|
37
|
-
!AbstractNode.isAbstract(targetElement)) {
|
|
38
|
-
const targetElements = selectedElements.filter(element => MindElement.isMindElement(board, element) && !element.isRoot && !AbstractNode.isAbstract(element));
|
|
39
|
-
const isMultiple = selectedElements.length > 0 && selectedElements.includes(targetElement);
|
|
40
|
-
if (isMultiple) {
|
|
41
|
-
activeElements = targetElements;
|
|
42
|
-
startPoint = point;
|
|
43
|
-
}
|
|
44
|
-
else {
|
|
45
|
-
activeElements = [targetElement];
|
|
46
|
-
startPoint = point;
|
|
47
|
-
}
|
|
48
|
-
}
|
|
49
|
-
if (activeElements.length) {
|
|
50
|
-
correspondingElements = getOverallAbstracts(board, activeElements);
|
|
51
|
-
}
|
|
52
|
-
pointerDown(event);
|
|
53
|
-
};
|
|
54
|
-
board.pointerMove = (event) => {
|
|
55
|
-
if (!board.options.readonly && activeElements?.length && startPoint) {
|
|
56
|
-
// prevent text from being selected
|
|
57
|
-
event.preventDefault();
|
|
58
|
-
const endPoint = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));
|
|
59
|
-
const distance = distanceBetweenPointAndPoint(startPoint[0], startPoint[1], endPoint[0], endPoint[1]);
|
|
60
|
-
if (distance < DRAG_MOVE_BUFFER) {
|
|
61
|
-
return;
|
|
62
|
-
}
|
|
63
|
-
setIsDragging(board, true);
|
|
64
|
-
fakeDropNodeG?.remove();
|
|
65
|
-
const detectPoint = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));
|
|
66
|
-
dropTarget = detectDropTarget(board, detectPoint, dropTarget, [...activeElements, ...correspondingElements]);
|
|
67
|
-
if (dropTarget?.target) {
|
|
68
|
-
targetPath = getPathByDropTarget(board, dropTarget);
|
|
69
|
-
fakeDropNodeG = drawFakeDropNode(board, dropTarget, targetPath);
|
|
70
|
-
PlaitBoard.getHost(board).appendChild(fakeDropNodeG);
|
|
71
|
-
}
|
|
72
|
-
const offsetX = endPoint[0] - startPoint[0];
|
|
73
|
-
const offsetY = endPoint[1] - startPoint[1];
|
|
74
|
-
dragFakeNodeG?.remove();
|
|
75
|
-
dragFakeNodeG = createG();
|
|
76
|
-
[...activeElements, ...correspondingElements].forEach(element => {
|
|
77
|
-
addActiveOnDragOrigin(element);
|
|
78
|
-
});
|
|
79
|
-
activeElements.forEach(element => {
|
|
80
|
-
const nodeG = drawFakeDragNode(board, element, offsetX, offsetY);
|
|
81
|
-
dragFakeNodeG?.appendChild(nodeG);
|
|
82
|
-
});
|
|
83
|
-
PlaitBoard.getHost(board).appendChild(dragFakeNodeG);
|
|
84
|
-
}
|
|
85
|
-
pointerMove(event);
|
|
86
|
-
};
|
|
87
|
-
board.globalPointerUp = (event) => {
|
|
88
|
-
const firstLevelElements = getFirstLevelElement(activeElements);
|
|
89
|
-
if (!board.options.readonly && firstLevelElements.length) {
|
|
90
|
-
firstLevelElements.push(...correspondingElements);
|
|
91
|
-
if (isDragging(board)) {
|
|
92
|
-
firstLevelElements.forEach(element => {
|
|
93
|
-
removeActiveOnDragOrigin(element);
|
|
94
|
-
});
|
|
95
|
-
}
|
|
96
|
-
if (dropTarget) {
|
|
97
|
-
const targetPathRef = board.pathRef(targetPath);
|
|
98
|
-
const targetPreviousPathRef = Path.hasPrevious(targetPath) && board.pathRef(Path.previous(targetPath));
|
|
99
|
-
const targetElementPathRef = board.pathRef(PlaitBoard.findPath(board, dropTarget.target));
|
|
100
|
-
let abstractRefs = getValidAbstractRefs(board, firstLevelElements);
|
|
101
|
-
const normalElements = firstLevelElements
|
|
102
|
-
.filter(element => !abstractRefs.some(refs => refs.abstract === element))
|
|
103
|
-
.map(element => {
|
|
104
|
-
if (AbstractNode.isAbstract(element)) {
|
|
105
|
-
return adjustAbstractToNode(element);
|
|
106
|
-
}
|
|
107
|
-
return element;
|
|
108
|
-
});
|
|
109
|
-
const hasPreviousNode = targetPath[targetPath.length - 1] !== 0;
|
|
110
|
-
if (hasPreviousNode) {
|
|
111
|
-
const previousElement = PlaitNode.get(board, Path.previous(targetPath));
|
|
112
|
-
const correspondingAbstract = getCorrespondingAbstract(previousElement);
|
|
113
|
-
const targetHasCorrespondAbstract = correspondingAbstract && correspondingAbstract.end !== targetPath[targetPath.length - 1] - 1;
|
|
114
|
-
if (targetHasCorrespondAbstract) {
|
|
115
|
-
const adjustedNode = abstractRefs.map(ref => {
|
|
116
|
-
return adjustAbstractToNode(ref.abstract);
|
|
117
|
-
});
|
|
118
|
-
normalElements.push(...adjustedNode);
|
|
119
|
-
abstractRefs = [];
|
|
120
|
-
}
|
|
121
|
-
}
|
|
122
|
-
const effectedAbstracts = deleteElementHandleAbstract(board, firstLevelElements);
|
|
123
|
-
insertElementHandleAbstract(board, targetPath, normalElements.length, false, effectedAbstracts);
|
|
124
|
-
MindTransforms.setAbstractsByRefs(board, effectedAbstracts);
|
|
125
|
-
let refs = deleteElementsHandleRightNodeCount(board, firstLevelElements);
|
|
126
|
-
const parent = PlaitNode.get(board, Path.parent(targetPath));
|
|
127
|
-
const shouldChangeRoot = isDropStandardRight(parent, dropTarget);
|
|
128
|
-
if (shouldChangeRoot && targetElementPathRef.current) {
|
|
129
|
-
refs = insertElementHandleRightNodeCount(board, targetElementPathRef.current.slice(0, 1), normalElements.length, refs);
|
|
130
|
-
}
|
|
131
|
-
MindTransforms.setRightNodeCountByRefs(board, refs);
|
|
132
|
-
MindTransforms.removeElements(board, firstLevelElements);
|
|
133
|
-
let insertPath = targetPathRef.current;
|
|
134
|
-
const parentPath = Path.parent(targetPathRef.current || targetPath);
|
|
135
|
-
if (!insertPath) {
|
|
136
|
-
//当插入位置和选中节点位置相同时,使用记录的 previousPath
|
|
137
|
-
const previousPath = targetPreviousPathRef && targetPreviousPathRef.unref();
|
|
138
|
-
if (previousPath) {
|
|
139
|
-
insertPath = Path.next(previousPath);
|
|
140
|
-
}
|
|
141
|
-
else {
|
|
142
|
-
const parent = PlaitNode.get(board, parentPath);
|
|
143
|
-
const children = getNonAbstractChildren(parent);
|
|
144
|
-
insertPath = [...parentPath, children.length || 0];
|
|
145
|
-
}
|
|
146
|
-
}
|
|
147
|
-
MindTransforms.insertNodes(board, normalElements, insertPath);
|
|
148
|
-
if (abstractRefs.length) {
|
|
149
|
-
MindTransforms.insertAbstractNodes(board, abstractRefs, normalElements, insertPath);
|
|
150
|
-
}
|
|
151
|
-
if (targetElementPathRef.current &&
|
|
152
|
-
targetPathRef.current &&
|
|
153
|
-
Path.isAncestor(targetElementPathRef.current, targetPathRef.current) &&
|
|
154
|
-
dropTarget.target.isCollapsed) {
|
|
155
|
-
Transforms.setNode(board, { isCollapsed: false }, targetElementPathRef.current);
|
|
156
|
-
}
|
|
157
|
-
targetElementPathRef.unref();
|
|
158
|
-
targetPathRef.unref();
|
|
159
|
-
let setActiveElements = [];
|
|
160
|
-
depthFirstRecursion(board, node => {
|
|
161
|
-
const isSelected = activeElements.some(element => element.id === node.id);
|
|
162
|
-
if (isSelected) {
|
|
163
|
-
setActiveElements.push(node);
|
|
164
|
-
}
|
|
165
|
-
});
|
|
166
|
-
Transforms.setSelectionWithTemporaryElements(board, setActiveElements);
|
|
167
|
-
}
|
|
168
|
-
setIsDragging(board, false);
|
|
169
|
-
activeElements = [];
|
|
170
|
-
dragFakeNodeG?.remove();
|
|
171
|
-
dragFakeNodeG = undefined;
|
|
172
|
-
fakeDropNodeG?.remove();
|
|
173
|
-
fakeDropNodeG = undefined;
|
|
174
|
-
dropTarget = null;
|
|
175
|
-
}
|
|
176
|
-
globalPointerUp(event);
|
|
177
|
-
};
|
|
178
|
-
return board;
|
|
179
|
-
};
|
|
180
|
-
//# 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,IAAI,EACJ,UAAU,EAEV,OAAO,EACP,cAAc,EACd,UAAU,EACV,mBAAmB,EACnB,mBAAmB,EACnB,OAAO,EACP,SAAS,EACT,gBAAgB,EAChB,cAAc,EAEd,aAAa,EAChB,MAAM,aAAa,CAAC;AACrB,OAAO,EAAE,YAAY,EAAE,sBAAsB,EAAE,MAAM,gBAAgB,CAAC;AACtE,OAAO,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AAGpD,OAAO,EACH,2BAA2B,EAC3B,kCAAkC,EAClC,wBAAwB,EACxB,oBAAoB,EACpB,mBAAmB,EACnB,oBAAoB,EACpB,2BAA2B,EAC3B,iCAAiC,EACpC,MAAM,UAAU,CAAC;AAClB,OAAO,EAAE,qBAAqB,EAAE,UAAU,EAAE,mBAAmB,EAAE,wBAAwB,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AACtI,OAAO,EAAE,gBAAgB,EAAE,mBAAmB,EAAE,MAAM,uBAAuB,CAAC;AAC9E,OAAO,EAAE,gBAAgB,EAAE,gBAAgB,EAAE,MAAM,wBAAwB,CAAC;AAC5E,OAAO,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAC/C,OAAO,EAAE,oBAAoB,EAAE,MAAM,2BAA2B,CAAC;AAEjE,MAAM,gBAAgB,GAAG,CAAC,CAAC;AAE3B,MAAM,CAAC,MAAM,WAAW,GAAG,CAAC,KAAiB,EAAE,EAAE;IAC7C,MAAM,EAAE,WAAW,EAAE,WAAW,EAAE,eAAe,EAAE,GAAG,KAAK,CAAC;IAE5D,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,WAAW,GAAG,CAAC,KAAmB,EAAE,EAAE;QACxC,IACI,UAAU,CAAC,UAAU,CAAC,KAAK,CAAC;YAC5B,UAAU,CAAC,kBAAkB,CAAC,KAAK,CAAC;YACpC,CAAC,UAAU,CAAC,SAAS,CAAC,KAAK,EAAE,gBAAgB,CAAC,SAAS,CAAC;YACxD,CAAC,aAAa,CAAC,KAAK,CAAC,EACvB;YACE,WAAW,CAAC,KAAK,CAAC,CAAC;YACnB,OAAO;SACV;QAED,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,MAAM,SAAS,GAAG,cAAc,CAAC,KAAK,EAAE,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC,EAAE,EAAE,CAAC,OAAqB,EAAE,EAAE;YAC7G,OAAO,WAAW,CAAC,aAAa,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC;QACrD,CAAC,CAAC,CAAC;QAEH,MAAM,aAAa,GAAG,SAAS,IAAI,SAAS,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;QAChF,IACI,aAAa;YACb,WAAW,CAAC,aAAa,CAAC,KAAK,EAAE,aAAa,CAAC;YAC/C,CAAC,aAAa,CAAC,MAAM;YACrB,CAAC,YAAY,CAAC,UAAU,CAAC,aAAa,CAAC,EACzC;YACE,MAAM,cAAc,GAAG,gBAAgB,CAAC,MAAM,CAC1C,OAAO,CAAC,EAAE,CAAC,WAAW,CAAC,aAAa,CAAC,KAAK,EAAE,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC,OAAO,CAAC,CAC9F,CAAC;YACnB,MAAM,UAAU,GAAG,gBAAgB,CAAC,MAAM,GAAG,CAAC,IAAI,gBAAgB,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAC;YAC3F,IAAI,UAAU,EAAE;gBACZ,cAAc,GAAG,cAAc,CAAC;gBAChC,UAAU,GAAG,KAAK,CAAC;aACtB;iBAAM;gBACH,cAAc,GAAG,CAAC,aAAa,CAAC,CAAC;gBACjC,UAAU,GAAG,KAAK,CAAC;aACtB;SACJ;QAED,IAAI,cAAc,CAAC,MAAM,EAAE;YACvB,qBAAqB,GAAG,mBAAmB,CAAC,KAAK,EAAE,cAAc,CAAC,CAAC;SACtE;QAED,WAAW,CAAC,KAAK,CAAC,CAAC;IACvB,CAAC,CAAC;IAEF,KAAK,CAAC,WAAW,GAAG,CAAC,KAAmB,EAAE,EAAE;QACxC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,QAAQ,IAAI,cAAc,EAAE,MAAM,IAAI,UAAU,EAAE;YACjE,mCAAmC;YACnC,KAAK,CAAC,cAAc,EAAE,CAAC;YACvB,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,gBAAgB,CAAC,KAAK,EAAE,UAAU,EAAE,UAAU,CAAC,CAAC;gBAChE,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;YACnC,CAAC,CAAC,CAAC;YACH,cAAc,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE;gBAC7B,MAAM,KAAK,GAAG,gBAAgB,CAAC,KAAK,EAAE,OAAO,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC;gBACjE,aAAa,EAAE,WAAW,CAAC,KAAK,CAAC,CAAC;YACtC,CAAC,CAAC,CAAC;YAEH,UAAU,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,WAAW,CAAC,aAAa,CAAC,CAAC;SACxD;QAED,WAAW,CAAC,KAAK,CAAC,CAAC;IACvB,CAAC,CAAC;IAEF,KAAK,CAAC,eAAe,GAAG,CAAC,KAAmB,EAAE,EAAE;QAC5C,MAAM,kBAAkB,GAAG,oBAAoB,CAAC,cAAc,CAAC,CAAC;QAChE,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,QAAQ,IAAI,kBAAkB,CAAC,MAAM,EAAE;YACtD,kBAAkB,CAAC,IAAI,CAAC,GAAG,qBAAqB,CAAC,CAAC;YAClD,IAAI,UAAU,CAAC,KAAK,CAAC,EAAE;gBACnB,kBAAkB,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE;oBACjC,wBAAwB,CAAC,OAAO,CAAC,CAAC;gBACtC,CAAC,CAAC,CAAC;aACN;YACD,IAAI,UAAU,EAAE;gBACZ,MAAM,aAAa,GAAG,KAAK,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;gBAChD,MAAM,qBAAqB,GAAG,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC,CAAC;gBACvG,MAAM,oBAAoB,GAAG,KAAK,CAAC,OAAO,CAAC,UAAU,CAAC,QAAQ,CAAC,KAAK,EAAE,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC;gBAC1F,IAAI,YAAY,GAAG,oBAAoB,CAAC,KAAK,EAAE,kBAAkB,CAAC,CAAC;gBACnE,MAAM,cAAc,GAAG,kBAAkB;qBACpC,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,OAAO,OAAO,CAAC;gBACnB,CAAC,CAAC,CAAC;gBAEP,MAAM,eAAe,GAAG,UAAU,CAAC,UAAU,CAAC,MAAM,GAAG,CAAC,CAAC,KAAK,CAAC,CAAC;gBAChE,IAAI,eAAe,EAAE;oBACjB,MAAM,eAAe,GAAG,SAAS,CAAC,GAAG,CAAC,KAAK,EAAE,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAgB,CAAC;oBACvF,MAAM,qBAAqB,GAAG,wBAAwB,CAAC,eAAe,CAAC,CAAC;oBACxE,MAAM,2BAA2B,GAC7B,qBAAqB,IAAI,qBAAqB,CAAC,GAAG,KAAK,UAAU,CAAC,UAAU,CAAC,MAAM,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC;oBACjG,IAAI,2BAA2B,EAAE;wBAC7B,MAAM,YAAY,GAAG,YAAY,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE;4BACxC,OAAO,oBAAoB,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;wBAC9C,CAAC,CAAC,CAAC;wBACH,cAAc,CAAC,IAAI,CAAC,GAAG,YAAY,CAAC,CAAC;wBACrC,YAAY,GAAG,EAAE,CAAC;qBACrB;iBACJ;gBAED,MAAM,iBAAiB,GAAG,2BAA2B,CAAC,KAAK,EAAE,kBAAkB,CAAC,CAAC;gBACjF,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,IAAI,IAAI,GAAG,kCAAkC,CAAC,KAAK,EAAE,kBAAkB,CAAC,CAAC;gBACzE,MAAM,MAAM,GAAG,SAAS,CAAC,GAAG,CAAC,KAAK,EAAE,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,CAAgB,CAAC;gBAC5E,MAAM,gBAAgB,GAAG,mBAAmB,CAAC,MAAM,EAAE,UAAU,CAAC,CAAC;gBACjE,IAAI,gBAAgB,IAAI,oBAAoB,CAAC,OAAO,EAAE;oBAClD,IAAI,GAAG,iCAAiC,CAAC,KAAK,EAAE,oBAAoB,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,cAAc,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;iBAC1H;gBAED,cAAc,CAAC,uBAAuB,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;gBACpD,cAAc,CAAC,cAAc,CAAC,KAAK,EAAE,kBAAkB,CAAC,CAAC;gBAEzD,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,oCAAoC;oBACpC,MAAM,YAAY,GAAG,qBAAqB,IAAI,qBAAqB,CAAC,KAAK,EAAE,CAAC;oBAC5E,IAAI,YAAY,EAAE;wBACd,UAAU,GAAG,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;qBACxC;yBAAM;wBACH,MAAM,MAAM,GAAG,SAAS,CAAC,GAAG,CAAC,KAAK,EAAE,UAAU,CAAC,CAAC;wBAChD,MAAM,QAAQ,GAAG,sBAAsB,CAAC,MAAM,CAAC,CAAC;wBAChD,UAAU,GAAG,CAAC,GAAG,UAAU,EAAE,QAAQ,CAAC,MAAM,IAAI,CAAC,CAAC,CAAC;qBACtD;iBACJ;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,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,IAAI,iBAAiB,GAAkB,EAAE,CAAC;gBAC1C,mBAAmB,CAAE,KAAgC,EAAE,IAAI,CAAC,EAAE;oBAC1D,MAAM,UAAU,GAAG,cAAc,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,OAAO,CAAC,EAAE,KAAK,IAAI,CAAC,EAAE,CAAC,CAAC;oBAC1E,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,eAAe,CAAC,KAAK,CAAC,CAAC;IAC3B,CAAC,CAAC;IAEF,OAAO,KAAK,CAAC;AACjB,CAAC,CAAC","sourcesContent":["import {\n    distanceBetweenPointAndPoint,\n    Path,\n    PlaitBoard,\n    Point,\n    toPoint,\n    transformPoint,\n    Transforms,\n    getSelectedElements,\n    depthFirstRecursion,\n    createG,\n    PlaitNode,\n    PlaitPointerType,\n    getHitElements,\n    PlaitElement,\n    isMainPointer\n} from '@plait/core';\nimport { AbstractNode, getNonAbstractChildren } from '@plait/layouts';\nimport { MindElement } from '../interfaces/element';\nimport { DetectResult } from '../interfaces/node';\n\nimport {\n    deleteElementHandleAbstract,\n    deleteElementsHandleRightNodeCount,\n    getCorrespondingAbstract,\n    getFirstLevelElement,\n    getOverallAbstracts,\n    getValidAbstractRefs,\n    insertElementHandleAbstract,\n    insertElementHandleRightNodeCount\n} from '../utils';\nimport { addActiveOnDragOrigin, isDragging, isDropStandardRight, removeActiveOnDragOrigin, setIsDragging } from '../utils/dnd/common';\nimport { detectDropTarget, getPathByDropTarget } from '../utils/dnd/detector';\nimport { drawFakeDragNode, drawFakeDropNode } from '../utils/draw/node-dnd';\nimport { MindTransforms } from '../transforms';\nimport { adjustAbstractToNode } from '../utils/node/adjust-node';\n\nconst DRAG_MOVE_BUFFER = 5;\n\nexport const withNodeDnd = (board: PlaitBoard) => {\n    const { pointerDown, pointerMove, globalPointerUp } = 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.pointerDown = (event: PointerEvent) => {\n        if (\n            PlaitBoard.isReadonly(board) ||\n            PlaitBoard.hasBeenTextEditing(board) ||\n            !PlaitBoard.isPointer(board, PlaitPointerType.selection) ||\n            !isMainPointer(event)\n        ) {\n            pointerDown(event);\n            return;\n        }\n\n        const point = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));\n        const selectedElements = getSelectedElements(board);\n        const hitTarget = getHitElements(board, { ranges: [{ anchor: point, focus: point }] }, (element: PlaitElement) => {\n            return MindElement.isMindElement(board, element);\n        });\n\n        const targetElement = hitTarget && hitTarget.length === 1 ? hitTarget[0] : null;\n        if (\n            targetElement &&\n            MindElement.isMindElement(board, targetElement) &&\n            !targetElement.isRoot &&\n            !AbstractNode.isAbstract(targetElement)\n        ) {\n            const targetElements = selectedElements.filter(\n                element => MindElement.isMindElement(board, element) && !element.isRoot && !AbstractNode.isAbstract(element)\n            ) as MindElement[];\n            const isMultiple = selectedElements.length > 0 && selectedElements.includes(targetElement);\n            if (isMultiple) {\n                activeElements = targetElements;\n                startPoint = point;\n            } else {\n                activeElements = [targetElement];\n                startPoint = point;\n            }\n        }\n\n        if (activeElements.length) {\n            correspondingElements = getOverallAbstracts(board, activeElements);\n        }\n\n        pointerDown(event);\n    };\n\n    board.pointerMove = (event: PointerEvent) => {\n        if (!board.options.readonly && activeElements?.length && startPoint) {\n            // prevent text from being selected\n            event.preventDefault();\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 = drawFakeDropNode(board, dropTarget, 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            });\n            activeElements.forEach(element => {\n                const nodeG = drawFakeDragNode(board, element, offsetX, offsetY);\n                dragFakeNodeG?.appendChild(nodeG);\n            });\n\n            PlaitBoard.getHost(board).appendChild(dragFakeNodeG);\n        }\n\n        pointerMove(event);\n    };\n\n    board.globalPointerUp = (event: PointerEvent) => {\n        const firstLevelElements = getFirstLevelElement(activeElements);\n        if (!board.options.readonly && firstLevelElements.length) {\n            firstLevelElements.push(...correspondingElements);\n            if (isDragging(board)) {\n                firstLevelElements.forEach(element => {\n                    removeActiveOnDragOrigin(element);\n                });\n            }\n            if (dropTarget) {\n                const targetPathRef = board.pathRef(targetPath);\n                const targetPreviousPathRef = Path.hasPrevious(targetPath) && board.pathRef(Path.previous(targetPath));\n                const targetElementPathRef = board.pathRef(PlaitBoard.findPath(board, dropTarget.target));\n                let abstractRefs = getValidAbstractRefs(board, firstLevelElements);\n                const normalElements = firstLevelElements\n                    .filter(element => !abstractRefs.some(refs => refs.abstract === element))\n                    .map(element => {\n                        if (AbstractNode.isAbstract(element)) {\n                            return adjustAbstractToNode(element);\n                        }\n                        return element;\n                    });\n\n                const hasPreviousNode = targetPath[targetPath.length - 1] !== 0;\n                if (hasPreviousNode) {\n                    const previousElement = PlaitNode.get(board, Path.previous(targetPath)) as MindElement;\n                    const correspondingAbstract = getCorrespondingAbstract(previousElement);\n                    const targetHasCorrespondAbstract =\n                        correspondingAbstract && correspondingAbstract.end !== targetPath[targetPath.length - 1] - 1;\n                    if (targetHasCorrespondAbstract) {\n                        const adjustedNode = abstractRefs.map(ref => {\n                            return adjustAbstractToNode(ref.abstract);\n                        });\n                        normalElements.push(...adjustedNode);\n                        abstractRefs = [];\n                    }\n                }\n\n                const effectedAbstracts = deleteElementHandleAbstract(board, firstLevelElements);\n                insertElementHandleAbstract(board, targetPath, normalElements.length, false, effectedAbstracts);\n                MindTransforms.setAbstractsByRefs(board, effectedAbstracts);\n\n                let refs = deleteElementsHandleRightNodeCount(board, firstLevelElements);\n                const parent = PlaitNode.get(board, Path.parent(targetPath)) as MindElement;\n                const shouldChangeRoot = isDropStandardRight(parent, dropTarget);\n                if (shouldChangeRoot && targetElementPathRef.current) {\n                    refs = insertElementHandleRightNodeCount(board, targetElementPathRef.current.slice(0, 1), normalElements.length, refs);\n                }\n\n                MindTransforms.setRightNodeCountByRefs(board, refs);\n                MindTransforms.removeElements(board, firstLevelElements);\n\n                let insertPath = targetPathRef.current;\n                const parentPath = Path.parent(targetPathRef.current || targetPath);\n                if (!insertPath) {\n                    //当插入位置和选中节点位置相同时，使用记录的 previousPath\n                    const previousPath = targetPreviousPathRef && targetPreviousPathRef.unref();\n                    if (previousPath) {\n                        insertPath = Path.next(previousPath);\n                    } else {\n                        const parent = PlaitNode.get(board, parentPath);\n                        const children = getNonAbstractChildren(parent);\n                        insertPath = [...parentPath, children.length || 0];\n                    }\n                }\n\n                MindTransforms.insertNodes(board, normalElements, insertPath);\n\n                if (abstractRefs.length) {\n                    MindTransforms.insertAbstractNodes(board, abstractRefs, normalElements, insertPath);\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                let setActiveElements: MindElement[] = [];\n                depthFirstRecursion((board as unknown) as MindElement, node => {\n                    const isSelected = activeElements.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        globalPointerUp(event);\n    };\n\n    return board;\n};\n"]}
|
|
@@ -1,96 +0,0 @@
|
|
|
1
|
-
import { PlaitBoard, getHitElements, isMainPointer, toPoint, transformPoint, hotkeys, PlaitPointerType, addSelectedElement, getSelectedElements, setClipboardDataByMedia, getClipboardDataByMedia } from '@plait/core';
|
|
2
|
-
import { MindElement } from '../interfaces';
|
|
3
|
-
import { buildImage, getSelectedImageElement, setImageFocus } from '../utils/node/image';
|
|
4
|
-
import { isHitImage, temporaryDisableSelection } from '../utils';
|
|
5
|
-
import { MindTransforms } from '../transforms';
|
|
6
|
-
import { acceptImageTypes } from '../constants/image';
|
|
7
|
-
import { MediaKeys } from '@plait/common';
|
|
8
|
-
export const withNodeImage = (board) => {
|
|
9
|
-
const { keydown, pointerDown, globalPointerUp, setFragment, insertFragment, deleteFragment } = board;
|
|
10
|
-
board.pointerDown = (event) => {
|
|
11
|
-
const selectedImageElement = getSelectedImageElement(board);
|
|
12
|
-
if (PlaitBoard.isReadonly(board) || !isMainPointer(event) || !PlaitBoard.isPointer(board, PlaitPointerType.selection)) {
|
|
13
|
-
if (selectedImageElement) {
|
|
14
|
-
setImageFocus(board, selectedImageElement, false);
|
|
15
|
-
}
|
|
16
|
-
pointerDown(event);
|
|
17
|
-
return;
|
|
18
|
-
}
|
|
19
|
-
const point = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));
|
|
20
|
-
const range = { anchor: point, focus: point };
|
|
21
|
-
const hitImageElements = getHitElements(board, { ranges: [range] }, (value) => MindElement.isMindElement(board, value) && MindElement.hasImage(value));
|
|
22
|
-
const hasImage = hitImageElements.length;
|
|
23
|
-
const hitImage = hasImage > 0 && isHitImage(board, hitImageElements[0], range);
|
|
24
|
-
if (selectedImageElement && hitImage && hitImageElements[0] === selectedImageElement) {
|
|
25
|
-
temporaryDisableSelection(board);
|
|
26
|
-
pointerDown(event);
|
|
27
|
-
return;
|
|
28
|
-
}
|
|
29
|
-
if (selectedImageElement) {
|
|
30
|
-
setImageFocus(board, selectedImageElement, false);
|
|
31
|
-
}
|
|
32
|
-
if (hitImage) {
|
|
33
|
-
temporaryDisableSelection(board);
|
|
34
|
-
setImageFocus(board, hitImageElements[0], true);
|
|
35
|
-
}
|
|
36
|
-
pointerDown(event);
|
|
37
|
-
};
|
|
38
|
-
board.keydown = (event) => {
|
|
39
|
-
const selectedImageElement = getSelectedImageElement(board);
|
|
40
|
-
if (!PlaitBoard.isReadonly(board) && selectedImageElement && (hotkeys.isDeleteBackward(event) || hotkeys.isDeleteForward(event))) {
|
|
41
|
-
addSelectedElement(board, selectedImageElement);
|
|
42
|
-
MindTransforms.removeImage(board, selectedImageElement);
|
|
43
|
-
return;
|
|
44
|
-
}
|
|
45
|
-
keydown(event);
|
|
46
|
-
};
|
|
47
|
-
board.globalPointerUp = (event) => {
|
|
48
|
-
if (PlaitBoard.isFocus(board)) {
|
|
49
|
-
const isInBoard = event.target instanceof Node && PlaitBoard.getBoardContainer(board).contains(event.target);
|
|
50
|
-
const selectedImageElement = getSelectedImageElement(board);
|
|
51
|
-
// Clear image selection when mouse board outside area
|
|
52
|
-
if (selectedImageElement && !isInBoard) {
|
|
53
|
-
setImageFocus(board, selectedImageElement, false);
|
|
54
|
-
}
|
|
55
|
-
}
|
|
56
|
-
globalPointerUp(event);
|
|
57
|
-
};
|
|
58
|
-
board.setFragment = (data, rectangle) => {
|
|
59
|
-
const selectedImageElement = getSelectedImageElement(board);
|
|
60
|
-
if (selectedImageElement) {
|
|
61
|
-
setClipboardDataByMedia(data, selectedImageElement.data.image, MediaKeys.image);
|
|
62
|
-
return;
|
|
63
|
-
}
|
|
64
|
-
setFragment(data, rectangle);
|
|
65
|
-
};
|
|
66
|
-
board.deleteFragment = (data) => {
|
|
67
|
-
const selectedImageElement = getSelectedImageElement(board);
|
|
68
|
-
if (selectedImageElement) {
|
|
69
|
-
MindTransforms.removeImage(board, selectedImageElement);
|
|
70
|
-
}
|
|
71
|
-
deleteFragment(data);
|
|
72
|
-
};
|
|
73
|
-
board.insertFragment = (data, targetPoint) => {
|
|
74
|
-
const selectedElements = getSelectedElements(board);
|
|
75
|
-
const isSelectedImage = !!getSelectedImageElement(board);
|
|
76
|
-
const isSingleSelection = selectedElements.length === 1 && MindElement.isMindElement(board, selectedElements[0]);
|
|
77
|
-
if (data?.files.length && (isSingleSelection || isSelectedImage)) {
|
|
78
|
-
const selectedElement = (selectedElements[0] || getSelectedImageElement(board));
|
|
79
|
-
const acceptImageArray = acceptImageTypes.map(type => 'image/' + type);
|
|
80
|
-
if (acceptImageArray.includes(data?.files[0].type)) {
|
|
81
|
-
const imageFile = data.files[0];
|
|
82
|
-
buildImage(board, selectedElement, imageFile);
|
|
83
|
-
return;
|
|
84
|
-
}
|
|
85
|
-
}
|
|
86
|
-
const imageItem = getClipboardDataByMedia(data, MediaKeys.image);
|
|
87
|
-
if (imageItem && (isSingleSelection || isSelectedImage)) {
|
|
88
|
-
const selectedElement = (selectedElements[0] || getSelectedImageElement(board));
|
|
89
|
-
MindTransforms.setImage(board, selectedElement, imageItem);
|
|
90
|
-
return;
|
|
91
|
-
}
|
|
92
|
-
insertFragment(data, targetPoint);
|
|
93
|
-
};
|
|
94
|
-
return board;
|
|
95
|
-
};
|
|
96
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-node-image.js","sourceRoot":"","sources":["../../../../packages/mind/src/plugins/with-node-image.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    PlaitBoard,\n    getHitElements,\n    isMainPointer,\n    toPoint,\n    transformPoint,\n    PlaitOptionsBoard,\n    hotkeys,\n    PlaitPointerType,\n    addSelectedElement,\n    Point,\n    getSelectedElements,\n    PlaitElement,\n    setClipboardDataByMedia,\n    getClipboardDataByMedia,\n    RectangleClient\n} from '@plait/core';\nimport { MindElement } from '../interfaces';\nimport { ImageData } from '../interfaces/element-data';\nimport { buildImage, getSelectedImageElement, setImageFocus } from '../utils/node/image';\nimport { isHitImage, temporaryDisableSelection } from '../utils';\nimport { MindTransforms } from '../transforms';\nimport { acceptImageTypes } from '../constants/image';\nimport { MediaKeys } from '@plait/common';\n\nexport const withNodeImage = (board: PlaitBoard) => {\n    const { keydown, pointerDown, globalPointerUp, setFragment, insertFragment, deleteFragment } = board;\n\n    board.pointerDown = (event: PointerEvent) => {\n        const selectedImageElement = getSelectedImageElement(board);\n        if (PlaitBoard.isReadonly(board) || !isMainPointer(event) || !PlaitBoard.isPointer(board, PlaitPointerType.selection)) {\n            if (selectedImageElement) {\n                setImageFocus(board, selectedImageElement, false);\n            }\n            pointerDown(event);\n            return;\n        }\n\n        const point = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));\n        const range = { anchor: point, focus: point };\n        const hitImageElements = getHitElements(\n            board,\n            { ranges: [range] },\n            (value: PlaitElement) => MindElement.isMindElement(board, value) && MindElement.hasImage(value)\n        );\n        const hasImage = hitImageElements.length;\n        const hitImage = hasImage > 0 && isHitImage(board, hitImageElements[0] as MindElement<ImageData>, range);\n        if (selectedImageElement && hitImage && hitImageElements[0] === selectedImageElement) {\n            temporaryDisableSelection(board as PlaitOptionsBoard);\n            pointerDown(event);\n            return;\n        }\n\n        if (selectedImageElement) {\n            setImageFocus(board, selectedImageElement, false);\n        }\n\n        if (hitImage) {\n            temporaryDisableSelection(board as PlaitOptionsBoard);\n            setImageFocus(board, hitImageElements[0] as MindElement<ImageData>, true);\n        }\n\n        pointerDown(event);\n    };\n\n    board.keydown = (event: KeyboardEvent) => {\n        const selectedImageElement = getSelectedImageElement(board);\n\n        if (!PlaitBoard.isReadonly(board) && selectedImageElement && (hotkeys.isDeleteBackward(event) || hotkeys.isDeleteForward(event))) {\n            addSelectedElement(board, selectedImageElement);\n            MindTransforms.removeImage(board, selectedImageElement as MindElement<ImageData>);\n            return;\n        }\n\n        keydown(event);\n    };\n\n    board.globalPointerUp = (event: PointerEvent) => {\n        if (PlaitBoard.isFocus(board)) {\n            const isInBoard = event.target instanceof Node && PlaitBoard.getBoardContainer(board).contains(event.target);\n            const selectedImageElement = getSelectedImageElement(board);\n\n            // Clear image selection when mouse board outside area\n            if (selectedImageElement && !isInBoard) {\n                setImageFocus(board, selectedImageElement, false);\n            }\n        }\n        globalPointerUp(event);\n    };\n\n    board.setFragment = (data: DataTransfer | null, rectangle: RectangleClient | null) => {\n        const selectedImageElement = getSelectedImageElement(board);\n        if (selectedImageElement) {\n            setClipboardDataByMedia(data, selectedImageElement.data.image!, MediaKeys.image);\n            return;\n        }\n\n        setFragment(data, rectangle);\n    };\n\n    board.deleteFragment = (data: DataTransfer | null) => {\n        const selectedImageElement = getSelectedImageElement(board);\n\n        if (selectedImageElement) {\n            MindTransforms.removeImage(board, selectedImageElement as MindElement<ImageData>);\n        }\n\n        deleteFragment(data);\n    };\n\n    board.insertFragment = (data: DataTransfer | null, targetPoint: Point) => {\n        const selectedElements = getSelectedElements(board);\n        const isSelectedImage = !!getSelectedImageElement(board);\n        const isSingleSelection = selectedElements.length === 1 && MindElement.isMindElement(board, selectedElements[0]);\n\n        if (data?.files.length && (isSingleSelection || isSelectedImage)) {\n            const selectedElement = (selectedElements[0] || getSelectedImageElement(board)) as MindElement;\n            const acceptImageArray = acceptImageTypes.map(type => 'image/' + type);\n            if (acceptImageArray.includes(data?.files[0].type)) {\n                const imageFile = data.files[0];\n                buildImage(board, selectedElement as MindElement, imageFile);\n                return;\n            }\n        }\n\n        const imageItem = getClipboardDataByMedia(data, MediaKeys.image);\n        if (imageItem && (isSingleSelection || isSelectedImage)) {\n            const selectedElement = (selectedElements[0] || getSelectedImageElement(board)) as MindElement;\n            MindTransforms.setImage(board, selectedElement, imageItem);\n            return;\n        }\n\n        insertFragment(data, targetPoint);\n    };\n\n    return board;\n};\n"]}
|
|
@@ -1,133 +0,0 @@
|
|
|
1
|
-
import { MERGING, PRESS_AND_MOVE_BUFFER, PlaitBoard, PlaitElement, PlaitNode, ResizeCursorClass, distanceBetweenPointAndPoint, distanceBetweenPointAndRectangle, getSelectedElements, preventTouchMove, throttleRAF, toPoint, transformPoint } from '@plait/core';
|
|
2
|
-
import { MindElement } from '../interfaces/element';
|
|
3
|
-
import { getRectangleByNode } from '../utils/position/node';
|
|
4
|
-
import { NodeSpace } from '../utils/space/node-space';
|
|
5
|
-
import { MindTransforms } from '../transforms';
|
|
6
|
-
import { EXTEND_OFFSET } from '../constants/default';
|
|
7
|
-
import { isDragging } from '../utils/dnd/common';
|
|
8
|
-
export const withNodeResize = (board) => {
|
|
9
|
-
const { pointerDown, pointerMove, globalPointerUp } = board;
|
|
10
|
-
let targetElement = null;
|
|
11
|
-
let targetElementRef = null;
|
|
12
|
-
let startPoint = null;
|
|
13
|
-
board.pointerDown = (event) => {
|
|
14
|
-
const point = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));
|
|
15
|
-
const newTargetElement = getSelectedTarget(board, point);
|
|
16
|
-
if (newTargetElement) {
|
|
17
|
-
PlaitBoard.getBoardContainer(board).classList.add(ResizeCursorClass['ew-resize']);
|
|
18
|
-
targetElement = newTargetElement;
|
|
19
|
-
startPoint = [event.x, event.y];
|
|
20
|
-
return;
|
|
21
|
-
}
|
|
22
|
-
pointerDown(event);
|
|
23
|
-
};
|
|
24
|
-
board.pointerMove = (event) => {
|
|
25
|
-
if (PlaitBoard.isReadonly(board) || PlaitBoard.hasBeenTextEditing(board)) {
|
|
26
|
-
pointerMove(event);
|
|
27
|
-
return;
|
|
28
|
-
}
|
|
29
|
-
if (startPoint && targetElement && !isMindNodeResizing(board)) {
|
|
30
|
-
// prevent text from being selected
|
|
31
|
-
event.preventDefault();
|
|
32
|
-
preventTouchMove(board, true);
|
|
33
|
-
const endPoint = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));
|
|
34
|
-
const distance = distanceBetweenPointAndPoint(startPoint[0], startPoint[1], endPoint[0], endPoint[1]);
|
|
35
|
-
if (distance > PRESS_AND_MOVE_BUFFER) {
|
|
36
|
-
addResizing(board, targetElement);
|
|
37
|
-
targetElementRef = {
|
|
38
|
-
minWidth: NodeSpace.getNodeResizableMinWidth(board, targetElement),
|
|
39
|
-
currentWidth: NodeSpace.getNodeDynamicWidth(board, targetElement),
|
|
40
|
-
path: PlaitBoard.findPath(board, targetElement),
|
|
41
|
-
textManage: PlaitElement.getComponent(targetElement).textManage
|
|
42
|
-
};
|
|
43
|
-
MERGING.set(board, true);
|
|
44
|
-
}
|
|
45
|
-
}
|
|
46
|
-
if (isMindNodeResizing(board) && startPoint && targetElementRef) {
|
|
47
|
-
// prevent text from being selected
|
|
48
|
-
event.preventDefault();
|
|
49
|
-
preventTouchMove(board, true);
|
|
50
|
-
throttleRAF(() => {
|
|
51
|
-
if (!startPoint) {
|
|
52
|
-
return;
|
|
53
|
-
}
|
|
54
|
-
const endPoint = [event.x, event.y];
|
|
55
|
-
const offsetX = endPoint[0] - startPoint[0];
|
|
56
|
-
const zoom = board.viewport.zoom;
|
|
57
|
-
let resizedWidth = targetElementRef.currentWidth + offsetX / zoom;
|
|
58
|
-
if (resizedWidth <= targetElementRef.minWidth) {
|
|
59
|
-
resizedWidth = targetElementRef.minWidth;
|
|
60
|
-
}
|
|
61
|
-
const newTarget = PlaitNode.get(board, targetElementRef.path);
|
|
62
|
-
if (newTarget && NodeSpace.getNodeTopicMinWidth(board, newTarget) !== resizedWidth) {
|
|
63
|
-
targetElementRef.textManage.updateWidth(resizedWidth);
|
|
64
|
-
const { height } = targetElementRef.textManage.getSize();
|
|
65
|
-
MindTransforms.setNodeManualWidth(board, newTarget, resizedWidth * zoom, height);
|
|
66
|
-
}
|
|
67
|
-
});
|
|
68
|
-
return;
|
|
69
|
-
}
|
|
70
|
-
else {
|
|
71
|
-
// press and start drag when node is non selected
|
|
72
|
-
if (!isDragging(board)) {
|
|
73
|
-
const point = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));
|
|
74
|
-
const newTargetElement = getSelectedTarget(board, point);
|
|
75
|
-
if (newTargetElement) {
|
|
76
|
-
PlaitBoard.getBoardContainer(board).classList.add(ResizeCursorClass['ew-resize']);
|
|
77
|
-
}
|
|
78
|
-
else {
|
|
79
|
-
PlaitBoard.getBoardContainer(board).classList.remove(ResizeCursorClass['ew-resize']);
|
|
80
|
-
}
|
|
81
|
-
}
|
|
82
|
-
}
|
|
83
|
-
pointerMove(event);
|
|
84
|
-
};
|
|
85
|
-
board.globalPointerUp = (event) => {
|
|
86
|
-
globalPointerUp(event);
|
|
87
|
-
if (isMindNodeResizing(board) || targetElement) {
|
|
88
|
-
targetElement && removeResizing(board, targetElement);
|
|
89
|
-
targetElementRef = null;
|
|
90
|
-
targetElement = null;
|
|
91
|
-
startPoint = null;
|
|
92
|
-
MERGING.set(board, false);
|
|
93
|
-
preventTouchMove(board, false);
|
|
94
|
-
}
|
|
95
|
-
};
|
|
96
|
-
return board;
|
|
97
|
-
};
|
|
98
|
-
export const IS_MIND_NODE_RESIZING = new WeakMap();
|
|
99
|
-
export const isMindNodeResizing = (board) => {
|
|
100
|
-
return !!IS_MIND_NODE_RESIZING.get(board);
|
|
101
|
-
};
|
|
102
|
-
export const addResizing = (board, element) => {
|
|
103
|
-
PlaitBoard.getBoardContainer(board).classList.add('mind-node-resizing');
|
|
104
|
-
const component = PlaitElement.getComponent(element);
|
|
105
|
-
component.g.classList.add('resizing');
|
|
106
|
-
IS_MIND_NODE_RESIZING.set(board, true);
|
|
107
|
-
};
|
|
108
|
-
export const removeResizing = (board, element) => {
|
|
109
|
-
PlaitBoard.getBoardContainer(board).classList.remove('mind-node-resizing');
|
|
110
|
-
PlaitBoard.getBoardContainer(board).classList.remove(ResizeCursorClass['ew-resize']);
|
|
111
|
-
const component = PlaitElement.getComponent(element);
|
|
112
|
-
if (component && component.g) {
|
|
113
|
-
component.g.classList.remove('resizing');
|
|
114
|
-
}
|
|
115
|
-
IS_MIND_NODE_RESIZING.set(board, false);
|
|
116
|
-
};
|
|
117
|
-
export const getSelectedTarget = (board, point) => {
|
|
118
|
-
const selectedElements = getSelectedElements(board).filter(value => MindElement.isMindElement(board, value));
|
|
119
|
-
if (selectedElements.length > 0) {
|
|
120
|
-
const target = selectedElements.find(value => {
|
|
121
|
-
const rectangle = getResizeActiveRectangle(board, value);
|
|
122
|
-
return distanceBetweenPointAndRectangle(point[0], point[1], rectangle) <= 0;
|
|
123
|
-
});
|
|
124
|
-
return target ? target : null;
|
|
125
|
-
}
|
|
126
|
-
return null;
|
|
127
|
-
};
|
|
128
|
-
export const getResizeActiveRectangle = (board, element) => {
|
|
129
|
-
const node = MindElement.getNode(element);
|
|
130
|
-
const rectangle = getRectangleByNode(node);
|
|
131
|
-
return { x: rectangle.x + rectangle.width - EXTEND_OFFSET, y: rectangle.y, width: EXTEND_OFFSET * 2, height: rectangle.height };
|
|
132
|
-
};
|
|
133
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-node-resize.js","sourceRoot":"","sources":["../../../../packages/mind/src/plugins/with-node-resize.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    MERGING,\n    PRESS_AND_MOVE_BUFFER,\n    Path,\n    PlaitBoard,\n    PlaitElement,\n    PlaitNode,\n    Point,\n    RectangleClient,\n    ResizeCursorClass,\n    distanceBetweenPointAndPoint,\n    distanceBetweenPointAndRectangle,\n    getSelectedElements,\n    preventTouchMove,\n    throttleRAF,\n    toPoint,\n    transformPoint\n} from '@plait/core';\nimport { MindElement } from '../interfaces/element';\nimport { getRectangleByNode } from '../utils/position/node';\nimport { NodeSpace } from '../utils/space/node-space';\nimport { PlaitMindBoard } from './with-mind.board';\nimport { MindNodeComponent } from '../node.component';\nimport { MindTransforms } from '../transforms';\nimport { TextManage } from '@plait/text';\nimport { EXTEND_OFFSET } from '../constants/default';\nimport { isDragging } from '../utils/dnd/common';\n\ninterface TargetElementRef {\n    minWidth: number;\n    currentWidth: number;\n    path: Path;\n    textManage: TextManage;\n}\n\nexport const withNodeResize = (board: PlaitBoard) => {\n    const { pointerDown, pointerMove, globalPointerUp } = board;\n    let targetElement: MindElement | null = null;\n    let targetElementRef: TargetElementRef | null = null;\n    let startPoint: Point | null = null;\n\n    board.pointerDown = (event: PointerEvent) => {\n        const point = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));\n        \n        const newTargetElement = getSelectedTarget(board as PlaitMindBoard, point);\n        if (newTargetElement) {\n            PlaitBoard.getBoardContainer(board).classList.add(ResizeCursorClass['ew-resize']);\n            targetElement = newTargetElement;\n            startPoint = [event.x, event.y];\n            return;\n        }\n\n        pointerDown(event);\n    };\n\n    board.pointerMove = (event: PointerEvent) => {\n        if (PlaitBoard.isReadonly(board) || PlaitBoard.hasBeenTextEditing(board)) {\n            pointerMove(event);\n            return;\n        }\n\n        if (startPoint && targetElement && !isMindNodeResizing(board)) {\n            // prevent text from being selected\n            event.preventDefault();\n            preventTouchMove(board, true);\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 > PRESS_AND_MOVE_BUFFER) {\n                addResizing(board, targetElement);\n                targetElementRef = {\n                    minWidth: NodeSpace.getNodeResizableMinWidth(board as PlaitMindBoard, targetElement),\n                    currentWidth: NodeSpace.getNodeDynamicWidth(board as PlaitMindBoard, targetElement),\n                    path: PlaitBoard.findPath(board, targetElement),\n                    textManage: (PlaitElement.getComponent(targetElement) as MindNodeComponent).textManage\n                };\n                MERGING.set(board, true);\n            }\n        }\n\n        if (isMindNodeResizing(board) && startPoint && targetElementRef) {\n            // prevent text from being selected\n            event.preventDefault();\n            preventTouchMove(board, true);\n            throttleRAF(() => {\n                if (!startPoint) {\n                    return;\n                }\n\n                const endPoint = [event.x, event.y];\n                const offsetX = endPoint[0] - startPoint![0];\n                const zoom = board.viewport.zoom;\n                let resizedWidth = targetElementRef!.currentWidth + offsetX / zoom;\n                if (resizedWidth <= targetElementRef!.minWidth) {\n                    resizedWidth = targetElementRef!.minWidth;\n                }\n\n                const newTarget = PlaitNode.get<MindElement>(board, targetElementRef!.path);\n                if (newTarget && NodeSpace.getNodeTopicMinWidth(board as PlaitMindBoard, newTarget) !== resizedWidth) {\n                    targetElementRef!.textManage.updateWidth(resizedWidth);\n                    const { height } = targetElementRef!.textManage.getSize();\n                    MindTransforms.setNodeManualWidth(board as PlaitMindBoard, newTarget, resizedWidth * zoom, height);\n                }\n            });\n            return;\n        } else {\n            // press and start drag when node is non selected\n            if (!isDragging(board)) {\n                const point = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));\n                const newTargetElement = getSelectedTarget(board as PlaitMindBoard, point);\n                if (newTargetElement) {\n                    PlaitBoard.getBoardContainer(board).classList.add(ResizeCursorClass['ew-resize']);\n                } else {\n                    PlaitBoard.getBoardContainer(board).classList.remove(ResizeCursorClass['ew-resize']);\n                }\n            }\n        }\n\n        pointerMove(event);\n    };\n\n    board.globalPointerUp = (event: PointerEvent) => {\n        globalPointerUp(event);\n\n        if (isMindNodeResizing(board) || targetElement) {\n            targetElement && removeResizing(board, targetElement);\n            targetElementRef = null;\n            targetElement = null;\n            startPoint = null;\n            MERGING.set(board, false);\n            preventTouchMove(board, false);\n        }\n    };\n\n    return board;\n};\n\nexport const IS_MIND_NODE_RESIZING = new WeakMap<PlaitBoard, boolean>();\n\nexport const isMindNodeResizing = (board: PlaitBoard) => {\n    return !!IS_MIND_NODE_RESIZING.get(board);\n};\n\nexport const addResizing = (board: PlaitBoard, element: MindElement) => {\n    PlaitBoard.getBoardContainer(board).classList.add('mind-node-resizing');\n    const component = PlaitElement.getComponent(element);\n    component.g.classList.add('resizing');\n    IS_MIND_NODE_RESIZING.set(board, true);\n};\n\nexport const removeResizing = (board: PlaitBoard, element: MindElement) => {\n    PlaitBoard.getBoardContainer(board).classList.remove('mind-node-resizing');\n    PlaitBoard.getBoardContainer(board).classList.remove(ResizeCursorClass['ew-resize']);\n    const component = PlaitElement.getComponent(element);\n    if (component && component.g) {\n        component.g.classList.remove('resizing');\n    }\n    IS_MIND_NODE_RESIZING.set(board, false);\n};\n\nexport const getSelectedTarget = (board: PlaitMindBoard, point: Point) => {\n    const selectedElements = getSelectedElements(board).filter(value => MindElement.isMindElement(board, value)) as MindElement[];\n    if (selectedElements.length > 0) {\n        const target = selectedElements.find(value => {\n            const rectangle = getResizeActiveRectangle(board, value);\n            return distanceBetweenPointAndRectangle(point[0], point[1], rectangle) <= 0;\n        });\n        return target ? target : null;\n    }\n\n    return null;\n};\n\nexport const getResizeActiveRectangle = (board: PlaitBoard, element: MindElement): RectangleClient => {\n    const node = MindElement.getNode(element);\n    const rectangle = getRectangleByNode(node);\n    return { x: rectangle.x + rectangle.width - EXTEND_OFFSET, y: rectangle.y, width: EXTEND_OFFSET * 2, height: rectangle.height };\n};\n"]}
|
|
@@ -1,24 +0,0 @@
|
|
|
1
|
-
import { insertAbstract, setAbstractsByRefs, setAbstractByStandardLayout } from './abstract-node';
|
|
2
|
-
import { setLayout } from './layout';
|
|
3
|
-
import { setTopic, setTopicSize, removeElements, insertNodes, insertAbstractNodes, setRightNodeCountByRefs, setNodeManualWidth } from './node';
|
|
4
|
-
import { addEmoji, removeEmoji, replaceEmoji } from './emoji';
|
|
5
|
-
import { removeImage, setImage } from './image';
|
|
6
|
-
export const MindTransforms = {
|
|
7
|
-
setLayout,
|
|
8
|
-
setTopic,
|
|
9
|
-
setTopicSize,
|
|
10
|
-
setNodeManualWidth,
|
|
11
|
-
addEmoji,
|
|
12
|
-
removeEmoji,
|
|
13
|
-
replaceEmoji,
|
|
14
|
-
insertAbstract,
|
|
15
|
-
setAbstractsByRefs,
|
|
16
|
-
setAbstractByStandardLayout,
|
|
17
|
-
removeElements,
|
|
18
|
-
insertNodes,
|
|
19
|
-
insertAbstractNodes,
|
|
20
|
-
setRightNodeCountByRefs,
|
|
21
|
-
removeImage,
|
|
22
|
-
setImage
|
|
23
|
-
};
|
|
24
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9taW5kL3NyYy90cmFuc2Zvcm1zL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxjQUFjLEVBQUUsa0JBQWtCLEVBQUUsMkJBQTJCLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUNsRyxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sVUFBVSxDQUFDO0FBQ3JDLE9BQU8sRUFDSCxRQUFRLEVBQ1IsWUFBWSxFQUNaLGNBQWMsRUFDZCxXQUFXLEVBQ1gsbUJBQW1CLEVBQ25CLHVCQUF1QixFQUN2QixrQkFBa0IsRUFDckIsTUFBTSxRQUFRLENBQUM7QUFDaEIsT0FBTyxFQUFFLFFBQVEsRUFBRSxXQUFXLEVBQUUsWUFBWSxFQUFFLE1BQU0sU0FBUyxDQUFDO0FBQzlELE9BQU8sRUFBRSxXQUFXLEVBQUUsUUFBUSxFQUFFLE1BQU0sU0FBUyxDQUFDO0FBRWhELE1BQU0sQ0FBQyxNQUFNLGNBQWMsR0FBRztJQUMxQixTQUFTO0lBQ1QsUUFBUTtJQUNSLFlBQVk7SUFDWixrQkFBa0I7SUFDbEIsUUFBUTtJQUNSLFdBQVc7SUFDWCxZQUFZO0lBQ1osY0FBYztJQUNkLGtCQUFrQjtJQUNsQiwyQkFBMkI7SUFDM0IsY0FBYztJQUNkLFdBQVc7SUFDWCxtQkFBbUI7SUFDbkIsdUJBQXVCO0lBQ3ZCLFdBQVc7SUFDWCxRQUFRO0NBQ1gsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGluc2VydEFic3RyYWN0LCBzZXRBYnN0cmFjdHNCeVJlZnMsIHNldEFic3RyYWN0QnlTdGFuZGFyZExheW91dCB9IGZyb20gJy4vYWJzdHJhY3Qtbm9kZSc7XG5pbXBvcnQgeyBzZXRMYXlvdXQgfSBmcm9tICcuL2xheW91dCc7XG5pbXBvcnQge1xuICAgIHNldFRvcGljLFxuICAgIHNldFRvcGljU2l6ZSxcbiAgICByZW1vdmVFbGVtZW50cyxcbiAgICBpbnNlcnROb2RlcyxcbiAgICBpbnNlcnRBYnN0cmFjdE5vZGVzLFxuICAgIHNldFJpZ2h0Tm9kZUNvdW50QnlSZWZzLFxuICAgIHNldE5vZGVNYW51YWxXaWR0aFxufSBmcm9tICcuL25vZGUnO1xuaW1wb3J0IHsgYWRkRW1vamksIHJlbW92ZUVtb2ppLCByZXBsYWNlRW1vamkgfSBmcm9tICcuL2Vtb2ppJztcbmltcG9ydCB7IHJlbW92ZUltYWdlLCBzZXRJbWFnZSB9IGZyb20gJy4vaW1hZ2UnO1xuXG5leHBvcnQgY29uc3QgTWluZFRyYW5zZm9ybXMgPSB7XG4gICAgc2V0TGF5b3V0LFxuICAgIHNldFRvcGljLFxuICAgIHNldFRvcGljU2l6ZSxcbiAgICBzZXROb2RlTWFudWFsV2lkdGgsXG4gICAgYWRkRW1vamksXG4gICAgcmVtb3ZlRW1vamksXG4gICAgcmVwbGFjZUVtb2ppLFxuICAgIGluc2VydEFic3RyYWN0LFxuICAgIHNldEFic3RyYWN0c0J5UmVmcyxcbiAgICBzZXRBYnN0cmFjdEJ5U3RhbmRhcmRMYXlvdXQsXG4gICAgcmVtb3ZlRWxlbWVudHMsXG4gICAgaW5zZXJ0Tm9kZXMsXG4gICAgaW5zZXJ0QWJzdHJhY3ROb2RlcyxcbiAgICBzZXRSaWdodE5vZGVDb3VudEJ5UmVmcyxcbiAgICByZW1vdmVJbWFnZSxcbiAgICBzZXRJbWFnZVxufTtcbiJdfQ==
|