@plait/draw 0.71.0 → 0.72.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/arrow-line.component.d.ts +1 -1
- package/constants/default.d.ts +1 -0
- package/constants/geometry.d.ts +5 -5
- package/constants/index.d.ts +1 -0
- package/constants/pointer.d.ts +3 -3
- package/engines/table/table.d.ts +2 -2
- package/engines/uml/combined-fragment.d.ts +2 -2
- package/engines/uml/package.d.ts +2 -2
- package/esm2022/arrow-line.component.mjs +13 -13
- package/esm2022/constants/default.mjs +2 -0
- package/esm2022/constants/geometry.mjs +8 -8
- package/esm2022/constants/index.mjs +2 -1
- package/esm2022/constants/pointer.mjs +4 -4
- package/esm2022/engines/table/table.mjs +3 -3
- package/esm2022/engines/uml/combined-fragment.mjs +5 -5
- package/esm2022/engines/uml/package.mjs +5 -5
- package/esm2022/generators/single-text.generator.mjs +3 -3
- package/esm2022/generators/text.generator.mjs +25 -21
- package/esm2022/geometry.component.mjs +4 -5
- package/esm2022/interfaces/arrow-line.mjs +1 -1
- package/esm2022/interfaces/element.mjs +1 -7
- package/esm2022/interfaces/geometry.mjs +6 -6
- package/esm2022/interfaces/index.mjs +13 -1
- package/esm2022/interfaces/options.mjs +2 -0
- package/esm2022/interfaces/vector-line.mjs +5 -5
- package/esm2022/plugins/with-arrow-line-text.mjs +2 -2
- package/esm2022/plugins/with-draw-fragment.mjs +8 -12
- package/esm2022/plugins/with-draw-hotkey.mjs +3 -3
- package/esm2022/plugins/with-draw-resize.mjs +11 -6
- package/esm2022/plugins/with-draw-rotate.mjs +3 -2
- package/esm2022/plugins/with-draw.mjs +10 -11
- package/esm2022/plugins/with-vector-line-create.mjs +123 -0
- package/esm2022/plugins/with-vector-line-resize.mjs +3 -3
- package/esm2022/table.component.mjs +8 -9
- package/esm2022/transforms/index.mjs +3 -3
- package/esm2022/transforms/multi-text-geometry-text.mjs +3 -3
- package/esm2022/utils/arrow-line/arrow-line-basic.mjs +3 -3
- package/esm2022/utils/clipboard.mjs +6 -17
- package/esm2022/utils/common.mjs +15 -8
- package/esm2022/utils/geometry.mjs +3 -3
- package/esm2022/utils/hit.mjs +21 -19
- package/esm2022/utils/index.mjs +2 -1
- package/esm2022/utils/multi-text-geometry.mjs +3 -3
- package/esm2022/utils/selected.mjs +9 -1
- package/esm2022/utils/snap-resizing.mjs +1 -1
- package/esm2022/utils/style/stroke.mjs +6 -6
- package/esm2022/utils/table.mjs +2 -2
- package/esm2022/utils/vector-line.mjs +3 -9
- package/esm2022/vector-line.component.mjs +2 -4
- package/fesm2022/plait-draw.mjs +248 -301
- package/fesm2022/plait-draw.mjs.map +1 -1
- package/generators/single-text.generator.d.ts +2 -2
- package/generators/text.generator.d.ts +11 -11
- package/interfaces/arrow-line.d.ts +1 -1
- package/interfaces/element.d.ts +0 -5
- package/interfaces/geometry.d.ts +11 -10
- package/interfaces/index.d.ts +4 -1
- package/interfaces/options.d.ts +4 -0
- package/interfaces/vector-line.d.ts +4 -4
- package/package.json +1 -1
- package/plugins/with-vector-line-create.d.ts +2 -0
- package/styles/styles.scss +1 -1
- package/table.component.d.ts +2 -2
- package/transforms/common.d.ts +1 -1
- package/transforms/geometry.d.ts +1 -1
- package/transforms/index.d.ts +3 -3
- package/transforms/multi-text-geometry-text.d.ts +2 -2
- package/utils/clipboard.d.ts +10 -3
- package/utils/common.d.ts +5 -3
- package/utils/geometry.d.ts +6 -6
- package/utils/hit.d.ts +8 -4
- package/utils/index.d.ts +1 -0
- package/utils/multi-text-geometry.d.ts +6 -10
- package/utils/selected.d.ts +3 -1
- package/utils/snap-resizing.d.ts +2 -2
- package/utils/vector-line.d.ts +0 -1
- package/esm2022/plugins/with-geometry-resize.mjs +0 -70
- package/esm2022/plugins/with-vector-pen-create.mjs +0 -123
- package/plugins/with-geometry-resize.d.ts +0 -2
- package/plugins/with-vector-pen-create.d.ts +0 -2
|
@@ -1,123 +0,0 @@
|
|
|
1
|
-
import { BoardTransforms, PlaitBoard, PlaitPointerType, Transforms, addSelectedElement, clearSelectedElement, createG, distanceBetweenPointAndPoint, getElementById, toHostPoint, toViewBoxPoint } from '@plait/core';
|
|
2
|
-
import { VectorLineShape, VectorPenPointerType } from '../interfaces';
|
|
3
|
-
import { LINE_HIT_GEOMETRY_BUFFER, getVectorPenPointers } from '../constants';
|
|
4
|
-
import { isDrawingMode } from '@plait/common';
|
|
5
|
-
import { vectorLineCreating } from '../utils';
|
|
6
|
-
import { isKeyHotkey } from 'is-hotkey';
|
|
7
|
-
export const withVectorPenCreateByDraw = (board) => {
|
|
8
|
-
const { pointerDown, pointerMove, dblClick, globalKeyDown } = board;
|
|
9
|
-
let lineShapeG = null;
|
|
10
|
-
let temporaryElement = null;
|
|
11
|
-
let vectorPenRef;
|
|
12
|
-
const vectorLineComplete = () => {
|
|
13
|
-
if (vectorPenRef) {
|
|
14
|
-
clearSelectedElement(board);
|
|
15
|
-
if (vectorPenRef?.element) {
|
|
16
|
-
addSelectedElement(board, vectorPenRef?.element);
|
|
17
|
-
}
|
|
18
|
-
}
|
|
19
|
-
PlaitBoard.getBoardContainer(board).classList.remove(`vector-line-closed`);
|
|
20
|
-
lineShapeG?.remove();
|
|
21
|
-
lineShapeG = null;
|
|
22
|
-
vectorPenRef = null;
|
|
23
|
-
temporaryElement = null;
|
|
24
|
-
};
|
|
25
|
-
board.pointerDown = (event) => {
|
|
26
|
-
const penPointers = getVectorPenPointers();
|
|
27
|
-
const isVectorPenPointer = PlaitBoard.isInPointer(board, penPointers);
|
|
28
|
-
if (isVectorPenPointer && !vectorPenRef) {
|
|
29
|
-
vectorPenRef = { shape: VectorLineShape.straight };
|
|
30
|
-
}
|
|
31
|
-
if (!PlaitBoard.isReadonly(board) && vectorPenRef && isDrawingMode(board)) {
|
|
32
|
-
let point = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));
|
|
33
|
-
if (!temporaryElement) {
|
|
34
|
-
vectorPenRef = {
|
|
35
|
-
...vectorPenRef,
|
|
36
|
-
start: point
|
|
37
|
-
};
|
|
38
|
-
}
|
|
39
|
-
else {
|
|
40
|
-
if (!vectorPenRef.element) {
|
|
41
|
-
vectorPenRef.element = temporaryElement;
|
|
42
|
-
Transforms.insertNode(board, vectorPenRef.element, [board.children.length]);
|
|
43
|
-
}
|
|
44
|
-
else {
|
|
45
|
-
let points = vectorPenRef.element.points;
|
|
46
|
-
const isClosed = distanceBetweenPointAndPoint(...point, ...vectorPenRef.start) <= LINE_HIT_GEOMETRY_BUFFER;
|
|
47
|
-
if (isClosed) {
|
|
48
|
-
point = vectorPenRef.start;
|
|
49
|
-
}
|
|
50
|
-
if (vectorPenRef.path) {
|
|
51
|
-
const lastPoint = points[points.length - 1];
|
|
52
|
-
const distance = distanceBetweenPointAndPoint(...point, ...lastPoint);
|
|
53
|
-
if (distance > 2) {
|
|
54
|
-
Transforms.setNode(board, { points: [...points, point] }, vectorPenRef.path);
|
|
55
|
-
}
|
|
56
|
-
}
|
|
57
|
-
vectorPenRef.element = getElementById(board, vectorPenRef.element.id);
|
|
58
|
-
if (isClosed) {
|
|
59
|
-
vectorLineComplete();
|
|
60
|
-
}
|
|
61
|
-
}
|
|
62
|
-
}
|
|
63
|
-
}
|
|
64
|
-
pointerDown(event);
|
|
65
|
-
};
|
|
66
|
-
board.pointerMove = (event) => {
|
|
67
|
-
lineShapeG?.remove();
|
|
68
|
-
lineShapeG = createG();
|
|
69
|
-
let movingPoint = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));
|
|
70
|
-
const pointer = PlaitBoard.getPointer(board);
|
|
71
|
-
if (pointer !== VectorPenPointerType.vectorPen) {
|
|
72
|
-
vectorLineComplete();
|
|
73
|
-
}
|
|
74
|
-
if (vectorPenRef && vectorPenRef.start) {
|
|
75
|
-
let drawPoints = [vectorPenRef.start];
|
|
76
|
-
if (vectorPenRef.element) {
|
|
77
|
-
drawPoints = [vectorPenRef.start, ...vectorPenRef.element.points];
|
|
78
|
-
const path = PlaitBoard.findPath(board, vectorPenRef.element);
|
|
79
|
-
vectorPenRef.path = path;
|
|
80
|
-
}
|
|
81
|
-
const distance = distanceBetweenPointAndPoint(...movingPoint, ...vectorPenRef.start);
|
|
82
|
-
if (distance <= LINE_HIT_GEOMETRY_BUFFER) {
|
|
83
|
-
movingPoint = vectorPenRef.start;
|
|
84
|
-
PlaitBoard.getBoardContainer(board).classList.add(`vector-line-closed`);
|
|
85
|
-
}
|
|
86
|
-
else {
|
|
87
|
-
PlaitBoard.getBoardContainer(board).classList.remove(`vector-line-closed`);
|
|
88
|
-
}
|
|
89
|
-
temporaryElement = vectorLineCreating(board, vectorPenRef.shape, drawPoints, movingPoint, lineShapeG);
|
|
90
|
-
}
|
|
91
|
-
pointerMove(event);
|
|
92
|
-
};
|
|
93
|
-
board.dblClick = (event) => {
|
|
94
|
-
if (!PlaitBoard.isReadonly(board)) {
|
|
95
|
-
if (vectorPenRef) {
|
|
96
|
-
if (vectorPenRef.path) {
|
|
97
|
-
Transforms.setNode(board, { points: vectorPenRef?.element?.points }, vectorPenRef.path);
|
|
98
|
-
}
|
|
99
|
-
vectorLineComplete();
|
|
100
|
-
BoardTransforms.updatePointerType(board, PlaitPointerType.selection);
|
|
101
|
-
}
|
|
102
|
-
}
|
|
103
|
-
dblClick(event);
|
|
104
|
-
};
|
|
105
|
-
board.globalKeyDown = (event) => {
|
|
106
|
-
if (!PlaitBoard.isReadonly(board)) {
|
|
107
|
-
const isEsc = isKeyHotkey('esc', event);
|
|
108
|
-
const isV = isKeyHotkey('v', event);
|
|
109
|
-
if ((isEsc || isV) && vectorPenRef) {
|
|
110
|
-
if (vectorPenRef.path) {
|
|
111
|
-
Transforms.setNode(board, { points: vectorPenRef.element?.points }, vectorPenRef.path);
|
|
112
|
-
}
|
|
113
|
-
vectorLineComplete();
|
|
114
|
-
if (isV) {
|
|
115
|
-
BoardTransforms.updatePointerType(board, PlaitPointerType.selection);
|
|
116
|
-
}
|
|
117
|
-
}
|
|
118
|
-
}
|
|
119
|
-
globalKeyDown(event);
|
|
120
|
-
};
|
|
121
|
-
return board;
|
|
122
|
-
};
|
|
123
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-vector-pen-create.js","sourceRoot":"","sources":["../../../../packages/draw/src/plugins/with-vector-pen-create.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    BoardTransforms,\n    PlaitBoard,\n    PlaitPointerType,\n    Transforms,\n    addSelectedElement,\n    clearSelectedElement,\n    createG,\n    distanceBetweenPointAndPoint,\n    getElementById,\n    toHostPoint,\n    toViewBoxPoint\n} from '@plait/core';\nimport { PlaitVectorLine, VectorLineShape, VectorPenPointerType, VectorPenRef } from '../interfaces';\nimport { DrawPointerType, LINE_HIT_GEOMETRY_BUFFER, getVectorPenPointers } from '../constants';\nimport { isDrawingMode } from '@plait/common';\nimport { vectorLineCreating } from '../utils';\nimport { isKeyHotkey } from 'is-hotkey';\n\nexport const withVectorPenCreateByDraw = (board: PlaitBoard) => {\n    const { pointerDown, pointerMove, dblClick, globalKeyDown } = board;\n\n    let lineShapeG: SVGGElement | null = null;\n\n    let temporaryElement: PlaitVectorLine | null = null;\n\n    let vectorPenRef: VectorPenRef | null;\n\n    const vectorLineComplete = () => {\n        if (vectorPenRef) {\n            clearSelectedElement(board);\n            if (vectorPenRef?.element) {\n                addSelectedElement(board, vectorPenRef?.element);\n            }\n        }\n        PlaitBoard.getBoardContainer(board).classList.remove(`vector-line-closed`);\n        lineShapeG?.remove();\n        lineShapeG = null;\n        vectorPenRef = null;\n        temporaryElement = null;\n    };\n\n    board.pointerDown = (event: PointerEvent) => {\n        const penPointers = getVectorPenPointers();\n        const isVectorPenPointer = PlaitBoard.isInPointer(board, penPointers);\n\n        if (isVectorPenPointer && !vectorPenRef) {\n            vectorPenRef = { shape: VectorLineShape.straight };\n        }\n\n        if (!PlaitBoard.isReadonly(board) && vectorPenRef && isDrawingMode(board)) {\n            let point = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));\n            if (!temporaryElement) {\n                vectorPenRef = {\n                    ...vectorPenRef,\n                    start: point\n                };\n            } else {\n                if (!vectorPenRef.element) {\n                    vectorPenRef.element = temporaryElement;\n                    Transforms.insertNode(board, vectorPenRef.element, [board.children.length]);\n                } else {\n                    let points = vectorPenRef.element.points;\n                    const isClosed = distanceBetweenPointAndPoint(...point, ...vectorPenRef.start!) <= LINE_HIT_GEOMETRY_BUFFER;\n                    if (isClosed) {\n                        point = vectorPenRef.start!;\n                    }\n                    if (vectorPenRef.path) {\n                        const lastPoint = points[points.length - 1];\n                        const distance = distanceBetweenPointAndPoint(...point, ...lastPoint);\n                        if (distance > 2) {\n                            Transforms.setNode(board, { points: [...points, point] }, vectorPenRef.path);\n                        }\n                    }\n                    vectorPenRef.element = getElementById(board, vectorPenRef.element.id);\n                    if (isClosed) {\n                        vectorLineComplete();\n                    }\n                }\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        const pointer = PlaitBoard.getPointer(board) as DrawPointerType;\n        if (pointer !== VectorPenPointerType.vectorPen) {\n            vectorLineComplete();\n        }\n        if (vectorPenRef && vectorPenRef.start) {\n            let drawPoints = [vectorPenRef.start];\n            if (vectorPenRef.element) {\n                drawPoints = [vectorPenRef.start, ...vectorPenRef.element.points];\n                const path = PlaitBoard.findPath(board, vectorPenRef.element!);\n                vectorPenRef.path = path;\n            }\n            const distance = distanceBetweenPointAndPoint(...movingPoint, ...vectorPenRef.start);\n            if (distance <= LINE_HIT_GEOMETRY_BUFFER) {\n                movingPoint = vectorPenRef.start;\n                PlaitBoard.getBoardContainer(board).classList.add(`vector-line-closed`);\n            } else {\n                PlaitBoard.getBoardContainer(board).classList.remove(`vector-line-closed`);\n            }\n            temporaryElement = vectorLineCreating(board, vectorPenRef.shape, drawPoints, movingPoint, lineShapeG);\n        }\n        pointerMove(event);\n    };\n\n    board.dblClick = (event: MouseEvent) => {\n        if (!PlaitBoard.isReadonly(board)) {\n            if (vectorPenRef) {\n                if (vectorPenRef.path) {\n                    Transforms.setNode(board, { points: vectorPenRef?.element?.points }, vectorPenRef.path);\n                }\n                vectorLineComplete();\n                BoardTransforms.updatePointerType(board, PlaitPointerType.selection);\n            }\n        }\n        dblClick(event);\n    };\n\n    board.globalKeyDown = (event: KeyboardEvent) => {\n        if (!PlaitBoard.isReadonly(board)) {\n            const isEsc = isKeyHotkey('esc', event);\n            const isV = isKeyHotkey('v', event);\n            if ((isEsc || isV) && vectorPenRef) {\n                if (vectorPenRef.path) {\n                    Transforms.setNode(board, { points: vectorPenRef.element?.points }, vectorPenRef.path);\n                }\n                vectorLineComplete();\n                if (isV) {\n                    BoardTransforms.updatePointerType(board, PlaitPointerType.selection);\n                }\n            }\n        }\n        globalKeyDown(event);\n    };\n\n    return board;\n};\n"]}
|