@plait/draw 0.52.0 → 0.54.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/constants/geometry.d.ts +3 -1
- package/esm2022/constants/geometry.mjs +4 -2
- package/esm2022/generators/line-auto-complete.generator.mjs +1 -1
- package/esm2022/interfaces/index.mjs +2 -2
- package/esm2022/interfaces/line.mjs +20 -8
- package/esm2022/line.component.mjs +5 -17
- package/esm2022/plugins/with-draw-fragment.mjs +1 -1
- package/esm2022/plugins/with-draw-hotkey.mjs +9 -7
- package/esm2022/plugins/with-draw-resize.mjs +114 -13
- package/esm2022/plugins/with-draw.mjs +5 -12
- package/esm2022/plugins/with-geometry-resize.mjs +8 -5
- package/esm2022/plugins/with-line-auto-complete-reaction.mjs +7 -4
- package/esm2022/plugins/with-line-auto-complete.mjs +17 -16
- package/esm2022/plugins/with-line-bound-reaction.mjs +20 -19
- package/esm2022/plugins/with-line-create.mjs +4 -4
- package/esm2022/plugins/with-line-resize.mjs +10 -11
- package/esm2022/transforms/line.mjs +4 -4
- package/esm2022/utils/geometry.mjs +31 -22
- package/esm2022/utils/hit.mjs +29 -27
- package/esm2022/utils/line/elbow.mjs +22 -9
- package/esm2022/utils/line/line-basic.mjs +21 -25
- package/esm2022/utils/line/line-common.mjs +27 -15
- package/esm2022/utils/line/line-resize.mjs +7 -11
- package/esm2022/utils/position/geometry.mjs +52 -20
- package/esm2022/utils/resize-snap.mjs +361 -0
- package/esm2022/utils/shape.mjs +2 -2
- package/fesm2022/plait-draw.mjs +556 -437
- package/fesm2022/plait-draw.mjs.map +1 -1
- package/generators/line-auto-complete.generator.d.ts +3 -3
- package/interfaces/index.d.ts +2 -2
- package/package.json +1 -1
- package/plugins/with-draw-fragment.d.ts +2 -2
- package/plugins/with-draw-resize.d.ts +12 -0
- package/utils/geometry.d.ts +7 -4
- package/utils/hit.d.ts +3 -1
- package/utils/line/elbow.d.ts +6 -13
- package/utils/line/line-basic.d.ts +4 -4
- package/utils/line/line-common.d.ts +3 -13
- package/utils/position/geometry.d.ts +12 -5
- package/utils/resize-snap.d.ts +49 -0
- package/utils/shape.d.ts +2 -2
- package/esm2022/generators/group.generator.mjs +0 -20
- package/esm2022/group.component.mjs +0 -47
- package/esm2022/utils/resize-align-reaction.mjs +0 -316
- package/esm2022/utils/resize-align.mjs +0 -37
- package/generators/group.generator.d.ts +0 -6
- package/group.component.d.ts +0 -17
- package/utils/resize-align-reaction.d.ts +0 -42
- package/utils/resize-align.d.ts +0 -8
|
@@ -1,11 +1,11 @@
|
|
|
1
|
-
import { ACTIVE_STROKE_WIDTH, BoardTransforms, PlaitBoard, PlaitPointerType, RectangleClient, SELECTION_BORDER_COLOR, SELECTION_FILL_COLOR, Transforms, addSelectedElement, clearSelectedElement, createG, drawCircle, idCreator } from '@plait/core';
|
|
1
|
+
import { ACTIVE_STROKE_WIDTH, BoardTransforms, PlaitBoard, PlaitPointerType, RectangleClient, SELECTION_BORDER_COLOR, SELECTION_FILL_COLOR, SNAPPING_STROKE_WIDTH, Transforms, addSelectedElement, clearSelectedElement, createG, drawCircle, idCreator } from '@plait/core';
|
|
2
2
|
import { BasicShapes, FlowchartSymbols } from '../interfaces/geometry';
|
|
3
3
|
import { Alignment, DEFAULT_FONT_SIZE, buildText, getTextSize } from '@plait/text';
|
|
4
4
|
import { DefaultBasicShapeProperty, DefaultFlowchartPropertyMap, DefaultTextProperty, DrawThemeColors, ShapeDefaultSpace, getFlowchartPointers } from '../constants';
|
|
5
5
|
import { RESIZE_HANDLE_DIAMETER } from '@plait/common';
|
|
6
6
|
import { getStrokeWidthByElement } from './style/stroke';
|
|
7
7
|
import { getEngine } from '../engines';
|
|
8
|
-
import {
|
|
8
|
+
import { getElementShape } from './shape';
|
|
9
9
|
import { createLineElement } from './line/line-basic';
|
|
10
10
|
import { LineMarkerType, LineShape } from '../interfaces';
|
|
11
11
|
import { DefaultLineStyle } from '../constants/line';
|
|
@@ -48,36 +48,45 @@ export const getTextRectangle = (element) => {
|
|
|
48
48
|
y: elementRectangle.y + (elementRectangle.height - height) / 2
|
|
49
49
|
};
|
|
50
50
|
};
|
|
51
|
-
export const
|
|
52
|
-
const
|
|
51
|
+
export const drawBoundReaction = (board, element, options = { hasMask: true, hasConnector: true }) => {
|
|
52
|
+
const g = createG();
|
|
53
53
|
const rectangle = RectangleClient.getRectangleByPoints(element.points);
|
|
54
|
-
const activeRectangle = RectangleClient.inflate(rectangle,
|
|
55
|
-
const shape =
|
|
56
|
-
const
|
|
54
|
+
const activeRectangle = RectangleClient.inflate(rectangle, SNAPPING_STROKE_WIDTH);
|
|
55
|
+
const shape = getElementShape(element);
|
|
56
|
+
const strokeG = drawGeometry(board, activeRectangle, shape, {
|
|
57
57
|
stroke: SELECTION_BORDER_COLOR,
|
|
58
|
-
strokeWidth:
|
|
59
|
-
fill: SELECTION_FILL_COLOR,
|
|
60
|
-
fillStyle: 'solid'
|
|
58
|
+
strokeWidth: SNAPPING_STROKE_WIDTH
|
|
61
59
|
});
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
fill: '#FFF',
|
|
60
|
+
g.appendChild(strokeG);
|
|
61
|
+
if (options.hasMask) {
|
|
62
|
+
const maskG = drawGeometry(board, activeRectangle, shape, {
|
|
63
|
+
stroke: SELECTION_BORDER_COLOR,
|
|
64
|
+
strokeWidth: 0,
|
|
65
|
+
fill: SELECTION_FILL_COLOR,
|
|
69
66
|
fillStyle: 'solid'
|
|
70
67
|
});
|
|
71
|
-
|
|
72
|
-
}
|
|
73
|
-
|
|
68
|
+
g.appendChild(maskG);
|
|
69
|
+
}
|
|
70
|
+
if (options.hasConnector) {
|
|
71
|
+
const connectorPoints = getEngine(shape).getConnectorPoints(rectangle);
|
|
72
|
+
connectorPoints.forEach(point => {
|
|
73
|
+
const circleG = drawCircle(PlaitBoard.getRoughSVG(board), point, 8, {
|
|
74
|
+
stroke: SELECTION_BORDER_COLOR,
|
|
75
|
+
strokeWidth: ACTIVE_STROKE_WIDTH,
|
|
76
|
+
fill: '#FFF',
|
|
77
|
+
fillStyle: 'solid'
|
|
78
|
+
});
|
|
79
|
+
g.appendChild(circleG);
|
|
80
|
+
});
|
|
81
|
+
}
|
|
82
|
+
return g;
|
|
74
83
|
};
|
|
75
84
|
export const drawGeometry = (board, outerRectangle, shape, options) => {
|
|
76
85
|
return getEngine(shape).draw(board, outerRectangle, options);
|
|
77
86
|
};
|
|
78
87
|
export const getNearestPoint = (element, point) => {
|
|
79
88
|
const rectangle = RectangleClient.getRectangleByPoints(element.points);
|
|
80
|
-
const shape =
|
|
89
|
+
const shape = getElementShape(element);
|
|
81
90
|
return getEngine(shape).getNearestPoint(rectangle, point);
|
|
82
91
|
};
|
|
83
92
|
export const getCenterPointsOnPolygon = (points) => {
|
|
@@ -214,4 +223,4 @@ export const createDefaultGeometry = (board, points, shape) => {
|
|
|
214
223
|
...memorizedLatest.geometryProperties
|
|
215
224
|
}, { ...memorizedLatest.textProperties, textHeight });
|
|
216
225
|
};
|
|
217
|
-
//# 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    BoardTransforms,\n    PlaitBoard,\n    PlaitPointerType,\n    Point,\n    RectangleClient,\n    SELECTION_BORDER_COLOR,\n    SELECTION_FILL_COLOR,\n    ThemeColorMode,\n    Transforms,\n    Vector,\n    addSelectedElement,\n    clearSelectedElement,\n    createG,\n    drawCircle,\n    idCreator\n} from '@plait/core';\nimport { GeometryShapes, BasicShapes, PlaitGeometry, FlowchartSymbols } from '../interfaces/geometry';\nimport { Alignment, CustomText, DEFAULT_FONT_SIZE, buildText, getTextSize } from '@plait/text';\nimport { Element } from 'slate';\nimport {\n    DefaultBasicShapeProperty,\n    DefaultFlowchartPropertyMap,\n    DefaultTextProperty,\n    DrawPointerType,\n    DrawThemeColors,\n    ShapeDefaultSpace,\n    getFlowchartPointers\n} from '../constants';\nimport { RESIZE_HANDLE_DIAMETER } from '@plait/common';\nimport { getStrokeWidthByElement } from './style/stroke';\nimport { Options } from 'roughjs/bin/core';\nimport { getEngine } from '../engines';\nimport { getShape } from './shape';\nimport { createLineElement } from './line/line-basic';\nimport { LineMarkerType, LineShape, PlaitShape } from '../interfaces';\nimport { DefaultLineStyle } from '../constants/line';\nimport { getMemorizedLatestByPointer, memorizeLatestShape } from './memorize';\n\nexport type GeometryStyleOptions = Pick<PlaitGeometry, 'fill' | 'strokeColor' | 'strokeWidth'>;\n\nexport type TextProperties = Partial<CustomText> & { align?: Alignment; textHeight?: number };\n\nexport const createGeometryElement = (\n    shape: GeometryShapes,\n    points: [Point, Point],\n    text: string | Element,\n    options: GeometryStyleOptions = {},\n    textProperties: TextProperties = {}\n): PlaitGeometry => {\n    let textOptions = {};\n    let alignment: undefined | Alignment = Alignment.center;\n    let textHeight = DefaultTextProperty.height;\n    if (shape === BasicShapes.text) {\n        textOptions = { autoSize: true };\n        alignment = undefined;\n    }\n    textProperties = { ...textProperties };\n    textProperties?.align && (alignment = textProperties?.align);\n    textProperties?.textHeight && (textHeight = textProperties?.textHeight);\n    delete textProperties?.align;\n    delete textProperties?.textHeight;\n    return {\n        id: idCreator(),\n        type: 'geometry',\n        shape,\n        angle: 0,\n        opacity: 1,\n        textHeight,\n        text: buildText(text, alignment, textProperties),\n        points,\n        ...textOptions,\n        ...options\n    };\n};\n\nexport const getTextRectangle = (element: PlaitGeometry) => {\n    const elementRectangle = RectangleClient.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 = RectangleClient.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: PlaitShape, point: Point) => {\n    const rectangle = RectangleClient.getRectangleByPoints(element.points);\n    const shape = getShape(element);\n    return getEngine(shape).getNearestPoint(rectangle, 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 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        strokeWidth: DefaultBasicShapeProperty.strokeWidth\n    };\n\n    const lineOptions = {\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\nexport const getAutoCompletePoints = (element: PlaitShape) => {\n    const AutoCompleteMargin = (12 + RESIZE_HANDLE_DIAMETER / 2) * 2;\n    let rectangle = RectangleClient.getRectangleByPoints(element.points);\n    rectangle = RectangleClient.inflate(rectangle, AutoCompleteMargin);\n    return RectangleClient.getEdgeCenterPoints(rectangle);\n};\n\nexport const getHitIndexOfAutoCompletePoint = (movingPoint: Point, points: Point[]) => {\n    return points.findIndex(point => {\n        const movingRectangle = RectangleClient.getRectangleByPoints([movingPoint]);\n        let rectangle = RectangleClient.getRectangleByPoints([point]);\n        rectangle = RectangleClient.inflate(rectangle, RESIZE_HANDLE_DIAMETER);\n        return RectangleClient.isHit(movingRectangle, rectangle);\n    });\n};\n\nexport const getDrawDefaultStrokeColor = (theme: ThemeColorMode) => {\n    return DrawThemeColors[theme].strokeColor;\n};\n\nexport const getFlowchartDefaultFill = (theme: ThemeColorMode) => {\n    return DrawThemeColors[theme].fill;\n};\n\nexport const getTextShapeProperty = (board: PlaitBoard, text: string | Element = DefaultTextProperty.text, fontSize?: number | string) => {\n    fontSize = fontSize ? Number(fontSize) : DEFAULT_FONT_SIZE;\n    const textSize = getTextSize(board, text, Infinity, { fontSize });\n    return {\n        width: textSize.width + ShapeDefaultSpace.rectangleAndText * 2,\n        height: textSize.height\n    };\n};\n\nexport const getDefaultGeometryPoints = (pointer: DrawPointerType, centerPoint: Point) => {\n    const property = getDefaultGeometryProperty(pointer);\n    return RectangleClient.getPoints(\n        RectangleClient.getRectangleByCenterPoint(centerPoint, property.width, property.height)\n    );\n};\n\nexport const getDefaultGeometryProperty = (pointer: DrawPointerType) => {\n    const isFlowChart = getFlowchartPointers().includes(pointer);\n    if (isFlowChart) {\n        return getDefaultFlowchartProperty(pointer as FlowchartSymbols);\n    } else {\n        return DefaultBasicShapeProperty;\n    }\n};\n\nexport const getDefaultTextPoints = (board: PlaitBoard, centerPoint: Point, fontSize?: number | string) => {\n    const property = getTextShapeProperty(board, DefaultTextProperty.text, fontSize);\n    return RectangleClient.getPoints(\n        RectangleClient.getRectangleByCenterPoint(centerPoint, property.width, property.height)\n    );\n};\n\nexport const insertElement = (board: PlaitBoard, element: PlaitGeometry) => {\n    memorizeLatestShape(board, element.shape);\n    Transforms.insertNode(board, element, [board.children.length]);\n    clearSelectedElement(board);\n    addSelectedElement(board, element);\n    BoardTransforms.updatePointerType(board, PlaitPointerType.selection);\n};\n\nexport const createTextElement = (\n    board: PlaitBoard,\n    points: [Point, Point],\n    text: string | Element = DefaultTextProperty.text,\n    textHeight?: number\n) => {\n    const memorizedLatest = getMemorizedLatestByPointer(BasicShapes.text);\n    textHeight = textHeight ? textHeight : RectangleClient.getRectangleByPoints(points).height;\n    return createGeometryElement(BasicShapes.text, points, text, memorizedLatest.geometryProperties as GeometryStyleOptions, {\n        ...memorizedLatest.textProperties,\n        textHeight\n    });\n};\n\nexport const createDefaultGeometry = (board: PlaitBoard, points: [Point, Point], shape: GeometryShapes) => {\n    const memorizedLatest = getMemorizedLatestByPointer(shape);\n    const textHeight = getTextShapeProperty(board, DefaultTextProperty.text, memorizedLatest.textProperties['font-size']).height;\n    return createGeometryElement(\n        shape,\n        points,\n        '',\n        {\n            strokeWidth: DefaultBasicShapeProperty.strokeWidth,\n            ...(memorizedLatest.geometryProperties as GeometryStyleOptions)\n        },\n        { ...memorizedLatest.textProperties, textHeight }\n    );\n};\n"]}
|
|
226
|
+
//# 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    BoardTransforms,\n    PlaitBoard,\n    PlaitPointerType,\n    Point,\n    RectangleClient,\n    SELECTION_BORDER_COLOR,\n    SELECTION_FILL_COLOR,\n    SNAPPING_STROKE_WIDTH,\n    ThemeColorMode,\n    Transforms,\n    addSelectedElement,\n    clearSelectedElement,\n    createG,\n    drawCircle,\n    idCreator\n} from '@plait/core';\nimport { GeometryShapes, BasicShapes, PlaitGeometry, FlowchartSymbols } from '../interfaces/geometry';\nimport { Alignment, CustomText, DEFAULT_FONT_SIZE, buildText, getTextSize } from '@plait/text';\nimport { Element } from 'slate';\nimport {\n    DefaultBasicShapeProperty,\n    DefaultFlowchartPropertyMap,\n    DefaultTextProperty,\n    DrawPointerType,\n    DrawThemeColors,\n    ShapeDefaultSpace,\n    getFlowchartPointers\n} from '../constants';\nimport { RESIZE_HANDLE_DIAMETER } from '@plait/common';\nimport { getStrokeWidthByElement } from './style/stroke';\nimport { Options } from 'roughjs/bin/core';\nimport { getEngine } from '../engines';\nimport { getElementShape } from './shape';\nimport { createLineElement } from './line/line-basic';\nimport { LineMarkerType, LineShape, PlaitShapeElement } from '../interfaces';\nimport { DefaultLineStyle } from '../constants/line';\nimport { getMemorizedLatestByPointer, memorizeLatestShape } from './memorize';\n\nexport type GeometryStyleOptions = Pick<PlaitGeometry, 'fill' | 'strokeColor' | 'strokeWidth'>;\n\nexport type TextProperties = Partial<CustomText> & { align?: Alignment; textHeight?: number };\n\nexport const createGeometryElement = (\n    shape: GeometryShapes,\n    points: [Point, Point],\n    text: string | Element,\n    options: GeometryStyleOptions = {},\n    textProperties: TextProperties = {}\n): PlaitGeometry => {\n    let textOptions = {};\n    let alignment: undefined | Alignment = Alignment.center;\n    let textHeight = DefaultTextProperty.height;\n    if (shape === BasicShapes.text) {\n        textOptions = { autoSize: true };\n        alignment = undefined;\n    }\n    textProperties = { ...textProperties };\n    textProperties?.align && (alignment = textProperties?.align);\n    textProperties?.textHeight && (textHeight = textProperties?.textHeight);\n    delete textProperties?.align;\n    delete textProperties?.textHeight;\n    return {\n        id: idCreator(),\n        type: 'geometry',\n        shape,\n        angle: 0,\n        opacity: 1,\n        textHeight,\n        text: buildText(text, alignment, textProperties),\n        points,\n        ...textOptions,\n        ...options\n    };\n};\n\nexport const getTextRectangle = (element: PlaitGeometry) => {\n    const elementRectangle = RectangleClient.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 drawBoundReaction = (\n    board: PlaitBoard,\n    element: PlaitGeometry,\n    options: { hasMask: boolean; hasConnector: boolean } = { hasMask: true, hasConnector: true }\n) => {\n    const g = createG();\n    const rectangle = RectangleClient.getRectangleByPoints(element.points);\n    const activeRectangle = RectangleClient.inflate(rectangle, SNAPPING_STROKE_WIDTH);\n    const shape = getElementShape(element);\n    const strokeG = drawGeometry(board, activeRectangle, shape, {\n        stroke: SELECTION_BORDER_COLOR,\n        strokeWidth: SNAPPING_STROKE_WIDTH\n    });\n    g.appendChild(strokeG);\n    if (options.hasMask) {\n        const maskG = drawGeometry(board, activeRectangle, shape, {\n            stroke: SELECTION_BORDER_COLOR,\n            strokeWidth: 0,\n            fill: SELECTION_FILL_COLOR,\n            fillStyle: 'solid'\n        });\n        g.appendChild(maskG);\n    }\n    if (options.hasConnector) {\n        const connectorPoints = getEngine(shape).getConnectorPoints(rectangle);\n        connectorPoints.forEach(point => {\n            const circleG = drawCircle(PlaitBoard.getRoughSVG(board), point, 8, {\n                stroke: SELECTION_BORDER_COLOR,\n                strokeWidth: ACTIVE_STROKE_WIDTH,\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: PlaitShapeElement, point: Point) => {\n    const rectangle = RectangleClient.getRectangleByPoints(element.points);\n    const shape = getElementShape(element);\n    return getEngine(shape).getNearestPoint(rectangle, 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 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        strokeWidth: DefaultBasicShapeProperty.strokeWidth\n    };\n\n    const lineOptions = {\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\nexport const getAutoCompletePoints = (element: PlaitShapeElement) => {\n    const AutoCompleteMargin = (12 + RESIZE_HANDLE_DIAMETER / 2) * 2;\n    let rectangle = RectangleClient.getRectangleByPoints(element.points);\n    rectangle = RectangleClient.inflate(rectangle, AutoCompleteMargin);\n    return RectangleClient.getEdgeCenterPoints(rectangle);\n};\n\nexport const getHitIndexOfAutoCompletePoint = (movingPoint: Point, points: Point[]) => {\n    return points.findIndex(point => {\n        const movingRectangle = RectangleClient.getRectangleByPoints([movingPoint]);\n        let rectangle = RectangleClient.getRectangleByPoints([point]);\n        rectangle = RectangleClient.inflate(rectangle, RESIZE_HANDLE_DIAMETER);\n        return RectangleClient.isHit(movingRectangle, rectangle);\n    });\n};\n\nexport const getDrawDefaultStrokeColor = (theme: ThemeColorMode) => {\n    return DrawThemeColors[theme].strokeColor;\n};\n\nexport const getFlowchartDefaultFill = (theme: ThemeColorMode) => {\n    return DrawThemeColors[theme].fill;\n};\n\nexport const getTextShapeProperty = (board: PlaitBoard, text: string | Element = DefaultTextProperty.text, fontSize?: number | string) => {\n    fontSize = fontSize ? Number(fontSize) : DEFAULT_FONT_SIZE;\n    const textSize = getTextSize(board, text, Infinity, { fontSize });\n    return {\n        width: textSize.width + ShapeDefaultSpace.rectangleAndText * 2,\n        height: textSize.height\n    };\n};\n\nexport const getDefaultGeometryPoints = (pointer: DrawPointerType, centerPoint: Point) => {\n    const property = getDefaultGeometryProperty(pointer);\n    return RectangleClient.getPoints(RectangleClient.getRectangleByCenterPoint(centerPoint, property.width, property.height));\n};\n\nexport const getDefaultGeometryProperty = (pointer: DrawPointerType) => {\n    const isFlowChart = getFlowchartPointers().includes(pointer);\n    if (isFlowChart) {\n        return getDefaultFlowchartProperty(pointer as FlowchartSymbols);\n    } else {\n        return DefaultBasicShapeProperty;\n    }\n};\n\nexport const getDefaultTextPoints = (board: PlaitBoard, centerPoint: Point, fontSize?: number | string) => {\n    const property = getTextShapeProperty(board, DefaultTextProperty.text, fontSize);\n    return RectangleClient.getPoints(RectangleClient.getRectangleByCenterPoint(centerPoint, property.width, property.height));\n};\n\nexport const insertElement = (board: PlaitBoard, element: PlaitGeometry) => {\n    memorizeLatestShape(board, element.shape);\n    Transforms.insertNode(board, element, [board.children.length]);\n    clearSelectedElement(board);\n    addSelectedElement(board, element);\n    BoardTransforms.updatePointerType(board, PlaitPointerType.selection);\n};\n\nexport const createTextElement = (\n    board: PlaitBoard,\n    points: [Point, Point],\n    text: string | Element = DefaultTextProperty.text,\n    textHeight?: number\n) => {\n    const memorizedLatest = getMemorizedLatestByPointer(BasicShapes.text);\n    textHeight = textHeight ? textHeight : RectangleClient.getRectangleByPoints(points).height;\n    return createGeometryElement(BasicShapes.text, points, text, memorizedLatest.geometryProperties as GeometryStyleOptions, {\n        ...memorizedLatest.textProperties,\n        textHeight\n    });\n};\n\nexport const createDefaultGeometry = (board: PlaitBoard, points: [Point, Point], shape: GeometryShapes) => {\n    const memorizedLatest = getMemorizedLatestByPointer(shape);\n    const textHeight = getTextShapeProperty(board, DefaultTextProperty.text, memorizedLatest.textProperties['font-size']).height;\n    return createGeometryElement(\n        shape,\n        points,\n        '',\n        {\n            strokeWidth: DefaultBasicShapeProperty.strokeWidth,\n            ...(memorizedLatest.geometryProperties as GeometryStyleOptions)\n        },\n        { ...memorizedLatest.textProperties, textHeight }\n    );\n};\n"]}
|
package/esm2022/utils/hit.mjs
CHANGED
|
@@ -1,12 +1,12 @@
|
|
|
1
|
-
import { RectangleClient, isPolylineHitRectangle, distanceBetweenPointAndSegments, distanceBetweenPointAndPoint, HIT_DISTANCE_BUFFER,
|
|
1
|
+
import { RectangleClient, isPolylineHitRectangle, distanceBetweenPointAndSegments, distanceBetweenPointAndPoint, HIT_DISTANCE_BUFFER, rotatePointsByElement, rotateAntiPointsByElement } from '@plait/core';
|
|
2
2
|
import { PlaitDrawElement } from '../interfaces';
|
|
3
|
-
import { TRANSPARENT
|
|
4
|
-
import { getTextRectangle } from './geometry';
|
|
3
|
+
import { TRANSPARENT } from '@plait/common';
|
|
4
|
+
import { getNearestPoint, getTextRectangle } from './geometry';
|
|
5
5
|
import { getLinePoints } from './line/line-basic';
|
|
6
6
|
import { getFillByElement } from './style/stroke';
|
|
7
7
|
import { DefaultGeometryStyle } from '../constants/geometry';
|
|
8
8
|
import { getEngine } from '../engines';
|
|
9
|
-
import {
|
|
9
|
+
import { getElementShape } from './shape';
|
|
10
10
|
import { getHitLineTextIndex } from './position/line';
|
|
11
11
|
export const isTextExceedingBounds = (geometry) => {
|
|
12
12
|
const client = RectangleClient.getRectangleByPoints(geometry.points);
|
|
@@ -31,18 +31,18 @@ export const isRectangleHitDrawElement = (board, element, selection) => {
|
|
|
31
31
|
const rangeRectangle = RectangleClient.getRectangleByPoints([selection.anchor, selection.focus]);
|
|
32
32
|
if (PlaitDrawElement.isGeometry(element)) {
|
|
33
33
|
const client = RectangleClient.getRectangleByPoints(element.points);
|
|
34
|
-
|
|
35
|
-
let rotatedCornerPoints = rotatePoints(RectangleClient.getCornerPoints(client), centerPoint, element.angle);
|
|
34
|
+
let rotatedCornerPoints = rotatePointsByElement(RectangleClient.getCornerPoints(client), element) || RectangleClient.getCornerPoints(client);
|
|
36
35
|
if (isTextExceedingBounds(element)) {
|
|
37
36
|
const textClient = getTextRectangle(element);
|
|
38
|
-
rotatedCornerPoints =
|
|
37
|
+
rotatedCornerPoints =
|
|
38
|
+
rotatePointsByElement(RectangleClient.getCornerPoints(textClient), element) || RectangleClient.getCornerPoints(textClient);
|
|
39
39
|
}
|
|
40
40
|
return isPolylineHitRectangle(rotatedCornerPoints, rangeRectangle);
|
|
41
41
|
}
|
|
42
42
|
if (PlaitDrawElement.isImage(element)) {
|
|
43
43
|
const client = RectangleClient.getRectangleByPoints(element.points);
|
|
44
|
-
const rotatedCornerPoints =
|
|
45
|
-
return isPolylineHitRectangle(rotatedCornerPoints,
|
|
44
|
+
const rotatedCornerPoints = rotatePointsByElement(RectangleClient.getCornerPoints(client), element) || RectangleClient.getCornerPoints(client);
|
|
45
|
+
return isPolylineHitRectangle(rotatedCornerPoints, rangeRectangle);
|
|
46
46
|
}
|
|
47
47
|
if (PlaitDrawElement.isLine(element)) {
|
|
48
48
|
const points = getLinePoints(board, element);
|
|
@@ -52,19 +52,13 @@ export const isRectangleHitDrawElement = (board, element, selection) => {
|
|
|
52
52
|
};
|
|
53
53
|
export const isHitDrawElement = (board, element, point) => {
|
|
54
54
|
const rectangle = board.getRectangle(element);
|
|
55
|
-
|
|
56
|
-
if (element.angle) {
|
|
57
|
-
point = rotate(point[0], point[1], centerPoint[0], centerPoint[1], -element.angle);
|
|
58
|
-
}
|
|
55
|
+
point = rotateAntiPointsByElement(point, element) || point;
|
|
59
56
|
if (PlaitDrawElement.isGeometry(element)) {
|
|
60
57
|
const fill = getFillByElement(board, element);
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
const distance = distanceBetweenPointAndPoint(nearestPoint[0], nearestPoint[1], point[0], point[1]);
|
|
64
|
-
const isHitEdge = distance <= HIT_DISTANCE_BUFFER;
|
|
65
|
-
if (isHitEdge) {
|
|
66
|
-
return isHitEdge;
|
|
58
|
+
if (isHitEdgeOfShape(board, element, point, HIT_DISTANCE_BUFFER)) {
|
|
59
|
+
return true;
|
|
67
60
|
}
|
|
61
|
+
const engine = getEngine(getElementShape(element));
|
|
68
62
|
// when shape equals text, fill is not allowed
|
|
69
63
|
if (fill !== DefaultGeometryStyle.fill && fill !== TRANSPARENT && !PlaitDrawElement.isText(element)) {
|
|
70
64
|
const isHitInside = engine.isInsidePoint(rectangle, point);
|
|
@@ -88,21 +82,28 @@ export const isHitDrawElement = (board, element, point) => {
|
|
|
88
82
|
}
|
|
89
83
|
}
|
|
90
84
|
if (PlaitDrawElement.isImage(element)) {
|
|
91
|
-
|
|
85
|
+
const client = RectangleClient.getRectangleByPoints(element.points);
|
|
86
|
+
return RectangleClient.isPointInRectangle(client, point);
|
|
92
87
|
}
|
|
93
88
|
if (PlaitDrawElement.isLine(element)) {
|
|
94
89
|
return isHitLine(board, element, point);
|
|
95
90
|
}
|
|
96
91
|
return null;
|
|
97
92
|
};
|
|
93
|
+
export const isHitEdgeOfShape = (board, element, point, hitDistanceBuffer) => {
|
|
94
|
+
const nearestPoint = getNearestPoint(element, point);
|
|
95
|
+
const distance = distanceBetweenPointAndPoint(nearestPoint[0], nearestPoint[1], point[0], point[1]);
|
|
96
|
+
return distance <= hitDistanceBuffer;
|
|
97
|
+
};
|
|
98
|
+
export const isInsideOfShape = (board, element, point, hitDistanceBuffer) => {
|
|
99
|
+
const client = RectangleClient.inflate(RectangleClient.getRectangleByPoints(element.points), hitDistanceBuffer);
|
|
100
|
+
return getEngine(getElementShape(element)).isInsidePoint(client, point);
|
|
101
|
+
};
|
|
98
102
|
export const isHitElementInside = (board, element, point) => {
|
|
99
103
|
const rectangle = board.getRectangle(element);
|
|
100
|
-
|
|
101
|
-
if (element.angle) {
|
|
102
|
-
point = rotate(point[0], point[1], centerPoint[0], centerPoint[1], -element.angle);
|
|
103
|
-
}
|
|
104
|
+
point = rotateAntiPointsByElement(point, element) || point;
|
|
104
105
|
if (PlaitDrawElement.isGeometry(element)) {
|
|
105
|
-
const engine = getEngine(
|
|
106
|
+
const engine = getEngine(getElementShape(element));
|
|
106
107
|
const isHitInside = engine.isInsidePoint(rectangle, point);
|
|
107
108
|
if (isHitInside) {
|
|
108
109
|
return isHitInside;
|
|
@@ -116,11 +117,12 @@ export const isHitElementInside = (board, element, point) => {
|
|
|
116
117
|
}
|
|
117
118
|
}
|
|
118
119
|
if (PlaitDrawElement.isImage(element)) {
|
|
119
|
-
|
|
120
|
+
const client = RectangleClient.getRectangleByPoints(element.points);
|
|
121
|
+
return RectangleClient.isPointInRectangle(client, point);
|
|
120
122
|
}
|
|
121
123
|
if (PlaitDrawElement.isLine(element)) {
|
|
122
124
|
return isHitLine(board, element, point);
|
|
123
125
|
}
|
|
124
126
|
return null;
|
|
125
127
|
};
|
|
126
|
-
//# 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    rotate\n} from '@plait/core';\nimport { PlaitDrawElement, PlaitGeometry, PlaitLine } from '../interfaces';\nimport { TRANSPARENT, rotatePoints } from '@plait/common';\nimport { getTextRectangle } from './geometry';\nimport { getLinePoints } from './line/line-basic';\nimport { getFillByElement } from './style/stroke';\nimport { DefaultGeometryStyle } from '../constants/geometry';\nimport { getEngine } from '../engines';\nimport { getShape } from './shape';\nimport { getHitLineTextIndex } from './position/line';\n\nexport const isTextExceedingBounds = (geometry: PlaitGeometry) => {\n    const client = RectangleClient.getRectangleByPoints(geometry.points);\n    if (geometry.textHeight > client.height) {\n        return true;\n    }\n    return false;\n};\n\nexport const isHitLineText = (board: PlaitBoard, element: PlaitLine, point: Point) => {\n    return getHitLineTextIndex(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 isHitLine = (board: PlaitBoard, element: PlaitLine, point: Point) => {\n    const points = getLinePoints(board, element);\n    const isHitText = isHitLineText(board, element, point);\n    return isHitText || isHitPolyLine(points, point);\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        const centerPoint = RectangleClient.getCenterPoint(client);\n        let rotatedCornerPoints = rotatePoints(RectangleClient.getCornerPoints(client), centerPoint, element.angle);\n        if (isTextExceedingBounds(element)) {\n            const textClient = getTextRectangle(element);\n            rotatedCornerPoints = rotatePoints(RectangleClient.getCornerPoints(textClient), centerPoint, element.angle);\n        }\n        return isPolylineHitRectangle(rotatedCornerPoints, rangeRectangle);\n    }\n\n    if (PlaitDrawElement.isImage(element)) {\n        const client = RectangleClient.getRectangleByPoints(element.points);\n        const rotatedCornerPoints = rotatePoints(\n            RectangleClient.getCornerPoints(client),\n            RectangleClient.getCenterPoint(client),\n            element.angle\n        );\n        return isPolylineHitRectangle(rotatedCornerPoints, client);\n    }\n\n    if (PlaitDrawElement.isLine(element)) {\n        const points = getLinePoints(board, element);\n        return isPolylineHitRectangle(points, rangeRectangle);\n    }\n   return null;\n};\n\nexport const isHitDrawElement = (board: PlaitBoard, element: PlaitElement, point: Point) => {\n    const rectangle = board.getRectangle(element);\n    const centerPoint = RectangleClient.getCenterPoint(rectangle!);\n    if (element.angle) {\n        point = rotate(point[0], point[1], centerPoint[0], centerPoint[1], -element.angle) as Point;\n    }\n    if (PlaitDrawElement.isGeometry(element)) {\n        const fill = getFillByElement(board, element);\n        const engine = getEngine(getShape(element));\n        const nearestPoint = engine.getNearestPoint(rectangle!, point);\n        const distance = distanceBetweenPointAndPoint(nearestPoint[0], nearestPoint[1], point[0], point[1]);\n        const isHitEdge = distance <= HIT_DISTANCE_BUFFER;\n        if (isHitEdge) {\n            return isHitEdge;\n        }\n        // when shape equals text, fill is not allowed\n        if (fill !== DefaultGeometryStyle.fill && fill !== TRANSPARENT && !PlaitDrawElement.isText(element)) {\n            const isHitInside = engine.isInsidePoint(rectangle!, point);\n            if (isHitInside) {\n                return isHitInside;\n            }\n        } else {\n            // if shape equals text, only check text rectangle\n            if (PlaitDrawElement.isText(element)) {\n                const textClient = getTextRectangle(element);\n                let isHitText = RectangleClient.isPointInRectangle(textClient, point);\n                return isHitText;\n            }\n\n            // check textRectangle of element\n            const textClient = engine.getTextRectangle ? engine.getTextRectangle(element) : getTextRectangle(element);\n            const isHitTextRectangle = RectangleClient.isPointInRectangle(textClient, point);\n            if (isHitTextRectangle) {\n                return isHitTextRectangle;\n            }\n        }\n    }\n    if (PlaitDrawElement.isImage(element)) {\n        return isRectangleHitDrawElement(board, element, { anchor: point, focus: point });\n    }\n\n    if (PlaitDrawElement.isLine(element)) {\n        return isHitLine(board, element, point);\n    }\n    return null;\n};\n\nexport const isHitElementInside = (board: PlaitBoard, element: PlaitElement, point: Point) => {\n    const rectangle = board.getRectangle(element);\n    const centerPoint = RectangleClient.getCenterPoint(rectangle!);\n    if (element.angle) {\n        point = rotate(point[0], point[1], centerPoint[0], centerPoint[1], -element.angle) as Point;\n    }\n    if (PlaitDrawElement.isGeometry(element)) {\n        const engine = getEngine(getShape(element));\n        const isHitInside = engine.isInsidePoint(rectangle!, point);\n        if (isHitInside) {\n            return isHitInside;\n        }\n\n        if (engine.getTextRectangle) {\n            const textClient = engine.getTextRectangle(element);\n            const isHitTextRectangle = RectangleClient.isPointInRectangle(textClient, point);\n            if (isHitTextRectangle) {\n                return isHitTextRectangle;\n            }\n        }\n    }\n    if (PlaitDrawElement.isImage(element)) {\n        return isRectangleHitDrawElement(board, element, { anchor: point, focus: point });\n    }\n\n    if (PlaitDrawElement.isLine(element)) {\n        return isHitLine(board, element, point);\n    }\n\n    return null;\n};\n"]}
|
|
128
|
+
//# 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 { PlaitDrawElement, PlaitGeometry, PlaitLine, PlaitShapeElement } from '../interfaces';\nimport { TRANSPARENT } from '@plait/common';\nimport { getNearestPoint, getTextRectangle } from './geometry';\nimport { getLinePoints } from './line/line-basic';\nimport { getFillByElement } from './style/stroke';\nimport { DefaultGeometryStyle } from '../constants/geometry';\nimport { getEngine } from '../engines';\nimport { getElementShape } from './shape';\nimport { getHitLineTextIndex } from './position/line';\n\nexport const isTextExceedingBounds = (geometry: PlaitGeometry) => {\n    const client = RectangleClient.getRectangleByPoints(geometry.points);\n    if (geometry.textHeight > client.height) {\n        return true;\n    }\n    return false;\n};\n\nexport const isHitLineText = (board: PlaitBoard, element: PlaitLine, point: Point) => {\n    return getHitLineTextIndex(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 isHitLine = (board: PlaitBoard, element: PlaitLine, point: Point) => {\n    const points = getLinePoints(board, element);\n    const isHitText = isHitLineText(board, element, point);\n    return isHitText || isHitPolyLine(points, point);\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        if (isTextExceedingBounds(element)) {\n            const textClient = getTextRectangle(element);\n            rotatedCornerPoints =\n                rotatePointsByElement(RectangleClient.getCornerPoints(textClient), element) || RectangleClient.getCornerPoints(textClient);\n        }\n        return isPolylineHitRectangle(rotatedCornerPoints, 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.isLine(element)) {\n        const points = getLinePoints(board, element);\n        return isPolylineHitRectangle(points, rangeRectangle);\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        const fill = getFillByElement(board, element);\n        if (isHitEdgeOfShape(board, element, point, HIT_DISTANCE_BUFFER)) {\n            return true;\n        }\n        const engine = getEngine(getElementShape(element));\n        // when shape equals text, fill is not allowed\n        if (fill !== DefaultGeometryStyle.fill && fill !== TRANSPARENT && !PlaitDrawElement.isText(element)) {\n            const isHitInside = engine.isInsidePoint(rectangle!, point);\n            if (isHitInside) {\n                return isHitInside;\n            }\n        } else {\n            // if shape equals text, only check text rectangle\n            if (PlaitDrawElement.isText(element)) {\n                const textClient = getTextRectangle(element);\n                let isHitText = RectangleClient.isPointInRectangle(textClient, point);\n                return isHitText;\n            }\n\n            // check textRectangle of element\n            const textClient = engine.getTextRectangle ? engine.getTextRectangle(element) : getTextRectangle(element);\n            const isHitTextRectangle = RectangleClient.isPointInRectangle(textClient, point);\n            if (isHitTextRectangle) {\n                return isHitTextRectangle;\n            }\n        }\n    }\n    if (PlaitDrawElement.isImage(element)) {\n        const client = RectangleClient.getRectangleByPoints(element.points);\n        return RectangleClient.isPointInRectangle(client, point);\n    }\n    if (PlaitDrawElement.isLine(element)) {\n        return isHitLine(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)) {\n        const engine = getEngine(getElementShape(element));\n        const isHitInside = engine.isInsidePoint(rectangle!, point);\n        if (isHitInside) {\n            return isHitInside;\n        }\n\n        if (engine.getTextRectangle) {\n            const textClient = engine.getTextRectangle(element);\n            const isHitTextRectangle = RectangleClient.isPointInRectangle(textClient, point);\n            if (isHitTextRectangle) {\n                return isHitTextRectangle;\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.isLine(element)) {\n        return isHitLine(board, element, point);\n    }\n\n    return null;\n};\n"]}
|
|
@@ -1,19 +1,24 @@
|
|
|
1
|
-
import { Point, getElementById, RectangleClient } from '@plait/core';
|
|
2
|
-
import { getPoints, getPointByVectorComponent, removeDuplicatePoints, generateElbowLineRoute, simplifyOrthogonalPoints, isSourceAndTargetIntersect } from '@plait/common';
|
|
1
|
+
import { Point, getElementById, RectangleClient, rotatePointsByElement } from '@plait/core';
|
|
2
|
+
import { getPoints, getPointByVectorComponent, removeDuplicatePoints, generateElbowLineRoute, simplifyOrthogonalPoints, isSourceAndTargetIntersect, DEFAULT_ROUTE_MARGIN } from '@plait/common';
|
|
3
3
|
import { BasicShapes, PlaitLine } from '../../interfaces';
|
|
4
4
|
import { createGeometryElement } from '../geometry';
|
|
5
5
|
import { getStrokeWidthByElement } from '../style/stroke';
|
|
6
6
|
import { getElbowLineRouteOptions, getLineHandleRefPair } from './line-common';
|
|
7
7
|
import { getMidKeyPoints, getMirrorDataPoints, hasIllegalElbowPoint } from './line-resize';
|
|
8
|
+
export const isSelfLoop = (element) => {
|
|
9
|
+
return element.source.boundId && element.source.boundId === element.target.boundId;
|
|
10
|
+
};
|
|
11
|
+
export const isUseDefaultOrthogonalRoute = (element, options) => {
|
|
12
|
+
return isSourceAndTargetIntersect(options) && !isSelfLoop(element);
|
|
13
|
+
};
|
|
8
14
|
export const getElbowPoints = (board, element) => {
|
|
9
15
|
const handleRefPair = getLineHandleRefPair(board, element);
|
|
10
16
|
const params = getElbowLineRouteOptions(board, element, handleRefPair);
|
|
11
17
|
// console.log(params, 'params');
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
return simplifyOrthogonalPoints(getPoints(handleRefPair.source.point, handleRefPair.source.direction, handleRefPair.target.point, handleRefPair.target.direction, 0));
|
|
18
|
+
if (isUseDefaultOrthogonalRoute(element, params)) {
|
|
19
|
+
return simplifyOrthogonalPoints(getPoints(handleRefPair.source.point, handleRefPair.source.direction, handleRefPair.target.point, handleRefPair.target.direction, DEFAULT_ROUTE_MARGIN));
|
|
15
20
|
}
|
|
16
|
-
const keyPoints = removeDuplicatePoints(generateElbowLineRoute(params));
|
|
21
|
+
const keyPoints = removeDuplicatePoints(generateElbowLineRoute(params, board));
|
|
17
22
|
const nextKeyPoints = keyPoints.slice(1, keyPoints.length - 1);
|
|
18
23
|
if (element.points.length === 2) {
|
|
19
24
|
return simplifyOrthogonalPoints(keyPoints);
|
|
@@ -79,8 +84,16 @@ export const getSourceAndTargetRectangle = (board, element, handleRefPair) => {
|
|
|
79
84
|
const target = handleRefPair.target;
|
|
80
85
|
targetElement = createFakeElement(target.point, target.vector);
|
|
81
86
|
}
|
|
82
|
-
|
|
83
|
-
const
|
|
87
|
+
let sourceRectangle = RectangleClient.getRectangleByPoints(sourceElement.points);
|
|
88
|
+
const rotatedSourceCornerPoints = rotatePointsByElement(RectangleClient.getCornerPoints(sourceRectangle), sourceElement) ||
|
|
89
|
+
RectangleClient.getCornerPoints(sourceRectangle);
|
|
90
|
+
sourceRectangle = RectangleClient.getRectangleByPoints(rotatedSourceCornerPoints);
|
|
91
|
+
sourceRectangle = RectangleClient.inflate(sourceRectangle, getStrokeWidthByElement(sourceElement) * 2);
|
|
92
|
+
let targetRectangle = RectangleClient.getRectangleByPoints(targetElement.points);
|
|
93
|
+
const rotatedTargetCornerPoints = rotatePointsByElement(RectangleClient.getCornerPoints(targetRectangle), targetElement) ||
|
|
94
|
+
RectangleClient.getCornerPoints(targetRectangle);
|
|
95
|
+
targetRectangle = RectangleClient.getRectangleByPoints(rotatedTargetCornerPoints);
|
|
96
|
+
targetRectangle = RectangleClient.inflate(targetRectangle, getStrokeWidthByElement(targetElement) * 2);
|
|
84
97
|
return {
|
|
85
98
|
sourceRectangle,
|
|
86
99
|
targetRectangle
|
|
@@ -98,4 +111,4 @@ export function getNextRenderPoints(board, element, renderPoints) {
|
|
|
98
111
|
newRenderKeyPoints.splice(-1, 1, nextTargetPoint);
|
|
99
112
|
return removeDuplicatePoints(newRenderKeyPoints);
|
|
100
113
|
}
|
|
101
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elbow.js","sourceRoot":"","sources":["../../../../../packages/draw/src/utils/line/elbow.ts"],"names":[],"mappings":"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","sourcesContent":["import { Point, PlaitBoard, getElementById, RectangleClient, Vector } from '@plait/core';\nimport {\n    getPoints,\n    getPointByVectorComponent,\n    removeDuplicatePoints,\n    generateElbowLineRoute,\n    simplifyOrthogonalPoints,\n    isSourceAndTargetIntersect\n} from '@plait/common';\nimport { BasicShapes, LineHandleRefPair, PlaitGeometry, PlaitLine } from '../../interfaces';\nimport { createGeometryElement } from '../geometry';\nimport { getStrokeWidthByElement } from '../style/stroke';\nimport { getElbowLineRouteOptions, getLineHandleRefPair } from './line-common';\nimport { getMidKeyPoints, getMirrorDataPoints, hasIllegalElbowPoint } from './line-resize';\n\nexport const getElbowPoints = (board: PlaitBoard, element: PlaitLine) => {\n    const handleRefPair = getLineHandleRefPair(board, element);\n    const params = getElbowLineRouteOptions(board, element, handleRefPair);\n    // console.log(params, 'params');\n    const isIntersect = isSourceAndTargetIntersect(params);\n    if (isIntersect) {\n        return simplifyOrthogonalPoints(\n            getPoints(\n                handleRefPair.source.point,\n                handleRefPair.source.direction,\n                handleRefPair.target.point,\n                handleRefPair.target.direction,\n                0\n            )\n        );\n    }\n    const keyPoints = removeDuplicatePoints(generateElbowLineRoute(params));\n    const nextKeyPoints = keyPoints.slice(1, keyPoints.length - 1);\n    if (element.points.length === 2) {\n        return simplifyOrthogonalPoints(keyPoints);\n    } else {\n        const simplifiedNextKeyPoints = simplifyOrthogonalPoints(nextKeyPoints);\n        const dataPoints = removeDuplicatePoints(PlaitLine.getPoints(board, element));\n        const midDataPoints = dataPoints.slice(1, -1);\n        if (hasIllegalElbowPoint(midDataPoints)) {\n            return simplifyOrthogonalPoints(keyPoints);\n        }\n        \n        const nextDataPoints = [simplifiedNextKeyPoints[0], ...midDataPoints, simplifiedNextKeyPoints[simplifiedNextKeyPoints.length - 1]];\n        const mirrorDataPoints = getMirrorDataPoints(board, nextDataPoints, simplifiedNextKeyPoints, params);\n        // console.log(mirrorDataPoints, 'mirrorDataPoints');\n        const renderPoints: Point[] = [keyPoints[0]];\n        for (let index = 0; index < mirrorDataPoints.length - 1; index++) {\n            let currentPoint = mirrorDataPoints[index];\n            let nextPoint = mirrorDataPoints[index + 1];\n            const isStraight = Point.isAlign([currentPoint, nextPoint]);\n            if (!isStraight) {\n                const midKeyPoints = getMidKeyPoints(simplifiedNextKeyPoints, currentPoint, nextPoint);\n                if (midKeyPoints.length) {\n                    renderPoints.push(currentPoint);\n                    renderPoints.push(...midKeyPoints);\n                } else {\n                    renderPoints.push(currentPoint);\n                    console.log('unknown data points');\n                }\n            } else {\n                renderPoints.push(currentPoint);\n            }\n        }\n        renderPoints.push(keyPoints[keyPoints.length - 2], keyPoints[keyPoints.length - 1]);\n        // Remove the middle point to avoid the situation where the starting and ending positions are drawn back, such as when sourcePoint is between nextSourcePoint and the first key point.\n        // Issue\n        //                           keyPoint2\n        //                                |\n        //                                |\n        // nextPoint---sourcePoint---keyPoint1\n        // The correct rendering should be (nextPoint should be filtered out):\n        //                           keyPoint2\n        //                                |\n        //                                |\n        //             sourcePoint---keyPoint1\n        const ret = simplifyOrthogonalPoints(renderPoints);\n        return ret;\n    }\n};\n\nexport const getNextSourceAndTargetPoints = (board: PlaitBoard, element: PlaitLine) => {\n    const options = getElbowLineRouteOptions(board, element);\n    return [options.nextSourcePoint, options.nextTargetPoint];\n};\n\nexport const getSourceAndTargetRectangle = (board: PlaitBoard, element: PlaitLine, handleRefPair: LineHandleRefPair) => {\n    let sourceElement = element.source.boundId ? getElementById<PlaitGeometry>(board, element.source.boundId) : undefined;\n    let targetElement = element.target.boundId ? getElementById<PlaitGeometry>(board, element.target.boundId) : undefined;\n    if (!sourceElement) {\n        const source = handleRefPair.source;\n        sourceElement = createFakeElement(source.point, source.vector);\n    }\n    if (!targetElement) {\n        const target = handleRefPair.target;\n        targetElement = createFakeElement(target.point, target.vector);\n    }\n    const sourceRectangle = RectangleClient.inflate(\n        RectangleClient.getRectangleByPoints(sourceElement.points),\n        getStrokeWidthByElement(sourceElement) * 2\n    );\n    const targetRectangle = RectangleClient.inflate(\n        RectangleClient.getRectangleByPoints(targetElement.points),\n        getStrokeWidthByElement(targetElement) * 2\n    );\n    return {\n        sourceRectangle,\n        targetRectangle\n    };\n};\n\nconst createFakeElement = (startPoint: Point, vector: Vector) => {\n    const point = getPointByVectorComponent(startPoint, vector, -25);\n    const points = RectangleClient.getPoints(RectangleClient.getRectangleByCenterPoint(point, 50, 50));\n    return createGeometryElement(BasicShapes.rectangle, points, '');\n};\n\nexport function getNextRenderPoints(board: PlaitBoard, element: PlaitLine, renderPoints?: Point[]) {\n    let newRenderKeyPoints = renderPoints ?? getElbowPoints(board, element);\n    const [nextSourcePoint, nextTargetPoint] = getNextSourceAndTargetPoints(board, element);\n    newRenderKeyPoints.splice(0, 1, nextSourcePoint);\n    newRenderKeyPoints.splice(-1, 1, nextTargetPoint);\n    return removeDuplicatePoints(newRenderKeyPoints);\n}\n"]}
|
|
114
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elbow.js","sourceRoot":"","sources":["../../../../../packages/draw/src/utils/line/elbow.ts"],"names":[],"mappings":"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","sourcesContent":["import { Point, PlaitBoard, getElementById, RectangleClient, Vector, rotatePoints, rotatePointsByElement } from '@plait/core';\nimport {\n    getPoints,\n    getPointByVectorComponent,\n    removeDuplicatePoints,\n    generateElbowLineRoute,\n    simplifyOrthogonalPoints,\n    isSourceAndTargetIntersect,\n    DEFAULT_ROUTE_MARGIN,\n    ElbowLineRouteOptions\n} from '@plait/common';\nimport { BasicShapes, LineHandleRefPair, PlaitGeometry, PlaitLine } from '../../interfaces';\nimport { createGeometryElement } from '../geometry';\nimport { getStrokeWidthByElement } from '../style/stroke';\nimport { getElbowLineRouteOptions, getLineHandleRefPair } from './line-common';\nimport { getMidKeyPoints, getMirrorDataPoints, hasIllegalElbowPoint } from './line-resize';\n\nexport const isSelfLoop = (element: PlaitLine) => {\n    return element.source.boundId && element.source.boundId === element.target.boundId;\n};\n\nexport const isUseDefaultOrthogonalRoute = (element: PlaitLine, options: ElbowLineRouteOptions) => {\n    return isSourceAndTargetIntersect(options) && !isSelfLoop(element);\n};\n\nexport const getElbowPoints = (board: PlaitBoard, element: PlaitLine) => {\n    const handleRefPair = getLineHandleRefPair(board, element);\n    const params = getElbowLineRouteOptions(board, element, handleRefPair);\n    // console.log(params, 'params');\n    if (isUseDefaultOrthogonalRoute(element, params)) {\n        return simplifyOrthogonalPoints(\n            getPoints(\n                handleRefPair.source.point,\n                handleRefPair.source.direction,\n                handleRefPair.target.point,\n                handleRefPair.target.direction,\n                DEFAULT_ROUTE_MARGIN\n            )\n        );\n    }\n    const keyPoints = removeDuplicatePoints(generateElbowLineRoute(params, board));\n    const nextKeyPoints = keyPoints.slice(1, keyPoints.length - 1);\n    if (element.points.length === 2) {\n        return simplifyOrthogonalPoints(keyPoints);\n    } else {\n        const simplifiedNextKeyPoints = simplifyOrthogonalPoints(nextKeyPoints);\n        const dataPoints = removeDuplicatePoints(PlaitLine.getPoints(board, element));\n        const midDataPoints = dataPoints.slice(1, -1);\n        if (hasIllegalElbowPoint(midDataPoints)) {\n            return simplifyOrthogonalPoints(keyPoints);\n        }\n        const nextDataPoints = [simplifiedNextKeyPoints[0], ...midDataPoints, simplifiedNextKeyPoints[simplifiedNextKeyPoints.length - 1]];\n        const mirrorDataPoints = getMirrorDataPoints(board, nextDataPoints, simplifiedNextKeyPoints, params);\n        // console.log(mirrorDataPoints, 'mirrorDataPoints');\n        const renderPoints: Point[] = [keyPoints[0]];\n        for (let index = 0; index < mirrorDataPoints.length - 1; index++) {\n            let currentPoint = mirrorDataPoints[index];\n            let nextPoint = mirrorDataPoints[index + 1];\n            const isStraight = Point.isAlign([currentPoint, nextPoint]);\n            if (!isStraight) {\n                const midKeyPoints = getMidKeyPoints(simplifiedNextKeyPoints, currentPoint, nextPoint);\n                if (midKeyPoints.length) {\n                    renderPoints.push(currentPoint);\n                    renderPoints.push(...midKeyPoints);\n                } else {\n                    renderPoints.push(currentPoint);\n                    console.log('unknown data points');\n                }\n            } else {\n                renderPoints.push(currentPoint);\n            }\n        }\n        renderPoints.push(keyPoints[keyPoints.length - 2], keyPoints[keyPoints.length - 1]);\n        // Remove the middle point to avoid the situation where the starting and ending positions are drawn back, such as when sourcePoint is between nextSourcePoint and the first key point.\n        // Issue\n        //                           keyPoint2\n        //                                |\n        //                                |\n        // nextPoint---sourcePoint---keyPoint1\n        // The correct rendering should be (nextPoint should be filtered out):\n        //                           keyPoint2\n        //                                |\n        //                                |\n        //             sourcePoint---keyPoint1\n        const ret = simplifyOrthogonalPoints(renderPoints);\n        return ret;\n    }\n};\n\nexport const getNextSourceAndTargetPoints = (board: PlaitBoard, element: PlaitLine) => {\n    const options = getElbowLineRouteOptions(board, element);\n    return [options.nextSourcePoint, options.nextTargetPoint];\n};\n\nexport const getSourceAndTargetRectangle = (board: PlaitBoard, element: PlaitLine, handleRefPair: LineHandleRefPair) => {\n    let sourceElement = element.source.boundId ? getElementById<PlaitGeometry>(board, element.source.boundId) : undefined;\n    let targetElement = element.target.boundId ? getElementById<PlaitGeometry>(board, element.target.boundId) : undefined;\n    if (!sourceElement) {\n        const source = handleRefPair.source;\n        sourceElement = createFakeElement(source.point, source.vector);\n    }\n    if (!targetElement) {\n        const target = handleRefPair.target;\n        targetElement = createFakeElement(target.point, target.vector);\n    }\n\n    let sourceRectangle = RectangleClient.getRectangleByPoints(sourceElement.points);\n    const rotatedSourceCornerPoints =\n        rotatePointsByElement(RectangleClient.getCornerPoints(sourceRectangle), sourceElement) ||\n        RectangleClient.getCornerPoints(sourceRectangle);\n    sourceRectangle = RectangleClient.getRectangleByPoints(rotatedSourceCornerPoints);\n    sourceRectangle = RectangleClient.inflate(sourceRectangle, getStrokeWidthByElement(sourceElement) * 2);\n\n    let targetRectangle = RectangleClient.getRectangleByPoints(targetElement.points);\n    const rotatedTargetCornerPoints =\n        rotatePointsByElement(RectangleClient.getCornerPoints(targetRectangle), targetElement) ||\n        RectangleClient.getCornerPoints(targetRectangle);\n    targetRectangle = RectangleClient.getRectangleByPoints(rotatedTargetCornerPoints);\n    targetRectangle = RectangleClient.inflate(targetRectangle, getStrokeWidthByElement(targetElement) * 2);\n\n    return {\n        sourceRectangle,\n        targetRectangle\n    };\n};\n\nconst createFakeElement = (startPoint: Point, vector: Vector) => {\n    const point = getPointByVectorComponent(startPoint, vector, -25);\n    const points = RectangleClient.getPoints(RectangleClient.getRectangleByCenterPoint(point, 50, 50));\n    return createGeometryElement(BasicShapes.rectangle, points, '');\n};\n\nexport function getNextRenderPoints(board: PlaitBoard, element: PlaitLine, renderPoints?: Point[]) {\n    let newRenderKeyPoints = renderPoints ?? getElbowPoints(board, element);\n    const [nextSourcePoint, nextTargetPoint] = getNextSourceAndTargetPoints(board, element);\n    newRenderKeyPoints.splice(0, 1, nextSourcePoint);\n    newRenderKeyPoints.splice(-1, 1, nextTargetPoint);\n    return removeDuplicatePoints(newRenderKeyPoints);\n}\n"]}
|