@plait/draw 0.29.0 → 0.31.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/constants/line.mjs +1 -1
- package/esm2022/generators/line-active.generator.mjs +1 -1
- package/esm2022/plugins/with-draw-fragment.mjs +5 -4
- package/esm2022/plugins/with-draw.mjs +15 -31
- package/esm2022/plugins/with-geometry-create.mjs +2 -2
- package/esm2022/plugins/with-geometry-resize.mjs +50 -15
- package/esm2022/plugins/with-line-create.mjs +2 -2
- package/esm2022/plugins/with-line-resize.mjs +28 -10
- package/esm2022/plugins/with-line-text.mjs +4 -4
- package/esm2022/utils/geometry.mjs +64 -3
- package/esm2022/utils/hit.mjs +58 -0
- package/esm2022/utils/index.mjs +2 -1
- package/esm2022/utils/line.mjs +39 -17
- package/esm2022/utils/position/geometry.mjs +1 -1
- package/fesm2022/plait-draw.mjs +770 -604
- package/fesm2022/plait-draw.mjs.map +1 -1
- package/package.json +1 -1
- package/plugins/with-geometry-create.d.ts +2 -1
- package/utils/geometry.d.ts +1 -0
- package/utils/hit.d.ts +3 -0
- package/utils/index.d.ts +1 -0
- package/utils/line.d.ts +2 -3
- package/utils/position/geometry.d.ts +2 -1
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { Point } from '@plait/core';
|
|
1
2
|
import { withResize } from '@plait/common';
|
|
2
3
|
import { getSelectedLineElements } from '../utils/selected';
|
|
3
4
|
import { getHitLineResizeHandleRef, LineResizeHandle } from '../utils/position/line';
|
|
@@ -33,17 +34,23 @@ export const withLineResize = (board) => {
|
|
|
33
34
|
let points = [...resizeRef.element.points];
|
|
34
35
|
let source = { ...resizeRef.element.source };
|
|
35
36
|
let target = { ...resizeRef.element.target };
|
|
36
|
-
if (resizeRef.handle === LineResizeHandle.source) {
|
|
37
|
+
if (resizeRef.handle === LineResizeHandle.source || resizeRef.handle === LineResizeHandle.target) {
|
|
38
|
+
const object = resizeRef.handle === LineResizeHandle.source ? source : target;
|
|
37
39
|
points[pointIndex] = resizeState.endTransformPoint;
|
|
38
40
|
const hitElement = getHitOutlineGeometry(board, resizeState.endTransformPoint, -4);
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
41
|
+
if (hitElement) {
|
|
42
|
+
object.connection = transformPointToConnection(board, resizeState.endTransformPoint, hitElement);
|
|
43
|
+
object.boundId = hitElement.id;
|
|
44
|
+
}
|
|
45
|
+
else {
|
|
46
|
+
object.connection = undefined;
|
|
47
|
+
object.boundId = undefined;
|
|
48
|
+
if (points.length === 2) {
|
|
49
|
+
let movingPoint = points[pointIndex];
|
|
50
|
+
const otherPoint = points[Number(!pointIndex)];
|
|
51
|
+
points[pointIndex] = alignPoints(otherPoint, movingPoint);
|
|
52
|
+
}
|
|
53
|
+
}
|
|
47
54
|
}
|
|
48
55
|
else if (resizeRef.handle === LineResizeHandle.addHandle) {
|
|
49
56
|
points.splice(pointIndex + 1, 0, resizeState.endTransformPoint);
|
|
@@ -57,4 +64,15 @@ export const withLineResize = (board) => {
|
|
|
57
64
|
withResize(board, options);
|
|
58
65
|
return board;
|
|
59
66
|
};
|
|
60
|
-
|
|
67
|
+
const alignPoints = (basePoint, movingPoint) => {
|
|
68
|
+
const offset = 3;
|
|
69
|
+
const newPoint = [...movingPoint];
|
|
70
|
+
if (Point.isVerticalAlign(newPoint, basePoint, offset)) {
|
|
71
|
+
newPoint[0] = basePoint[0];
|
|
72
|
+
}
|
|
73
|
+
if (Point.isHorizontalAlign(newPoint, basePoint, offset)) {
|
|
74
|
+
newPoint[1] = basePoint[1];
|
|
75
|
+
}
|
|
76
|
+
return newPoint;
|
|
77
|
+
};
|
|
78
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-line-resize.js","sourceRoot":"","sources":["../../../../packages/draw/src/plugins/with-line-resize.ts"],"names":[],"mappings":"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","sourcesContent":["import { PlaitBoard, Point } from '@plait/core';\nimport { ResizeRef, ResizeState, WithResizeOptions, withResize } from '@plait/common';\nimport { getSelectedLineElements } from '../utils/selected';\nimport { getHitLineResizeHandleRef, LineResizeHandle } from '../utils/position/line';\nimport { getHitOutlineGeometry } from '../utils/position/geometry';\nimport { LineHandle, PlaitLine } from '../interfaces';\nimport { transformPointToConnection } from '../utils';\nimport { DrawTransforms } from '../transforms';\n\nexport const withLineResize = (board: PlaitBoard) => {\n    let pointIndex = 0;\n    const options: WithResizeOptions<PlaitLine, LineResizeHandle> = {\n        key: 'draw-line',\n        canResize: () => {\n            return true;\n        },\n        detect: (point: Point) => {\n            const selectedLineElements = getSelectedLineElements(board);\n            if (selectedLineElements.length > 0) {\n                let result = null;\n                selectedLineElements.forEach(value => {\n                    const handleRef = getHitLineResizeHandleRef(board, value, point);\n                    if (handleRef) {\n                        result = {\n                            element: value,\n                            handle: handleRef.handle\n                        };\n                        pointIndex = handleRef.index;\n                    }\n                });\n                return result;\n            }\n            return null;\n        },\n        onResize: (resizeRef: ResizeRef<PlaitLine, LineResizeHandle>, resizeState: ResizeState) => {\n            let points: Point[] = [...resizeRef.element.points];\n            let source: LineHandle = { ...resizeRef.element.source };\n            let target: LineHandle = { ...resizeRef.element.target };\n            if (resizeRef.handle === LineResizeHandle.source || resizeRef.handle === LineResizeHandle.target) {\n                const object = resizeRef.handle === LineResizeHandle.source ? source : target;\n                points[pointIndex] = resizeState.endTransformPoint;\n                const hitElement = getHitOutlineGeometry(board, resizeState.endTransformPoint, -4);\n                if (hitElement) {\n                    object.connection = transformPointToConnection(board, resizeState.endTransformPoint, hitElement);\n                    object.boundId = hitElement.id;\n                } else {\n                    object.connection = undefined;\n                    object.boundId = undefined;\n                    if (points.length === 2) {\n                        let movingPoint = points[pointIndex];\n                        const otherPoint = points[Number(!pointIndex)];\n                        points[pointIndex] = alignPoints(otherPoint, movingPoint);\n                    }\n                }\n            } else if (resizeRef.handle === LineResizeHandle.addHandle) {\n                points.splice(pointIndex + 1, 0, resizeState.endTransformPoint);\n            } else {\n                points[pointIndex] = resizeState.endTransformPoint;\n            }\n            DrawTransforms.resizeLine(board, { points, source, target }, resizeRef.path);\n        }\n    };\n\n    withResize<PlaitLine, LineResizeHandle>(board, options);\n\n    return board;\n};\n\nconst alignPoints = (basePoint: Point, movingPoint: Point) => {\n    const offset = 3;\n    const newPoint: Point = [...movingPoint];\n    if (Point.isVerticalAlign(newPoint, basePoint, offset)) {\n        newPoint[0] = basePoint[0];\n    }\n    if (Point.isHorizontalAlign(newPoint, basePoint, offset)) {\n        newPoint[1] = basePoint[1];\n    }\n    return newPoint;\n};\n"]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { PlaitBoard, PlaitElement,
|
|
1
|
+
import { PlaitBoard, PlaitElement, getHitElementByPoint, getNearestPointBetweenPointAndSegments, toPoint, transformPoint } from '@plait/core';
|
|
2
2
|
import { PlaitDrawElement } from '../interfaces';
|
|
3
3
|
import { Node } from 'slate';
|
|
4
4
|
import { getHitLineTextIndex, getLinePoints, isHitLineText } from '../utils';
|
|
@@ -9,9 +9,9 @@ export const withLineText = (board) => {
|
|
|
9
9
|
const { dblclick } = board;
|
|
10
10
|
board.dblclick = (event) => {
|
|
11
11
|
const clickPoint = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));
|
|
12
|
-
const hitTarget =
|
|
12
|
+
const hitTarget = getHitElementByPoint(board, clickPoint, (element) => {
|
|
13
13
|
return PlaitDrawElement.isLine(element);
|
|
14
|
-
})
|
|
14
|
+
});
|
|
15
15
|
if (hitTarget) {
|
|
16
16
|
const points = getLinePoints(board, hitTarget);
|
|
17
17
|
const point = getNearestPointBetweenPointAndSegments(clickPoint, points);
|
|
@@ -52,4 +52,4 @@ function editHandle(board, element, manageIndex, isFirstEdit = false) {
|
|
|
52
52
|
}
|
|
53
53
|
});
|
|
54
54
|
}
|
|
55
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
55
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2l0aC1saW5lLXRleHQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9kcmF3L3NyYy9wbHVnaW5zL3dpdGgtbGluZS10ZXh0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDSCxVQUFVLEVBQ1YsWUFBWSxFQUNaLG9CQUFvQixFQUNwQixzQ0FBc0MsRUFDdEMsT0FBTyxFQUNQLGNBQWMsRUFDakIsTUFBTSxhQUFhLENBQUM7QUFDckIsT0FBTyxFQUFFLGdCQUFnQixFQUFhLE1BQU0sZUFBZSxDQUFDO0FBQzVELE9BQU8sRUFBRSxJQUFJLEVBQUUsTUFBTSxPQUFPLENBQUM7QUFDN0IsT0FBTyxFQUFFLG1CQUFtQixFQUFFLGFBQWEsRUFBRSxhQUFhLEVBQUUsTUFBTSxVQUFVLENBQUM7QUFDN0UsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNoRCxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sYUFBYSxDQUFDO0FBRXhDLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFL0MsTUFBTSxDQUFDLE1BQU0sWUFBWSxHQUFHLENBQUMsS0FBaUIsRUFBRSxFQUFFO0lBQzlDLE1BQU0sRUFBRSxRQUFRLEVBQUUsR0FBRyxLQUFLLENBQUM7SUFFM0IsS0FBSyxDQUFDLFFBQVEsR0FBRyxDQUFDLEtBQWlCLEVBQUUsRUFBRTtRQUNuQyxNQUFNLFVBQVUsR0FBRyxjQUFjLENBQUMsS0FBSyxFQUFFLE9BQU8sQ0FBQyxLQUFLLENBQUMsQ0FBQyxFQUFFLEtBQUssQ0FBQyxDQUFDLEVBQUUsVUFBVSxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDL0YsTUFBTSxTQUFTLEdBQUcsb0JBQW9CLENBQUMsS0FBSyxFQUFFLFVBQVUsRUFBRSxDQUFDLE9BQXFCLEVBQUUsRUFBRTtZQUNoRixPQUFPLGdCQUFnQixDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUM1QyxDQUFDLENBQTBCLENBQUM7UUFDNUIsSUFBSSxTQUFTLEVBQUU7WUFDWCxNQUFNLE1BQU0sR0FBRyxhQUFhLENBQUMsS0FBSyxFQUFFLFNBQVMsQ0FBQyxDQUFDO1lBQy9DLE1BQU0sS0FBSyxHQUFHLHNDQUFzQyxDQUFDLFVBQVUsRUFBRSxNQUFNLENBQUMsQ0FBQztZQUN6RSxNQUFNLEtBQUssR0FBRyxTQUFTLENBQUMsS0FBSyxFQUFFLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLFNBQVMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDO1lBQ2xFLE1BQU0sU0FBUyxHQUFHLG1CQUFtQixDQUFDLEtBQUssRUFBRSxTQUFTLEVBQUUsVUFBVSxDQUFDLENBQUM7WUFDcEUsTUFBTSxTQUFTLEdBQUcsYUFBYSxDQUFDLEtBQUssRUFBRSxTQUFTLEVBQUUsVUFBVSxDQUFDLENBQUM7WUFDOUQsSUFBSSxTQUFTLEVBQUU7Z0JBQ1gsVUFBVSxDQUFDLEtBQUssRUFBRSxTQUFTLEVBQUUsU0FBUyxDQUFDLENBQUM7YUFDM0M7aUJBQU07Z0JBQ0gsTUFBTSxLQUFLLEdBQUcsZUFBZSxDQUFDLE1BQU0sRUFBRSxLQUFLLENBQUMsQ0FBQztnQkFDN0MsS0FBSyxDQUFDLElBQUksQ0FBQztvQkFDUCxJQUFJLEVBQUUsU0FBUyxDQUFDLElBQUksQ0FBQztvQkFDckIsUUFBUSxFQUFFLEtBQUs7b0JBQ2YsS0FBSyxFQUFFLEVBQUU7b0JBQ1QsTUFBTSxFQUFFLEVBQUU7aUJBQ2IsQ0FBQyxDQUFDO2dCQUNILGNBQWMsQ0FBQyxZQUFZLENBQUMsS0FBSyxFQUFFLFNBQVMsRUFBRSxLQUFLLENBQUMsQ0FBQztnQkFDckQsVUFBVSxDQUFDLEdBQUcsRUFBRTtvQkFDWixNQUFNLFlBQVksR0FBRyxZQUFZLENBQUMsWUFBWSxDQUFDLFNBQVMsQ0FBa0IsQ0FBQztvQkFDM0UsVUFBVSxDQUFDLEtBQUssRUFBRSxTQUFTLEVBQUUsWUFBWSxDQUFDLFdBQVcsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxFQUFFLElBQUksQ0FBQyxDQUFDO2dCQUM1RSxDQUFDLENBQUMsQ0FBQzthQUNOO1NBQ0o7UUFFRCxRQUFRLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDcEIsQ0FBQyxDQUFDO0lBRUYsT0FBTyxLQUFLLENBQUM7QUFDakIsQ0FBQyxDQUFDO0FBRUYsU0FBUyxVQUFVLENBQUMsS0FBaUIsRUFBRSxPQUFrQixFQUFFLFdBQW1CLEVBQUUsY0FBdUIsS0FBSztJQUN4RyxNQUFNLFlBQVksR0FBRyxZQUFZLENBQUMsWUFBWSxDQUFDLE9BQU8sQ0FBa0IsQ0FBQztJQUN6RSxNQUFNLFVBQVUsR0FBRyxZQUFZLENBQUMsV0FBVyxDQUFDLFdBQVcsQ0FBQyxDQUFDO0lBQ3pELE1BQU0sVUFBVSxHQUFHLFVBQVUsQ0FBQyxZQUFZLENBQUMsUUFBUSxDQUFDLFFBQVEsQ0FBQztJQUU3RCxVQUFVLENBQUMsSUFBSSxDQUFDLENBQUMsTUFBTSxFQUFFLFVBQVUsRUFBRSxFQUFFO1FBQ25DLE1BQU0sSUFBSSxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDeEMsTUFBTSxZQUFZLEdBQUcsQ0FBQyxXQUFXLElBQUksVUFBVSxLQUFLLFVBQVUsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDO1FBQ3pFLElBQUksWUFBWSxFQUFFO1lBQ2QsY0FBYyxDQUFDLGNBQWMsQ0FBQyxLQUFLLEVBQUUsT0FBTyxFQUFFLFdBQVcsQ0FBQyxDQUFDO1NBQzlEO0lBQ0wsQ0FBQyxDQUFDLENBQUM7QUFDUCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgICBQbGFpdEJvYXJkLFxuICAgIFBsYWl0RWxlbWVudCxcbiAgICBnZXRIaXRFbGVtZW50QnlQb2ludCxcbiAgICBnZXROZWFyZXN0UG9pbnRCZXR3ZWVuUG9pbnRBbmRTZWdtZW50cyxcbiAgICB0b1BvaW50LFxuICAgIHRyYW5zZm9ybVBvaW50XG59IGZyb20gJ0BwbGFpdC9jb3JlJztcbmltcG9ydCB7IFBsYWl0RHJhd0VsZW1lbnQsIFBsYWl0TGluZSB9IGZyb20gJy4uL2ludGVyZmFjZXMnO1xuaW1wb3J0IHsgTm9kZSB9IGZyb20gJ3NsYXRlJztcbmltcG9ydCB7IGdldEhpdExpbmVUZXh0SW5kZXgsIGdldExpbmVQb2ludHMsIGlzSGl0TGluZVRleHQgfSBmcm9tICcuLi91dGlscyc7XG5pbXBvcnQgeyBnZXRSYXRpb0J5UG9pbnQgfSBmcm9tICdAcGxhaXQvY29tbW9uJztcbmltcG9ydCB7IGJ1aWxkVGV4dCB9IGZyb20gJ0BwbGFpdC90ZXh0JztcbmltcG9ydCB7IExpbmVDb21wb25lbnQgfSBmcm9tICcuLi9saW5lLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBEcmF3VHJhbnNmb3JtcyB9IGZyb20gJy4uL3RyYW5zZm9ybXMnO1xuXG5leHBvcnQgY29uc3Qgd2l0aExpbmVUZXh0ID0gKGJvYXJkOiBQbGFpdEJvYXJkKSA9PiB7XG4gICAgY29uc3QgeyBkYmxjbGljayB9ID0gYm9hcmQ7XG5cbiAgICBib2FyZC5kYmxjbGljayA9IChldmVudDogTW91c2VFdmVudCkgPT4ge1xuICAgICAgICBjb25zdCBjbGlja1BvaW50ID0gdHJhbnNmb3JtUG9pbnQoYm9hcmQsIHRvUG9pbnQoZXZlbnQueCwgZXZlbnQueSwgUGxhaXRCb2FyZC5nZXRIb3N0KGJvYXJkKSkpO1xuICAgICAgICBjb25zdCBoaXRUYXJnZXQgPSBnZXRIaXRFbGVtZW50QnlQb2ludChib2FyZCwgY2xpY2tQb2ludCwgKGVsZW1lbnQ6IFBsYWl0RWxlbWVudCkgPT4ge1xuICAgICAgICAgICAgcmV0dXJuIFBsYWl0RHJhd0VsZW1lbnQuaXNMaW5lKGVsZW1lbnQpO1xuICAgICAgICB9KSBhcyB1bmRlZmluZWQgfCBQbGFpdExpbmU7XG4gICAgICAgIGlmIChoaXRUYXJnZXQpIHtcbiAgICAgICAgICAgIGNvbnN0IHBvaW50cyA9IGdldExpbmVQb2ludHMoYm9hcmQsIGhpdFRhcmdldCk7XG4gICAgICAgICAgICBjb25zdCBwb2ludCA9IGdldE5lYXJlc3RQb2ludEJldHdlZW5Qb2ludEFuZFNlZ21lbnRzKGNsaWNrUG9pbnQsIHBvaW50cyk7XG4gICAgICAgICAgICBjb25zdCB0ZXh0cyA9IGhpdFRhcmdldC50ZXh0cz8ubGVuZ3RoID8gWy4uLmhpdFRhcmdldC50ZXh0c10gOiBbXTtcbiAgICAgICAgICAgIGNvbnN0IHRleHRJbmRleCA9IGdldEhpdExpbmVUZXh0SW5kZXgoYm9hcmQsIGhpdFRhcmdldCwgY2xpY2tQb2ludCk7XG4gICAgICAgICAgICBjb25zdCBpc0hpdFRleHQgPSBpc0hpdExpbmVUZXh0KGJvYXJkLCBoaXRUYXJnZXQsIGNsaWNrUG9pbnQpO1xuICAgICAgICAgICAgaWYgKGlzSGl0VGV4dCkge1xuICAgICAgICAgICAgICAgIGVkaXRIYW5kbGUoYm9hcmQsIGhpdFRhcmdldCwgdGV4dEluZGV4KTtcbiAgICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAgICAgY29uc3QgcmF0aW8gPSBnZXRSYXRpb0J5UG9pbnQocG9pbnRzLCBwb2ludCk7XG4gICAgICAgICAgICAgICAgdGV4dHMucHVzaCh7XG4gICAgICAgICAgICAgICAgICAgIHRleHQ6IGJ1aWxkVGV4dCgn5paH5pysJyksXG4gICAgICAgICAgICAgICAgICAgIHBvc2l0aW9uOiByYXRpbyxcbiAgICAgICAgICAgICAgICAgICAgd2lkdGg6IDI4LFxuICAgICAgICAgICAgICAgICAgICBoZWlnaHQ6IDIwXG4gICAgICAgICAgICAgICAgfSk7XG4gICAgICAgICAgICAgICAgRHJhd1RyYW5zZm9ybXMuc2V0TGluZVRleHRzKGJvYXJkLCBoaXRUYXJnZXQsIHRleHRzKTtcbiAgICAgICAgICAgICAgICBzZXRUaW1lb3V0KCgpID0+IHtcbiAgICAgICAgICAgICAgICAgICAgY29uc3QgaGl0Q29tcG9uZW50ID0gUGxhaXRFbGVtZW50LmdldENvbXBvbmVudChoaXRUYXJnZXQpIGFzIExpbmVDb21wb25lbnQ7XG4gICAgICAgICAgICAgICAgICAgIGVkaXRIYW5kbGUoYm9hcmQsIGhpdFRhcmdldCwgaGl0Q29tcG9uZW50LnRleHRNYW5hZ2VzLmxlbmd0aCAtIDEsIHRydWUpO1xuICAgICAgICAgICAgICAgIH0pO1xuICAgICAgICAgICAgfVxuICAgICAgICB9XG5cbiAgICAgICAgZGJsY2xpY2soZXZlbnQpO1xuICAgIH07XG5cbiAgICByZXR1cm4gYm9hcmQ7XG59O1xuXG5mdW5jdGlvbiBlZGl0SGFuZGxlKGJvYXJkOiBQbGFpdEJvYXJkLCBlbGVtZW50OiBQbGFpdExpbmUsIG1hbmFnZUluZGV4OiBudW1iZXIsIGlzRmlyc3RFZGl0OiBib29sZWFuID0gZmFsc2UpIHtcbiAgICBjb25zdCBoaXRDb21wb25lbnQgPSBQbGFpdEVsZW1lbnQuZ2V0Q29tcG9uZW50KGVsZW1lbnQpIGFzIExpbmVDb21wb25lbnQ7XG4gICAgY29uc3QgdGV4dE1hbmFnZSA9IGhpdENvbXBvbmVudC50ZXh0TWFuYWdlc1ttYW5hZ2VJbmRleF07XG4gICAgY29uc3Qgb3JpZ2luVGV4dCA9IHRleHRNYW5hZ2UuY29tcG9uZW50UmVmLmluc3RhbmNlLmNoaWxkcmVuO1xuXG4gICAgdGV4dE1hbmFnZS5lZGl0KChvcmlnaW4sIGRlc2NlbmRhbnQpID0+IHtcbiAgICAgICAgY29uc3QgdGV4dCA9IE5vZGUuc3RyaW5nKGRlc2NlbmRhbnRbMF0pO1xuICAgICAgICBjb25zdCBzaG91bGRSZW1vdmUgPSAoaXNGaXJzdEVkaXQgJiYgb3JpZ2luVGV4dCA9PT0gZGVzY2VuZGFudCkgfHwgIXRleHQ7XG4gICAgICAgIGlmIChzaG91bGRSZW1vdmUpIHtcbiAgICAgICAgICAgIERyYXdUcmFuc2Zvcm1zLnJlbW92ZUxpbmVUZXh0KGJvYXJkLCBlbGVtZW50LCBtYW5hZ2VJbmRleCk7XG4gICAgICAgIH1cbiAgICB9KTtcbn1cbiJdfQ==
|
|
@@ -1,11 +1,15 @@
|
|
|
1
1
|
import { ACTIVE_STROKE_WIDTH, PlaitBoard, RectangleClient, SELECTION_BORDER_COLOR, SELECTION_FILL_COLOR, createG, distanceBetweenPointAndSegment, drawCircle, idCreator } from '@plait/core';
|
|
2
|
-
import { BasicShapes } from '../interfaces/geometry';
|
|
2
|
+
import { BasicShapes, FlowchartSymbols } from '../interfaces/geometry';
|
|
3
3
|
import { Alignment, buildText } from '@plait/text';
|
|
4
|
-
import { DefaultFlowchartPropertyMap, DefaultTextProperty, ShapeDefaultSpace, getFlowchartPointers } from '../constants';
|
|
4
|
+
import { DefaultBasicShapeProperty, DefaultFlowchartPropertyMap, DefaultTextProperty, ShapeDefaultSpace, getFlowchartPointers } from '../constants';
|
|
5
5
|
import { getRectangleByPoints } from '@plait/common';
|
|
6
6
|
import { getStrokeWidthByElement } from './style/stroke';
|
|
7
7
|
import { getEngine } from '../engines';
|
|
8
8
|
import { getShape } from './shape';
|
|
9
|
+
import { getDefaultGeometryPoints } from '../plugins/with-geometry-create';
|
|
10
|
+
import { createLineElement } from './line';
|
|
11
|
+
import { LineMarkerType, LineShape } from '../interfaces';
|
|
12
|
+
import { DefaultLineStyle } from '../constants/line';
|
|
9
13
|
export const createGeometryElement = (shape, points, text, options) => {
|
|
10
14
|
let textOptions = {};
|
|
11
15
|
let alignment = Alignment.center;
|
|
@@ -103,4 +107,61 @@ export const getEdgeOnPolygonByPoint = (corners, point) => {
|
|
|
103
107
|
export const getDefaultFlowchartProperty = (symbol) => {
|
|
104
108
|
return DefaultFlowchartPropertyMap[symbol];
|
|
105
109
|
};
|
|
106
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"geometry.js","sourceRoot":"","sources":["../../../../packages/draw/src/utils/geometry.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    ACTIVE_STROKE_WIDTH,\n    PlaitBoard,\n    Point,\n    RectangleClient,\n    SELECTION_BORDER_COLOR,\n    SELECTION_FILL_COLOR,\n    createG,\n    distanceBetweenPointAndSegment,\n    drawCircle,\n    idCreator\n} from '@plait/core';\nimport { GeometryShapes, BasicShapes, PlaitGeometry, FlowchartSymbols } from '../interfaces/geometry';\nimport { Alignment, buildText } from '@plait/text';\nimport { Element } from 'slate';\nimport { DefaultFlowchartPropertyMap, DefaultTextProperty, ShapeDefaultSpace, getFlowchartPointers } from '../constants';\nimport { getRectangleByPoints } from '@plait/common';\nimport { getStrokeWidthByElement } from './style/stroke';\nimport { Options } from 'roughjs/bin/core';\nimport { getEngine } from '../engines';\nimport { getShape } from './shape';\n\nexport const createGeometryElement = (\n    shape: GeometryShapes,\n    points: [Point, Point],\n    text: string | Element,\n    options?: Pick<PlaitGeometry, 'fill' | 'strokeColor' | 'strokeWidth'>\n): PlaitGeometry => {\n    let textOptions = {};\n    let alignment: undefined | Alignment = Alignment.center;\n    if (shape === BasicShapes.text) {\n        textOptions = { autoSize: true };\n        alignment = undefined;\n    }\n\n    let flowchartOptions = {};\n    if (getFlowchartPointers().includes(shape)) {\n        flowchartOptions = { fill: '#ffffff' };\n    }\n\n    return {\n        id: idCreator(),\n        type: 'geometry',\n        shape,\n        angle: 0,\n        opacity: 1,\n        textHeight: DefaultTextProperty.height,\n        text: buildText(text, alignment),\n        points,\n        ...textOptions,\n        ...options,\n        ...flowchartOptions\n    };\n};\n\nexport const getPointsByCenterPoint = (point: Point, width: number, height: number): [Point, Point] => {\n    const leftTopPoint: Point = [point[0] - width / 2, point[1] - height / 2];\n    const rightBottomPoint: Point = [point[0] + width / 2, point[1] + height / 2];\n\n    return [leftTopPoint, rightBottomPoint];\n};\n\nexport const getTextRectangle = (element: PlaitGeometry) => {\n    const elementRectangle = getRectangleByPoints(element.points!);\n    const strokeWidth = getStrokeWidthByElement(element);\n    const height = element.textHeight;\n    const width = elementRectangle.width - ShapeDefaultSpace.rectangleAndText * 2 - strokeWidth * 2;\n    return {\n        height,\n        width: width > 0 ? width : 0,\n        x: elementRectangle.x + ShapeDefaultSpace.rectangleAndText + strokeWidth,\n        y: elementRectangle.y + (elementRectangle.height - height) / 2\n    };\n};\n\nexport const drawBoundMask = (board: PlaitBoard, element: PlaitGeometry) => {\n    const G = createG();\n    const rectangle = getRectangleByPoints(element.points);\n    const activeRectangle = RectangleClient.inflate(rectangle, ACTIVE_STROKE_WIDTH);\n    const shape = getShape(element);\n    const maskG = drawGeometry(board, activeRectangle, shape, {\n        stroke: SELECTION_BORDER_COLOR,\n        strokeWidth: 1,\n        fill: SELECTION_FILL_COLOR,\n        fillStyle: 'solid'\n    });\n    G.appendChild(maskG);\n    const connectorPoints = getEngine(shape).getConnectorPoints(activeRectangle);\n    connectorPoints.forEach(point => {\n        const circleG = drawCircle(PlaitBoard.getRoughSVG(board), point, 6, {\n            stroke: '#999999',\n            strokeWidth: 1,\n            fill: '#FFF',\n            fillStyle: 'solid'\n        });\n        G.appendChild(circleG);\n    });\n\n    return G;\n};\n\nexport const drawGeometry = (board: PlaitBoard, outerRectangle: RectangleClient, shape: GeometryShapes, options: Options) => {\n    return getEngine(shape).draw(board, outerRectangle, options);\n};\n\nexport const getNearestPoint = (element: PlaitGeometry, point: Point, inflateDelta = 0) => {\n    const rectangle = getRectangleByPoints(element.points);\n    const activeRectangle = RectangleClient.inflate(rectangle, inflateDelta);\n    const shape = getShape(element);\n    return getEngine(shape).getNearestPoint(activeRectangle, point);\n};\n\nexport const getCenterPointsOnPolygon = (points: Point[]) => {\n    const centerPoint: Point[] = [];\n    for (let i = 0; i < points.length; i++) {\n        let j = i == points.length - 1 ? 0 : i + 1;\n        centerPoint.push([(points[i][0] + points[j][0]) / 2, (points[i][1] + points[j][1]) / 2]);\n    }\n    return centerPoint;\n};\n\nexport const getEdgeOnPolygonByPoint = (corners: Point[], point: Point) => {\n    for (let index = 1; index <= corners.length; index++) {\n        let start = corners[index - 1];\n        let end = index === corners.length ? corners[0] : corners[index];\n        const distance = distanceBetweenPointAndSegment(point[0], point[1], start[0], start[1], end[0], end[1]);\n        if (distance < 1) {\n            return [start, end] as [Point, Point];\n        }\n    }\n    return null;\n};\n\nexport const getDefaultFlowchartProperty = (symbol: FlowchartSymbols) => {\n    return DefaultFlowchartPropertyMap[symbol];\n};\n"]}
|
|
110
|
+
export const createDefaultFlowchart = (point) => {
|
|
111
|
+
const decisionProperty = getDefaultFlowchartProperty(FlowchartSymbols.decision);
|
|
112
|
+
const processProperty = getDefaultFlowchartProperty(FlowchartSymbols.process);
|
|
113
|
+
const terminalProperty = getDefaultFlowchartProperty(FlowchartSymbols.terminal);
|
|
114
|
+
const options = {
|
|
115
|
+
strokeColor: DefaultBasicShapeProperty.strokeColor,
|
|
116
|
+
strokeWidth: DefaultBasicShapeProperty.strokeWidth
|
|
117
|
+
};
|
|
118
|
+
const lineOptions = {
|
|
119
|
+
strokeColor: DefaultLineStyle.strokeColor,
|
|
120
|
+
strokeWidth: DefaultLineStyle.strokeWidth
|
|
121
|
+
};
|
|
122
|
+
const startElement = createGeometryElement(FlowchartSymbols.terminal, getDefaultGeometryPoints(FlowchartSymbols.terminal, point), '开始', options);
|
|
123
|
+
const processPoint1 = [point[0], point[1] + terminalProperty.height / 2 + 55 + processProperty.height / 2];
|
|
124
|
+
const processElement1 = createGeometryElement(FlowchartSymbols.process, getDefaultGeometryPoints(FlowchartSymbols.process, processPoint1), '过程', options);
|
|
125
|
+
const decisionPoint = [processPoint1[0], processPoint1[1] + processProperty.height / 2 + 55 + decisionProperty.height / 2];
|
|
126
|
+
const decisionElement = createGeometryElement(FlowchartSymbols.decision, getDefaultGeometryPoints(FlowchartSymbols.decision, decisionPoint), '过程', options);
|
|
127
|
+
const processPoint2 = [decisionPoint[0] + decisionProperty.width / 2 + 75 + processProperty.width / 2, decisionPoint[1]];
|
|
128
|
+
const processElement2 = createGeometryElement(FlowchartSymbols.process, getDefaultGeometryPoints(FlowchartSymbols.process, processPoint2), '过程', options);
|
|
129
|
+
const endPoint = [decisionPoint[0], decisionPoint[1] + decisionProperty.height / 2 + 95 + terminalProperty.height / 2];
|
|
130
|
+
const endElement = createGeometryElement(FlowchartSymbols.terminal, getDefaultGeometryPoints(FlowchartSymbols.terminal, endPoint), '结束', options);
|
|
131
|
+
const line1 = createLineElement(LineShape.elbow, [
|
|
132
|
+
[0, 0],
|
|
133
|
+
[0, 0]
|
|
134
|
+
], { marker: LineMarkerType.none, connection: [0.5, 1], boundId: startElement.id }, { marker: LineMarkerType.arrow, connection: [0.5, 0], boundId: processElement1.id }, [], lineOptions);
|
|
135
|
+
const line2 = createLineElement(LineShape.elbow, [
|
|
136
|
+
[0, 0],
|
|
137
|
+
[0, 0]
|
|
138
|
+
], { marker: LineMarkerType.none, connection: [0.5, 1], boundId: processElement1.id }, { marker: LineMarkerType.arrow, connection: [0.5, 0], boundId: decisionElement.id }, [], lineOptions);
|
|
139
|
+
const line3 = createLineElement(LineShape.elbow, [
|
|
140
|
+
[0, 0],
|
|
141
|
+
[0, 0]
|
|
142
|
+
], { marker: LineMarkerType.none, connection: [0.5, 1], boundId: decisionElement.id }, { marker: LineMarkerType.arrow, connection: [0.5, 0], boundId: endElement.id }, [
|
|
143
|
+
{
|
|
144
|
+
text: buildText('是'),
|
|
145
|
+
position: 0.5,
|
|
146
|
+
width: 14,
|
|
147
|
+
height: 20
|
|
148
|
+
}
|
|
149
|
+
], lineOptions);
|
|
150
|
+
const line4 = createLineElement(LineShape.elbow, [
|
|
151
|
+
[0, 0],
|
|
152
|
+
[0, 0]
|
|
153
|
+
], { marker: LineMarkerType.none, connection: [1, 0.5], boundId: decisionElement.id }, { marker: LineMarkerType.arrow, connection: [0, 0.5], boundId: processElement2.id }, [
|
|
154
|
+
{
|
|
155
|
+
text: buildText('否'),
|
|
156
|
+
position: 0.5,
|
|
157
|
+
width: 14,
|
|
158
|
+
height: 20
|
|
159
|
+
}
|
|
160
|
+
], lineOptions);
|
|
161
|
+
const line5 = createLineElement(LineShape.elbow, [
|
|
162
|
+
[0, 0],
|
|
163
|
+
[0, 0]
|
|
164
|
+
], { marker: LineMarkerType.none, connection: [0.5, 1], boundId: processElement2.id }, { marker: LineMarkerType.arrow, connection: [1, 0.5], boundId: endElement.id }, [], lineOptions);
|
|
165
|
+
return [startElement, processElement1, decisionElement, processElement2, endElement, line1, line2, line3, line4, line5];
|
|
166
|
+
};
|
|
167
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"geometry.js","sourceRoot":"","sources":["../../../../packages/draw/src/utils/geometry.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    ACTIVE_STROKE_WIDTH,\n    PlaitBoard,\n    Point,\n    RectangleClient,\n    SELECTION_BORDER_COLOR,\n    SELECTION_FILL_COLOR,\n    createG,\n    distanceBetweenPointAndSegment,\n    drawCircle,\n    idCreator\n} from '@plait/core';\nimport { GeometryShapes, BasicShapes, PlaitGeometry, FlowchartSymbols } from '../interfaces/geometry';\nimport { Alignment, buildText } from '@plait/text';\nimport { Element } from 'slate';\nimport {\n    DefaultBasicShapeProperty,\n    DefaultFlowchartPropertyMap,\n    DefaultTextProperty,\n    ShapeDefaultSpace,\n    getFlowchartPointers\n} from '../constants';\nimport { getRectangleByPoints } from '@plait/common';\nimport { getStrokeWidthByElement } from './style/stroke';\nimport { Options } from 'roughjs/bin/core';\nimport { getEngine } from '../engines';\nimport { getShape } from './shape';\nimport { getDefaultGeometryPoints } from '../plugins/with-geometry-create';\nimport { createLineElement } from './line';\nimport { LineMarkerType, LineShape } from '../interfaces';\nimport { DefaultLineStyle } from '../constants/line';\n\nexport const createGeometryElement = (\n    shape: GeometryShapes,\n    points: [Point, Point],\n    text: string | Element,\n    options?: Pick<PlaitGeometry, 'fill' | 'strokeColor' | 'strokeWidth'>\n): PlaitGeometry => {\n    let textOptions = {};\n    let alignment: undefined | Alignment = Alignment.center;\n    if (shape === BasicShapes.text) {\n        textOptions = { autoSize: true };\n        alignment = undefined;\n    }\n\n    let flowchartOptions = {};\n    if (getFlowchartPointers().includes(shape)) {\n        flowchartOptions = { fill: '#ffffff' };\n    }\n\n    return {\n        id: idCreator(),\n        type: 'geometry',\n        shape,\n        angle: 0,\n        opacity: 1,\n        textHeight: DefaultTextProperty.height,\n        text: buildText(text, alignment),\n        points,\n        ...textOptions,\n        ...options,\n        ...flowchartOptions\n    };\n};\n\nexport const getPointsByCenterPoint = (point: Point, width: number, height: number): [Point, Point] => {\n    const leftTopPoint: Point = [point[0] - width / 2, point[1] - height / 2];\n    const rightBottomPoint: Point = [point[0] + width / 2, point[1] + height / 2];\n\n    return [leftTopPoint, rightBottomPoint];\n};\n\nexport const getTextRectangle = (element: PlaitGeometry) => {\n    const elementRectangle = getRectangleByPoints(element.points!);\n    const strokeWidth = getStrokeWidthByElement(element);\n    const height = element.textHeight;\n    const width = elementRectangle.width - ShapeDefaultSpace.rectangleAndText * 2 - strokeWidth * 2;\n    return {\n        height,\n        width: width > 0 ? width : 0,\n        x: elementRectangle.x + ShapeDefaultSpace.rectangleAndText + strokeWidth,\n        y: elementRectangle.y + (elementRectangle.height - height) / 2\n    };\n};\n\nexport const drawBoundMask = (board: PlaitBoard, element: PlaitGeometry) => {\n    const G = createG();\n    const rectangle = getRectangleByPoints(element.points);\n    const activeRectangle = RectangleClient.inflate(rectangle, ACTIVE_STROKE_WIDTH);\n    const shape = getShape(element);\n    const maskG = drawGeometry(board, activeRectangle, shape, {\n        stroke: SELECTION_BORDER_COLOR,\n        strokeWidth: 1,\n        fill: SELECTION_FILL_COLOR,\n        fillStyle: 'solid'\n    });\n    G.appendChild(maskG);\n    const connectorPoints = getEngine(shape).getConnectorPoints(activeRectangle);\n    connectorPoints.forEach(point => {\n        const circleG = drawCircle(PlaitBoard.getRoughSVG(board), point, 6, {\n            stroke: '#999999',\n            strokeWidth: 1,\n            fill: '#FFF',\n            fillStyle: 'solid'\n        });\n        G.appendChild(circleG);\n    });\n\n    return G;\n};\n\nexport const drawGeometry = (board: PlaitBoard, outerRectangle: RectangleClient, shape: GeometryShapes, options: Options) => {\n    return getEngine(shape).draw(board, outerRectangle, options);\n};\n\nexport const getNearestPoint = (element: PlaitGeometry, point: Point, inflateDelta = 0) => {\n    const rectangle = getRectangleByPoints(element.points);\n    const activeRectangle = RectangleClient.inflate(rectangle, inflateDelta);\n    const shape = getShape(element);\n    return getEngine(shape).getNearestPoint(activeRectangle, point);\n};\n\nexport const getCenterPointsOnPolygon = (points: Point[]) => {\n    const centerPoint: Point[] = [];\n    for (let i = 0; i < points.length; i++) {\n        let j = i == points.length - 1 ? 0 : i + 1;\n        centerPoint.push([(points[i][0] + points[j][0]) / 2, (points[i][1] + points[j][1]) / 2]);\n    }\n    return centerPoint;\n};\n\nexport const getEdgeOnPolygonByPoint = (corners: Point[], point: Point) => {\n    for (let index = 1; index <= corners.length; index++) {\n        let start = corners[index - 1];\n        let end = index === corners.length ? corners[0] : corners[index];\n        const distance = distanceBetweenPointAndSegment(point[0], point[1], start[0], start[1], end[0], end[1]);\n        if (distance < 1) {\n            return [start, end] as [Point, Point];\n        }\n    }\n    return null;\n};\n\nexport const getDefaultFlowchartProperty = (symbol: FlowchartSymbols) => {\n    return DefaultFlowchartPropertyMap[symbol];\n};\n\nexport const createDefaultFlowchart = (point: Point) => {\n    const decisionProperty = getDefaultFlowchartProperty(FlowchartSymbols.decision);\n    const processProperty = getDefaultFlowchartProperty(FlowchartSymbols.process);\n    const terminalProperty = getDefaultFlowchartProperty(FlowchartSymbols.terminal);\n\n    const options = {\n        strokeColor: DefaultBasicShapeProperty.strokeColor,\n        strokeWidth: DefaultBasicShapeProperty.strokeWidth\n    };\n\n    const lineOptions = {\n        strokeColor: DefaultLineStyle.strokeColor,\n        strokeWidth: DefaultLineStyle.strokeWidth\n    };\n    const startElement = createGeometryElement(\n        FlowchartSymbols.terminal,\n        getDefaultGeometryPoints(FlowchartSymbols.terminal, point),\n        '开始',\n        options\n    );\n\n    const processPoint1: Point = [point[0], point[1] + terminalProperty.height / 2 + 55 + processProperty.height / 2];\n    const processElement1 = createGeometryElement(\n        FlowchartSymbols.process,\n        getDefaultGeometryPoints(FlowchartSymbols.process, processPoint1),\n        '过程',\n        options\n    );\n\n    const decisionPoint: Point = [processPoint1[0], processPoint1[1] + processProperty.height / 2 + 55 + decisionProperty.height / 2];\n    const decisionElement = createGeometryElement(\n        FlowchartSymbols.decision,\n        getDefaultGeometryPoints(FlowchartSymbols.decision, decisionPoint),\n        '过程',\n        options\n    );\n\n    const processPoint2: Point = [decisionPoint[0] + decisionProperty.width / 2 + 75 + processProperty.width / 2, decisionPoint[1]];\n    const processElement2 = createGeometryElement(\n        FlowchartSymbols.process,\n        getDefaultGeometryPoints(FlowchartSymbols.process, processPoint2),\n        '过程',\n        options\n    );\n\n    const endPoint: Point = [decisionPoint[0], decisionPoint[1] + decisionProperty.height / 2 + 95 + terminalProperty.height / 2];\n    const endElement = createGeometryElement(\n        FlowchartSymbols.terminal,\n        getDefaultGeometryPoints(FlowchartSymbols.terminal, endPoint),\n        '结束',\n        options\n    );\n\n    const line1 = createLineElement(\n        LineShape.elbow,\n        [\n            [0, 0],\n            [0, 0]\n        ],\n        { marker: LineMarkerType.none, connection: [0.5, 1], boundId: startElement.id },\n        { marker: LineMarkerType.arrow, connection: [0.5, 0], boundId: processElement1.id },\n        [],\n        lineOptions\n    );\n\n    const line2 = createLineElement(\n        LineShape.elbow,\n        [\n            [0, 0],\n            [0, 0]\n        ],\n        { marker: LineMarkerType.none, connection: [0.5, 1], boundId: processElement1.id },\n        { marker: LineMarkerType.arrow, connection: [0.5, 0], boundId: decisionElement.id },\n        [],\n        lineOptions\n    );\n\n    const line3 = createLineElement(\n        LineShape.elbow,\n        [\n            [0, 0],\n            [0, 0]\n        ],\n        { marker: LineMarkerType.none, connection: [0.5, 1], boundId: decisionElement.id },\n        { marker: LineMarkerType.arrow, connection: [0.5, 0], boundId: endElement.id },\n        [\n            {\n                text: buildText('是'),\n                position: 0.5,\n                width: 14,\n                height: 20\n            }\n        ],\n        lineOptions\n    );\n\n    const line4 = createLineElement(\n        LineShape.elbow,\n        [\n            [0, 0],\n            [0, 0]\n        ],\n        { marker: LineMarkerType.none, connection: [1, 0.5], boundId: decisionElement.id },\n        { marker: LineMarkerType.arrow, connection: [0, 0.5], boundId: processElement2.id },\n        [\n            {\n                text: buildText('否'),\n                position: 0.5,\n                width: 14,\n                height: 20\n            }\n        ],\n        lineOptions\n    );\n\n    const line5 = createLineElement(\n        LineShape.elbow,\n        [\n            [0, 0],\n            [0, 0]\n        ],\n        { marker: LineMarkerType.none, connection: [0.5, 1], boundId: processElement2.id },\n        { marker: LineMarkerType.arrow, connection: [1, 0.5], boundId: endElement.id },\n        [],\n        lineOptions\n    );\n\n    return [startElement, processElement1, decisionElement, processElement2, endElement, line1, line2, line3, line4, line5];\n};\n"]}
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
import { RectangleClient, isPolylineHitRectangle, Point } from '@plait/core';
|
|
2
|
+
import { PlaitDrawElement } from '../interfaces';
|
|
3
|
+
import { TRANSPARENT, getRectangleByPoints } from '@plait/common';
|
|
4
|
+
import { getTextRectangle } from './geometry';
|
|
5
|
+
import { getLinePoints, isHitLineText, isHitPolyLine } from './line';
|
|
6
|
+
import { getFillByElement, getStrokeWidthByElement } from './style/stroke';
|
|
7
|
+
import { DefaultGeometryStyle } from '../constants/geometry';
|
|
8
|
+
import { getEngine } from '../engines';
|
|
9
|
+
import { getShape } from './shape';
|
|
10
|
+
export const isRectangleHitDrawElement = (board, element, selection) => {
|
|
11
|
+
if (PlaitDrawElement.isGeometry(element)) {
|
|
12
|
+
const client = getRectangleByPoints(element.points);
|
|
13
|
+
const rangeRectangle = RectangleClient.toRectangleClient([selection.anchor, selection.focus]);
|
|
14
|
+
if (element.textHeight > client.height) {
|
|
15
|
+
const textClient = getTextRectangle(element);
|
|
16
|
+
return RectangleClient.isHit(rangeRectangle, client) || RectangleClient.isHit(rangeRectangle, textClient);
|
|
17
|
+
}
|
|
18
|
+
return RectangleClient.isHit(rangeRectangle, client);
|
|
19
|
+
}
|
|
20
|
+
if (PlaitDrawElement.isImage(element)) {
|
|
21
|
+
const client = getRectangleByPoints(element.points);
|
|
22
|
+
const rangeRectangle = RectangleClient.toRectangleClient([selection.anchor, selection.focus]);
|
|
23
|
+
return RectangleClient.isHit(rangeRectangle, client);
|
|
24
|
+
}
|
|
25
|
+
if (PlaitDrawElement.isLine(element)) {
|
|
26
|
+
const points = getLinePoints(board, element);
|
|
27
|
+
const strokeWidth = getStrokeWidthByElement(element);
|
|
28
|
+
const isHitText = isHitLineText(board, element, selection.focus);
|
|
29
|
+
const isHit = isHitPolyLine(points, selection.focus, strokeWidth, 3) || isHitText;
|
|
30
|
+
const rangeRectangle = RectangleClient.toRectangleClient([selection.anchor, selection.focus]);
|
|
31
|
+
const isContainPolyLinePoint = points.some(point => {
|
|
32
|
+
return RectangleClient.isHit(rangeRectangle, RectangleClient.toRectangleClient([point, point]));
|
|
33
|
+
});
|
|
34
|
+
const isIntersect = Point.isEquals(selection.anchor, selection.focus) ? isHit : isPolylineHitRectangle(points, rangeRectangle);
|
|
35
|
+
return isContainPolyLinePoint || isIntersect;
|
|
36
|
+
}
|
|
37
|
+
return null;
|
|
38
|
+
};
|
|
39
|
+
export const isHitDrawElement = (board, element, point) => {
|
|
40
|
+
if (PlaitDrawElement.isGeometry(element)) {
|
|
41
|
+
const fill = getFillByElement(element);
|
|
42
|
+
if (fill !== DefaultGeometryStyle.fill && fill !== TRANSPARENT) {
|
|
43
|
+
return isRectangleHitDrawElement(board, element, { anchor: point, focus: point });
|
|
44
|
+
}
|
|
45
|
+
else {
|
|
46
|
+
const strokeWidth = getStrokeWidthByElement(element);
|
|
47
|
+
const engine = getEngine(getShape(element));
|
|
48
|
+
const corners = engine.getCornerPoints(getRectangleByPoints(element.points));
|
|
49
|
+
const isHit = isHitPolyLine(corners, point, strokeWidth, 3);
|
|
50
|
+
return isHit;
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
if (PlaitDrawElement.isImage(element) || PlaitDrawElement.isLine(element)) {
|
|
54
|
+
return isRectangleHitDrawElement(board, element, { anchor: point, focus: point });
|
|
55
|
+
}
|
|
56
|
+
return null;
|
|
57
|
+
};
|
|
58
|
+
//# 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 { PlaitElement, RectangleClient, Selection, PlaitBoard, isPolylineHitRectangle, Point } from '@plait/core';\nimport { PlaitDrawElement } from '../interfaces';\nimport { TRANSPARENT, getRectangleByPoints } from '@plait/common';\nimport { getTextRectangle } from './geometry';\nimport { getLinePoints, isHitLineText, isHitPolyLine } from './line';\nimport { getFillByElement, getStrokeWidthByElement } from './style/stroke';\nimport { DefaultGeometryStyle } from '../constants/geometry';\nimport { getEngine } from '../engines';\nimport { getShape } from './shape';\n\nexport const isRectangleHitDrawElement = (board: PlaitBoard, element: PlaitElement, selection: Selection) => {\n    if (PlaitDrawElement.isGeometry(element)) {\n        const client = getRectangleByPoints(element.points);\n        const rangeRectangle = RectangleClient.toRectangleClient([selection.anchor, selection.focus]);\n        if (element.textHeight > client.height) {\n            const textClient = getTextRectangle(element);\n            return RectangleClient.isHit(rangeRectangle, client) || RectangleClient.isHit(rangeRectangle, textClient);\n        }\n        return RectangleClient.isHit(rangeRectangle, client);\n    }\n    if (PlaitDrawElement.isImage(element)) {\n        const client = getRectangleByPoints(element.points);\n        const rangeRectangle = RectangleClient.toRectangleClient([selection.anchor, selection.focus]);\n        return RectangleClient.isHit(rangeRectangle, client);\n    }\n    if (PlaitDrawElement.isLine(element)) {\n        const points = getLinePoints(board, element);\n        const strokeWidth = getStrokeWidthByElement(element);\n        const isHitText = isHitLineText(board, element, selection.focus);\n        const isHit = isHitPolyLine(points, selection.focus, strokeWidth, 3) || isHitText;\n        const rangeRectangle = RectangleClient.toRectangleClient([selection.anchor, selection.focus]);\n        const isContainPolyLinePoint = points.some(point => {\n            return RectangleClient.isHit(rangeRectangle, RectangleClient.toRectangleClient([point, point]));\n        });\n        const isIntersect = Point.isEquals(selection.anchor, selection.focus) ? isHit : isPolylineHitRectangle(points, rangeRectangle);\n        return isContainPolyLinePoint || isIntersect;\n    }\n    return null;\n};\n\nexport const isHitDrawElement = (board: PlaitBoard, element: PlaitElement, point: Point) => {\n    if (PlaitDrawElement.isGeometry(element)) {\n        const fill = getFillByElement(element);\n        if (fill !== DefaultGeometryStyle.fill && fill !== TRANSPARENT) {\n            return isRectangleHitDrawElement(board, element, { anchor: point, focus: point });\n        } else {\n            const strokeWidth = getStrokeWidthByElement(element);\n            const engine = getEngine(getShape(element));\n            const corners = engine.getCornerPoints(getRectangleByPoints(element.points));\n            const isHit = isHitPolyLine(corners, point, strokeWidth, 3);\n            return isHit;\n        }\n    }\n    if (PlaitDrawElement.isImage(element) || PlaitDrawElement.isLine(element)) {\n        return isRectangleHitDrawElement(board, element, { anchor: point, focus: point });\n    }\n    return null;\n};\n"]}
|
package/esm2022/utils/index.mjs
CHANGED
|
@@ -2,4 +2,5 @@ export * from './line';
|
|
|
2
2
|
export * from './geometry';
|
|
3
3
|
export * from './selected';
|
|
4
4
|
export * from './style';
|
|
5
|
-
|
|
5
|
+
export * from './hit';
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9kcmF3L3NyYy91dGlscy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLFFBQVEsQ0FBQztBQUN2QixjQUFjLFlBQVksQ0FBQztBQUMzQixjQUFjLFlBQVksQ0FBQztBQUMzQixjQUFjLFNBQVMsQ0FBQztBQUN4QixjQUFjLE9BQU8sQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbGluZSc7XG5leHBvcnQgKiBmcm9tICcuL2dlb21ldHJ5JztcbmV4cG9ydCAqIGZyb20gJy4vc2VsZWN0ZWQnO1xuZXhwb3J0ICogZnJvbSAnLi9zdHlsZSc7XG5leHBvcnQgKiBmcm9tICcuL2hpdCc7XG4iXX0=
|