@plait/draw 0.63.0 → 0.64.1
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/arrow-line.component.d.ts +3 -3
- package/constants/pointer.d.ts +3 -2
- package/esm2022/arrow-line.component.mjs +6 -5
- package/esm2022/constants/pointer.mjs +5 -2
- package/esm2022/generators/arrow-line.generator.mjs +3 -3
- package/esm2022/generators/index.mjs +2 -2
- package/esm2022/generators/line-active.generator.mjs +81 -0
- package/esm2022/generators/vector-line-generator.mjs +13 -0
- package/esm2022/interfaces/index.mjs +8 -5
- package/esm2022/interfaces/line.mjs +2 -0
- package/esm2022/interfaces/vector-line.mjs +5 -1
- package/esm2022/plugins/with-arrow-line-bound-reaction.mjs +3 -3
- package/esm2022/plugins/with-arrow-line-resize.mjs +9 -9
- package/esm2022/plugins/with-draw-fragment.mjs +7 -5
- package/esm2022/plugins/with-draw.mjs +17 -2
- package/esm2022/plugins/with-vector-line-resize.mjs +61 -0
- package/esm2022/plugins/with-vector-pen-create.mjs +124 -0
- package/esm2022/public-api.mjs +2 -1
- package/esm2022/transforms/index.mjs +3 -1
- package/esm2022/transforms/vector-line.mjs +13 -0
- package/esm2022/utils/arrow-line/arrow-line-basic.mjs +5 -58
- package/esm2022/utils/common.mjs +5 -1
- package/esm2022/utils/hit.mjs +24 -4
- package/esm2022/utils/index.mjs +3 -1
- package/esm2022/utils/line.mjs +64 -0
- package/esm2022/utils/position/arrow-line.mjs +3 -50
- package/esm2022/utils/position/line.mjs +51 -0
- package/esm2022/utils/selected.mjs +5 -1
- package/esm2022/utils/vector-line.mjs +75 -0
- package/esm2022/vector-line.component.mjs +50 -0
- package/fesm2022/plait-draw.mjs +510 -146
- package/fesm2022/plait-draw.mjs.map +1 -1
- package/generators/arrow-line.generator.d.ts +3 -5
- package/generators/index.d.ts +1 -1
- package/generators/line-active.generator.d.ts +13 -0
- package/generators/vector-line-generator.d.ts +6 -0
- package/interfaces/index.d.ts +3 -0
- package/interfaces/line.d.ts +3 -0
- package/interfaces/vector-line.d.ts +10 -1
- package/package.json +1 -1
- package/plugins/with-vector-line-resize.d.ts +2 -0
- package/plugins/with-vector-pen-create.d.ts +2 -0
- package/public-api.d.ts +1 -0
- package/styles/styles.scss +2 -2
- package/transforms/index.d.ts +1 -0
- package/transforms/vector-line.d.ts +3 -0
- package/utils/arrow-line/arrow-line-basic.d.ts +0 -1
- package/utils/hit.d.ts +3 -2
- package/utils/index.d.ts +2 -0
- package/utils/line.d.ts +3 -0
- package/utils/position/arrow-line.d.ts +0 -13
- package/utils/position/line.d.ts +15 -0
- package/utils/selected.d.ts +2 -1
- package/utils/vector-line.d.ts +7 -0
- package/vector-line.component.d.ts +14 -0
- package/esm2022/generators/arrow-line-active.generator.mjs +0 -81
- package/generators/arrow-line-active.generator.d.ts +0 -13
package/esm2022/utils/hit.mjs
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { RectangleClient, isPolylineHitRectangle, distanceBetweenPointAndSegments, distanceBetweenPointAndPoint, HIT_DISTANCE_BUFFER, rotatePointsByElement, rotateAntiPointsByElement } from '@plait/core';
|
|
1
|
+
import { RectangleClient, isPolylineHitRectangle, distanceBetweenPointAndSegments, distanceBetweenPointAndPoint, HIT_DISTANCE_BUFFER, rotatePointsByElement, rotateAntiPointsByElement, isPointInPolygon } from '@plait/core';
|
|
2
2
|
import { PlaitDrawElement } from '../interfaces';
|
|
3
3
|
import { getNearestPoint } from './geometry';
|
|
4
4
|
import { getArrowLinePoints } from './arrow-line/arrow-line-basic';
|
|
@@ -6,9 +6,10 @@ import { getFillByElement } from './style/stroke';
|
|
|
6
6
|
import { getEngine } from '../engines';
|
|
7
7
|
import { getElementShape } from './shape';
|
|
8
8
|
import { getHitArrowLineTextIndex } from './position/arrow-line';
|
|
9
|
-
import { getTextRectangle } from './common';
|
|
9
|
+
import { getTextRectangle, isDrawElementClosed } from './common';
|
|
10
10
|
import { isMultipleTextGeometry } from './multi-text-geometry';
|
|
11
11
|
import { isFilled, sortElementsByArea } from '@plait/common';
|
|
12
|
+
import { getVectorLinePoints, isClosedVectorLine } from './vector-line';
|
|
12
13
|
export const isTextExceedingBounds = (geometry) => {
|
|
13
14
|
const client = RectangleClient.getRectangleByPoints(geometry.points);
|
|
14
15
|
if (geometry.textHeight && geometry.textHeight > client.height) {
|
|
@@ -28,6 +29,15 @@ export const isHitArrowLine = (board, element, point) => {
|
|
|
28
29
|
const isHitText = isHitArrowLineText(board, element, point);
|
|
29
30
|
return isHitText || isHitPolyLine(points, point);
|
|
30
31
|
};
|
|
32
|
+
export const isHitVectorLine = (board, element, point) => {
|
|
33
|
+
const points = getVectorLinePoints(board, element);
|
|
34
|
+
if (isClosedVectorLine(element)) {
|
|
35
|
+
return isPointInPolygon(point, points) || isHitPolyLine(points, point);
|
|
36
|
+
}
|
|
37
|
+
else {
|
|
38
|
+
return isHitPolyLine(points, point);
|
|
39
|
+
}
|
|
40
|
+
};
|
|
31
41
|
export const isRectangleHitElementText = (element, rectangle) => {
|
|
32
42
|
const engine = getEngine(element.shape);
|
|
33
43
|
if (isMultipleTextGeometry(element)) {
|
|
@@ -78,6 +88,10 @@ export const isRectangleHitDrawElement = (board, element, selection) => {
|
|
|
78
88
|
const points = getArrowLinePoints(board, element);
|
|
79
89
|
return isPolylineHitRectangle(points, rangeRectangle);
|
|
80
90
|
}
|
|
91
|
+
if (PlaitDrawElement.isVectorLine(element)) {
|
|
92
|
+
const points = getVectorLinePoints(board, element);
|
|
93
|
+
return isPolylineHitRectangle(points, rangeRectangle, false);
|
|
94
|
+
}
|
|
81
95
|
return null;
|
|
82
96
|
};
|
|
83
97
|
export const getDrawHitElement = (board, elements) => {
|
|
@@ -98,7 +112,7 @@ export const getFirstFilledDrawElement = (board, elements) => {
|
|
|
98
112
|
let filledElement = null;
|
|
99
113
|
for (let i = 0; i < elements.length; i++) {
|
|
100
114
|
const element = elements[i];
|
|
101
|
-
if (
|
|
115
|
+
if (isDrawElementClosed(element)) {
|
|
102
116
|
const fill = getFillByElement(board, element);
|
|
103
117
|
if (isFilled(fill)) {
|
|
104
118
|
filledElement = element;
|
|
@@ -141,6 +155,9 @@ export const isHitDrawElement = (board, element, point) => {
|
|
|
141
155
|
if (PlaitDrawElement.isArrowLine(element)) {
|
|
142
156
|
return isHitArrowLine(board, element, point);
|
|
143
157
|
}
|
|
158
|
+
if (PlaitDrawElement.isVectorLine(element)) {
|
|
159
|
+
return isHitVectorLine(board, element, point);
|
|
160
|
+
}
|
|
144
161
|
return null;
|
|
145
162
|
};
|
|
146
163
|
export const isHitEdgeOfShape = (board, element, point, hitDistanceBuffer) => {
|
|
@@ -175,6 +192,9 @@ export const isHitElementInside = (board, element, point) => {
|
|
|
175
192
|
if (PlaitDrawElement.isArrowLine(element)) {
|
|
176
193
|
return isHitArrowLine(board, element, point);
|
|
177
194
|
}
|
|
195
|
+
if (PlaitDrawElement.isVectorLine(element)) {
|
|
196
|
+
return isHitVectorLine(board, element, point);
|
|
197
|
+
}
|
|
178
198
|
return null;
|
|
179
199
|
};
|
|
180
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hit.js","sourceRoot":"","sources":["../../../../packages/draw/src/utils/hit.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    PlaitElement,\n    RectangleClient,\n    Selection,\n    PlaitBoard,\n    isPolylineHitRectangle,\n    Point,\n    distanceBetweenPointAndSegments,\n    distanceBetweenPointAndPoint,\n    HIT_DISTANCE_BUFFER,\n    rotatePointsByElement,\n    rotateAntiPointsByElement\n} from '@plait/core';\nimport { PlaitArrowLine, PlaitCommonGeometry, PlaitDrawElement, PlaitGeometry, PlaitShapeElement } from '../interfaces';\nimport { getNearestPoint } from './geometry';\nimport { getArrowLinePoints } from './arrow-line/arrow-line-basic';\nimport { getFillByElement } from './style/stroke';\nimport { getEngine } from '../engines';\nimport { getElementShape } from './shape';\nimport { getHitArrowLineTextIndex } from './position/arrow-line';\nimport { getTextRectangle } from './common';\nimport { isMultipleTextGeometry } from './multi-text-geometry';\nimport { isFilled, sortElementsByArea } from '@plait/common';\n\nexport const isTextExceedingBounds = (geometry: PlaitGeometry) => {\n    const client = RectangleClient.getRectangleByPoints(geometry.points);\n    if (geometry.textHeight && geometry.textHeight > client.height) {\n        return true;\n    }\n    return false;\n};\n\nexport const isHitArrowLineText = (board: PlaitBoard, element: PlaitArrowLine, point: Point) => {\n    return getHitArrowLineTextIndex(board, element, point) !== -1;\n};\n\nexport const isHitPolyLine = (pathPoints: Point[], point: Point) => {\n    const distance = distanceBetweenPointAndSegments(pathPoints, point);\n    return distance <= HIT_DISTANCE_BUFFER;\n};\n\nexport const isHitArrowLine = (board: PlaitBoard, element: PlaitArrowLine, point: Point) => {\n    const points = getArrowLinePoints(board, element);\n    const isHitText = isHitArrowLineText(board, element as PlaitArrowLine, point);\n    return isHitText || isHitPolyLine(points, point);\n};\n\nexport const isRectangleHitElementText = (element: PlaitCommonGeometry, rectangle: RectangleClient) => {\n    const engine = getEngine<PlaitCommonGeometry>(element.shape);\n    if (isMultipleTextGeometry(element)) {\n        const texts = element.texts;\n        return texts.some(item => {\n            const textClient = engine.getTextRectangle!(element, { key: item.key });\n            const rotatedCornerPoints =\n                rotatePointsByElement(RectangleClient.getCornerPoints(textClient), element) || RectangleClient.getCornerPoints(textClient);\n            return isPolylineHitRectangle(rotatedCornerPoints, rectangle);\n        });\n    } else {\n        const textClient = engine.getTextRectangle ? engine.getTextRectangle(element) : getTextRectangle(element);\n        const rotatedCornerPoints =\n            rotatePointsByElement(RectangleClient.getCornerPoints(textClient), element) || RectangleClient.getCornerPoints(textClient);\n        return isPolylineHitRectangle(rotatedCornerPoints, rectangle);\n    }\n};\n\nexport const isHitElementText = (element: PlaitCommonGeometry, point: Point) => {\n    const engine = getEngine<PlaitCommonGeometry>(element.shape);\n    if (isMultipleTextGeometry(element)) {\n        const texts = element.texts;\n        return texts.some(item => {\n            const textClient = engine.getTextRectangle!(element, { key: item.key });\n            return RectangleClient.isPointInRectangle(textClient, point);\n        });\n    } else {\n        const textClient = engine.getTextRectangle ? engine.getTextRectangle(element) : getTextRectangle(element);\n        return RectangleClient.isPointInRectangle(textClient, point);\n    }\n};\n\nexport const isRectangleHitDrawElement = (board: PlaitBoard, element: PlaitElement, selection: Selection) => {\n    const rangeRectangle = RectangleClient.getRectangleByPoints([selection.anchor, selection.focus]);\n    if (PlaitDrawElement.isGeometry(element)) {\n        const client = RectangleClient.getRectangleByPoints(element.points);\n        let rotatedCornerPoints =\n            rotatePointsByElement(RectangleClient.getCornerPoints(client), element) || RectangleClient.getCornerPoints(client);\n        const isHitElement = isPolylineHitRectangle(rotatedCornerPoints, rangeRectangle);\n        if (isHitElement) {\n            return isHitElement;\n        }\n        return isRectangleHitElementText(element, rangeRectangle);\n    }\n\n    if (PlaitDrawElement.isImage(element)) {\n        const client = RectangleClient.getRectangleByPoints(element.points);\n        const rotatedCornerPoints =\n            rotatePointsByElement(RectangleClient.getCornerPoints(client), element) || RectangleClient.getCornerPoints(client);\n        return isPolylineHitRectangle(rotatedCornerPoints, rangeRectangle);\n    }\n\n    if (PlaitDrawElement.isArrowLine(element)) {\n        const points = getArrowLinePoints(board, element);\n        return isPolylineHitRectangle(points, rangeRectangle);\n    }\n    return null;\n};\n\nexport const getDrawHitElement = (board: PlaitBoard, elements: PlaitDrawElement[]) => {\n    let firstFilledElement = getFirstFilledDrawElement(board, elements);\n    let endIndex = elements.length;\n    if (firstFilledElement) {\n        endIndex = elements.indexOf(firstFilledElement) + 1;\n    }\n    const newElements = elements.slice(0, endIndex);\n    const element = getFirstTextOrLineElement(newElements);\n    if (element) {\n        return element;\n    }\n    const sortElements = sortElementsByArea(board, newElements, 'asc');\n    return sortElements[0];\n};\n\nexport const getFirstFilledDrawElement = (board: PlaitBoard, elements: PlaitDrawElement[]) => {\n    let filledElement: PlaitGeometry | null = null;\n    for (let i = 0; i < elements.length; i++) {\n        const element = elements[i];\n        if (PlaitDrawElement.isGeometry(element) && !PlaitDrawElement.isText(element)) {\n            const fill = getFillByElement(board, element);\n            if (isFilled(fill)) {\n                filledElement = element as PlaitGeometry;\n                break;\n            }\n        }\n    }\n    return filledElement;\n};\n\nexport const getFirstTextOrLineElement = (elements: PlaitDrawElement[]) => {\n    const texts = elements.filter(item => PlaitDrawElement.isText(item));\n    if (texts.length) {\n        return texts[0];\n    }\n    const lines = elements.filter(item => PlaitDrawElement.isArrowLine(item));\n    if (lines.length) {\n        return lines[0];\n    }\n    return null;\n};\n\nexport const isHitDrawElement = (board: PlaitBoard, element: PlaitElement, point: Point) => {\n    const rectangle = board.getRectangle(element);\n    point = rotateAntiPointsByElement(point, element) || point;\n    if (PlaitDrawElement.isGeometry(element)) {\n        if (isHitEdgeOfShape(board, element, point, HIT_DISTANCE_BUFFER)) {\n            return true;\n        }\n        const engine = getEngine(getElementShape(element));\n        if (PlaitDrawElement.isText(element)) {\n            const textClient = getTextRectangle(element);\n            return RectangleClient.isPointInRectangle(textClient, point);\n        }\n        const isHitText = isHitElementText(element, point);\n        return isHitText || engine.isInsidePoint(rectangle!, point);\n    }\n    if (PlaitDrawElement.isImage(element)) {\n        const client = RectangleClient.getRectangleByPoints(element.points);\n        return RectangleClient.isPointInRectangle(client, point);\n    }\n    if (PlaitDrawElement.isArrowLine(element)) {\n        return isHitArrowLine(board, element, point);\n    }\n    return null;\n};\n\nexport const isHitEdgeOfShape = (board: PlaitBoard, element: PlaitShapeElement, point: Point, hitDistanceBuffer: number) => {\n    const nearestPoint = getNearestPoint(element, point);\n    const distance = distanceBetweenPointAndPoint(nearestPoint[0], nearestPoint[1], point[0], point[1]);\n    return distance <= hitDistanceBuffer;\n};\n\nexport const isInsideOfShape = (board: PlaitBoard, element: PlaitShapeElement, point: Point, hitDistanceBuffer: number) => {\n    const client = RectangleClient.inflate(RectangleClient.getRectangleByPoints(element.points), hitDistanceBuffer);\n    return getEngine(getElementShape(element)).isInsidePoint(client, point);\n};\n\nexport const isHitElementInside = (board: PlaitBoard, element: PlaitElement, point: Point) => {\n    const rectangle = board.getRectangle(element);\n    point = rotateAntiPointsByElement(point, element) || point;\n    if (PlaitDrawElement.isGeometry(element) && !PlaitDrawElement.isGeometryByTable(element)) {\n        const engine = getEngine(getElementShape(element));\n        const isHitInside = engine.isInsidePoint(rectangle!, point);\n        if (isHitInside) {\n            return isHitInside;\n        }\n        if (engine.getTextRectangle) {\n            const isHitText = isHitElementText(element, point);\n            if (isHitText) {\n                return isHitText;\n            }\n        }\n    }\n    if (PlaitDrawElement.isImage(element)) {\n        const client = RectangleClient.getRectangleByPoints(element.points);\n        return RectangleClient.isPointInRectangle(client, point);\n    }\n\n    if (PlaitDrawElement.isArrowLine(element)) {\n        return isHitArrowLine(board, element, point);\n    }\n\n    return null;\n};\n"]}
|
|
200
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hit.js","sourceRoot":"","sources":["../../../../packages/draw/src/utils/hit.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    PlaitElement,\n    RectangleClient,\n    Selection,\n    PlaitBoard,\n    isPolylineHitRectangle,\n    Point,\n    distanceBetweenPointAndSegments,\n    distanceBetweenPointAndPoint,\n    HIT_DISTANCE_BUFFER,\n    rotatePointsByElement,\n    rotateAntiPointsByElement,\n    isPointInPolygon\n} from '@plait/core';\nimport { PlaitArrowLine, PlaitCommonGeometry, PlaitDrawElement, PlaitGeometry, PlaitShapeElement, PlaitVectorLine } from '../interfaces';\nimport { getNearestPoint } from './geometry';\nimport { getArrowLinePoints } from './arrow-line/arrow-line-basic';\nimport { getFillByElement } from './style/stroke';\nimport { getEngine } from '../engines';\nimport { getElementShape } from './shape';\nimport { getHitArrowLineTextIndex } from './position/arrow-line';\nimport { getTextRectangle, isDrawElementClosed } from './common';\nimport { isMultipleTextGeometry } from './multi-text-geometry';\nimport { isFilled, sortElementsByArea } from '@plait/common';\nimport { getVectorLinePoints, isClosedVectorLine } from './vector-line';\n\nexport const isTextExceedingBounds = (geometry: PlaitGeometry) => {\n    const client = RectangleClient.getRectangleByPoints(geometry.points);\n    if (geometry.textHeight && geometry.textHeight > client.height) {\n        return true;\n    }\n    return false;\n};\n\nexport const isHitArrowLineText = (board: PlaitBoard, element: PlaitArrowLine, point: Point) => {\n    return getHitArrowLineTextIndex(board, element, point) !== -1;\n};\n\nexport const isHitPolyLine = (pathPoints: Point[], point: Point) => {\n    const distance = distanceBetweenPointAndSegments(pathPoints, point);\n    return distance <= HIT_DISTANCE_BUFFER;\n};\n\nexport const isHitArrowLine = (board: PlaitBoard, element: PlaitArrowLine, point: Point) => {\n    const points = getArrowLinePoints(board, element);\n    const isHitText = isHitArrowLineText(board, element as PlaitArrowLine, point);\n    return isHitText || isHitPolyLine(points, point);\n};\n\nexport const isHitVectorLine = (board: PlaitBoard, element: PlaitVectorLine, point: Point) => {\n    const points = getVectorLinePoints(board, element)!;\n    if (isClosedVectorLine(element)) {\n        return isPointInPolygon(point, points) || isHitPolyLine(points, point);\n    } else {\n        return isHitPolyLine(points, point);\n    }\n};\n\nexport const isRectangleHitElementText = (element: PlaitCommonGeometry, rectangle: RectangleClient) => {\n    const engine = getEngine<PlaitCommonGeometry>(element.shape);\n    if (isMultipleTextGeometry(element)) {\n        const texts = element.texts;\n        return texts.some(item => {\n            const textClient = engine.getTextRectangle!(element, { key: item.key });\n            const rotatedCornerPoints =\n                rotatePointsByElement(RectangleClient.getCornerPoints(textClient), element) || RectangleClient.getCornerPoints(textClient);\n            return isPolylineHitRectangle(rotatedCornerPoints, rectangle);\n        });\n    } else {\n        const textClient = engine.getTextRectangle ? engine.getTextRectangle(element) : getTextRectangle(element);\n        const rotatedCornerPoints =\n            rotatePointsByElement(RectangleClient.getCornerPoints(textClient), element) || RectangleClient.getCornerPoints(textClient);\n        return isPolylineHitRectangle(rotatedCornerPoints, rectangle);\n    }\n};\n\nexport const isHitElementText = (element: PlaitCommonGeometry, point: Point) => {\n    const engine = getEngine<PlaitCommonGeometry>(element.shape);\n    if (isMultipleTextGeometry(element)) {\n        const texts = element.texts;\n        return texts.some(item => {\n            const textClient = engine.getTextRectangle!(element, { key: item.key });\n            return RectangleClient.isPointInRectangle(textClient, point);\n        });\n    } else {\n        const textClient = engine.getTextRectangle ? engine.getTextRectangle(element) : getTextRectangle(element);\n        return RectangleClient.isPointInRectangle(textClient, point);\n    }\n};\n\nexport const isRectangleHitDrawElement = (board: PlaitBoard, element: PlaitElement, selection: Selection) => {\n    const rangeRectangle = RectangleClient.getRectangleByPoints([selection.anchor, selection.focus]);\n    if (PlaitDrawElement.isGeometry(element)) {\n        const client = RectangleClient.getRectangleByPoints(element.points);\n        let rotatedCornerPoints =\n            rotatePointsByElement(RectangleClient.getCornerPoints(client), element) || RectangleClient.getCornerPoints(client);\n        const isHitElement = isPolylineHitRectangle(rotatedCornerPoints, rangeRectangle);\n        if (isHitElement) {\n            return isHitElement;\n        }\n        return isRectangleHitElementText(element, rangeRectangle);\n    }\n\n    if (PlaitDrawElement.isImage(element)) {\n        const client = RectangleClient.getRectangleByPoints(element.points);\n        const rotatedCornerPoints =\n            rotatePointsByElement(RectangleClient.getCornerPoints(client), element) || RectangleClient.getCornerPoints(client);\n        return isPolylineHitRectangle(rotatedCornerPoints, rangeRectangle);\n    }\n\n    if (PlaitDrawElement.isArrowLine(element)) {\n        const points = getArrowLinePoints(board, element);\n        return isPolylineHitRectangle(points, rangeRectangle);\n    }\n\n    if (PlaitDrawElement.isVectorLine(element)) {\n        const points = getVectorLinePoints(board, element)!;\n        return isPolylineHitRectangle(points, rangeRectangle, false);\n    }\n\n    return null;\n};\n\nexport const getDrawHitElement = (board: PlaitBoard, elements: PlaitDrawElement[]) => {\n    let firstFilledElement = getFirstFilledDrawElement(board, elements);\n    let endIndex = elements.length;\n    if (firstFilledElement) {\n        endIndex = elements.indexOf(firstFilledElement) + 1;\n    }\n    const newElements = elements.slice(0, endIndex);\n    const element = getFirstTextOrLineElement(newElements);\n    if (element) {\n        return element;\n    }\n    const sortElements = sortElementsByArea(board, newElements, 'asc');\n    return sortElements[0];\n};\n\nexport const getFirstFilledDrawElement = (board: PlaitBoard, elements: PlaitDrawElement[]) => {\n    let filledElement: PlaitGeometry | null = null;\n    for (let i = 0; i < elements.length; i++) {\n        const element = elements[i];\n        if (isDrawElementClosed(element)) {\n            const fill = getFillByElement(board, element);\n            if (isFilled(fill)) {\n                filledElement = element as PlaitGeometry;\n                break;\n            }\n        }\n    }\n    return filledElement;\n};\n\nexport const getFirstTextOrLineElement = (elements: PlaitDrawElement[]) => {\n    const texts = elements.filter(item => PlaitDrawElement.isText(item));\n    if (texts.length) {\n        return texts[0];\n    }\n    const lines = elements.filter(item => PlaitDrawElement.isArrowLine(item));\n    if (lines.length) {\n        return lines[0];\n    }\n    return null;\n};\n\nexport const isHitDrawElement = (board: PlaitBoard, element: PlaitElement, point: Point) => {\n    const rectangle = board.getRectangle(element);\n    point = rotateAntiPointsByElement(point, element) || point;\n    if (PlaitDrawElement.isGeometry(element)) {\n        if (isHitEdgeOfShape(board, element, point, HIT_DISTANCE_BUFFER)) {\n            return true;\n        }\n        const engine = getEngine(getElementShape(element));\n        if (PlaitDrawElement.isText(element)) {\n            const textClient = getTextRectangle(element);\n            return RectangleClient.isPointInRectangle(textClient, point);\n        }\n        const isHitText = isHitElementText(element, point);\n        return isHitText || engine.isInsidePoint(rectangle!, point);\n    }\n    if (PlaitDrawElement.isImage(element)) {\n        const client = RectangleClient.getRectangleByPoints(element.points);\n        return RectangleClient.isPointInRectangle(client, point);\n    }\n    if (PlaitDrawElement.isArrowLine(element)) {\n        return isHitArrowLine(board, element, point);\n    }\n\n    if (PlaitDrawElement.isVectorLine(element)) {\n        return isHitVectorLine(board, element, point);\n    }\n    return null;\n};\n\nexport const isHitEdgeOfShape = (board: PlaitBoard, element: PlaitShapeElement, point: Point, hitDistanceBuffer: number) => {\n    const nearestPoint = getNearestPoint(element, point);\n    const distance = distanceBetweenPointAndPoint(nearestPoint[0], nearestPoint[1], point[0], point[1]);\n    return distance <= hitDistanceBuffer;\n};\n\nexport const isInsideOfShape = (board: PlaitBoard, element: PlaitShapeElement, point: Point, hitDistanceBuffer: number) => {\n    const client = RectangleClient.inflate(RectangleClient.getRectangleByPoints(element.points), hitDistanceBuffer);\n    return getEngine(getElementShape(element)).isInsidePoint(client, point);\n};\n\nexport const isHitElementInside = (board: PlaitBoard, element: PlaitElement, point: Point) => {\n    const rectangle = board.getRectangle(element);\n    point = rotateAntiPointsByElement(point, element) || point;\n    if (PlaitDrawElement.isGeometry(element) && !PlaitDrawElement.isGeometryByTable(element)) {\n        const engine = getEngine(getElementShape(element));\n        const isHitInside = engine.isInsidePoint(rectangle!, point);\n        if (isHitInside) {\n            return isHitInside;\n        }\n        if (engine.getTextRectangle) {\n            const isHitText = isHitElementText(element, point);\n            if (isHitText) {\n                return isHitText;\n            }\n        }\n    }\n    if (PlaitDrawElement.isImage(element)) {\n        const client = RectangleClient.getRectangleByPoints(element.points);\n        return RectangleClient.isPointInRectangle(client, point);\n    }\n\n    if (PlaitDrawElement.isArrowLine(element)) {\n        return isHitArrowLine(board, element, point);\n    }\n\n    if (PlaitDrawElement.isVectorLine(element)) {\n        return isHitVectorLine(board, element, point);\n    }\n\n    return null;\n};\n"]}
|
package/esm2022/utils/index.mjs
CHANGED
|
@@ -11,4 +11,6 @@ export * from './snap-resizing';
|
|
|
11
11
|
export * from './table';
|
|
12
12
|
export * from './table-selected';
|
|
13
13
|
export * from './swimlane';
|
|
14
|
-
|
|
14
|
+
export * from './line';
|
|
15
|
+
export * from './vector-line';
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9kcmF3L3NyYy91dGlscy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLG9CQUFvQixDQUFDO0FBQ25DLGNBQWMsWUFBWSxDQUFDO0FBQzNCLGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYyxPQUFPLENBQUM7QUFDdEIsY0FBYyxZQUFZLENBQUM7QUFDM0IsY0FBYyxTQUFTLENBQUM7QUFDeEIsY0FBYyxPQUFPLENBQUM7QUFDdEIsY0FBYyxZQUFZLENBQUM7QUFDM0IsY0FBYyxVQUFVLENBQUM7QUFDekIsY0FBYyxpQkFBaUIsQ0FBQztBQUNoQyxjQUFjLFNBQVMsQ0FBQztBQUN4QixjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsWUFBWSxDQUFDO0FBQzNCLGNBQWMsUUFBUSxDQUFDO0FBQ3ZCLGNBQWMsZUFBZSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9hcnJvdy1saW5lL2luZGV4JztcbmV4cG9ydCAqIGZyb20gJy4vZ2VvbWV0cnknO1xuZXhwb3J0ICogZnJvbSAnLi9tdWx0aS10ZXh0LWdlb21ldHJ5JztcbmV4cG9ydCAqIGZyb20gJy4vdW1sJztcbmV4cG9ydCAqIGZyb20gJy4vc2VsZWN0ZWQnO1xuZXhwb3J0ICogZnJvbSAnLi9zdHlsZSc7XG5leHBvcnQgKiBmcm9tICcuL2hpdCc7XG5leHBvcnQgKiBmcm9tICcuL21lbW9yaXplJztcbmV4cG9ydCAqIGZyb20gJy4vY29tbW9uJztcbmV4cG9ydCAqIGZyb20gJy4vc25hcC1yZXNpemluZyc7XG5leHBvcnQgKiBmcm9tICcuL3RhYmxlJztcbmV4cG9ydCAqIGZyb20gJy4vdGFibGUtc2VsZWN0ZWQnO1xuZXhwb3J0ICogZnJvbSAnLi9zd2ltbGFuZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpbmUnO1xuZXhwb3J0ICogZnJvbSAnLi92ZWN0b3ItbGluZSc7XG4iXX0=
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
import { Point, distanceBetweenPointAndPoint } from '@plait/core';
|
|
2
|
+
import { ArrowLineShape, PlaitArrowLine, PlaitDrawElement } from '../interfaces';
|
|
3
|
+
import { getCurvePoints, getElbowLineRouteOptions, getElbowPoints, getNextSourceAndTargetPoints, isUseDefaultOrthogonalRoute } from './arrow-line';
|
|
4
|
+
import { getVectorLinePoints } from './vector-line';
|
|
5
|
+
export function getMiddlePoints(board, element) {
|
|
6
|
+
const result = [];
|
|
7
|
+
const shape = element.shape;
|
|
8
|
+
const hideBuffer = 10;
|
|
9
|
+
if (shape === ArrowLineShape.straight) {
|
|
10
|
+
const points = PlaitDrawElement.isArrowLine(element)
|
|
11
|
+
? PlaitArrowLine.getPoints(board, element)
|
|
12
|
+
: element.points;
|
|
13
|
+
for (let i = 0; i < points.length - 1; i++) {
|
|
14
|
+
const distance = distanceBetweenPointAndPoint(...points[i], ...points[i + 1]);
|
|
15
|
+
if (distance < hideBuffer)
|
|
16
|
+
continue;
|
|
17
|
+
result.push([(points[i][0] + points[i + 1][0]) / 2, (points[i][1] + points[i + 1][1]) / 2]);
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
if (shape === ArrowLineShape.curve) {
|
|
21
|
+
const points = PlaitDrawElement.isArrowLine(element)
|
|
22
|
+
? PlaitArrowLine.getPoints(board, element)
|
|
23
|
+
: element.points;
|
|
24
|
+
const pointsOnBezier = PlaitDrawElement.isArrowLine(element)
|
|
25
|
+
? getCurvePoints(board, element)
|
|
26
|
+
: getVectorLinePoints(board, element);
|
|
27
|
+
if (points.length === 2) {
|
|
28
|
+
const start = 0;
|
|
29
|
+
const endIndex = pointsOnBezier.length - 1;
|
|
30
|
+
const middleIndex = Math.round((start + endIndex) / 2);
|
|
31
|
+
result.push(pointsOnBezier[middleIndex]);
|
|
32
|
+
}
|
|
33
|
+
else {
|
|
34
|
+
for (let i = 0; i < points.length - 1; i++) {
|
|
35
|
+
const startIndex = pointsOnBezier.findIndex(point => point[0] === points[i][0] && point[1] === points[i][1]);
|
|
36
|
+
const endIndex = pointsOnBezier.findIndex(point => point[0] === points[i + 1][0] && point[1] === points[i + 1][1]);
|
|
37
|
+
const middleIndex = Math.round((startIndex + endIndex) / 2);
|
|
38
|
+
const distance = distanceBetweenPointAndPoint(...points[i], ...points[i + 1]);
|
|
39
|
+
if (distance < hideBuffer)
|
|
40
|
+
continue;
|
|
41
|
+
result.push(pointsOnBezier[middleIndex]);
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
if (shape === ArrowLineShape.elbow) {
|
|
46
|
+
const renderPoints = getElbowPoints(board, element);
|
|
47
|
+
const options = getElbowLineRouteOptions(board, element);
|
|
48
|
+
if (!isUseDefaultOrthogonalRoute(element, options)) {
|
|
49
|
+
const [nextSourcePoint, nextTargetPoint] = getNextSourceAndTargetPoints(board, element);
|
|
50
|
+
for (let i = 0; i < renderPoints.length - 1; i++) {
|
|
51
|
+
if ((i == 0 && Point.isEquals(renderPoints[i + 1], nextSourcePoint)) ||
|
|
52
|
+
(i === renderPoints.length - 2 && Point.isEquals(renderPoints[renderPoints.length - 2], nextTargetPoint))) {
|
|
53
|
+
continue;
|
|
54
|
+
}
|
|
55
|
+
const [currentX, currentY] = renderPoints[i];
|
|
56
|
+
const [nextX, nextY] = renderPoints[i + 1];
|
|
57
|
+
const middlePoint = [(currentX + nextX) / 2, (currentY + nextY) / 2];
|
|
58
|
+
result.push(middlePoint);
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
return result;
|
|
63
|
+
}
|
|
64
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"line.js","sourceRoot":"","sources":["../../../../packages/draw/src/utils/line.ts"],"names":[],"mappings":"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","sourcesContent":["import { PlaitBoard, Point, distanceBetweenPointAndPoint } from '@plait/core';\nimport { PlaitLine } from '../interfaces/line';\nimport { ArrowLineShape, PlaitArrowLine, PlaitDrawElement, PlaitVectorLine } from '../interfaces';\nimport {\n    getCurvePoints,\n    getElbowLineRouteOptions,\n    getElbowPoints,\n    getNextSourceAndTargetPoints,\n    isUseDefaultOrthogonalRoute\n} from './arrow-line';\nimport { getVectorLinePoints } from './vector-line';\n\nexport function getMiddlePoints(board: PlaitBoard, element: PlaitLine) {\n    const result: Point[] = [];\n    const shape = element.shape;\n    const hideBuffer = 10;\n    if (shape === ArrowLineShape.straight) {\n        const points = PlaitDrawElement.isArrowLine(element)\n            ? PlaitArrowLine.getPoints(board, element)\n            : (element as PlaitVectorLine).points;\n        for (let i = 0; i < points.length - 1; i++) {\n            const distance = distanceBetweenPointAndPoint(...points[i], ...points[i + 1]);\n            if (distance < hideBuffer) continue;\n            result.push([(points[i][0] + points[i + 1][0]) / 2, (points[i][1] + points[i + 1][1]) / 2]);\n        }\n    }\n    if (shape === ArrowLineShape.curve) {\n        const points = PlaitDrawElement.isArrowLine(element)\n            ? PlaitArrowLine.getPoints(board, element)\n            : (element as PlaitVectorLine).points;\n        const pointsOnBezier = PlaitDrawElement.isArrowLine(element)\n            ? getCurvePoints(board, element)\n            : getVectorLinePoints(board, element)!;\n        if (points.length === 2) {\n            const start = 0;\n            const endIndex = pointsOnBezier.length - 1;\n            const middleIndex = Math.round((start + endIndex) / 2);\n            result.push(pointsOnBezier[middleIndex]);\n        } else {\n            for (let i = 0; i < points.length - 1; i++) {\n                const startIndex = pointsOnBezier.findIndex(point => point[0] === points[i][0] && point[1] === points[i][1]);\n                const endIndex = pointsOnBezier.findIndex(point => point[0] === points[i + 1][0] && point[1] === points[i + 1][1]);\n                const middleIndex = Math.round((startIndex + endIndex) / 2);\n                const distance = distanceBetweenPointAndPoint(...points[i], ...points[i + 1]);\n                if (distance < hideBuffer) continue;\n                result.push(pointsOnBezier[middleIndex]);\n            }\n        }\n    }\n    if (shape === ArrowLineShape.elbow) {\n        const renderPoints = getElbowPoints(board, element);\n        const options = getElbowLineRouteOptions(board, element);\n        if (!isUseDefaultOrthogonalRoute(element, options)) {\n            const [nextSourcePoint, nextTargetPoint] = getNextSourceAndTargetPoints(board, element);\n            for (let i = 0; i < renderPoints.length - 1; i++) {\n                if (\n                    (i == 0 && Point.isEquals(renderPoints[i + 1], nextSourcePoint)) ||\n                    (i === renderPoints.length - 2 && Point.isEquals(renderPoints[renderPoints.length - 2], nextTargetPoint))\n                ) {\n                    continue;\n                }\n                const [currentX, currentY] = renderPoints[i];\n                const [nextX, nextY] = renderPoints[i + 1];\n                const middlePoint = [(currentX + nextX) / 2, (currentY + nextY) / 2] as Point;\n                result.push(middlePoint);\n            }\n        }\n    }\n    return result;\n}\n"]}
|
|
@@ -1,53 +1,6 @@
|
|
|
1
1
|
import { RectangleClient } from '@plait/core';
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
4
|
-
import { getArrowLinePoints, getMiddlePoints } from '../arrow-line/arrow-line-basic';
|
|
5
|
-
export var ArrowLineResizeHandle;
|
|
6
|
-
(function (ArrowLineResizeHandle) {
|
|
7
|
-
ArrowLineResizeHandle["source"] = "source";
|
|
8
|
-
ArrowLineResizeHandle["target"] = "target";
|
|
9
|
-
ArrowLineResizeHandle["addHandle"] = "addHandle";
|
|
10
|
-
})(ArrowLineResizeHandle || (ArrowLineResizeHandle = {}));
|
|
11
|
-
export const getHitArrowLineResizeHandleRef = (board, element, point) => {
|
|
12
|
-
let dataPoints = PlaitArrowLine.getPoints(board, element);
|
|
13
|
-
const index = getHitPointIndex(dataPoints, point);
|
|
14
|
-
if (index !== -1) {
|
|
15
|
-
const handleIndex = index;
|
|
16
|
-
if (index === 0) {
|
|
17
|
-
return { handle: ArrowLineResizeHandle.source, handleIndex };
|
|
18
|
-
}
|
|
19
|
-
if (index === dataPoints.length - 1) {
|
|
20
|
-
return { handle: ArrowLineResizeHandle.target, handleIndex };
|
|
21
|
-
}
|
|
22
|
-
// elbow line, data points only verify source connection point and target connection point
|
|
23
|
-
if (element.shape !== ArrowLineShape.elbow) {
|
|
24
|
-
return { handleIndex };
|
|
25
|
-
}
|
|
26
|
-
}
|
|
27
|
-
const middlePoints = getMiddlePoints(board, element);
|
|
28
|
-
const indexOfMiddlePoints = getHitPointIndex(middlePoints, point);
|
|
29
|
-
if (indexOfMiddlePoints !== -1) {
|
|
30
|
-
return {
|
|
31
|
-
handle: ArrowLineResizeHandle.addHandle,
|
|
32
|
-
handleIndex: indexOfMiddlePoints
|
|
33
|
-
};
|
|
34
|
-
}
|
|
35
|
-
return undefined;
|
|
36
|
-
};
|
|
37
|
-
export function getHitPointIndex(points, movingPoint) {
|
|
38
|
-
const rectangles = points.map(point => {
|
|
39
|
-
return {
|
|
40
|
-
x: point[0] - RESIZE_HANDLE_DIAMETER / 2,
|
|
41
|
-
y: point[1] - RESIZE_HANDLE_DIAMETER / 2,
|
|
42
|
-
width: RESIZE_HANDLE_DIAMETER,
|
|
43
|
-
height: RESIZE_HANDLE_DIAMETER
|
|
44
|
-
};
|
|
45
|
-
});
|
|
46
|
-
const rectangle = rectangles.find(rectangle => {
|
|
47
|
-
return RectangleClient.isHit(RectangleClient.getRectangleByPoints([movingPoint, movingPoint]), rectangle);
|
|
48
|
-
});
|
|
49
|
-
return rectangle ? rectangles.indexOf(rectangle) : -1;
|
|
50
|
-
}
|
|
2
|
+
import { getPointOnPolyline } from '@plait/common';
|
|
3
|
+
import { getArrowLinePoints } from '../arrow-line/arrow-line-basic';
|
|
51
4
|
export const getHitArrowLineTextIndex = (board, element, point) => {
|
|
52
5
|
const texts = element.texts;
|
|
53
6
|
if (!texts.length)
|
|
@@ -64,4 +17,4 @@ export const getHitArrowLineTextIndex = (board, element, point) => {
|
|
|
64
17
|
return RectangleClient.isHit(rectangle, RectangleClient.getRectangleByPoints([point, point]));
|
|
65
18
|
});
|
|
66
19
|
};
|
|
67
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXJyb3ctbGluZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2RyYXcvc3JjL3V0aWxzL3Bvc2l0aW9uL2Fycm93LWxpbmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFxQixlQUFlLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFFakUsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ25ELE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLGdDQUFnQyxDQUFDO0FBRXBFLE1BQU0sQ0FBQyxNQUFNLHdCQUF3QixHQUFHLENBQUMsS0FBaUIsRUFBRSxPQUF1QixFQUFFLEtBQVksRUFBRSxFQUFFO0lBQ2pHLE1BQU0sS0FBSyxHQUFHLE9BQU8sQ0FBQyxLQUFLLENBQUM7SUFDNUIsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNO1FBQUUsT0FBTyxDQUFDLENBQUMsQ0FBQztJQUU3QixNQUFNLE1BQU0sR0FBRyxrQkFBa0IsQ0FBQyxLQUFLLEVBQUUsT0FBTyxDQUFDLENBQUM7SUFDbEQsT0FBTyxLQUFLLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxFQUFFO1FBQzFCLE1BQU0sTUFBTSxHQUFHLGtCQUFrQixDQUFDLE1BQU0sRUFBRSxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUM7UUFDekQsTUFBTSxTQUFTLEdBQUc7WUFDZCxDQUFDLEVBQUUsTUFBTSxDQUFDLENBQUMsQ0FBQyxHQUFHLElBQUksQ0FBQyxLQUFNLEdBQUcsQ0FBQztZQUM5QixDQUFDLEVBQUUsTUFBTSxDQUFDLENBQUMsQ0FBQyxHQUFHLElBQUksQ0FBQyxNQUFPLEdBQUcsQ0FBQztZQUMvQixLQUFLLEVBQUUsSUFBSSxDQUFDLEtBQU07WUFDbEIsTUFBTSxFQUFFLElBQUksQ0FBQyxNQUFPO1NBQ3ZCLENBQUM7UUFDRixPQUFPLGVBQWUsQ0FBQyxLQUFLLENBQUMsU0FBUyxFQUFFLGVBQWUsQ0FBQyxvQkFBb0IsQ0FBQyxDQUFDLEtBQUssRUFBRSxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDbEcsQ0FBQyxDQUFDLENBQUM7QUFDUCxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQbGFpdEJvYXJkLCBQb2ludCwgUmVjdGFuZ2xlQ2xpZW50IH0gZnJvbSAnQHBsYWl0L2NvcmUnO1xuaW1wb3J0IHsgUGxhaXRBcnJvd0xpbmUgfSBmcm9tICcuLi8uLi9pbnRlcmZhY2VzJztcbmltcG9ydCB7IGdldFBvaW50T25Qb2x5bGluZSB9IGZyb20gJ0BwbGFpdC9jb21tb24nO1xuaW1wb3J0IHsgZ2V0QXJyb3dMaW5lUG9pbnRzIH0gZnJvbSAnLi4vYXJyb3ctbGluZS9hcnJvdy1saW5lLWJhc2ljJztcblxuZXhwb3J0IGNvbnN0IGdldEhpdEFycm93TGluZVRleHRJbmRleCA9IChib2FyZDogUGxhaXRCb2FyZCwgZWxlbWVudDogUGxhaXRBcnJvd0xpbmUsIHBvaW50OiBQb2ludCkgPT4ge1xuICAgIGNvbnN0IHRleHRzID0gZWxlbWVudC50ZXh0cztcbiAgICBpZiAoIXRleHRzLmxlbmd0aCkgcmV0dXJuIC0xO1xuXG4gICAgY29uc3QgcG9pbnRzID0gZ2V0QXJyb3dMaW5lUG9pbnRzKGJvYXJkLCBlbGVtZW50KTtcbiAgICByZXR1cm4gdGV4dHMuZmluZEluZGV4KHRleHQgPT4ge1xuICAgICAgICBjb25zdCBjZW50ZXIgPSBnZXRQb2ludE9uUG9seWxpbmUocG9pbnRzLCB0ZXh0LnBvc2l0aW9uKTtcbiAgICAgICAgY29uc3QgcmVjdGFuZ2xlID0ge1xuICAgICAgICAgICAgeDogY2VudGVyWzBdIC0gdGV4dC53aWR0aCEgLyAyLFxuICAgICAgICAgICAgeTogY2VudGVyWzFdIC0gdGV4dC5oZWlnaHQhIC8gMixcbiAgICAgICAgICAgIHdpZHRoOiB0ZXh0LndpZHRoISxcbiAgICAgICAgICAgIGhlaWdodDogdGV4dC5oZWlnaHQhXG4gICAgICAgIH07XG4gICAgICAgIHJldHVybiBSZWN0YW5nbGVDbGllbnQuaXNIaXQocmVjdGFuZ2xlLCBSZWN0YW5nbGVDbGllbnQuZ2V0UmVjdGFuZ2xlQnlQb2ludHMoW3BvaW50LCBwb2ludF0pKTtcbiAgICB9KTtcbn07XG4iXX0=
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import { RectangleClient } from '@plait/core';
|
|
2
|
+
import { ArrowLineShape, PlaitArrowLine, PlaitDrawElement } from '../../interfaces';
|
|
3
|
+
import { RESIZE_HANDLE_DIAMETER } from '@plait/common';
|
|
4
|
+
import { getMiddlePoints } from '../line';
|
|
5
|
+
export var LineResizeHandle;
|
|
6
|
+
(function (LineResizeHandle) {
|
|
7
|
+
LineResizeHandle["source"] = "source";
|
|
8
|
+
LineResizeHandle["target"] = "target";
|
|
9
|
+
LineResizeHandle["addHandle"] = "addHandle";
|
|
10
|
+
})(LineResizeHandle || (LineResizeHandle = {}));
|
|
11
|
+
export const getHitLineResizeHandleRef = (board, element, point) => {
|
|
12
|
+
let dataPoints = PlaitDrawElement.isArrowLine(element) ? PlaitArrowLine.getPoints(board, element) : element.points;
|
|
13
|
+
const index = getHitPointIndex(dataPoints, point);
|
|
14
|
+
if (index !== -1) {
|
|
15
|
+
const handleIndex = index;
|
|
16
|
+
if (index === 0) {
|
|
17
|
+
return { handle: LineResizeHandle.source, handleIndex };
|
|
18
|
+
}
|
|
19
|
+
if (index === dataPoints.length - 1) {
|
|
20
|
+
return { handle: LineResizeHandle.target, handleIndex };
|
|
21
|
+
}
|
|
22
|
+
// elbow line, data points only verify source connection point and target connection point
|
|
23
|
+
if (element.shape !== ArrowLineShape.elbow) {
|
|
24
|
+
return { handleIndex };
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
const middlePoints = getMiddlePoints(board, element);
|
|
28
|
+
const indexOfMiddlePoints = getHitPointIndex(middlePoints, point);
|
|
29
|
+
if (indexOfMiddlePoints !== -1) {
|
|
30
|
+
return {
|
|
31
|
+
handle: LineResizeHandle.addHandle,
|
|
32
|
+
handleIndex: indexOfMiddlePoints
|
|
33
|
+
};
|
|
34
|
+
}
|
|
35
|
+
return undefined;
|
|
36
|
+
};
|
|
37
|
+
export function getHitPointIndex(points, movingPoint) {
|
|
38
|
+
const rectangles = points.map(point => {
|
|
39
|
+
return {
|
|
40
|
+
x: point[0] - RESIZE_HANDLE_DIAMETER / 2,
|
|
41
|
+
y: point[1] - RESIZE_HANDLE_DIAMETER / 2,
|
|
42
|
+
width: RESIZE_HANDLE_DIAMETER,
|
|
43
|
+
height: RESIZE_HANDLE_DIAMETER
|
|
44
|
+
};
|
|
45
|
+
});
|
|
46
|
+
const rectangle = rectangles.find(rectangle => {
|
|
47
|
+
return RectangleClient.isHit(RectangleClient.getRectangleByPoints([movingPoint, movingPoint]), rectangle);
|
|
48
|
+
});
|
|
49
|
+
return rectangle ? rectangles.indexOf(rectangle) : -1;
|
|
50
|
+
}
|
|
51
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGluZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2RyYXcvc3JjL3V0aWxzL3Bvc2l0aW9uL2xpbmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFxQixlQUFlLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFDakUsT0FBTyxFQUFFLGNBQWMsRUFBRSxjQUFjLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUNwRixPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFdkQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLFNBQVMsQ0FBQztBQUUxQyxNQUFNLENBQU4sSUFBWSxnQkFJWDtBQUpELFdBQVksZ0JBQWdCO0lBQ3hCLHFDQUFtQixDQUFBO0lBQ25CLHFDQUFtQixDQUFBO0lBQ25CLDJDQUF5QixDQUFBO0FBQzdCLENBQUMsRUFKVyxnQkFBZ0IsS0FBaEIsZ0JBQWdCLFFBSTNCO0FBRUQsTUFBTSxDQUFDLE1BQU0seUJBQXlCLEdBQUcsQ0FBQyxLQUFpQixFQUFFLE9BQWtCLEVBQUUsS0FBWSxFQUFFLEVBQUU7SUFDN0YsSUFBSSxVQUFVLEdBQUcsZ0JBQWdCLENBQUMsV0FBVyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0FBQyxjQUFjLENBQUMsU0FBUyxDQUFDLEtBQUssRUFBRSxPQUFPLENBQUMsQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQztJQUNuSCxNQUFNLEtBQUssR0FBRyxnQkFBZ0IsQ0FBQyxVQUFVLEVBQUUsS0FBSyxDQUFDLENBQUM7SUFDbEQsSUFBSSxLQUFLLEtBQUssQ0FBQyxDQUFDLEVBQUUsQ0FBQztRQUNmLE1BQU0sV0FBVyxHQUFHLEtBQUssQ0FBQztRQUMxQixJQUFJLEtBQUssS0FBSyxDQUFDLEVBQUUsQ0FBQztZQUNkLE9BQU8sRUFBRSxNQUFNLEVBQUUsZ0JBQWdCLENBQUMsTUFBTSxFQUFFLFdBQVcsRUFBRSxDQUFDO1FBQzVELENBQUM7UUFDRCxJQUFJLEtBQUssS0FBSyxVQUFVLENBQUMsTUFBTSxHQUFHLENBQUMsRUFBRSxDQUFDO1lBQ2xDLE9BQU8sRUFBRSxNQUFNLEVBQUUsZ0JBQWdCLENBQUMsTUFBTSxFQUFFLFdBQVcsRUFBRSxDQUFDO1FBQzVELENBQUM7UUFDRCwwRkFBMEY7UUFDMUYsSUFBSSxPQUFPLENBQUMsS0FBSyxLQUFLLGNBQWMsQ0FBQyxLQUFLLEVBQUUsQ0FBQztZQUN6QyxPQUFPLEVBQUUsV0FBVyxFQUFFLENBQUM7UUFDM0IsQ0FBQztJQUNMLENBQUM7SUFDRCxNQUFNLFlBQVksR0FBRyxlQUFlLENBQUMsS0FBSyxFQUFFLE9BQU8sQ0FBQyxDQUFDO0lBQ3JELE1BQU0sbUJBQW1CLEdBQUcsZ0JBQWdCLENBQUMsWUFBWSxFQUFFLEtBQUssQ0FBQyxDQUFDO0lBQ2xFLElBQUksbUJBQW1CLEtBQUssQ0FBQyxDQUFDLEVBQUUsQ0FBQztRQUM3QixPQUFPO1lBQ0gsTUFBTSxFQUFFLGdCQUFnQixDQUFDLFNBQVM7WUFDbEMsV0FBVyxFQUFFLG1CQUFtQjtTQUNuQyxDQUFDO0lBQ04sQ0FBQztJQUNELE9BQU8sU0FBUyxDQUFDO0FBQ3JCLENBQUMsQ0FBQztBQUVGLE1BQU0sVUFBVSxnQkFBZ0IsQ0FBQyxNQUFlLEVBQUUsV0FBa0I7SUFDaEUsTUFBTSxVQUFVLEdBQUcsTUFBTSxDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsRUFBRTtRQUNsQyxPQUFPO1lBQ0gsQ0FBQyxFQUFFLEtBQUssQ0FBQyxDQUFDLENBQUMsR0FBRyxzQkFBc0IsR0FBRyxDQUFDO1lBQ3hDLENBQUMsRUFBRSxLQUFLLENBQUMsQ0FBQyxDQUFDLEdBQUcsc0JBQXNCLEdBQUcsQ0FBQztZQUN4QyxLQUFLLEVBQUUsc0JBQXNCO1lBQzdCLE1BQU0sRUFBRSxzQkFBc0I7U0FDakMsQ0FBQztJQUNOLENBQUMsQ0FBQyxDQUFDO0lBQ0gsTUFBTSxTQUFTLEdBQUcsVUFBVSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsRUFBRTtRQUMxQyxPQUFPLGVBQWUsQ0FBQyxLQUFLLENBQUMsZUFBZSxDQUFDLG9CQUFvQixDQUFDLENBQUMsV0FBVyxFQUFFLFdBQVcsQ0FBQyxDQUFDLEVBQUUsU0FBUyxDQUFDLENBQUM7SUFDOUcsQ0FBQyxDQUFDLENBQUM7SUFDSCxPQUFPLFNBQVMsQ0FBQyxDQUFDLENBQUMsVUFBVSxDQUFDLE9BQU8sQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7QUFDMUQsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBsYWl0Qm9hcmQsIFBvaW50LCBSZWN0YW5nbGVDbGllbnQgfSBmcm9tICdAcGxhaXQvY29yZSc7XG5pbXBvcnQgeyBBcnJvd0xpbmVTaGFwZSwgUGxhaXRBcnJvd0xpbmUsIFBsYWl0RHJhd0VsZW1lbnQgfSBmcm9tICcuLi8uLi9pbnRlcmZhY2VzJztcbmltcG9ydCB7IFJFU0laRV9IQU5ETEVfRElBTUVURVIgfSBmcm9tICdAcGxhaXQvY29tbW9uJztcbmltcG9ydCB7IFBsYWl0TGluZSB9IGZyb20gJy4uLy4uL2ludGVyZmFjZXMvbGluZSc7XG5pbXBvcnQgeyBnZXRNaWRkbGVQb2ludHMgfSBmcm9tICcuLi9saW5lJztcblxuZXhwb3J0IGVudW0gTGluZVJlc2l6ZUhhbmRsZSB7XG4gICAgJ3NvdXJjZScgPSAnc291cmNlJyxcbiAgICAndGFyZ2V0JyA9ICd0YXJnZXQnLFxuICAgICdhZGRIYW5kbGUnID0gJ2FkZEhhbmRsZSdcbn1cblxuZXhwb3J0IGNvbnN0IGdldEhpdExpbmVSZXNpemVIYW5kbGVSZWYgPSAoYm9hcmQ6IFBsYWl0Qm9hcmQsIGVsZW1lbnQ6IFBsYWl0TGluZSwgcG9pbnQ6IFBvaW50KSA9PiB7XG4gICAgbGV0IGRhdGFQb2ludHMgPSBQbGFpdERyYXdFbGVtZW50LmlzQXJyb3dMaW5lKGVsZW1lbnQpID8gUGxhaXRBcnJvd0xpbmUuZ2V0UG9pbnRzKGJvYXJkLCBlbGVtZW50KSA6IGVsZW1lbnQucG9pbnRzO1xuICAgIGNvbnN0IGluZGV4ID0gZ2V0SGl0UG9pbnRJbmRleChkYXRhUG9pbnRzLCBwb2ludCk7XG4gICAgaWYgKGluZGV4ICE9PSAtMSkge1xuICAgICAgICBjb25zdCBoYW5kbGVJbmRleCA9IGluZGV4O1xuICAgICAgICBpZiAoaW5kZXggPT09IDApIHtcbiAgICAgICAgICAgIHJldHVybiB7IGhhbmRsZTogTGluZVJlc2l6ZUhhbmRsZS5zb3VyY2UsIGhhbmRsZUluZGV4IH07XG4gICAgICAgIH1cbiAgICAgICAgaWYgKGluZGV4ID09PSBkYXRhUG9pbnRzLmxlbmd0aCAtIDEpIHtcbiAgICAgICAgICAgIHJldHVybiB7IGhhbmRsZTogTGluZVJlc2l6ZUhhbmRsZS50YXJnZXQsIGhhbmRsZUluZGV4IH07XG4gICAgICAgIH1cbiAgICAgICAgLy8gZWxib3cgbGluZSwgZGF0YSBwb2ludHMgb25seSB2ZXJpZnkgc291cmNlIGNvbm5lY3Rpb24gcG9pbnQgYW5kIHRhcmdldCBjb25uZWN0aW9uIHBvaW50XG4gICAgICAgIGlmIChlbGVtZW50LnNoYXBlICE9PSBBcnJvd0xpbmVTaGFwZS5lbGJvdykge1xuICAgICAgICAgICAgcmV0dXJuIHsgaGFuZGxlSW5kZXggfTtcbiAgICAgICAgfVxuICAgIH1cbiAgICBjb25zdCBtaWRkbGVQb2ludHMgPSBnZXRNaWRkbGVQb2ludHMoYm9hcmQsIGVsZW1lbnQpO1xuICAgIGNvbnN0IGluZGV4T2ZNaWRkbGVQb2ludHMgPSBnZXRIaXRQb2ludEluZGV4KG1pZGRsZVBvaW50cywgcG9pbnQpO1xuICAgIGlmIChpbmRleE9mTWlkZGxlUG9pbnRzICE9PSAtMSkge1xuICAgICAgICByZXR1cm4ge1xuICAgICAgICAgICAgaGFuZGxlOiBMaW5lUmVzaXplSGFuZGxlLmFkZEhhbmRsZSxcbiAgICAgICAgICAgIGhhbmRsZUluZGV4OiBpbmRleE9mTWlkZGxlUG9pbnRzXG4gICAgICAgIH07XG4gICAgfVxuICAgIHJldHVybiB1bmRlZmluZWQ7XG59O1xuXG5leHBvcnQgZnVuY3Rpb24gZ2V0SGl0UG9pbnRJbmRleChwb2ludHM6IFBvaW50W10sIG1vdmluZ1BvaW50OiBQb2ludCkge1xuICAgIGNvbnN0IHJlY3RhbmdsZXMgPSBwb2ludHMubWFwKHBvaW50ID0+IHtcbiAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICAgIHg6IHBvaW50WzBdIC0gUkVTSVpFX0hBTkRMRV9ESUFNRVRFUiAvIDIsXG4gICAgICAgICAgICB5OiBwb2ludFsxXSAtIFJFU0laRV9IQU5ETEVfRElBTUVURVIgLyAyLFxuICAgICAgICAgICAgd2lkdGg6IFJFU0laRV9IQU5ETEVfRElBTUVURVIsXG4gICAgICAgICAgICBoZWlnaHQ6IFJFU0laRV9IQU5ETEVfRElBTUVURVJcbiAgICAgICAgfTtcbiAgICB9KTtcbiAgICBjb25zdCByZWN0YW5nbGUgPSByZWN0YW5nbGVzLmZpbmQocmVjdGFuZ2xlID0+IHtcbiAgICAgICAgcmV0dXJuIFJlY3RhbmdsZUNsaWVudC5pc0hpdChSZWN0YW5nbGVDbGllbnQuZ2V0UmVjdGFuZ2xlQnlQb2ludHMoW21vdmluZ1BvaW50LCBtb3ZpbmdQb2ludF0pLCByZWN0YW5nbGUpO1xuICAgIH0pO1xuICAgIHJldHVybiByZWN0YW5nbGUgPyByZWN0YW5nbGVzLmluZGV4T2YocmVjdGFuZ2xlKSA6IC0xO1xufVxuIl19
|
|
@@ -12,6 +12,10 @@ export const getSelectedArrowLineElements = (board) => {
|
|
|
12
12
|
const selectedElements = getSelectedElements(board).filter(value => PlaitDrawElement.isArrowLine(value));
|
|
13
13
|
return selectedElements;
|
|
14
14
|
};
|
|
15
|
+
export const getSelectedVectorLineElements = (board) => {
|
|
16
|
+
const selectedElements = getSelectedElements(board).filter(value => PlaitDrawElement.isVectorLine(value));
|
|
17
|
+
return selectedElements;
|
|
18
|
+
};
|
|
15
19
|
export const getSelectedImageElements = (board) => {
|
|
16
20
|
const selectedElements = getSelectedElements(board).filter(value => PlaitDrawElement.isImage(value));
|
|
17
21
|
return selectedElements;
|
|
@@ -24,4 +28,4 @@ export const getSelectedSwimlane = (board) => {
|
|
|
24
28
|
const selectedElements = getSelectedElements(board);
|
|
25
29
|
return selectedElements.find(item => PlaitDrawElement.isSwimlane(item));
|
|
26
30
|
};
|
|
27
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
31
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0ZWQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9kcmF3L3NyYy91dGlscy9zZWxlY3RlZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQTRCLG1CQUFtQixFQUFFLE1BQU0sYUFBYSxDQUFDO0FBQzVFLE9BQU8sRUFBa0IsZ0JBQWdCLEVBQWlELE1BQU0sZUFBZSxDQUFDO0FBSWhILE1BQU0sQ0FBQyxNQUFNLHVCQUF1QixHQUFHLENBQUMsS0FBaUIsRUFBRSxRQUF5QixFQUFFLEVBQUU7SUFDcEYsTUFBTSxnQkFBZ0IsR0FBRyxRQUFRLEVBQUUsTUFBTSxDQUFDLENBQUMsQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDLG1CQUFtQixDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ2xGLE9BQU8sZ0JBQWdCLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUMsZ0JBQWdCLENBQUMsYUFBYSxDQUFDLEtBQUssQ0FBQyxDQUF1QixDQUFDO0FBQ3pHLENBQUMsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLDJCQUEyQixHQUFHLENBQUMsS0FBaUIsRUFBRSxFQUFFO0lBQzdELE1BQU0sZ0JBQWdCLEdBQUcsbUJBQW1CLENBQUMsS0FBSyxDQUFDLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUMsZ0JBQWdCLENBQUMsVUFBVSxDQUFDLEtBQUssQ0FBQyxDQUFvQixDQUFDO0lBQzNILE9BQU8sZ0JBQWdCLENBQUM7QUFDNUIsQ0FBQyxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sNEJBQTRCLEdBQUcsQ0FBQyxLQUFpQixFQUFFLEVBQUU7SUFDOUQsTUFBTSxnQkFBZ0IsR0FBRyxtQkFBbUIsQ0FBQyxLQUFLLENBQUMsQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxnQkFBZ0IsQ0FBQyxXQUFXLENBQUMsS0FBSyxDQUFDLENBQXFCLENBQUM7SUFDN0gsT0FBTyxnQkFBZ0IsQ0FBQztBQUM1QixDQUFDLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSw2QkFBNkIsR0FBRyxDQUFDLEtBQWlCLEVBQUUsRUFBRTtJQUMvRCxNQUFNLGdCQUFnQixHQUFHLG1CQUFtQixDQUFDLEtBQUssQ0FBQyxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLGdCQUFnQixDQUFDLFlBQVksQ0FBQyxLQUFLLENBQUMsQ0FBc0IsQ0FBQztJQUMvSCxPQUFPLGdCQUFnQixDQUFDO0FBQzVCLENBQUMsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLHdCQUF3QixHQUFHLENBQUMsS0FBaUIsRUFBRSxFQUFFO0lBQzFELE1BQU0sZ0JBQWdCLEdBQUcsbUJBQW1CLENBQUMsS0FBSyxDQUFDLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUMsZ0JBQWdCLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxDQUFpQixDQUFDO0lBQ3JILE9BQU8sZ0JBQWdCLENBQUM7QUFDNUIsQ0FBQyxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sc0JBQXNCLEdBQUcsQ0FBQyxLQUFpQixFQUFFLEVBQUU7SUFDeEQsTUFBTSxnQkFBZ0IsR0FBRyxtQkFBbUIsQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUNwRCxPQUFPLGdCQUFnQixJQUFJLGdCQUFnQixDQUFDLE1BQU0sS0FBSyxDQUFDLElBQUksZ0JBQWdCLENBQUMsVUFBVSxDQUFDLGdCQUFnQixDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7QUFDakgsQ0FBQyxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sbUJBQW1CLEdBQUcsQ0FBQyxLQUFpQixFQUFpQixFQUFFO0lBQ3BFLE1BQU0sZ0JBQWdCLEdBQUcsbUJBQW1CLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDcEQsT0FBTyxnQkFBZ0IsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxnQkFBZ0IsQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLENBQWtCLENBQUM7QUFDN0YsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUGxhaXRCb2FyZCwgUGxhaXRFbGVtZW50LCBnZXRTZWxlY3RlZEVsZW1lbnRzIH0gZnJvbSAnQHBsYWl0L2NvcmUnO1xuaW1wb3J0IHsgUGxhaXRBcnJvd0xpbmUsIFBsYWl0RHJhd0VsZW1lbnQsIFBsYWl0R2VvbWV0cnksIFBsYWl0U3dpbWxhbmUsIFBsYWl0VmVjdG9yTGluZSB9IGZyb20gJy4uL2ludGVyZmFjZXMnO1xuaW1wb3J0IHsgUGxhaXRJbWFnZSB9IGZyb20gJy4uL2ludGVyZmFjZXMvaW1hZ2UnO1xuaW1wb3J0IHsgUGxhaXRUYWJsZSwgUGxhaXRUYWJsZUVsZW1lbnQgfSBmcm9tICcuLi9pbnRlcmZhY2VzL3RhYmxlJztcblxuZXhwb3J0IGNvbnN0IGdldFNlbGVjdGVkRHJhd0VsZW1lbnRzID0gKGJvYXJkOiBQbGFpdEJvYXJkLCBlbGVtZW50cz86IFBsYWl0RWxlbWVudFtdKSA9PiB7XG4gICAgY29uc3Qgc2VsZWN0ZWRFbGVtZW50cyA9IGVsZW1lbnRzPy5sZW5ndGggPyBlbGVtZW50cyA6IGdldFNlbGVjdGVkRWxlbWVudHMoYm9hcmQpO1xuICAgIHJldHVybiBzZWxlY3RlZEVsZW1lbnRzLmZpbHRlcih2YWx1ZSA9PiBQbGFpdERyYXdFbGVtZW50LmlzRHJhd0VsZW1lbnQodmFsdWUpKSBhcyBQbGFpdERyYXdFbGVtZW50W107XG59O1xuXG5leHBvcnQgY29uc3QgZ2V0U2VsZWN0ZWRHZW9tZXRyeUVsZW1lbnRzID0gKGJvYXJkOiBQbGFpdEJvYXJkKSA9PiB7XG4gICAgY29uc3Qgc2VsZWN0ZWRFbGVtZW50cyA9IGdldFNlbGVjdGVkRWxlbWVudHMoYm9hcmQpLmZpbHRlcih2YWx1ZSA9PiBQbGFpdERyYXdFbGVtZW50LmlzR2VvbWV0cnkodmFsdWUpKSBhcyBQbGFpdEdlb21ldHJ5W107XG4gICAgcmV0dXJuIHNlbGVjdGVkRWxlbWVudHM7XG59O1xuXG5leHBvcnQgY29uc3QgZ2V0U2VsZWN0ZWRBcnJvd0xpbmVFbGVtZW50cyA9IChib2FyZDogUGxhaXRCb2FyZCkgPT4ge1xuICAgIGNvbnN0IHNlbGVjdGVkRWxlbWVudHMgPSBnZXRTZWxlY3RlZEVsZW1lbnRzKGJvYXJkKS5maWx0ZXIodmFsdWUgPT4gUGxhaXREcmF3RWxlbWVudC5pc0Fycm93TGluZSh2YWx1ZSkpIGFzIFBsYWl0QXJyb3dMaW5lW107XG4gICAgcmV0dXJuIHNlbGVjdGVkRWxlbWVudHM7XG59O1xuXG5leHBvcnQgY29uc3QgZ2V0U2VsZWN0ZWRWZWN0b3JMaW5lRWxlbWVudHMgPSAoYm9hcmQ6IFBsYWl0Qm9hcmQpID0+IHtcbiAgICBjb25zdCBzZWxlY3RlZEVsZW1lbnRzID0gZ2V0U2VsZWN0ZWRFbGVtZW50cyhib2FyZCkuZmlsdGVyKHZhbHVlID0+IFBsYWl0RHJhd0VsZW1lbnQuaXNWZWN0b3JMaW5lKHZhbHVlKSkgYXMgUGxhaXRWZWN0b3JMaW5lW107XG4gICAgcmV0dXJuIHNlbGVjdGVkRWxlbWVudHM7XG59O1xuXG5leHBvcnQgY29uc3QgZ2V0U2VsZWN0ZWRJbWFnZUVsZW1lbnRzID0gKGJvYXJkOiBQbGFpdEJvYXJkKSA9PiB7XG4gICAgY29uc3Qgc2VsZWN0ZWRFbGVtZW50cyA9IGdldFNlbGVjdGVkRWxlbWVudHMoYm9hcmQpLmZpbHRlcih2YWx1ZSA9PiBQbGFpdERyYXdFbGVtZW50LmlzSW1hZ2UodmFsdWUpKSBhcyBQbGFpdEltYWdlW107XG4gICAgcmV0dXJuIHNlbGVjdGVkRWxlbWVudHM7XG59O1xuXG5leHBvcnQgY29uc3QgaXNTaW5nbGVTZWxlY3RTd2ltbGFuZSA9IChib2FyZDogUGxhaXRCb2FyZCkgPT4ge1xuICAgIGNvbnN0IHNlbGVjdGVkRWxlbWVudHMgPSBnZXRTZWxlY3RlZEVsZW1lbnRzKGJvYXJkKTtcbiAgICByZXR1cm4gc2VsZWN0ZWRFbGVtZW50cyAmJiBzZWxlY3RlZEVsZW1lbnRzLmxlbmd0aCA9PT0gMSAmJiBQbGFpdERyYXdFbGVtZW50LmlzU3dpbWxhbmUoc2VsZWN0ZWRFbGVtZW50c1swXSk7XG59O1xuXG5leHBvcnQgY29uc3QgZ2V0U2VsZWN0ZWRTd2ltbGFuZSA9IChib2FyZDogUGxhaXRCb2FyZCk6IFBsYWl0U3dpbWxhbmUgPT4ge1xuICAgIGNvbnN0IHNlbGVjdGVkRWxlbWVudHMgPSBnZXRTZWxlY3RlZEVsZW1lbnRzKGJvYXJkKTtcbiAgICByZXR1cm4gc2VsZWN0ZWRFbGVtZW50cy5maW5kKGl0ZW0gPT4gUGxhaXREcmF3RWxlbWVudC5pc1N3aW1sYW5lKGl0ZW0pKSBhcyBQbGFpdFN3aW1sYW5lO1xufTtcbiJdfQ==
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
import { PlaitBoard, catmullRomFitting, createG, drawLinearPath, idCreator, setStrokeLinecap } from '@plait/core';
|
|
2
|
+
import { StrokeStyle, VectorLineShape } from '../interfaces';
|
|
3
|
+
import { getLineMemorizedLatest } from './memorize';
|
|
4
|
+
import { DefaultLineStyle } from '../constants/line';
|
|
5
|
+
import { alignPoints } from './arrow-line';
|
|
6
|
+
import { getStrokeWidthByElement } from './common';
|
|
7
|
+
import { getFillByElement, getLineDashByElement, getStrokeColorByElement } from './style';
|
|
8
|
+
import { VectorLineShapeGenerator } from '../generators/vector-line-generator';
|
|
9
|
+
import { pointsOnBezierCurves } from 'points-on-curve';
|
|
10
|
+
export const isClosedVectorLine = (vectorLine) => {
|
|
11
|
+
const points = vectorLine.points;
|
|
12
|
+
const startPoint = points[0];
|
|
13
|
+
const endPoint = points[points.length - 1];
|
|
14
|
+
return startPoint[0] === endPoint[0] && startPoint[1] === endPoint[1];
|
|
15
|
+
};
|
|
16
|
+
export const getVectorLinePoints = (board, element) => {
|
|
17
|
+
switch (element.shape) {
|
|
18
|
+
case VectorLineShape.straight: {
|
|
19
|
+
return element.points;
|
|
20
|
+
}
|
|
21
|
+
case VectorLineShape.curve: {
|
|
22
|
+
if (element.points.length === 2) {
|
|
23
|
+
return pointsOnBezierCurves(element.points);
|
|
24
|
+
}
|
|
25
|
+
else {
|
|
26
|
+
let dataPoints = element.points;
|
|
27
|
+
const points = catmullRomFitting(dataPoints);
|
|
28
|
+
return pointsOnBezierCurves(points);
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
default:
|
|
32
|
+
return null;
|
|
33
|
+
}
|
|
34
|
+
};
|
|
35
|
+
export const createVectorLineElement = (shape, points, options) => {
|
|
36
|
+
return {
|
|
37
|
+
id: idCreator(),
|
|
38
|
+
type: 'vector-line',
|
|
39
|
+
shape,
|
|
40
|
+
opacity: 1,
|
|
41
|
+
points,
|
|
42
|
+
...options
|
|
43
|
+
};
|
|
44
|
+
};
|
|
45
|
+
export const vectorLineCreating = (board, lineShape, points, movingPoint, lineShapeG) => {
|
|
46
|
+
const lineGenerator = new VectorLineShapeGenerator(board);
|
|
47
|
+
const memorizedLatest = getLineMemorizedLatest();
|
|
48
|
+
const temporaryLineElement = createVectorLineElement(lineShape, [...points, movingPoint], {
|
|
49
|
+
strokeWidth: DefaultLineStyle.strokeWidth,
|
|
50
|
+
...memorizedLatest
|
|
51
|
+
});
|
|
52
|
+
const otherPoint = points[points.length - 1];
|
|
53
|
+
temporaryLineElement.points[temporaryLineElement.points.length - 1] = alignPoints(otherPoint, movingPoint);
|
|
54
|
+
lineGenerator.processDrawing(temporaryLineElement, lineShapeG);
|
|
55
|
+
PlaitBoard.getElementActiveHost(board).append(lineShapeG);
|
|
56
|
+
return temporaryLineElement;
|
|
57
|
+
};
|
|
58
|
+
export const drawVectorLine = (board, element) => {
|
|
59
|
+
const strokeWidth = getStrokeWidthByElement(element);
|
|
60
|
+
const strokeColor = getStrokeColorByElement(board, element);
|
|
61
|
+
const strokeLineDash = getLineDashByElement(element);
|
|
62
|
+
const fill = getFillByElement(board, element);
|
|
63
|
+
const options = { stroke: strokeColor, strokeWidth, strokeLineDash, fill };
|
|
64
|
+
const lineG = createG();
|
|
65
|
+
let points = getVectorLinePoints(board, element);
|
|
66
|
+
const line = drawLinearPath(points, options);
|
|
67
|
+
const id = idCreator();
|
|
68
|
+
line.setAttribute('mask', `url(#${id})`);
|
|
69
|
+
if (element.strokeStyle === StrokeStyle.dotted) {
|
|
70
|
+
setStrokeLinecap(line, 'round');
|
|
71
|
+
}
|
|
72
|
+
lineG.appendChild(line);
|
|
73
|
+
return lineG;
|
|
74
|
+
};
|
|
75
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"vector-line.js","sourceRoot":"","sources":["../../../../packages/draw/src/utils/vector-line.ts"],"names":[],"mappings":"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","sourcesContent":["import { PlaitBoard, Point, catmullRomFitting, createG, drawLinearPath, idCreator, setStrokeLinecap } from '@plait/core';\nimport { PlaitVectorLine, StrokeStyle, VectorLineShape } from '../interfaces';\nimport { getLineMemorizedLatest } from './memorize';\nimport { DefaultLineStyle } from '../constants/line';\nimport { alignPoints } from './arrow-line';\nimport { getStrokeWidthByElement } from './common';\nimport { getFillByElement, getLineDashByElement, getStrokeColorByElement } from './style';\nimport { VectorLineShapeGenerator } from '../generators/vector-line-generator';\nimport { pointsOnBezierCurves } from 'points-on-curve';\nimport { removeDuplicatePoints } from '@plait/common';\n\nexport const isClosedVectorLine = (vectorLine: PlaitVectorLine) => {\n    const points = vectorLine.points;\n    const startPoint = points[0];\n    const endPoint = points[points.length - 1];\n    return startPoint[0] === endPoint[0] && startPoint[1] === endPoint[1];\n};\n\nexport const getVectorLinePoints = (board: PlaitBoard, element: PlaitVectorLine) => {\n    switch (element.shape) {\n        case VectorLineShape.straight: {\n            return element.points;\n        }\n        case VectorLineShape.curve: {\n            if (element.points.length === 2) {\n                return pointsOnBezierCurves(element.points) as Point[];\n            } else {\n                let dataPoints = element.points;\n                const points = catmullRomFitting(dataPoints);\n                return pointsOnBezierCurves(points) as Point[];\n            }\n        }\n        default:\n            return null;\n    }\n};\n\nexport const createVectorLineElement = (\n    shape: VectorLineShape,\n    points: Point[],\n    options?: Pick<PlaitVectorLine, 'strokeColor' | 'strokeWidth' | 'fill'>\n): PlaitVectorLine => {\n    return {\n        id: idCreator(),\n        type: 'vector-line',\n        shape,\n        opacity: 1,\n        points,\n        ...options\n    };\n};\n\nexport const vectorLineCreating = (\n    board: PlaitBoard,\n    lineShape: VectorLineShape,\n    points: Point[],\n    movingPoint: Point,\n    lineShapeG: SVGGElement\n) => {\n    const lineGenerator = new VectorLineShapeGenerator(board);\n    const memorizedLatest = getLineMemorizedLatest();\n\n    const temporaryLineElement = createVectorLineElement(lineShape, [...points, movingPoint], {\n        strokeWidth: DefaultLineStyle.strokeWidth,\n        ...memorizedLatest\n    });\n    const otherPoint = points[points.length - 1];\n    temporaryLineElement.points[temporaryLineElement.points.length - 1] = alignPoints(otherPoint, movingPoint);\n    lineGenerator.processDrawing(temporaryLineElement, lineShapeG);\n    PlaitBoard.getElementActiveHost(board).append(lineShapeG);\n    return temporaryLineElement;\n};\n\nexport const drawVectorLine = (board: PlaitBoard, element: PlaitVectorLine) => {\n    const strokeWidth = getStrokeWidthByElement(element);\n    const strokeColor = getStrokeColorByElement(board, element);\n    const strokeLineDash = getLineDashByElement(element);\n    const fill = getFillByElement(board, element);\n    const options = { stroke: strokeColor, strokeWidth, strokeLineDash, fill };\n    const lineG = createG();\n    let points = getVectorLinePoints(board, element)!;\n    const line = drawLinearPath(points, options);\n    const id = idCreator();\n    line.setAttribute('mask', `url(#${id})`);\n    if (element.strokeStyle === StrokeStyle.dotted) {\n        setStrokeLinecap(line, 'round');\n    }\n    lineG.appendChild(line);\n    return lineG;\n};\n"]}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import { PlaitBoard } from '@plait/core';
|
|
2
|
+
import { LineActiveGenerator } from './generators/line-active.generator';
|
|
3
|
+
import { CommonElementFlavour } from '@plait/common';
|
|
4
|
+
import { getVectorLinePoints } from './utils';
|
|
5
|
+
import { VectorLineShapeGenerator } from './generators/vector-line-generator';
|
|
6
|
+
export class VectorLineComponent extends CommonElementFlavour {
|
|
7
|
+
constructor() {
|
|
8
|
+
super();
|
|
9
|
+
}
|
|
10
|
+
initializeGenerator() {
|
|
11
|
+
this.shapeGenerator = new VectorLineShapeGenerator(this.board);
|
|
12
|
+
this.activeGenerator = new LineActiveGenerator(this.board);
|
|
13
|
+
}
|
|
14
|
+
initialize() {
|
|
15
|
+
this.initializeGenerator();
|
|
16
|
+
this.shapeGenerator.processDrawing(this.element, this.getElementG());
|
|
17
|
+
const linePoints = getVectorLinePoints(this.board, this.element);
|
|
18
|
+
this.activeGenerator.processDrawing(this.element, PlaitBoard.getElementActiveHost(this.board), {
|
|
19
|
+
selected: this.selected,
|
|
20
|
+
linePoints
|
|
21
|
+
});
|
|
22
|
+
super.initialize();
|
|
23
|
+
}
|
|
24
|
+
onContextChanged(value, previous) {
|
|
25
|
+
this.initializeWeakMap();
|
|
26
|
+
const isChangeTheme = this.board.operations.find(op => op.type === 'set_theme');
|
|
27
|
+
const linePoints = getVectorLinePoints(this.board, this.element);
|
|
28
|
+
if (value.element !== previous.element || isChangeTheme) {
|
|
29
|
+
this.shapeGenerator.processDrawing(this.element, this.getElementG());
|
|
30
|
+
this.activeGenerator.processDrawing(this.element, PlaitBoard.getElementActiveHost(this.board), {
|
|
31
|
+
selected: this.selected,
|
|
32
|
+
linePoints
|
|
33
|
+
});
|
|
34
|
+
}
|
|
35
|
+
else {
|
|
36
|
+
const needUpdate = value.selected !== previous.selected || this.activeGenerator.needUpdate();
|
|
37
|
+
if (needUpdate) {
|
|
38
|
+
this.activeGenerator.processDrawing(this.element, PlaitBoard.getElementActiveHost(this.board), {
|
|
39
|
+
selected: this.selected,
|
|
40
|
+
linePoints
|
|
41
|
+
});
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
destroy() {
|
|
46
|
+
super.destroy();
|
|
47
|
+
this.activeGenerator.destroy();
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVjdG9yLWxpbmUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vcGFja2FnZXMvZHJhdy9zcmMvdmVjdG9yLWxpbmUuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQStDLE1BQU0sYUFBYSxDQUFDO0FBRXRGLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLG9DQUFvQyxDQUFDO0FBQ3pFLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNyRCxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxTQUFTLENBQUM7QUFDOUMsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0sb0NBQW9DLENBQUM7QUFFOUUsTUFBTSxPQUFPLG1CQUFvQixTQUFRLG9CQUFpRDtJQU10RjtRQUNJLEtBQUssRUFBRSxDQUFDO0lBQ1osQ0FBQztJQUVELG1CQUFtQjtRQUNmLElBQUksQ0FBQyxjQUFjLEdBQUcsSUFBSSx3QkFBd0IsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDL0QsSUFBSSxDQUFDLGVBQWUsR0FBRyxJQUFJLG1CQUFtQixDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUMvRCxDQUFDO0lBRUQsVUFBVTtRQUNOLElBQUksQ0FBQyxtQkFBbUIsRUFBRSxDQUFDO1FBQzNCLElBQUksQ0FBQyxjQUFjLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDLENBQUM7UUFDckUsTUFBTSxVQUFVLEdBQUcsbUJBQW1CLENBQUMsSUFBSSxDQUFDLEtBQUssRUFBRSxJQUFJLENBQUMsT0FBTyxDQUFFLENBQUM7UUFDbEUsSUFBSSxDQUFDLGVBQWUsQ0FBQyxjQUFjLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRSxVQUFVLENBQUMsb0JBQW9CLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxFQUFFO1lBQzNGLFFBQVEsRUFBRSxJQUFJLENBQUMsUUFBUTtZQUN2QixVQUFVO1NBQ2IsQ0FBQyxDQUFDO1FBQ0gsS0FBSyxDQUFDLFVBQVUsRUFBRSxDQUFDO0lBQ3ZCLENBQUM7SUFFRCxnQkFBZ0IsQ0FDWixLQUE2RCxFQUM3RCxRQUFnRTtRQUVoRSxJQUFJLENBQUMsaUJBQWlCLEVBQUUsQ0FBQztRQUN6QixNQUFNLGFBQWEsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsSUFBSSxLQUFLLFdBQVcsQ0FBQyxDQUFDO1FBQ2hGLE1BQU0sVUFBVSxHQUFHLG1CQUFtQixDQUFDLElBQUksQ0FBQyxLQUFLLEVBQUUsSUFBSSxDQUFDLE9BQU8sQ0FBRSxDQUFDO1FBQ2xFLElBQUksS0FBSyxDQUFDLE9BQU8sS0FBSyxRQUFRLENBQUMsT0FBTyxJQUFJLGFBQWEsRUFBRSxDQUFDO1lBQ3RELElBQUksQ0FBQyxjQUFjLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDLENBQUM7WUFDckUsSUFBSSxDQUFDLGVBQWUsQ0FBQyxjQUFjLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRSxVQUFVLENBQUMsb0JBQW9CLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxFQUFFO2dCQUMzRixRQUFRLEVBQUUsSUFBSSxDQUFDLFFBQVE7Z0JBQ3ZCLFVBQVU7YUFDYixDQUFDLENBQUM7UUFDUCxDQUFDO2FBQU0sQ0FBQztZQUNKLE1BQU0sVUFBVSxHQUFHLEtBQUssQ0FBQyxRQUFRLEtBQUssUUFBUSxDQUFDLFFBQVEsSUFBSSxJQUFJLENBQUMsZUFBZSxDQUFDLFVBQVUsRUFBRSxDQUFDO1lBQzdGLElBQUksVUFBVSxFQUFFLENBQUM7Z0JBQ2IsSUFBSSxDQUFDLGVBQWUsQ0FBQyxjQUFjLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRSxVQUFVLENBQUMsb0JBQW9CLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxFQUFFO29CQUMzRixRQUFRLEVBQUUsSUFBSSxDQUFDLFFBQVE7b0JBQ3ZCLFVBQVU7aUJBQ2IsQ0FBQyxDQUFDO1lBQ1AsQ0FBQztRQUNMLENBQUM7SUFDTCxDQUFDO0lBRUQsT0FBTztRQUNILEtBQUssQ0FBQyxPQUFPLEVBQUUsQ0FBQztRQUNoQixJQUFJLENBQUMsZUFBZSxDQUFDLE9BQU8sRUFBRSxDQUFDO0lBQ25DLENBQUM7Q0FDSiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBsYWl0Qm9hcmQsIFBsYWl0UGx1Z2luRWxlbWVudENvbnRleHQsIE9uQ29udGV4dENoYW5nZWQgfSBmcm9tICdAcGxhaXQvY29yZSc7XG5pbXBvcnQgeyBQbGFpdFZlY3RvckxpbmUgfSBmcm9tICcuL2ludGVyZmFjZXMnO1xuaW1wb3J0IHsgTGluZUFjdGl2ZUdlbmVyYXRvciB9IGZyb20gJy4vZ2VuZXJhdG9ycy9saW5lLWFjdGl2ZS5nZW5lcmF0b3InO1xuaW1wb3J0IHsgQ29tbW9uRWxlbWVudEZsYXZvdXIgfSBmcm9tICdAcGxhaXQvY29tbW9uJztcbmltcG9ydCB7IGdldFZlY3RvckxpbmVQb2ludHMgfSBmcm9tICcuL3V0aWxzJztcbmltcG9ydCB7IFZlY3RvckxpbmVTaGFwZUdlbmVyYXRvciB9IGZyb20gJy4vZ2VuZXJhdG9ycy92ZWN0b3ItbGluZS1nZW5lcmF0b3InO1xuXG5leHBvcnQgY2xhc3MgVmVjdG9yTGluZUNvbXBvbmVudCBleHRlbmRzIENvbW1vbkVsZW1lbnRGbGF2b3VyPFBsYWl0VmVjdG9yTGluZSwgUGxhaXRCb2FyZD5cbiAgICBpbXBsZW1lbnRzIE9uQ29udGV4dENoYW5nZWQ8UGxhaXRWZWN0b3JMaW5lLCBQbGFpdEJvYXJkPiB7XG4gICAgc2hhcGVHZW5lcmF0b3IhOiBWZWN0b3JMaW5lU2hhcGVHZW5lcmF0b3I7XG5cbiAgICBhY3RpdmVHZW5lcmF0b3IhOiBMaW5lQWN0aXZlR2VuZXJhdG9yO1xuXG4gICAgY29uc3RydWN0b3IoKSB7XG4gICAgICAgIHN1cGVyKCk7XG4gICAgfVxuXG4gICAgaW5pdGlhbGl6ZUdlbmVyYXRvcigpIHtcbiAgICAgICAgdGhpcy5zaGFwZUdlbmVyYXRvciA9IG5ldyBWZWN0b3JMaW5lU2hhcGVHZW5lcmF0b3IodGhpcy5ib2FyZCk7XG4gICAgICAgIHRoaXMuYWN0aXZlR2VuZXJhdG9yID0gbmV3IExpbmVBY3RpdmVHZW5lcmF0b3IodGhpcy5ib2FyZCk7XG4gICAgfVxuXG4gICAgaW5pdGlhbGl6ZSgpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5pbml0aWFsaXplR2VuZXJhdG9yKCk7XG4gICAgICAgIHRoaXMuc2hhcGVHZW5lcmF0b3IucHJvY2Vzc0RyYXdpbmcodGhpcy5lbGVtZW50LCB0aGlzLmdldEVsZW1lbnRHKCkpO1xuICAgICAgICBjb25zdCBsaW5lUG9pbnRzID0gZ2V0VmVjdG9yTGluZVBvaW50cyh0aGlzLmJvYXJkLCB0aGlzLmVsZW1lbnQpITtcbiAgICAgICAgdGhpcy5hY3RpdmVHZW5lcmF0b3IucHJvY2Vzc0RyYXdpbmcodGhpcy5lbGVtZW50LCBQbGFpdEJvYXJkLmdldEVsZW1lbnRBY3RpdmVIb3N0KHRoaXMuYm9hcmQpLCB7XG4gICAgICAgICAgICBzZWxlY3RlZDogdGhpcy5zZWxlY3RlZCxcbiAgICAgICAgICAgIGxpbmVQb2ludHNcbiAgICAgICAgfSk7XG4gICAgICAgIHN1cGVyLmluaXRpYWxpemUoKTtcbiAgICB9XG5cbiAgICBvbkNvbnRleHRDaGFuZ2VkKFxuICAgICAgICB2YWx1ZTogUGxhaXRQbHVnaW5FbGVtZW50Q29udGV4dDxQbGFpdFZlY3RvckxpbmUsIFBsYWl0Qm9hcmQ+LFxuICAgICAgICBwcmV2aW91czogUGxhaXRQbHVnaW5FbGVtZW50Q29udGV4dDxQbGFpdFZlY3RvckxpbmUsIFBsYWl0Qm9hcmQ+XG4gICAgKSB7XG4gICAgICAgIHRoaXMuaW5pdGlhbGl6ZVdlYWtNYXAoKTtcbiAgICAgICAgY29uc3QgaXNDaGFuZ2VUaGVtZSA9IHRoaXMuYm9hcmQub3BlcmF0aW9ucy5maW5kKG9wID0+IG9wLnR5cGUgPT09ICdzZXRfdGhlbWUnKTtcbiAgICAgICAgY29uc3QgbGluZVBvaW50cyA9IGdldFZlY3RvckxpbmVQb2ludHModGhpcy5ib2FyZCwgdGhpcy5lbGVtZW50KSE7XG4gICAgICAgIGlmICh2YWx1ZS5lbGVtZW50ICE9PSBwcmV2aW91cy5lbGVtZW50IHx8IGlzQ2hhbmdlVGhlbWUpIHtcbiAgICAgICAgICAgIHRoaXMuc2hhcGVHZW5lcmF0b3IucHJvY2Vzc0RyYXdpbmcodGhpcy5lbGVtZW50LCB0aGlzLmdldEVsZW1lbnRHKCkpO1xuICAgICAgICAgICAgdGhpcy5hY3RpdmVHZW5lcmF0b3IucHJvY2Vzc0RyYXdpbmcodGhpcy5lbGVtZW50LCBQbGFpdEJvYXJkLmdldEVsZW1lbnRBY3RpdmVIb3N0KHRoaXMuYm9hcmQpLCB7XG4gICAgICAgICAgICAgICAgc2VsZWN0ZWQ6IHRoaXMuc2VsZWN0ZWQsXG4gICAgICAgICAgICAgICAgbGluZVBvaW50c1xuICAgICAgICAgICAgfSk7XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICBjb25zdCBuZWVkVXBkYXRlID0gdmFsdWUuc2VsZWN0ZWQgIT09IHByZXZpb3VzLnNlbGVjdGVkIHx8IHRoaXMuYWN0aXZlR2VuZXJhdG9yLm5lZWRVcGRhdGUoKTtcbiAgICAgICAgICAgIGlmIChuZWVkVXBkYXRlKSB7XG4gICAgICAgICAgICAgICAgdGhpcy5hY3RpdmVHZW5lcmF0b3IucHJvY2Vzc0RyYXdpbmcodGhpcy5lbGVtZW50LCBQbGFpdEJvYXJkLmdldEVsZW1lbnRBY3RpdmVIb3N0KHRoaXMuYm9hcmQpLCB7XG4gICAgICAgICAgICAgICAgICAgIHNlbGVjdGVkOiB0aGlzLnNlbGVjdGVkLFxuICAgICAgICAgICAgICAgICAgICBsaW5lUG9pbnRzXG4gICAgICAgICAgICAgICAgfSk7XG4gICAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICBkZXN0cm95KCk6IHZvaWQge1xuICAgICAgICBzdXBlci5kZXN0cm95KCk7XG4gICAgICAgIHRoaXMuYWN0aXZlR2VuZXJhdG9yLmRlc3Ryb3koKTtcbiAgICB9XG59XG4iXX0=
|