@plait/draw 0.56.0 → 0.56.2
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 +17 -3
- package/esm2022/constants/geometry.mjs +24 -6
- package/esm2022/engines/basic-shapes/pentagon-arrow.mjs +7 -4
- package/esm2022/engines/basic-shapes/process-arrow.mjs +5 -5
- package/esm2022/engines/basic-shapes/star.mjs +2 -2
- package/esm2022/geometry.component.mjs +2 -1
- package/esm2022/plugins/with-draw-fragment.mjs +7 -7
- package/esm2022/plugins/with-draw-hotkey.mjs +3 -3
- package/esm2022/plugins/with-draw.mjs +2 -2
- package/esm2022/transforms/geometry.mjs +5 -3
- package/esm2022/utils/geometry.mjs +22 -10
- package/esm2022/utils/memorize.mjs +16 -3
- package/fesm2022/plait-draw.mjs +81 -32
- package/fesm2022/plait-draw.mjs.map +1 -1
- package/package.json +1 -1
- package/utils/geometry.d.ts +7 -2
|
@@ -4,14 +4,16 @@ import { createDefaultGeometry, createTextElement, getMemorizedLatestByPointer,
|
|
|
4
4
|
import { getDirectionByVector, getPointByVectorComponent, normalizeShapePoints } from '@plait/common';
|
|
5
5
|
import { DrawTransforms } from '.';
|
|
6
6
|
import { collectLineUpdatedRefsByGeometry } from './line';
|
|
7
|
-
import { DefaultBasicShapeProperty, DefaultFlowchartPropertyMap } from '../constants';
|
|
7
|
+
import { DefaultBasicShapeProperty, DefaultBasicShapePropertyMap, DefaultFlowchartPropertyMap } from '../constants';
|
|
8
8
|
export const insertGeometry = (board, points, shape) => {
|
|
9
9
|
const newElement = createDefaultGeometry(board, points, shape);
|
|
10
10
|
insertElement(board, newElement);
|
|
11
11
|
return newElement;
|
|
12
12
|
};
|
|
13
13
|
export const insertGeometryByVector = (board, point, shape, vector) => {
|
|
14
|
-
const shapeProperty = DefaultFlowchartPropertyMap[shape] ||
|
|
14
|
+
const shapeProperty = DefaultFlowchartPropertyMap[shape] ||
|
|
15
|
+
DefaultBasicShapePropertyMap[shape] ||
|
|
16
|
+
DefaultBasicShapeProperty;
|
|
15
17
|
const direction = getDirectionByVector(vector);
|
|
16
18
|
if (direction) {
|
|
17
19
|
let offset = 0;
|
|
@@ -60,4 +62,4 @@ export const switchGeometryShape = (board, shape) => {
|
|
|
60
62
|
});
|
|
61
63
|
}
|
|
62
64
|
};
|
|
63
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
65
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"geometry.js","sourceRoot":"","sources":["../../../../packages/draw/src/transforms/geometry.ts"],"names":[],"mappings":"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","sourcesContent":["import { PlaitBoard, Transforms, Point, Path, PlaitNode, getSelectedElements, Vector, Direction, RectangleClient } from '@plait/core';\nimport { PlaitDrawElement, GeometryShapes, PlaitText, PlaitLine, FlowchartSymbols, BasicShapes } from '../interfaces';\nimport { createDefaultGeometry, createTextElement, getMemorizedLatestByPointer, getTextShapeProperty, insertElement } from '../utils';\nimport { Element } from 'slate';\nimport { getDirectionByVector, getPointByVectorComponent, normalizeShapePoints } from '@plait/common';\nimport { DrawTransforms } from '.';\nimport { collectLineUpdatedRefsByGeometry } from './line';\nimport { DefaultBasicShapeProperty, DefaultBasicShapePropertyMap, DefaultFlowchartPropertyMap } from '../constants';\n\nexport const insertGeometry = (board: PlaitBoard, points: [Point, Point], shape: GeometryShapes) => {\n    const newElement = createDefaultGeometry(board, points, shape);\n    insertElement(board, newElement);\n    return newElement;\n};\n\nexport const insertGeometryByVector = (board: PlaitBoard, point: Point, shape: GeometryShapes, vector: Vector) => {\n    const shapeProperty =\n        DefaultFlowchartPropertyMap[shape as FlowchartSymbols] ||\n        DefaultBasicShapePropertyMap[shape as BasicShapes] ||\n        DefaultBasicShapeProperty;\n    const direction = getDirectionByVector(vector);\n    if (direction) {\n        let offset = 0;\n        if ([Direction.left, Direction.right].includes(direction)) {\n            offset = -shapeProperty.width / 2;\n        } else {\n            offset = -shapeProperty.height / 2;\n        }\n        const vectorPoint = getPointByVectorComponent(point, vector, offset);\n        const points = RectangleClient.getPoints(\n            RectangleClient.getRectangleByCenterPoint(vectorPoint, shapeProperty.width, shapeProperty.height)\n        );\n        return insertGeometry(board, points, shape);\n    }\n    return null;\n};\n\nexport const insertText = (board: PlaitBoard, point: Point, text: string | Element) => {\n    const memorizedLatest = getMemorizedLatestByPointer(BasicShapes.text);\n    const property = getTextShapeProperty(board, text, memorizedLatest.textProperties['font-size']);\n    const points: [Point, Point] = [point, [point[0] + property.width, point[1] + property.height]];\n    const newElement = createTextElement(board, points, text);\n    insertElement(board, newElement);\n};\n\nexport const resizeGeometry = (board: PlaitBoard, points: [Point, Point], textHeight: number, path: Path) => {\n    const normalizePoints = normalizeShapePoints(points);\n    const element = PlaitNode.get(board, path);\n    const newHeight = textHeight / board.viewport.zoom;\n    const newProperties = { points: normalizePoints, textHeight: newHeight };\n    if (PlaitDrawElement.isText(element) && element.autoSize) {\n        (newProperties as Partial<PlaitText>).autoSize = false;\n    }\n    Transforms.setNode(board, newProperties, path);\n};\n\nexport const switchGeometryShape = (board: PlaitBoard, shape: GeometryShapes) => {\n    const selectedElements = getSelectedElements(board);\n    const refs: { property: Partial<PlaitLine>; path: Path }[] = [];\n    selectedElements.forEach(item => {\n        if (PlaitDrawElement.isGeometry(item) && !PlaitDrawElement.isText(item)) {\n            const path = PlaitBoard.findPath(board, item);\n            Transforms.setNode(board, { shape }, path);\n            collectLineUpdatedRefsByGeometry(board, { ...item, shape }, refs);\n        }\n    });\n    if (refs.length) {\n        refs.forEach(ref => {\n            DrawTransforms.resizeLine(board, ref.property, ref.path);\n        });\n    }\n};\n"]}
|
|
@@ -1,8 +1,8 @@
|
|
|
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';
|
|
1
|
+
import { ACTIVE_STROKE_WIDTH, BoardTransforms, PlaitBoard, PlaitElement, PlaitPointerType, RectangleClient, SELECTION_BORDER_COLOR, SELECTION_FILL_COLOR, SNAPPING_STROKE_WIDTH, Transforms, addSelectedElement, clearSelectedElement, createG, drawCircle, getSelectedElements, 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
|
-
import { DefaultBasicShapeProperty,
|
|
5
|
-
import { RESIZE_HANDLE_DIAMETER, getFirstTextManage } from '@plait/common';
|
|
4
|
+
import { DefaultBasicShapeProperty, DefaultBasicShapePropertyMap, DefaultFlowchartPropertyMap, DefaultTextProperty, DrawThemeColors, ShapeDefaultSpace, getFlowchartPointers } from '../constants';
|
|
5
|
+
import { ActiveGenerator, RESIZE_HANDLE_DIAMETER, getFirstTextManage } from '@plait/common';
|
|
6
6
|
import { getStrokeWidthByElement } from './style/stroke';
|
|
7
7
|
import { getEngine } from '../engines';
|
|
8
8
|
import { getElementShape } from './shape';
|
|
@@ -100,6 +100,9 @@ export const getCenterPointsOnPolygon = (points) => {
|
|
|
100
100
|
export const getDefaultFlowchartProperty = (symbol) => {
|
|
101
101
|
return DefaultFlowchartPropertyMap[symbol];
|
|
102
102
|
};
|
|
103
|
+
export const getDefaultBasicShapeProperty = (shape) => {
|
|
104
|
+
return DefaultBasicShapePropertyMap[shape] || DefaultBasicShapeProperty;
|
|
105
|
+
};
|
|
103
106
|
export const createDefaultFlowchart = (point) => {
|
|
104
107
|
const decisionProperty = getDefaultFlowchartProperty(FlowchartSymbols.decision);
|
|
105
108
|
const processProperty = getDefaultFlowchartProperty(FlowchartSymbols.process);
|
|
@@ -193,10 +196,7 @@ export const getDefaultGeometryProperty = (pointer) => {
|
|
|
193
196
|
return getDefaultFlowchartProperty(pointer);
|
|
194
197
|
}
|
|
195
198
|
else {
|
|
196
|
-
|
|
197
|
-
return DefaultCloudShapeProperty;
|
|
198
|
-
}
|
|
199
|
-
return DefaultBasicShapeProperty;
|
|
199
|
+
return getDefaultBasicShapeProperty(pointer);
|
|
200
200
|
}
|
|
201
201
|
};
|
|
202
202
|
export const getDefaultTextPoints = (board, centerPoint, fontSize) => {
|
|
@@ -226,8 +226,20 @@ export const createDefaultGeometry = (board, points, shape) => {
|
|
|
226
226
|
...memorizedLatest.geometryProperties
|
|
227
227
|
}, { ...memorizedLatest.textProperties, textHeight });
|
|
228
228
|
};
|
|
229
|
-
export const editText = (element) => {
|
|
229
|
+
export const editText = (board, element) => {
|
|
230
230
|
const textManage = getFirstTextManage(element);
|
|
231
|
-
textManage.edit()
|
|
231
|
+
textManage.edit(() => {
|
|
232
|
+
// delay to avoid blinking
|
|
233
|
+
setTimeout(() => {
|
|
234
|
+
rerenderGeometryActive(board, element);
|
|
235
|
+
}, 200);
|
|
236
|
+
});
|
|
237
|
+
rerenderGeometryActive(board, element);
|
|
238
|
+
};
|
|
239
|
+
export const rerenderGeometryActive = (board, element) => {
|
|
240
|
+
const elementRef = PlaitElement.getElementRef(element);
|
|
241
|
+
const activeGenerator = elementRef.getGenerator(ActiveGenerator.key);
|
|
242
|
+
const selected = getSelectedElements(board).includes(element);
|
|
243
|
+
activeGenerator.processDrawing(element, PlaitBoard.getElementActiveHost(board), { selected });
|
|
232
244
|
};
|
|
233
|
-
//# 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    DefaultCloudShapeProperty,\n    DefaultFlowchartPropertyMap,\n    DefaultTextProperty,\n    DrawPointerType,\n    DrawThemeColors,\n    ShapeDefaultSpace,\n    getFlowchartPointers\n} from '../constants';\nimport { RESIZE_HANDLE_DIAMETER, getFirstTextManage } 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        if (pointer === BasicShapes.cloud) {\n            return DefaultCloudShapeProperty;\n        }\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\nexport const editText = (element: PlaitGeometry) => {\n    const textManage = getFirstTextManage(element);\n    textManage.edit();\n};\n"]}
|
|
245
|
+
//# 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    PlaitElement,\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    getSelectedElements,\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    DefaultBasicShapePropertyMap,\n    DefaultFlowchartPropertyMap,\n    DefaultTextProperty,\n    DrawPointerType,\n    DrawThemeColors,\n    ShapeDefaultSpace,\n    getFlowchartPointers\n} from '../constants';\nimport { ActiveGenerator, PlaitCommonElementRef, RESIZE_HANDLE_DIAMETER, getFirstTextManage } 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 getDefaultBasicShapeProperty = (shape: BasicShapes) => {\n    return DefaultBasicShapePropertyMap[shape] || DefaultBasicShapeProperty;\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 getDefaultBasicShapeProperty(pointer as BasicShapes);\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\nexport const editText = (board: PlaitBoard, element: PlaitGeometry) => {\n    const textManage = getFirstTextManage(element);\n    textManage.edit(() => {\n        // delay to avoid blinking\n        setTimeout(() => {\n            rerenderGeometryActive(board, element);\n        }, 200);\n    });\n    rerenderGeometryActive(board, element);\n};\n\nexport const rerenderGeometryActive = (board: PlaitBoard, element: PlaitGeometry) => {\n    const elementRef = PlaitElement.getElementRef<PlaitCommonElementRef>(element);\n    const activeGenerator = elementRef.getGenerator(ActiveGenerator.key);\n    const selected = getSelectedElements(board).includes(element);\n    activeGenerator.processDrawing(element, PlaitBoard.getElementActiveHost(board), { selected });\n};\n"]}
|
|
@@ -47,8 +47,21 @@ export const memorizeLatestText = (element, operations) => {
|
|
|
47
47
|
let textMemory = getMemorizedLatest(memorizeKey)?.text || {};
|
|
48
48
|
const setNodeOperation = operations.find(operation => operation.type === 'set_node');
|
|
49
49
|
if (setNodeOperation) {
|
|
50
|
-
const newProperties = setNodeOperation
|
|
51
|
-
|
|
50
|
+
const { properties, newProperties } = setNodeOperation;
|
|
51
|
+
for (const key in newProperties) {
|
|
52
|
+
const value = newProperties[key];
|
|
53
|
+
if (value == null) {
|
|
54
|
+
delete textMemory[key];
|
|
55
|
+
}
|
|
56
|
+
else {
|
|
57
|
+
textMemory[key] = value;
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
for (const key in properties) {
|
|
61
|
+
if (!newProperties.hasOwnProperty(key)) {
|
|
62
|
+
delete textMemory[key];
|
|
63
|
+
}
|
|
64
|
+
}
|
|
52
65
|
memorizeLatest(memorizeKey, 'text', textMemory);
|
|
53
66
|
}
|
|
54
67
|
};
|
|
@@ -72,4 +85,4 @@ export const memorizeLatestShape = (board, shape) => {
|
|
|
72
85
|
export const getMemorizedLatestShape = (board) => {
|
|
73
86
|
return memorizedShape.get(board);
|
|
74
87
|
};
|
|
75
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
88
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"memorize.js","sourceRoot":"","sources":["../../../../packages/draw/src/utils/memorize.ts"],"names":[],"mappings":"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","sourcesContent":["import { PlaitBoard, PlaitElement } from '@plait/core';\nimport { BasicShapes, GeometryShapes, MemorizeKey, PlaitDrawElement } from '../interfaces';\nimport { getMemorizedLatest, memorizeLatest } from '@plait/common';\nimport { DrawPointerType } from '../constants';\nimport { BaseOperation, BaseSetNodeOperation, Node } from 'slate';\n\nconst SHAPE_MAX_LENGTH = 6;\nconst memorizedShape: WeakMap<PlaitBoard, GeometryShapes[]> = new WeakMap();\n\nexport const getMemorizeKey = (element: PlaitElement) => {\n    let key = '';\n    switch (true) {\n        case PlaitDrawElement.isText(element): {\n            key = MemorizeKey.text;\n            break;\n        }\n        case PlaitDrawElement.isBasicShape(element): {\n            key = MemorizeKey.basicShape;\n            break;\n        }\n        case PlaitDrawElement.isFlowchart(element): {\n            key = MemorizeKey.flowchart;\n            break;\n        }\n        case PlaitDrawElement.isLine(element): {\n            key = MemorizeKey.line;\n            break;\n        }\n    }\n    return key;\n};\n\nexport const getLineMemorizedLatest = () => {\n    const properties = getMemorizedLatest(MemorizeKey.line);\n    delete properties?.text;\n    return { ...properties } || {};\n};\n\nexport const getMemorizedLatestByPointer = (pointer: DrawPointerType) => {\n    let memorizeKey = '';\n    if (PlaitDrawElement.isBasicShape({ shape: pointer })) {\n        memorizeKey = pointer === BasicShapes.text ? MemorizeKey.text : MemorizeKey.basicShape;\n    } else {\n        memorizeKey = MemorizeKey.flowchart;\n    }\n    const properties = { ...getMemorizedLatest(memorizeKey) } || {};\n    const textProperties = { ...properties.text } || {};\n    delete properties.text;\n    return { textProperties, geometryProperties: properties };\n};\n\nexport const memorizeLatestText = (element: PlaitDrawElement, operations: BaseOperation[]) => {\n    const memorizeKey = getMemorizeKey(element);\n    let textMemory = getMemorizedLatest(memorizeKey)?.text || {};\n    const setNodeOperation = operations.find(operation => operation.type === 'set_node');\n    if (setNodeOperation) {\n        const { properties, newProperties } = setNodeOperation as BaseSetNodeOperation;\n        for (const key in newProperties) {\n            const value = newProperties[key as keyof Partial<Node>];\n            if (value == null) {\n                delete textMemory[key];\n            } else {\n                textMemory[key] = value;\n            }\n        }\n        for (const key in properties) {\n            if (!newProperties.hasOwnProperty(key)) {\n                delete textMemory[key];\n            }\n        }\n        memorizeLatest(memorizeKey, 'text', textMemory);\n    }\n};\n\nexport const memorizeLatestShape = (board: PlaitBoard, shape: GeometryShapes) => {\n    const shapes = memorizedShape.has(board) ? memorizedShape.get(board)! : [];\n    const shapeIndex = shapes.indexOf(shape);\n    if (shape === BasicShapes.text || shapeIndex === 0) {\n        return;\n    }\n    if (shapeIndex !== -1) {\n        shapes.splice(shapeIndex, 1);\n    } else {\n        if (shapes.length === SHAPE_MAX_LENGTH) {\n            shapes.pop();\n        }\n    }\n    shapes.unshift(shape);\n    memorizedShape.set(board, shapes);\n};\n\nexport const getMemorizedLatestShape = (board: PlaitBoard) => {\n    return memorizedShape.get(board);\n};\n"]}
|
package/fesm2022/plait-draw.mjs
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { ACTIVE_STROKE_WIDTH, ThemeColorMode, createDebugGenerator, Point, RectangleClient, getElementById, rotatePointsByElement, createG, arrowPoints, createPath, distanceBetweenPointAndPoint, drawLinearPath, rotate, distanceBetweenPointAndSegments, HIT_DISTANCE_BUFFER, isPolylineHitRectangle, rotateAntiPointsByElement, rotatePoints, depthFirstRecursion, PlaitBoard, getIsRecursionFunc, idCreator, catmullRomFitting, setStrokeLinecap, findElements, createMask, createRect, getSelectedElements, isPointInPolygon, getNearestPointBetweenPointAndSegments, isPointInEllipse, getNearestPointBetweenPointAndEllipse, getEllipseTangentSlope, getVectorFromPointAndSlope, drawRectangle, drawRoundRectangle, isPointInRoundRectangle, setPathStrokeLinecap, getCrossingPointsBetweenEllipseAndSegment, Direction, SNAPPING_STROKE_WIDTH, SELECTION_BORDER_COLOR, SELECTION_FILL_COLOR, drawCircle, Transforms, clearSelectedElement, addSelectedElement, BoardTransforms, PlaitPointerType, hasValidAngle, Path, PlaitNode, toViewBoxPoint, toHostPoint, isSelectionMoving, RgbaToHEX, getHitElementByPoint, getRectangleByElements, getSelectionAngle, rotatedDataPoints, isAxisChangedByAngle, getRectangleByAngle, getSnapRectangles, getTripleAxis, getMinPointDelta, SNAP_TOLERANCE, drawPointSnapLines, drawSolidLines, preventTouchMove, createClipboardContext, WritableClipboardType, addClipboardContext, setAngleForG, CursorClass,
|
|
2
|
-
import { removeDuplicatePoints, generateElbowLineRoute, simplifyOrthogonalPoints, isSourceAndTargetIntersect, getPoints, DEFAULT_ROUTE_MARGIN, getPointByVectorComponent, getExtendPoint, getUnitVectorByPointAndPoint, Generator, RESIZE_HANDLE_DIAMETER, getPointOnPolyline, TRANSPARENT, getRectangleResizeHandleRefs, getRotatedResizeCursorClassByAngle, ROTATE_HANDLE_DISTANCE_TO_ELEMENT, ROTATE_HANDLE_SIZE, getMemorizedLatest, memorizeLatest, getCrossingPointsBetweenPointAndSegment, isPointOnSegment, getDirectionByPointOfRectangle, getDirectionFactor, getFirstTextManage, getDirectionByVector, getOppositeDirection, rotateVector, rotateVectorAnti90, getSourceAndTargetOuterRectangle, getNextPoint, normalizeShapePoints, getFirstTextEditor, PRIMARY_COLOR, CommonPluginElement,
|
|
1
|
+
import { ACTIVE_STROKE_WIDTH, ThemeColorMode, createDebugGenerator, Point, RectangleClient, getElementById, rotatePointsByElement, createG, arrowPoints, createPath, distanceBetweenPointAndPoint, drawLinearPath, rotate, distanceBetweenPointAndSegments, HIT_DISTANCE_BUFFER, isPolylineHitRectangle, rotateAntiPointsByElement, rotatePoints, depthFirstRecursion, PlaitBoard, getIsRecursionFunc, idCreator, catmullRomFitting, setStrokeLinecap, findElements, createMask, createRect, getSelectedElements, isPointInPolygon, getNearestPointBetweenPointAndSegments, isPointInEllipse, getNearestPointBetweenPointAndEllipse, getEllipseTangentSlope, getVectorFromPointAndSlope, drawRectangle, drawRoundRectangle, isPointInRoundRectangle, setPathStrokeLinecap, getCrossingPointsBetweenEllipseAndSegment, Direction, SNAPPING_STROKE_WIDTH, SELECTION_BORDER_COLOR, SELECTION_FILL_COLOR, drawCircle, Transforms, clearSelectedElement, addSelectedElement, BoardTransforms, PlaitPointerType, PlaitElement, hasValidAngle, Path, PlaitNode, toViewBoxPoint, toHostPoint, isSelectionMoving, RgbaToHEX, getHitElementByPoint, getRectangleByElements, getSelectionAngle, rotatedDataPoints, isAxisChangedByAngle, getRectangleByAngle, getSnapRectangles, getTripleAxis, getMinPointDelta, SNAP_TOLERANCE, drawPointSnapLines, drawSolidLines, preventTouchMove, WritableClipboardOperationType, createClipboardContext, WritableClipboardType, addClipboardContext, setAngleForG, CursorClass, temporaryDisableSelection, PRESS_AND_MOVE_BUFFER, isMainPointer, throttleRAF, getAngleBetweenPoints, normalizeAngle, degreesToRadians, rotateElements, MERGING, ROTATE_HANDLE_CLASS_NAME, SELECTION_RECTANGLE_CLASS_NAME } from '@plait/core';
|
|
2
|
+
import { removeDuplicatePoints, generateElbowLineRoute, simplifyOrthogonalPoints, isSourceAndTargetIntersect, getPoints, DEFAULT_ROUTE_MARGIN, getPointByVectorComponent, getExtendPoint, getUnitVectorByPointAndPoint, Generator, RESIZE_HANDLE_DIAMETER, getPointOnPolyline, TRANSPARENT, getRectangleResizeHandleRefs, getRotatedResizeCursorClassByAngle, ROTATE_HANDLE_DISTANCE_TO_ELEMENT, ROTATE_HANDLE_SIZE, getMemorizedLatest, memorizeLatest, getCrossingPointsBetweenPointAndSegment, isPointOnSegment, getDirectionByPointOfRectangle, getDirectionFactor, getFirstTextManage, ActiveGenerator, getDirectionByVector, getOppositeDirection, rotateVector, rotateVectorAnti90, getSourceAndTargetOuterRectangle, getNextPoint, normalizeShapePoints, getFirstTextEditor, PRIMARY_COLOR, CommonPluginElement, canResize, WithTextPluginKey, drawPrimaryHandle, drawFillPrimaryHandle, isVirtualKey, isDelete, isSpaceHotkey, isCornerHandle, getIndexByResizeHandle, resetPointsAfterResize, withResize, drawHandle, getSymmetricHandleIndex, getResizeHandlePointByIndex, getDirectionFactorByDirectionComponent, isDndMode, isDrawingMode, getElementsText, acceptImageTypes, getElementOfFocusedImage, buildImage, isResizingByCondition, getRatioByPoint, getTextManages, ImageGenerator, ResizeHandle, addRotating, removeRotating, drawRotateHandle } from '@plait/common';
|
|
3
3
|
import { Alignment, buildText, DEFAULT_FONT_SIZE, getTextSize, AlignEditor, TextManage } from '@plait/text';
|
|
4
4
|
import { pointsOnBezierCurves } from 'points-on-curve';
|
|
5
5
|
import * as i0 from '@angular/core';
|
|
@@ -79,11 +79,21 @@ const DefaultBasicShapeProperty = {
|
|
|
79
79
|
strokeColor: '#333',
|
|
80
80
|
strokeWidth: 2
|
|
81
81
|
};
|
|
82
|
-
const
|
|
82
|
+
const DefaultPentagonArrowProperty = {
|
|
83
83
|
width: 120,
|
|
84
|
-
height:
|
|
85
|
-
|
|
86
|
-
|
|
84
|
+
height: 50
|
|
85
|
+
};
|
|
86
|
+
const DefaultTwoWayArrowProperty = {
|
|
87
|
+
width: 138,
|
|
88
|
+
height: 80
|
|
89
|
+
};
|
|
90
|
+
const DefaultArrowProperty = {
|
|
91
|
+
width: 100,
|
|
92
|
+
height: 80
|
|
93
|
+
};
|
|
94
|
+
const DefaultCloudProperty = {
|
|
95
|
+
width: 120,
|
|
96
|
+
height: 100
|
|
87
97
|
};
|
|
88
98
|
const DefaultTextProperty = {
|
|
89
99
|
width: 36,
|
|
@@ -137,6 +147,14 @@ const DefaultMergeProperty = {
|
|
|
137
147
|
width: 47,
|
|
138
148
|
height: 33
|
|
139
149
|
};
|
|
150
|
+
const DefaultBasicShapePropertyMap = {
|
|
151
|
+
[BasicShapes.pentagonArrow]: DefaultPentagonArrowProperty,
|
|
152
|
+
[BasicShapes.processArrow]: DefaultPentagonArrowProperty,
|
|
153
|
+
[BasicShapes.cloud]: DefaultCloudProperty,
|
|
154
|
+
[BasicShapes.twoWayArrow]: DefaultTwoWayArrowProperty,
|
|
155
|
+
[BasicShapes.leftArrow]: DefaultArrowProperty,
|
|
156
|
+
[BasicShapes.rightArrow]: DefaultArrowProperty
|
|
157
|
+
};
|
|
140
158
|
const DefaultFlowchartPropertyMap = {
|
|
141
159
|
[FlowchartSymbols.connector]: DefaultConnectorProperty,
|
|
142
160
|
[FlowchartSymbols.process]: DefaultFlowchartProperty,
|
|
@@ -1057,8 +1075,21 @@ const memorizeLatestText = (element, operations) => {
|
|
|
1057
1075
|
let textMemory = getMemorizedLatest(memorizeKey)?.text || {};
|
|
1058
1076
|
const setNodeOperation = operations.find(operation => operation.type === 'set_node');
|
|
1059
1077
|
if (setNodeOperation) {
|
|
1060
|
-
const newProperties = setNodeOperation
|
|
1061
|
-
|
|
1078
|
+
const { properties, newProperties } = setNodeOperation;
|
|
1079
|
+
for (const key in newProperties) {
|
|
1080
|
+
const value = newProperties[key];
|
|
1081
|
+
if (value == null) {
|
|
1082
|
+
delete textMemory[key];
|
|
1083
|
+
}
|
|
1084
|
+
else {
|
|
1085
|
+
textMemory[key] = value;
|
|
1086
|
+
}
|
|
1087
|
+
}
|
|
1088
|
+
for (const key in properties) {
|
|
1089
|
+
if (!newProperties.hasOwnProperty(key)) {
|
|
1090
|
+
delete textMemory[key];
|
|
1091
|
+
}
|
|
1092
|
+
}
|
|
1062
1093
|
memorizeLatest(memorizeKey, 'text', textMemory);
|
|
1063
1094
|
}
|
|
1064
1095
|
};
|
|
@@ -1696,11 +1727,12 @@ const PentagonEngine = createPolygonEngine({
|
|
|
1696
1727
|
});
|
|
1697
1728
|
|
|
1698
1729
|
const getPentagonArrowPoints = (rectangle) => {
|
|
1730
|
+
const wider = rectangle.width > rectangle.height / 2;
|
|
1699
1731
|
return [
|
|
1700
1732
|
[rectangle.x, rectangle.y],
|
|
1701
|
-
[rectangle.x + (rectangle.width
|
|
1733
|
+
[rectangle.x + (wider ? rectangle.width - rectangle.height / 2 : 0), rectangle.y],
|
|
1702
1734
|
[rectangle.x + rectangle.width, rectangle.y + rectangle.height / 2],
|
|
1703
|
-
[rectangle.x + (rectangle.width
|
|
1735
|
+
[rectangle.x + (wider ? rectangle.width - rectangle.height / 2 : 0), rectangle.y + rectangle.height],
|
|
1704
1736
|
[rectangle.x, rectangle.y + rectangle.height]
|
|
1705
1737
|
];
|
|
1706
1738
|
};
|
|
@@ -1710,8 +1742,10 @@ const PentagonArrowEngine = createPolygonEngine({
|
|
|
1710
1742
|
return RectangleClient.getEdgeCenterPoints(rectangle);
|
|
1711
1743
|
},
|
|
1712
1744
|
getTextRectangle(element) {
|
|
1745
|
+
const elementRectangle = RectangleClient.getRectangleByPoints(element.points);
|
|
1713
1746
|
const rectangle = getTextRectangle(element);
|
|
1714
|
-
|
|
1747
|
+
const wider = elementRectangle.width > elementRectangle.height / 2 + 20;
|
|
1748
|
+
rectangle.width = wider ? elementRectangle.width - elementRectangle.height / 2 : rectangle.width;
|
|
1715
1749
|
return rectangle;
|
|
1716
1750
|
}
|
|
1717
1751
|
});
|
|
@@ -1730,11 +1764,11 @@ const getProcessArrowPoints = (rectangle) => {
|
|
|
1730
1764
|
const ProcessArrowEngine = createPolygonEngine({
|
|
1731
1765
|
getPolygonPoints: getProcessArrowPoints,
|
|
1732
1766
|
getTextRectangle(element) {
|
|
1733
|
-
const rectangle = getTextRectangle(element);
|
|
1734
1767
|
const elementRectangle = RectangleClient.getRectangleByPoints(element.points);
|
|
1735
|
-
const
|
|
1736
|
-
|
|
1737
|
-
rectangle.
|
|
1768
|
+
const rectangle = getTextRectangle(element);
|
|
1769
|
+
const wider = elementRectangle.width > elementRectangle.height + 20;
|
|
1770
|
+
rectangle.width = wider ? elementRectangle.width - elementRectangle.height : rectangle.width;
|
|
1771
|
+
rectangle.x = wider ? elementRectangle.x + elementRectangle.height / 2 : rectangle.x;
|
|
1738
1772
|
return rectangle;
|
|
1739
1773
|
}
|
|
1740
1774
|
});
|
|
@@ -2025,7 +2059,7 @@ const StarEngine = createPolygonEngine({
|
|
|
2025
2059
|
height,
|
|
2026
2060
|
width: width > 0 ? width : 0,
|
|
2027
2061
|
x: elementRectangle.x + ShapeDefaultSpace.rectangleAndText + strokeWidth + originWidth / 4,
|
|
2028
|
-
y: elementRectangle.y + (elementRectangle.height * 1) /
|
|
2062
|
+
y: elementRectangle.y + (elementRectangle.height * 1) / 6 + ((elementRectangle.height * 4) / 5 - height) / 2
|
|
2029
2063
|
};
|
|
2030
2064
|
}
|
|
2031
2065
|
});
|
|
@@ -3174,6 +3208,9 @@ const getCenterPointsOnPolygon = (points) => {
|
|
|
3174
3208
|
const getDefaultFlowchartProperty = (symbol) => {
|
|
3175
3209
|
return DefaultFlowchartPropertyMap[symbol];
|
|
3176
3210
|
};
|
|
3211
|
+
const getDefaultBasicShapeProperty = (shape) => {
|
|
3212
|
+
return DefaultBasicShapePropertyMap[shape] || DefaultBasicShapeProperty;
|
|
3213
|
+
};
|
|
3177
3214
|
const createDefaultFlowchart = (point) => {
|
|
3178
3215
|
const decisionProperty = getDefaultFlowchartProperty(FlowchartSymbols.decision);
|
|
3179
3216
|
const processProperty = getDefaultFlowchartProperty(FlowchartSymbols.process);
|
|
@@ -3267,10 +3304,7 @@ const getDefaultGeometryProperty = (pointer) => {
|
|
|
3267
3304
|
return getDefaultFlowchartProperty(pointer);
|
|
3268
3305
|
}
|
|
3269
3306
|
else {
|
|
3270
|
-
|
|
3271
|
-
return DefaultCloudShapeProperty;
|
|
3272
|
-
}
|
|
3273
|
-
return DefaultBasicShapeProperty;
|
|
3307
|
+
return getDefaultBasicShapeProperty(pointer);
|
|
3274
3308
|
}
|
|
3275
3309
|
};
|
|
3276
3310
|
const getDefaultTextPoints = (board, centerPoint, fontSize) => {
|
|
@@ -3300,9 +3334,21 @@ const createDefaultGeometry = (board, points, shape) => {
|
|
|
3300
3334
|
...memorizedLatest.geometryProperties
|
|
3301
3335
|
}, { ...memorizedLatest.textProperties, textHeight });
|
|
3302
3336
|
};
|
|
3303
|
-
const editText = (element) => {
|
|
3337
|
+
const editText = (board, element) => {
|
|
3304
3338
|
const textManage = getFirstTextManage(element);
|
|
3305
|
-
textManage.edit()
|
|
3339
|
+
textManage.edit(() => {
|
|
3340
|
+
// delay to avoid blinking
|
|
3341
|
+
setTimeout(() => {
|
|
3342
|
+
rerenderGeometryActive(board, element);
|
|
3343
|
+
}, 200);
|
|
3344
|
+
});
|
|
3345
|
+
rerenderGeometryActive(board, element);
|
|
3346
|
+
};
|
|
3347
|
+
const rerenderGeometryActive = (board, element) => {
|
|
3348
|
+
const elementRef = PlaitElement.getElementRef(element);
|
|
3349
|
+
const activeGenerator = elementRef.getGenerator(ActiveGenerator.key);
|
|
3350
|
+
const selected = getSelectedElements(board).includes(element);
|
|
3351
|
+
activeGenerator.processDrawing(element, PlaitBoard.getElementActiveHost(board), { selected });
|
|
3306
3352
|
};
|
|
3307
3353
|
|
|
3308
3354
|
const getStrokeWidthByElement = (element) => {
|
|
@@ -3692,7 +3738,9 @@ const insertGeometry = (board, points, shape) => {
|
|
|
3692
3738
|
return newElement;
|
|
3693
3739
|
};
|
|
3694
3740
|
const insertGeometryByVector = (board, point, shape, vector) => {
|
|
3695
|
-
const shapeProperty = DefaultFlowchartPropertyMap[shape] ||
|
|
3741
|
+
const shapeProperty = DefaultFlowchartPropertyMap[shape] ||
|
|
3742
|
+
DefaultBasicShapePropertyMap[shape] ||
|
|
3743
|
+
DefaultBasicShapeProperty;
|
|
3696
3744
|
const direction = getDirectionByVector(vector);
|
|
3697
3745
|
if (direction) {
|
|
3698
3746
|
let offset = 0;
|
|
@@ -3911,6 +3959,7 @@ class GeometryComponent extends CommonPluginElement {
|
|
|
3911
3959
|
this.shapeGenerator = new GeometryShapeGenerator(this.board);
|
|
3912
3960
|
this.initializeTextManage();
|
|
3913
3961
|
this.getRef().addGenerator(LineAutoCompleteGenerator.key, this.lineAutoCompleteGenerator);
|
|
3962
|
+
this.getRef().addGenerator(ActiveGenerator.key, this.activeGenerator);
|
|
3914
3963
|
}
|
|
3915
3964
|
ngOnInit() {
|
|
3916
3965
|
super.ngOnInit();
|
|
@@ -4257,7 +4306,7 @@ const withDrawHotkey = (board) => {
|
|
|
4257
4306
|
isSingleSelection &&
|
|
4258
4307
|
PlaitDrawElement.isGeometry(targetElement)) {
|
|
4259
4308
|
event.preventDefault();
|
|
4260
|
-
editText(targetElement);
|
|
4309
|
+
editText(board, targetElement);
|
|
4261
4310
|
return;
|
|
4262
4311
|
}
|
|
4263
4312
|
keyDown(event);
|
|
@@ -4268,7 +4317,7 @@ const withDrawHotkey = (board) => {
|
|
|
4268
4317
|
const point = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));
|
|
4269
4318
|
const hitElement = getHitElementByPoint(board, point);
|
|
4270
4319
|
if (hitElement && PlaitDrawElement.isGeometry(hitElement)) {
|
|
4271
|
-
editText(hitElement);
|
|
4320
|
+
editText(board, hitElement);
|
|
4272
4321
|
}
|
|
4273
4322
|
}
|
|
4274
4323
|
dblClick(event);
|
|
@@ -4954,11 +5003,11 @@ const withDrawFragment = (baseBoard) => {
|
|
|
4954
5003
|
}
|
|
4955
5004
|
return getDeletedFragment(data);
|
|
4956
5005
|
};
|
|
4957
|
-
board.buildFragment = (clipboardContext, rectangle,
|
|
5006
|
+
board.buildFragment = (clipboardContext, rectangle, operationType, originData) => {
|
|
4958
5007
|
const targetDrawElements = getSelectedDrawElements(board, originData);
|
|
4959
5008
|
let boundLineElements = [];
|
|
4960
5009
|
if (targetDrawElements.length) {
|
|
4961
|
-
if (
|
|
5010
|
+
if (operationType === WritableClipboardOperationType.cut) {
|
|
4962
5011
|
const geometryElements = targetDrawElements.filter(value => PlaitDrawElement.isGeometry(value));
|
|
4963
5012
|
const lineElements = targetDrawElements.filter(value => PlaitDrawElement.isLine(value));
|
|
4964
5013
|
boundLineElements = getBoundedLineElements(board, geometryElements).filter(line => !lineElements.includes(line));
|
|
@@ -4977,9 +5026,9 @@ const withDrawFragment = (baseBoard) => {
|
|
|
4977
5026
|
});
|
|
4978
5027
|
}
|
|
4979
5028
|
}
|
|
4980
|
-
return buildFragment(clipboardContext, rectangle,
|
|
5029
|
+
return buildFragment(clipboardContext, rectangle, operationType, originData);
|
|
4981
5030
|
};
|
|
4982
|
-
board.insertFragment = (clipboardData, targetPoint) => {
|
|
5031
|
+
board.insertFragment = (clipboardData, targetPoint, operationType) => {
|
|
4983
5032
|
const selectedElements = getSelectedElements(board);
|
|
4984
5033
|
if (clipboardData?.files?.length) {
|
|
4985
5034
|
const acceptImageArray = acceptImageTypes.map(type => 'image/' + type);
|
|
@@ -5009,7 +5058,7 @@ const withDrawFragment = (baseBoard) => {
|
|
|
5009
5058
|
}
|
|
5010
5059
|
}
|
|
5011
5060
|
}
|
|
5012
|
-
insertFragment(clipboardData, targetPoint);
|
|
5061
|
+
insertFragment(clipboardData, targetPoint, operationType);
|
|
5013
5062
|
};
|
|
5014
5063
|
return board;
|
|
5015
5064
|
};
|
|
@@ -5819,12 +5868,12 @@ const withDraw = (board) => {
|
|
|
5819
5868
|
});
|
|
5820
5869
|
return getRelatedFragment([...elements, ...activeLines], originData);
|
|
5821
5870
|
};
|
|
5822
|
-
return withDrawResize(withLineResize(withLineTextMove(
|
|
5871
|
+
return withDrawResize(withLineAutoCompleteReaction(withLineBoundReaction(withLineResize(withLineTextMove(withLineText(withGeometryResize(withDrawRotate(withLineCreateByDraw(withLineAutoComplete(withGeometryCreateByDrag(withGeometryCreateByDrawing(withDrawFragment(withDrawHotkey(board))))))))))))));
|
|
5823
5872
|
};
|
|
5824
5873
|
|
|
5825
5874
|
/**
|
|
5826
5875
|
* Generated bundle index. Do not edit.
|
|
5827
5876
|
*/
|
|
5828
5877
|
|
|
5829
|
-
export { BasicShapes, DEFAULT_IMAGE_WIDTH, DefaultBasicShapeProperty,
|
|
5878
|
+
export { BasicShapes, DEFAULT_IMAGE_WIDTH, DefaultArrowProperty, DefaultBasicShapeProperty, DefaultBasicShapePropertyMap, DefaultCloudProperty, DefaultConnectorProperty, DefaultDataBaseProperty, DefaultDataProperty, DefaultDecisionProperty, DefaultDocumentProperty, DefaultFlowchartProperty, DefaultFlowchartPropertyMap, DefaultGeometryActiveStyle, DefaultGeometryStyle, DefaultInternalStorageProperty, DefaultManualInputProperty, DefaultMergeProperty, DefaultMultiDocumentProperty, DefaultNoteProperty, DefaultPentagonArrowProperty, DefaultTextProperty, DefaultTwoWayArrowProperty, DrawThemeColors, DrawTransforms, FlowchartSymbols, GeometryComponent, GeometryThreshold, LINE_HIT_GEOMETRY_BUFFER, LINE_SNAPPING_BUFFER, LINE_SNAPPING_CONNECTOR_BUFFER, LineComponent, LineHandleKey, LineMarkerType, LineShape, MemorizeKey, PlaitDrawElement, PlaitGeometry, PlaitLine, Q2C, ShapeDefaultSpace, StrokeStyle, WithLineAutoCompletePluginKey, alignElbowSegment, alignPoints, createDefaultFlowchart, createDefaultGeometry, createGeometryElement, createLineElement, createTextElement, drawBoundReaction, drawGeometry, drawLine, drawLineArrow, editText, getAutoCompletePoints, getBasicPointers, getCenterPointsOnPolygon, getConnectionPoint, getCurvePoints, getDefaultBasicShapeProperty, getDefaultFlowchartProperty, getDefaultGeometryPoints, getDefaultGeometryProperty, getDefaultTextPoints, getDrawDefaultStrokeColor, getElbowLineRouteOptions, getElbowPoints, getFillByElement, getFlowchartDefaultFill, getFlowchartPointers, getGeometryPointers, getHitConnection, getHitConnectorPoint, getHitIndexOfAutoCompletePoint, getIndexAndDeleteCountByKeyPoint, getLineDashByElement, getLineHandleRefPair, getLineMemorizedLatest, getLinePointers, getLinePoints, getLineTextRectangle, getLines, getMemorizeKey, getMemorizedLatestByPointer, getMemorizedLatestShape, getMidKeyPoints, getMiddlePoints, getMirrorDataPoints, getNearestPoint, getNextRenderPoints, getNextSourceAndTargetPoints, getResizedPreviousAndNextPoint, getSelectedDrawElements, getSelectedGeometryElements, getSelectedImageElements, getSelectedLineElements, getSourceAndTargetRectangle, getStrokeColorByElement, getStrokeStyleByElement, getStrokeWidthByElement, getTextRectangle, getTextShapeProperty, getVectorByConnection, handleLineCreating, hasIllegalElbowPoint, insertElement, isHitDrawElement, isHitEdgeOfShape, isHitElementInside, isHitLine, isHitLineText, isHitPolyLine, isInsideOfShape, isRectangleHitDrawElement, isSelfLoop, isTextExceedingBounds, isUpdatedHandleIndex, isUseDefaultOrthogonalRoute, memorizeLatestShape, memorizeLatestText, rerenderGeometryActive, withDraw, withLineAutoComplete };
|
|
5830
5879
|
//# sourceMappingURL=plait-draw.mjs.map
|