@plait/mind 0.47.0 → 0.48.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/interfaces/node.mjs +1 -1
- package/esm2022/plugins/with-node-dnd.mjs +2 -2
- package/esm2022/queries/get-branch-layouts.mjs +2 -2
- package/esm2022/utils/abstract/common.mjs +2 -2
- package/esm2022/utils/dnd/detector.mjs +4 -9
- package/esm2022/utils/draw/node-link/indented-link.mjs +1 -2
- package/esm2022/utils/draw/node-link/logic-link.mjs +4 -5
- package/esm2022/utils/point-placement.mjs +11 -11
- package/fesm2022/plait-mind.mjs +19 -26
- package/fesm2022/plait-mind.mjs.map +1 -1
- package/package.json +1 -1
|
@@ -46,16 +46,16 @@ export const getLayoutDirection = (node, isHorizontal) => {
|
|
|
46
46
|
}
|
|
47
47
|
}
|
|
48
48
|
};
|
|
49
|
-
//
|
|
50
|
-
//
|
|
51
|
-
// 1.
|
|
52
|
-
// 2.
|
|
53
|
-
//
|
|
54
|
-
// 1.
|
|
55
|
-
// 2.
|
|
56
|
-
//
|
|
57
|
-
// 1.
|
|
58
|
-
// 2.
|
|
49
|
+
// Based on right
|
|
50
|
+
// Right -> Left:
|
|
51
|
+
// 1. End point -> starting point/start point -> end point
|
|
52
|
+
// 2. Add -> Subtract
|
|
53
|
+
// Horizontal -> Vertical:
|
|
54
|
+
// 1. Starting point/end point -> vertical axis
|
|
55
|
+
// 2. Addition and subtraction -> vertical axis
|
|
56
|
+
// Bottom -> Top:
|
|
57
|
+
// 1. End point -> starting point/end point -> starting point
|
|
58
|
+
// 2. Add -> Subtract
|
|
59
59
|
export const moveXOfPoint = (point, distance, direction = LayoutDirection.right) => {
|
|
60
60
|
if (direction === LayoutDirection.left) {
|
|
61
61
|
return [point[0] - distance, point[1]];
|
|
@@ -116,4 +116,4 @@ export const transformPlacement = (placement, direction) => {
|
|
|
116
116
|
}
|
|
117
117
|
}
|
|
118
118
|
};
|
|
119
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"point-placement.js","sourceRoot":"","sources":["../../../../packages/mind/src/utils/point-placement.ts"],"names":[],"mappings":"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","sourcesContent":["import { Point, RectangleClient } from '@plait/core';\nimport { MindNode } from '../interfaces/node';\nimport { LayoutDirection } from '../interfaces/layout';\nimport { HorizontalPlacement, PointPlacement, VerticalPlacement } from '../interfaces/types';\n\nexport const getPointByPlacement = (client: RectangleClient, placement: PointPlacement): Point => {\n    let x = client.x;\n    let y = client.y;\n    if (placement[0] === HorizontalPlacement.center) {\n        x = client.x + client.width / 2;\n    }\n    if (placement[0] === HorizontalPlacement.right) {\n        x = client.x + client.width;\n    }\n    if (placement[1] === VerticalPlacement.middle) {\n        y = client.y + client.height / 2;\n    }\n    if (placement[1] === VerticalPlacement.bottom) {\n        y = client.y + client.height;\n    }\n    return [x, y];\n};\n\nexport interface PlacementRef {\n    placement: PointPlacement;\n    client: RectangleClient;\n}\n\nexport const getXDistanceBetweenPoint = (point1: Point, point2: Point, isHorizontalLayout: boolean) => {\n    if (isHorizontalLayout) {\n        return Math.abs(point1[0] - point2[0]);\n    } else {\n        return Math.abs(point1[1] - point2[1]);\n    }\n};\n\nexport const getYDistanceBetweenPoint = (point1: Point, point2: Point, isHorizontalLayout: boolean) => {\n    getXDistanceBetweenPoint(point1, point2, !isHorizontalLayout);\n};\n\nexport const getLayoutDirection = (node: MindNode, isHorizontal: boolean) => {\n    if (isHorizontal) {\n        if (node.left) {\n            return LayoutDirection.left;\n        } else {\n            return LayoutDirection.right;\n        }\n    } else {\n        if (node.up) {\n            return LayoutDirection.top;\n        } else {\n            return LayoutDirection.bottom;\n        }\n    }\n};\n\n// 以右为基准\n// 右 -> 左:\n// 1. 终点 -> 起点/起点 -> 终点\n// 2. 加 -> 减\n\n// 水平 -> 垂直:\n// 1. 起点/终点 -> 纵轴\n// 2. 加减 -> 纵轴\n\n// 下 -> 上:\n// 1. 终点 -> 起点/终点 -> 起点\n// 2. 加 -> 减\nexport const moveXOfPoint = (point: Point, distance: number, direction: LayoutDirection = LayoutDirection.right): Point => {\n    if (direction === LayoutDirection.left) {\n        return [point[0] - distance, point[1]];\n    }\n    if (direction === LayoutDirection.bottom) {\n        return [point[0], point[1] + distance];\n    }\n    if (direction === LayoutDirection.top) {\n        return [point[0], point[1] - distance];\n    }\n    return [point[0] + distance, point[1]];\n};\n\nexport const moveYOfPoint = (point: Point, distance: number, direction: LayoutDirection = LayoutDirection.right): Point => {\n    if (direction === LayoutDirection.bottom) {\n        return [point[0] + distance, point[1]];\n    }\n    if (direction === LayoutDirection.top) {\n        return [point[0] + distance, point[1]];\n    }\n    return [point[0], point[1] + distance];\n};\n\nexport const transformPlacement = (placement: PointPlacement, direction: LayoutDirection) => {\n    // to left\n    if (direction === LayoutDirection.left) {\n        if (placement[0] === HorizontalPlacement.right) {\n            placement[0] = HorizontalPlacement.left;\n        } else if (placement[0] === HorizontalPlacement.left) {\n            placement[0] = HorizontalPlacement.right;\n        }\n    }\n    // to bottom\n    if (direction === LayoutDirection.bottom || direction === LayoutDirection.top) {\n        let horizontal = HorizontalPlacement.center;\n        let vertical = VerticalPlacement.middle;\n        if (placement[1] === VerticalPlacement.top) {\n            horizontal = HorizontalPlacement.left;\n        }\n        if (placement[1] === VerticalPlacement.bottom) {\n            horizontal = HorizontalPlacement.right;\n        }\n        if (placement[0] === HorizontalPlacement.left) {\n            vertical = VerticalPlacement.top;\n        }\n        if (placement[0] === HorizontalPlacement.right) {\n            vertical = VerticalPlacement.bottom;\n        }\n        placement[0] = horizontal;\n        placement[1] = vertical;\n    }\n    // to up\n    if (direction === LayoutDirection.top) {\n        if (placement[1] === VerticalPlacement.bottom) {\n            placement[1] = VerticalPlacement.top;\n        } else if (placement[1] === VerticalPlacement.top) {\n            placement[1] = VerticalPlacement.bottom;\n        }\n    }\n};\n"]}
|
|
119
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"point-placement.js","sourceRoot":"","sources":["../../../../packages/mind/src/utils/point-placement.ts"],"names":[],"mappings":"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","sourcesContent":["import { Point, RectangleClient } from '@plait/core';\nimport { MindNode } from '../interfaces/node';\nimport { LayoutDirection } from '../interfaces/layout';\nimport { HorizontalPlacement, PointPlacement, VerticalPlacement } from '../interfaces/types';\n\nexport const getPointByPlacement = (client: RectangleClient, placement: PointPlacement): Point => {\n    let x = client.x;\n    let y = client.y;\n    if (placement[0] === HorizontalPlacement.center) {\n        x = client.x + client.width / 2;\n    }\n    if (placement[0] === HorizontalPlacement.right) {\n        x = client.x + client.width;\n    }\n    if (placement[1] === VerticalPlacement.middle) {\n        y = client.y + client.height / 2;\n    }\n    if (placement[1] === VerticalPlacement.bottom) {\n        y = client.y + client.height;\n    }\n    return [x, y];\n};\n\nexport interface PlacementRef {\n    placement: PointPlacement;\n    client: RectangleClient;\n}\n\nexport const getXDistanceBetweenPoint = (point1: Point, point2: Point, isHorizontalLayout: boolean) => {\n    if (isHorizontalLayout) {\n        return Math.abs(point1[0] - point2[0]);\n    } else {\n        return Math.abs(point1[1] - point2[1]);\n    }\n};\n\nexport const getYDistanceBetweenPoint = (point1: Point, point2: Point, isHorizontalLayout: boolean) => {\n    getXDistanceBetweenPoint(point1, point2, !isHorizontalLayout);\n};\n\nexport const getLayoutDirection = (node: MindNode, isHorizontal: boolean) => {\n    if (isHorizontal) {\n        if (node.left) {\n            return LayoutDirection.left;\n        } else {\n            return LayoutDirection.right;\n        }\n    } else {\n        if (node.up) {\n            return LayoutDirection.top;\n        } else {\n            return LayoutDirection.bottom;\n        }\n    }\n};\n\n// Based on right\n// Right -> Left:\n// 1. End point -> starting point/start point -> end point\n// 2. Add -> Subtract\n\n// Horizontal -> Vertical:\n// 1. Starting point/end point -> vertical axis\n// 2. Addition and subtraction -> vertical axis\n\n// Bottom -> Top:\n// 1. End point -> starting point/end point -> starting point\n// 2. Add -> Subtract\nexport const moveXOfPoint = (point: Point, distance: number, direction: LayoutDirection = LayoutDirection.right): Point => {\n    if (direction === LayoutDirection.left) {\n        return [point[0] - distance, point[1]];\n    }\n    if (direction === LayoutDirection.bottom) {\n        return [point[0], point[1] + distance];\n    }\n    if (direction === LayoutDirection.top) {\n        return [point[0], point[1] - distance];\n    }\n    return [point[0] + distance, point[1]];\n};\n\nexport const moveYOfPoint = (point: Point, distance: number, direction: LayoutDirection = LayoutDirection.right): Point => {\n    if (direction === LayoutDirection.bottom) {\n        return [point[0] + distance, point[1]];\n    }\n    if (direction === LayoutDirection.top) {\n        return [point[0] + distance, point[1]];\n    }\n    return [point[0], point[1] + distance];\n};\n\nexport const transformPlacement = (placement: PointPlacement, direction: LayoutDirection) => {\n    // to left\n    if (direction === LayoutDirection.left) {\n        if (placement[0] === HorizontalPlacement.right) {\n            placement[0] = HorizontalPlacement.left;\n        } else if (placement[0] === HorizontalPlacement.left) {\n            placement[0] = HorizontalPlacement.right;\n        }\n    }\n    // to bottom\n    if (direction === LayoutDirection.bottom || direction === LayoutDirection.top) {\n        let horizontal = HorizontalPlacement.center;\n        let vertical = VerticalPlacement.middle;\n        if (placement[1] === VerticalPlacement.top) {\n            horizontal = HorizontalPlacement.left;\n        }\n        if (placement[1] === VerticalPlacement.bottom) {\n            horizontal = HorizontalPlacement.right;\n        }\n        if (placement[0] === HorizontalPlacement.left) {\n            vertical = VerticalPlacement.top;\n        }\n        if (placement[0] === HorizontalPlacement.right) {\n            vertical = VerticalPlacement.bottom;\n        }\n        placement[0] = horizontal;\n        placement[1] = vertical;\n    }\n    // to up\n    if (direction === LayoutDirection.top) {\n        if (placement[1] === VerticalPlacement.bottom) {\n            placement[1] = VerticalPlacement.top;\n        } else if (placement[1] === VerticalPlacement.top) {\n            placement[1] = VerticalPlacement.bottom;\n        }\n    }\n};\n"]}
|
package/fesm2022/plait-mind.mjs
CHANGED
|
@@ -337,7 +337,7 @@ function getRelativeStartEndByAbstractRef(abstractRef, elements) {
|
|
|
337
337
|
return { start, end };
|
|
338
338
|
}
|
|
339
339
|
const insertElementHandleAbstract = (board, path, step = 1,
|
|
340
|
-
|
|
340
|
+
// This distinguishes between dragging and adding to the last node summarized in the abstract node
|
|
341
341
|
isExtendPreviousNode = true, effectedAbstracts = new Map()) => {
|
|
342
342
|
const parent = PlaitNode.parent(board, path);
|
|
343
343
|
const hasPreviousNode = path[path.length - 1] !== 0;
|
|
@@ -1256,7 +1256,7 @@ const directionDetector = (targetNode, centerPoint) => {
|
|
|
1256
1256
|
const left = targetNode.x;
|
|
1257
1257
|
const right = targetNode.x + targetNode.width;
|
|
1258
1258
|
const direction = [];
|
|
1259
|
-
// x
|
|
1259
|
+
// x-axis
|
|
1260
1260
|
if (centerPoint[1] > y && centerPoint[1] < y + height) {
|
|
1261
1261
|
if (centerPoint[0] > left && centerPoint[0] < xCenter) {
|
|
1262
1262
|
direction.push('left');
|
|
@@ -1264,7 +1264,7 @@ const directionDetector = (targetNode, centerPoint) => {
|
|
|
1264
1264
|
if (centerPoint[0] > xCenter && centerPoint[0] < right) {
|
|
1265
1265
|
direction.push('right');
|
|
1266
1266
|
}
|
|
1267
|
-
//
|
|
1267
|
+
// Overlapping area, return in both directions
|
|
1268
1268
|
if ((centerPoint[0] > x && centerPoint[0] < xCenter) || (centerPoint[0] > xCenter && centerPoint[0] < x + width)) {
|
|
1269
1269
|
if (centerPoint[1] < yCenter) {
|
|
1270
1270
|
direction.push('top');
|
|
@@ -1275,7 +1275,7 @@ const directionDetector = (targetNode, centerPoint) => {
|
|
|
1275
1275
|
}
|
|
1276
1276
|
return direction.length ? direction : null;
|
|
1277
1277
|
}
|
|
1278
|
-
// y
|
|
1278
|
+
// y-axis
|
|
1279
1279
|
if (centerPoint[0] > x && centerPoint[0] < x + width) {
|
|
1280
1280
|
if (centerPoint[1] > top && centerPoint[1] < yCenter) {
|
|
1281
1281
|
direction.push('top');
|
|
@@ -1304,17 +1304,14 @@ const getPathByDropTarget = (board, dropTarget) => {
|
|
|
1304
1304
|
? getRootLayout(dropTarget?.target)
|
|
1305
1305
|
: MindQueries.getCorrectLayoutByElement(board, MindElement.getParent(dropTarget?.target));
|
|
1306
1306
|
const children = getNonAbstractChildren(dropTarget.target);
|
|
1307
|
-
// 上下布局:左右是兄弟节点,上下是子节点
|
|
1308
1307
|
if (isVerticalLogicLayout(layout)) {
|
|
1309
1308
|
if (dropTarget.detectResult === 'top' || dropTarget.detectResult === 'bottom') {
|
|
1310
1309
|
targetPath.push(children.length);
|
|
1311
1310
|
}
|
|
1312
|
-
// 如果是左,位置不变,右则插入到下一个兄弟节点
|
|
1313
1311
|
if (dropTarget.detectResult === 'right') {
|
|
1314
1312
|
targetPath = Path.next(targetPath);
|
|
1315
1313
|
}
|
|
1316
1314
|
}
|
|
1317
|
-
// 水平布局/标准布局:上下是兄弟节点,左右是子节点
|
|
1318
1315
|
if (isHorizontalLogicLayout(layout)) {
|
|
1319
1316
|
if (dropTarget.detectResult === 'right') {
|
|
1320
1317
|
if (PlaitMind.isMind(dropTarget?.target) && isStandardLayout(layout)) {
|
|
@@ -1327,12 +1324,10 @@ const getPathByDropTarget = (board, dropTarget) => {
|
|
|
1327
1324
|
if (dropTarget.detectResult === 'left') {
|
|
1328
1325
|
targetPath.push(children.length);
|
|
1329
1326
|
}
|
|
1330
|
-
// 如果是上,位置不变,下插入到下一个兄弟节点
|
|
1331
1327
|
if (dropTarget.detectResult === 'bottom') {
|
|
1332
1328
|
targetPath = Path.next(targetPath);
|
|
1333
1329
|
}
|
|
1334
1330
|
}
|
|
1335
|
-
// 缩进布局:上下是兄弟节点,左右是子节点,但上(左上/右上),探测到上是子节点,下则位置不变,反之同理。
|
|
1336
1331
|
if (isIndentedLayout(layout)) {
|
|
1337
1332
|
if (isTopLayout(layout) && dropTarget.detectResult === 'top') {
|
|
1338
1333
|
targetPath = Path.next(targetPath);
|
|
@@ -1432,16 +1427,16 @@ const getLayoutDirection = (node, isHorizontal) => {
|
|
|
1432
1427
|
}
|
|
1433
1428
|
}
|
|
1434
1429
|
};
|
|
1435
|
-
//
|
|
1436
|
-
//
|
|
1437
|
-
// 1.
|
|
1438
|
-
// 2.
|
|
1439
|
-
//
|
|
1440
|
-
// 1.
|
|
1441
|
-
// 2.
|
|
1442
|
-
//
|
|
1443
|
-
// 1.
|
|
1444
|
-
// 2.
|
|
1430
|
+
// Based on right
|
|
1431
|
+
// Right -> Left:
|
|
1432
|
+
// 1. End point -> starting point/start point -> end point
|
|
1433
|
+
// 2. Add -> Subtract
|
|
1434
|
+
// Horizontal -> Vertical:
|
|
1435
|
+
// 1. Starting point/end point -> vertical axis
|
|
1436
|
+
// 2. Addition and subtraction -> vertical axis
|
|
1437
|
+
// Bottom -> Top:
|
|
1438
|
+
// 1. End point -> starting point/end point -> starting point
|
|
1439
|
+
// 2. Add -> Subtract
|
|
1445
1440
|
const moveXOfPoint = (point, distance, direction = LayoutDirection.right) => {
|
|
1446
1441
|
if (direction === LayoutDirection.left) {
|
|
1447
1442
|
return [point[0] - distance, point[1]];
|
|
@@ -1515,7 +1510,6 @@ function drawIndentedLink(board, node, child, defaultStroke = null, needDrawUnde
|
|
|
1515
1510
|
beginY = isChildUp(node, child) ? beginRectangle.y : beginRectangle.y + beginRectangle.height;
|
|
1516
1511
|
endX = node.left ? endNode.x + endNode.hGap + endRectangle.width : endNode.x + endNode.hGap;
|
|
1517
1512
|
endY = isUnderlineShape ? endNode.y + endNode.height - endNode.vGap : endNode.y + endNode.height / 2;
|
|
1518
|
-
//根据位置,设置正负参数
|
|
1519
1513
|
let plusMinus = isChildUp(node, child) ? (node.left ? [-1, -1] : [1, -1]) : node.left ? [-1, 1] : [1, 1];
|
|
1520
1514
|
let curve = [
|
|
1521
1515
|
[beginX, beginY],
|
|
@@ -1569,12 +1563,11 @@ function drawLogicLink(board, parent, node, isHorizontal, defaultStroke = null,
|
|
|
1569
1563
|
}
|
|
1570
1564
|
let beginPoint = getPointByPlacement(parentClient, beginPlacement);
|
|
1571
1565
|
let endPoint = getPointByPlacement(nodeClient, endPlacement);
|
|
1572
|
-
// ②
|
|
1573
|
-
// 绘制贝塞尔曲线要求,需要增加三个点,正常两个点就可以确定这条直线
|
|
1566
|
+
// ② Determine the convex straight line
|
|
1574
1567
|
const straightLineDistance = 8;
|
|
1575
1568
|
const beginPoint2 = hasStraightLine ? moveXOfPoint(beginPoint, straightLineDistance, linkDirection) : beginPoint;
|
|
1576
1569
|
let straightLine = hasStraightLine ? [beginPoint, beginPoint2, beginPoint2] : [];
|
|
1577
|
-
// ③
|
|
1570
|
+
// ③ Determine the curve
|
|
1578
1571
|
const beginBufferDistance = (parent.hGap + node.hGap) / 3;
|
|
1579
1572
|
const endBufferDistance = -(parent.hGap + node.hGap) / 2.4;
|
|
1580
1573
|
let curve = [
|
|
@@ -1583,7 +1576,7 @@ function drawLogicLink(board, parent, node, isHorizontal, defaultStroke = null,
|
|
|
1583
1576
|
moveXOfPoint(endPoint, endBufferDistance, linkDirection),
|
|
1584
1577
|
endPoint
|
|
1585
1578
|
];
|
|
1586
|
-
// ④
|
|
1579
|
+
// ④ underline shape and horizontal
|
|
1587
1580
|
const underlineEnd = moveXOfPoint(endPoint, nodeClient.width, linkDirection);
|
|
1588
1581
|
const underline = hasUnderlineShape && isHorizontal ? [underlineEnd, underlineEnd, underlineEnd] : [];
|
|
1589
1582
|
const points = pointsOnBezierCurves([...straightLine, ...curve, ...underline]);
|
|
@@ -2047,7 +2040,7 @@ const getCorrectLayoutByElement = (board, element) => {
|
|
|
2047
2040
|
const getBranchLayouts = (board, element) => {
|
|
2048
2041
|
const layouts = [];
|
|
2049
2042
|
if (element.layout) {
|
|
2050
|
-
// TODO: getCorrectLayoutByElement
|
|
2043
|
+
// TODO: getCorrectLayoutByElement Contains recursive operations. getBranchLayouts itself also has recursive operations and needs to be optimized.
|
|
2051
2044
|
layouts.unshift(getCorrectLayoutByElement(board, element));
|
|
2052
2045
|
}
|
|
2053
2046
|
let parent = MindElement.findParent(element);
|
|
@@ -3302,7 +3295,7 @@ const withNodeDnd = (board) => {
|
|
|
3302
3295
|
let insertPath = targetPathRef.current;
|
|
3303
3296
|
const parentPath = Path.parent(targetPathRef.current || targetPath);
|
|
3304
3297
|
if (!insertPath) {
|
|
3305
|
-
|
|
3298
|
+
// When the insertion position and the selected node position are the same, the recorded previousPath is used
|
|
3306
3299
|
const previousPath = targetPreviousPathRef && targetPreviousPathRef.unref();
|
|
3307
3300
|
if (previousPath) {
|
|
3308
3301
|
insertPath = Path.next(previousPath);
|