@plait/draw 0.77.2 → 0.78.0-next.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/fesm2022/plait-draw.mjs +21 -14
- package/fesm2022/plait-draw.mjs.map +1 -1
- package/package.json +1 -3
- package/transforms/image.d.ts +6 -0
- package/utils/hit.d.ts +1 -1
- package/esm2022/arrow-line.component.mjs +0 -165
- package/esm2022/constants/default.mjs +0 -7
- package/esm2022/constants/geometry.mjs +0 -272
- package/esm2022/constants/image.mjs +0 -2
- package/esm2022/constants/index.mjs +0 -9
- package/esm2022/constants/line.mjs +0 -12
- package/esm2022/constants/pointer.mjs +0 -23
- package/esm2022/constants/swimlane.mjs +0 -25
- package/esm2022/constants/text.mjs +0 -2
- package/esm2022/constants/theme.mjs +0 -28
- package/esm2022/engines/basic-shapes/cloud.mjs +0 -146
- package/esm2022/engines/basic-shapes/comment.mjs +0 -56
- package/esm2022/engines/basic-shapes/cross.mjs +0 -33
- package/esm2022/engines/basic-shapes/diamond.mjs +0 -16
- package/esm2022/engines/basic-shapes/ellipse.mjs +0 -53
- package/esm2022/engines/basic-shapes/hexagon.mjs +0 -27
- package/esm2022/engines/basic-shapes/left-arrow.mjs +0 -30
- package/esm2022/engines/basic-shapes/octagon.mjs +0 -29
- package/esm2022/engines/basic-shapes/parallelogram.mjs +0 -26
- package/esm2022/engines/basic-shapes/pentagon-arrow.mjs +0 -27
- package/esm2022/engines/basic-shapes/pentagon.mjs +0 -30
- package/esm2022/engines/basic-shapes/polygon.mjs +0 -56
- package/esm2022/engines/basic-shapes/process-arrow.mjs +0 -26
- package/esm2022/engines/basic-shapes/rectangle.mjs +0 -26
- package/esm2022/engines/basic-shapes/right-arrow.mjs +0 -28
- package/esm2022/engines/basic-shapes/round-comment.mjs +0 -82
- package/esm2022/engines/basic-shapes/round-rectangle.mjs +0 -58
- package/esm2022/engines/basic-shapes/star.mjs +0 -39
- package/esm2022/engines/basic-shapes/trapezoid.mjs +0 -26
- package/esm2022/engines/basic-shapes/triangle.mjs +0 -34
- package/esm2022/engines/basic-shapes/two-way-arrow.mjs +0 -25
- package/esm2022/engines/flowchart/database.mjs +0 -84
- package/esm2022/engines/flowchart/delay.mjs +0 -44
- package/esm2022/engines/flowchart/display.mjs +0 -74
- package/esm2022/engines/flowchart/document.mjs +0 -81
- package/esm2022/engines/flowchart/hard-disk.mjs +0 -84
- package/esm2022/engines/flowchart/internal-storage.mjs +0 -47
- package/esm2022/engines/flowchart/manual-input.mjs +0 -33
- package/esm2022/engines/flowchart/manual-loop.mjs +0 -26
- package/esm2022/engines/flowchart/merge.mjs +0 -34
- package/esm2022/engines/flowchart/multi-document.mjs +0 -143
- package/esm2022/engines/flowchart/note-curly-left.mjs +0 -86
- package/esm2022/engines/flowchart/note-curly-right.mjs +0 -89
- package/esm2022/engines/flowchart/note-square.mjs +0 -46
- package/esm2022/engines/flowchart/off-page.mjs +0 -32
- package/esm2022/engines/flowchart/or.mjs +0 -20
- package/esm2022/engines/flowchart/predefined-process.mjs +0 -47
- package/esm2022/engines/flowchart/preparation.mjs +0 -27
- package/esm2022/engines/flowchart/stored-data.mjs +0 -79
- package/esm2022/engines/flowchart/summing-junction.mjs +0 -23
- package/esm2022/engines/flowchart/terminal.mjs +0 -68
- package/esm2022/engines/index.mjs +0 -130
- package/esm2022/engines/table/table.mjs +0 -101
- package/esm2022/engines/uml/activity-class.mjs +0 -47
- package/esm2022/engines/uml/actor.mjs +0 -119
- package/esm2022/engines/uml/assembly.mjs +0 -105
- package/esm2022/engines/uml/combined-fragment.mjs +0 -66
- package/esm2022/engines/uml/component-box.mjs +0 -61
- package/esm2022/engines/uml/component.mjs +0 -117
- package/esm2022/engines/uml/container.mjs +0 -44
- package/esm2022/engines/uml/deletion.mjs +0 -54
- package/esm2022/engines/uml/note.mjs +0 -58
- package/esm2022/engines/uml/package.mjs +0 -105
- package/esm2022/engines/uml/provided-interface.mjs +0 -92
- package/esm2022/engines/uml/required-interface.mjs +0 -81
- package/esm2022/engines/uml/template.mjs +0 -47
- package/esm2022/generators/arrow-line-auto-complete.generator.mjs +0 -46
- package/esm2022/generators/arrow-line.generator.mjs +0 -13
- package/esm2022/generators/geometry-shape.generator.mjs +0 -29
- package/esm2022/generators/index.mjs +0 -7
- package/esm2022/generators/line-active.generator.mjs +0 -84
- package/esm2022/generators/single-text.generator.mjs +0 -16
- package/esm2022/generators/table.generator.mjs +0 -25
- package/esm2022/generators/text.generator.mjs +0 -131
- package/esm2022/generators/vector-line-generator.mjs +0 -13
- package/esm2022/geometry.component.mjs +0 -145
- package/esm2022/image.component.mjs +0 -67
- package/esm2022/interfaces/arrow-line.mjs +0 -70
- package/esm2022/interfaces/element.mjs +0 -9
- package/esm2022/interfaces/engine.mjs +0 -2
- package/esm2022/interfaces/geometry.mjs +0 -82
- package/esm2022/interfaces/image.mjs +0 -2
- package/esm2022/interfaces/index.mjs +0 -92
- package/esm2022/interfaces/line.mjs +0 -2
- package/esm2022/interfaces/options.mjs +0 -2
- package/esm2022/interfaces/swimlane.mjs +0 -13
- package/esm2022/interfaces/table.mjs +0 -13
- package/esm2022/interfaces/text.mjs +0 -2
- package/esm2022/interfaces/vector-line.mjs +0 -10
- package/esm2022/plait-draw.mjs +0 -5
- package/esm2022/plugins/with-arrow-line-auto-complete-reaction.mjs +0 -43
- package/esm2022/plugins/with-arrow-line-auto-complete.mjs +0 -76
- package/esm2022/plugins/with-arrow-line-bound-reaction.mjs +0 -53
- package/esm2022/plugins/with-arrow-line-create.mjs +0 -51
- package/esm2022/plugins/with-arrow-line-resize.mjs +0 -158
- package/esm2022/plugins/with-arrow-line-text-move.mjs +0 -53
- package/esm2022/plugins/with-arrow-line-text.mjs +0 -73
- package/esm2022/plugins/with-draw-fragment.mjs +0 -98
- package/esm2022/plugins/with-draw-hotkey.mjs +0 -45
- package/esm2022/plugins/with-draw-resize.mjs +0 -269
- package/esm2022/plugins/with-draw-rotate.mjs +0 -132
- package/esm2022/plugins/with-draw.mjs +0 -144
- package/esm2022/plugins/with-geometry-create.mjs +0 -182
- package/esm2022/plugins/with-swimlane-create.mjs +0 -127
- package/esm2022/plugins/with-swimlane.mjs +0 -21
- package/esm2022/plugins/with-table-resize.mjs +0 -135
- package/esm2022/plugins/with-table.mjs +0 -109
- package/esm2022/plugins/with-vector-line-create.mjs +0 -85
- package/esm2022/plugins/with-vector-line-resize.mjs +0 -61
- package/esm2022/public-api.mjs +0 -11
- package/esm2022/table.component.mjs +0 -162
- package/esm2022/transforms/arrow-line.mjs +0 -66
- package/esm2022/transforms/common.mjs +0 -36
- package/esm2022/transforms/geometry-text.mjs +0 -59
- package/esm2022/transforms/geometry.mjs +0 -43
- package/esm2022/transforms/image.mjs +0 -22
- package/esm2022/transforms/index.mjs +0 -36
- package/esm2022/transforms/multi-text-geometry-text.mjs +0 -15
- package/esm2022/transforms/swimlane.mjs +0 -164
- package/esm2022/transforms/table-text.mjs +0 -44
- package/esm2022/transforms/table.mjs +0 -36
- package/esm2022/transforms/vector-line.mjs +0 -13
- package/esm2022/utils/arrow-line/arrow-line-arrow.mjs +0 -123
- package/esm2022/utils/arrow-line/arrow-line-basic.mjs +0 -205
- package/esm2022/utils/arrow-line/arrow-line-common.mjs +0 -162
- package/esm2022/utils/arrow-line/arrow-line-resize.mjs +0 -309
- package/esm2022/utils/arrow-line/elbow.mjs +0 -114
- package/esm2022/utils/arrow-line/index.mjs +0 -6
- package/esm2022/utils/clipboard.mjs +0 -55
- package/esm2022/utils/common.mjs +0 -184
- package/esm2022/utils/geometry.mjs +0 -178
- package/esm2022/utils/hit.mjs +0 -242
- package/esm2022/utils/index.mjs +0 -17
- package/esm2022/utils/line.mjs +0 -64
- package/esm2022/utils/memorize.mjs +0 -93
- package/esm2022/utils/multi-text-geometry.mjs +0 -61
- package/esm2022/utils/polygon.mjs +0 -30
- package/esm2022/utils/position/arrow-line.mjs +0 -20
- package/esm2022/utils/position/geometry.mjs +0 -30
- package/esm2022/utils/position/line.mjs +0 -51
- package/esm2022/utils/selected.mjs +0 -39
- package/esm2022/utils/shape.mjs +0 -11
- package/esm2022/utils/snap-resizing.mjs +0 -185
- package/esm2022/utils/style/index.mjs +0 -2
- package/esm2022/utils/style/stroke.mjs +0 -21
- package/esm2022/utils/swimlane.mjs +0 -124
- package/esm2022/utils/table-selected.mjs +0 -21
- package/esm2022/utils/table.mjs +0 -172
- package/esm2022/utils/uml.mjs +0 -90
- package/esm2022/utils/vector-line.mjs +0 -71
- package/esm2022/vector-line.component.mjs +0 -55
|
@@ -1,164 +0,0 @@
|
|
|
1
|
-
import { idCreator, PlaitBoard, RectangleClient, Transforms } from '@plait/core';
|
|
2
|
-
import { PlaitDrawElement } from '../interfaces';
|
|
3
|
-
import { getCellWithPoints } from '../utils/table';
|
|
4
|
-
import { getSwimlaneCount } from '../utils/swimlane';
|
|
5
|
-
import { Alignment } from '@plait/common';
|
|
6
|
-
export const updateSwimlaneCount = (board, swimlane, count) => {
|
|
7
|
-
if (count > 0 && PlaitDrawElement.isSwimlane(swimlane)) {
|
|
8
|
-
const currentCount = getSwimlaneCount(swimlane);
|
|
9
|
-
if (PlaitDrawElement.isHorizontalSwimlane(swimlane)) {
|
|
10
|
-
if (count > currentCount) {
|
|
11
|
-
addSwimlaneRow(board, swimlane, swimlane.rows.length, count - currentCount);
|
|
12
|
-
}
|
|
13
|
-
else {
|
|
14
|
-
const deleteIndex = swimlane.rows.length - (currentCount - count);
|
|
15
|
-
removeSwimlaneRow(board, swimlane, deleteIndex, currentCount - count);
|
|
16
|
-
}
|
|
17
|
-
}
|
|
18
|
-
if (PlaitDrawElement.isVerticalSwimlane(swimlane)) {
|
|
19
|
-
if (count > currentCount) {
|
|
20
|
-
addSwimlaneColumn(board, swimlane, swimlane.columns.length, count - currentCount);
|
|
21
|
-
}
|
|
22
|
-
else {
|
|
23
|
-
const deleteIndex = swimlane.columns.length - (currentCount - count);
|
|
24
|
-
removeSwimlaneColumn(board, swimlane, deleteIndex, currentCount - count);
|
|
25
|
-
}
|
|
26
|
-
}
|
|
27
|
-
}
|
|
28
|
-
};
|
|
29
|
-
export const addSwimlaneRow = (board, swimlane, index, count = 1) => {
|
|
30
|
-
if (PlaitDrawElement.isHorizontalSwimlane(swimlane)) {
|
|
31
|
-
const newRows = [...swimlane.rows];
|
|
32
|
-
const addRows = [];
|
|
33
|
-
for (let i = 0; i < count; i++) {
|
|
34
|
-
addRows.push({ id: idCreator() });
|
|
35
|
-
}
|
|
36
|
-
newRows.splice(index, 0, ...addRows);
|
|
37
|
-
const newCells = [...swimlane.cells];
|
|
38
|
-
addRows.forEach(item => {
|
|
39
|
-
newCells.push(...createNewSwimlaneCells(swimlane, item.id, 'column'));
|
|
40
|
-
});
|
|
41
|
-
const lastCellPoints = getCellWithPoints(board, swimlane, swimlane.cells[swimlane.cells.length - 1].id).points;
|
|
42
|
-
const lastRowHeight = RectangleClient.getRectangleByPoints(lastCellPoints).height;
|
|
43
|
-
const newPoints = [swimlane.points[0], [swimlane.points[1][0], swimlane.points[1][1] + lastRowHeight * count]];
|
|
44
|
-
updateSwimlane(board, swimlane, swimlane.columns, newRows, newCells, newPoints);
|
|
45
|
-
}
|
|
46
|
-
};
|
|
47
|
-
export const addSwimlaneColumn = (board, swimlane, index, count = 1) => {
|
|
48
|
-
if (PlaitDrawElement.isVerticalSwimlane(swimlane)) {
|
|
49
|
-
const newColumns = [...swimlane.columns];
|
|
50
|
-
const addColumns = [];
|
|
51
|
-
for (let i = 0; i < count; i++) {
|
|
52
|
-
addColumns.push({ id: idCreator() });
|
|
53
|
-
}
|
|
54
|
-
newColumns.splice(index, 0, ...addColumns);
|
|
55
|
-
const newCells = [...swimlane.cells];
|
|
56
|
-
addColumns.forEach(item => {
|
|
57
|
-
newCells.push(...createNewSwimlaneCells(swimlane, item.id, 'row'));
|
|
58
|
-
});
|
|
59
|
-
const lastCellPoints = getCellWithPoints(board, swimlane, swimlane.cells[swimlane.cells.length - 1].id).points;
|
|
60
|
-
const lastColumnWidth = RectangleClient.getRectangleByPoints(lastCellPoints).width;
|
|
61
|
-
const newPoints = [swimlane.points[0], [swimlane.points[1][0] + lastColumnWidth * count, swimlane.points[1][1]]];
|
|
62
|
-
updateSwimlane(board, swimlane, newColumns, swimlane.rows, newCells, newPoints);
|
|
63
|
-
}
|
|
64
|
-
};
|
|
65
|
-
export const removeSwimlaneRow = (board, swimlane, index, count = 1) => {
|
|
66
|
-
if (PlaitDrawElement.isHorizontalSwimlane(swimlane)) {
|
|
67
|
-
if (count > swimlane.rows.length) {
|
|
68
|
-
return;
|
|
69
|
-
}
|
|
70
|
-
const newRows = [...swimlane.rows];
|
|
71
|
-
newRows.splice(index, count);
|
|
72
|
-
if (newRows.length === 0) {
|
|
73
|
-
const path = PlaitBoard.findPath(board, swimlane);
|
|
74
|
-
Transforms.removeNode(board, path);
|
|
75
|
-
}
|
|
76
|
-
else {
|
|
77
|
-
let newCells = [...swimlane.cells];
|
|
78
|
-
const removeRows = [];
|
|
79
|
-
for (let i = index; i < count + index; i++) {
|
|
80
|
-
const removeRow = swimlane.rows[i];
|
|
81
|
-
removeRows.push(removeRow);
|
|
82
|
-
newCells = newCells.filter(item => item.rowId !== removeRow.id);
|
|
83
|
-
}
|
|
84
|
-
let removeRowHeight = 0;
|
|
85
|
-
removeRows.forEach(row => {
|
|
86
|
-
if (!row.height) {
|
|
87
|
-
const rowCell = swimlane.cells.find(item => item.rowId === row.id);
|
|
88
|
-
const cellPoints = getCellWithPoints(board, swimlane, rowCell.id).points;
|
|
89
|
-
removeRowHeight += RectangleClient.getRectangleByPoints(cellPoints).height;
|
|
90
|
-
}
|
|
91
|
-
else {
|
|
92
|
-
removeRowHeight += row.height;
|
|
93
|
-
}
|
|
94
|
-
});
|
|
95
|
-
const newPoints = [swimlane.points[0], [swimlane.points[1][0], swimlane.points[1][1] - removeRowHeight]];
|
|
96
|
-
updateSwimlane(board, swimlane, swimlane.columns, newRows, newCells, newPoints);
|
|
97
|
-
}
|
|
98
|
-
}
|
|
99
|
-
};
|
|
100
|
-
export const removeSwimlaneColumn = (board, swimlane, index, count = 1) => {
|
|
101
|
-
if (PlaitDrawElement.isVerticalSwimlane(swimlane)) {
|
|
102
|
-
if (count > swimlane.columns.length) {
|
|
103
|
-
return;
|
|
104
|
-
}
|
|
105
|
-
const newColumns = [...swimlane.columns];
|
|
106
|
-
newColumns.splice(index, count);
|
|
107
|
-
if (newColumns.length === 0) {
|
|
108
|
-
const path = PlaitBoard.findPath(board, swimlane);
|
|
109
|
-
Transforms.removeNode(board, path);
|
|
110
|
-
}
|
|
111
|
-
else {
|
|
112
|
-
let newCells = [...swimlane.cells];
|
|
113
|
-
const removeColumns = [];
|
|
114
|
-
for (let i = index; i < count + index; i++) {
|
|
115
|
-
const removeColumn = swimlane.columns[i];
|
|
116
|
-
removeColumns.push(removeColumn);
|
|
117
|
-
newCells = newCells.filter(item => item.columnId !== removeColumn.id);
|
|
118
|
-
}
|
|
119
|
-
let removeColumnWidth = 0;
|
|
120
|
-
removeColumns.forEach(column => {
|
|
121
|
-
if (!column.width) {
|
|
122
|
-
const rowCell = swimlane.cells.find(item => item.columnId === column.id);
|
|
123
|
-
const cellPoints = getCellWithPoints(board, swimlane, rowCell.id).points;
|
|
124
|
-
removeColumnWidth += RectangleClient.getRectangleByPoints(cellPoints).width;
|
|
125
|
-
}
|
|
126
|
-
else {
|
|
127
|
-
removeColumnWidth += column.width;
|
|
128
|
-
}
|
|
129
|
-
});
|
|
130
|
-
const newPoints = [swimlane.points[0], [swimlane.points[1][0] - removeColumnWidth, swimlane.points[1][1]]];
|
|
131
|
-
updateSwimlane(board, swimlane, newColumns, swimlane.rows, newCells, newPoints);
|
|
132
|
-
}
|
|
133
|
-
}
|
|
134
|
-
};
|
|
135
|
-
const createNewSwimlaneCells = (swimlane, newId, type) => {
|
|
136
|
-
const cells = swimlane[`${type}s`].map(item => ({
|
|
137
|
-
id: idCreator(),
|
|
138
|
-
rowId: type === 'row' ? item.id : newId,
|
|
139
|
-
columnId: type === 'row' ? newId : item.id
|
|
140
|
-
}));
|
|
141
|
-
if (swimlane.header) {
|
|
142
|
-
cells.shift();
|
|
143
|
-
}
|
|
144
|
-
cells[0] = {
|
|
145
|
-
...cells[0],
|
|
146
|
-
text: {
|
|
147
|
-
children: [{ text: swimlane.header ? 'Lane' : 'New Swimlane' }],
|
|
148
|
-
align: Alignment.center,
|
|
149
|
-
direction: type === 'row' ? undefined : 'vertical'
|
|
150
|
-
},
|
|
151
|
-
textHeight: 20
|
|
152
|
-
};
|
|
153
|
-
return cells;
|
|
154
|
-
};
|
|
155
|
-
const updateSwimlane = (board, swimlane, newColumns, newRows, newCells, newPoints) => {
|
|
156
|
-
const path = PlaitBoard.findPath(board, swimlane);
|
|
157
|
-
Transforms.setNode(board, {
|
|
158
|
-
columns: newColumns,
|
|
159
|
-
rows: newRows,
|
|
160
|
-
cells: newCells,
|
|
161
|
-
points: newPoints
|
|
162
|
-
}, path);
|
|
163
|
-
};
|
|
164
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"swimlane.js","sourceRoot":"","sources":["../../../../packages/draw/src/transforms/swimlane.ts"],"names":[],"mappings":"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","sourcesContent":["import { idCreator, Path, PlaitBoard, Point, RectangleClient, Transforms } from '@plait/core';\nimport { PlaitDrawElement, PlaitSwimlane } from '../interfaces';\nimport { PlaitBaseTable, PlaitTableCell } from '../interfaces/table';\nimport { getCellWithPoints } from '../utils/table';\nimport { getSwimlaneCount } from '../utils/swimlane';\nimport { Alignment } from '@plait/common';\n\nexport const updateSwimlaneCount = (board: PlaitBoard, swimlane: PlaitSwimlane, count: number) => {\n    if (count > 0 && PlaitDrawElement.isSwimlane(swimlane)) {\n        const currentCount = getSwimlaneCount(swimlane);\n        if (PlaitDrawElement.isHorizontalSwimlane(swimlane)) {\n            if (count > currentCount) {\n                addSwimlaneRow(board, swimlane, swimlane.rows.length, count - currentCount);\n            } else {\n                const deleteIndex = swimlane.rows.length - (currentCount - count);\n                removeSwimlaneRow(board, swimlane, deleteIndex, currentCount - count);\n            }\n        }\n        if (PlaitDrawElement.isVerticalSwimlane(swimlane)) {\n            if (count > currentCount) {\n                addSwimlaneColumn(board, swimlane, swimlane.columns.length, count - currentCount);\n            } else {\n                const deleteIndex = swimlane.columns.length - (currentCount - count);\n                removeSwimlaneColumn(board, swimlane, deleteIndex, currentCount - count);\n            }\n        }\n    }\n};\n\nexport const addSwimlaneRow = (board: PlaitBoard, swimlane: PlaitSwimlane, index: number, count: number = 1) => {\n    if (PlaitDrawElement.isHorizontalSwimlane(swimlane)) {\n        const newRows = [...swimlane.rows];\n        const addRows: { id: string }[] = [];\n        for (let i = 0; i < count; i++) {\n            addRows.push({ id: idCreator() });\n        }\n        newRows.splice(index, 0, ...addRows);\n        const newCells = [...swimlane.cells];\n        addRows.forEach(item => {\n            newCells.push(...createNewSwimlaneCells(swimlane, item.id, 'column'));\n        });\n        const lastCellPoints = getCellWithPoints(board, swimlane, swimlane.cells[swimlane.cells.length - 1].id).points;\n        const lastRowHeight = RectangleClient.getRectangleByPoints(lastCellPoints).height;\n        const newPoints: Point[] = [swimlane.points[0], [swimlane.points[1][0], swimlane.points[1][1] + lastRowHeight * count]];\n        updateSwimlane(board, swimlane, swimlane.columns, newRows, newCells, newPoints);\n    }\n};\n\nexport const addSwimlaneColumn = (board: PlaitBoard, swimlane: PlaitSwimlane, index: number, count: number = 1) => {\n    if (PlaitDrawElement.isVerticalSwimlane(swimlane)) {\n        const newColumns = [...swimlane.columns];\n        const addColumns: { id: string }[] = [];\n        for (let i = 0; i < count; i++) {\n            addColumns.push({ id: idCreator() });\n        }\n        newColumns.splice(index, 0, ...addColumns);\n        const newCells = [...swimlane.cells];\n        addColumns.forEach(item => {\n            newCells.push(...createNewSwimlaneCells(swimlane, item.id, 'row'));\n        });\n        const lastCellPoints = getCellWithPoints(board, swimlane, swimlane.cells[swimlane.cells.length - 1].id).points;\n        const lastColumnWidth = RectangleClient.getRectangleByPoints(lastCellPoints).width;\n        const newPoints: Point[] = [swimlane.points[0], [swimlane.points[1][0] + lastColumnWidth * count, swimlane.points[1][1]]];\n        updateSwimlane(board, swimlane, newColumns, swimlane.rows, newCells, newPoints);\n    }\n};\n\nexport const removeSwimlaneRow = (board: PlaitBoard, swimlane: PlaitSwimlane, index: number, count: number = 1) => {\n    if (PlaitDrawElement.isHorizontalSwimlane(swimlane)) {\n        if (count > swimlane.rows.length) {\n            return;\n        }\n        const newRows = [...swimlane.rows];\n        newRows.splice(index, count);\n        if (newRows.length === 0) {\n            const path = PlaitBoard.findPath(board, swimlane);\n            Transforms.removeNode(board, path);\n        } else {\n            let newCells = [...swimlane.cells];\n            const removeRows = [];\n            for (let i = index; i < count + index; i++) {\n                const removeRow = swimlane.rows[i];\n                removeRows.push(removeRow);\n                newCells = newCells.filter(item => item.rowId !== removeRow.id);\n            }\n            let removeRowHeight = 0;\n            removeRows.forEach(row => {\n                if (!row.height) {\n                    const rowCell = swimlane.cells.find(item => item.rowId === row.id)!;\n                    const cellPoints = getCellWithPoints(board, swimlane, rowCell.id).points;\n                    removeRowHeight += RectangleClient.getRectangleByPoints(cellPoints).height;\n                } else {\n                    removeRowHeight += row.height;\n                }\n            });\n\n            const newPoints: Point[] = [swimlane.points[0], [swimlane.points[1][0], swimlane.points[1][1] - removeRowHeight]];\n            updateSwimlane(board, swimlane, swimlane.columns, newRows, newCells, newPoints);\n        }\n    }\n};\n\nexport const removeSwimlaneColumn = (board: PlaitBoard, swimlane: PlaitSwimlane, index: number, count: number = 1) => {\n    if (PlaitDrawElement.isVerticalSwimlane(swimlane)) {\n        if (count > swimlane.columns.length) {\n            return;\n        }\n        const newColumns = [...swimlane.columns];\n        newColumns.splice(index, count);\n        if (newColumns.length === 0) {\n            const path = PlaitBoard.findPath(board, swimlane);\n            Transforms.removeNode(board, path);\n        } else {\n            let newCells = [...swimlane.cells];\n            const removeColumns = [];\n            for (let i = index; i < count + index; i++) {\n                const removeColumn = swimlane.columns[i];\n                removeColumns.push(removeColumn);\n                newCells = newCells.filter(item => item.columnId !== removeColumn.id);\n            }\n            let removeColumnWidth = 0;\n            removeColumns.forEach(column => {\n                if (!column.width) {\n                    const rowCell = swimlane.cells.find(item => item.columnId === column.id)!;\n                    const cellPoints = getCellWithPoints(board, swimlane, rowCell.id).points;\n                    removeColumnWidth += RectangleClient.getRectangleByPoints(cellPoints).width;\n                } else {\n                    removeColumnWidth += column.width;\n                }\n            });\n            const newPoints: Point[] = [swimlane.points[0], [swimlane.points[1][0] - removeColumnWidth, swimlane.points[1][1]]];\n            updateSwimlane(board, swimlane, newColumns, swimlane.rows, newCells, newPoints);\n        }\n    }\n};\n\nconst createNewSwimlaneCells = (swimlane: PlaitSwimlane, newId: string, type: 'row' | 'column'): PlaitTableCell[] => {\n    const cells: PlaitTableCell[] = swimlane[`${type}s`].map(item => ({\n        id: idCreator(),\n        rowId: type === 'row' ? item.id : newId,\n        columnId: type === 'row' ? newId : item.id\n    }));\n    if (swimlane.header) {\n        cells.shift();\n    }\n    cells[0] = {\n        ...cells[0],\n        text: {\n            children: [{ text: swimlane.header ? 'Lane' : 'New Swimlane' }],\n            align: Alignment.center,\n            direction: type === 'row' ? undefined : 'vertical'\n        },\n        textHeight: 20\n    };\n    return cells;\n};\n\nconst updateSwimlane = (\n    board: PlaitBoard,\n    swimlane: PlaitSwimlane,\n    newColumns: { id: string; width?: number }[],\n    newRows: { id: string; height?: number }[],\n    newCells: PlaitTableCell[],\n    newPoints: Point[]\n) => {\n    const path = PlaitBoard.findPath(board, swimlane);\n    Transforms.setNode(\n        board,\n        {\n            columns: newColumns,\n            rows: newRows,\n            cells: newCells,\n            points: newPoints\n        },\n        path\n    );\n};\n"]}
|
|
@@ -1,44 +0,0 @@
|
|
|
1
|
-
import { PlaitNode, RectangleClient, Transforms } from '@plait/core';
|
|
2
|
-
import { ShapeDefaultSpace } from '../constants';
|
|
3
|
-
import { PlaitTableElement } from '../interfaces/table';
|
|
4
|
-
import { getCellWithPoints, updateColumns, updateRows } from '../utils/table';
|
|
5
|
-
export const setTableText = (board, path, cellId, text, textHeight) => {
|
|
6
|
-
const table = PlaitNode.get(board, path);
|
|
7
|
-
const cell = getCellWithPoints(board, table, cellId);
|
|
8
|
-
const cellIndex = table.cells.findIndex(item => item.id === cell.id);
|
|
9
|
-
let rows = [...table.rows];
|
|
10
|
-
let columns = [...table.columns];
|
|
11
|
-
let cells = [...table.cells];
|
|
12
|
-
let points = [...table.points];
|
|
13
|
-
const { width: cellWidth, height: cellHeight } = RectangleClient.getRectangleByPoints(cell.points);
|
|
14
|
-
const defaultSpace = ShapeDefaultSpace.rectangleAndText;
|
|
15
|
-
if (PlaitTableElement.isVerticalText(cell)) {
|
|
16
|
-
const columnIdx = table.columns.findIndex(column => column.id === cell.columnId);
|
|
17
|
-
if (textHeight > cellWidth) {
|
|
18
|
-
const newColumnWidth = textHeight + defaultSpace * 2;
|
|
19
|
-
const offset = newColumnWidth - cellWidth;
|
|
20
|
-
const result = updateColumns(table, table.columns[columnIdx].id, newColumnWidth, offset);
|
|
21
|
-
points = result.points;
|
|
22
|
-
columns = result.columns;
|
|
23
|
-
}
|
|
24
|
-
}
|
|
25
|
-
else {
|
|
26
|
-
const rowIdx = table.rows.findIndex(row => row.id === cell.rowId);
|
|
27
|
-
const tableRow = table.rows[rowIdx];
|
|
28
|
-
const compareHeight = tableRow.height ?? Math.max(cellHeight, cell.textHeight || 0);
|
|
29
|
-
if (textHeight > compareHeight) {
|
|
30
|
-
const newRowHeight = textHeight + defaultSpace * 2;
|
|
31
|
-
const offset = newRowHeight - compareHeight;
|
|
32
|
-
const result = updateRows(table, table.rows[rowIdx].id, newRowHeight, offset);
|
|
33
|
-
points = result.points;
|
|
34
|
-
rows = result.rows;
|
|
35
|
-
}
|
|
36
|
-
}
|
|
37
|
-
cells[cellIndex] = {
|
|
38
|
-
...cells[cellIndex],
|
|
39
|
-
textHeight: textHeight,
|
|
40
|
-
text
|
|
41
|
-
};
|
|
42
|
-
Transforms.setNode(board, { rows, columns, cells, points }, path);
|
|
43
|
-
};
|
|
44
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtdGV4dC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3BhY2thZ2VzL2RyYXcvc3JjL3RyYW5zZm9ybXMvdGFibGUtdGV4dC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQW9CLFNBQVMsRUFBRSxlQUFlLEVBQUUsVUFBVSxFQUFFLE1BQU0sYUFBYSxDQUFDO0FBQ3ZGLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGNBQWMsQ0FBQztBQUVqRCxPQUFPLEVBQWtDLGlCQUFpQixFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDeEYsT0FBTyxFQUFFLGlCQUFpQixFQUFFLGFBQWEsRUFBRSxVQUFVLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUU5RSxNQUFNLENBQUMsTUFBTSxZQUFZLEdBQUcsQ0FBQyxLQUFpQixFQUFFLElBQVUsRUFBRSxNQUFjLEVBQUUsSUFBYSxFQUFFLFVBQWtCLEVBQUUsRUFBRTtJQUM3RyxNQUFNLEtBQUssR0FBRyxTQUFTLENBQUMsR0FBRyxDQUFDLEtBQUssRUFBRSxJQUFJLENBQW1CLENBQUM7SUFDM0QsTUFBTSxJQUFJLEdBQUcsaUJBQWlCLENBQUMsS0FBSyxFQUFFLEtBQUssRUFBRSxNQUFNLENBQUMsQ0FBQztJQUNyRCxNQUFNLFNBQVMsR0FBRyxLQUFLLENBQUMsS0FBSyxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLElBQUksQ0FBQyxFQUFFLEtBQUssSUFBSSxDQUFDLEVBQUUsQ0FBQyxDQUFDO0lBQ3JFLElBQUksSUFBSSxHQUFHLENBQUMsR0FBRyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDM0IsSUFBSSxPQUFPLEdBQUcsQ0FBQyxHQUFHLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUNqQyxJQUFJLEtBQUssR0FBRyxDQUFDLEdBQUcsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQzdCLElBQUksTUFBTSxHQUFHLENBQUMsR0FBRyxLQUFLLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDL0IsTUFBTSxFQUFFLEtBQUssRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLFVBQVUsRUFBRSxHQUFHLGVBQWUsQ0FBQyxvQkFBb0IsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDbkcsTUFBTSxZQUFZLEdBQUcsaUJBQWlCLENBQUMsZ0JBQWdCLENBQUM7SUFDeEQsSUFBSSxpQkFBaUIsQ0FBQyxjQUFjLENBQUMsSUFBc0IsQ0FBQyxFQUFFLENBQUM7UUFDM0QsTUFBTSxTQUFTLEdBQUcsS0FBSyxDQUFDLE9BQU8sQ0FBQyxTQUFTLENBQUMsTUFBTSxDQUFDLEVBQUUsQ0FBQyxNQUFNLENBQUMsRUFBRSxLQUFLLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQztRQUNqRixJQUFJLFVBQVUsR0FBRyxTQUFTLEVBQUUsQ0FBQztZQUN6QixNQUFNLGNBQWMsR0FBRyxVQUFVLEdBQUcsWUFBWSxHQUFHLENBQUMsQ0FBQztZQUNyRCxNQUFNLE1BQU0sR0FBRyxjQUFjLEdBQUcsU0FBUyxDQUFDO1lBQzFDLE1BQU0sTUFBTSxHQUFHLGFBQWEsQ0FBQyxLQUFLLEVBQUUsS0FBSyxDQUFDLE9BQU8sQ0FBQyxTQUFTLENBQUMsQ0FBQyxFQUFFLEVBQUUsY0FBYyxFQUFFLE1BQU0sQ0FBQyxDQUFDO1lBQ3pGLE1BQU0sR0FBRyxNQUFNLENBQUMsTUFBTSxDQUFDO1lBQ3ZCLE9BQU8sR0FBRyxNQUFNLENBQUMsT0FBTyxDQUFDO1FBQzdCLENBQUM7SUFDTCxDQUFDO1NBQU0sQ0FBQztRQUNKLE1BQU0sTUFBTSxHQUFHLEtBQUssQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsR0FBRyxDQUFDLEVBQUUsS0FBSyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDbEUsTUFBTSxRQUFRLEdBQUcsS0FBSyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUNwQyxNQUFNLGFBQWEsR0FBRyxRQUFRLENBQUMsTUFBTSxJQUFJLElBQUksQ0FBQyxHQUFHLENBQUMsVUFBVSxFQUFFLElBQUksQ0FBQyxVQUFVLElBQUksQ0FBQyxDQUFDLENBQUM7UUFDcEYsSUFBSSxVQUFVLEdBQUcsYUFBYSxFQUFFLENBQUM7WUFDN0IsTUFBTSxZQUFZLEdBQUcsVUFBVSxHQUFHLFlBQVksR0FBRyxDQUFDLENBQUM7WUFDbkQsTUFBTSxNQUFNLEdBQUcsWUFBWSxHQUFHLGFBQWEsQ0FBQztZQUM1QyxNQUFNLE1BQU0sR0FBRyxVQUFVLENBQUMsS0FBSyxFQUFFLEtBQUssQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUMsRUFBRSxFQUFFLFlBQVksRUFBRSxNQUFNLENBQUMsQ0FBQztZQUM5RSxNQUFNLEdBQUcsTUFBTSxDQUFDLE1BQU0sQ0FBQztZQUN2QixJQUFJLEdBQUcsTUFBTSxDQUFDLElBQUksQ0FBQztRQUN2QixDQUFDO0lBQ0wsQ0FBQztJQUNELEtBQUssQ0FBQyxTQUFTLENBQUMsR0FBRztRQUNmLEdBQUcsS0FBSyxDQUFDLFNBQVMsQ0FBQztRQUNuQixVQUFVLEVBQUUsVUFBVTtRQUN0QixJQUFJO0tBQ1AsQ0FBQztJQUVGLFVBQVUsQ0FBQyxPQUFPLENBQUMsS0FBSyxFQUFFLEVBQUUsSUFBSSxFQUFFLE9BQU8sRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLEVBQUUsSUFBSSxDQUFDLENBQUM7QUFDdEUsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUGF0aCwgUGxhaXRCb2FyZCwgUGxhaXROb2RlLCBSZWN0YW5nbGVDbGllbnQsIFRyYW5zZm9ybXMgfSBmcm9tICdAcGxhaXQvY29yZSc7XG5pbXBvcnQgeyBTaGFwZURlZmF1bHRTcGFjZSB9IGZyb20gJy4uL2NvbnN0YW50cyc7XG5pbXBvcnQgeyBFbGVtZW50IH0gZnJvbSAnc2xhdGUnO1xuaW1wb3J0IHsgUGxhaXRCYXNlVGFibGUsIFBsYWl0VGFibGVDZWxsLCBQbGFpdFRhYmxlRWxlbWVudCB9IGZyb20gJy4uL2ludGVyZmFjZXMvdGFibGUnO1xuaW1wb3J0IHsgZ2V0Q2VsbFdpdGhQb2ludHMsIHVwZGF0ZUNvbHVtbnMsIHVwZGF0ZVJvd3MgfSBmcm9tICcuLi91dGlscy90YWJsZSc7XG5cbmV4cG9ydCBjb25zdCBzZXRUYWJsZVRleHQgPSAoYm9hcmQ6IFBsYWl0Qm9hcmQsIHBhdGg6IFBhdGgsIGNlbGxJZDogc3RyaW5nLCB0ZXh0OiBFbGVtZW50LCB0ZXh0SGVpZ2h0OiBudW1iZXIpID0+IHtcbiAgICBjb25zdCB0YWJsZSA9IFBsYWl0Tm9kZS5nZXQoYm9hcmQsIHBhdGgpIGFzIFBsYWl0QmFzZVRhYmxlO1xuICAgIGNvbnN0IGNlbGwgPSBnZXRDZWxsV2l0aFBvaW50cyhib2FyZCwgdGFibGUsIGNlbGxJZCk7XG4gICAgY29uc3QgY2VsbEluZGV4ID0gdGFibGUuY2VsbHMuZmluZEluZGV4KGl0ZW0gPT4gaXRlbS5pZCA9PT0gY2VsbC5pZCk7XG4gICAgbGV0IHJvd3MgPSBbLi4udGFibGUucm93c107XG4gICAgbGV0IGNvbHVtbnMgPSBbLi4udGFibGUuY29sdW1uc107XG4gICAgbGV0IGNlbGxzID0gWy4uLnRhYmxlLmNlbGxzXTtcbiAgICBsZXQgcG9pbnRzID0gWy4uLnRhYmxlLnBvaW50c107XG4gICAgY29uc3QgeyB3aWR0aDogY2VsbFdpZHRoLCBoZWlnaHQ6IGNlbGxIZWlnaHQgfSA9IFJlY3RhbmdsZUNsaWVudC5nZXRSZWN0YW5nbGVCeVBvaW50cyhjZWxsLnBvaW50cyk7XG4gICAgY29uc3QgZGVmYXVsdFNwYWNlID0gU2hhcGVEZWZhdWx0U3BhY2UucmVjdGFuZ2xlQW5kVGV4dDtcbiAgICBpZiAoUGxhaXRUYWJsZUVsZW1lbnQuaXNWZXJ0aWNhbFRleHQoY2VsbCBhcyBQbGFpdFRhYmxlQ2VsbCkpIHtcbiAgICAgICAgY29uc3QgY29sdW1uSWR4ID0gdGFibGUuY29sdW1ucy5maW5kSW5kZXgoY29sdW1uID0+IGNvbHVtbi5pZCA9PT0gY2VsbC5jb2x1bW5JZCk7XG4gICAgICAgIGlmICh0ZXh0SGVpZ2h0ID4gY2VsbFdpZHRoKSB7XG4gICAgICAgICAgICBjb25zdCBuZXdDb2x1bW5XaWR0aCA9IHRleHRIZWlnaHQgKyBkZWZhdWx0U3BhY2UgKiAyO1xuICAgICAgICAgICAgY29uc3Qgb2Zmc2V0ID0gbmV3Q29sdW1uV2lkdGggLSBjZWxsV2lkdGg7XG4gICAgICAgICAgICBjb25zdCByZXN1bHQgPSB1cGRhdGVDb2x1bW5zKHRhYmxlLCB0YWJsZS5jb2x1bW5zW2NvbHVtbklkeF0uaWQsIG5ld0NvbHVtbldpZHRoLCBvZmZzZXQpO1xuICAgICAgICAgICAgcG9pbnRzID0gcmVzdWx0LnBvaW50cztcbiAgICAgICAgICAgIGNvbHVtbnMgPSByZXN1bHQuY29sdW1ucztcbiAgICAgICAgfVxuICAgIH0gZWxzZSB7XG4gICAgICAgIGNvbnN0IHJvd0lkeCA9IHRhYmxlLnJvd3MuZmluZEluZGV4KHJvdyA9PiByb3cuaWQgPT09IGNlbGwucm93SWQpO1xuICAgICAgICBjb25zdCB0YWJsZVJvdyA9IHRhYmxlLnJvd3Nbcm93SWR4XTtcbiAgICAgICAgY29uc3QgY29tcGFyZUhlaWdodCA9IHRhYmxlUm93LmhlaWdodCA/PyBNYXRoLm1heChjZWxsSGVpZ2h0LCBjZWxsLnRleHRIZWlnaHQgfHwgMCk7XG4gICAgICAgIGlmICh0ZXh0SGVpZ2h0ID4gY29tcGFyZUhlaWdodCkge1xuICAgICAgICAgICAgY29uc3QgbmV3Um93SGVpZ2h0ID0gdGV4dEhlaWdodCArIGRlZmF1bHRTcGFjZSAqIDI7XG4gICAgICAgICAgICBjb25zdCBvZmZzZXQgPSBuZXdSb3dIZWlnaHQgLSBjb21wYXJlSGVpZ2h0O1xuICAgICAgICAgICAgY29uc3QgcmVzdWx0ID0gdXBkYXRlUm93cyh0YWJsZSwgdGFibGUucm93c1tyb3dJZHhdLmlkLCBuZXdSb3dIZWlnaHQsIG9mZnNldCk7XG4gICAgICAgICAgICBwb2ludHMgPSByZXN1bHQucG9pbnRzO1xuICAgICAgICAgICAgcm93cyA9IHJlc3VsdC5yb3dzO1xuICAgICAgICB9XG4gICAgfVxuICAgIGNlbGxzW2NlbGxJbmRleF0gPSB7XG4gICAgICAgIC4uLmNlbGxzW2NlbGxJbmRleF0sXG4gICAgICAgIHRleHRIZWlnaHQ6IHRleHRIZWlnaHQsXG4gICAgICAgIHRleHRcbiAgICB9O1xuXG4gICAgVHJhbnNmb3Jtcy5zZXROb2RlKGJvYXJkLCB7IHJvd3MsIGNvbHVtbnMsIGNlbGxzLCBwb2ludHMgfSwgcGF0aCk7XG59O1xuIl19
|
|
@@ -1,36 +0,0 @@
|
|
|
1
|
-
import { Transforms } from '@plait/core';
|
|
2
|
-
import { getSelectedCells } from '../utils';
|
|
3
|
-
export const setTableFill = (board, element, fill, path) => {
|
|
4
|
-
const selectedCells = getSelectedCells(element);
|
|
5
|
-
let newCells = element.cells;
|
|
6
|
-
if (selectedCells?.length) {
|
|
7
|
-
newCells = element.cells.map(cell => {
|
|
8
|
-
if (selectedCells.map(item => item.id).includes(cell.id)) {
|
|
9
|
-
return getNewCell(cell, fill);
|
|
10
|
-
}
|
|
11
|
-
return cell;
|
|
12
|
-
});
|
|
13
|
-
}
|
|
14
|
-
else {
|
|
15
|
-
newCells = element.cells.map(cell => {
|
|
16
|
-
if (cell.text && cell.textHeight) {
|
|
17
|
-
return getNewCell(cell, fill);
|
|
18
|
-
}
|
|
19
|
-
return cell;
|
|
20
|
-
});
|
|
21
|
-
}
|
|
22
|
-
Transforms.setNode(board, { cells: newCells }, path);
|
|
23
|
-
};
|
|
24
|
-
const getNewCell = (cell, fill) => {
|
|
25
|
-
const newCell = {
|
|
26
|
-
...cell
|
|
27
|
-
};
|
|
28
|
-
if (fill) {
|
|
29
|
-
newCell.fill = fill;
|
|
30
|
-
}
|
|
31
|
-
else {
|
|
32
|
-
delete newCell.fill;
|
|
33
|
-
}
|
|
34
|
-
return newCell;
|
|
35
|
-
};
|
|
36
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9kcmF3L3NyYy90cmFuc2Zvcm1zL3RhYmxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBb0IsVUFBVSxFQUFFLE1BQU0sYUFBYSxDQUFDO0FBRTNELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLFVBQVUsQ0FBQztBQUU1QyxNQUFNLENBQUMsTUFBTSxZQUFZLEdBQUcsQ0FBQyxLQUFpQixFQUFFLE9BQXVCLEVBQUUsSUFBbUIsRUFBRSxJQUFVLEVBQUUsRUFBRTtJQUN4RyxNQUFNLGFBQWEsR0FBRyxnQkFBZ0IsQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUNoRCxJQUFJLFFBQVEsR0FBRyxPQUFPLENBQUMsS0FBSyxDQUFDO0lBQzdCLElBQUksYUFBYSxFQUFFLE1BQU0sRUFBRSxDQUFDO1FBQ3hCLFFBQVEsR0FBRyxPQUFPLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsRUFBRTtZQUNoQyxJQUFJLGFBQWEsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDO2dCQUN2RCxPQUFPLFVBQVUsQ0FBQyxJQUFJLEVBQUUsSUFBSSxDQUFDLENBQUM7WUFDbEMsQ0FBQztZQUNELE9BQU8sSUFBSSxDQUFDO1FBQ2hCLENBQUMsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztTQUFNLENBQUM7UUFDSixRQUFRLEdBQUcsT0FBTyxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLEVBQUU7WUFDaEMsSUFBSSxJQUFJLENBQUMsSUFBSSxJQUFJLElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQztnQkFDL0IsT0FBTyxVQUFVLENBQUMsSUFBSSxFQUFFLElBQUksQ0FBQyxDQUFDO1lBQ2xDLENBQUM7WUFDRCxPQUFPLElBQUksQ0FBQztRQUNoQixDQUFDLENBQUMsQ0FBQztJQUNQLENBQUM7SUFDRCxVQUFVLENBQUMsT0FBTyxDQUFDLEtBQUssRUFBRSxFQUFFLEtBQUssRUFBRSxRQUFRLEVBQUUsRUFBRSxJQUFJLENBQUMsQ0FBQztBQUN6RCxDQUFDLENBQUM7QUFFRixNQUFNLFVBQVUsR0FBRyxDQUFDLElBQW9CLEVBQUUsSUFBbUIsRUFBRSxFQUFFO0lBQzdELE1BQU0sT0FBTyxHQUFHO1FBQ1osR0FBRyxJQUFJO0tBQ1YsQ0FBQztJQUNGLElBQUksSUFBSSxFQUFFLENBQUM7UUFDUCxPQUFPLENBQUMsSUFBSSxHQUFHLElBQUksQ0FBQztJQUN4QixDQUFDO1NBQU0sQ0FBQztRQUNKLE9BQU8sT0FBTyxDQUFDLElBQUksQ0FBQztJQUN4QixDQUFDO0lBQ0QsT0FBTyxPQUFPLENBQUM7QUFDbkIsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUGF0aCwgUGxhaXRCb2FyZCwgVHJhbnNmb3JtcyB9IGZyb20gJ0BwbGFpdC9jb3JlJztcbmltcG9ydCB7IFBsYWl0QmFzZVRhYmxlLCBQbGFpdFRhYmxlQ2VsbCB9IGZyb20gJy4uL2ludGVyZmFjZXMnO1xuaW1wb3J0IHsgZ2V0U2VsZWN0ZWRDZWxscyB9IGZyb20gJy4uL3V0aWxzJztcblxuZXhwb3J0IGNvbnN0IHNldFRhYmxlRmlsbCA9IChib2FyZDogUGxhaXRCb2FyZCwgZWxlbWVudDogUGxhaXRCYXNlVGFibGUsIGZpbGw6IHN0cmluZyB8IG51bGwsIHBhdGg6IFBhdGgpID0+IHtcbiAgICBjb25zdCBzZWxlY3RlZENlbGxzID0gZ2V0U2VsZWN0ZWRDZWxscyhlbGVtZW50KTtcbiAgICBsZXQgbmV3Q2VsbHMgPSBlbGVtZW50LmNlbGxzO1xuICAgIGlmIChzZWxlY3RlZENlbGxzPy5sZW5ndGgpIHtcbiAgICAgICAgbmV3Q2VsbHMgPSBlbGVtZW50LmNlbGxzLm1hcChjZWxsID0+IHtcbiAgICAgICAgICAgIGlmIChzZWxlY3RlZENlbGxzLm1hcChpdGVtID0+IGl0ZW0uaWQpLmluY2x1ZGVzKGNlbGwuaWQpKSB7XG4gICAgICAgICAgICAgICAgcmV0dXJuIGdldE5ld0NlbGwoY2VsbCwgZmlsbCk7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICByZXR1cm4gY2VsbDtcbiAgICAgICAgfSk7XG4gICAgfSBlbHNlIHtcbiAgICAgICAgbmV3Q2VsbHMgPSBlbGVtZW50LmNlbGxzLm1hcChjZWxsID0+IHtcbiAgICAgICAgICAgIGlmIChjZWxsLnRleHQgJiYgY2VsbC50ZXh0SGVpZ2h0KSB7XG4gICAgICAgICAgICAgICAgcmV0dXJuIGdldE5ld0NlbGwoY2VsbCwgZmlsbCk7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICByZXR1cm4gY2VsbDtcbiAgICAgICAgfSk7XG4gICAgfVxuICAgIFRyYW5zZm9ybXMuc2V0Tm9kZShib2FyZCwgeyBjZWxsczogbmV3Q2VsbHMgfSwgcGF0aCk7XG59O1xuXG5jb25zdCBnZXROZXdDZWxsID0gKGNlbGw6IFBsYWl0VGFibGVDZWxsLCBmaWxsOiBzdHJpbmcgfCBudWxsKSA9PiB7XG4gICAgY29uc3QgbmV3Q2VsbCA9IHtcbiAgICAgICAgLi4uY2VsbFxuICAgIH07XG4gICAgaWYgKGZpbGwpIHtcbiAgICAgICAgbmV3Q2VsbC5maWxsID0gZmlsbDtcbiAgICB9IGVsc2Uge1xuICAgICAgICBkZWxldGUgbmV3Q2VsbC5maWxsO1xuICAgIH1cbiAgICByZXR1cm4gbmV3Q2VsbDtcbn07XG4iXX0=
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
import { PlaitBoard, Transforms } from '@plait/core';
|
|
2
|
-
import { getSelectedVectorLineElements } from '../utils';
|
|
3
|
-
export const setVectorLineShape = (board, newProperties) => {
|
|
4
|
-
const elements = getSelectedVectorLineElements(board);
|
|
5
|
-
elements.map(element => {
|
|
6
|
-
if (element.shape === newProperties.shape) {
|
|
7
|
-
return;
|
|
8
|
-
}
|
|
9
|
-
const path = PlaitBoard.findPath(board, element);
|
|
10
|
-
Transforms.setNode(board, { ...newProperties }, path);
|
|
11
|
-
});
|
|
12
|
-
};
|
|
13
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVjdG9yLWxpbmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9kcmF3L3NyYy90cmFuc2Zvcm1zL3ZlY3Rvci1saW5lLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsVUFBVSxFQUFFLE1BQU0sYUFBYSxDQUFDO0FBRXJELE9BQU8sRUFBRSw2QkFBNkIsRUFBRSxNQUFNLFVBQVUsQ0FBQztBQUV6RCxNQUFNLENBQUMsTUFBTSxrQkFBa0IsR0FBRyxDQUFDLEtBQWlCLEVBQUUsYUFBdUMsRUFBRSxFQUFFO0lBQzdGLE1BQU0sUUFBUSxHQUFHLDZCQUE2QixDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ3RELFFBQVEsQ0FBQyxHQUFHLENBQUMsT0FBTyxDQUFDLEVBQUU7UUFDbkIsSUFBSSxPQUFPLENBQUMsS0FBSyxLQUFLLGFBQWEsQ0FBQyxLQUFLLEVBQUUsQ0FBQztZQUN4QyxPQUFPO1FBQ1gsQ0FBQztRQUNELE1BQU0sSUFBSSxHQUFHLFVBQVUsQ0FBQyxRQUFRLENBQUMsS0FBSyxFQUFFLE9BQU8sQ0FBQyxDQUFDO1FBQ2pELFVBQVUsQ0FBQyxPQUFPLENBQUMsS0FBSyxFQUFFLEVBQUUsR0FBRyxhQUFhLEVBQUUsRUFBRSxJQUFJLENBQUMsQ0FBQztJQUMxRCxDQUFDLENBQUMsQ0FBQztBQUNQLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBsYWl0Qm9hcmQsIFRyYW5zZm9ybXMgfSBmcm9tICdAcGxhaXQvY29yZSc7XG5pbXBvcnQgeyBQbGFpdFZlY3RvckxpbmUgfSBmcm9tICcuLi9pbnRlcmZhY2VzJztcbmltcG9ydCB7IGdldFNlbGVjdGVkVmVjdG9yTGluZUVsZW1lbnRzIH0gZnJvbSAnLi4vdXRpbHMnO1xuXG5leHBvcnQgY29uc3Qgc2V0VmVjdG9yTGluZVNoYXBlID0gKGJvYXJkOiBQbGFpdEJvYXJkLCBuZXdQcm9wZXJ0aWVzOiBQYXJ0aWFsPFBsYWl0VmVjdG9yTGluZT4pID0+IHtcbiAgICBjb25zdCBlbGVtZW50cyA9IGdldFNlbGVjdGVkVmVjdG9yTGluZUVsZW1lbnRzKGJvYXJkKTtcbiAgICBlbGVtZW50cy5tYXAoZWxlbWVudCA9PiB7XG4gICAgICAgIGlmIChlbGVtZW50LnNoYXBlID09PSBuZXdQcm9wZXJ0aWVzLnNoYXBlKSB7XG4gICAgICAgICAgICByZXR1cm47XG4gICAgICAgIH1cbiAgICAgICAgY29uc3QgcGF0aCA9IFBsYWl0Qm9hcmQuZmluZFBhdGgoYm9hcmQsIGVsZW1lbnQpO1xuICAgICAgICBUcmFuc2Zvcm1zLnNldE5vZGUoYm9hcmQsIHsgLi4ubmV3UHJvcGVydGllcyB9LCBwYXRoKTtcbiAgICB9KTtcbn07XG4iXX0=
|
|
@@ -1,123 +0,0 @@
|
|
|
1
|
-
import { arrowPoints, createG, createPath, distanceBetweenPointAndPoint, drawLinearPath, rotate } from '@plait/core';
|
|
2
|
-
import { ArrowLineMarkerType, PlaitArrowLine } from '../../interfaces';
|
|
3
|
-
import { getExtendPoint, getUnitVectorByPointAndPoint } from '@plait/common';
|
|
4
|
-
import { getStrokeWidthByElement } from '../common';
|
|
5
|
-
const ARROW_LENGTH = 20;
|
|
6
|
-
export const drawArrowLineArrow = (element, points, options) => {
|
|
7
|
-
const arrowG = createG();
|
|
8
|
-
if (PlaitArrowLine.isSourceMark(element, ArrowLineMarkerType.none) && PlaitArrowLine.isTargetMark(element, ArrowLineMarkerType.none)) {
|
|
9
|
-
return null;
|
|
10
|
-
}
|
|
11
|
-
const strokeWidth = getStrokeWidthByElement(element);
|
|
12
|
-
const offset = (strokeWidth * strokeWidth) / 3;
|
|
13
|
-
if (points.length === 1) {
|
|
14
|
-
points = [points[0], [points[0][0] + 0.1, points[0][1]]];
|
|
15
|
-
}
|
|
16
|
-
if (!PlaitArrowLine.isSourceMark(element, ArrowLineMarkerType.none)) {
|
|
17
|
-
const source = getExtendPoint(points[0], points[1], ARROW_LENGTH + offset);
|
|
18
|
-
const sourceArrow = getArrow(element, { marker: element.source.marker, source, target: points[0], isSource: true }, options);
|
|
19
|
-
sourceArrow && arrowG.appendChild(sourceArrow);
|
|
20
|
-
}
|
|
21
|
-
if (!PlaitArrowLine.isTargetMark(element, ArrowLineMarkerType.none)) {
|
|
22
|
-
const source = getExtendPoint(points[points.length - 1], points[points.length - 2], ARROW_LENGTH + offset);
|
|
23
|
-
const arrow = getArrow(element, { marker: element.target.marker, source, target: points[points.length - 1], isSource: false }, options);
|
|
24
|
-
arrow && arrowG.appendChild(arrow);
|
|
25
|
-
}
|
|
26
|
-
return arrowG;
|
|
27
|
-
};
|
|
28
|
-
const getArrow = (element, arrowOptions, options) => {
|
|
29
|
-
const { marker, target, source, isSource } = arrowOptions;
|
|
30
|
-
let targetArrow;
|
|
31
|
-
switch (marker) {
|
|
32
|
-
case ArrowLineMarkerType.openTriangle: {
|
|
33
|
-
targetArrow = drawOpenTriangle(element, source, target, options);
|
|
34
|
-
break;
|
|
35
|
-
}
|
|
36
|
-
case ArrowLineMarkerType.solidTriangle: {
|
|
37
|
-
targetArrow = drawSolidTriangle(source, target, options);
|
|
38
|
-
break;
|
|
39
|
-
}
|
|
40
|
-
case ArrowLineMarkerType.arrow: {
|
|
41
|
-
targetArrow = drawArrow(element, source, target, options);
|
|
42
|
-
break;
|
|
43
|
-
}
|
|
44
|
-
case ArrowLineMarkerType.sharpArrow: {
|
|
45
|
-
targetArrow = drawSharpArrow(source, target, options);
|
|
46
|
-
break;
|
|
47
|
-
}
|
|
48
|
-
case ArrowLineMarkerType.oneSideUp: {
|
|
49
|
-
targetArrow = drawOneSideArrow(source, target, isSource ? 'down' : 'up', options);
|
|
50
|
-
break;
|
|
51
|
-
}
|
|
52
|
-
case ArrowLineMarkerType.oneSideDown: {
|
|
53
|
-
targetArrow = drawOneSideArrow(source, target, isSource ? 'up' : 'down', options);
|
|
54
|
-
break;
|
|
55
|
-
}
|
|
56
|
-
case ArrowLineMarkerType.hollowTriangle: {
|
|
57
|
-
targetArrow = drawHollowTriangleArrow(source, target, options);
|
|
58
|
-
break;
|
|
59
|
-
}
|
|
60
|
-
case ArrowLineMarkerType.singleSlash: {
|
|
61
|
-
targetArrow = drawSingleSlash(source, target, isSource, options);
|
|
62
|
-
break;
|
|
63
|
-
}
|
|
64
|
-
}
|
|
65
|
-
return targetArrow;
|
|
66
|
-
};
|
|
67
|
-
const drawSharpArrow = (source, target, options) => {
|
|
68
|
-
const startPoint = target;
|
|
69
|
-
const { pointLeft, pointRight } = arrowPoints(source, target, 20);
|
|
70
|
-
const g = createG();
|
|
71
|
-
const path = createPath();
|
|
72
|
-
let polylinePath = `M${pointRight[0]},${pointRight[1]}A25,25,20,0,1,${pointLeft[0]},${pointLeft[1]}L${startPoint[0]},${startPoint[1]}Z`;
|
|
73
|
-
path.setAttribute('d', polylinePath);
|
|
74
|
-
path.setAttribute('stroke', `${options?.stroke}`);
|
|
75
|
-
path.setAttribute('stroke-width', `${options?.strokeWidth}`);
|
|
76
|
-
path.setAttribute('fill', `${options?.stroke}`);
|
|
77
|
-
g.appendChild(path);
|
|
78
|
-
return g;
|
|
79
|
-
};
|
|
80
|
-
const drawArrow = (element, source, target, options) => {
|
|
81
|
-
const unitVector = getUnitVectorByPointAndPoint(source, target);
|
|
82
|
-
const strokeWidth = getStrokeWidthByElement(element);
|
|
83
|
-
const endPoint = [target[0] + (strokeWidth * unitVector[0]) / 2, target[1] + (strokeWidth * unitVector[1]) / 2];
|
|
84
|
-
const distance = distanceBetweenPointAndPoint(...source, ...endPoint);
|
|
85
|
-
const middlePoint = [
|
|
86
|
-
endPoint[0] - (((distance * 3) / 5 + strokeWidth) / 2) * unitVector[0],
|
|
87
|
-
endPoint[1] - (((distance * 3) / 5 + strokeWidth) / 2) * unitVector[1]
|
|
88
|
-
];
|
|
89
|
-
const { pointLeft, pointRight } = arrowPoints(source, endPoint, 30);
|
|
90
|
-
const arrowG = drawLinearPath([pointLeft, endPoint, pointRight, middlePoint], { ...options, fill: options.stroke }, true);
|
|
91
|
-
const path = arrowG.querySelector('path');
|
|
92
|
-
path.setAttribute('stroke-linejoin', 'round');
|
|
93
|
-
return arrowG;
|
|
94
|
-
};
|
|
95
|
-
const drawSolidTriangle = (source, target, options) => {
|
|
96
|
-
const endPoint = target;
|
|
97
|
-
const { pointLeft, pointRight } = arrowPoints(source, endPoint, 30);
|
|
98
|
-
return drawLinearPath([pointLeft, endPoint, pointRight], { ...options, fill: options.stroke }, true);
|
|
99
|
-
};
|
|
100
|
-
const drawOpenTriangle = (element, source, target, options) => {
|
|
101
|
-
const unitVector = getUnitVectorByPointAndPoint(source, target);
|
|
102
|
-
const strokeWidth = getStrokeWidthByElement(element);
|
|
103
|
-
const endPoint = [target[0] + (strokeWidth * unitVector[0]) / 2, target[1] + (strokeWidth * unitVector[1]) / 2];
|
|
104
|
-
const { pointLeft, pointRight } = arrowPoints(source, endPoint, 40);
|
|
105
|
-
return drawLinearPath([pointLeft, endPoint, pointRight], options);
|
|
106
|
-
};
|
|
107
|
-
const drawOneSideArrow = (source, target, side, options) => {
|
|
108
|
-
const { pointLeft, pointRight } = arrowPoints(source, target, 40);
|
|
109
|
-
return drawLinearPath([side === 'up' ? pointRight : pointLeft, target], options);
|
|
110
|
-
};
|
|
111
|
-
const drawSingleSlash = (source, target, isSource, options) => {
|
|
112
|
-
const length = distanceBetweenPointAndPoint(...source, ...target);
|
|
113
|
-
const middlePoint = getExtendPoint(target, source, length / 2);
|
|
114
|
-
const angle = isSource ? 120 : 60;
|
|
115
|
-
const start = rotate(...source, ...middlePoint, (angle * Math.PI) / 180);
|
|
116
|
-
const end = rotate(...target, ...middlePoint, (angle * Math.PI) / 180);
|
|
117
|
-
return drawLinearPath([start, end], options);
|
|
118
|
-
};
|
|
119
|
-
const drawHollowTriangleArrow = (source, target, options) => {
|
|
120
|
-
const { pointLeft, pointRight } = arrowPoints(source, target, 30);
|
|
121
|
-
return drawLinearPath([pointLeft, pointRight, target], { ...options, fill: 'white' }, true);
|
|
122
|
-
};
|
|
123
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"arrow-line-arrow.js","sourceRoot":"","sources":["../../../../../packages/draw/src/utils/arrow-line/arrow-line-arrow.ts"],"names":[],"mappings":"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","sourcesContent":["import { Point, arrowPoints, createG, createPath, distanceBetweenPointAndPoint, drawLinearPath, rotate } from '@plait/core';\nimport { ArrowLineMarkerType, PlaitArrowLine } from '../../interfaces';\nimport { Options } from 'roughjs/bin/core';\nimport { getExtendPoint, getUnitVectorByPointAndPoint } from '@plait/common';\nimport { getStrokeWidthByElement } from '../common';\n\ninterface ArrowOptions {\n    marker: ArrowLineMarkerType;\n    source: Point;\n    target: Point;\n    isSource: boolean;\n}\nconst ARROW_LENGTH = 20;\n\nexport const drawArrowLineArrow = (element: PlaitArrowLine, points: Point[], options: Options) => {\n    const arrowG = createG();\n    if (PlaitArrowLine.isSourceMark(element, ArrowLineMarkerType.none) && PlaitArrowLine.isTargetMark(element, ArrowLineMarkerType.none)) {\n        return null;\n    }\n    const strokeWidth = getStrokeWidthByElement(element);\n    const offset = (strokeWidth * strokeWidth) / 3;\n    if (points.length === 1) {\n        points = [points[0], [points[0][0] + 0.1, points[0][1]]];\n    }\n\n    if (!PlaitArrowLine.isSourceMark(element, ArrowLineMarkerType.none)) {\n        const source = getExtendPoint(points[0], points[1], ARROW_LENGTH + offset);\n        const sourceArrow = getArrow(element, { marker: element.source.marker, source, target: points[0], isSource: true }, options);\n        sourceArrow && arrowG.appendChild(sourceArrow);\n    }\n    if (!PlaitArrowLine.isTargetMark(element, ArrowLineMarkerType.none)) {\n        const source = getExtendPoint(points[points.length - 1], points[points.length - 2], ARROW_LENGTH + offset);\n        const arrow = getArrow(\n            element,\n            { marker: element.target.marker, source, target: points[points.length - 1], isSource: false },\n            options\n        );\n\n        arrow && arrowG.appendChild(arrow);\n    }\n    return arrowG;\n};\n\nconst getArrow = (element: PlaitArrowLine, arrowOptions: ArrowOptions, options: Options) => {\n    const { marker, target, source, isSource } = arrowOptions;\n    let targetArrow;\n    switch (marker) {\n        case ArrowLineMarkerType.openTriangle: {\n            targetArrow = drawOpenTriangle(element, source, target, options);\n            break;\n        }\n        case ArrowLineMarkerType.solidTriangle: {\n            targetArrow = drawSolidTriangle(source, target, options);\n            break;\n        }\n        case ArrowLineMarkerType.arrow: {\n            targetArrow = drawArrow(element, source, target, options);\n            break;\n        }\n        case ArrowLineMarkerType.sharpArrow: {\n            targetArrow = drawSharpArrow(source, target, options);\n            break;\n        }\n        case ArrowLineMarkerType.oneSideUp: {\n            targetArrow = drawOneSideArrow(source, target, isSource ? 'down' : 'up', options);\n            break;\n        }\n        case ArrowLineMarkerType.oneSideDown: {\n            targetArrow = drawOneSideArrow(source, target, isSource ? 'up' : 'down', options);\n            break;\n        }\n        case ArrowLineMarkerType.hollowTriangle: {\n            targetArrow = drawHollowTriangleArrow(source, target, options);\n            break;\n        }\n        case ArrowLineMarkerType.singleSlash: {\n            targetArrow = drawSingleSlash(source, target, isSource, options);\n            break;\n        }\n    }\n    return targetArrow;\n};\n\nconst drawSharpArrow = (source: Point, target: Point, options: Options) => {\n    const startPoint: Point = target;\n    const { pointLeft, pointRight } = arrowPoints(source, target, 20);\n    const g = createG();\n    const path = createPath();\n    let polylinePath = `M${pointRight[0]},${pointRight[1]}A25,25,20,0,1,${pointLeft[0]},${pointLeft[1]}L${startPoint[0]},${startPoint[1]}Z`;\n    path.setAttribute('d', polylinePath);\n    path.setAttribute('stroke', `${options?.stroke}`);\n    path.setAttribute('stroke-width', `${options?.strokeWidth}`);\n    path.setAttribute('fill', `${options?.stroke}`);\n    g.appendChild(path);\n    return g;\n};\n\nconst drawArrow = (element: PlaitArrowLine, source: Point, target: Point, options: Options) => {\n    const unitVector = getUnitVectorByPointAndPoint(source, target);\n    const strokeWidth = getStrokeWidthByElement(element);\n    const endPoint: Point = [target[0] + (strokeWidth * unitVector[0]) / 2, target[1] + (strokeWidth * unitVector[1]) / 2];\n    const distance = distanceBetweenPointAndPoint(...source, ...endPoint);\n    const middlePoint: Point = [\n        endPoint[0] - (((distance * 3) / 5 + strokeWidth) / 2) * unitVector[0],\n        endPoint[1] - (((distance * 3) / 5 + strokeWidth) / 2) * unitVector[1]\n    ];\n    const { pointLeft, pointRight } = arrowPoints(source, endPoint, 30);\n    const arrowG = drawLinearPath([pointLeft, endPoint, pointRight, middlePoint], { ...options, fill: options.stroke }, true);\n    const path = arrowG.querySelector('path');\n    path!.setAttribute('stroke-linejoin', 'round');\n    return arrowG;\n};\n\nconst drawSolidTriangle = (source: Point, target: Point, options: Options) => {\n    const endPoint: Point = target;\n    const { pointLeft, pointRight } = arrowPoints(source, endPoint, 30);\n    return drawLinearPath([pointLeft, endPoint, pointRight], { ...options, fill: options.stroke }, true);\n};\n\nconst drawOpenTriangle = (element: PlaitArrowLine, source: Point, target: Point, options: Options) => {\n    const unitVector = getUnitVectorByPointAndPoint(source, target);\n    const strokeWidth = getStrokeWidthByElement(element);\n    const endPoint: Point = [target[0] + (strokeWidth * unitVector[0]) / 2, target[1] + (strokeWidth * unitVector[1]) / 2];\n    const { pointLeft, pointRight } = arrowPoints(source, endPoint, 40);\n    return drawLinearPath([pointLeft, endPoint, pointRight], options);\n};\n\nconst drawOneSideArrow = (source: Point, target: Point, side: string, options: Options) => {\n    const { pointLeft, pointRight } = arrowPoints(source, target, 40);\n    return drawLinearPath([side === 'up' ? pointRight : pointLeft, target], options);\n};\n\nconst drawSingleSlash = (source: Point, target: Point, isSource: boolean, options: Options) => {\n    const length = distanceBetweenPointAndPoint(...source, ...target);\n    const middlePoint = getExtendPoint(target, source, length / 2);\n    const angle = isSource ? 120 : 60;\n    const start = rotate(...source, ...middlePoint, (angle * Math.PI) / 180) as Point;\n    const end = rotate(...target, ...middlePoint, (angle * Math.PI) / 180) as Point;\n    return drawLinearPath([start, end], options);\n};\n\nconst drawHollowTriangleArrow = (source: Point, target: Point, options: Options) => {\n    const { pointLeft, pointRight } = arrowPoints(source, target, 30);\n    return drawLinearPath([pointLeft, pointRight, target], { ...options, fill: 'white' }, true);\n};\n"]}
|