@plait/mind 0.2.0-next.9 → 0.2.2
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/draw/richtext.d.ts +1 -1
- package/esm2020/draw/indented-link.mjs +3 -3
- package/esm2020/draw/link/logic-link.mjs +6 -4
- package/esm2020/draw/link.mjs +4 -4
- package/esm2020/draw/richtext.mjs +10 -8
- package/esm2020/draw/shape.mjs +2 -2
- package/esm2020/drawer/quick-insert.drawer.mjs +3 -3
- package/esm2020/interfaces/element.mjs +15 -1
- package/esm2020/interfaces/node.mjs +1 -10
- package/esm2020/node.component.mjs +49 -42
- package/esm2020/plugins/emoji/emoji.drawer.mjs +4 -8
- package/esm2020/plugins/emoji/emoji.mjs +31 -3
- package/esm2020/plugins/with-dnd.mjs +14 -9
- package/esm2020/plugins/with-mind.mjs +33 -27
- package/esm2020/queries/get-available-sublayouts-by-element.mjs +3 -3
- package/esm2020/queries/get-branch-layouts.mjs +4 -4
- package/esm2020/queries/get-layout-by-element.mjs +4 -4
- package/esm2020/transforms/abstract-node.mjs +3 -3
- package/esm2020/utils/dnd.mjs +9 -5
- package/esm2020/utils/draw-placeholder.mjs +7 -5
- package/esm2020/utils/index.mjs +1 -2
- package/esm2020/utils/mind.mjs +9 -16
- package/esm2020/utils/node-space.mjs +23 -18
- package/esm2020/utils/node-style/branch.mjs +14 -27
- package/esm2020/utils/node-style/common.mjs +13 -0
- package/esm2020/utils/node-style/index.mjs +3 -2
- package/esm2020/utils/node-style/shape.mjs +21 -0
- package/fesm2015/plait-mind.mjs +221 -188
- package/fesm2015/plait-mind.mjs.map +1 -1
- package/fesm2020/plait-mind.mjs +220 -186
- package/fesm2020/plait-mind.mjs.map +1 -1
- package/interfaces/element.d.ts +2 -0
- package/interfaces/node.d.ts +0 -1
- package/node.component.d.ts +3 -3
- package/package.json +1 -1
- package/plugins/emoji/emoji.d.ts +5 -1
- package/styles/styles.scss +19 -19
- package/utils/index.d.ts +0 -1
- package/utils/mind.d.ts +1 -2
- package/utils/node-space.d.ts +5 -4
- package/utils/node-style/branch.d.ts +4 -2
- package/utils/node-style/common.d.ts +3 -0
- package/utils/node-style/index.d.ts +2 -1
- package/utils/node-style/shape.d.ts +4 -0
- package/esm2020/utils/node-style/node.mjs +0 -23
- package/esm2020/utils/shape.mjs +0 -17
- package/utils/node-style/node.d.ts +0 -3
- package/utils/shape.d.ts +0 -2
|
@@ -1,5 +1,8 @@
|
|
|
1
|
-
import {
|
|
2
|
-
|
|
1
|
+
import { RectangleClient } from '@plait/core';
|
|
2
|
+
import { MindElement, PlaitMind } from '../../interfaces';
|
|
3
|
+
import { getRectangleByNode } from '../../utils/graph';
|
|
4
|
+
import { NodeSpace } from '../../utils/node-space';
|
|
5
|
+
export function getEmojisWidthHeight(board, element) {
|
|
3
6
|
const options = board.getMindOptions();
|
|
4
7
|
const count = element.data.emojis.length;
|
|
5
8
|
const fontSize = getEmojiFontSize(element);
|
|
@@ -16,4 +19,29 @@ export function getEmojiFontSize(element) {
|
|
|
16
19
|
return 14 + 2;
|
|
17
20
|
}
|
|
18
21
|
}
|
|
19
|
-
|
|
22
|
+
export function getEmojiRectangle(board, element) {
|
|
23
|
+
let { x, y } = getRectangleByNode(MindElement.getNode(element));
|
|
24
|
+
x = x + NodeSpace.getEmojiLeftSpace(board, element);
|
|
25
|
+
const { width, height } = getEmojisWidthHeight(board, element);
|
|
26
|
+
return {
|
|
27
|
+
x,
|
|
28
|
+
y,
|
|
29
|
+
width,
|
|
30
|
+
height
|
|
31
|
+
};
|
|
32
|
+
}
|
|
33
|
+
export function getEmojiForeignRectangle(board, element) {
|
|
34
|
+
let { x, y } = getRectangleByNode(MindElement.getNode(element));
|
|
35
|
+
x = x + NodeSpace.getEmojiLeftSpace(board, element);
|
|
36
|
+
const { width, height } = getEmojisWidthHeight(board, element);
|
|
37
|
+
return {
|
|
38
|
+
x,
|
|
39
|
+
y,
|
|
40
|
+
width,
|
|
41
|
+
height: height + NodeSpace.getEmojiTopSpace(element) * 2
|
|
42
|
+
};
|
|
43
|
+
}
|
|
44
|
+
export const isHitEmojis = (board, element, point) => {
|
|
45
|
+
return RectangleClient.isHit(RectangleClient.toRectangleClient([point, point]), getEmojiRectangle(board, element));
|
|
46
|
+
};
|
|
47
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW1vamkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9taW5kL3NyYy9wbHVnaW5zL2Vtb2ppL2Vtb2ppLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBcUIsZUFBZSxFQUFFLE1BQU0sYUFBYSxDQUFDO0FBQ2pFLE9BQU8sRUFBYSxXQUFXLEVBQUUsU0FBUyxFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFDckUsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFDdkQsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBR25ELE1BQU0sVUFBVSxvQkFBb0IsQ0FBQyxLQUFxQixFQUFFLE9BQStCO0lBQ3ZGLE1BQU0sT0FBTyxHQUFHLEtBQUssQ0FBQyxjQUFjLEVBQUUsQ0FBQztJQUN2QyxNQUFNLEtBQUssR0FBRyxPQUFPLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUM7SUFDekMsTUFBTSxRQUFRLEdBQUcsZ0JBQWdCLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDM0MsT0FBTztRQUNILEtBQUssRUFBRSxRQUFRLEdBQUcsS0FBSyxHQUFHLEtBQUssR0FBRyxDQUFDLEdBQUcsT0FBTyxDQUFDLFlBQVksR0FBRyxDQUFDLEtBQUssR0FBRyxDQUFDLENBQUMsR0FBRyxPQUFPLENBQUMsa0JBQWtCO1FBQ3JHLE1BQU0sRUFBRSxPQUFPLENBQUMsTUFBTTtLQUN6QixDQUFDO0FBQ04sQ0FBQztBQUVELE1BQU0sVUFBVSxnQkFBZ0IsQ0FBQyxPQUErQjtJQUM1RCxJQUFJLFNBQVMsQ0FBQyxNQUFNLENBQUMsT0FBTyxDQUFDLEVBQUU7UUFDM0IsT0FBTyxFQUFFLEdBQUcsQ0FBQyxDQUFDO0tBQ2pCO1NBQU07UUFDSCxPQUFPLEVBQUUsR0FBRyxDQUFDLENBQUM7S0FDakI7QUFDTCxDQUFDO0FBRUQsTUFBTSxVQUFVLGlCQUFpQixDQUFDLEtBQXFCLEVBQUUsT0FBK0I7SUFDcEYsSUFBSSxFQUFFLENBQUMsRUFBRSxDQUFDLEVBQUUsR0FBRyxrQkFBa0IsQ0FBQyxXQUFXLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUM7SUFDaEUsQ0FBQyxHQUFHLENBQUMsR0FBRyxTQUFTLENBQUMsaUJBQWlCLENBQUMsS0FBSyxFQUFFLE9BQU8sQ0FBQyxDQUFDO0lBQ3BELE1BQU0sRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLEdBQUcsb0JBQW9CLENBQUMsS0FBSyxFQUFFLE9BQU8sQ0FBQyxDQUFDO0lBQy9ELE9BQU87UUFDSCxDQUFDO1FBQ0QsQ0FBQztRQUNELEtBQUs7UUFDTCxNQUFNO0tBQ1QsQ0FBQztBQUNOLENBQUM7QUFFRCxNQUFNLFVBQVUsd0JBQXdCLENBQUMsS0FBcUIsRUFBRSxPQUErQjtJQUMzRixJQUFJLEVBQUUsQ0FBQyxFQUFFLENBQUMsRUFBRSxHQUFHLGtCQUFrQixDQUFDLFdBQVcsQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQztJQUNoRSxDQUFDLEdBQUcsQ0FBQyxHQUFHLFNBQVMsQ0FBQyxpQkFBaUIsQ0FBQyxLQUFLLEVBQUUsT0FBTyxDQUFDLENBQUM7SUFDcEQsTUFBTSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsR0FBRyxvQkFBb0IsQ0FBQyxLQUFLLEVBQUUsT0FBTyxDQUFDLENBQUM7SUFDL0QsT0FBTztRQUNILENBQUM7UUFDRCxDQUFDO1FBQ0QsS0FBSztRQUNMLE1BQU0sRUFBRSxNQUFNLEdBQUcsU0FBUyxDQUFDLGdCQUFnQixDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUM7S0FDM0QsQ0FBQztBQUNOLENBQUM7QUFFRCxNQUFNLENBQUMsTUFBTSxXQUFXLEdBQUcsQ0FBQyxLQUFpQixFQUFFLE9BQStCLEVBQUUsS0FBWSxFQUFFLEVBQUU7SUFDNUYsT0FBTyxlQUFlLENBQUMsS0FBSyxDQUFDLGVBQWUsQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDLEtBQUssRUFBRSxLQUFLLENBQUMsQ0FBQyxFQUFFLGlCQUFpQixDQUFDLEtBQXVCLEVBQUUsT0FBTyxDQUFDLENBQUMsQ0FBQztBQUN6SSxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQbGFpdEJvYXJkLCBQb2ludCwgUmVjdGFuZ2xlQ2xpZW50IH0gZnJvbSAnQHBsYWl0L2NvcmUnO1xuaW1wb3J0IHsgRW1vamlEYXRhLCBNaW5kRWxlbWVudCwgUGxhaXRNaW5kIH0gZnJvbSAnLi4vLi4vaW50ZXJmYWNlcyc7XG5pbXBvcnQgeyBnZXRSZWN0YW5nbGVCeU5vZGUgfSBmcm9tICcuLi8uLi91dGlscy9ncmFwaCc7XG5pbXBvcnQgeyBOb2RlU3BhY2UgfSBmcm9tICcuLi8uLi91dGlscy9ub2RlLXNwYWNlJztcbmltcG9ydCB7IFBsYWl0TWluZEJvYXJkIH0gZnJvbSAnLi4vd2l0aC1leHRlbmQtbWluZCc7XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXRFbW9qaXNXaWR0aEhlaWdodChib2FyZDogUGxhaXRNaW5kQm9hcmQsIGVsZW1lbnQ6IE1pbmRFbGVtZW50PEVtb2ppRGF0YT4pIHtcbiAgICBjb25zdCBvcHRpb25zID0gYm9hcmQuZ2V0TWluZE9wdGlvbnMoKTtcbiAgICBjb25zdCBjb3VudCA9IGVsZW1lbnQuZGF0YS5lbW9qaXMubGVuZ3RoO1xuICAgIGNvbnN0IGZvbnRTaXplID0gZ2V0RW1vamlGb250U2l6ZShlbGVtZW50KTtcbiAgICByZXR1cm4ge1xuICAgICAgICB3aWR0aDogZm9udFNpemUgKiBjb3VudCArIGNvdW50ICogMiAqIG9wdGlvbnMuZW1vamlQYWRkaW5nICsgKGNvdW50IC0gMSkgKiBvcHRpb25zLnNwYWNlQmV0d2VlbkVtb2ppcyxcbiAgICAgICAgaGVpZ2h0OiBlbGVtZW50LmhlaWdodFxuICAgIH07XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXRFbW9qaUZvbnRTaXplKGVsZW1lbnQ6IE1pbmRFbGVtZW50PEVtb2ppRGF0YT4pIHtcbiAgICBpZiAoUGxhaXRNaW5kLmlzTWluZChlbGVtZW50KSkge1xuICAgICAgICByZXR1cm4gMTggKyAyO1xuICAgIH0gZWxzZSB7XG4gICAgICAgIHJldHVybiAxNCArIDI7XG4gICAgfVxufVxuXG5leHBvcnQgZnVuY3Rpb24gZ2V0RW1vamlSZWN0YW5nbGUoYm9hcmQ6IFBsYWl0TWluZEJvYXJkLCBlbGVtZW50OiBNaW5kRWxlbWVudDxFbW9qaURhdGE+KTogUmVjdGFuZ2xlQ2xpZW50IHtcbiAgICBsZXQgeyB4LCB5IH0gPSBnZXRSZWN0YW5nbGVCeU5vZGUoTWluZEVsZW1lbnQuZ2V0Tm9kZShlbGVtZW50KSk7XG4gICAgeCA9IHggKyBOb2RlU3BhY2UuZ2V0RW1vamlMZWZ0U3BhY2UoYm9hcmQsIGVsZW1lbnQpO1xuICAgIGNvbnN0IHsgd2lkdGgsIGhlaWdodCB9ID0gZ2V0RW1vamlzV2lkdGhIZWlnaHQoYm9hcmQsIGVsZW1lbnQpO1xuICAgIHJldHVybiB7XG4gICAgICAgIHgsXG4gICAgICAgIHksXG4gICAgICAgIHdpZHRoLFxuICAgICAgICBoZWlnaHRcbiAgICB9O1xufVxuXG5leHBvcnQgZnVuY3Rpb24gZ2V0RW1vamlGb3JlaWduUmVjdGFuZ2xlKGJvYXJkOiBQbGFpdE1pbmRCb2FyZCwgZWxlbWVudDogTWluZEVsZW1lbnQ8RW1vamlEYXRhPik6IFJlY3RhbmdsZUNsaWVudCB7XG4gICAgbGV0IHsgeCwgeSB9ID0gZ2V0UmVjdGFuZ2xlQnlOb2RlKE1pbmRFbGVtZW50LmdldE5vZGUoZWxlbWVudCkpO1xuICAgIHggPSB4ICsgTm9kZVNwYWNlLmdldEVtb2ppTGVmdFNwYWNlKGJvYXJkLCBlbGVtZW50KTtcbiAgICBjb25zdCB7IHdpZHRoLCBoZWlnaHQgfSA9IGdldEVtb2ppc1dpZHRoSGVpZ2h0KGJvYXJkLCBlbGVtZW50KTtcbiAgICByZXR1cm4ge1xuICAgICAgICB4LFxuICAgICAgICB5LFxuICAgICAgICB3aWR0aCxcbiAgICAgICAgaGVpZ2h0OiBoZWlnaHQgKyBOb2RlU3BhY2UuZ2V0RW1vamlUb3BTcGFjZShlbGVtZW50KSAqIDJcbiAgICB9O1xufVxuXG5leHBvcnQgY29uc3QgaXNIaXRFbW9qaXMgPSAoYm9hcmQ6IFBsYWl0Qm9hcmQsIGVsZW1lbnQ6IE1pbmRFbGVtZW50PEVtb2ppRGF0YT4sIHBvaW50OiBQb2ludCkgPT4ge1xuICAgIHJldHVybiBSZWN0YW5nbGVDbGllbnQuaXNIaXQoUmVjdGFuZ2xlQ2xpZW50LnRvUmVjdGFuZ2xlQ2xpZW50KFtwb2ludCwgcG9pbnRdKSwgZ2V0RW1vamlSZWN0YW5nbGUoYm9hcmQgYXMgUGxhaXRNaW5kQm9hcmQsIGVsZW1lbnQpKTtcbn07XG4iXX0=
|
|
@@ -1,14 +1,13 @@
|
|
|
1
|
-
import { createG, distanceBetweenPointAndPoint, IS_TEXT_EDITABLE, PlaitBoard, PlaitElement, toPoint, transformPoint, Transforms, ELEMENT_TO_COMPONENT, getSelectedElements } from '@plait/core';
|
|
1
|
+
import { createG, distanceBetweenPointAndPoint, IS_TEXT_EDITABLE, PlaitBoard, PlaitElement, toPoint, transformPoint, Transforms, ELEMENT_TO_COMPONENT, getSelectedElements, updateForeignObject } from '@plait/core';
|
|
2
2
|
import { AbstractNode, isStandardLayout } from '@plait/layouts';
|
|
3
|
-
import { updateForeignObject } from '@plait/richtext';
|
|
4
|
-
import { BASE } from '../constants';
|
|
5
3
|
import { getRichtextRectangleByNode } from '../draw/richtext';
|
|
6
4
|
import { drawRectangleNode } from '../draw/shape';
|
|
7
|
-
import { PlaitMind } from '../interfaces/element';
|
|
5
|
+
import { MindElement, PlaitMind } from '../interfaces/element';
|
|
8
6
|
import { directionCorrector, directionDetector, drawPlaceholderDropNodeG, findUpElement, readjustmentDropTarget } from '../utils';
|
|
9
7
|
import { getRectangleByNode, hitMindElement } from '../utils/graph';
|
|
10
8
|
import { MindQueries } from '../queries';
|
|
11
9
|
import { addActiveOnDragOrigin, isDragging, isValidTarget, removeActiveOnDragOrigin, setIsDragging, updateAbstractInDnd, updatePathByLayoutAndDropTarget, updateRightNodeCount } from '../utils/dnd';
|
|
10
|
+
import { getEmojiForeignRectangle } from './emoji/emoji';
|
|
12
11
|
const DRAG_MOVE_BUFFER = 5;
|
|
13
12
|
export const withDnd = (board) => {
|
|
14
13
|
const { mousedown, mousemove, globalMouseup, keydown } = board;
|
|
@@ -30,8 +29,8 @@ export const withDnd = (board) => {
|
|
|
30
29
|
return;
|
|
31
30
|
}
|
|
32
31
|
if (PlaitMind.isMind(value)) {
|
|
33
|
-
const
|
|
34
|
-
const root =
|
|
32
|
+
const mindComponent = ELEMENT_TO_COMPONENT.get(value);
|
|
33
|
+
const root = mindComponent.root;
|
|
35
34
|
root.eachNode((node) => {
|
|
36
35
|
if (activeElement) {
|
|
37
36
|
return;
|
|
@@ -80,7 +79,6 @@ export const withDnd = (board) => {
|
|
|
80
79
|
const offsetX = endPoint[0] - startPoint[0];
|
|
81
80
|
const offsetY = endPoint[1] - startPoint[1];
|
|
82
81
|
const activeComponent = PlaitElement.getComponent(activeElement);
|
|
83
|
-
const roughSVG = PlaitBoard.getRoughSVG(board);
|
|
84
82
|
const fakeDraggingNode = {
|
|
85
83
|
...activeComponent.node,
|
|
86
84
|
children: [],
|
|
@@ -90,9 +88,16 @@ export const withDnd = (board) => {
|
|
|
90
88
|
const textRectangle = getRichtextRectangleByNode(board, activeComponent.node);
|
|
91
89
|
const fakeNodeG = drawRectangleNode(board, fakeDraggingNode);
|
|
92
90
|
const richtextG = activeComponent.richtextG?.cloneNode(true);
|
|
93
|
-
updateForeignObject(richtextG, textRectangle.width
|
|
91
|
+
updateForeignObject(richtextG, textRectangle.width, textRectangle.height, textRectangle.x + offsetX, textRectangle.y + offsetY);
|
|
94
92
|
fakeDragNodeG?.append(fakeNodeG);
|
|
95
93
|
fakeDragNodeG?.append(richtextG);
|
|
94
|
+
// draw emojis
|
|
95
|
+
if (MindElement.hasEmojis(activeElement)) {
|
|
96
|
+
const fakeEmojisG = activeComponent.emojisDrawer.g.cloneNode(true);
|
|
97
|
+
const foreignRectangle = getEmojiForeignRectangle(board, activeElement);
|
|
98
|
+
updateForeignObject(fakeEmojisG, foreignRectangle.width, foreignRectangle.height, foreignRectangle.x + offsetX, foreignRectangle.y + offsetY);
|
|
99
|
+
fakeDragNodeG?.append(fakeEmojisG);
|
|
100
|
+
}
|
|
96
101
|
// drop position detect
|
|
97
102
|
const { x, y } = getRectangleByNode(fakeDraggingNode);
|
|
98
103
|
const detectCenterPoint = [x + textRectangle.width / 2, y + textRectangle.height / 2];
|
|
@@ -171,4 +176,4 @@ export const withDnd = (board) => {
|
|
|
171
176
|
};
|
|
172
177
|
return board;
|
|
173
178
|
};
|
|
174
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-dnd.js","sourceRoot":"","sources":["../../../../packages/mind/src/plugins/with-dnd.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    createG,\n    distanceBetweenPointAndPoint,\n    IS_TEXT_EDITABLE,\n    Path,\n    PlaitBoard,\n    PlaitElement,\n    Point,\n    toPoint,\n    transformPoint,\n    Transforms,\n    ELEMENT_TO_COMPONENT,\n    getSelectedElements\n} from '@plait/core';\nimport { AbstractNode, isStandardLayout } from '@plait/layouts';\nimport { updateForeignObject } from '@plait/richtext';\nimport { BASE } from '../constants';\nimport { getRichtextRectangleByNode } from '../draw/richtext';\nimport { drawRectangleNode } from '../draw/shape';\nimport { MindElement, PlaitMind } from '../interfaces/element';\nimport { DetectResult, MindNode } from '../interfaces/node';\nimport { MindNodeComponent } from '../node.component';\nimport { directionCorrector, directionDetector, drawPlaceholderDropNodeG, findUpElement, readjustmentDropTarget } from '../utils';\nimport { getRectangleByNode, hitMindElement } from '../utils/graph';\nimport { MindQueries } from '../queries';\nimport { PlaitMindComponent } from '../mind.component';\nimport { PlaitMindBoard } from './with-extend-mind';\nimport {\n    addActiveOnDragOrigin,\n    isDragging,\n    isValidTarget,\n    removeActiveOnDragOrigin,\n    setIsDragging,\n    updateAbstractInDnd,\n    updatePathByLayoutAndDropTarget,\n    updateRightNodeCount\n} from '../utils/dnd';\n\nconst DRAG_MOVE_BUFFER = 5;\n\nexport const withDnd = (board: PlaitBoard) => {\n    const { mousedown, mousemove, globalMouseup, keydown } = board;\n\n    let activeElement: MindElement | null;\n    let startPoint: Point;\n    let fakeDragNodeG: SVGGElement | undefined;\n    let fakeDropNodeG: SVGGElement | undefined;\n    let dropTarget: { target: MindElement; detectResult: DetectResult } | null = null;\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        board.children.forEach((value: PlaitElement) => {\n            if (activeElement) {\n                return;\n            }\n            if (PlaitMind.isMind(value)) {\n                const mindmapComponent = ELEMENT_TO_COMPONENT.get(value) as PlaitMindComponent;\n                const root = mindmapComponent?.root;\n                (root as any).eachNode((node: MindNode) => {\n                    if (activeElement) {\n                        return;\n                    }\n\n                    const canDrag =\n                        hitMindElement(board, point, node.origin) &&\n                        !node.origin.isRoot &&\n                        !AbstractNode.isAbstract(node.origin) &&\n                        selectedElements.length <= 1;\n\n                    if (canDrag) {\n                        activeElement = node.origin;\n                        startPoint = point;\n                    }\n                });\n            }\n        });\n\n        if (activeElement) {\n            event.preventDefault();\n        }\n\n        mousedown(event);\n    };\n\n    board.mousemove = (event: MouseEvent) => {\n        if (!board.options.readonly && activeElement && 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            if (!isDragging(board)) {\n                setIsDragging(board, true);\n                fakeDragNodeG = createG();\n                fakeDragNodeG.classList.add('dragging', 'fake-node', 'plait-board-attached');\n                fakeDropNodeG = createG();\n                addActiveOnDragOrigin(activeElement);\n                PlaitBoard.getHost(board).appendChild(fakeDropNodeG);\n                PlaitBoard.getHost(board).appendChild(fakeDragNodeG);\n            } else {\n                if (fakeDragNodeG) {\n                    fakeDragNodeG.innerHTML = '';\n                }\n\n                fakeDropNodeG?.childNodes.forEach(node => {\n                    node.remove();\n                });\n            }\n\n            // fake dragging origin node\n            const offsetX = endPoint[0] - startPoint[0];\n            const offsetY = endPoint[1] - startPoint[1];\n            const activeComponent = PlaitElement.getComponent(activeElement) as MindNodeComponent;\n            const roughSVG = PlaitBoard.getRoughSVG(board);\n            const fakeDraggingNode: MindNode = {\n                ...activeComponent.node,\n                children: [],\n                x: activeComponent.node.x + offsetX,\n                y: activeComponent.node.y + offsetY\n            };\n            const textRectangle = getRichtextRectangleByNode(board as PlaitMindBoard, activeComponent.node);\n            const fakeNodeG = drawRectangleNode(board, fakeDraggingNode);\n            const richtextG = activeComponent.richtextG?.cloneNode(true) as SVGGElement;\n            updateForeignObject(\n                richtextG,\n                textRectangle.width + BASE * 10,\n                textRectangle.height,\n                textRectangle.x + offsetX,\n                textRectangle.y + offsetY\n            );\n            fakeDragNodeG?.append(fakeNodeG);\n            fakeDragNodeG?.append(richtextG);\n\n            // drop position detect\n            const { x, y } = getRectangleByNode(fakeDraggingNode);\n            const detectCenterPoint = [x + textRectangle.width / 2, y + textRectangle.height / 2] as Point;\n\n            let detectResult: DetectResult[] | null = null;\n            board.children.forEach((value: PlaitElement) => {\n                if (detectResult) {\n                    return;\n                }\n                if (PlaitMind.isMind(value)) {\n                    const mindmapComponent = ELEMENT_TO_COMPONENT.get(value) as PlaitMindComponent;\n                    const root = mindmapComponent?.root;\n\n                    (root as any).eachNode((node: MindNode) => {\n                        if (detectResult) {\n                            return;\n                        }\n                        const directions = directionDetector(node, detectCenterPoint);\n                        if (directions) {\n                            detectResult = directionCorrector(board, node, directions);\n                        }\n                        dropTarget = null;\n                        if (detectResult && isValidTarget(activeComponent.node.origin, node.origin)) {\n                            dropTarget = { target: node.origin, detectResult: detectResult[0] };\n                        }\n                    });\n                }\n            });\n\n            if (dropTarget?.target) {\n                dropTarget = readjustmentDropTarget(board, dropTarget);\n                drawPlaceholderDropNodeG(board, dropTarget, fakeDropNodeG);\n            }\n        }\n\n        mousemove(event);\n    };\n\n    board.globalMouseup = (event: MouseEvent) => {\n        if (!board.options.readonly && activeElement) {\n            if (dropTarget?.target) {\n                const activeComponent = PlaitElement.getComponent(activeElement) as MindNodeComponent;\n                const targetComponent = PlaitElement.getComponent(dropTarget.target) as MindNodeComponent;\n                let targetPath = PlaitBoard.findPath(board, targetComponent.element);\n                const mindElement = findUpElement(dropTarget.target).root;\n                const mindComponent = ELEMENT_TO_COMPONENT.get(mindElement as PlaitMind) as PlaitMindComponent;\n                const layout = MindQueries.getCorrectLayoutByElement(board, mindComponent?.root.origin as MindElement);\n                targetPath = updatePathByLayoutAndDropTarget(targetPath, layout, dropTarget);\n                const originPath = PlaitBoard.findPath(board, activeComponent.element);\n                let newElement: Partial<MindElement> = { isCollapsed: false },\n                    rightTargetPath = PlaitBoard.findPath(board, targetComponent.element);\n\n                updateAbstractInDnd(board, [activeElement], targetPath);\n\n                if (isStandardLayout(layout)) {\n                    updateRightNodeCount(board, activeComponent, targetComponent, dropTarget.detectResult);\n                }\n\n                if (dropTarget.detectResult === 'right') {\n                    if (targetComponent.node.origin.isRoot) {\n                        targetPath = PlaitBoard.findPath(board, targetComponent.element);\n                        targetPath.push(0);\n                        const rightNodeCount = (targetComponent.node.origin.rightNodeCount as number) + 1;\n                        newElement = { isCollapsed: false, rightNodeCount };\n                    }\n                    Transforms.setNode(board, newElement, rightTargetPath as Path);\n                }\n\n                Transforms.moveNode(board, originPath, targetPath);\n            }\n\n            if (isDragging(board)) {\n                removeActiveOnDragOrigin(activeElement);\n            }\n            setIsDragging(board, false);\n            activeElement = null;\n            fakeDragNodeG?.remove();\n            fakeDragNodeG = undefined;\n            fakeDropNodeG?.remove();\n            fakeDropNodeG = undefined;\n            dropTarget = null;\n        }\n        globalMouseup(event);\n    };\n\n    board.keydown = (event: KeyboardEvent) => {\n        keydown(event);\n    };\n\n    return board;\n};\n"]}
|
|
179
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-dnd.js","sourceRoot":"","sources":["../../../../packages/mind/src/plugins/with-dnd.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    createG,\n    distanceBetweenPointAndPoint,\n    IS_TEXT_EDITABLE,\n    Path,\n    PlaitBoard,\n    PlaitElement,\n    Point,\n    toPoint,\n    transformPoint,\n    Transforms,\n    ELEMENT_TO_COMPONENT,\n    getSelectedElements,\n    updateForeignObject\n} from '@plait/core';\nimport { AbstractNode, isStandardLayout } from '@plait/layouts';\nimport { getRichtextRectangleByNode } from '../draw/richtext';\nimport { drawRectangleNode } from '../draw/shape';\nimport { MindElement, PlaitMind } from '../interfaces/element';\nimport { DetectResult, MindNode } from '../interfaces/node';\nimport { MindNodeComponent } from '../node.component';\nimport { directionCorrector, directionDetector, drawPlaceholderDropNodeG, findUpElement, readjustmentDropTarget } from '../utils';\nimport { getRectangleByNode, hitMindElement } from '../utils/graph';\nimport { MindQueries } from '../queries';\nimport { PlaitMindComponent } from '../mind.component';\nimport { PlaitMindBoard } from './with-extend-mind';\nimport {\n    addActiveOnDragOrigin,\n    isDragging,\n    isValidTarget,\n    removeActiveOnDragOrigin,\n    setIsDragging,\n    updateAbstractInDnd,\n    updatePathByLayoutAndDropTarget,\n    updateRightNodeCount\n} from '../utils/dnd';\nimport { getEmojiForeignRectangle } from './emoji/emoji';\n\nconst DRAG_MOVE_BUFFER = 5;\n\nexport const withDnd = (board: PlaitBoard) => {\n    const { mousedown, mousemove, globalMouseup, keydown } = board;\n\n    let activeElement: MindElement | null;\n    let startPoint: Point;\n    let fakeDragNodeG: SVGGElement | undefined;\n    let fakeDropNodeG: SVGGElement | undefined;\n    let dropTarget: { target: MindElement; detectResult: DetectResult } | null = null;\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        board.children.forEach((value: PlaitElement) => {\n            if (activeElement) {\n                return;\n            }\n            if (PlaitMind.isMind(value)) {\n                const mindComponent = ELEMENT_TO_COMPONENT.get(value) as PlaitMindComponent;\n                const root = mindComponent.root;\n                (root as any).eachNode((node: MindNode) => {\n                    if (activeElement) {\n                        return;\n                    }\n\n                    const canDrag =\n                        hitMindElement(board, point, node.origin) &&\n                        !node.origin.isRoot &&\n                        !AbstractNode.isAbstract(node.origin) &&\n                        selectedElements.length <= 1;\n\n                    if (canDrag) {\n                        activeElement = node.origin;\n                        startPoint = point;\n                    }\n                });\n            }\n        });\n\n        if (activeElement) {\n            event.preventDefault();\n        }\n\n        mousedown(event);\n    };\n\n    board.mousemove = (event: MouseEvent) => {\n        if (!board.options.readonly && activeElement && 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            if (!isDragging(board)) {\n                setIsDragging(board, true);\n                fakeDragNodeG = createG();\n                fakeDragNodeG.classList.add('dragging', 'fake-node', 'plait-board-attached');\n                fakeDropNodeG = createG();\n                addActiveOnDragOrigin(activeElement);\n                PlaitBoard.getHost(board).appendChild(fakeDropNodeG);\n                PlaitBoard.getHost(board).appendChild(fakeDragNodeG);\n            } else {\n                if (fakeDragNodeG) {\n                    fakeDragNodeG.innerHTML = '';\n                }\n\n                fakeDropNodeG?.childNodes.forEach(node => {\n                    node.remove();\n                });\n            }\n\n            // fake dragging origin node\n            const offsetX = endPoint[0] - startPoint[0];\n            const offsetY = endPoint[1] - startPoint[1];\n            const activeComponent = PlaitElement.getComponent(activeElement) as MindNodeComponent;\n            const fakeDraggingNode: MindNode = {\n                ...activeComponent.node,\n                children: [],\n                x: activeComponent.node.x + offsetX,\n                y: activeComponent.node.y + offsetY\n            };\n            const textRectangle = getRichtextRectangleByNode(board as PlaitMindBoard, activeComponent.node);\n            const fakeNodeG = drawRectangleNode(board, fakeDraggingNode);\n            const richtextG = activeComponent.richtextG?.cloneNode(true) as SVGGElement;\n\n            updateForeignObject(richtextG, textRectangle.width, textRectangle.height, textRectangle.x + offsetX, textRectangle.y + offsetY);\n\n            fakeDragNodeG?.append(fakeNodeG);\n            fakeDragNodeG?.append(richtextG);\n\n            // draw emojis\n            if (MindElement.hasEmojis(activeElement)) {\n                const fakeEmojisG = (activeComponent.emojisDrawer.g as SVGGElement).cloneNode(true) as SVGGElement;\n                const foreignRectangle = getEmojiForeignRectangle(board as PlaitMindBoard, activeElement);\n                updateForeignObject(\n                    fakeEmojisG,\n                    foreignRectangle.width,\n                    foreignRectangle.height,\n                    foreignRectangle.x + offsetX,\n                    foreignRectangle.y + offsetY\n                );\n                fakeDragNodeG?.append(fakeEmojisG);\n            }\n\n            // drop position detect\n            const { x, y } = getRectangleByNode(fakeDraggingNode);\n            const detectCenterPoint = [x + textRectangle.width / 2, y + textRectangle.height / 2] as Point;\n\n            let detectResult: DetectResult[] | null = null;\n            board.children.forEach((value: PlaitElement) => {\n                if (detectResult) {\n                    return;\n                }\n                if (PlaitMind.isMind(value)) {\n                    const mindmapComponent = ELEMENT_TO_COMPONENT.get(value) as PlaitMindComponent;\n                    const root = mindmapComponent?.root;\n\n                    (root as any).eachNode((node: MindNode) => {\n                        if (detectResult) {\n                            return;\n                        }\n                        const directions = directionDetector(node, detectCenterPoint);\n                        if (directions) {\n                            detectResult = directionCorrector(board, node, directions);\n                        }\n                        dropTarget = null;\n                        if (detectResult && isValidTarget(activeComponent.node.origin, node.origin)) {\n                            dropTarget = { target: node.origin, detectResult: detectResult[0] };\n                        }\n                    });\n                }\n            });\n\n            if (dropTarget?.target) {\n                dropTarget = readjustmentDropTarget(board, dropTarget);\n                drawPlaceholderDropNodeG(board, dropTarget, fakeDropNodeG);\n            }\n        }\n\n        mousemove(event);\n    };\n\n    board.globalMouseup = (event: MouseEvent) => {\n        if (!board.options.readonly && activeElement) {\n            if (dropTarget?.target) {\n                const activeComponent = PlaitElement.getComponent(activeElement) as MindNodeComponent;\n                const targetComponent = PlaitElement.getComponent(dropTarget.target) as MindNodeComponent;\n                let targetPath = PlaitBoard.findPath(board, targetComponent.element);\n                const mindElement = findUpElement(dropTarget.target).root;\n                const mindComponent = ELEMENT_TO_COMPONENT.get(mindElement as PlaitMind) as PlaitMindComponent;\n                const layout = MindQueries.getCorrectLayoutByElement(board, mindComponent?.root.origin as MindElement);\n                targetPath = updatePathByLayoutAndDropTarget(targetPath, layout, dropTarget);\n                const originPath = PlaitBoard.findPath(board, activeComponent.element);\n                let newElement: Partial<MindElement> = { isCollapsed: false },\n                    rightTargetPath = PlaitBoard.findPath(board, targetComponent.element);\n\n                updateAbstractInDnd(board, [activeElement], targetPath);\n\n                if (isStandardLayout(layout)) {\n                    updateRightNodeCount(board, activeComponent, targetComponent, dropTarget.detectResult);\n                }\n\n                if (dropTarget.detectResult === 'right') {\n                    if (targetComponent.node.origin.isRoot) {\n                        targetPath = PlaitBoard.findPath(board, targetComponent.element);\n                        targetPath.push(0);\n                        const rightNodeCount = (targetComponent.node.origin.rightNodeCount as number) + 1;\n                        newElement = { isCollapsed: false, rightNodeCount };\n                    }\n                    Transforms.setNode(board, newElement, rightTargetPath as Path);\n                }\n\n                Transforms.moveNode(board, originPath, targetPath);\n            }\n\n            if (isDragging(board)) {\n                removeActiveOnDragOrigin(activeElement);\n            }\n            setIsDragging(board, false);\n            activeElement = null;\n            fakeDragNodeG?.remove();\n            fakeDragNodeG = undefined;\n            fakeDropNodeG?.remove();\n            fakeDropNodeG = undefined;\n            dropTarget = null;\n        }\n        globalMouseup(event);\n    };\n\n    board.keydown = (event: KeyboardEvent) => {\n        keydown(event);\n    };\n\n    return board;\n};\n"]}
|
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
import { addSelectedElement, getSelectedElements, hotkeys, IS_TEXT_EDITABLE, PlaitBoard, PlaitHistoryBoard, RectangleClient, removeSelectedElement, toPoint, transformPoint, Transforms, depthFirstRecursion,
|
|
1
|
+
import { addSelectedElement, getSelectedElements, hotkeys, IS_TEXT_EDITABLE, PlaitBoard, PlaitHistoryBoard, RectangleClient, removeSelectedElement, toPoint, transformPoint, Transforms, depthFirstRecursion, Path, Selection } from '@plait/core';
|
|
2
2
|
import { getSizeByText } from '@plait/richtext';
|
|
3
3
|
import { MindElement, PlaitMind } from '../interfaces';
|
|
4
4
|
import { PlaitMindComponent } from '../mind.component';
|
|
5
5
|
import { MindNodeComponent } from '../node.component';
|
|
6
|
-
import { changeRightNodeCount, insertMindElement, deleteSelectedELements,
|
|
6
|
+
import { changeRightNodeCount, insertMindElement, deleteSelectedELements, getFirstLevelElement, shouldChangeRightNodeCount, insertElementHandleAbstract } from '../utils';
|
|
7
7
|
import { getRectangleByNode, hitMindElement } from '../utils/graph';
|
|
8
8
|
import { isVirtualKey } from '../utils/is-virtual-key';
|
|
9
9
|
import { withDnd } from './with-dnd';
|
|
@@ -15,6 +15,7 @@ import { withAbstract } from './with-abstract';
|
|
|
15
15
|
import { withExtendMind } from './with-extend-mind';
|
|
16
16
|
import { TOPIC_DEFAULT_MAX_WORD_COUNT } from '../constants/node-topic-style';
|
|
17
17
|
import { MindTransforms } from '../transforms';
|
|
18
|
+
import { isHitEmojis } from './emoji/emoji';
|
|
18
19
|
export const withMind = (board) => {
|
|
19
20
|
const { drawElement, dblclick, keydown, insertFragment, setFragment, deleteFragment, isHitSelection, getRectangle, isMovable, isRecursion } = board;
|
|
20
21
|
board.drawElement = (context) => {
|
|
@@ -41,7 +42,11 @@ export const withMind = (board) => {
|
|
|
41
42
|
board.isHitSelection = (element, range) => {
|
|
42
43
|
if (MindElement.isMindElement(board, element) && board.selection) {
|
|
43
44
|
const client = getRectangleByNode(MindElement.getNode(element));
|
|
44
|
-
|
|
45
|
+
const isHit = RectangleClient.isHit(RectangleClient.toRectangleClient([range.anchor, range.focus]), client);
|
|
46
|
+
if (isHit && MindElement.hasEmojis(element) && Selection.isCollapsed(range) && isHitEmojis(board, element, range.anchor)) {
|
|
47
|
+
return false;
|
|
48
|
+
}
|
|
49
|
+
return isHit;
|
|
45
50
|
}
|
|
46
51
|
return isHitSelection(element, range);
|
|
47
52
|
};
|
|
@@ -87,31 +92,32 @@ export const withMind = (board) => {
|
|
|
87
92
|
if (hotkeys.isDeleteBackward(event) || hotkeys.isDeleteForward(event)) {
|
|
88
93
|
event.preventDefault();
|
|
89
94
|
deleteSelectedELements(board, selectedElements);
|
|
90
|
-
let
|
|
91
|
-
const firstLevelElements =
|
|
95
|
+
let activeElement;
|
|
96
|
+
const firstLevelElements = getFirstLevelElement(selectedElements);
|
|
97
|
+
if (AbstractNode.isAbstract(firstLevelElements[0])) {
|
|
98
|
+
const parent = MindElement.getParent(firstLevelElements[0]);
|
|
99
|
+
activeElement = parent.children[firstLevelElements[0].start];
|
|
100
|
+
}
|
|
92
101
|
const firstElement = firstLevelElements[0];
|
|
93
|
-
const
|
|
94
|
-
const
|
|
95
|
-
|
|
96
|
-
return findParentElement(element) && findParentElement(firstLevelElements[0]) === findParentElement(element);
|
|
102
|
+
const firstElementParent = MindElement.findParent(firstElement);
|
|
103
|
+
const hasSameParent = firstLevelElements.every(element => {
|
|
104
|
+
return MindElement.findParent(element) === firstElementParent;
|
|
97
105
|
});
|
|
98
|
-
if (
|
|
99
|
-
const
|
|
100
|
-
|
|
101
|
-
|
|
106
|
+
if (firstElementParent && hasSameParent && !activeElement) {
|
|
107
|
+
const firstElementIndex = firstElementParent.children.indexOf(firstElement);
|
|
108
|
+
const childrenCount = firstElementParent.children.length;
|
|
109
|
+
// active parent element
|
|
110
|
+
if (childrenCount === firstLevelElements.length) {
|
|
111
|
+
activeElement = firstElementParent;
|
|
102
112
|
}
|
|
103
|
-
else
|
|
104
|
-
|
|
113
|
+
else {
|
|
114
|
+
if (firstElementIndex > 0) {
|
|
115
|
+
activeElement = firstElementParent.children[firstElementIndex - 1];
|
|
116
|
+
}
|
|
105
117
|
}
|
|
106
|
-
else if (nodeIndex > 0) {
|
|
107
|
-
lastNode = firstComponent?.parent.children[nodeIndex - 1];
|
|
108
|
-
}
|
|
109
|
-
}
|
|
110
|
-
if (firstLevelElements.length === 1 && AbstractNode.isAbstract(firstElement)) {
|
|
111
|
-
lastNode = firstComponent.parent.children[firstElement.start];
|
|
112
118
|
}
|
|
113
|
-
if (
|
|
114
|
-
addSelectedElement(board,
|
|
119
|
+
if (activeElement) {
|
|
120
|
+
addSelectedElement(board, activeElement);
|
|
115
121
|
}
|
|
116
122
|
return;
|
|
117
123
|
}
|
|
@@ -138,8 +144,8 @@ export const withMind = (board) => {
|
|
|
138
144
|
const point = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));
|
|
139
145
|
board.children
|
|
140
146
|
.filter(value => PlaitMind.isMind(value))
|
|
141
|
-
.forEach(
|
|
142
|
-
depthFirstRecursion(
|
|
147
|
+
.forEach(mindMap => {
|
|
148
|
+
depthFirstRecursion(mindMap, node => {
|
|
143
149
|
if (!PlaitBoard.hasBeenTextEditing(board) && hitMindElement(board, point, node)) {
|
|
144
150
|
enterNodeEditing(node);
|
|
145
151
|
}
|
|
@@ -151,7 +157,7 @@ export const withMind = (board) => {
|
|
|
151
157
|
dblclick(event);
|
|
152
158
|
};
|
|
153
159
|
board.setFragment = (data) => {
|
|
154
|
-
const selectedElements =
|
|
160
|
+
const selectedElements = getFirstLevelElement(getSelectedElements(board));
|
|
155
161
|
if (selectedElements.length) {
|
|
156
162
|
const elements = buildClipboardData(board, selectedElements);
|
|
157
163
|
setClipboardData(data, elements);
|
|
@@ -185,4 +191,4 @@ export const withMind = (board) => {
|
|
|
185
191
|
};
|
|
186
192
|
return withExtendMind(withAbstract(withDnd(board)));
|
|
187
193
|
};
|
|
188
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-mind.js","sourceRoot":"","sources":["../../../../packages/mind/src/plugins/with-mind.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    addSelectedElement,\n    getSelectedElements,\n    hotkeys,\n    IS_TEXT_EDITABLE,\n    PlaitBoard,\n    PlaitHistoryBoard,\n    PlaitPluginElementContext,\n    Point,\n    RectangleClient,\n    removeSelectedElement,\n    toPoint,\n    transformPoint,\n    Transforms,\n    Range,\n    depthFirstRecursion,\n    PlaitElement,\n    Path\n} from '@plait/core';\nimport { getSizeByText } from '@plait/richtext';\nimport { MindElement, PlaitMind } from '../interfaces';\nimport { MindNode } from '../interfaces/node';\nimport { PlaitMindComponent } from '../mind.component';\nimport { MindNodeComponent } from '../node.component';\nimport {\n    changeRightNodeCount,\n    insertMindElement,\n    deleteSelectedELements,\n    filterChildElement,\n    findParentElement,\n    shouldChangeRightNodeCount,\n    insertElementHandleAbstract\n} from '../utils';\nimport { getRectangleByNode, hitMindElement } from '../utils/graph';\nimport { isVirtualKey } from '../utils/is-virtual-key';\nimport { withDnd } from './with-dnd';\nimport { buildClipboardData, getDataFromClipboard, insertClipboardData, insertClipboardText, setClipboardData } from '../utils/clipboard';\nimport { AbstractNode } from '@plait/layouts';\nimport { findNewChildNodePath, findNewSiblingNodePath } from '../utils/path';\nimport { enterNodeEditing } from '../utils/node';\nimport { withAbstract } from './with-abstract';\nimport { withExtendMind } from './with-extend-mind';\nimport { TOPIC_DEFAULT_MAX_WORD_COUNT } from '../constants/node-topic-style';\nimport { MindTransforms } from '../transforms';\n\nexport const withMind = (board: PlaitBoard) => {\n    const {\n        drawElement,\n        dblclick,\n        keydown,\n        insertFragment,\n        setFragment,\n        deleteFragment,\n        isHitSelection,\n        getRectangle,\n        isMovable,\n        isRecursion\n    } = board;\n\n    board.drawElement = (context: PlaitPluginElementContext) => {\n        if (PlaitMind.isMind(context.element)) {\n            return PlaitMindComponent;\n        } else if (MindElement.isMindElement(board, context.element)) {\n            return MindNodeComponent;\n        }\n        return drawElement(context);\n    };\n\n    board.getRectangle = element => {\n        if (MindElement.isMindElement(board, element)) {\n            return getRectangleByNode(MindElement.getNode(element));\n        }\n        return getRectangle(element);\n    };\n\n    board.isRecursion = element => {\n        if (MindElement.isMindElement(board, element) && element.isCollapsed) {\n            return false;\n        }\n        return isRecursion(element);\n    };\n\n    board.isHitSelection = (element, range: Range) => {\n        if (MindElement.isMindElement(board, element) && board.selection) {\n            const client = getRectangleByNode(MindElement.getNode(element));\n            return RectangleClient.isHit(RectangleClient.toRectangleClient([range.anchor, range.focus]), client);\n        }\n        return isHitSelection(element, range);\n    };\n\n    board.isMovable = element => {\n        if (PlaitMind.isMind(element) && element.isRoot) {\n            return true;\n        }\n        return isMovable(element);\n    };\n\n    board.keydown = (event: KeyboardEvent) => {\n        if (board.options.readonly || IS_TEXT_EDITABLE.get(board)) {\n            keydown(event);\n            return;\n        }\n        const selectedElements = getSelectedElements(board) as MindElement[];\n        if (selectedElements.length) {\n            if (\n                selectedElements.length === 1 &&\n                (event.key === 'Tab' ||\n                    (event.key === 'Enter' && !selectedElements[0].isRoot && !AbstractNode.isAbstract(selectedElements[0])))\n            ) {\n                event.preventDefault();\n                const selectedElement = selectedElements[0];\n                removeSelectedElement(board, selectedElement);\n                const selectedElementPath = PlaitBoard.findPath(board, selectedElement);\n                if (event.key === 'Tab') {\n                    if (selectedElement.isCollapsed) {\n                        const newElement: Partial<MindElement> = { isCollapsed: false };\n                        PlaitHistoryBoard.withoutSaving(board, () => {\n                            Transforms.setNode(board, newElement, selectedElementPath);\n                        });\n                    }\n                    insertMindElement(board, selectedElement, findNewChildNodePath(board, selectedElement));\n                } else {\n                    if (shouldChangeRightNodeCount(selectedElement)) {\n                        changeRightNodeCount(board, selectedElementPath.slice(0, 1), 1);\n                    }\n\n                    const abstractRefs = insertElementHandleAbstract(board, Path.next(selectedElementPath));\n                    MindTransforms.setAbstractsByRefs(board, abstractRefs);\n\n                    insertMindElement(board, selectedElement, findNewSiblingNodePath(board, selectedElement));\n                }\n                return;\n            }\n            if (hotkeys.isDeleteBackward(event) || hotkeys.isDeleteForward(event)) {\n                event.preventDefault();\n                deleteSelectedELements(board, selectedElements);\n                let lastNode: MindNode | any = null;\n                const firstLevelElements = filterChildElement(selectedElements);\n                const firstElement = firstLevelElements[0];\n                const firstComponent = PlaitElement.getComponent(firstElement) as MindNodeComponent;\n                const nodeIndex = firstComponent?.parent?.children.findIndex(item => item.origin.id === firstElement.id);\n                const isSameParent = firstLevelElements.every(element => {\n                    return findParentElement(element) && findParentElement(firstLevelElements[0]) === findParentElement(element);\n                });\n                if (isSameParent) {\n                    const childCount = firstComponent!.parent?.children.length - firstLevelElements.length;\n                    if (childCount === 0) {\n                        lastNode = firstComponent?.parent;\n                    } else if (nodeIndex === 0) {\n                        lastNode = firstComponent?.parent.children[firstLevelElements.length];\n                    } else if (nodeIndex! > 0) {\n                        lastNode = firstComponent?.parent.children[nodeIndex! - 1];\n                    }\n                }\n\n                if (firstLevelElements.length === 1 && AbstractNode.isAbstract(firstElement)) {\n                    lastNode = firstComponent.parent.children[firstElement.start];\n                }\n\n                if (lastNode) {\n                    addSelectedElement(board, lastNode.origin);\n                }\n                return;\n            }\n            // auto enter edit status\n            if (!isVirtualKey(event)) {\n                event.preventDefault();\n                const selectedElement = selectedElements[0];\n                enterNodeEditing(selectedElement);\n                return;\n            }\n        }\n\n        if (board.selection && event.code === 'Space') {\n            if (selectedElements?.length) {\n                return;\n            }\n        }\n\n        keydown(event);\n    };\n\n    board.dblclick = (event: MouseEvent) => {\n        if (board.options.readonly || IS_TEXT_EDITABLE.get(board)) {\n            dblclick(event);\n            return;\n        }\n        const point = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));\n        board.children\n            .filter(value => PlaitMind.isMind(value))\n            .forEach(mindmap => {\n                depthFirstRecursion<MindElement>(mindmap as MindElement, node => {\n                    if (!PlaitBoard.hasBeenTextEditing(board) && hitMindElement(board, point, node)) {\n                        enterNodeEditing(node);\n                    }\n                });\n            });\n        if (PlaitBoard.hasBeenTextEditing(board)) {\n            return;\n        }\n        dblclick(event);\n    };\n\n    board.setFragment = (data: DataTransfer | null) => {\n        const selectedElements = filterChildElement(getSelectedElements(board) as MindElement[]);\n        if (selectedElements.length) {\n            const elements = buildClipboardData(board, selectedElements);\n            setClipboardData(data, elements);\n            return;\n        }\n        setFragment(data);\n    };\n\n    board.insertFragment = (data: DataTransfer | null, targetPoint?: Point) => {\n        if (board.options.readonly) {\n            insertFragment(data, targetPoint);\n            return;\n        }\n\n        const elements = getDataFromClipboard(data);\n        if (elements.length) {\n            insertClipboardData(board, elements, targetPoint || [0, 0]);\n        } else {\n            const text = data?.getData(`text/plain`) as string;\n            const { width, height } = getSizeByText(\n                text,\n                PlaitBoard.getHost(board).parentElement as HTMLElement,\n                TOPIC_DEFAULT_MAX_WORD_COUNT\n            );\n            const selectedElements = getSelectedElements(board);\n            if (text && selectedElements.length === 1) {\n                insertClipboardText(board, selectedElements[0], text, width, height);\n            }\n        }\n        insertFragment(data, targetPoint);\n    };\n\n    board.deleteFragment = (data: DataTransfer | null) => {\n        const selectedElements = getSelectedElements(board) as MindElement[];\n        deleteSelectedELements(board, selectedElements);\n        deleteFragment(data);\n    };\n\n    return withExtendMind(withAbstract(withDnd(board)));\n};\n"]}
|
|
194
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-mind.js","sourceRoot":"","sources":["../../../../packages/mind/src/plugins/with-mind.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    addSelectedElement,\n    getSelectedElements,\n    hotkeys,\n    IS_TEXT_EDITABLE,\n    PlaitBoard,\n    PlaitHistoryBoard,\n    PlaitPluginElementContext,\n    Point,\n    RectangleClient,\n    removeSelectedElement,\n    toPoint,\n    transformPoint,\n    Transforms,\n    Range,\n    depthFirstRecursion,\n    PlaitElement,\n    Path,\n    Selection\n} from '@plait/core';\nimport { getSizeByText } from '@plait/richtext';\nimport { MindElement, PlaitMind } from '../interfaces';\nimport { MindNode } from '../interfaces/node';\nimport { PlaitMindComponent } from '../mind.component';\nimport { MindNodeComponent } from '../node.component';\nimport {\n    changeRightNodeCount,\n    insertMindElement,\n    deleteSelectedELements,\n    getFirstLevelElement,\n    shouldChangeRightNodeCount,\n    insertElementHandleAbstract\n} from '../utils';\nimport { getRectangleByNode, hitMindElement } from '../utils/graph';\nimport { isVirtualKey } from '../utils/is-virtual-key';\nimport { withDnd } from './with-dnd';\nimport { buildClipboardData, getDataFromClipboard, insertClipboardData, insertClipboardText, setClipboardData } from '../utils/clipboard';\nimport { AbstractNode } from '@plait/layouts';\nimport { findNewChildNodePath, findNewSiblingNodePath } from '../utils/path';\nimport { enterNodeEditing } from '../utils/node';\nimport { withAbstract } from './with-abstract';\nimport { withExtendMind } from './with-extend-mind';\nimport { TOPIC_DEFAULT_MAX_WORD_COUNT } from '../constants/node-topic-style';\nimport { MindTransforms } from '../transforms';\nimport { isHitEmojis } from './emoji/emoji';\n\nexport const withMind = (board: PlaitBoard) => {\n    const {\n        drawElement,\n        dblclick,\n        keydown,\n        insertFragment,\n        setFragment,\n        deleteFragment,\n        isHitSelection,\n        getRectangle,\n        isMovable,\n        isRecursion\n    } = board;\n\n    board.drawElement = (context: PlaitPluginElementContext) => {\n        if (PlaitMind.isMind(context.element)) {\n            return PlaitMindComponent;\n        } else if (MindElement.isMindElement(board, context.element)) {\n            return MindNodeComponent;\n        }\n        return drawElement(context);\n    };\n\n    board.getRectangle = element => {\n        if (MindElement.isMindElement(board, element)) {\n            return getRectangleByNode(MindElement.getNode(element));\n        }\n        return getRectangle(element);\n    };\n\n    board.isRecursion = element => {\n        if (MindElement.isMindElement(board, element) && element.isCollapsed) {\n            return false;\n        }\n        return isRecursion(element);\n    };\n\n    board.isHitSelection = (element, range: Range) => {\n        if (MindElement.isMindElement(board, element) && board.selection) {\n            const client = getRectangleByNode(MindElement.getNode(element));\n            const isHit = RectangleClient.isHit(RectangleClient.toRectangleClient([range.anchor, range.focus]), client);\n            if (isHit && MindElement.hasEmojis(element) && Selection.isCollapsed(range) && isHitEmojis(board, element, range.anchor)) {\n                return false;\n            }\n            return isHit;\n        }\n        return isHitSelection(element, range);\n    };\n\n    board.isMovable = element => {\n        if (PlaitMind.isMind(element) && element.isRoot) {\n            return true;\n        }\n        return isMovable(element);\n    };\n\n    board.keydown = (event: KeyboardEvent) => {\n        if (board.options.readonly || IS_TEXT_EDITABLE.get(board)) {\n            keydown(event);\n            return;\n        }\n        const selectedElements = getSelectedElements(board) as MindElement[];\n        if (selectedElements.length) {\n            if (\n                selectedElements.length === 1 &&\n                (event.key === 'Tab' ||\n                    (event.key === 'Enter' && !selectedElements[0].isRoot && !AbstractNode.isAbstract(selectedElements[0])))\n            ) {\n                event.preventDefault();\n                const selectedElement = selectedElements[0];\n                removeSelectedElement(board, selectedElement);\n                const selectedElementPath = PlaitBoard.findPath(board, selectedElement);\n                if (event.key === 'Tab') {\n                    if (selectedElement.isCollapsed) {\n                        const newElement: Partial<MindElement> = { isCollapsed: false };\n                        PlaitHistoryBoard.withoutSaving(board, () => {\n                            Transforms.setNode(board, newElement, selectedElementPath);\n                        });\n                    }\n                    insertMindElement(board, selectedElement, findNewChildNodePath(board, selectedElement));\n                } else {\n                    if (shouldChangeRightNodeCount(selectedElement)) {\n                        changeRightNodeCount(board, selectedElementPath.slice(0, 1), 1);\n                    }\n\n                    const abstractRefs = insertElementHandleAbstract(board, Path.next(selectedElementPath));\n                    MindTransforms.setAbstractsByRefs(board, abstractRefs);\n\n                    insertMindElement(board, selectedElement, findNewSiblingNodePath(board, selectedElement));\n                }\n                return;\n            }\n            if (hotkeys.isDeleteBackward(event) || hotkeys.isDeleteForward(event)) {\n                event.preventDefault();\n                deleteSelectedELements(board, selectedElements);\n\n                let activeElement: MindElement | undefined;\n                const firstLevelElements = getFirstLevelElement(selectedElements);\n\n                if (AbstractNode.isAbstract(firstLevelElements[0])) {\n                    const parent = MindElement.getParent(firstLevelElements[0]);\n                    activeElement = parent.children[firstLevelElements[0].start];\n                }\n\n                const firstElement = firstLevelElements[0];\n                const firstElementParent = MindElement.findParent(firstElement);\n                const hasSameParent = firstLevelElements.every(element => {\n                    return MindElement.findParent(element) === firstElementParent;\n                });\n                if (firstElementParent && hasSameParent && !activeElement) {\n                    const firstElementIndex = firstElementParent.children.indexOf(firstElement);\n                    const childrenCount = firstElementParent.children.length;\n                    // active parent element\n                    if (childrenCount === firstLevelElements.length) {\n                        activeElement = firstElementParent;\n                    } else {\n                        if (firstElementIndex > 0) {\n                            activeElement = firstElementParent.children[firstElementIndex - 1];\n                        }\n                    }\n                }\n                if (activeElement) {\n                    addSelectedElement(board, activeElement);\n                }\n                return;\n            }\n            // auto enter edit status\n            if (!isVirtualKey(event)) {\n                event.preventDefault();\n                const selectedElement = selectedElements[0];\n                enterNodeEditing(selectedElement);\n                return;\n            }\n        }\n\n        if (board.selection && event.code === 'Space') {\n            if (selectedElements?.length) {\n                return;\n            }\n        }\n\n        keydown(event);\n    };\n\n    board.dblclick = (event: MouseEvent) => {\n        if (board.options.readonly || IS_TEXT_EDITABLE.get(board)) {\n            dblclick(event);\n            return;\n        }\n        const point = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));\n        board.children\n            .filter(value => PlaitMind.isMind(value))\n            .forEach(mindMap => {\n                depthFirstRecursion<MindElement>(mindMap as MindElement, node => {\n                    if (!PlaitBoard.hasBeenTextEditing(board) && hitMindElement(board, point, node)) {\n                        enterNodeEditing(node);\n                    }\n                });\n            });\n        if (PlaitBoard.hasBeenTextEditing(board)) {\n            return;\n        }\n        dblclick(event);\n    };\n\n    board.setFragment = (data: DataTransfer | null) => {\n        const selectedElements = getFirstLevelElement(getSelectedElements(board) as MindElement[]);\n        if (selectedElements.length) {\n            const elements = buildClipboardData(board, selectedElements);\n            setClipboardData(data, elements);\n            return;\n        }\n        setFragment(data);\n    };\n\n    board.insertFragment = (data: DataTransfer | null, targetPoint?: Point) => {\n        if (board.options.readonly) {\n            insertFragment(data, targetPoint);\n            return;\n        }\n\n        const elements = getDataFromClipboard(data);\n        if (elements.length) {\n            insertClipboardData(board, elements, targetPoint || [0, 0]);\n        } else {\n            const text = data?.getData(`text/plain`) as string;\n            const { width, height } = getSizeByText(\n                text,\n                PlaitBoard.getHost(board).parentElement as HTMLElement,\n                TOPIC_DEFAULT_MAX_WORD_COUNT\n            );\n            const selectedElements = getSelectedElements(board);\n            if (text && selectedElements.length === 1) {\n                insertClipboardText(board, selectedElements[0], text, width, height);\n            }\n        }\n        insertFragment(data, targetPoint);\n    };\n\n    board.deleteFragment = (data: DataTransfer | null) => {\n        const selectedElements = getSelectedElements(board) as MindElement[];\n        deleteSelectedELements(board, selectedElements);\n        deleteFragment(data);\n    };\n\n    return withExtendMind(withAbstract(withDnd(board)));\n};\n"]}
|
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
import { MindElement } from '../interfaces';
|
|
2
|
-
import {
|
|
2
|
+
import { getAvailableSubLayoutsByLayoutDirections, getBranchDirectionsByLayouts } from '../utils';
|
|
3
3
|
import { MindLayoutType } from '@plait/layouts';
|
|
4
4
|
import { getBranchLayouts } from './get-branch-layouts';
|
|
5
5
|
export const getAvailableSubLayoutsByElement = (board, element) => {
|
|
6
|
-
const parentElement =
|
|
6
|
+
const parentElement = MindElement.findParent(element);
|
|
7
7
|
if (parentElement) {
|
|
8
8
|
const branchLayouts = getBranchLayouts(board, parentElement);
|
|
9
9
|
if (branchLayouts[0] === MindLayoutType.standard) {
|
|
@@ -20,4 +20,4 @@ export const getAvailableSubLayoutsByElement = (board, element) => {
|
|
|
20
20
|
}
|
|
21
21
|
return undefined;
|
|
22
22
|
};
|
|
23
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
23
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2V0LWF2YWlsYWJsZS1zdWJsYXlvdXRzLWJ5LWVsZW1lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9taW5kL3NyYy9xdWVyaWVzL2dldC1hdmFpbGFibGUtc3VibGF5b3V0cy1ieS1lbGVtZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDNUMsT0FBTyxFQUFFLHdDQUF3QyxFQUFFLDRCQUE0QixFQUFFLE1BQU0sVUFBVSxDQUFDO0FBQ2xHLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUNoRCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUd4RCxNQUFNLENBQUMsTUFBTSwrQkFBK0IsR0FBRyxDQUFDLEtBQWlCLEVBQUUsT0FBb0IsRUFBRSxFQUFFO0lBQ3ZGLE1BQU0sYUFBYSxHQUFHLFdBQVcsQ0FBQyxVQUFVLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDdEQsSUFBSSxhQUFhLEVBQUU7UUFDZixNQUFNLGFBQWEsR0FBRyxnQkFBZ0IsQ0FBQyxLQUFLLEVBQUUsYUFBYSxDQUFDLENBQUM7UUFDN0QsSUFBSSxhQUFhLENBQUMsQ0FBQyxDQUFDLEtBQUssY0FBYyxDQUFDLFFBQVEsRUFBRTtZQUM5QyxNQUFNLElBQUksR0FBRyxXQUFXLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxDQUFDO1lBQzFDLGFBQWEsQ0FBQyxDQUFDLENBQUMsR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxjQUFjLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxjQUFjLENBQUMsS0FBSyxDQUFDO1NBQzdFO1FBQ0QsTUFBTSx1QkFBdUIsR0FBRyw0QkFBNEIsQ0FBQyxhQUFhLENBQUMsQ0FBQztRQUM1RSxJQUFJLG1CQUFtQixHQUFHLHdDQUF3QyxDQUFDLHVCQUF1QixDQUFDLENBQUM7UUFDNUYsTUFBTSxZQUFZLEdBQUcsQ0FBQyxhQUFhLENBQUMsYUFBYSxDQUFDLE1BQU0sR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQy9ELE1BQU0sZ0JBQWdCLEdBQUcsNEJBQTRCLENBQUMsWUFBWSxDQUFDLENBQUM7UUFDcEUsTUFBTSx5QkFBeUIsR0FBRyx3Q0FBd0MsQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO1FBRTdGLG1CQUFtQixHQUFHLG1CQUFtQixDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsRUFBRSxDQUN0RCx5QkFBeUIsQ0FBQyxJQUFJLENBQUMsd0JBQXdCLENBQUMsRUFBRSxDQUFDLHdCQUF3QixLQUFLLE1BQU0sQ0FBQyxDQUNsRyxDQUFDO1FBQ0YsT0FBTyxtQkFBbUIsQ0FBQztLQUM5QjtJQUNELE9BQU8sU0FBUyxDQUFDO0FBQ3JCLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE1pbmRFbGVtZW50IH0gZnJvbSAnLi4vaW50ZXJmYWNlcyc7XG5pbXBvcnQgeyBnZXRBdmFpbGFibGVTdWJMYXlvdXRzQnlMYXlvdXREaXJlY3Rpb25zLCBnZXRCcmFuY2hEaXJlY3Rpb25zQnlMYXlvdXRzIH0gZnJvbSAnLi4vdXRpbHMnO1xuaW1wb3J0IHsgTWluZExheW91dFR5cGUgfSBmcm9tICdAcGxhaXQvbGF5b3V0cyc7XG5pbXBvcnQgeyBnZXRCcmFuY2hMYXlvdXRzIH0gZnJvbSAnLi9nZXQtYnJhbmNoLWxheW91dHMnO1xuaW1wb3J0IHsgUGxhaXRCb2FyZCB9IGZyb20gJ0BwbGFpdC9jb3JlJztcblxuZXhwb3J0IGNvbnN0IGdldEF2YWlsYWJsZVN1YkxheW91dHNCeUVsZW1lbnQgPSAoYm9hcmQ6IFBsYWl0Qm9hcmQsIGVsZW1lbnQ6IE1pbmRFbGVtZW50KSA9PiB7XG4gICAgY29uc3QgcGFyZW50RWxlbWVudCA9IE1pbmRFbGVtZW50LmZpbmRQYXJlbnQoZWxlbWVudCk7XG4gICAgaWYgKHBhcmVudEVsZW1lbnQpIHtcbiAgICAgICAgY29uc3QgYnJhbmNoTGF5b3V0cyA9IGdldEJyYW5jaExheW91dHMoYm9hcmQsIHBhcmVudEVsZW1lbnQpO1xuICAgICAgICBpZiAoYnJhbmNoTGF5b3V0c1swXSA9PT0gTWluZExheW91dFR5cGUuc3RhbmRhcmQpIHtcbiAgICAgICAgICAgIGNvbnN0IG5vZGUgPSBNaW5kRWxlbWVudC5nZXROb2RlKGVsZW1lbnQpO1xuICAgICAgICAgICAgYnJhbmNoTGF5b3V0c1swXSA9IG5vZGUubGVmdCA/IE1pbmRMYXlvdXRUeXBlLmxlZnQgOiBNaW5kTGF5b3V0VHlwZS5yaWdodDtcbiAgICAgICAgfVxuICAgICAgICBjb25zdCBjdXJyZW50TGF5b3V0RGlyZWN0aW9ucyA9IGdldEJyYW5jaERpcmVjdGlvbnNCeUxheW91dHMoYnJhbmNoTGF5b3V0cyk7XG4gICAgICAgIGxldCBhdmFpbGFibGVTdWJMYXlvdXRzID0gZ2V0QXZhaWxhYmxlU3ViTGF5b3V0c0J5TGF5b3V0RGlyZWN0aW9ucyhjdXJyZW50TGF5b3V0RGlyZWN0aW9ucyk7XG4gICAgICAgIGNvbnN0IHBhcmVudExheW91dCA9IFticmFuY2hMYXlvdXRzW2JyYW5jaExheW91dHMubGVuZ3RoIC0gMV1dO1xuICAgICAgICBjb25zdCBwYXJlbnREaXJlY3Rpb25zID0gZ2V0QnJhbmNoRGlyZWN0aW9uc0J5TGF5b3V0cyhwYXJlbnRMYXlvdXQpO1xuICAgICAgICBjb25zdCBwYXJlbnRBdmFpbGFibGVTdWJMYXlvdXRzID0gZ2V0QXZhaWxhYmxlU3ViTGF5b3V0c0J5TGF5b3V0RGlyZWN0aW9ucyhwYXJlbnREaXJlY3Rpb25zKTtcblxuICAgICAgICBhdmFpbGFibGVTdWJMYXlvdXRzID0gYXZhaWxhYmxlU3ViTGF5b3V0cy5maWx0ZXIobGF5b3V0ID0+XG4gICAgICAgICAgICBwYXJlbnRBdmFpbGFibGVTdWJMYXlvdXRzLnNvbWUocGFyZW50QXZhaWxhYmxlU3ViTGF5b3V0ID0+IHBhcmVudEF2YWlsYWJsZVN1YkxheW91dCA9PT0gbGF5b3V0KVxuICAgICAgICApO1xuICAgICAgICByZXR1cm4gYXZhaWxhYmxlU3ViTGF5b3V0cztcbiAgICB9XG4gICAgcmV0dXJuIHVuZGVmaW5lZDtcbn07XG4iXX0=
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { MindElement } from '../interfaces';
|
|
2
2
|
import { getCorrectLayoutByElement } from './get-correct-layout-by-element';
|
|
3
3
|
export const getBranchLayouts = (board, element) => {
|
|
4
4
|
const layouts = [];
|
|
@@ -6,13 +6,13 @@ export const getBranchLayouts = (board, element) => {
|
|
|
6
6
|
// TODO: getCorrectLayoutByElement 含有递归操作,getBranchLayouts 本身也有递归操作,有待优化
|
|
7
7
|
layouts.unshift(getCorrectLayoutByElement(board, element));
|
|
8
8
|
}
|
|
9
|
-
let parent =
|
|
9
|
+
let parent = MindElement.findParent(element);
|
|
10
10
|
while (parent) {
|
|
11
11
|
if (parent.layout) {
|
|
12
12
|
layouts.unshift(parent.layout);
|
|
13
13
|
}
|
|
14
|
-
parent =
|
|
14
|
+
parent = MindElement.findParent(parent);
|
|
15
15
|
}
|
|
16
16
|
return layouts;
|
|
17
17
|
};
|
|
18
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2V0LWJyYW5jaC1sYXlvdXRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcGFja2FnZXMvbWluZC9zcmMvcXVlcmllcy9nZXQtYnJhbmNoLWxheW91dHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUU1QyxPQUFPLEVBQUUseUJBQXlCLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUc1RSxNQUFNLENBQUMsTUFBTSxnQkFBZ0IsR0FBRyxDQUFDLEtBQWlCLEVBQUUsT0FBb0IsRUFBRSxFQUFFO0lBQ3hFLE1BQU0sT0FBTyxHQUFxQixFQUFFLENBQUM7SUFDckMsSUFBSSxPQUFPLENBQUMsTUFBTSxFQUFFO1FBQ2hCLHdFQUF3RTtRQUN4RSxPQUFPLENBQUMsT0FBTyxDQUFDLHlCQUF5QixDQUFDLEtBQUssRUFBRSxPQUFPLENBQUMsQ0FBQyxDQUFDO0tBQzlEO0lBQ0QsSUFBSSxNQUFNLEdBQUcsV0FBVyxDQUFDLFVBQVUsQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUM3QyxPQUFPLE1BQU0sRUFBRTtRQUNYLElBQUksTUFBTSxDQUFDLE1BQU0sRUFBRTtZQUNmLE9BQU8sQ0FBQyxPQUFPLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1NBQ2xDO1FBQ0QsTUFBTSxHQUFHLFdBQVcsQ0FBQyxVQUFVLENBQUMsTUFBTSxDQUFDLENBQUM7S0FDM0M7SUFDRCxPQUFPLE9BQU8sQ0FBQztBQUNuQixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBNaW5kRWxlbWVudCB9IGZyb20gJy4uL2ludGVyZmFjZXMnO1xuaW1wb3J0IHsgTWluZExheW91dFR5cGUgfSBmcm9tICdAcGxhaXQvbGF5b3V0cyc7XG5pbXBvcnQgeyBnZXRDb3JyZWN0TGF5b3V0QnlFbGVtZW50IH0gZnJvbSAnLi9nZXQtY29ycmVjdC1sYXlvdXQtYnktZWxlbWVudCc7XG5pbXBvcnQgeyBQbGFpdEJvYXJkIH0gZnJvbSAnQHBsYWl0L2NvcmUnO1xuXG5leHBvcnQgY29uc3QgZ2V0QnJhbmNoTGF5b3V0cyA9IChib2FyZDogUGxhaXRCb2FyZCwgZWxlbWVudDogTWluZEVsZW1lbnQpID0+IHtcbiAgICBjb25zdCBsYXlvdXRzOiBNaW5kTGF5b3V0VHlwZVtdID0gW107XG4gICAgaWYgKGVsZW1lbnQubGF5b3V0KSB7XG4gICAgICAgIC8vIFRPRE86IGdldENvcnJlY3RMYXlvdXRCeUVsZW1lbnQg5ZCr5pyJ6YCS5b2S5pON5L2c77yMZ2V0QnJhbmNoTGF5b3V0cyDmnKzouqvkuZ/mnInpgJLlvZLmk43kvZzvvIzmnInlvoXkvJjljJZcbiAgICAgICAgbGF5b3V0cy51bnNoaWZ0KGdldENvcnJlY3RMYXlvdXRCeUVsZW1lbnQoYm9hcmQsIGVsZW1lbnQpKTtcbiAgICB9XG4gICAgbGV0IHBhcmVudCA9IE1pbmRFbGVtZW50LmZpbmRQYXJlbnQoZWxlbWVudCk7XG4gICAgd2hpbGUgKHBhcmVudCkge1xuICAgICAgICBpZiAocGFyZW50LmxheW91dCkge1xuICAgICAgICAgICAgbGF5b3V0cy51bnNoaWZ0KHBhcmVudC5sYXlvdXQpO1xuICAgICAgICB9XG4gICAgICAgIHBhcmVudCA9IE1pbmRFbGVtZW50LmZpbmRQYXJlbnQocGFyZW50KTtcbiAgICB9XG4gICAgcmV0dXJuIGxheW91dHM7XG59O1xuIl19
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { MindElement } from '../interfaces';
|
|
1
|
+
import { MindElement, PlaitMind } from '../interfaces';
|
|
2
2
|
import { AbstractNode, getAbstractLayout } from '@plait/layouts';
|
|
3
3
|
import { getDefaultLayout } from '../utils/layout';
|
|
4
4
|
export const getLayoutByElement = (element) => {
|
|
@@ -6,8 +6,8 @@ export const getLayoutByElement = (element) => {
|
|
|
6
6
|
if (layout) {
|
|
7
7
|
return layout;
|
|
8
8
|
}
|
|
9
|
-
const parent = MindElement.getParent(element);
|
|
10
|
-
if (AbstractNode.isAbstract(element)) {
|
|
9
|
+
const parent = !PlaitMind.isMind(element) && MindElement.getParent(element);
|
|
10
|
+
if (AbstractNode.isAbstract(element) && parent) {
|
|
11
11
|
return getAbstractLayout(getLayoutByElement(parent));
|
|
12
12
|
}
|
|
13
13
|
if (parent) {
|
|
@@ -15,4 +15,4 @@ export const getLayoutByElement = (element) => {
|
|
|
15
15
|
}
|
|
16
16
|
return getDefaultLayout();
|
|
17
17
|
};
|
|
18
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2V0LWxheW91dC1ieS1lbGVtZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcGFja2FnZXMvbWluZC9zcmMvcXVlcmllcy9nZXQtbGF5b3V0LWJ5LWVsZW1lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFdBQVcsRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDdkQsT0FBTyxFQUFFLFlBQVksRUFBa0IsaUJBQWlCLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUNqRixPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUVuRCxNQUFNLENBQUMsTUFBTSxrQkFBa0IsR0FBRyxDQUFDLE9BQW9CLEVBQWtCLEVBQUU7SUFDdkUsTUFBTSxNQUFNLEdBQUcsT0FBTyxDQUFDLE1BQU0sQ0FBQztJQUM5QixJQUFJLE1BQU0sRUFBRTtRQUNSLE9BQU8sTUFBTSxDQUFDO0tBQ2pCO0lBRUQsTUFBTSxNQUFNLEdBQUcsQ0FBQyxTQUFTLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxJQUFJLFdBQVcsQ0FBQyxTQUFTLENBQUMsT0FBTyxDQUFDLENBQUM7SUFFNUUsSUFBSSxZQUFZLENBQUMsVUFBVSxDQUFDLE9BQU8sQ0FBQyxJQUFJLE1BQU0sRUFBRTtRQUM1QyxPQUFPLGlCQUFpQixDQUFDLGtCQUFrQixDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUM7S0FDeEQ7SUFFRCxJQUFJLE1BQU0sRUFBRTtRQUNSLE9BQU8sa0JBQWtCLENBQUMsTUFBTSxDQUFDLENBQUM7S0FDckM7SUFFRCxPQUFPLGdCQUFnQixFQUFFLENBQUM7QUFDOUIsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTWluZEVsZW1lbnQsIFBsYWl0TWluZCB9IGZyb20gJy4uL2ludGVyZmFjZXMnO1xuaW1wb3J0IHsgQWJzdHJhY3ROb2RlLCBNaW5kTGF5b3V0VHlwZSwgZ2V0QWJzdHJhY3RMYXlvdXQgfSBmcm9tICdAcGxhaXQvbGF5b3V0cyc7XG5pbXBvcnQgeyBnZXREZWZhdWx0TGF5b3V0IH0gZnJvbSAnLi4vdXRpbHMvbGF5b3V0JztcblxuZXhwb3J0IGNvbnN0IGdldExheW91dEJ5RWxlbWVudCA9IChlbGVtZW50OiBNaW5kRWxlbWVudCk6IE1pbmRMYXlvdXRUeXBlID0+IHtcbiAgICBjb25zdCBsYXlvdXQgPSBlbGVtZW50LmxheW91dDtcbiAgICBpZiAobGF5b3V0KSB7XG4gICAgICAgIHJldHVybiBsYXlvdXQ7XG4gICAgfVxuXG4gICAgY29uc3QgcGFyZW50ID0gIVBsYWl0TWluZC5pc01pbmQoZWxlbWVudCkgJiYgTWluZEVsZW1lbnQuZ2V0UGFyZW50KGVsZW1lbnQpO1xuXG4gICAgaWYgKEFic3RyYWN0Tm9kZS5pc0Fic3RyYWN0KGVsZW1lbnQpICYmIHBhcmVudCkge1xuICAgICAgICByZXR1cm4gZ2V0QWJzdHJhY3RMYXlvdXQoZ2V0TGF5b3V0QnlFbGVtZW50KHBhcmVudCkpO1xuICAgIH1cblxuICAgIGlmIChwYXJlbnQpIHtcbiAgICAgICAgcmV0dXJuIGdldExheW91dEJ5RWxlbWVudChwYXJlbnQpO1xuICAgIH1cblxuICAgIHJldHVybiBnZXREZWZhdWx0TGF5b3V0KCk7XG59O1xuIl19
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { Path, PlaitBoard, Transforms } from '@plait/core';
|
|
2
2
|
import { AbstractNode, isStandardLayout } from '@plait/layouts';
|
|
3
|
-
import { createMindElement, divideElementByParent,
|
|
3
|
+
import { createMindElement, divideElementByParent, getFirstLevelElement } from '../utils/mind';
|
|
4
4
|
import { MindQueries } from '../queries';
|
|
5
5
|
import { DefaultAbstractNodeStyle } from '../constants/node-style';
|
|
6
6
|
export const setAbstractsByRefs = (board, abstractRefs) => {
|
|
@@ -27,7 +27,7 @@ export const setAbstractByStandardLayout = (board, element) => {
|
|
|
27
27
|
}
|
|
28
28
|
};
|
|
29
29
|
export const insertAbstract = (board, elements) => {
|
|
30
|
-
let elementGroup =
|
|
30
|
+
let elementGroup = getFirstLevelElement(elements);
|
|
31
31
|
const { parentElements, abstractIncludedGroups } = divideElementByParent(elementGroup);
|
|
32
32
|
abstractIncludedGroups.forEach((group, index) => {
|
|
33
33
|
const groupParent = parentElements[index];
|
|
@@ -65,4 +65,4 @@ const insertAbstractNode = (board, path, start, end) => {
|
|
|
65
65
|
mindElement.end = end;
|
|
66
66
|
Transforms.insertNode(board, mindElement, path);
|
|
67
67
|
};
|
|
68
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
68
|
+
//# 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 '../interfaces/abstract';\nimport { MindElement } from '../interfaces/element';\nimport { AbstractNode, isStandardLayout } from '@plait/layouts';\nimport { createMindElement, divideElementByParent, getFirstLevelElement } from '../utils/mind';\nimport { MindQueries } from '../queries';\nimport { DefaultAbstractNodeStyle } from '../constants/node-style';\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"]}
|