@plait/mind 0.2.0-next.3 → 0.2.0-next.5
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/indented-link.d.ts +2 -2
- package/draw/link/logic-link.d.ts +2 -2
- package/draw/link.d.ts +2 -2
- package/esm2020/draw/indented-link.mjs +7 -6
- package/esm2020/draw/link/logic-link.mjs +7 -6
- package/esm2020/draw/link.mjs +8 -7
- package/esm2020/draw/shape.mjs +3 -3
- package/esm2020/drawer/quick-insert.drawer.mjs +9 -8
- package/esm2020/interfaces/element.mjs +13 -2
- package/esm2020/node.component.mjs +6 -6
- package/esm2020/plugins/emoji/emoji-base.component.mjs +4 -2
- package/esm2020/plugins/emoji/emoji.drawer.mjs +2 -1
- package/esm2020/plugins/with-abstract.mjs +2 -2
- package/esm2020/plugins/with-dnd.mjs +2 -2
- package/esm2020/plugins/with-mind.mjs +3 -2
- package/esm2020/transforms/layout.mjs +8 -2
- package/esm2020/utils/abstract/common.mjs +49 -15
- package/esm2020/utils/abstract/resize.mjs +2 -2
- package/esm2020/utils/clipboard.mjs +10 -3
- package/esm2020/utils/draw-placeholder.mjs +20 -20
- package/esm2020/utils/index.mjs +2 -2
- package/esm2020/utils/mind.mjs +30 -21
- package/esm2020/utils/node-style/branch.mjs +28 -0
- package/esm2020/utils/node-style/index.mjs +3 -0
- package/esm2020/utils/node-style/node.mjs +22 -0
- package/esm2020/utils/path.mjs +3 -3
- package/fesm2015/plait-mind.mjs +1449 -1377
- package/fesm2015/plait-mind.mjs.map +1 -1
- package/fesm2020/plait-mind.mjs +1451 -1379
- package/fesm2020/plait-mind.mjs.map +1 -1
- package/interfaces/element.d.ts +3 -2
- package/package.json +1 -1
- package/plugins/emoji/emoji-base.component.d.ts +3 -1
- package/utils/abstract/common.d.ts +6 -1
- package/utils/abstract/resize.d.ts +1 -1
- package/utils/draw-placeholder.d.ts +8 -8
- package/utils/index.d.ts +1 -1
- package/utils/mind.d.ts +2 -1
- package/utils/node-style/branch.d.ts +7 -0
- package/utils/node-style/index.d.ts +2 -0
- package/utils/node-style/node.d.ts +3 -0
- package/esm2020/utils/colors.mjs +0 -41
- package/utils/colors.d.ts +0 -4
package/draw/indented-link.d.ts
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import { RoughSVG } from 'roughjs/bin/svg';
|
|
2
1
|
import { MindNode } from '../interfaces/node';
|
|
3
|
-
|
|
2
|
+
import { PlaitBoard } from '@plait/core';
|
|
3
|
+
export declare function drawIndentedLink(board: PlaitBoard, node: MindNode, child: MindNode, defaultStroke?: string | null, needDrawUnderline?: boolean): SVGGElement;
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import { RoughSVG } from 'roughjs/bin/svg';
|
|
2
1
|
import { MindNode } from '../../interfaces/node';
|
|
3
|
-
|
|
2
|
+
import { PlaitBoard } from '@plait/core';
|
|
3
|
+
export declare function drawLogicLink(board: PlaitBoard, node: MindNode, parent: MindNode, isHorizontal: boolean): SVGGElement;
|
package/draw/link.d.ts
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import { RoughSVG } from 'roughjs/bin/svg';
|
|
2
1
|
import { MindNode } from '../interfaces/node';
|
|
3
|
-
|
|
2
|
+
import { PlaitBoard } from '@plait/core';
|
|
3
|
+
export declare function drawLink(board: PlaitBoard, node: MindNode, child: MindNode, defaultStroke?: string | null, isHorizontal?: boolean, needDrawUnderline?: boolean): SVGGElement;
|
|
@@ -1,10 +1,11 @@
|
|
|
1
1
|
import { pointsOnBezierCurves } from 'points-on-curve';
|
|
2
2
|
import { MindNodeShape, STROKE_WIDTH } from '../constants';
|
|
3
|
-
import {
|
|
3
|
+
import { PlaitBoard } from '@plait/core';
|
|
4
4
|
import { getNodeShapeByElement, getRectangleByNode, isChildUp } from '../utils';
|
|
5
5
|
import { MindLayoutType } from '@plait/layouts';
|
|
6
6
|
import { MindQueries } from '../queries';
|
|
7
|
-
|
|
7
|
+
import { getBranchColorByMindElement } from '../utils/node-style/branch';
|
|
8
|
+
export function drawIndentedLink(board, node, child, defaultStroke = null, needDrawUnderline = true) {
|
|
8
9
|
const isUnderlineShap = getNodeShapeByElement(child.origin) === MindNodeShape.underline;
|
|
9
10
|
let beginX, beginY, endX, endY, beginNode = node, endNode = child;
|
|
10
11
|
const beginRectangle = getRectangleByNode(beginNode);
|
|
@@ -16,7 +17,7 @@ export function drawIndentedLink(roughSVG, node, child, defaultStroke = null, ne
|
|
|
16
17
|
//根据位置,设置正负参数
|
|
17
18
|
let plusMinus = isChildUp(node, child) ? (node.left ? [-1, -1] : [1, -1]) : node.left ? [-1, 1] : [1, 1];
|
|
18
19
|
const layout = MindQueries.getCorrectLayoutByElement(node.origin);
|
|
19
|
-
const strokeWidth = child.origin.
|
|
20
|
+
const strokeWidth = child.origin.branchWidth ? child.origin.branchWidth : STROKE_WIDTH;
|
|
20
21
|
if (beginNode.origin.isRoot) {
|
|
21
22
|
if (layout === MindLayoutType.leftBottomIndented || layout === MindLayoutType.rightBottomIndented) {
|
|
22
23
|
beginY += strokeWidth;
|
|
@@ -37,8 +38,8 @@ export function drawIndentedLink(roughSVG, node, child, defaultStroke = null, ne
|
|
|
37
38
|
isUnderlineShap && needDrawUnderline ? [endX + (endNode.width - endNode.hGap * 2) * plusMinus[0], endY] : [endX, endY],
|
|
38
39
|
isUnderlineShap && needDrawUnderline ? [endX + (endNode.width - endNode.hGap * 2) * plusMinus[0], endY] : [endX, endY]
|
|
39
40
|
];
|
|
40
|
-
const stroke = defaultStroke ||
|
|
41
|
+
const stroke = defaultStroke || getBranchColorByMindElement(board, child.origin);
|
|
41
42
|
const points = pointsOnBezierCurves(curve);
|
|
42
|
-
return
|
|
43
|
+
return PlaitBoard.getRoughSVG(board).curve(points, { stroke, strokeWidth });
|
|
43
44
|
}
|
|
44
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
45
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"indented-link.js","sourceRoot":"","sources":["../../../../packages/mind/src/draw/indented-link.ts"],"names":[],"mappings":"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","sourcesContent":["import { pointsOnBezierCurves } from 'points-on-curve';\nimport { MindNodeShape, STROKE_WIDTH } from '../constants';\nimport { MindNode } from '../interfaces/node';\nimport { PlaitBoard, Point } from '@plait/core';\nimport { getNodeShapeByElement, getRectangleByNode, isChildUp } from '../utils';\nimport { MindLayoutType } from '@plait/layouts';\nimport { MindQueries } from '../queries';\nimport { getBranchColorByMindElement } from '../utils/node-style/branch';\n\nexport function drawIndentedLink(\n    board: PlaitBoard,\n    node: MindNode,\n    child: MindNode,\n    defaultStroke: string | null = null,\n    needDrawUnderline = true\n) {\n    const isUnderlineShap = (getNodeShapeByElement(child.origin) as MindNodeShape) === MindNodeShape.underline;\n    let beginX,\n        beginY,\n        endX,\n        endY,\n        beginNode = node,\n        endNode = child;\n    const beginRectangle = getRectangleByNode(beginNode);\n    const endRectangle = getRectangleByNode(endNode);\n\n    beginX = beginNode.x + beginNode.width / 2;\n    beginY = isChildUp(node, child) ? beginRectangle.y : beginRectangle.y + beginRectangle.height;\n    endX = node.left ? endNode.x + endNode.hGap + endRectangle.width : endNode.x + endNode.hGap;\n    endY = isUnderlineShap ? endNode.y + endNode.height - endNode.vGap : endNode.y + endNode.height / 2;\n    //根据位置，设置正负参数\n    let plusMinus = isChildUp(node, child) ? (node.left ? [-1, -1] : [1, -1]) : node.left ? [-1, 1] : [1, 1];\n    const layout = MindQueries.getCorrectLayoutByElement(node.origin);\n    const strokeWidth = child.origin.branchWidth ? child.origin.branchWidth : STROKE_WIDTH;\n    if (beginNode.origin.isRoot) {\n        if (layout === MindLayoutType.leftBottomIndented || layout === MindLayoutType.rightBottomIndented) {\n            beginY += strokeWidth;\n        }\n        if (layout === MindLayoutType.leftTopIndented || layout === MindLayoutType.rightTopIndented) {\n            beginY -= strokeWidth;\n        }\n    }\n    let curve: Point[] = [\n        [beginX, beginY],\n        [beginX, beginY],\n        [beginX, beginY],\n        [beginX, endY - (endNode.hGap * 3 * plusMinus[1]) / 5],\n        [beginX, endY - (endNode.hGap * plusMinus[1]) / 5],\n        [beginX + (endNode.hGap * plusMinus[0]) / 4, endY],\n        [beginX + (endNode.hGap * plusMinus[0] * 3) / 5, endY],\n        isUnderlineShap && needDrawUnderline ? [endX + (endNode.width - endNode.hGap * 2) * plusMinus[0], endY] : [endX, endY],\n        isUnderlineShap && needDrawUnderline ? [endX + (endNode.width - endNode.hGap * 2) * plusMinus[0], endY] : [endX, endY],\n        isUnderlineShap && needDrawUnderline ? [endX + (endNode.width - endNode.hGap * 2) * plusMinus[0], endY] : [endX, endY]\n    ];\n\n    const stroke = defaultStroke || getBranchColorByMindElement(board, child.origin);\n\n    const points = pointsOnBezierCurves(curve);\n    return PlaitBoard.getRoughSVG(board).curve(points as any, { stroke, strokeWidth });\n}\n"]}
|
|
@@ -1,12 +1,13 @@
|
|
|
1
1
|
import { pointsOnBezierCurves } from 'points-on-curve';
|
|
2
2
|
import { MindNodeShape, STROKE_WIDTH } from '../../constants';
|
|
3
|
-
import {
|
|
3
|
+
import { PlaitBoard } from '@plait/core';
|
|
4
4
|
import { getRectangleByNode } from '../../utils';
|
|
5
5
|
import { getLayoutDirection, getPointByPlacement, movePoint, transformPlacement } from '../../utils/point-placement';
|
|
6
6
|
import { HorizontalPlacement, VerticalPlacement } from '../../interfaces/types';
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
const
|
|
7
|
+
import { getBranchColorByMindElement } from '../../utils/node-style/branch';
|
|
8
|
+
export function drawLogicLink(board, node, parent, isHorizontal) {
|
|
9
|
+
const branchColor = getBranchColorByMindElement(board, node.origin);
|
|
10
|
+
const strokeWidth = node.origin.branchWidth ? node.origin.branchWidth : STROKE_WIDTH;
|
|
10
11
|
const hasStraightLine = !parent.origin.isRoot;
|
|
11
12
|
const hasUnderlineShape = node.origin.shape === MindNodeShape.underline;
|
|
12
13
|
const hasUnderlineShapeOfParent = parent.origin.shape === MindNodeShape.underline;
|
|
@@ -46,6 +47,6 @@ export function drawLogicLink(roughSVG, node, parent, isHorizontal) {
|
|
|
46
47
|
const underlineEnd = movePoint(endPoint, nodeClient.width, linkDirection);
|
|
47
48
|
const underline = hasUnderlineShape && isHorizontal ? [underlineEnd, underlineEnd, underlineEnd] : [];
|
|
48
49
|
const points = pointsOnBezierCurves([...straightLine, ...curve, ...underline]);
|
|
49
|
-
return
|
|
50
|
+
return PlaitBoard.getRoughSVG(board).curve(points, { stroke: branchColor, strokeWidth });
|
|
50
51
|
}
|
|
51
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
52
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"logic-link.js","sourceRoot":"","sources":["../../../../../packages/mind/src/draw/link/logic-link.ts"],"names":[],"mappings":"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","sourcesContent":["import { pointsOnBezierCurves } from 'points-on-curve';\nimport { MindNodeShape, STROKE_WIDTH } from '../../constants';\nimport { MindNode } from '../../interfaces/node';\nimport { PlaitBoard, Point } from '@plait/core';\nimport { getRectangleByNode } from '../../utils';\nimport { getLayoutDirection, getPointByPlacement, movePoint, transformPlacement } from '../../utils/point-placement';\nimport { HorizontalPlacement, PointPlacement, VerticalPlacement } from '../../interfaces/types';\nimport { getBranchColorByMindElement } from '../../utils/node-style/branch';\n\nexport function drawLogicLink(board: PlaitBoard, node: MindNode, parent: MindNode, isHorizontal: boolean) {\n    const branchColor = getBranchColorByMindElement(board, node.origin);\n    const strokeWidth = node.origin.branchWidth ? node.origin.branchWidth : STROKE_WIDTH;\n    const hasStraightLine = !parent.origin.isRoot;\n    const hasUnderlineShape = node.origin.shape === MindNodeShape.underline;\n    const hasUnderlineShapeOfParent = parent.origin.shape === MindNodeShape.underline;\n    const nodeClient = getRectangleByNode(node);\n    const parentClient = getRectangleByNode(parent);\n    const linkDirection = getLayoutDirection(node, isHorizontal);\n\n    // ① ensure begin placement and end placement\n    // begin placement represent parent connector position and end placement represent child connector\n    const beginPlacement: PointPlacement = [HorizontalPlacement.right, VerticalPlacement.middle];\n    const endPlacement: PointPlacement = [HorizontalPlacement.left, VerticalPlacement.middle];\n\n    transformPlacement(beginPlacement, linkDirection);\n    transformPlacement(endPlacement, linkDirection);\n\n    // underline shape and horizontal\n    if (isHorizontal && hasUnderlineShapeOfParent && !parent.origin.isRoot) {\n        beginPlacement[1] = VerticalPlacement.bottom;\n    }\n    if (isHorizontal && hasUnderlineShape) {\n        endPlacement[1] = VerticalPlacement.bottom;\n    }\n\n    let beginPoint = getPointByPlacement(parentClient, beginPlacement);\n    let endPoint = getPointByPlacement(nodeClient, endPlacement);\n\n    // ② 确定凸出直线，从起始点开始画一条直线，从直线的结束位置绘制曲线，保证收起图标可以完美覆盖起始连线，根节点不需要这条直线\n    // 绘制贝塞尔曲线要求，需要增加三个点，正常两个点就可以确定这条直线\n    const straightLineDistance = 8;\n    const beginPoint2 = hasStraightLine ? movePoint(beginPoint, straightLineDistance, linkDirection) : beginPoint;\n    let straightLine: Point[] = hasStraightLine ? [beginPoint, beginPoint2, beginPoint2] : [];\n\n    // ③ 确定曲线\n    const beginBufferDistance = (parent.hGap + node.hGap) / 3;\n    const endBufferDistance = -(parent.hGap + node.hGap) / 2.4;\n    let curve: Point[] = [\n        beginPoint2,\n        movePoint(beginPoint2, beginBufferDistance, linkDirection),\n        movePoint(endPoint, endBufferDistance, linkDirection),\n        endPoint\n    ];\n\n    // ④ 下划线绘制，underline shape and horizontal\n    const underlineEnd = movePoint(endPoint, nodeClient.width, linkDirection);\n    const underline: Point[] = hasUnderlineShape && isHorizontal ? [underlineEnd, underlineEnd, underlineEnd] : [];\n\n    const points = pointsOnBezierCurves([...straightLine, ...curve, ...underline]);\n    return PlaitBoard.getRoughSVG(board).curve(points as any, { stroke: branchColor, strokeWidth });\n}\n"]}
|
package/esm2020/draw/link.mjs
CHANGED
|
@@ -1,10 +1,11 @@
|
|
|
1
1
|
import { pointsOnBezierCurves } from 'points-on-curve';
|
|
2
2
|
import { MindNodeShape, STROKE_WIDTH } from '../constants';
|
|
3
|
-
import {
|
|
3
|
+
import { PlaitBoard } from '@plait/core';
|
|
4
4
|
import { getNodeShapeByElement, isChildRight } from '../utils';
|
|
5
5
|
import { MindLayoutType, isTopLayout, isIndentedLayout, isStandardLayout } from '@plait/layouts';
|
|
6
6
|
import { MindQueries } from '../queries';
|
|
7
|
-
|
|
7
|
+
import { getBranchColorByMindElement } from '../utils/node-style/branch';
|
|
8
|
+
export function drawLink(board, node, child, defaultStroke = null, isHorizontal = true, needDrawUnderline = true) {
|
|
8
9
|
let beginX, beginY, endX, endY, beginNode = node, endNode = child;
|
|
9
10
|
const layout = MindQueries.getCorrectLayoutByElement(node.origin);
|
|
10
11
|
if (isHorizontal) {
|
|
@@ -37,8 +38,8 @@ export function drawLink(roughSVG, node, child, defaultStroke = null, isHorizont
|
|
|
37
38
|
endX = endNode.x + endNode.width / 2;
|
|
38
39
|
endY = endNode.y + endNode.vGap;
|
|
39
40
|
}
|
|
40
|
-
const stroke = defaultStroke ||
|
|
41
|
-
const strokeWidth = child.origin.
|
|
41
|
+
const stroke = defaultStroke || getBranchColorByMindElement(board, child.origin);
|
|
42
|
+
const strokeWidth = child.origin.branchWidth ? child.origin.branchWidth : STROKE_WIDTH;
|
|
42
43
|
if (endNode.origin.isRoot) {
|
|
43
44
|
if (layout === MindLayoutType.left || isStandardLayout(layout)) {
|
|
44
45
|
endX -= strokeWidth;
|
|
@@ -112,7 +113,7 @@ export function drawLink(roughSVG, node, child, defaultStroke = null, isHorizont
|
|
|
112
113
|
}
|
|
113
114
|
}
|
|
114
115
|
const points = pointsOnBezierCurves(curve);
|
|
115
|
-
return
|
|
116
|
+
return PlaitBoard.getRoughSVG(board).curve(points, { stroke, strokeWidth });
|
|
116
117
|
}
|
|
117
118
|
else {
|
|
118
119
|
let curve = [
|
|
@@ -152,7 +153,7 @@ export function drawLink(roughSVG, node, child, defaultStroke = null, isHorizont
|
|
|
152
153
|
}
|
|
153
154
|
}
|
|
154
155
|
const points = pointsOnBezierCurves(curve);
|
|
155
|
-
return
|
|
156
|
+
return PlaitBoard.getRoughSVG(board).curve(points, { stroke, strokeWidth });
|
|
156
157
|
}
|
|
157
158
|
}
|
|
158
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"link.js","sourceRoot":"","sources":["../../../../packages/mind/src/draw/link.ts"],"names":[],"mappings":"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","sourcesContent":["import { pointsOnBezierCurves } from 'points-on-curve';\nimport { RoughSVG } from 'roughjs/bin/svg';\nimport { GRAY_COLOR, MindNodeShape, STROKE_WIDTH } from '../constants';\nimport { MindNode } from '../interfaces/node';\nimport { getLinkLineColorByMindElement } from '../utils/colors';\nimport { PlaitBoard, Point, createG, getRectangleByElements } from '@plait/core';\nimport { getNodeShapeByElement, getRectangleByNode, isChildRight } from '../utils';\nimport { MindLayoutType, isTopLayout, isIndentedLayout, isStandardLayout } from '@plait/layouts';\nimport { MindQueries } from '../queries';\n\nexport function drawLink(\n    roughSVG: RoughSVG,\n    node: MindNode,\n    child: MindNode,\n    defaultStroke: string | null = null,\n    isHorizontal = true,\n    needDrawUnderline = true\n) {\n    let beginX,\n        beginY,\n        endX,\n        endY,\n        beginNode = node,\n        endNode = child;\n    const layout = MindQueries.getCorrectLayoutByElement(node.origin) as MindLayoutType;\n    if (isHorizontal) {\n        if (!isChildRight(node, child)) {\n            beginNode = child;\n            endNode = node;\n        }\n        beginX = beginNode.x + beginNode.width - beginNode.hGap;\n        beginY = beginNode.y + beginNode.height / 2;\n        endX = endNode.x + endNode.hGap;\n        endY = endNode.y + endNode.height / 2;\n\n        if (\n            node.parent &&\n            isIndentedLayout(MindQueries.getLayoutByElement(node.parent?.origin)) &&\n            (getNodeShapeByElement(node.origin) as MindNodeShape) === MindNodeShape.underline\n        ) {\n            if (isChildRight(node, child)) {\n                beginY = node.y + node.height - node.vGap;\n            } else {\n                endY = node.y + node.height - node.vGap;\n            }\n        }\n    } else {\n        if (node.y > child.y) {\n            beginNode = child;\n            endNode = node;\n        }\n        beginX = beginNode.x + beginNode.width / 2;\n        beginY = beginNode.y + beginNode.height - beginNode.vGap;\n        endX = endNode.x + endNode.width / 2;\n        endY = endNode.y + endNode.vGap;\n    }\n\n    const stroke = defaultStroke || getLinkLineColorByMindElement(child.origin);\n    const strokeWidth = child.origin.linkLineWidth ? child.origin.linkLineWidth : STROKE_WIDTH;\n    if (endNode.origin.isRoot) {\n        if (layout === MindLayoutType.left || isStandardLayout(layout)) {\n            endX -= strokeWidth;\n        }\n        if (layout === MindLayoutType.upward) {\n            endY -= strokeWidth;\n        }\n    }\n    if (beginNode.origin.isRoot) {\n        if (layout === MindLayoutType.right || isStandardLayout(layout)) {\n            beginX += strokeWidth;\n        }\n        if (layout === MindLayoutType.downward) {\n            beginY += strokeWidth;\n        }\n    }\n    if (isHorizontal) {\n        let curve: Point[] = [\n            [beginX, beginY],\n            [beginX + (beginNode.hGap + endNode.hGap) / 3, beginY],\n            [endX - (beginNode.hGap + endNode.hGap) / 2, endY],\n            [endX, endY]\n        ];\n        const shape = getNodeShapeByElement(child.origin) as MindNodeShape;\n\n        if (!node.origin.isRoot) {\n            if (node.x > child.x) {\n                curve = [\n                    [beginX, beginY],\n                    [beginX + (beginNode.hGap + endNode.hGap) / 3, beginY],\n                    [endX - (beginNode.hGap + endNode.hGap) / 2, endY],\n                    [endX - 12, endY]\n                ];\n                const line = [\n                    [endX - 12, endY],\n                    [endX - 12, endY],\n                    [endX, endY]\n                ] as Point[];\n                curve = [...curve, ...line];\n            } else {\n                curve = [\n                    [beginX + 12, beginY],\n                    [beginX + (beginNode.hGap + endNode.hGap) / 2, beginY],\n                    [endX - (beginNode.hGap + endNode.hGap) / 3, endY],\n                    [endX, endY]\n                ];\n                const line = [\n                    [beginX, beginY],\n                    [beginX + 12, beginY],\n                    [beginX + 12, beginY]\n                ] as Point[];\n                curve = [...line, ...curve];\n            }\n        }\n\n        if (needDrawUnderline && shape === MindNodeShape.underline) {\n            if (child.left) {\n                const underline = [\n                    [beginX - (beginNode.width - beginNode.hGap * 2), beginY],\n                    [beginX - (beginNode.width - beginNode.hGap * 2), beginY],\n                    [beginX - (beginNode.width - beginNode.hGap * 2), beginY]\n                ] as Point[];\n                curve = [...underline, ...curve];\n            } else {\n                const underline = [\n                    [endX + (endNode.width - endNode.hGap * 2), endY],\n                    [endX + (endNode.width - endNode.hGap * 2), endY],\n                    [endX + (endNode.width - endNode.hGap * 2), endY]\n                ] as Point[];\n                curve = [...curve, ...underline];\n            }\n        }\n\n        const points = pointsOnBezierCurves(curve);\n        return roughSVG.curve(points as any, { stroke, strokeWidth });\n    } else {\n        let curve: Point[] = [\n            [beginX, beginY],\n            [beginX, beginY + (beginNode.vGap + endNode.vGap) / 2],\n            [endX, endY - (beginNode.vGap + endNode.vGap) / 2],\n            [endX, endY]\n        ];\n\n        if (!node.origin.isRoot) {\n            if (isTopLayout(layout)) {\n                curve = [\n                    [beginX, beginY],\n                    [beginX, beginY + (beginNode.vGap + endNode.vGap) / 2],\n                    [endX, endY - (beginNode.vGap + endNode.vGap) / 2],\n                    [endX, endY - 12]\n                ];\n\n                const line = [\n                    [endX, endY - 12],\n                    [endX, endY - 12],\n                    [endX, endY]\n                ] as Point[];\n                curve = [...curve, ...line];\n            } else {\n                curve = [\n                    [beginX, beginY + 12],\n                    [beginX, beginY + (beginNode.vGap + endNode.vGap) / 2],\n                    [endX, endY - (beginNode.vGap + endNode.vGap) / 2],\n                    [endX, endY]\n                ];\n                const line = [\n                    [beginX, beginY],\n                    [beginX, beginY + 12],\n                    [beginX, beginY + 12]\n                ] as Point[];\n\n                curve = [...line, ...curve];\n            }\n        }\n        const points = pointsOnBezierCurves(curve);\n        return roughSVG.curve(points as any, { stroke, strokeWidth });\n    }\n}\n"]}
|
|
159
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"link.js","sourceRoot":"","sources":["../../../../packages/mind/src/draw/link.ts"],"names":[],"mappings":"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","sourcesContent":["import { pointsOnBezierCurves } from 'points-on-curve';\nimport { MindNodeShape, STROKE_WIDTH } from '../constants';\nimport { MindNode } from '../interfaces/node';\nimport { PlaitBoard, Point } from '@plait/core';\nimport { getNodeShapeByElement, isChildRight } from '../utils';\nimport { MindLayoutType, isTopLayout, isIndentedLayout, isStandardLayout } from '@plait/layouts';\nimport { MindQueries } from '../queries';\nimport { getBranchColorByMindElement } from '../utils/node-style/branch';\n\nexport function drawLink(\n    board: PlaitBoard,\n    node: MindNode,\n    child: MindNode,\n    defaultStroke: string | null = null,\n    isHorizontal = true,\n    needDrawUnderline = true\n) {\n    let beginX,\n        beginY,\n        endX,\n        endY,\n        beginNode = node,\n        endNode = child;\n    const layout = MindQueries.getCorrectLayoutByElement(node.origin) as MindLayoutType;\n    if (isHorizontal) {\n        if (!isChildRight(node, child)) {\n            beginNode = child;\n            endNode = node;\n        }\n        beginX = beginNode.x + beginNode.width - beginNode.hGap;\n        beginY = beginNode.y + beginNode.height / 2;\n        endX = endNode.x + endNode.hGap;\n        endY = endNode.y + endNode.height / 2;\n\n        if (\n            node.parent &&\n            isIndentedLayout(MindQueries.getLayoutByElement(node.parent?.origin)) &&\n            (getNodeShapeByElement(node.origin) as MindNodeShape) === MindNodeShape.underline\n        ) {\n            if (isChildRight(node, child)) {\n                beginY = node.y + node.height - node.vGap;\n            } else {\n                endY = node.y + node.height - node.vGap;\n            }\n        }\n    } else {\n        if (node.y > child.y) {\n            beginNode = child;\n            endNode = node;\n        }\n        beginX = beginNode.x + beginNode.width / 2;\n        beginY = beginNode.y + beginNode.height - beginNode.vGap;\n        endX = endNode.x + endNode.width / 2;\n        endY = endNode.y + endNode.vGap;\n    }\n\n    const stroke = defaultStroke || getBranchColorByMindElement(board, child.origin);\n    const strokeWidth = child.origin.branchWidth ? child.origin.branchWidth : STROKE_WIDTH;\n    if (endNode.origin.isRoot) {\n        if (layout === MindLayoutType.left || isStandardLayout(layout)) {\n            endX -= strokeWidth;\n        }\n        if (layout === MindLayoutType.upward) {\n            endY -= strokeWidth;\n        }\n    }\n    if (beginNode.origin.isRoot) {\n        if (layout === MindLayoutType.right || isStandardLayout(layout)) {\n            beginX += strokeWidth;\n        }\n        if (layout === MindLayoutType.downward) {\n            beginY += strokeWidth;\n        }\n    }\n    if (isHorizontal) {\n        let curve: Point[] = [\n            [beginX, beginY],\n            [beginX + (beginNode.hGap + endNode.hGap) / 3, beginY],\n            [endX - (beginNode.hGap + endNode.hGap) / 2, endY],\n            [endX, endY]\n        ];\n        const shape = getNodeShapeByElement(child.origin) as MindNodeShape;\n\n        if (!node.origin.isRoot) {\n            if (node.x > child.x) {\n                curve = [\n                    [beginX, beginY],\n                    [beginX + (beginNode.hGap + endNode.hGap) / 3, beginY],\n                    [endX - (beginNode.hGap + endNode.hGap) / 2, endY],\n                    [endX - 12, endY]\n                ];\n                const line = [\n                    [endX - 12, endY],\n                    [endX - 12, endY],\n                    [endX, endY]\n                ] as Point[];\n                curve = [...curve, ...line];\n            } else {\n                curve = [\n                    [beginX + 12, beginY],\n                    [beginX + (beginNode.hGap + endNode.hGap) / 2, beginY],\n                    [endX - (beginNode.hGap + endNode.hGap) / 3, endY],\n                    [endX, endY]\n                ];\n                const line = [\n                    [beginX, beginY],\n                    [beginX + 12, beginY],\n                    [beginX + 12, beginY]\n                ] as Point[];\n                curve = [...line, ...curve];\n            }\n        }\n\n        if (needDrawUnderline && shape === MindNodeShape.underline) {\n            if (child.left) {\n                const underline = [\n                    [beginX - (beginNode.width - beginNode.hGap * 2), beginY],\n                    [beginX - (beginNode.width - beginNode.hGap * 2), beginY],\n                    [beginX - (beginNode.width - beginNode.hGap * 2), beginY]\n                ] as Point[];\n                curve = [...underline, ...curve];\n            } else {\n                const underline = [\n                    [endX + (endNode.width - endNode.hGap * 2), endY],\n                    [endX + (endNode.width - endNode.hGap * 2), endY],\n                    [endX + (endNode.width - endNode.hGap * 2), endY]\n                ] as Point[];\n                curve = [...curve, ...underline];\n            }\n        }\n\n        const points = pointsOnBezierCurves(curve);\n        return PlaitBoard.getRoughSVG(board).curve(points as any, { stroke, strokeWidth });\n    } else {\n        let curve: Point[] = [\n            [beginX, beginY],\n            [beginX, beginY + (beginNode.vGap + endNode.vGap) / 2],\n            [endX, endY - (beginNode.vGap + endNode.vGap) / 2],\n            [endX, endY]\n        ];\n\n        if (!node.origin.isRoot) {\n            if (isTopLayout(layout)) {\n                curve = [\n                    [beginX, beginY],\n                    [beginX, beginY + (beginNode.vGap + endNode.vGap) / 2],\n                    [endX, endY - (beginNode.vGap + endNode.vGap) / 2],\n                    [endX, endY - 12]\n                ];\n\n                const line = [\n                    [endX, endY - 12],\n                    [endX, endY - 12],\n                    [endX, endY]\n                ] as Point[];\n                curve = [...curve, ...line];\n            } else {\n                curve = [\n                    [beginX, beginY + 12],\n                    [beginX, beginY + (beginNode.vGap + endNode.vGap) / 2],\n                    [endX, endY - (beginNode.vGap + endNode.vGap) / 2],\n                    [endX, endY]\n                ];\n                const line = [\n                    [beginX, beginY],\n                    [beginX, beginY + 12],\n                    [beginX, beginY + 12]\n                ] as Point[];\n\n                curve = [...line, ...curve];\n            }\n        }\n        const points = pointsOnBezierCurves(curve);\n        return PlaitBoard.getRoughSVG(board).curve(points as any, { stroke, strokeWidth });\n    }\n}\n"]}
|
package/esm2020/draw/shape.mjs
CHANGED
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
import { NODE_FILL, ROOT_NODE_FILL, STROKE_WIDTH } from '../constants';
|
|
2
|
-
import { getStrokeByMindElement } from '../utils/colors';
|
|
3
2
|
import { getRectangleByNode } from '../utils/graph';
|
|
4
3
|
import { PlaitBoard, drawRoundRectangle } from '@plait/core';
|
|
4
|
+
import { getStrokeByMindElement } from '../utils/node-style/node';
|
|
5
5
|
export function drawRectangleNode(board, node) {
|
|
6
6
|
const { x, y, width, height } = getRectangleByNode(node);
|
|
7
7
|
const fill = node.origin.fill ? node.origin.fill : node.origin.isRoot ? ROOT_NODE_FILL : NODE_FILL;
|
|
8
|
-
const stroke = getStrokeByMindElement(node.origin);
|
|
8
|
+
const stroke = getStrokeByMindElement(board, node.origin);
|
|
9
9
|
const strokeWidth = node.origin.strokeWidth ? node.origin.strokeWidth : STROKE_WIDTH;
|
|
10
10
|
const nodeG = drawRoundRectangle(PlaitBoard.getRoughSVG(board), x, y, x + width, y + height, {
|
|
11
11
|
stroke,
|
|
@@ -15,4 +15,4 @@ export function drawRectangleNode(board, node) {
|
|
|
15
15
|
});
|
|
16
16
|
return nodeG;
|
|
17
17
|
}
|
|
18
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2hhcGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9taW5kL3NyYy9kcmF3L3NoYXBlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsY0FBYyxFQUFFLFlBQVksRUFBRSxNQUFNLGNBQWMsQ0FBQztBQUV2RSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUNwRCxPQUFPLEVBQUUsVUFBVSxFQUFFLGtCQUFrQixFQUFFLE1BQU0sYUFBYSxDQUFDO0FBQzdELE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBRWxFLE1BQU0sVUFBVSxpQkFBaUIsQ0FBQyxLQUFpQixFQUFFLElBQWM7SUFDL0QsTUFBTSxFQUFFLENBQUMsRUFBRSxDQUFDLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxHQUFHLGtCQUFrQixDQUFDLElBQUksQ0FBQyxDQUFDO0lBRXpELE1BQU0sSUFBSSxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLGNBQWMsQ0FBQyxDQUFDLENBQUMsU0FBUyxDQUFDO0lBQ25HLE1BQU0sTUFBTSxHQUFHLHNCQUFzQixDQUFDLEtBQUssRUFBRSxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDMUQsTUFBTSxXQUFXLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxXQUFXLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsV0FBVyxDQUFDLENBQUMsQ0FBQyxZQUFZLENBQUM7SUFFckYsTUFBTSxLQUFLLEdBQUcsa0JBQWtCLENBQUMsVUFBVSxDQUFDLFdBQVcsQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsR0FBRyxLQUFLLEVBQUUsQ0FBQyxHQUFHLE1BQU0sRUFBRTtRQUN6RixNQUFNO1FBQ04sV0FBVztRQUNYLElBQUk7UUFDSixTQUFTLEVBQUUsT0FBTztLQUNyQixDQUFDLENBQUM7SUFFSCxPQUFPLEtBQUssQ0FBQztBQUNqQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTk9ERV9GSUxMLCBST09UX05PREVfRklMTCwgU1RST0tFX1dJRFRIIH0gZnJvbSAnLi4vY29uc3RhbnRzJztcbmltcG9ydCB7IE1pbmROb2RlIH0gZnJvbSAnLi4vaW50ZXJmYWNlcy9ub2RlJztcbmltcG9ydCB7IGdldFJlY3RhbmdsZUJ5Tm9kZSB9IGZyb20gJy4uL3V0aWxzL2dyYXBoJztcbmltcG9ydCB7IFBsYWl0Qm9hcmQsIGRyYXdSb3VuZFJlY3RhbmdsZSB9IGZyb20gJ0BwbGFpdC9jb3JlJztcbmltcG9ydCB7IGdldFN0cm9rZUJ5TWluZEVsZW1lbnQgfSBmcm9tICcuLi91dGlscy9ub2RlLXN0eWxlL25vZGUnO1xuXG5leHBvcnQgZnVuY3Rpb24gZHJhd1JlY3RhbmdsZU5vZGUoYm9hcmQ6IFBsYWl0Qm9hcmQsIG5vZGU6IE1pbmROb2RlKSB7XG4gICAgY29uc3QgeyB4LCB5LCB3aWR0aCwgaGVpZ2h0IH0gPSBnZXRSZWN0YW5nbGVCeU5vZGUobm9kZSk7XG5cbiAgICBjb25zdCBmaWxsID0gbm9kZS5vcmlnaW4uZmlsbCA/IG5vZGUub3JpZ2luLmZpbGwgOiBub2RlLm9yaWdpbi5pc1Jvb3QgPyBST09UX05PREVfRklMTCA6IE5PREVfRklMTDtcbiAgICBjb25zdCBzdHJva2UgPSBnZXRTdHJva2VCeU1pbmRFbGVtZW50KGJvYXJkLCBub2RlLm9yaWdpbik7XG4gICAgY29uc3Qgc3Ryb2tlV2lkdGggPSBub2RlLm9yaWdpbi5zdHJva2VXaWR0aCA/IG5vZGUub3JpZ2luLnN0cm9rZVdpZHRoIDogU1RST0tFX1dJRFRIO1xuXG4gICAgY29uc3Qgbm9kZUcgPSBkcmF3Um91bmRSZWN0YW5nbGUoUGxhaXRCb2FyZC5nZXRSb3VnaFNWRyhib2FyZCksIHgsIHksIHggKyB3aWR0aCwgeSArIGhlaWdodCwge1xuICAgICAgICBzdHJva2UsXG4gICAgICAgIHN0cm9rZVdpZHRoLFxuICAgICAgICBmaWxsLFxuICAgICAgICBmaWxsU3R5bGU6ICdzb2xpZCdcbiAgICB9KTtcblxuICAgIHJldHVybiBub2RlRztcbn1cbiJdfQ==
|
|
@@ -1,16 +1,17 @@
|
|
|
1
1
|
import { PlaitBoard, createG } from '@plait/core';
|
|
2
|
-
import { MindElement } from '../interfaces';
|
|
2
|
+
import { MindElement, PlaitMind } from '../interfaces';
|
|
3
3
|
import { BaseDrawer } from './base/base';
|
|
4
4
|
import { getRectangleByNode } from '../utils/graph';
|
|
5
5
|
import { getNodeShapeByElement } from '../utils/shape';
|
|
6
6
|
import { EXTEND_RADIUS, QUICK_INSERT_CIRCLE_COLOR, QUICK_INSERT_CIRCLE_OFFSET, QUICK_INSERT_INNER_CROSS_COLOR, STROKE_WIDTH } from '../constants/default';
|
|
7
7
|
import { MindNodeShape } from '../constants/node';
|
|
8
|
-
import {
|
|
9
|
-
import { getLinkLineColorByMindElement, getRootLinkLineColorByMindElement } from '../utils/colors';
|
|
8
|
+
import { MindLayoutType, isStandardLayout } from '@plait/layouts';
|
|
10
9
|
import { MindQueries } from '../queries';
|
|
11
10
|
import { fromEvent } from 'rxjs';
|
|
12
11
|
import { insertMindElement } from '../utils/mind';
|
|
13
12
|
import { take } from 'rxjs/operators';
|
|
13
|
+
import { findNewChildNodePath } from '../utils/path';
|
|
14
|
+
import { getBranchColorByMindElement, getNextBranchColor } from '../utils/node-style/branch';
|
|
14
15
|
export class QuickInsertDrawer extends BaseDrawer {
|
|
15
16
|
canDraw(element) {
|
|
16
17
|
if (PlaitBoard.isReadonly(this.board) || element?.isCollapsed) {
|
|
@@ -34,7 +35,7 @@ export class QuickInsertDrawer extends BaseDrawer {
|
|
|
34
35
|
*/
|
|
35
36
|
const shape = getNodeShapeByElement(element);
|
|
36
37
|
// 形状是矩形要偏移边框的线宽
|
|
37
|
-
const strokeWidth = element.
|
|
38
|
+
const strokeWidth = element.branchWidth ? element.branchWidth : STROKE_WIDTH;
|
|
38
39
|
let offsetBorderLineWidth = 0;
|
|
39
40
|
if (shape === MindNodeShape.roundRectangle && offset === 0) {
|
|
40
41
|
offsetBorderLineWidth = strokeWidth;
|
|
@@ -142,7 +143,7 @@ export class QuickInsertDrawer extends BaseDrawer {
|
|
|
142
143
|
underlineCoordinates[MindLayoutType.right].startY -= height * 0.5;
|
|
143
144
|
underlineCoordinates[MindLayoutType.right].endY -= height * 0.5;
|
|
144
145
|
}
|
|
145
|
-
const
|
|
146
|
+
const branchColor = PlaitMind.isMind(element) ? getNextBranchColor(element) : getBranchColorByMindElement(this.board, element);
|
|
146
147
|
let nodeLayout = MindQueries.getCorrectLayoutByElement(element);
|
|
147
148
|
if (element.isRoot && isStandardLayout(nodeLayout)) {
|
|
148
149
|
const root = element;
|
|
@@ -150,7 +151,7 @@ export class QuickInsertDrawer extends BaseDrawer {
|
|
|
150
151
|
}
|
|
151
152
|
const underlineCoordinate = underlineCoordinates[nodeLayout];
|
|
152
153
|
if (underlineCoordinate) {
|
|
153
|
-
const underline = PlaitBoard.getRoughSVG(this.board).line(underlineCoordinate.startX, underlineCoordinate.startY, underlineCoordinate.endX, underlineCoordinate.endY, { stroke, strokeWidth });
|
|
154
|
+
const underline = PlaitBoard.getRoughSVG(this.board).line(underlineCoordinate.startX, underlineCoordinate.startY, underlineCoordinate.endX, underlineCoordinate.endY, { stroke: branchColor, strokeWidth });
|
|
154
155
|
const circleCoordinates = {
|
|
155
156
|
startX: underlineCoordinate.endX,
|
|
156
157
|
startY: underlineCoordinate.endY
|
|
@@ -201,9 +202,9 @@ export class QuickInsertDrawer extends BaseDrawer {
|
|
|
201
202
|
fromEvent(this.g, 'mouseup')
|
|
202
203
|
.pipe(take(1))
|
|
203
204
|
.subscribe(() => {
|
|
204
|
-
const path =
|
|
205
|
+
const path = findNewChildNodePath(this.board, element);
|
|
205
206
|
insertMindElement(this.board, element, path);
|
|
206
207
|
});
|
|
207
208
|
}
|
|
208
209
|
}
|
|
209
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"quick-insert.drawer.js","sourceRoot":"","sources":["../../../../packages/mind/src/drawer/quick-insert.drawer.ts"],"names":[],"mappings":"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","sourcesContent":["import { PlaitBoard, createG } from '@plait/core';\nimport { MindElement, BaseData, ExtendUnderlineCoordinateType, ExtendLayoutType } from '../interfaces';\nimport { AfterDraw, BaseDrawer } from './base/base';\nimport { getRectangleByNode } from '../utils/graph';\nimport { getNodeShapeByElement } from '../utils/shape';\nimport {\n    EXTEND_RADIUS,\n    QUICK_INSERT_CIRCLE_COLOR,\n    QUICK_INSERT_CIRCLE_OFFSET,\n    QUICK_INSERT_INNER_CROSS_COLOR,\n    STROKE_WIDTH\n} from '../constants/default';\nimport { MindNodeShape } from '../constants/node';\nimport { AbstractNode, MindLayoutType, OriginNode, isStandardLayout } from '@plait/layouts';\nimport { getLinkLineColorByMindElement, getRootLinkLineColorByMindElement } from '../utils/colors';\nimport { MindQueries } from '../queries';\nimport { fromEvent } from 'rxjs';\nimport { insertMindElement } from '../utils/mind';\nimport { take } from 'rxjs/operators';\n\nexport class QuickInsertDrawer extends BaseDrawer implements AfterDraw {\n    canDraw(element: MindElement<BaseData>): boolean {\n        if (PlaitBoard.isReadonly(this.board) || element?.isCollapsed) {\n            return false;\n        }\n        return true;\n    }\n    draw(element: MindElement<BaseData>): SVGGElement {\n        let offset = element.children.length > 0 && !element.isRoot ? EXTEND_RADIUS : 0;\n        const quickInsertG = createG();\n        this.g = quickInsertG;\n        quickInsertG.classList.add('quick-insert');\n        const node = MindElement.getNode(element);\n        const { x, y, width, height } = getRectangleByNode(node);\n\n        /**\n         * 方位：\n         *    1. 左、左上、左下\n         *    2. 右、右上、右下\n         *    3. 上、上左、上右\n         *    4. 下、下左、下右\n         */\n        const shape = getNodeShapeByElement(element);\n        // 形状是矩形要偏移边框的线宽\n        const strokeWidth = element.linkLineWidth ? element.linkLineWidth : STROKE_WIDTH;\n        let offsetBorderLineWidth = 0;\n        if (shape === MindNodeShape.roundRectangle && offset === 0) {\n            offsetBorderLineWidth = strokeWidth;\n        }\n        let offsetRootBorderLineWidth = 0;\n        if (element.isRoot) {\n            offsetRootBorderLineWidth = strokeWidth;\n        }\n        // 当没有子节点时，需要缩小的偏移量\n        const extraOffset = 3;\n        const underlineCoordinates: ExtendUnderlineCoordinateType = {\n            // 画线方向：右向左 <--\n            [MindLayoutType.left]: {\n                // EXTEND_RADIUS * 0.5 是 左方向，折叠/收起的偏移量\n                startX: x - (offset > 0 ? offset + EXTEND_RADIUS * 0.5 : 0) - offsetRootBorderLineWidth,\n                startY: y + height,\n                endX:\n                    x -\n                    offsetBorderLineWidth -\n                    offsetRootBorderLineWidth -\n                    (offset > 0 ? offset + QUICK_INSERT_CIRCLE_OFFSET - extraOffset : 0) -\n                    EXTEND_RADIUS,\n                endY: y + height\n            },\n            // 画线方向：左向右 -->\n            [MindLayoutType.right]: {\n                startX: x + width + (offset > 0 ? offset + QUICK_INSERT_CIRCLE_OFFSET : 0) + offsetRootBorderLineWidth,\n                startY: y + height,\n                endX:\n                    x +\n                    width +\n                    offsetBorderLineWidth +\n                    (offset > 0 ? offset + QUICK_INSERT_CIRCLE_OFFSET - extraOffset : 0) +\n                    EXTEND_RADIUS +\n                    offsetRootBorderLineWidth,\n                endY: y + height\n            },\n            // 画线方向：下向上 -->\n            [MindLayoutType.upward]: {\n                startX: x + width * 0.5,\n                startY: y - offsetBorderLineWidth - (offset > 0 ? offset + QUICK_INSERT_CIRCLE_OFFSET : 0) - offsetRootBorderLineWidth,\n                endX: x + width * 0.5,\n                endY:\n                    y -\n                    offsetBorderLineWidth -\n                    (offset > 0 ? offset + QUICK_INSERT_CIRCLE_OFFSET - extraOffset : 0) -\n                    EXTEND_RADIUS -\n                    offsetRootBorderLineWidth\n            },\n            // 画线方向：上向下 -->\n            [MindLayoutType.downward]: {\n                startX: x + width * 0.5,\n                startY:\n                    y + height + offsetBorderLineWidth + (offset > 0 ? offset + QUICK_INSERT_CIRCLE_OFFSET : 0) + offsetRootBorderLineWidth,\n                endX: x + width * 0.5,\n                endY:\n                    y +\n                    height +\n                    offsetBorderLineWidth +\n                    (offset > 0 ? offset + QUICK_INSERT_CIRCLE_OFFSET - extraOffset : 0) +\n                    EXTEND_RADIUS +\n                    offsetRootBorderLineWidth\n            },\n            [MindLayoutType.leftBottomIndented]: {\n                startX: x + width * 0.5,\n                startY:\n                    y + height + offsetBorderLineWidth + (offset > 0 ? offset + QUICK_INSERT_CIRCLE_OFFSET : 0) + offsetRootBorderLineWidth,\n                endX: x + width * 0.5,\n                endY:\n                    y +\n                    height +\n                    offsetBorderLineWidth +\n                    (offset > 0 ? offset + QUICK_INSERT_CIRCLE_OFFSET - extraOffset : 0) +\n                    EXTEND_RADIUS +\n                    offsetRootBorderLineWidth\n            },\n            [MindLayoutType.leftTopIndented]: {\n                startX: x + width * 0.5,\n                startY: y - offsetBorderLineWidth - (offset > 0 ? offset + QUICK_INSERT_CIRCLE_OFFSET : 0) - offsetRootBorderLineWidth,\n                endX: x + width * 0.5,\n                endY:\n                    y -\n                    offsetBorderLineWidth -\n                    (offset > 0 ? offset + QUICK_INSERT_CIRCLE_OFFSET : 0) -\n                    EXTEND_RADIUS -\n                    offsetRootBorderLineWidth\n            },\n            [MindLayoutType.rightBottomIndented]: {\n                startX: x + width * 0.5,\n                startY:\n                    y + height + offsetBorderLineWidth + (offset > 0 ? offset + QUICK_INSERT_CIRCLE_OFFSET : 0) + offsetRootBorderLineWidth,\n                endX: x + width * 0.5,\n                endY:\n                    y +\n                    height +\n                    offsetBorderLineWidth +\n                    (offset > 0 ? offset + QUICK_INSERT_CIRCLE_OFFSET - extraOffset : 0) +\n                    EXTEND_RADIUS +\n                    offsetRootBorderLineWidth\n            },\n            [MindLayoutType.rightTopIndented]: {\n                startX: x + width * 0.5,\n                startY: y - offsetBorderLineWidth - (offset > 0 ? offset + QUICK_INSERT_CIRCLE_OFFSET : 0) - offsetRootBorderLineWidth,\n                endX: x + width * 0.5,\n                endY:\n                    y -\n                    offsetBorderLineWidth -\n                    (offset > 0 ? offset + QUICK_INSERT_CIRCLE_OFFSET : 0) -\n                    EXTEND_RADIUS -\n                    offsetRootBorderLineWidth\n            }\n        };\n        if (shape === MindNodeShape.roundRectangle || element.isRoot) {\n            underlineCoordinates[MindLayoutType.left].startY -= height * 0.5;\n            underlineCoordinates[MindLayoutType.left].endY -= height * 0.5;\n            underlineCoordinates[MindLayoutType.right].startY -= height * 0.5;\n            underlineCoordinates[MindLayoutType.right].endY -= height * 0.5;\n        }\n        const stroke = element.isRoot ? getRootLinkLineColorByMindElement(element) : getLinkLineColorByMindElement(element);\n        let nodeLayout = MindQueries.getCorrectLayoutByElement(element) as ExtendLayoutType;\n        if (element.isRoot && isStandardLayout(nodeLayout)) {\n            const root = element as OriginNode;\n            nodeLayout = root.children.length >= root.rightNodeCount ? MindLayoutType.left : MindLayoutType.right;\n        }\n        const underlineCoordinate = underlineCoordinates[nodeLayout];\n        if (underlineCoordinate) {\n            const underline = PlaitBoard.getRoughSVG(this.board).line(\n                underlineCoordinate.startX,\n                underlineCoordinate.startY,\n                underlineCoordinate.endX,\n                underlineCoordinate.endY,\n                { stroke, strokeWidth }\n            );\n            const circleCoordinates = {\n                startX: underlineCoordinate.endX,\n                startY: underlineCoordinate.endY\n            };\n            const circle = PlaitBoard.getRoughSVG(this.board).circle(circleCoordinates.startX, circleCoordinates.startY, EXTEND_RADIUS, {\n                fill: QUICK_INSERT_CIRCLE_COLOR,\n                stroke: QUICK_INSERT_CIRCLE_COLOR,\n                fillStyle: 'solid'\n            });\n            const innerCrossCoordinates = {\n                horizontal: {\n                    startX: circleCoordinates.startX - EXTEND_RADIUS * 0.5 + 3,\n                    startY: circleCoordinates.startY,\n                    endX: circleCoordinates.startX + EXTEND_RADIUS * 0.5 - 3,\n                    endY: circleCoordinates.startY\n                },\n                vertical: {\n                    startX: circleCoordinates.startX,\n                    startY: circleCoordinates.startY - EXTEND_RADIUS * 0.5 + 3,\n                    endX: circleCoordinates.startX,\n                    endY: circleCoordinates.startY + EXTEND_RADIUS * 0.5 - 3\n                }\n            };\n            const innerCrossHLine = PlaitBoard.getRoughSVG(this.board).line(\n                innerCrossCoordinates.horizontal.startX,\n                innerCrossCoordinates.horizontal.startY,\n                innerCrossCoordinates.horizontal.endX,\n                innerCrossCoordinates.horizontal.endY,\n                {\n                    stroke: QUICK_INSERT_INNER_CROSS_COLOR,\n                    strokeWidth: 2\n                }\n            );\n            const innerRingVLine = PlaitBoard.getRoughSVG(this.board).line(\n                innerCrossCoordinates.vertical.startX,\n                innerCrossCoordinates.vertical.startY,\n                innerCrossCoordinates.vertical.endX,\n                innerCrossCoordinates.vertical.endY,\n                {\n                    stroke: QUICK_INSERT_INNER_CROSS_COLOR,\n                    strokeWidth: 2\n                }\n            );\n            quickInsertG.appendChild(underline);\n            quickInsertG.appendChild(circle);\n            quickInsertG.appendChild(innerCrossHLine);\n            quickInsertG.appendChild(innerRingVLine);\n        }\n        return quickInsertG;\n    }\n    afterDraw(element: MindElement): void {\n        if (!this.g) {\n            throw new Error(`can not find quick insert g`);\n        }\n        fromEvent<MouseEvent>(this.g, 'mousedown')\n            .pipe(take(1))\n            .subscribe(e => {\n                e.stopPropagation();\n            });\n        fromEvent(this.g, 'mouseup')\n            .pipe(take(1))\n            .subscribe(() => {\n                const path = PlaitBoard.findPath(this.board, element).concat(\n                    element.children.filter(child => !AbstractNode.isAbstract(child)).length\n                );\n                insertMindElement(this.board, element, path);\n            });\n    }\n}\n"]}
|
|
210
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"quick-insert.drawer.js","sourceRoot":"","sources":["../../../../packages/mind/src/drawer/quick-insert.drawer.ts"],"names":[],"mappings":"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","sourcesContent":["import { PlaitBoard, createG } from '@plait/core';\nimport { MindElement, BaseData, ExtendUnderlineCoordinateType, ExtendLayoutType, PlaitMind } from '../interfaces';\nimport { AfterDraw, BaseDrawer } from './base/base';\nimport { getRectangleByNode } from '../utils/graph';\nimport { getNodeShapeByElement } from '../utils/shape';\nimport {\n    EXTEND_RADIUS,\n    QUICK_INSERT_CIRCLE_COLOR,\n    QUICK_INSERT_CIRCLE_OFFSET,\n    QUICK_INSERT_INNER_CROSS_COLOR,\n    STROKE_WIDTH\n} from '../constants/default';\nimport { MindNodeShape } from '../constants/node';\nimport { MindLayoutType, OriginNode, isStandardLayout } from '@plait/layouts';\nimport { MindQueries } from '../queries';\nimport { fromEvent } from 'rxjs';\nimport { insertMindElement } from '../utils/mind';\nimport { take } from 'rxjs/operators';\nimport { findNewChildNodePath } from '../utils/path';\nimport { getBranchColorByMindElement, getNextBranchColor } from '../utils/node-style/branch';\n\nexport class QuickInsertDrawer extends BaseDrawer implements AfterDraw {\n    canDraw(element: MindElement<BaseData>): boolean {\n        if (PlaitBoard.isReadonly(this.board) || element?.isCollapsed) {\n            return false;\n        }\n        return true;\n    }\n    draw(element: MindElement<BaseData>): SVGGElement {\n        let offset = element.children.length > 0 && !element.isRoot ? EXTEND_RADIUS : 0;\n        const quickInsertG = createG();\n        this.g = quickInsertG;\n        quickInsertG.classList.add('quick-insert');\n        const node = MindElement.getNode(element);\n        const { x, y, width, height } = getRectangleByNode(node);\n\n        /**\n         * 方位：\n         *    1. 左、左上、左下\n         *    2. 右、右上、右下\n         *    3. 上、上左、上右\n         *    4. 下、下左、下右\n         */\n        const shape = getNodeShapeByElement(element);\n        // 形状是矩形要偏移边框的线宽\n        const strokeWidth = element.branchWidth ? element.branchWidth : STROKE_WIDTH;\n        let offsetBorderLineWidth = 0;\n        if (shape === MindNodeShape.roundRectangle && offset === 0) {\n            offsetBorderLineWidth = strokeWidth;\n        }\n        let offsetRootBorderLineWidth = 0;\n        if (element.isRoot) {\n            offsetRootBorderLineWidth = strokeWidth;\n        }\n        // 当没有子节点时，需要缩小的偏移量\n        const extraOffset = 3;\n        const underlineCoordinates: ExtendUnderlineCoordinateType = {\n            // 画线方向：右向左 <--\n            [MindLayoutType.left]: {\n                // EXTEND_RADIUS * 0.5 是 左方向，折叠/收起的偏移量\n                startX: x - (offset > 0 ? offset + EXTEND_RADIUS * 0.5 : 0) - offsetRootBorderLineWidth,\n                startY: y + height,\n                endX:\n                    x -\n                    offsetBorderLineWidth -\n                    offsetRootBorderLineWidth -\n                    (offset > 0 ? offset + QUICK_INSERT_CIRCLE_OFFSET - extraOffset : 0) -\n                    EXTEND_RADIUS,\n                endY: y + height\n            },\n            // 画线方向：左向右 -->\n            [MindLayoutType.right]: {\n                startX: x + width + (offset > 0 ? offset + QUICK_INSERT_CIRCLE_OFFSET : 0) + offsetRootBorderLineWidth,\n                startY: y + height,\n                endX:\n                    x +\n                    width +\n                    offsetBorderLineWidth +\n                    (offset > 0 ? offset + QUICK_INSERT_CIRCLE_OFFSET - extraOffset : 0) +\n                    EXTEND_RADIUS +\n                    offsetRootBorderLineWidth,\n                endY: y + height\n            },\n            // 画线方向：下向上 -->\n            [MindLayoutType.upward]: {\n                startX: x + width * 0.5,\n                startY: y - offsetBorderLineWidth - (offset > 0 ? offset + QUICK_INSERT_CIRCLE_OFFSET : 0) - offsetRootBorderLineWidth,\n                endX: x + width * 0.5,\n                endY:\n                    y -\n                    offsetBorderLineWidth -\n                    (offset > 0 ? offset + QUICK_INSERT_CIRCLE_OFFSET - extraOffset : 0) -\n                    EXTEND_RADIUS -\n                    offsetRootBorderLineWidth\n            },\n            // 画线方向：上向下 -->\n            [MindLayoutType.downward]: {\n                startX: x + width * 0.5,\n                startY:\n                    y + height + offsetBorderLineWidth + (offset > 0 ? offset + QUICK_INSERT_CIRCLE_OFFSET : 0) + offsetRootBorderLineWidth,\n                endX: x + width * 0.5,\n                endY:\n                    y +\n                    height +\n                    offsetBorderLineWidth +\n                    (offset > 0 ? offset + QUICK_INSERT_CIRCLE_OFFSET - extraOffset : 0) +\n                    EXTEND_RADIUS +\n                    offsetRootBorderLineWidth\n            },\n            [MindLayoutType.leftBottomIndented]: {\n                startX: x + width * 0.5,\n                startY:\n                    y + height + offsetBorderLineWidth + (offset > 0 ? offset + QUICK_INSERT_CIRCLE_OFFSET : 0) + offsetRootBorderLineWidth,\n                endX: x + width * 0.5,\n                endY:\n                    y +\n                    height +\n                    offsetBorderLineWidth +\n                    (offset > 0 ? offset + QUICK_INSERT_CIRCLE_OFFSET - extraOffset : 0) +\n                    EXTEND_RADIUS +\n                    offsetRootBorderLineWidth\n            },\n            [MindLayoutType.leftTopIndented]: {\n                startX: x + width * 0.5,\n                startY: y - offsetBorderLineWidth - (offset > 0 ? offset + QUICK_INSERT_CIRCLE_OFFSET : 0) - offsetRootBorderLineWidth,\n                endX: x + width * 0.5,\n                endY:\n                    y -\n                    offsetBorderLineWidth -\n                    (offset > 0 ? offset + QUICK_INSERT_CIRCLE_OFFSET : 0) -\n                    EXTEND_RADIUS -\n                    offsetRootBorderLineWidth\n            },\n            [MindLayoutType.rightBottomIndented]: {\n                startX: x + width * 0.5,\n                startY:\n                    y + height + offsetBorderLineWidth + (offset > 0 ? offset + QUICK_INSERT_CIRCLE_OFFSET : 0) + offsetRootBorderLineWidth,\n                endX: x + width * 0.5,\n                endY:\n                    y +\n                    height +\n                    offsetBorderLineWidth +\n                    (offset > 0 ? offset + QUICK_INSERT_CIRCLE_OFFSET - extraOffset : 0) +\n                    EXTEND_RADIUS +\n                    offsetRootBorderLineWidth\n            },\n            [MindLayoutType.rightTopIndented]: {\n                startX: x + width * 0.5,\n                startY: y - offsetBorderLineWidth - (offset > 0 ? offset + QUICK_INSERT_CIRCLE_OFFSET : 0) - offsetRootBorderLineWidth,\n                endX: x + width * 0.5,\n                endY:\n                    y -\n                    offsetBorderLineWidth -\n                    (offset > 0 ? offset + QUICK_INSERT_CIRCLE_OFFSET : 0) -\n                    EXTEND_RADIUS -\n                    offsetRootBorderLineWidth\n            }\n        };\n        if (shape === MindNodeShape.roundRectangle || element.isRoot) {\n            underlineCoordinates[MindLayoutType.left].startY -= height * 0.5;\n            underlineCoordinates[MindLayoutType.left].endY -= height * 0.5;\n            underlineCoordinates[MindLayoutType.right].startY -= height * 0.5;\n            underlineCoordinates[MindLayoutType.right].endY -= height * 0.5;\n        }\n        const branchColor = PlaitMind.isMind(element) ? getNextBranchColor(element) : getBranchColorByMindElement(this.board, element);\n        let nodeLayout = MindQueries.getCorrectLayoutByElement(element) as ExtendLayoutType;\n        if (element.isRoot && isStandardLayout(nodeLayout)) {\n            const root = element as OriginNode;\n            nodeLayout = root.children.length >= root.rightNodeCount ? MindLayoutType.left : MindLayoutType.right;\n        }\n        const underlineCoordinate = underlineCoordinates[nodeLayout];\n        if (underlineCoordinate) {\n            const underline = PlaitBoard.getRoughSVG(this.board).line(\n                underlineCoordinate.startX,\n                underlineCoordinate.startY,\n                underlineCoordinate.endX,\n                underlineCoordinate.endY,\n                { stroke: branchColor, strokeWidth }\n            );\n            const circleCoordinates = {\n                startX: underlineCoordinate.endX,\n                startY: underlineCoordinate.endY\n            };\n            const circle = PlaitBoard.getRoughSVG(this.board).circle(circleCoordinates.startX, circleCoordinates.startY, EXTEND_RADIUS, {\n                fill: QUICK_INSERT_CIRCLE_COLOR,\n                stroke: QUICK_INSERT_CIRCLE_COLOR,\n                fillStyle: 'solid'\n            });\n            const innerCrossCoordinates = {\n                horizontal: {\n                    startX: circleCoordinates.startX - EXTEND_RADIUS * 0.5 + 3,\n                    startY: circleCoordinates.startY,\n                    endX: circleCoordinates.startX + EXTEND_RADIUS * 0.5 - 3,\n                    endY: circleCoordinates.startY\n                },\n                vertical: {\n                    startX: circleCoordinates.startX,\n                    startY: circleCoordinates.startY - EXTEND_RADIUS * 0.5 + 3,\n                    endX: circleCoordinates.startX,\n                    endY: circleCoordinates.startY + EXTEND_RADIUS * 0.5 - 3\n                }\n            };\n            const innerCrossHLine = PlaitBoard.getRoughSVG(this.board).line(\n                innerCrossCoordinates.horizontal.startX,\n                innerCrossCoordinates.horizontal.startY,\n                innerCrossCoordinates.horizontal.endX,\n                innerCrossCoordinates.horizontal.endY,\n                {\n                    stroke: QUICK_INSERT_INNER_CROSS_COLOR,\n                    strokeWidth: 2\n                }\n            );\n            const innerRingVLine = PlaitBoard.getRoughSVG(this.board).line(\n                innerCrossCoordinates.vertical.startX,\n                innerCrossCoordinates.vertical.startY,\n                innerCrossCoordinates.vertical.endX,\n                innerCrossCoordinates.vertical.endY,\n                {\n                    stroke: QUICK_INSERT_INNER_CROSS_COLOR,\n                    strokeWidth: 2\n                }\n            );\n            quickInsertG.appendChild(underline);\n            quickInsertG.appendChild(circle);\n            quickInsertG.appendChild(innerCrossHLine);\n            quickInsertG.appendChild(innerRingVLine);\n        }\n        return quickInsertG;\n    }\n    afterDraw(element: MindElement): void {\n        if (!this.g) {\n            throw new Error(`can not find quick insert g`);\n        }\n        fromEvent<MouseEvent>(this.g, 'mousedown')\n            .pipe(take(1))\n            .subscribe(e => {\n                e.stopPropagation();\n            });\n        fromEvent(this.g, 'mouseup')\n            .pipe(take(1))\n            .subscribe(() => {\n                const path = findNewChildNodePath(this.board, element);\n                insertMindElement(this.board, element, path);\n            });\n    }\n}\n"]}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { isIndentedLayout } from '@plait/layouts';
|
|
2
|
-
import { NODE_TO_PARENT, PlaitBoard, PlaitNode } from '@plait/core';
|
|
2
|
+
import { NODE_TO_PARENT, Path, PlaitBoard, PlaitNode } from '@plait/core';
|
|
3
3
|
import { MindQueries } from '../queries';
|
|
4
4
|
import { ELEMENT_TO_NODE } from '../utils';
|
|
5
5
|
export const PlaitMind = {
|
|
@@ -37,6 +37,17 @@ export const MindElement = {
|
|
|
37
37
|
const path = PlaitBoard.findPath(board, element);
|
|
38
38
|
return PlaitNode.get(board, path.slice(0, 1));
|
|
39
39
|
},
|
|
40
|
+
getAncestors(board, element) {
|
|
41
|
+
const path = PlaitBoard.findPath(board, element);
|
|
42
|
+
const parents = [];
|
|
43
|
+
for (const p of Path.ancestors(path, { reverse: true })) {
|
|
44
|
+
const n = PlaitNode.get(board, p);
|
|
45
|
+
if (n && !PlaitBoard.isBoard(n)) {
|
|
46
|
+
parents.push(n);
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
return parents;
|
|
50
|
+
},
|
|
40
51
|
getNode(element) {
|
|
41
52
|
const node = ELEMENT_TO_NODE.get(element);
|
|
42
53
|
if (!node) {
|
|
@@ -56,4 +67,4 @@ export const MindElement = {
|
|
|
56
67
|
return element.data.emojis;
|
|
57
68
|
}
|
|
58
69
|
};
|
|
59
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
70
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxlbWVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3BhY2thZ2VzL21pbmQvc3JjL2ludGVyZmFjZXMvZWxlbWVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsZ0JBQWdCLEVBQWtCLE1BQU0sZ0JBQWdCLENBQUM7QUFDbEUsT0FBTyxFQUFFLGNBQWMsRUFBRSxJQUFJLEVBQUUsVUFBVSxFQUFnQixTQUFTLEVBQVMsTUFBTSxhQUFhLENBQUM7QUFDL0YsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLFlBQVksQ0FBQztBQUN6QyxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sVUFBVSxDQUFDO0FBa0MzQyxNQUFNLENBQUMsTUFBTSxTQUFTLEdBQUc7SUFDckIsTUFBTSxFQUFFLENBQUMsS0FBVSxFQUFzQixFQUFFO1FBQ3ZDLE9BQU8sS0FBSyxDQUFDLElBQUksS0FBSyxTQUFTLENBQUM7SUFDcEMsQ0FBQztDQUNKLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxXQUFXLEdBQUc7SUFDdkIsU0FBUyxDQUFDLEtBQWtCLEVBQUUsTUFBc0I7UUFDaEQsTUFBTSxPQUFPLEdBQUcsV0FBVyxDQUFDLGtCQUFrQixDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQ3RELE9BQU8sT0FBTyxLQUFLLE1BQU0sQ0FBQztJQUM5QixDQUFDO0lBQ0QsZ0JBQWdCLENBQUMsS0FBa0I7UUFDL0IsTUFBTSxPQUFPLEdBQUcsV0FBVyxDQUFDLGtCQUFrQixDQUFDLEtBQUssQ0FBbUIsQ0FBQztRQUN4RSxPQUFPLGdCQUFnQixDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQ3JDLENBQUM7SUFDRCxhQUFhLENBQUMsS0FBaUIsRUFBRSxPQUFxQjtRQUNsRCxNQUFNLElBQUksR0FBRyxVQUFVLENBQUMsUUFBUSxDQUFDLEtBQUssRUFBRSxPQUFPLENBQUMsQ0FBQztRQUNqRCxNQUFNLFdBQVcsR0FBRyxTQUFTLENBQUMsR0FBRyxDQUFDLEtBQUssRUFBRSxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQzNELElBQUksU0FBUyxDQUFDLE1BQU0sQ0FBQyxXQUFXLENBQUMsRUFBRTtZQUMvQixPQUFPLElBQUksQ0FBQztTQUNmO2FBQU07WUFDSCxPQUFPLEtBQUssQ0FBQztTQUNoQjtJQUNMLENBQUM7SUFDRCxTQUFTLENBQUMsSUFBaUI7UUFDdkIsSUFBSSxTQUFTLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxFQUFFO1lBQ3hCLE1BQU0sSUFBSSxLQUFLLENBQUMsbUNBQW1DLENBQUMsQ0FBQztTQUN4RDtRQUNELE1BQU0sTUFBTSxHQUFHLGNBQWMsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFnQixDQUFDO1FBQ3ZELE9BQU8sTUFBTSxDQUFDO0lBQ2xCLENBQUM7SUFDRCxPQUFPLENBQUMsS0FBaUIsRUFBRSxPQUFvQjtRQUMzQyxNQUFNLElBQUksR0FBRyxVQUFVLENBQUMsUUFBUSxDQUFDLEtBQUssRUFBRSxPQUFPLENBQUMsQ0FBQztRQUNqRCxPQUFPLFNBQVMsQ0FBQyxHQUFHLENBQUMsS0FBSyxFQUFFLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFjLENBQUM7SUFDL0QsQ0FBQztJQUNELFlBQVksQ0FBQyxLQUFpQixFQUFFLE9BQW9CO1FBQ2hELE1BQU0sSUFBSSxHQUFHLFVBQVUsQ0FBQyxRQUFRLENBQUMsS0FBSyxFQUFFLE9BQU8sQ0FBQyxDQUFDO1FBQ2pELE1BQU0sT0FBTyxHQUFtQixFQUFFLENBQUM7UUFDbkMsS0FBSyxNQUFNLENBQUMsSUFBSSxJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksRUFBRSxFQUFFLE9BQU8sRUFBRSxJQUFJLEVBQUUsQ0FBQyxFQUFFO1lBQ3JELE1BQU0sQ0FBQyxHQUFHLFNBQVMsQ0FBQyxHQUFHLENBQUMsS0FBSyxFQUFFLENBQUMsQ0FBQyxDQUFDO1lBQ2xDLElBQUksQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsRUFBRTtnQkFDN0IsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQzthQUNuQjtTQUNKO1FBQ0QsT0FBTyxPQUFPLENBQUM7SUFDbkIsQ0FBQztJQUNELE9BQU8sQ0FBQyxPQUFvQjtRQUN4QixNQUFNLElBQUksR0FBRyxlQUFlLENBQUMsR0FBRyxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQzFDLElBQUksQ0FBQyxJQUFJLEVBQUU7WUFDUCxNQUFNLElBQUksS0FBSyxDQUFDLHlCQUF5QixJQUFJLENBQUMsU0FBUyxDQUFDLE9BQU8sQ0FBQyxFQUFFLENBQUMsQ0FBQztTQUN2RTtRQUNELE9BQU8sSUFBSSxDQUFDO0lBQ2hCLENBQUM7SUFDRCxTQUFTLENBQUMsT0FBb0I7UUFDMUIsSUFBSSxPQUFPLENBQUMsSUFBSSxDQUFDLE1BQU0sRUFBRTtZQUNyQixPQUFPLElBQUksQ0FBQztTQUNmO2FBQU07WUFDSCxPQUFPLEtBQUssQ0FBQztTQUNoQjtJQUNMLENBQUM7SUFDRCxTQUFTLENBQUMsT0FBK0I7UUFDckMsT0FBTyxPQUFPLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQztJQUMvQixDQUFDO0NBQ0osQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE1pbmROb2RlU2hhcGUgfSBmcm9tICcuLi9jb25zdGFudHMvbm9kZSc7XG5pbXBvcnQgeyBpc0luZGVudGVkTGF5b3V0LCBNaW5kTGF5b3V0VHlwZSB9IGZyb20gJ0BwbGFpdC9sYXlvdXRzJztcbmltcG9ydCB7IE5PREVfVE9fUEFSRU5ULCBQYXRoLCBQbGFpdEJvYXJkLCBQbGFpdEVsZW1lbnQsIFBsYWl0Tm9kZSwgUG9pbnQgfSBmcm9tICdAcGxhaXQvY29yZSc7XG5pbXBvcnQgeyBNaW5kUXVlcmllcyB9IGZyb20gJy4uL3F1ZXJpZXMnO1xuaW1wb3J0IHsgRUxFTUVOVF9UT19OT0RFIH0gZnJvbSAnLi4vdXRpbHMnO1xuaW1wb3J0IHsgQmFzZURhdGEsIEVtb2ppRGF0YSB9IGZyb20gJy4vZWxlbWVudC1kYXRhJztcblxuZXhwb3J0IGludGVyZmFjZSBNaW5kRWxlbWVudDxUID0gQmFzZURhdGE+IGV4dGVuZHMgUGxhaXRFbGVtZW50IHtcbiAgICBkYXRhOiBUO1xuICAgIGNoaWxkcmVuOiBNaW5kRWxlbWVudFtdO1xuICAgIHJpZ2h0Tm9kZUNvdW50PzogbnVtYmVyO1xuICAgIHdpZHRoOiBudW1iZXI7XG4gICAgaGVpZ2h0OiBudW1iZXI7XG4gICAgaXNSb290PzogYm9vbGVhbjtcblxuICAgIC8vIG5vZGUgc3R5bGUgYXR0cmlidXRlc1xuICAgIGZpbGw/OiBzdHJpbmc7XG4gICAgc3Ryb2tlQ29sb3I/OiBzdHJpbmc7XG4gICAgc3Ryb2tlV2lkdGg/OiBudW1iZXI7XG4gICAgc2hhcGU/OiBNaW5kTm9kZVNoYXBlO1xuXG4gICAgLy8gbGluayBzdHlsZSBhdHRyaWJ1dGVzXG4gICAgYnJhbmNoQ29sb3I/OiBzdHJpbmc7XG4gICAgYnJhbmNoV2lkdGg/OiBudW1iZXI7XG5cbiAgICAvLyBsYXlvdXRcbiAgICBsYXlvdXQ/OiBNaW5kTGF5b3V0VHlwZTtcbiAgICBpc0NvbGxhcHNlZD86IGJvb2xlYW47XG5cbiAgICBzdGFydD86IG51bWJlcjtcbiAgICBlbmQ/OiBudW1iZXI7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgUGxhaXRNaW5kIGV4dGVuZHMgTWluZEVsZW1lbnQge1xuICAgIHR5cGU6ICdtaW5kbWFwJztcbiAgICBwb2ludHM6IFBvaW50W107XG59XG5cbmV4cG9ydCBjb25zdCBQbGFpdE1pbmQgPSB7XG4gICAgaXNNaW5kOiAodmFsdWU6IGFueSk6IHZhbHVlIGlzIFBsYWl0TWluZCA9PiB7XG4gICAgICAgIHJldHVybiB2YWx1ZS50eXBlID09PSAnbWluZG1hcCc7XG4gICAgfVxufTtcblxuZXhwb3J0IGNvbnN0IE1pbmRFbGVtZW50ID0ge1xuICAgIGhhc0xheW91dCh2YWx1ZTogTWluZEVsZW1lbnQsIGxheW91dDogTWluZExheW91dFR5cGUpIHtcbiAgICAgICAgY29uc3QgX2xheW91dCA9IE1pbmRRdWVyaWVzLmdldExheW91dEJ5RWxlbWVudCh2YWx1ZSk7XG4gICAgICAgIHJldHVybiBfbGF5b3V0ID09PSBsYXlvdXQ7XG4gICAgfSxcbiAgICBpc0luZGVudGVkTGF5b3V0KHZhbHVlOiBNaW5kRWxlbWVudCkge1xuICAgICAgICBjb25zdCBfbGF5b3V0ID0gTWluZFF1ZXJpZXMuZ2V0TGF5b3V0QnlFbGVtZW50KHZhbHVlKSBhcyBNaW5kTGF5b3V0VHlwZTtcbiAgICAgICAgcmV0dXJuIGlzSW5kZW50ZWRMYXlvdXQoX2xheW91dCk7XG4gICAgfSxcbiAgICBpc01pbmRFbGVtZW50KGJvYXJkOiBQbGFpdEJvYXJkLCBlbGVtZW50OiBQbGFpdEVsZW1lbnQpOiBlbGVtZW50IGlzIE1pbmRFbGVtZW50IHtcbiAgICAgICAgY29uc3QgcGF0aCA9IFBsYWl0Qm9hcmQuZmluZFBhdGgoYm9hcmQsIGVsZW1lbnQpO1xuICAgICAgICBjb25zdCByb290RWxlbWVudCA9IFBsYWl0Tm9kZS5nZXQoYm9hcmQsIHBhdGguc2xpY2UoMCwgMSkpO1xuICAgICAgICBpZiAoUGxhaXRNaW5kLmlzTWluZChyb290RWxlbWVudCkpIHtcbiAgICAgICAgICAgIHJldHVybiB0cnVlO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgcmV0dXJuIGZhbHNlO1xuICAgICAgICB9XG4gICAgfSxcbiAgICBnZXRQYXJlbnQobm9kZTogTWluZEVsZW1lbnQpIHtcbiAgICAgICAgaWYgKFBsYWl0TWluZC5pc01pbmQobm9kZSkpIHtcbiAgICAgICAgICAgIHRocm93IG5ldyBFcnJvcignbWluZCByb290IG5vZGUgY2FuIG5vdCBnZXQgcGFyZW50Jyk7XG4gICAgICAgIH1cbiAgICAgICAgY29uc3QgcGFyZW50ID0gTk9ERV9UT19QQVJFTlQuZ2V0KG5vZGUpIGFzIE1pbmRFbGVtZW50O1xuICAgICAgICByZXR1cm4gcGFyZW50O1xuICAgIH0sXG4gICAgZ2V0Um9vdChib2FyZDogUGxhaXRCb2FyZCwgZWxlbWVudDogTWluZEVsZW1lbnQpIHtcbiAgICAgICAgY29uc3QgcGF0aCA9IFBsYWl0Qm9hcmQuZmluZFBhdGgoYm9hcmQsIGVsZW1lbnQpO1xuICAgICAgICByZXR1cm4gUGxhaXROb2RlLmdldChib2FyZCwgcGF0aC5zbGljZSgwLCAxKSkgYXMgUGxhaXRNaW5kO1xuICAgIH0sXG4gICAgZ2V0QW5jZXN0b3JzKGJvYXJkOiBQbGFpdEJvYXJkLCBlbGVtZW50OiBNaW5kRWxlbWVudCkge1xuICAgICAgICBjb25zdCBwYXRoID0gUGxhaXRCb2FyZC5maW5kUGF0aChib2FyZCwgZWxlbWVudCk7XG4gICAgICAgIGNvbnN0IHBhcmVudHM6IFBsYWl0RWxlbWVudFtdID0gW107XG4gICAgICAgIGZvciAoY29uc3QgcCBvZiBQYXRoLmFuY2VzdG9ycyhwYXRoLCB7IHJldmVyc2U6IHRydWUgfSkpIHtcbiAgICAgICAgICAgIGNvbnN0IG4gPSBQbGFpdE5vZGUuZ2V0KGJvYXJkLCBwKTtcbiAgICAgICAgICAgIGlmIChuICYmICFQbGFpdEJvYXJkLmlzQm9hcmQobikpIHtcbiAgICAgICAgICAgICAgICBwYXJlbnRzLnB1c2gobik7XG4gICAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIHBhcmVudHM7XG4gICAgfSxcbiAgICBnZXROb2RlKGVsZW1lbnQ6IE1pbmRFbGVtZW50KSB7XG4gICAgICAgIGNvbnN0IG5vZGUgPSBFTEVNRU5UX1RPX05PREUuZ2V0KGVsZW1lbnQpO1xuICAgICAgICBpZiAoIW5vZGUpIHtcbiAgICAgICAgICAgIHRocm93IG5ldyBFcnJvcihgY2FuIG5vdCBnZXQgbm9kZSBmcm9tICR7SlNPTi5zdHJpbmdpZnkoZWxlbWVudCl9YCk7XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIG5vZGU7XG4gICAgfSxcbiAgICBoYXNFbW9qaXMoZWxlbWVudDogTWluZEVsZW1lbnQpOiBlbGVtZW50IGlzIE1pbmRFbGVtZW50PEVtb2ppRGF0YT4ge1xuICAgICAgICBpZiAoZWxlbWVudC5kYXRhLmVtb2ppcykge1xuICAgICAgICAgICAgcmV0dXJuIHRydWU7XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgICAgIH1cbiAgICB9LFxuICAgIGdldEVtb2ppcyhlbGVtZW50OiBNaW5kRWxlbWVudDxFbW9qaURhdGE+KSB7XG4gICAgICAgIHJldHVybiBlbGVtZW50LmRhdGEuZW1vamlzO1xuICAgIH1cbn07XG4iXX0=
|