@plait/draw 0.1.0-next.3 → 0.1.0-next.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/geometry.component.mjs +3 -2
- package/esm2022/interfaces/line.mjs +23 -1
- package/esm2022/plugins/with-draw-hotkey.mjs +12 -2
- package/esm2022/plugins/with-draw.mjs +2 -10
- package/esm2022/plugins/with-geometry-create.mjs +6 -9
- package/esm2022/plugins/with-line-create.mjs +4 -4
- package/esm2022/public-api.mjs +3 -1
- package/esm2022/utils/engine/diamond.mjs +5 -3
- package/esm2022/utils/engine/parallelogram.mjs +5 -3
- package/esm2022/utils/index.mjs +1 -2
- package/esm2022/utils/line.mjs +29 -17
- package/fesm2022/plait-draw.mjs +70 -49
- package/fesm2022/plait-draw.mjs.map +1 -1
- package/interfaces/line.d.ts +5 -0
- package/package.json +1 -1
- package/public-api.d.ts +2 -0
- package/utils/index.d.ts +0 -1
- package/utils/line.d.ts +1 -1
- package/esm2022/utils/create-mode.mjs +0 -13
- package/utils/create-mode.d.ts +0 -7
package/esm2022/utils/line.mjs
CHANGED
|
@@ -1,9 +1,10 @@
|
|
|
1
|
-
import { idCreator, distanceBetweenPointAndSegments, PlaitBoard, createG, arrowPoints, drawLinearPath, getElementById, RectangleClient } from '@plait/core';
|
|
2
|
-
import { getPoints, Direction, getRectangleByPoints, getDirectionByPoint, getPointOnPolyline } from '@plait/common';
|
|
3
|
-
import { LineMarkerType } from '../interfaces';
|
|
1
|
+
import { idCreator, distanceBetweenPointAndSegments, PlaitBoard, createG, arrowPoints, drawLinearPath, getElementById, RectangleClient, setPathStrokeLinecap } from '@plait/core';
|
|
2
|
+
import { getPoints, Direction, getRectangleByPoints, getDirectionByPoint, getPointOnPolyline, getDirectionFactor, getDirectionBetweenPointAndPoint } from '@plait/common';
|
|
3
|
+
import { LineMarkerType, PlaitLine } from '../interfaces';
|
|
4
4
|
import { getPointsByCenterPoint, getNearestPoint } from './geometry';
|
|
5
5
|
import { getLineDashByElement, getStrokeColorByElement, getStrokeWidthByElement } from './geometry-style/stroke';
|
|
6
6
|
import { getEngine } from './engine';
|
|
7
|
+
const BOUNDED_HANDLE_OFFSET = 0.5;
|
|
7
8
|
export const createLineElement = (shape, points, source, target, options) => {
|
|
8
9
|
return {
|
|
9
10
|
id: idCreator(),
|
|
@@ -67,26 +68,32 @@ export const drawElbowLine = (board, element) => {
|
|
|
67
68
|
const elbowLine = PlaitBoard.getRoughSVG(board).linearPath(points, options);
|
|
68
69
|
const path = elbowLine.querySelector('path');
|
|
69
70
|
path?.setAttribute('mask', `url(#${element.id})`);
|
|
71
|
+
setPathStrokeLinecap(elbowLine, 'square');
|
|
70
72
|
lineG.appendChild(elbowLine);
|
|
71
73
|
const arrow = drawLineArrow(element, points, options);
|
|
72
74
|
arrow && lineG.appendChild(arrow);
|
|
73
75
|
return lineG;
|
|
74
76
|
};
|
|
75
77
|
export const drawLineArrow = (element, points, options) => {
|
|
76
|
-
const sourceMarker = element.source.marker;
|
|
77
|
-
const targetMarker = element.target.marker;
|
|
78
78
|
const arrowG = createG();
|
|
79
|
-
if (
|
|
79
|
+
if (PlaitLine.isSourceMark(element, LineMarkerType.none) && PlaitLine.isTargetMark(element, LineMarkerType.none)) {
|
|
80
80
|
return null;
|
|
81
|
-
|
|
81
|
+
}
|
|
82
|
+
if (PlaitLine.isSourceMark(element, LineMarkerType.arrow)) {
|
|
82
83
|
const sourcePoint = points[0];
|
|
83
|
-
const { pointLeft, pointRight } = arrowPoints(points[1], sourcePoint,
|
|
84
|
+
const { pointLeft, pointRight } = arrowPoints(points[1], sourcePoint, 12, 40);
|
|
84
85
|
const sourceArrow = drawLinearPath([pointLeft, sourcePoint, pointRight], options);
|
|
85
86
|
arrowG.appendChild(sourceArrow);
|
|
86
87
|
}
|
|
87
|
-
if (
|
|
88
|
-
const
|
|
89
|
-
const
|
|
88
|
+
if (PlaitLine.isTargetMark(element, LineMarkerType.arrow)) {
|
|
89
|
+
const _endPoint = points[points.length - 1];
|
|
90
|
+
const arrowDirection = getDirectionBetweenPointAndPoint(points[points.length - 2], _endPoint);
|
|
91
|
+
const directionFactor = getDirectionFactor(arrowDirection);
|
|
92
|
+
const endPoint = [
|
|
93
|
+
_endPoint[0] + BOUNDED_HANDLE_OFFSET * directionFactor.x,
|
|
94
|
+
_endPoint[1] + BOUNDED_HANDLE_OFFSET * directionFactor.y
|
|
95
|
+
];
|
|
96
|
+
const { pointLeft, pointRight } = arrowPoints(points[points.length - 2], endPoint, 12, 40);
|
|
90
97
|
const targetArrow = drawLinearPath([pointLeft, endPoint, pointRight], options);
|
|
91
98
|
arrowG.appendChild(targetArrow);
|
|
92
99
|
}
|
|
@@ -94,24 +101,29 @@ export const drawLineArrow = (element, points, options) => {
|
|
|
94
101
|
};
|
|
95
102
|
export const getSourcePoint = (board, element) => {
|
|
96
103
|
if (element.source.boundId) {
|
|
104
|
+
const connectionOffset = PlaitLine.isSourceMark(element, LineMarkerType.arrow) ? BOUNDED_HANDLE_OFFSET : 0;
|
|
97
105
|
const boundElement = getElementById(board, element.source.boundId);
|
|
98
|
-
return boundElement ?
|
|
106
|
+
return boundElement ? getConnectionPoint(boundElement, element.source.connection, connectionOffset) : element.points[0];
|
|
99
107
|
}
|
|
100
108
|
return element.points[0];
|
|
101
109
|
};
|
|
102
110
|
export const getTargetPoint = (board, element) => {
|
|
103
111
|
if (element.target.boundId) {
|
|
112
|
+
const connectionOffset = PlaitLine.isTargetMark(element, LineMarkerType.arrow) ? BOUNDED_HANDLE_OFFSET : 0;
|
|
104
113
|
const boundElement = getElementById(board, element.target.boundId);
|
|
105
|
-
return boundElement
|
|
114
|
+
return boundElement
|
|
115
|
+
? getConnectionPoint(boundElement, element.target.connection, connectionOffset)
|
|
116
|
+
: element.points[element.points.length - 1];
|
|
106
117
|
}
|
|
107
118
|
return element.points[element.points.length - 1];
|
|
108
119
|
};
|
|
109
|
-
export const
|
|
120
|
+
export const getConnectionPoint = (geometry, connection, offset) => {
|
|
110
121
|
const rectangle = getRectangleByPoints(geometry.points);
|
|
111
122
|
const strokeWidth = getStrokeWidthByElement(geometry);
|
|
123
|
+
const directionFactor = getDirectionFactor(getDirectionByPoint(connection, Direction.bottom));
|
|
112
124
|
return [
|
|
113
|
-
rectangle.x
|
|
114
|
-
rectangle.y
|
|
125
|
+
rectangle.x + rectangle.width * connection[0] + strokeWidth * directionFactor.x + offset * directionFactor.x,
|
|
126
|
+
rectangle.y + rectangle.height * connection[1] + strokeWidth * directionFactor.y + offset * directionFactor.y
|
|
115
127
|
];
|
|
116
128
|
};
|
|
117
129
|
export const transformPointToConnection = (board, point, hitElement) => {
|
|
@@ -142,4 +154,4 @@ export const getLineTextRectangle = (board, element, index) => {
|
|
|
142
154
|
height: text.height
|
|
143
155
|
};
|
|
144
156
|
};
|
|
145
|
-
//# 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 {\n    Point,\n    idCreator,\n    distanceBetweenPointAndSegments,\n    PlaitBoard,\n    createG,\n    arrowPoints,\n    drawLinearPath,\n    getElementById,\n    RectangleClient\n} from '@plait/core';\nimport { getPoints, Direction, getRectangleByPoints, getDirectionByPoint, getPointOnPolyline } from '@plait/common';\nimport { LineHandle, LineMarkerType, LineShape, PlaitGeometry, PlaitLine } from '../interfaces';\nimport { Options } from 'roughjs/bin/core';\nimport { getPointsByCenterPoint, getNearestPoint } from './geometry';\nimport { getLineDashByElement, getStrokeColorByElement, getStrokeWidthByElement } from './geometry-style/stroke';\nimport { getEngine } from './engine';\n\nexport const createLineElement = (\n    shape: LineShape,\n    points: [Point, Point],\n    source: LineHandle,\n    target: LineHandle,\n    options?: Pick<PlaitLine, 'strokeColor' | 'strokeWidth'>\n): PlaitLine => {\n    return {\n        id: idCreator(),\n        type: 'line',\n        shape,\n        source,\n        texts: [],\n        target,\n        opacity: 1,\n        points,\n        ...options\n    };\n};\n\nexport const getElbowPoints = (board: PlaitBoard, element: PlaitLine) => {\n    if (element.points.length === 2) {\n        const source = getSourcePoint(board, element);\n        const target = getTargetPoint(board, element);\n        let sourceDirection = source[0] < target[0] ? Direction.right : Direction.left;\n        let targetDirection = source[0] < target[0] ? Direction.left : Direction.right;\n        if (element.source.connection) {\n            sourceDirection = getDirectionByPoint(element.source.connection, sourceDirection);\n        }\n        if (element.target.connection) {\n            targetDirection = getDirectionByPoint(element.target.connection, targetDirection);\n        }\n        const points: Point[] = getPoints(source, sourceDirection, target, targetDirection, 30);\n        return points;\n    }\n    return element.points;\n};\n\nexport const isHitPolyLine = (pathPoints: Point[], point: Point, strokeWidth: number, expand: number = 0) => {\n    const distance = distanceBetweenPointAndSegments(pathPoints, point);\n    return distance <= strokeWidth + expand;\n};\n\nexport const getHitLineTextIndex = (board: PlaitBoard, element: PlaitLine, point: Point) => {\n    const texts = element.texts;\n    if (!texts.length) return -1;\n\n    const points = getElbowPoints(board, element);\n    return texts.findIndex(text => {\n        const center = getPointOnPolyline(points, text.position);\n        const rectangle = {\n            x: center[0] - text.width! / 2,\n            y: center[1] - text.height! / 2,\n            width: text.width!,\n            height: text.height!\n        };\n        return RectangleClient.isHit(rectangle, RectangleClient.toRectangleClient([point, point]));\n    });\n};\n\nexport const isHitLineText = (board: PlaitBoard, element: PlaitLine, point: Point) => {\n    return getHitLineTextIndex(board, element, point) !== -1;\n};\n\nexport const drawElbowLine = (board: PlaitBoard, element: PlaitLine) => {\n    const strokeWidth = getStrokeWidthByElement(element);\n    const strokeColor = getStrokeColorByElement(element);\n    const strokeLineDash = getLineDashByElement(element);\n    const options = { stroke: strokeColor, strokeWidth, strokeLineDash };\n    const lineG = createG();\n    const points = getElbowPoints(board, element);\n    const elbowLine = PlaitBoard.getRoughSVG(board).linearPath(points, options);\n    const path = elbowLine.querySelector('path');\n    path?.setAttribute('mask', `url(#${element.id})`);\n    lineG.appendChild(elbowLine);\n    const arrow = drawLineArrow(element, points, options);\n    arrow && lineG.appendChild(arrow);\n    return lineG;\n};\n\nexport const drawLineArrow = (element: PlaitLine, points: Point[], options: Options) => {\n    const sourceMarker = element.source.marker;\n    const targetMarker = element.target.marker;\n    const arrowG = createG();\n    if (sourceMarker === LineMarkerType.none && targetMarker === LineMarkerType.none) return null;\n    if (sourceMarker === LineMarkerType.arrow) {\n        const sourcePoint = points[0];\n        const { pointLeft, pointRight } = arrowPoints(points[1], sourcePoint, 10, 20);\n        const sourceArrow = drawLinearPath([pointLeft, sourcePoint, pointRight], options);\n        arrowG.appendChild(sourceArrow);\n    }\n    if (targetMarker === LineMarkerType.arrow) {\n        const endPoint = points[points.length - 1];\n        const { pointLeft, pointRight } = arrowPoints(points[points.length - 2], endPoint, 10, 20);\n        const targetArrow = drawLinearPath([pointLeft, endPoint, pointRight], options);\n        arrowG.appendChild(targetArrow);\n    }\n    return arrowG;\n};\n\nexport const getSourcePoint = (board: PlaitBoard, element: PlaitLine) => {\n    if (element.source.boundId) {\n        const boundElement = getElementById<PlaitGeometry>(board, element.source.boundId);\n        return boundElement ? normalizeConnection(boundElement, element.source.connection!) : element.points[0];\n    }\n    return element.points[0];\n};\n\nexport const getTargetPoint = (board: PlaitBoard, element: PlaitLine) => {\n    if (element.target.boundId) {\n        const boundElement = getElementById<PlaitGeometry>(board, element.target.boundId);\n        return boundElement ? normalizeConnection(boundElement, element.target.connection!) : element.points[element.points.length - 1];\n    }\n    return element.points[element.points.length - 1];\n};\n\nexport const normalizeConnection = (geometry: PlaitGeometry, connection: Point): Point => {\n    const rectangle = getRectangleByPoints(geometry.points);\n    const strokeWidth = getStrokeWidthByElement(geometry);\n    return [\n        rectangle.x - strokeWidth / 2 + (rectangle.width + strokeWidth) * connection[0],\n        rectangle.y - strokeWidth / 2 + (rectangle.height + strokeWidth) * connection[1]\n    ];\n};\n\nexport const transformPointToConnection = (board: PlaitBoard, point: Point, hitElement: PlaitGeometry): Point => {\n    const offset = (getStrokeWidthByElement(hitElement) + 1) / 2;\n    let rectangle = getRectangleByPoints(hitElement.points);\n    rectangle = RectangleClient.getOutlineRectangle(rectangle, -offset);\n    let nearestPoint = getNearestPoint(hitElement, point, offset);\n    const hitConnector = getHitConnectorPoint(nearestPoint, hitElement, rectangle);\n    nearestPoint = hitConnector ? hitConnector : nearestPoint;\n    return [(nearestPoint[0] - rectangle.x) / rectangle.width, (nearestPoint[1] - rectangle.y) / rectangle.height];\n};\n\nexport const getHitConnectorPoint = (movingPoint: Point, hitElement: PlaitGeometry, rectangle: RectangleClient) => {\n    const connector = getEngine(hitElement.shape).getConnectorPoints(rectangle);\n    const points = getPointsByCenterPoint(movingPoint, 5, 5);\n    const pointRectangle = getRectangleByPoints(points);\n    return connector.find(point => {\n        return RectangleClient.isHit(pointRectangle, RectangleClient.toRectangleClient([point, point]));\n    });\n};\n\nexport const getLineTextRectangle = (board: PlaitBoard, element: PlaitLine, index: number): RectangleClient => {\n    const text = element.texts[index];\n    const elbowPoints = getElbowPoints(board, element);\n    const point = getPointOnPolyline(elbowPoints, text.position);\n    return {\n        x: point[0] - text.width! / 2,\n        y: point[1] - text.height! / 2,\n        width: text.width!,\n        height: text.height!\n    };\n};\n"]}
|
|
157
|
+
//# 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 {\n    Point,\n    idCreator,\n    distanceBetweenPointAndSegments,\n    PlaitBoard,\n    createG,\n    arrowPoints,\n    drawLinearPath,\n    getElementById,\n    RectangleClient,\n    setPathStrokeLinecap\n} from '@plait/core';\nimport {\n    getPoints,\n    Direction,\n    getRectangleByPoints,\n    getDirectionByPoint,\n    getPointOnPolyline,\n    getDirectionFactor,\n    getDirectionBetweenPointAndPoint\n} from '@plait/common';\nimport { LineHandle, LineMarkerType, LineShape, PlaitGeometry, PlaitLine } from '../interfaces';\nimport { Options } from 'roughjs/bin/core';\nimport { getPointsByCenterPoint, getNearestPoint } from './geometry';\nimport { getLineDashByElement, getStrokeColorByElement, getStrokeWidthByElement } from './geometry-style/stroke';\nimport { getEngine } from './engine';\n\nconst BOUNDED_HANDLE_OFFSET = 0.5;\n\nexport const createLineElement = (\n    shape: LineShape,\n    points: [Point, Point],\n    source: LineHandle,\n    target: LineHandle,\n    options?: Pick<PlaitLine, 'strokeColor' | 'strokeWidth'>\n): PlaitLine => {\n    return {\n        id: idCreator(),\n        type: 'line',\n        shape,\n        source,\n        texts: [],\n        target,\n        opacity: 1,\n        points,\n        ...options\n    };\n};\n\nexport const getElbowPoints = (board: PlaitBoard, element: PlaitLine) => {\n    if (element.points.length === 2) {\n        const source = getSourcePoint(board, element);\n        const target = getTargetPoint(board, element);\n        let sourceDirection = source[0] < target[0] ? Direction.right : Direction.left;\n        let targetDirection = source[0] < target[0] ? Direction.left : Direction.right;\n        if (element.source.connection) {\n            sourceDirection = getDirectionByPoint(element.source.connection, sourceDirection);\n        }\n        if (element.target.connection) {\n            targetDirection = getDirectionByPoint(element.target.connection, targetDirection);\n        }\n        const points: Point[] = getPoints(source, sourceDirection, target, targetDirection, 30);\n        return points;\n    }\n    return element.points;\n};\n\nexport const isHitPolyLine = (pathPoints: Point[], point: Point, strokeWidth: number, expand: number = 0) => {\n    const distance = distanceBetweenPointAndSegments(pathPoints, point);\n    return distance <= strokeWidth + expand;\n};\n\nexport const getHitLineTextIndex = (board: PlaitBoard, element: PlaitLine, point: Point) => {\n    const texts = element.texts;\n    if (!texts.length) return -1;\n\n    const points = getElbowPoints(board, element);\n    return texts.findIndex(text => {\n        const center = getPointOnPolyline(points, text.position);\n        const rectangle = {\n            x: center[0] - text.width! / 2,\n            y: center[1] - text.height! / 2,\n            width: text.width!,\n            height: text.height!\n        };\n        return RectangleClient.isHit(rectangle, RectangleClient.toRectangleClient([point, point]));\n    });\n};\n\nexport const isHitLineText = (board: PlaitBoard, element: PlaitLine, point: Point) => {\n    return getHitLineTextIndex(board, element, point) !== -1;\n};\n\nexport const drawElbowLine = (board: PlaitBoard, element: PlaitLine) => {\n    const strokeWidth = getStrokeWidthByElement(element);\n    const strokeColor = getStrokeColorByElement(element);\n    const strokeLineDash = getLineDashByElement(element);\n    const options = { stroke: strokeColor, strokeWidth, strokeLineDash };\n    const lineG = createG();\n    const points = getElbowPoints(board, element);\n    const elbowLine = PlaitBoard.getRoughSVG(board).linearPath(points, options);\n    const path = elbowLine.querySelector('path');\n    path?.setAttribute('mask', `url(#${element.id})`);\n    setPathStrokeLinecap(elbowLine, 'square');\n    lineG.appendChild(elbowLine);\n    const arrow = drawLineArrow(element, points, options);\n    arrow && lineG.appendChild(arrow);\n    return lineG;\n};\n\nexport const drawLineArrow = (element: PlaitLine, points: Point[], options: Options) => {\n    const arrowG = createG();\n    if (PlaitLine.isSourceMark(element, LineMarkerType.none) && PlaitLine.isTargetMark(element, LineMarkerType.none)) {\n        return null;\n    }\n    if (PlaitLine.isSourceMark(element, LineMarkerType.arrow)) {\n        const sourcePoint = points[0];\n        const { pointLeft, pointRight } = arrowPoints(points[1], sourcePoint, 12, 40);\n        const sourceArrow = drawLinearPath([pointLeft, sourcePoint, pointRight], options);\n        arrowG.appendChild(sourceArrow);\n    }\n    if (PlaitLine.isTargetMark(element, LineMarkerType.arrow)) {\n        const _endPoint = points[points.length - 1];\n        const arrowDirection = getDirectionBetweenPointAndPoint(points[points.length - 2], _endPoint);\n        const directionFactor = getDirectionFactor(arrowDirection);\n        const endPoint: Point = [\n            _endPoint[0] + BOUNDED_HANDLE_OFFSET * directionFactor.x,\n            _endPoint[1] + BOUNDED_HANDLE_OFFSET * directionFactor.y\n        ];\n        const { pointLeft, pointRight } = arrowPoints(points[points.length - 2], endPoint, 12, 40);\n        const targetArrow = drawLinearPath([pointLeft, endPoint, pointRight], options);\n        arrowG.appendChild(targetArrow);\n    }\n    return arrowG;\n};\n\nexport const getSourcePoint = (board: PlaitBoard, element: PlaitLine) => {\n    if (element.source.boundId) {\n        const connectionOffset = PlaitLine.isSourceMark(element, LineMarkerType.arrow) ? BOUNDED_HANDLE_OFFSET : 0;\n        const boundElement = getElementById<PlaitGeometry>(board, element.source.boundId);\n        return boundElement ? getConnectionPoint(boundElement, element.source.connection!, connectionOffset) : element.points[0];\n    }\n    return element.points[0];\n};\n\nexport const getTargetPoint = (board: PlaitBoard, element: PlaitLine) => {\n    if (element.target.boundId) {\n        const connectionOffset = PlaitLine.isTargetMark(element, LineMarkerType.arrow) ? BOUNDED_HANDLE_OFFSET : 0;\n        const boundElement = getElementById<PlaitGeometry>(board, element.target.boundId);\n        return boundElement\n            ? getConnectionPoint(boundElement, element.target.connection!, connectionOffset)\n            : element.points[element.points.length - 1];\n    }\n    return element.points[element.points.length - 1];\n};\n\nexport const getConnectionPoint = (geometry: PlaitGeometry, connection: Point, offset: number): Point => {\n    const rectangle = getRectangleByPoints(geometry.points);\n    const strokeWidth = getStrokeWidthByElement(geometry);\n    const directionFactor = getDirectionFactor(getDirectionByPoint(connection, Direction.bottom));\n    return [\n        rectangle.x + rectangle.width * connection[0] + strokeWidth * directionFactor.x + offset * directionFactor.x,\n        rectangle.y + rectangle.height * connection[1] + strokeWidth * directionFactor.y + offset * directionFactor.y\n    ];\n};\n\nexport const transformPointToConnection = (board: PlaitBoard, point: Point, hitElement: PlaitGeometry): Point => {\n    const offset = (getStrokeWidthByElement(hitElement) + 1) / 2;\n    let rectangle = getRectangleByPoints(hitElement.points);\n    rectangle = RectangleClient.getOutlineRectangle(rectangle, -offset);\n    let nearestPoint = getNearestPoint(hitElement, point, offset);\n    const hitConnector = getHitConnectorPoint(nearestPoint, hitElement, rectangle);\n    nearestPoint = hitConnector ? hitConnector : nearestPoint;\n    return [(nearestPoint[0] - rectangle.x) / rectangle.width, (nearestPoint[1] - rectangle.y) / rectangle.height];\n};\n\nexport const getHitConnectorPoint = (movingPoint: Point, hitElement: PlaitGeometry, rectangle: RectangleClient) => {\n    const connector = getEngine(hitElement.shape).getConnectorPoints(rectangle);\n    const points = getPointsByCenterPoint(movingPoint, 5, 5);\n    const pointRectangle = getRectangleByPoints(points);\n    return connector.find(point => {\n        return RectangleClient.isHit(pointRectangle, RectangleClient.toRectangleClient([point, point]));\n    });\n};\n\nexport const getLineTextRectangle = (board: PlaitBoard, element: PlaitLine, index: number): RectangleClient => {\n    const text = element.texts[index];\n    const elbowPoints = getElbowPoints(board, element);\n    const point = getPointOnPolyline(elbowPoints, text.position);\n    return {\n        x: point[0] - text.width! / 2,\n        y: point[1] - text.height! / 2,\n        width: text.width!,\n        height: text.height!\n    };\n};\n"]}
|
package/fesm2022/plait-draw.mjs
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
import { PlaitElement, RectangleClient, PlaitBoard, isPointInPolygon, getNearestPointBetweenPointAndSegments, isPointInEllipse, drawRectangle, drawRoundRectangle, isPointInRoundRectangle, idCreator, createG, SELECTION_BORDER_COLOR, SELECTION_FILL_COLOR, drawCircle, distanceBetweenPointAndSegments, arrowPoints, drawLinearPath, getElementById, getSelectedElements, Transforms, clearSelectedElement, addSelectedElement, PlaitNode, Point, PlaitPluginElementComponent, isSelectionMoving, createMask, createRect, transformPoint, toPoint, BoardTransforms, PlaitPointerType, preventTouchMove, createForeignObject, setClipboardData, getDataFromClipboard, depthFirstRecursion, getIsRecursionFunc, getHitElements, isPolylineHitRectangle } from '@plait/core';
|
|
1
|
+
import { PlaitElement, RectangleClient, PlaitBoard, setStrokeLinecap, isPointInPolygon, getNearestPointBetweenPointAndSegments, isPointInEllipse, drawRectangle, drawRoundRectangle, isPointInRoundRectangle, idCreator, createG, SELECTION_BORDER_COLOR, SELECTION_FILL_COLOR, drawCircle, distanceBetweenPointAndSegments, setPathStrokeLinecap, arrowPoints, drawLinearPath, getElementById, getSelectedElements, Transforms, clearSelectedElement, addSelectedElement, PlaitNode, Point, PlaitPluginElementComponent, isSelectionMoving, createMask, createRect, transformPoint, toPoint, BoardTransforms, PlaitPointerType, preventTouchMove, createForeignObject, setClipboardData, getDataFromClipboard, depthFirstRecursion, getIsRecursionFunc, getHitElements, isPolylineHitRectangle } from '@plait/core';
|
|
2
2
|
import * as i0 from '@angular/core';
|
|
3
3
|
import { Component, ChangeDetectionStrategy } from '@angular/core';
|
|
4
4
|
import { Subject } from 'rxjs';
|
|
5
|
-
import { getRectangleByPoints, Direction, getDirectionByPoint, getPoints, getPointOnPolyline, Generator, normalizeShapePoints, ActiveGenerator, RESIZE_HANDLE_DIAMETER, isVirtualKey, isSpaceHotkey, CommonTransforms, getRectangleResizeHandleRefs, ResizeHandle, withResize, isResizingByCondition, getRatioByPoint } from '@plait/common';
|
|
5
|
+
import { getRectangleByPoints, Direction, getDirectionByPoint, getPoints, getPointOnPolyline, getDirectionBetweenPointAndPoint, getDirectionFactor, Generator, normalizeShapePoints, ActiveGenerator, RESIZE_HANDLE_DIAMETER, isVirtualKey, isSpaceHotkey, isDndMode, isDrawingMode, CommonTransforms, getRectangleResizeHandleRefs, ResizeHandle, withResize, isResizingByCondition, getRatioByPoint } from '@plait/common';
|
|
6
6
|
import { Alignment, buildText, AlignEditor, TextManage, DEFAULT_FONT_SIZE, getTextFromClipboard, getTextSize } from '@plait/text';
|
|
7
7
|
import { isKeyHotkey } from 'is-hotkey';
|
|
8
8
|
import { Node } from 'slate';
|
|
@@ -37,6 +37,27 @@ var LineShape;
|
|
|
37
37
|
LineShape["curve"] = "curve";
|
|
38
38
|
LineShape["elbow"] = "elbow";
|
|
39
39
|
})(LineShape || (LineShape = {}));
|
|
40
|
+
const PlaitLine = {
|
|
41
|
+
getTextEditors(element) {
|
|
42
|
+
const component = PlaitElement.getComponent(element);
|
|
43
|
+
if (component) {
|
|
44
|
+
const manage = component.textManages.find(manage => manage.isEditing);
|
|
45
|
+
if (manage) {
|
|
46
|
+
return [manage.componentRef.instance.editor];
|
|
47
|
+
}
|
|
48
|
+
else {
|
|
49
|
+
return component.textManages.map(manage => manage.componentRef.instance.editor);
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
throw new Error('can not get correctly component in get text editor');
|
|
53
|
+
},
|
|
54
|
+
isSourceMark(line, markType) {
|
|
55
|
+
return line.source.marker === markType;
|
|
56
|
+
},
|
|
57
|
+
isTargetMark(line, markType) {
|
|
58
|
+
return line.target.marker === markType;
|
|
59
|
+
}
|
|
60
|
+
};
|
|
40
61
|
|
|
41
62
|
const PlaitDrawElement = {
|
|
42
63
|
isGeometry: (value) => {
|
|
@@ -125,7 +146,9 @@ const DiamondEngine = {
|
|
|
125
146
|
draw(board, rectangle, options) {
|
|
126
147
|
const points = RectangleClient.getEdgeCenterPoints(rectangle);
|
|
127
148
|
const rs = PlaitBoard.getRoughSVG(board);
|
|
128
|
-
|
|
149
|
+
const polygon = rs.polygon(points, { ...options, fillStyle: 'solid' });
|
|
150
|
+
setStrokeLinecap(polygon, 'round');
|
|
151
|
+
return polygon;
|
|
129
152
|
},
|
|
130
153
|
isHit(rectangle, point) {
|
|
131
154
|
const controlPoints = RectangleClient.getEdgeCenterPoints(rectangle);
|
|
@@ -198,7 +221,9 @@ const ParallelogramEngine = {
|
|
|
198
221
|
draw(board, rectangle, options) {
|
|
199
222
|
const points = getParallelogramPoints(rectangle);
|
|
200
223
|
const rs = PlaitBoard.getRoughSVG(board);
|
|
201
|
-
|
|
224
|
+
const polygon = rs.polygon(points, { ...options, fillStyle: 'solid' });
|
|
225
|
+
setStrokeLinecap(polygon, 'round');
|
|
226
|
+
return polygon;
|
|
202
227
|
},
|
|
203
228
|
isHit(rectangle, point) {
|
|
204
229
|
const parallelogramPoints = getParallelogramPoints(rectangle);
|
|
@@ -375,6 +400,7 @@ const getCenterPointsOnPolygon = (points) => {
|
|
|
375
400
|
return centerPoint;
|
|
376
401
|
};
|
|
377
402
|
|
|
403
|
+
const BOUNDED_HANDLE_OFFSET = 0.5;
|
|
378
404
|
const createLineElement = (shape, points, source, target, options) => {
|
|
379
405
|
return {
|
|
380
406
|
id: idCreator(),
|
|
@@ -438,26 +464,32 @@ const drawElbowLine = (board, element) => {
|
|
|
438
464
|
const elbowLine = PlaitBoard.getRoughSVG(board).linearPath(points, options);
|
|
439
465
|
const path = elbowLine.querySelector('path');
|
|
440
466
|
path?.setAttribute('mask', `url(#${element.id})`);
|
|
467
|
+
setPathStrokeLinecap(elbowLine, 'square');
|
|
441
468
|
lineG.appendChild(elbowLine);
|
|
442
469
|
const arrow = drawLineArrow(element, points, options);
|
|
443
470
|
arrow && lineG.appendChild(arrow);
|
|
444
471
|
return lineG;
|
|
445
472
|
};
|
|
446
473
|
const drawLineArrow = (element, points, options) => {
|
|
447
|
-
const sourceMarker = element.source.marker;
|
|
448
|
-
const targetMarker = element.target.marker;
|
|
449
474
|
const arrowG = createG();
|
|
450
|
-
if (
|
|
475
|
+
if (PlaitLine.isSourceMark(element, LineMarkerType.none) && PlaitLine.isTargetMark(element, LineMarkerType.none)) {
|
|
451
476
|
return null;
|
|
452
|
-
|
|
477
|
+
}
|
|
478
|
+
if (PlaitLine.isSourceMark(element, LineMarkerType.arrow)) {
|
|
453
479
|
const sourcePoint = points[0];
|
|
454
|
-
const { pointLeft, pointRight } = arrowPoints(points[1], sourcePoint,
|
|
480
|
+
const { pointLeft, pointRight } = arrowPoints(points[1], sourcePoint, 12, 40);
|
|
455
481
|
const sourceArrow = drawLinearPath([pointLeft, sourcePoint, pointRight], options);
|
|
456
482
|
arrowG.appendChild(sourceArrow);
|
|
457
483
|
}
|
|
458
|
-
if (
|
|
459
|
-
const
|
|
460
|
-
const
|
|
484
|
+
if (PlaitLine.isTargetMark(element, LineMarkerType.arrow)) {
|
|
485
|
+
const _endPoint = points[points.length - 1];
|
|
486
|
+
const arrowDirection = getDirectionBetweenPointAndPoint(points[points.length - 2], _endPoint);
|
|
487
|
+
const directionFactor = getDirectionFactor(arrowDirection);
|
|
488
|
+
const endPoint = [
|
|
489
|
+
_endPoint[0] + BOUNDED_HANDLE_OFFSET * directionFactor.x,
|
|
490
|
+
_endPoint[1] + BOUNDED_HANDLE_OFFSET * directionFactor.y
|
|
491
|
+
];
|
|
492
|
+
const { pointLeft, pointRight } = arrowPoints(points[points.length - 2], endPoint, 12, 40);
|
|
461
493
|
const targetArrow = drawLinearPath([pointLeft, endPoint, pointRight], options);
|
|
462
494
|
arrowG.appendChild(targetArrow);
|
|
463
495
|
}
|
|
@@ -465,24 +497,29 @@ const drawLineArrow = (element, points, options) => {
|
|
|
465
497
|
};
|
|
466
498
|
const getSourcePoint = (board, element) => {
|
|
467
499
|
if (element.source.boundId) {
|
|
500
|
+
const connectionOffset = PlaitLine.isSourceMark(element, LineMarkerType.arrow) ? BOUNDED_HANDLE_OFFSET : 0;
|
|
468
501
|
const boundElement = getElementById(board, element.source.boundId);
|
|
469
|
-
return boundElement ?
|
|
502
|
+
return boundElement ? getConnectionPoint(boundElement, element.source.connection, connectionOffset) : element.points[0];
|
|
470
503
|
}
|
|
471
504
|
return element.points[0];
|
|
472
505
|
};
|
|
473
506
|
const getTargetPoint = (board, element) => {
|
|
474
507
|
if (element.target.boundId) {
|
|
508
|
+
const connectionOffset = PlaitLine.isTargetMark(element, LineMarkerType.arrow) ? BOUNDED_HANDLE_OFFSET : 0;
|
|
475
509
|
const boundElement = getElementById(board, element.target.boundId);
|
|
476
|
-
return boundElement
|
|
510
|
+
return boundElement
|
|
511
|
+
? getConnectionPoint(boundElement, element.target.connection, connectionOffset)
|
|
512
|
+
: element.points[element.points.length - 1];
|
|
477
513
|
}
|
|
478
514
|
return element.points[element.points.length - 1];
|
|
479
515
|
};
|
|
480
|
-
const
|
|
516
|
+
const getConnectionPoint = (geometry, connection, offset) => {
|
|
481
517
|
const rectangle = getRectangleByPoints(geometry.points);
|
|
482
518
|
const strokeWidth = getStrokeWidthByElement(geometry);
|
|
519
|
+
const directionFactor = getDirectionFactor(getDirectionByPoint(connection, Direction.bottom));
|
|
483
520
|
return [
|
|
484
|
-
rectangle.x
|
|
485
|
-
rectangle.y
|
|
521
|
+
rectangle.x + rectangle.width * connection[0] + strokeWidth * directionFactor.x + offset * directionFactor.x,
|
|
522
|
+
rectangle.y + rectangle.height * connection[1] + strokeWidth * directionFactor.y + offset * directionFactor.y
|
|
486
523
|
];
|
|
487
524
|
};
|
|
488
525
|
const transformPointToConnection = (board, point, hitElement) => {
|
|
@@ -514,19 +551,6 @@ const getLineTextRectangle = (board, element, index) => {
|
|
|
514
551
|
};
|
|
515
552
|
};
|
|
516
553
|
|
|
517
|
-
var DrawCreateMode;
|
|
518
|
-
(function (DrawCreateMode) {
|
|
519
|
-
DrawCreateMode["drag"] = "drag";
|
|
520
|
-
DrawCreateMode["draw"] = "draw";
|
|
521
|
-
})(DrawCreateMode || (DrawCreateMode = {}));
|
|
522
|
-
const BOARD_TO_CREATE_MODE = new WeakMap();
|
|
523
|
-
const getCreateMode = (board) => {
|
|
524
|
-
return BOARD_TO_CREATE_MODE.get(board);
|
|
525
|
-
};
|
|
526
|
-
const setCreateMode = (board, mode) => {
|
|
527
|
-
BOARD_TO_CREATE_MODE.set(board, mode);
|
|
528
|
-
};
|
|
529
|
-
|
|
530
554
|
const getSelectedDrawElements = (board) => {
|
|
531
555
|
const selectedElements = getSelectedElements(board).filter(value => PlaitDrawElement.isDrawElement(value));
|
|
532
556
|
return selectedElements;
|
|
@@ -686,7 +710,7 @@ class GeometryComponent extends PlaitPluginElementComponent {
|
|
|
686
710
|
},
|
|
687
711
|
hasResizeHandle: () => {
|
|
688
712
|
const selectedElements = getSelectedElements(this.board);
|
|
689
|
-
if (PlaitBoard.hasBeenTextEditing(this.board)) {
|
|
713
|
+
if (PlaitBoard.hasBeenTextEditing(this.board) && PlaitDrawElement.isText(this.element)) {
|
|
690
714
|
return false;
|
|
691
715
|
}
|
|
692
716
|
return selectedElements.length === 1 && !isSelectionMoving(this.board);
|
|
@@ -982,7 +1006,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImpor
|
|
|
982
1006
|
}], ctorParameters: function () { return [{ type: i0.ViewContainerRef }, { type: i0.ChangeDetectorRef }]; } });
|
|
983
1007
|
|
|
984
1008
|
const withDrawHotkey = (board) => {
|
|
985
|
-
const { keydown } = board;
|
|
1009
|
+
const { keydown, dblclick } = board;
|
|
986
1010
|
board.keydown = (event) => {
|
|
987
1011
|
const selectedElements = getSelectedElements(board);
|
|
988
1012
|
const isSingleSelection = selectedElements.length === 1;
|
|
@@ -994,20 +1018,27 @@ const withDrawHotkey = (board) => {
|
|
|
994
1018
|
}
|
|
995
1019
|
keydown(event);
|
|
996
1020
|
};
|
|
1021
|
+
board.dblclick = (event) => {
|
|
1022
|
+
event.preventDefault();
|
|
1023
|
+
const geometries = getSelectedGeometryElements(board);
|
|
1024
|
+
if (geometries.length === 1) {
|
|
1025
|
+
const component = PlaitElement.getComponent(geometries[0]);
|
|
1026
|
+
component.editText();
|
|
1027
|
+
}
|
|
1028
|
+
dblclick(event);
|
|
1029
|
+
};
|
|
997
1030
|
return board;
|
|
998
1031
|
};
|
|
999
1032
|
|
|
1000
1033
|
const withGeometryCreateByDrag = (board) => {
|
|
1001
1034
|
const { pointerMove, pointerUp } = board;
|
|
1002
|
-
let createMode = undefined;
|
|
1003
1035
|
let geometryShapeG = null;
|
|
1004
1036
|
board.pointerMove = (event) => {
|
|
1005
1037
|
geometryShapeG?.remove();
|
|
1006
1038
|
geometryShapeG = createG();
|
|
1007
|
-
createMode = getCreateMode(board);
|
|
1008
1039
|
const geometryGenerator = new GeometryShapeGenerator(board);
|
|
1009
1040
|
const isGeometryPointer = PlaitBoard.isInPointer(board, GeometryPointer);
|
|
1010
|
-
const dragMode = isGeometryPointer &&
|
|
1041
|
+
const dragMode = isGeometryPointer && isDndMode(board);
|
|
1011
1042
|
const movingPoint = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));
|
|
1012
1043
|
const pointer = PlaitBoard.getPointer(board);
|
|
1013
1044
|
if (dragMode) {
|
|
@@ -1031,7 +1062,7 @@ const withGeometryCreateByDrag = (board) => {
|
|
|
1031
1062
|
board.pointerUp = (event) => {
|
|
1032
1063
|
const pointer = PlaitBoard.getPointer(board);
|
|
1033
1064
|
const isGeometryPointer = PlaitBoard.isInPointer(board, GeometryPointer);
|
|
1034
|
-
const dragMode = isGeometryPointer &&
|
|
1065
|
+
const dragMode = isGeometryPointer && isDndMode(board);
|
|
1035
1066
|
if (dragMode) {
|
|
1036
1067
|
const targetPoint = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));
|
|
1037
1068
|
const points = getDefaultGeometryPoints(pointer, targetPoint);
|
|
@@ -1065,9 +1096,8 @@ const withGeometryCreateByDraw = (board) => {
|
|
|
1065
1096
|
keyup(event);
|
|
1066
1097
|
};
|
|
1067
1098
|
board.pointerDown = (event) => {
|
|
1068
|
-
const createMode = getCreateMode(board);
|
|
1069
1099
|
const isGeometryPointer = PlaitBoard.isInPointer(board, GeometryPointer);
|
|
1070
|
-
if (isGeometryPointer &&
|
|
1100
|
+
if (isGeometryPointer && isDrawingMode(board)) {
|
|
1071
1101
|
const point = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));
|
|
1072
1102
|
start = point;
|
|
1073
1103
|
preventTouchMove(board, true);
|
|
@@ -1254,9 +1284,8 @@ const withLineCreateByDraw = (board) => {
|
|
|
1254
1284
|
let lineShapeG = null;
|
|
1255
1285
|
let temporaryElement = null;
|
|
1256
1286
|
board.pointerDown = (event) => {
|
|
1257
|
-
const createMode = getCreateMode(board);
|
|
1258
1287
|
const isLinePointer = PlaitBoard.isPointer(board, DrawPointerType.line);
|
|
1259
|
-
if (isLinePointer &&
|
|
1288
|
+
if (isLinePointer && isDrawingMode(board)) {
|
|
1260
1289
|
const point = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));
|
|
1261
1290
|
start = point;
|
|
1262
1291
|
const hitElement = getHitOutlineGeometry(board, point, -4);
|
|
@@ -1583,14 +1612,6 @@ const withDraw = (board) => {
|
|
|
1583
1612
|
}
|
|
1584
1613
|
return isMovable(element);
|
|
1585
1614
|
};
|
|
1586
|
-
board.dblclick = (event) => {
|
|
1587
|
-
const element = getSelectedElements(board)[0];
|
|
1588
|
-
if (element && PlaitDrawElement.isGeometry(element)) {
|
|
1589
|
-
const component = PlaitElement.getComponent(element);
|
|
1590
|
-
component.editText();
|
|
1591
|
-
}
|
|
1592
|
-
dblclick(event);
|
|
1593
|
-
};
|
|
1594
1615
|
return withLineText(withLineBoundReaction(withLineResize(withGeometryResize(withLineCreateByDraw(withGeometryCreateByDrag(withGeometryCreateByDraw(withDrawFragment(withDrawHotkey(board)))))))));
|
|
1595
1616
|
};
|
|
1596
1617
|
|
|
@@ -1598,5 +1619,5 @@ const withDraw = (board) => {
|
|
|
1598
1619
|
* Generated bundle index. Do not edit.
|
|
1599
1620
|
*/
|
|
1600
1621
|
|
|
1601
|
-
export { DefaultGeometryActiveStyle, DefaultGeometryProperty, DefaultGeometryStyle, DefaultTextProperty,
|
|
1622
|
+
export { DefaultGeometryActiveStyle, DefaultGeometryProperty, DefaultGeometryStyle, DefaultTextProperty, DrawPointerType, GeometryComponent, GeometryPointer, GeometryShape, GeometryThreshold, LineComponent, LineMarkerType, LineShape, PlaitDrawElement, PlaitGeometry, PlaitLine, ShapeDefaultSpace, createGeometryElement, createLineElement, drawBoundMask, drawElbowLine, drawGeometry, drawLineArrow, getCenterPointsOnPolygon, getConnectionPoint, getElbowPoints, getHitConnectorPoint, getHitLineTextIndex, getLineTextRectangle, getNearestPoint, getPointsByCenterPoint, getSelectedDrawElements, getSelectedGeometryElements, getSelectedLineElements, getSourcePoint, getTargetPoint, getTextRectangle, isHitLineText, isHitPolyLine, transformPointToConnection, withDraw };
|
|
1602
1623
|
//# sourceMappingURL=plait-draw.mjs.map
|