@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.
@@ -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":"AAEA,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAC;AACvD,OAAO,EAAE,mBAAmB,EAAkB,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;AAE7F,MAAM,CAAC,MAAM,mBAAmB,GAAG,CAAC,MAAuB,EAAE,SAAyB,EAAS,EAAE;IAC7F,IAAI,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC;IACjB,IAAI,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC;IACjB,IAAI,SAAS,CAAC,CAAC,CAAC,KAAK,mBAAmB,CAAC,MAAM,EAAE;QAC7C,CAAC,GAAG,MAAM,CAAC,CAAC,GAAG,MAAM,CAAC,KAAK,GAAG,CAAC,CAAC;KACnC;IACD,IAAI,SAAS,CAAC,CAAC,CAAC,KAAK,mBAAmB,CAAC,KAAK,EAAE;QAC5C,CAAC,GAAG,MAAM,CAAC,CAAC,GAAG,MAAM,CAAC,KAAK,CAAC;KAC/B;IACD,IAAI,SAAS,CAAC,CAAC,CAAC,KAAK,iBAAiB,CAAC,MAAM,EAAE;QAC3C,CAAC,GAAG,MAAM,CAAC,CAAC,GAAG,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC;KACpC;IACD,IAAI,SAAS,CAAC,CAAC,CAAC,KAAK,iBAAiB,CAAC,MAAM,EAAE;QAC3C,CAAC,GAAG,MAAM,CAAC,CAAC,GAAG,MAAM,CAAC,MAAM,CAAC;KAChC;IACD,OAAO,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;AAClB,CAAC,CAAC;AAOF,MAAM,CAAC,MAAM,wBAAwB,GAAG,CAAC,MAAa,EAAE,MAAa,EAAE,kBAA2B,EAAE,EAAE;IAClG,IAAI,kBAAkB,EAAE;QACpB,OAAO,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;KAC1C;SAAM;QACH,OAAO,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;KAC1C;AACL,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,wBAAwB,GAAG,CAAC,MAAa,EAAE,MAAa,EAAE,kBAA2B,EAAE,EAAE;IAClG,wBAAwB,CAAC,MAAM,EAAE,MAAM,EAAE,CAAC,kBAAkB,CAAC,CAAC;AAClE,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,kBAAkB,GAAG,CAAC,IAAc,EAAE,YAAqB,EAAE,EAAE;IACxE,IAAI,YAAY,EAAE;QACd,IAAI,IAAI,CAAC,IAAI,EAAE;YACX,OAAO,eAAe,CAAC,IAAI,CAAC;SAC/B;aAAM;YACH,OAAO,eAAe,CAAC,KAAK,CAAC;SAChC;KACJ;SAAM;QACH,IAAI,IAAI,CAAC,EAAE,EAAE;YACT,OAAO,eAAe,CAAC,GAAG,CAAC;SAC9B;aAAM;YACH,OAAO,eAAe,CAAC,MAAM,CAAC;SACjC;KACJ;AACL,CAAC,CAAC;AAEF,iBAAiB;AACjB,iBAAiB;AACjB,0DAA0D;AAC1D,qBAAqB;AAErB,0BAA0B;AAC1B,+CAA+C;AAC/C,+CAA+C;AAE/C,iBAAiB;AACjB,6DAA6D;AAC7D,qBAAqB;AACrB,MAAM,CAAC,MAAM,YAAY,GAAG,CAAC,KAAY,EAAE,QAAgB,EAAE,YAA6B,eAAe,CAAC,KAAK,EAAS,EAAE;IACtH,IAAI,SAAS,KAAK,eAAe,CAAC,IAAI,EAAE;QACpC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,QAAQ,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;KAC1C;IACD,IAAI,SAAS,KAAK,eAAe,CAAC,MAAM,EAAE;QACtC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC,CAAC;KAC1C;IACD,IAAI,SAAS,KAAK,eAAe,CAAC,GAAG,EAAE;QACnC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC,CAAC;KAC1C;IACD,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,QAAQ,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;AAC3C,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,YAAY,GAAG,CAAC,KAAY,EAAE,QAAgB,EAAE,YAA6B,eAAe,CAAC,KAAK,EAAS,EAAE;IACtH,IAAI,SAAS,KAAK,eAAe,CAAC,MAAM,EAAE;QACtC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,QAAQ,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;KAC1C;IACD,IAAI,SAAS,KAAK,eAAe,CAAC,GAAG,EAAE;QACnC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,QAAQ,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;KAC1C;IACD,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC,CAAC;AAC3C,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,kBAAkB,GAAG,CAAC,SAAyB,EAAE,SAA0B,EAAE,EAAE;IACxF,UAAU;IACV,IAAI,SAAS,KAAK,eAAe,CAAC,IAAI,EAAE;QACpC,IAAI,SAAS,CAAC,CAAC,CAAC,KAAK,mBAAmB,CAAC,KAAK,EAAE;YAC5C,SAAS,CAAC,CAAC,CAAC,GAAG,mBAAmB,CAAC,IAAI,CAAC;SAC3C;aAAM,IAAI,SAAS,CAAC,CAAC,CAAC,KAAK,mBAAmB,CAAC,IAAI,EAAE;YAClD,SAAS,CAAC,CAAC,CAAC,GAAG,mBAAmB,CAAC,KAAK,CAAC;SAC5C;KACJ;IACD,YAAY;IACZ,IAAI,SAAS,KAAK,eAAe,CAAC,MAAM,IAAI,SAAS,KAAK,eAAe,CAAC,GAAG,EAAE;QAC3E,IAAI,UAAU,GAAG,mBAAmB,CAAC,MAAM,CAAC;QAC5C,IAAI,QAAQ,GAAG,iBAAiB,CAAC,MAAM,CAAC;QACxC,IAAI,SAAS,CAAC,CAAC,CAAC,KAAK,iBAAiB,CAAC,GAAG,EAAE;YACxC,UAAU,GAAG,mBAAmB,CAAC,IAAI,CAAC;SACzC;QACD,IAAI,SAAS,CAAC,CAAC,CAAC,KAAK,iBAAiB,CAAC,MAAM,EAAE;YAC3C,UAAU,GAAG,mBAAmB,CAAC,KAAK,CAAC;SAC1C;QACD,IAAI,SAAS,CAAC,CAAC,CAAC,KAAK,mBAAmB,CAAC,IAAI,EAAE;YAC3C,QAAQ,GAAG,iBAAiB,CAAC,GAAG,CAAC;SACpC;QACD,IAAI,SAAS,CAAC,CAAC,CAAC,KAAK,mBAAmB,CAAC,KAAK,EAAE;YAC5C,QAAQ,GAAG,iBAAiB,CAAC,MAAM,CAAC;SACvC;QACD,SAAS,CAAC,CAAC,CAAC,GAAG,UAAU,CAAC;QAC1B,SAAS,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC;KAC3B;IACD,QAAQ;IACR,IAAI,SAAS,KAAK,eAAe,CAAC,GAAG,EAAE;QACnC,IAAI,SAAS,CAAC,CAAC,CAAC,KAAK,iBAAiB,CAAC,MAAM,EAAE;YAC3C,SAAS,CAAC,CAAC,CAAC,GAAG,iBAAiB,CAAC,GAAG,CAAC;SACxC;aAAM,IAAI,SAAS,CAAC,CAAC,CAAC,KAAK,iBAAiB,CAAC,GAAG,EAAE;YAC/C,SAAS,CAAC,CAAC,CAAC,GAAG,iBAAiB,CAAC,MAAM,CAAC;SAC3C;KACJ;AACL,CAAC,CAAC","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"]}
@@ -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
- // ④ 下划线绘制,underline shape and horizontal
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 含有递归操作,getBranchLayouts 本身也有递归操作,有待优化
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
- //当插入位置和选中节点位置相同时,使用记录的 previousPath
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);