@plait/draw 0.54.0 → 0.55.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/constants/geometry.d.ts +22 -0
- package/engines/basic-shapes/circle.d.ts +8 -0
- package/engines/basic-shapes/cloud.d.ts +2 -0
- package/engines/flowchart/off-page.d.ts +4 -0
- package/engines/flowchart/or.d.ts +2 -0
- package/engines/flowchart/predefined-process.d.ts +2 -0
- package/engines/flowchart/summing-junction.d.ts +2 -0
- package/esm2022/constants/geometry.mjs +12 -2
- package/esm2022/engines/basic-shapes/circle.mjs +51 -0
- package/esm2022/engines/basic-shapes/cloud.mjs +57 -0
- package/esm2022/engines/basic-shapes/ellipse.mjs +3 -41
- package/esm2022/engines/flowchart/off-page.mjs +32 -0
- package/esm2022/engines/flowchart/or.mjs +25 -0
- package/esm2022/engines/flowchart/predefined-process.mjs +47 -0
- package/esm2022/engines/flowchart/summing-junction.mjs +28 -0
- package/esm2022/engines/index.mjs +12 -2
- package/esm2022/geometry.component.mjs +7 -8
- package/esm2022/image.component.mjs +6 -7
- package/esm2022/interfaces/element.mjs +2 -1
- package/esm2022/interfaces/geometry.mjs +6 -1
- package/esm2022/line.component.mjs +8 -9
- package/esm2022/plugins/with-draw-fragment.mjs +7 -7
- package/esm2022/plugins/with-draw-hotkey.mjs +1 -1
- package/esm2022/plugins/with-draw-resize.mjs +23 -23
- package/esm2022/plugins/with-draw-rotate.mjs +127 -0
- package/esm2022/plugins/with-draw.mjs +3 -2
- package/esm2022/plugins/with-geometry-create.mjs +21 -5
- package/esm2022/plugins/with-geometry-resize.mjs +15 -14
- package/esm2022/plugins/with-line-auto-complete.mjs +4 -3
- package/esm2022/utils/geometry.mjs +5 -2
- package/esm2022/utils/line/line-basic.mjs +6 -3
- package/esm2022/utils/position/geometry.mjs +10 -2
- package/esm2022/utils/snap-resizing.mjs +185 -0
- package/esm2022/utils/style/stroke.mjs +9 -2
- package/fesm2022/plait-draw.mjs +1126 -942
- package/fesm2022/plait-draw.mjs.map +1 -1
- package/geometry.component.d.ts +2 -3
- package/image.component.d.ts +2 -3
- package/interfaces/element.d.ts +2 -1
- package/interfaces/geometry.d.ts +7 -2
- package/line.component.d.ts +2 -3
- package/package.json +1 -1
- package/plugins/with-draw-resize.d.ts +3 -5
- package/plugins/with-draw-rotate.d.ts +2 -0
- package/utils/position/geometry.d.ts +6 -0
- package/utils/snap-resizing.d.ts +25 -0
- package/esm2022/utils/resize-snap.mjs +0 -361
- package/utils/resize-snap.d.ts +0 -49
|
@@ -3,10 +3,11 @@ import { BasicShapes } from '../interfaces';
|
|
|
3
3
|
import { GeometryShapeGenerator } from '../generators/geometry-shape.generator';
|
|
4
4
|
import { createDefaultGeometry, createTextElement, getDefaultGeometryPoints, getTextShapeProperty, getMemorizedLatestByPointer, getTextRectangle, insertElement } from '../utils';
|
|
5
5
|
import { DefaultTextProperty, getGeometryPointers } from '../constants';
|
|
6
|
-
import { normalizeShapePoints, isDndMode, isDrawingMode } from '@plait/common';
|
|
6
|
+
import { normalizeShapePoints, isDndMode, isDrawingMode, getDirectionFactorByDirectionComponent, getUnitVectorByPointAndPoint } from '@plait/common';
|
|
7
7
|
import { TextManage } from '@plait/text';
|
|
8
8
|
import { isKeyHotkey } from 'is-hotkey';
|
|
9
9
|
import { NgZone } from '@angular/core';
|
|
10
|
+
import { getSnapResizingRef } from '../utils/snap-resizing';
|
|
10
11
|
export const withGeometryCreateByDrag = (board) => {
|
|
11
12
|
const { pointerMove, globalPointerUp } = board;
|
|
12
13
|
let geometryShapeG = null;
|
|
@@ -82,6 +83,7 @@ export const withGeometryCreateByDrawing = (board) => {
|
|
|
82
83
|
let geometryShapeG = null;
|
|
83
84
|
let temporaryElement = null;
|
|
84
85
|
let isShift = false;
|
|
86
|
+
let snapG;
|
|
85
87
|
board.keyDown = (event) => {
|
|
86
88
|
isShift = isKeyHotkey('shift', event);
|
|
87
89
|
keyDown(event);
|
|
@@ -113,11 +115,24 @@ export const withGeometryCreateByDrawing = (board) => {
|
|
|
113
115
|
geometryShapeG?.remove();
|
|
114
116
|
geometryShapeG = createG();
|
|
115
117
|
const geometryGenerator = new GeometryShapeGenerator(board);
|
|
116
|
-
const drawMode = !!start;
|
|
117
118
|
const movingPoint = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));
|
|
118
119
|
const pointer = PlaitBoard.getPointer(board);
|
|
119
|
-
|
|
120
|
-
|
|
120
|
+
snapG?.remove();
|
|
121
|
+
if (start && pointer !== BasicShapes.text) {
|
|
122
|
+
let points = normalizeShapePoints([start, movingPoint], isShift);
|
|
123
|
+
const activeRectangle = RectangleClient.getRectangleByPoints(points);
|
|
124
|
+
const [x, y] = getUnitVectorByPointAndPoint(start, movingPoint);
|
|
125
|
+
const resizeSnapRef = getSnapResizingRef(board, [], {
|
|
126
|
+
resizePoints: points,
|
|
127
|
+
activeRectangle,
|
|
128
|
+
directionFactors: [getDirectionFactorByDirectionComponent(x), getDirectionFactorByDirectionComponent(y)],
|
|
129
|
+
isAspectRatio: isShift,
|
|
130
|
+
isFromCorner: true,
|
|
131
|
+
isCreate: true
|
|
132
|
+
});
|
|
133
|
+
snapG = resizeSnapRef.snapG;
|
|
134
|
+
PlaitBoard.getElementActiveHost(board).append(snapG);
|
|
135
|
+
points = normalizeShapePoints(resizeSnapRef.activePoints, isShift);
|
|
121
136
|
temporaryElement = createDefaultGeometry(board, points, pointer);
|
|
122
137
|
geometryGenerator.processDrawing(temporaryElement, geometryShapeG);
|
|
123
138
|
PlaitBoard.getElementActiveHost(board).append(geometryShapeG);
|
|
@@ -140,6 +155,7 @@ export const withGeometryCreateByDrawing = (board) => {
|
|
|
140
155
|
if (temporaryElement) {
|
|
141
156
|
insertElement(board, temporaryElement);
|
|
142
157
|
}
|
|
158
|
+
snapG?.remove();
|
|
143
159
|
geometryShapeG?.remove();
|
|
144
160
|
geometryShapeG = null;
|
|
145
161
|
start = null;
|
|
@@ -149,4 +165,4 @@ export const withGeometryCreateByDrawing = (board) => {
|
|
|
149
165
|
};
|
|
150
166
|
return board;
|
|
151
167
|
};
|
|
152
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-geometry-create.js","sourceRoot":"","sources":["../../../../packages/draw/src/plugins/with-geometry-create.ts"],"names":[],"mappings":"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","sourcesContent":["import { PlaitBoard, Point, RectangleClient, createG, preventTouchMove, toHostPoint, toViewBoxPoint } from '@plait/core';\nimport { BasicShapes, GeometryShapes, PlaitGeometry } from '../interfaces';\nimport { GeometryShapeGenerator } from '../generators/geometry-shape.generator';\nimport {\n    createDefaultGeometry,\n    createTextElement,\n    getDefaultGeometryPoints,\n    getTextShapeProperty,\n    getMemorizedLatestByPointer,\n    getTextRectangle,\n    insertElement\n} from '../utils';\nimport { DefaultTextProperty, DrawPointerType, getGeometryPointers } from '../constants';\nimport { normalizeShapePoints, isDndMode, isDrawingMode } from '@plait/common';\nimport { TextManage } from '@plait/text';\nimport { isKeyHotkey } from 'is-hotkey';\nimport { NgZone } from '@angular/core';\n\nexport interface FakeCreateTextRef {\n    g: SVGGElement;\n    textManage: TextManage;\n}\n\nexport const withGeometryCreateByDrag = (board: PlaitBoard) => {\n    const { pointerMove, globalPointerUp } = board;\n\n    let geometryShapeG: SVGGElement | null = null;\n\n    let temporaryElement: PlaitGeometry | null = null;\n\n    let fakeCreateTextRef: FakeCreateTextRef | null = null;\n\n    board.pointerMove = (event: PointerEvent) => {\n        geometryShapeG?.remove();\n        geometryShapeG = createG();\n\n        const geometryGenerator = new GeometryShapeGenerator(board);\n        const geometryPointers = getGeometryPointers();\n        const isGeometryPointer = PlaitBoard.isInPointer(board, geometryPointers);\n        const dragMode = isGeometryPointer && isDndMode(board);\n        const movingPoint = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));\n        const pointer = PlaitBoard.getPointer(board) as DrawPointerType;\n\n        if (dragMode) {\n            const memorizedLatest = getMemorizedLatestByPointer(pointer);\n            if (pointer === BasicShapes.text) {\n                const property = getTextShapeProperty(board, DefaultTextProperty.text, memorizedLatest.textProperties['font-size']);\n                const points = RectangleClient.getPoints(\n                    RectangleClient.getRectangleByCenterPoint(movingPoint, property.width, property.height)\n                );\n                temporaryElement = createTextElement(board, points);\n                if (!fakeCreateTextRef) {\n                    const textManage = new TextManage(board, PlaitBoard.getComponent(board).viewContainerRef, {\n                        getRectangle: () => {\n                            return getTextRectangle(temporaryElement!);\n                        }\n                    });\n                    PlaitBoard.getComponent(board)\n                        .viewContainerRef.injector.get(NgZone)\n                        .run(() => {\n                            textManage.draw(temporaryElement!.text);\n                        });\n                    fakeCreateTextRef = {\n                        g: createG(),\n                        textManage\n                    };\n\n                    PlaitBoard.getHost(board).append(fakeCreateTextRef.g);\n                    fakeCreateTextRef.g.append(textManage.g);\n                } else {\n                    fakeCreateTextRef.textManage.updateRectangle();\n                    fakeCreateTextRef.g.append(fakeCreateTextRef.textManage.g);\n                }\n            } else {\n                const points = getDefaultGeometryPoints(pointer, movingPoint);\n                temporaryElement = createDefaultGeometry(board, points, pointer as GeometryShapes);\n                geometryGenerator.processDrawing(temporaryElement, geometryShapeG);\n                PlaitBoard.getElementActiveHost(board).append(geometryShapeG);\n            }\n        }\n\n        pointerMove(event);\n    };\n\n    board.globalPointerUp = (event: PointerEvent) => {\n        const geometryPointers = getGeometryPointers();\n        const isGeometryPointer = PlaitBoard.isInPointer(board, geometryPointers);\n        const dragMode = isGeometryPointer && isDndMode(board);\n\n        if (dragMode && temporaryElement) {\n            insertElement(board, temporaryElement);\n            fakeCreateTextRef?.textManage.destroy();\n            fakeCreateTextRef?.g.remove();\n            fakeCreateTextRef = null;\n        }\n\n        geometryShapeG?.remove();\n        geometryShapeG = null;\n        preventTouchMove(board, event, false);\n\n        globalPointerUp(event);\n    };\n\n    return board;\n};\n\nexport const withGeometryCreateByDrawing = (board: PlaitBoard) => {\n    const { pointerDown, pointerMove, pointerUp, keyDown, keyUp } = board;\n    let start: Point | null = null;\n\n    let geometryShapeG: SVGGElement | null = null;\n\n    let temporaryElement: PlaitGeometry | null = null;\n\n    let isShift = false;\n\n    board.keyDown = (event: KeyboardEvent) => {\n        isShift = isKeyHotkey('shift', event);\n        keyDown(event);\n    };\n\n    board.keyUp = (event: KeyboardEvent) => {\n        isShift = false;\n        keyUp(event);\n    };\n\n    board.pointerDown = (event: PointerEvent) => {\n        const geometryPointers = getGeometryPointers();\n        const isGeometryPointer = PlaitBoard.isInPointer(board, geometryPointers);\n        if (!PlaitBoard.isReadonly(board) && isGeometryPointer && isDrawingMode(board)) {\n            const point = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));\n            start = point;\n            const pointer = PlaitBoard.getPointer(board) as DrawPointerType;\n            preventTouchMove(board, event, true);\n            if (pointer === BasicShapes.text) {\n                const memorizedLatest = getMemorizedLatestByPointer(pointer);\n                const property = getTextShapeProperty(board, DefaultTextProperty.text, memorizedLatest.textProperties['font-size']);\n                const points = RectangleClient.getPoints(\n                    RectangleClient.getRectangleByCenterPoint(point, property.width, property.height)\n                );\n                const textElement = createTextElement(board, points);\n                insertElement(board, textElement);\n                start = null;\n            }\n        }\n        pointerDown(event);\n    };\n\n    board.pointerMove = (event: PointerEvent) => {\n        geometryShapeG?.remove();\n        geometryShapeG = createG();\n        const geometryGenerator = new GeometryShapeGenerator(board);\n        const drawMode = !!start;\n        const movingPoint = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));\n        const pointer = PlaitBoard.getPointer(board) as DrawPointerType;\n        if (drawMode && pointer !== BasicShapes.text) {\n            const points = normalizeShapePoints([start!, movingPoint], isShift);\n            temporaryElement = createDefaultGeometry(board, points, pointer as GeometryShapes);\n            geometryGenerator.processDrawing(temporaryElement, geometryShapeG);\n            PlaitBoard.getElementActiveHost(board).append(geometryShapeG);\n        }\n\n        pointerMove(event);\n    };\n\n    board.pointerUp = (event: PointerEvent) => {\n        const isDrawMode = !!start;\n        if (isDrawMode) {\n            const targetPoint = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));\n            const { width, height } = RectangleClient.getRectangleByPoints([start!, targetPoint]);\n            if (Math.hypot(width, height) === 0) {\n                const pointer = PlaitBoard.getPointer(board) as DrawPointerType;\n                if (pointer !== BasicShapes.text) {\n                    const points = getDefaultGeometryPoints(pointer, targetPoint);\n                    temporaryElement = createDefaultGeometry(board, points, pointer as GeometryShapes);\n                }\n            }\n        }\n        if (temporaryElement) {\n            insertElement(board, temporaryElement);\n        }\n\n        geometryShapeG?.remove();\n        geometryShapeG = null;\n        start = null;\n        temporaryElement = null;\n        preventTouchMove(board, event, false);\n        pointerUp(event);\n    };\n\n    return board;\n};\n"]}
|
|
168
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-geometry-create.js","sourceRoot":"","sources":["../../../../packages/draw/src/plugins/with-geometry-create.ts"],"names":[],"mappings":"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","sourcesContent":["import { PlaitBoard, Point, RectangleClient, createG, preventTouchMove, toHostPoint, toViewBoxPoint } from '@plait/core';\nimport { BasicShapes, GeometryShapes, PlaitGeometry } from '../interfaces';\nimport { GeometryShapeGenerator } from '../generators/geometry-shape.generator';\nimport {\n    createDefaultGeometry,\n    createTextElement,\n    getDefaultGeometryPoints,\n    getTextShapeProperty,\n    getMemorizedLatestByPointer,\n    getTextRectangle,\n    insertElement\n} from '../utils';\nimport { DefaultTextProperty, DrawPointerType, getGeometryPointers } from '../constants';\nimport {\n    normalizeShapePoints,\n    isDndMode,\n    isDrawingMode,\n    getDirectionFactorByDirectionComponent,\n    getUnitVectorByPointAndPoint\n} from '@plait/common';\nimport { TextManage } from '@plait/text';\nimport { isKeyHotkey } from 'is-hotkey';\nimport { NgZone } from '@angular/core';\nimport { getSnapResizingRef } from '../utils/snap-resizing';\n\nexport interface FakeCreateTextRef {\n    g: SVGGElement;\n    textManage: TextManage;\n}\n\nexport const withGeometryCreateByDrag = (board: PlaitBoard) => {\n    const { pointerMove, globalPointerUp } = board;\n\n    let geometryShapeG: SVGGElement | null = null;\n\n    let temporaryElement: PlaitGeometry | null = null;\n\n    let fakeCreateTextRef: FakeCreateTextRef | null = null;\n\n    board.pointerMove = (event: PointerEvent) => {\n        geometryShapeG?.remove();\n        geometryShapeG = createG();\n\n        const geometryGenerator = new GeometryShapeGenerator(board);\n        const geometryPointers = getGeometryPointers();\n        const isGeometryPointer = PlaitBoard.isInPointer(board, geometryPointers);\n        const dragMode = isGeometryPointer && isDndMode(board);\n        const movingPoint = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));\n        const pointer = PlaitBoard.getPointer(board) as DrawPointerType;\n\n        if (dragMode) {\n            const memorizedLatest = getMemorizedLatestByPointer(pointer);\n            if (pointer === BasicShapes.text) {\n                const property = getTextShapeProperty(board, DefaultTextProperty.text, memorizedLatest.textProperties['font-size']);\n                const points = RectangleClient.getPoints(\n                    RectangleClient.getRectangleByCenterPoint(movingPoint, property.width, property.height)\n                );\n                temporaryElement = createTextElement(board, points);\n                if (!fakeCreateTextRef) {\n                    const textManage = new TextManage(board, PlaitBoard.getComponent(board).viewContainerRef, {\n                        getRectangle: () => {\n                            return getTextRectangle(temporaryElement!);\n                        }\n                    });\n                    PlaitBoard.getComponent(board)\n                        .viewContainerRef.injector.get(NgZone)\n                        .run(() => {\n                            textManage.draw(temporaryElement!.text);\n                        });\n                    fakeCreateTextRef = {\n                        g: createG(),\n                        textManage\n                    };\n\n                    PlaitBoard.getHost(board).append(fakeCreateTextRef.g);\n                    fakeCreateTextRef.g.append(textManage.g);\n                } else {\n                    fakeCreateTextRef.textManage.updateRectangle();\n                    fakeCreateTextRef.g.append(fakeCreateTextRef.textManage.g);\n                }\n            } else {\n                const points = getDefaultGeometryPoints(pointer, movingPoint);\n                temporaryElement = createDefaultGeometry(board, points, pointer as GeometryShapes);\n                geometryGenerator.processDrawing(temporaryElement, geometryShapeG);\n                PlaitBoard.getElementActiveHost(board).append(geometryShapeG);\n            }\n        }\n\n        pointerMove(event);\n    };\n\n    board.globalPointerUp = (event: PointerEvent) => {\n        const geometryPointers = getGeometryPointers();\n        const isGeometryPointer = PlaitBoard.isInPointer(board, geometryPointers);\n        const dragMode = isGeometryPointer && isDndMode(board);\n\n        if (dragMode && temporaryElement) {\n            insertElement(board, temporaryElement);\n            fakeCreateTextRef?.textManage.destroy();\n            fakeCreateTextRef?.g.remove();\n            fakeCreateTextRef = null;\n        }\n\n        geometryShapeG?.remove();\n        geometryShapeG = null;\n        preventTouchMove(board, event, false);\n\n        globalPointerUp(event);\n    };\n\n    return board;\n};\n\nexport const withGeometryCreateByDrawing = (board: PlaitBoard) => {\n    const { pointerDown, pointerMove, pointerUp, keyDown, keyUp } = board;\n    let start: Point | null = null;\n\n    let geometryShapeG: SVGGElement | null = null;\n\n    let temporaryElement: PlaitGeometry | null = null;\n\n    let isShift = false;\n\n    let snapG: SVGGElement | null;\n\n    board.keyDown = (event: KeyboardEvent) => {\n        isShift = isKeyHotkey('shift', event);\n        keyDown(event);\n    };\n\n    board.keyUp = (event: KeyboardEvent) => {\n        isShift = false;\n        keyUp(event);\n    };\n\n    board.pointerDown = (event: PointerEvent) => {\n        const geometryPointers = getGeometryPointers();\n        const isGeometryPointer = PlaitBoard.isInPointer(board, geometryPointers);\n        if (!PlaitBoard.isReadonly(board) && isGeometryPointer && isDrawingMode(board)) {\n            const point = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));\n            start = point;\n            const pointer = PlaitBoard.getPointer(board) as DrawPointerType;\n            preventTouchMove(board, event, true);\n            if (pointer === BasicShapes.text) {\n                const memorizedLatest = getMemorizedLatestByPointer(pointer);\n                const property = getTextShapeProperty(board, DefaultTextProperty.text, memorizedLatest.textProperties['font-size']);\n                const points = RectangleClient.getPoints(RectangleClient.getRectangleByCenterPoint(point, property.width, property.height));\n                const textElement = createTextElement(board, points);\n                insertElement(board, textElement);\n                start = null;\n            }\n        }\n        pointerDown(event);\n    };\n\n    board.pointerMove = (event: PointerEvent) => {\n        geometryShapeG?.remove();\n        geometryShapeG = createG();\n        const geometryGenerator = new GeometryShapeGenerator(board);\n        const movingPoint = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));\n        const pointer = PlaitBoard.getPointer(board) as DrawPointerType;\n        snapG?.remove();\n        if (start && pointer !== BasicShapes.text) {\n            let points: [Point, Point] = normalizeShapePoints([start, movingPoint], isShift);\n            const activeRectangle = RectangleClient.getRectangleByPoints(points);\n            const [x, y] = getUnitVectorByPointAndPoint(start, movingPoint);\n            const resizeSnapRef = getSnapResizingRef(board, [], {\n                resizePoints: points,\n                activeRectangle,\n                directionFactors: [getDirectionFactorByDirectionComponent(x), getDirectionFactorByDirectionComponent(y)],\n                isAspectRatio: isShift,\n                isFromCorner: true,\n                isCreate: true\n            });\n            snapG = resizeSnapRef.snapG;\n            PlaitBoard.getElementActiveHost(board).append(snapG);\n            points = normalizeShapePoints(resizeSnapRef.activePoints as [Point, Point], isShift);\n            temporaryElement = createDefaultGeometry(board, points, pointer as GeometryShapes);\n            geometryGenerator.processDrawing(temporaryElement, geometryShapeG);\n            PlaitBoard.getElementActiveHost(board).append(geometryShapeG);\n        }\n\n        pointerMove(event);\n    };\n\n    board.pointerUp = (event: PointerEvent) => {\n        const isDrawMode = !!start;\n        if (isDrawMode) {\n            const targetPoint = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));\n            const { width, height } = RectangleClient.getRectangleByPoints([start!, targetPoint]);\n            if (Math.hypot(width, height) === 0) {\n                const pointer = PlaitBoard.getPointer(board) as DrawPointerType;\n                if (pointer !== BasicShapes.text) {\n                    const points = getDefaultGeometryPoints(pointer, targetPoint);\n                    temporaryElement = createDefaultGeometry(board, points, pointer as GeometryShapes);\n                }\n            }\n        }\n        if (temporaryElement) {\n            insertElement(board, temporaryElement);\n        }\n\n        snapG?.remove();\n        geometryShapeG?.remove();\n        geometryShapeG = null;\n        start = null;\n        temporaryElement = null;\n        preventTouchMove(board, event, false);\n        pointerUp(event);\n    };\n    return board;\n};\n"]}
|
|
@@ -1,13 +1,13 @@
|
|
|
1
|
-
import { PlaitBoard, PlaitElement,
|
|
2
|
-
import { getFirstTextManage, isCornerHandle, normalizeShapePoints, withResize } from '@plait/common';
|
|
1
|
+
import { PlaitBoard, PlaitElement, Transforms, getSelectedElements, rotateAntiPointsByElement } from '@plait/core';
|
|
2
|
+
import { getFirstTextManage, getIndexByResizeHandle, isCornerHandle, normalizeShapePoints, withResize } from '@plait/common';
|
|
3
3
|
import { getSelectedGeometryElements, getSelectedImageElements } from '../utils/selected';
|
|
4
4
|
import { DrawTransforms } from '../transforms';
|
|
5
5
|
import { PlaitDrawElement } from '../interfaces';
|
|
6
6
|
import { getHitRectangleResizeHandleRef } from '../utils/position/geometry';
|
|
7
7
|
import { getResizeOriginPointAndHandlePoint } from './with-draw-resize';
|
|
8
|
-
import {
|
|
8
|
+
import { getSnapResizingRefOptions, getSnapResizingRef } from '../utils/snap-resizing';
|
|
9
9
|
export const withGeometryResize = (board) => {
|
|
10
|
-
let
|
|
10
|
+
let snapG;
|
|
11
11
|
const options = {
|
|
12
12
|
key: 'draw-geometry',
|
|
13
13
|
canResize: () => {
|
|
@@ -35,20 +35,21 @@ export const withGeometryResize = (board) => {
|
|
|
35
35
|
return null;
|
|
36
36
|
},
|
|
37
37
|
onResize: (resizeRef, resizeState) => {
|
|
38
|
-
const centerPoint = RectangleClient.getCenterPoint(RectangleClient.getRectangleByPoints(resizeRef.element.points));
|
|
39
38
|
resizeState.startPoint = rotateAntiPointsByElement(resizeState.startPoint, resizeRef.element) || resizeState.startPoint;
|
|
40
39
|
resizeState.endPoint = rotateAntiPointsByElement(resizeState.endPoint, resizeRef.element) || resizeState.endPoint;
|
|
41
|
-
|
|
40
|
+
snapG?.remove();
|
|
42
41
|
const isFromCorner = isCornerHandle(board, resizeRef.handle);
|
|
43
42
|
const isAspectRatio = resizeState.isShift || PlaitDrawElement.isImage(resizeRef.element);
|
|
44
|
-
const
|
|
45
|
-
const
|
|
43
|
+
const handleIndex = getIndexByResizeHandle(resizeRef.handle);
|
|
44
|
+
const { originPoint, handlePoint } = getResizeOriginPointAndHandlePoint(board, handleIndex, resizeRef.rectangle);
|
|
45
|
+
const resizeSnapRefOptions = getSnapResizingRefOptions(board, resizeRef, resizeState, {
|
|
46
46
|
originPoint,
|
|
47
47
|
handlePoint
|
|
48
48
|
}, isAspectRatio, isFromCorner);
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
49
|
+
const resizeSnapRef = getSnapResizingRef(board, [resizeRef.element], resizeSnapRefOptions);
|
|
50
|
+
snapG = resizeSnapRef.snapG;
|
|
51
|
+
PlaitBoard.getElementActiveHost(board).append(snapG);
|
|
52
|
+
let points = resizeSnapRef.activePoints;
|
|
52
53
|
if (PlaitDrawElement.isGeometry(resizeRef.element)) {
|
|
53
54
|
const { height: textHeight } = getFirstTextManage(resizeRef.element).getSize();
|
|
54
55
|
DrawTransforms.resizeGeometry(board, points, textHeight, resizeRef.path);
|
|
@@ -59,11 +60,11 @@ export const withGeometryResize = (board) => {
|
|
|
59
60
|
}
|
|
60
61
|
},
|
|
61
62
|
afterResize: (resizeRef) => {
|
|
62
|
-
|
|
63
|
-
|
|
63
|
+
snapG?.remove();
|
|
64
|
+
snapG = null;
|
|
64
65
|
}
|
|
65
66
|
};
|
|
66
67
|
withResize(board, options);
|
|
67
68
|
return board;
|
|
68
69
|
};
|
|
69
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-geometry-resize.js","sourceRoot":"","sources":["../../../../packages/draw/src/plugins/with-geometry-resize.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    Path,\n    PlaitBoard,\n    PlaitElement,\n    Point,\n    RectangleClient,\n    Transforms,\n    getSelectedElements,\n    rotateAntiPointsByElement\n} from '@plait/core';\nimport { PlaitGeometry } from '../interfaces/geometry';\nimport {\n    ResizeRef,\n    ResizeState,\n    WithResizeOptions,\n    getFirstTextManage,\n    isCornerHandle,\n    normalizeShapePoints,\n    withResize\n} from '@plait/common';\nimport { getSelectedGeometryElements, getSelectedImageElements } from '../utils/selected';\nimport { DrawTransforms } from '../transforms';\nimport { GeometryComponent } from '../geometry.component';\nimport { PlaitImage } from '../interfaces/image';\nimport { PlaitDrawElement } from '../interfaces';\nimport { getHitRectangleResizeHandleRef } from '../utils/position/geometry';\nimport { getResizeOriginPointAndHandlePoint } from './with-draw-resize';\nimport { getResizeSnapRef } from '../utils/resize-snap';\n\nexport const withGeometryResize = (board: PlaitBoard) => {\n    let alignG: SVGGElement | null;\n    const options: WithResizeOptions<PlaitGeometry | PlaitImage> = {\n        key: 'draw-geometry',\n        canResize: () => {\n            return true;\n        },\n        hitTest: (point: Point) => {\n            const selectedElements = [...getSelectedGeometryElements(board), ...getSelectedImageElements(board)];\n            if (selectedElements.length !== 1 || getSelectedElements(board).length !== 1) {\n                return null;\n            }\n            const target = selectedElements[0];\n            const targetComponent = PlaitElement.getComponent(selectedElements[0]) as GeometryComponent;\n            if (targetComponent.activeGenerator.hasResizeHandle) {\n                const rectangle = board.getRectangle(target) as RectangleClient;\n                const handleRef = getHitRectangleResizeHandleRef(board, rectangle, point, target.angle);\n                if (handleRef) {\n                    return {\n                        element: target,\n                        handle: handleRef.handle,\n                        cursorClass: handleRef.cursorClass,\n                        rectangle\n                    };\n                }\n            }\n            return null;\n        },\n        onResize: (resizeRef: ResizeRef<PlaitGeometry | PlaitImage>, resizeState: ResizeState) => {\n            const centerPoint = RectangleClient.getCenterPoint(RectangleClient.getRectangleByPoints(resizeRef.element.points));\n            resizeState.startPoint = rotateAntiPointsByElement(resizeState.startPoint, resizeRef.element) || resizeState.startPoint;\n            resizeState.endPoint = rotateAntiPointsByElement(resizeState.endPoint, resizeRef.element) || resizeState.endPoint;\n            alignG?.remove();\n            const isFromCorner = isCornerHandle(board, resizeRef.handle);\n            const isAspectRatio = resizeState.isShift || PlaitDrawElement.isImage(resizeRef.element);\n            const { originPoint, handlePoint } = getResizeOriginPointAndHandlePoint(board, resizeRef);\n            const resizeAlignRef = getResizeSnapRef(\n                board,\n                resizeRef,\n                resizeState,\n                {\n                    originPoint,\n                    handlePoint\n                },\n                isAspectRatio,\n                isFromCorner\n            );\n            alignG = resizeAlignRef.alignG;\n            PlaitBoard.getElementActiveHost(board).append(alignG);\n            let points = resizeAlignRef.activePoints as [Point, Point];\n            if (PlaitDrawElement.isGeometry(resizeRef.element)) {\n                const { height: textHeight } = getFirstTextManage(resizeRef.element).getSize();\n                DrawTransforms.resizeGeometry(board, points, textHeight, resizeRef.path as Path);\n            } else {\n                points = normalizeShapePoints(points);\n                Transforms.setNode(board, { points }, resizeRef.path as Path);\n            }\n        },\n        afterResize: (resizeRef: ResizeRef<PlaitGeometry | PlaitImage>) => {\n            alignG?.remove();\n            alignG = null;\n        }\n    };\n\n    withResize<PlaitGeometry | PlaitImage>(board, options);\n\n    return board;\n};\n"]}
|
|
70
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-geometry-resize.js","sourceRoot":"","sources":["../../../../packages/draw/src/plugins/with-geometry-resize.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    Path,\n    PlaitBoard,\n    PlaitElement,\n    Point,\n    RectangleClient,\n    Transforms,\n    getSelectedElements,\n    rotateAntiPointsByElement\n} from '@plait/core';\nimport { PlaitGeometry } from '../interfaces/geometry';\nimport {\n    ResizeRef,\n    ResizeState,\n    WithResizeOptions,\n    getFirstTextManage,\n    getIndexByResizeHandle,\n    isCornerHandle,\n    normalizeShapePoints,\n    withResize\n} from '@plait/common';\nimport { getSelectedGeometryElements, getSelectedImageElements } from '../utils/selected';\nimport { DrawTransforms } from '../transforms';\nimport { GeometryComponent } from '../geometry.component';\nimport { PlaitImage } from '../interfaces/image';\nimport { PlaitDrawElement } from '../interfaces';\nimport { getHitRectangleResizeHandleRef } from '../utils/position/geometry';\nimport { getResizeOriginPointAndHandlePoint } from './with-draw-resize';\nimport { getSnapResizingRefOptions, getSnapResizingRef } from '../utils/snap-resizing';\n\nexport const withGeometryResize = (board: PlaitBoard) => {\n    let snapG: SVGGElement | null;\n    const options: WithResizeOptions<PlaitGeometry | PlaitImage> = {\n        key: 'draw-geometry',\n        canResize: () => {\n            return true;\n        },\n        hitTest: (point: Point) => {\n            const selectedElements = [...getSelectedGeometryElements(board), ...getSelectedImageElements(board)];\n            if (selectedElements.length !== 1 || getSelectedElements(board).length !== 1) {\n                return null;\n            }\n            const target = selectedElements[0];\n            const targetComponent = PlaitElement.getComponent(selectedElements[0]) as GeometryComponent;\n            if (targetComponent.activeGenerator.hasResizeHandle) {\n                const rectangle = board.getRectangle(target) as RectangleClient;\n                const handleRef = getHitRectangleResizeHandleRef(board, rectangle, point, target.angle);\n                if (handleRef) {\n                    return {\n                        element: target,\n                        handle: handleRef.handle,\n                        cursorClass: handleRef.cursorClass,\n                        rectangle\n                    };\n                }\n            }\n            return null;\n        },\n        onResize: (resizeRef: ResizeRef<PlaitGeometry | PlaitImage>, resizeState: ResizeState) => {\n            resizeState.startPoint = rotateAntiPointsByElement(resizeState.startPoint, resizeRef.element) || resizeState.startPoint;\n            resizeState.endPoint = rotateAntiPointsByElement(resizeState.endPoint, resizeRef.element) || resizeState.endPoint;\n            snapG?.remove();\n            const isFromCorner = isCornerHandle(board, resizeRef.handle);\n            const isAspectRatio = resizeState.isShift || PlaitDrawElement.isImage(resizeRef.element);\n            const handleIndex = getIndexByResizeHandle(resizeRef.handle);\n            const { originPoint, handlePoint } = getResizeOriginPointAndHandlePoint(board, handleIndex, resizeRef.rectangle!);\n            const resizeSnapRefOptions = getSnapResizingRefOptions(\n                board,\n                resizeRef,\n                resizeState,\n                {\n                    originPoint,\n                    handlePoint\n                },\n                isAspectRatio,\n                isFromCorner\n            );\n            const resizeSnapRef = getSnapResizingRef(board, [resizeRef.element], resizeSnapRefOptions);\n            snapG = resizeSnapRef.snapG;\n            PlaitBoard.getElementActiveHost(board).append(snapG);\n            let points = resizeSnapRef.activePoints as [Point, Point];\n            if (PlaitDrawElement.isGeometry(resizeRef.element)) {\n                const { height: textHeight } = getFirstTextManage(resizeRef.element).getSize();\n                DrawTransforms.resizeGeometry(board, points, textHeight, resizeRef.path as Path);\n            } else {\n                points = normalizeShapePoints(points);\n                Transforms.setNode(board, { points }, resizeRef.path as Path);\n            }\n        },\n        afterResize: (resizeRef: ResizeRef<PlaitGeometry | PlaitImage>) => {\n            snapG?.remove();\n            snapG = null;\n        }\n    };\n\n    withResize<PlaitGeometry | PlaitImage>(board, options);\n\n    return board;\n};\n"]}
|
|
@@ -39,12 +39,13 @@ export const withLineAutoComplete = (board) => {
|
|
|
39
39
|
const rectangle = RectangleClient.getRectangleByPoints(sourceElement.points);
|
|
40
40
|
const shape = getElementShape(sourceElement);
|
|
41
41
|
const engine = getEngine(shape);
|
|
42
|
+
let sourcePoint = autoCompletePoint;
|
|
42
43
|
if (engine.getNearestCrossingPoint) {
|
|
43
44
|
const crossingPoint = engine.getNearestCrossingPoint(rectangle, autoCompletePoint);
|
|
44
|
-
|
|
45
|
+
sourcePoint = crossingPoint;
|
|
45
46
|
}
|
|
46
47
|
// source point must be click point
|
|
47
|
-
const rotatedSourcePoint = rotatePointsByElement(
|
|
48
|
+
const rotatedSourcePoint = rotatePointsByElement(sourcePoint, sourceElement) || sourcePoint;
|
|
48
49
|
temporaryElement = handleLineCreating(board, LineShape.elbow, rotatedSourcePoint, movingPoint, sourceElement, lineShapeG);
|
|
49
50
|
}
|
|
50
51
|
}
|
|
@@ -71,4 +72,4 @@ export const withLineAutoComplete = (board) => {
|
|
|
71
72
|
};
|
|
72
73
|
return board;
|
|
73
74
|
};
|
|
74
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-line-auto-complete.js","sourceRoot":"","sources":["../../../../packages/draw/src/plugins/with-line-auto-complete.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    BoardTransforms,\n    PRESS_AND_MOVE_BUFFER,\n    PlaitBoard,\n    PlaitOptionsBoard,\n    PlaitPointerType,\n    Point,\n    RectangleClient,\n    Transforms,\n    addSelectedElement,\n    clearSelectedElement,\n    createG,\n    distanceBetweenPointAndPoint,\n    rotateAntiPointsByElement,\n    rotatePointsByElement,\n    temporaryDisableSelection,\n    toHostPoint,\n    toViewBoxPoint\n} from '@plait/core';\nimport { LineShape, PlaitDrawElement, PlaitLine, PlaitShapeElement } from '../interfaces';\nimport { getElementShape } from '../utils/shape';\nimport { getEngine } from '../engines';\nimport { handleLineCreating } from '../utils/line/line-basic';\nimport { getSelectedDrawElements } from '../utils/selected';\nimport { getAutoCompletePoints, getHitIndexOfAutoCompletePoint } from '../utils/geometry';\n\nexport const WithLineAutoCompletePluginKey = 'plait-line-auto-complete-plugin-key';\n\nexport interface LineAutoCompleteOptions {\n    afterComplete: (element: PlaitLine) => {};\n}\n\nexport const withLineAutoComplete = (board: PlaitBoard) => {\n    const { pointerDown, pointerMove, globalPointerUp } = board;\n\n    let autoCompletePoint: Point | null = null;\n    let lineShapeG: SVGGElement | null = null;\n    let sourceElement: PlaitShapeElement | null;\n    let temporaryElement: PlaitLine | null;\n\n    board.pointerDown = (event: PointerEvent) => {\n        const selectedElements = getSelectedDrawElements(board);\n        const targetElement = selectedElements.length === 1 && selectedElements[0];\n        const clickPoint = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));\n        if (!PlaitBoard.isReadonly(board) && targetElement && PlaitDrawElement.isShapeElement(targetElement)) {\n            const points = getAutoCompletePoints(targetElement);\n            const index = getHitIndexOfAutoCompletePoint(rotateAntiPointsByElement(clickPoint, targetElement) || clickPoint, points);\n            const hitPoint = points[index];\n            if (hitPoint) {\n                temporaryDisableSelection(board as PlaitOptionsBoard);\n                autoCompletePoint = hitPoint;\n                sourceElement = targetElement;\n                BoardTransforms.updatePointerType(board, LineShape.elbow);\n            }\n        }\n        pointerDown(event);\n    };\n\n    board.pointerMove = (event: PointerEvent) => {\n        lineShapeG?.remove();\n        lineShapeG = createG();\n        let movingPoint = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));\n        if (autoCompletePoint && sourceElement) {\n            const distance = distanceBetweenPointAndPoint(\n                ...(rotateAntiPointsByElement(movingPoint, sourceElement) || movingPoint),\n                ...autoCompletePoint\n            );\n            if (distance > PRESS_AND_MOVE_BUFFER) {\n                const rectangle = RectangleClient.getRectangleByPoints(sourceElement.points);\n                const shape = getElementShape(sourceElement);\n                const engine = getEngine(shape);\n                if (engine.getNearestCrossingPoint) {\n                    const crossingPoint = engine.getNearestCrossingPoint(rectangle, autoCompletePoint);\n                    autoCompletePoint = crossingPoint;\n                }\n                // source point must be click point\n                const rotatedSourcePoint = rotatePointsByElement(autoCompletePoint, sourceElement) || autoCompletePoint;\n                temporaryElement = handleLineCreating(board, LineShape.elbow, rotatedSourcePoint, movingPoint, sourceElement, lineShapeG);\n            }\n        }\n        pointerMove(event);\n    };\n\n    board.globalPointerUp = event => {\n        if (temporaryElement) {\n            Transforms.insertNode(board, temporaryElement, [board.children.length]);\n            clearSelectedElement(board);\n            addSelectedElement(board, temporaryElement);\n            const afterComplete = (board as PlaitOptionsBoard).getPluginOptions<LineAutoCompleteOptions>(WithLineAutoCompletePluginKey)\n                ?.afterComplete;\n            afterComplete && afterComplete(temporaryElement);\n        }\n        if (autoCompletePoint) {\n            BoardTransforms.updatePointerType(board, PlaitPointerType.selection);\n            autoCompletePoint = null;\n        }\n        lineShapeG?.remove();\n        lineShapeG = null;\n        sourceElement = null;\n        temporaryElement = null;\n        globalPointerUp(event);\n    };\n\n    return board;\n};\n"]}
|
|
75
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-line-auto-complete.js","sourceRoot":"","sources":["../../../../packages/draw/src/plugins/with-line-auto-complete.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    BoardTransforms,\n    PRESS_AND_MOVE_BUFFER,\n    PlaitBoard,\n    PlaitOptionsBoard,\n    PlaitPointerType,\n    Point,\n    RectangleClient,\n    Transforms,\n    addSelectedElement,\n    clearSelectedElement,\n    createG,\n    distanceBetweenPointAndPoint,\n    rotateAntiPointsByElement,\n    rotatePointsByElement,\n    temporaryDisableSelection,\n    toHostPoint,\n    toViewBoxPoint\n} from '@plait/core';\nimport { LineShape, PlaitDrawElement, PlaitLine, PlaitShapeElement } from '../interfaces';\nimport { getElementShape } from '../utils/shape';\nimport { getEngine } from '../engines';\nimport { handleLineCreating } from '../utils/line/line-basic';\nimport { getSelectedDrawElements } from '../utils/selected';\nimport { getAutoCompletePoints, getHitIndexOfAutoCompletePoint } from '../utils/geometry';\n\nexport const WithLineAutoCompletePluginKey = 'plait-line-auto-complete-plugin-key';\n\nexport interface LineAutoCompleteOptions {\n    afterComplete: (element: PlaitLine) => {};\n}\n\nexport const withLineAutoComplete = (board: PlaitBoard) => {\n    const { pointerDown, pointerMove, globalPointerUp } = board;\n\n    let autoCompletePoint: Point | null = null;\n    let lineShapeG: SVGGElement | null = null;\n    let sourceElement: PlaitShapeElement | null;\n    let temporaryElement: PlaitLine | null;\n\n    board.pointerDown = (event: PointerEvent) => {\n        const selectedElements = getSelectedDrawElements(board);\n        const targetElement = selectedElements.length === 1 && selectedElements[0];\n        const clickPoint = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));\n        if (!PlaitBoard.isReadonly(board) && targetElement && PlaitDrawElement.isShapeElement(targetElement)) {\n            const points = getAutoCompletePoints(targetElement);\n            const index = getHitIndexOfAutoCompletePoint(rotateAntiPointsByElement(clickPoint, targetElement) || clickPoint, points);\n            const hitPoint = points[index];\n            if (hitPoint) {\n                temporaryDisableSelection(board as PlaitOptionsBoard);\n                autoCompletePoint = hitPoint;\n                sourceElement = targetElement;\n                BoardTransforms.updatePointerType(board, LineShape.elbow);\n            }\n        }\n        pointerDown(event);\n    };\n\n    board.pointerMove = (event: PointerEvent) => {\n        lineShapeG?.remove();\n        lineShapeG = createG();\n        let movingPoint = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));\n        if (autoCompletePoint && sourceElement) {\n            const distance = distanceBetweenPointAndPoint(\n                ...(rotateAntiPointsByElement(movingPoint, sourceElement) || movingPoint),\n                ...autoCompletePoint\n            );\n            if (distance > PRESS_AND_MOVE_BUFFER) {\n                const rectangle = RectangleClient.getRectangleByPoints(sourceElement.points);\n                const shape = getElementShape(sourceElement);\n                const engine = getEngine(shape);\n                let sourcePoint = autoCompletePoint;\n                if (engine.getNearestCrossingPoint) {\n                    const crossingPoint = engine.getNearestCrossingPoint(rectangle, autoCompletePoint);\n                    sourcePoint = crossingPoint;\n                }\n                // source point must be click point\n                const rotatedSourcePoint = rotatePointsByElement(sourcePoint, sourceElement) || sourcePoint;\n                temporaryElement = handleLineCreating(board, LineShape.elbow, rotatedSourcePoint, movingPoint, sourceElement, lineShapeG);\n            }\n        }\n        pointerMove(event);\n    };\n\n    board.globalPointerUp = event => {\n        if (temporaryElement) {\n            Transforms.insertNode(board, temporaryElement, [board.children.length]);\n            clearSelectedElement(board);\n            addSelectedElement(board, temporaryElement);\n            const afterComplete = (board as PlaitOptionsBoard).getPluginOptions<LineAutoCompleteOptions>(WithLineAutoCompletePluginKey)\n                ?.afterComplete;\n            afterComplete && afterComplete(temporaryElement);\n        }\n        if (autoCompletePoint) {\n            BoardTransforms.updatePointerType(board, PlaitPointerType.selection);\n            autoCompletePoint = null;\n        }\n        lineShapeG?.remove();\n        lineShapeG = null;\n        sourceElement = null;\n        temporaryElement = null;\n        globalPointerUp(event);\n    };\n\n    return board;\n};\n"]}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
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
|
-
import { DefaultBasicShapeProperty, DefaultFlowchartPropertyMap, DefaultTextProperty, DrawThemeColors, ShapeDefaultSpace, getFlowchartPointers } from '../constants';
|
|
4
|
+
import { DefaultBasicShapeProperty, DefaultCloudShapeProperty, 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';
|
|
@@ -193,6 +193,9 @@ export const getDefaultGeometryProperty = (pointer) => {
|
|
|
193
193
|
return getDefaultFlowchartProperty(pointer);
|
|
194
194
|
}
|
|
195
195
|
else {
|
|
196
|
+
if (pointer === BasicShapes.cloud) {
|
|
197
|
+
return DefaultCloudShapeProperty;
|
|
198
|
+
}
|
|
196
199
|
return DefaultBasicShapeProperty;
|
|
197
200
|
}
|
|
198
201
|
};
|
|
@@ -223,4 +226,4 @@ export const createDefaultGeometry = (board, points, shape) => {
|
|
|
223
226
|
...memorizedLatest.geometryProperties
|
|
224
227
|
}, { ...memorizedLatest.textProperties, textHeight });
|
|
225
228
|
};
|
|
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"]}
|
|
229
|
+
//# 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 } 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"]}
|