@plait/draw 0.57.0 → 0.59.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/constants/draw.d.ts +1 -0
- package/constants/geometry.d.ts +79 -2
- package/constants/index.d.ts +1 -0
- package/constants/pointer.d.ts +4 -2
- package/engines/index.d.ts +3 -3
- package/engines/table/table.d.ts +15 -1
- package/engines/uml/actor.d.ts +2 -0
- package/engines/uml/combined-fragment.d.ts +3 -0
- package/engines/uml/container.d.ts +2 -0
- package/engines/uml/package.d.ts +3 -0
- package/esm2022/constants/draw.mjs +2 -0
- package/esm2022/constants/geometry.mjs +70 -4
- package/esm2022/constants/index.mjs +2 -1
- package/esm2022/constants/pointer.mjs +9 -3
- package/esm2022/engines/basic-shapes/cloud.mjs +1 -1
- package/esm2022/engines/basic-shapes/comment.mjs +1 -1
- package/esm2022/engines/basic-shapes/diamond.mjs +2 -2
- package/esm2022/engines/basic-shapes/parallelogram.mjs +2 -2
- package/esm2022/engines/basic-shapes/pentagon.mjs +1 -1
- package/esm2022/engines/basic-shapes/round-comment.mjs +2 -2
- package/esm2022/engines/basic-shapes/star.mjs +1 -1
- package/esm2022/engines/basic-shapes/trapezoid.mjs +2 -2
- package/esm2022/engines/basic-shapes/triangle.mjs +2 -2
- package/esm2022/engines/flowchart/database.mjs +2 -2
- package/esm2022/engines/flowchart/display.mjs +1 -1
- package/esm2022/engines/flowchart/document.mjs +1 -1
- package/esm2022/engines/flowchart/hard-disk.mjs +2 -2
- package/esm2022/engines/flowchart/internal-storage.mjs +2 -2
- package/esm2022/engines/flowchart/manual-input.mjs +2 -2
- package/esm2022/engines/flowchart/manual-loop.mjs +2 -2
- package/esm2022/engines/flowchart/merge.mjs +1 -1
- package/esm2022/engines/flowchart/multi-document.mjs +1 -1
- package/esm2022/engines/flowchart/note-curly-left.mjs +2 -2
- package/esm2022/engines/flowchart/note-curly-right.mjs +2 -2
- package/esm2022/engines/flowchart/note-square.mjs +1 -1
- package/esm2022/engines/flowchart/off-page.mjs +2 -2
- package/esm2022/engines/flowchart/or.mjs +1 -8
- package/esm2022/engines/flowchart/predefined-process.mjs +1 -1
- package/esm2022/engines/flowchart/summing-junction.mjs +1 -8
- package/esm2022/engines/index.mjs +14 -5
- package/esm2022/engines/table/table.mjs +58 -10
- package/esm2022/engines/uml/actor.mjs +102 -0
- package/esm2022/engines/uml/combined-fragment.mjs +66 -0
- package/esm2022/engines/uml/container.mjs +44 -0
- package/esm2022/engines/uml/package.mjs +75 -0
- package/esm2022/generators/geometry-shape.generator.mjs +3 -3
- package/esm2022/generators/index.mjs +7 -0
- package/esm2022/generators/line-active.generator.mjs +3 -3
- package/esm2022/generators/line-auto-complete.generator.mjs +1 -1
- package/esm2022/generators/single-text.generator.mjs +16 -0
- package/esm2022/generators/table.generator.mjs +20 -0
- package/esm2022/generators/text.generator.mjs +126 -0
- package/esm2022/geometry.component.mjs +63 -76
- package/esm2022/image.component.mjs +8 -25
- package/esm2022/interfaces/element.mjs +2 -1
- package/esm2022/interfaces/engine.mjs +2 -0
- package/esm2022/interfaces/geometry.mjs +14 -1
- package/esm2022/interfaces/image.mjs +1 -1
- package/esm2022/interfaces/index.mjs +27 -4
- package/esm2022/interfaces/line.mjs +1 -1
- package/esm2022/interfaces/table.mjs +9 -2
- package/esm2022/line.component.mjs +8 -25
- package/esm2022/plugins/with-draw-fragment.mjs +3 -1
- package/esm2022/plugins/with-draw-hotkey.mjs +12 -3
- package/esm2022/plugins/with-draw-resize.mjs +1 -1
- package/esm2022/plugins/with-draw.mjs +6 -2
- package/esm2022/plugins/with-geometry-create.mjs +2 -1
- package/esm2022/plugins/with-geometry-resize.mjs +3 -2
- package/esm2022/plugins/with-line-auto-complete-reaction.mjs +2 -2
- package/esm2022/plugins/with-line-bound-reaction.mjs +3 -4
- package/esm2022/plugins/with-line-create.mjs +3 -3
- package/esm2022/plugins/with-line-resize.mjs +3 -3
- package/esm2022/plugins/with-swimlane-create.mjs +132 -0
- package/esm2022/plugins/with-swimlane.mjs +21 -0
- package/esm2022/plugins/with-table-resize.mjs +130 -0
- package/esm2022/plugins/with-table.mjs +53 -7
- package/esm2022/public-api.mjs +2 -1
- package/esm2022/table.component.mjs +117 -24
- package/esm2022/transforms/geometry-text.mjs +6 -3
- package/esm2022/transforms/geometry.mjs +3 -2
- package/esm2022/transforms/index.mjs +11 -2
- package/esm2022/transforms/multi-text-geometry-text.mjs +15 -0
- package/esm2022/transforms/swimlane.mjs +97 -0
- package/esm2022/transforms/table-text.mjs +44 -0
- package/esm2022/utils/clipboard.mjs +15 -2
- package/esm2022/utils/common.mjs +159 -0
- package/esm2022/utils/geometry.mjs +55 -63
- package/esm2022/utils/hit.mjs +47 -18
- package/esm2022/utils/index.mjs +4 -1
- package/esm2022/utils/line/elbow.mjs +2 -2
- package/esm2022/utils/line/line-arrow.mjs +2 -2
- package/esm2022/utils/line/line-basic.mjs +4 -4
- package/esm2022/utils/line/line-common.mjs +2 -2
- package/esm2022/utils/memorize.mjs +7 -1
- package/esm2022/utils/multi-text-geometry.mjs +61 -0
- package/esm2022/utils/position/geometry.mjs +2 -40
- package/esm2022/utils/selected.mjs +14 -1
- package/esm2022/utils/shape.mjs +5 -2
- package/esm2022/utils/snap-resizing.mjs +7 -7
- package/esm2022/utils/style/stroke.mjs +4 -10
- package/esm2022/utils/swimlane.mjs +120 -0
- package/esm2022/utils/table.mjs +124 -0
- package/fesm2022/plait-draw.mjs +6376 -4834
- package/fesm2022/plait-draw.mjs.map +1 -1
- package/generators/index.d.ts +6 -0
- package/generators/line-auto-complete.generator.d.ts +2 -2
- package/generators/single-text.generator.d.ts +11 -0
- package/generators/table.generator.d.ts +9 -0
- package/generators/text.generator.d.ts +42 -0
- package/geometry.component.d.ts +11 -17
- package/image.component.d.ts +5 -11
- package/interfaces/element.d.ts +2 -1
- package/interfaces/engine.d.ts +16 -0
- package/interfaces/geometry.d.ts +23 -18
- package/interfaces/image.d.ts +4 -2
- package/interfaces/index.d.ts +12 -3
- package/interfaces/line.d.ts +4 -5
- package/interfaces/table.d.ts +14 -1
- package/line.component.d.ts +4 -10
- package/package.json +1 -1
- package/plugins/with-swimlane-create.d.ts +8 -0
- package/plugins/with-swimlane.d.ts +2 -0
- package/plugins/with-table-resize.d.ts +2 -0
- package/plugins/with-table.d.ts +5 -1
- package/public-api.d.ts +1 -0
- package/table.component.d.ts +17 -11
- package/transforms/geometry.d.ts +2 -2
- package/transforms/index.d.ts +8 -2
- package/transforms/multi-text-geometry-text.d.ts +4 -0
- package/transforms/swimlane.d.ts +6 -0
- package/transforms/table-text.d.ts +4 -0
- package/utils/clipboard.d.ts +2 -0
- package/utils/common.d.ts +32 -0
- package/utils/geometry.d.ts +36 -15
- package/utils/hit.d.ts +4 -2
- package/utils/index.d.ts +3 -0
- package/utils/line/line-common.d.ts +3 -3
- package/utils/memorize.d.ts +3 -1
- package/utils/multi-text-geometry.d.ts +14 -0
- package/utils/position/geometry.d.ts +8 -21
- package/utils/selected.d.ts +4 -0
- package/utils/shape.d.ts +2 -2
- package/utils/style/stroke.d.ts +4 -5
- package/utils/swimlane.d.ts +52 -0
- package/utils/table.d.ts +26 -0
|
@@ -0,0 +1,120 @@
|
|
|
1
|
+
import { idCreator, RectangleClient } from '@plait/core';
|
|
2
|
+
import { DEFAULT_TEXT_HEIGHT, DefaultSwimlanePropertyMap } from '../constants';
|
|
3
|
+
import { PlaitDrawElement, SwimlaneSymbols } from '../interfaces';
|
|
4
|
+
export function buildSwimlaneTable(element) {
|
|
5
|
+
const swimlaneElement = { ...element };
|
|
6
|
+
if (PlaitDrawElement.isHorizontalSwimlane(element)) {
|
|
7
|
+
swimlaneElement.cells = element.cells.map((item, index) => {
|
|
8
|
+
if (index === 0) {
|
|
9
|
+
item = {
|
|
10
|
+
...element.cells[0],
|
|
11
|
+
rowspan: element.rows.length
|
|
12
|
+
};
|
|
13
|
+
}
|
|
14
|
+
if (item.text && item.textHeight && !item.text.direction) {
|
|
15
|
+
item.text.direction = 'vertical';
|
|
16
|
+
}
|
|
17
|
+
return item;
|
|
18
|
+
});
|
|
19
|
+
return swimlaneElement;
|
|
20
|
+
}
|
|
21
|
+
swimlaneElement.cells = [
|
|
22
|
+
{
|
|
23
|
+
...element.cells[0],
|
|
24
|
+
colspan: element.columns.length
|
|
25
|
+
},
|
|
26
|
+
...element.cells.slice(1, element.cells.length)
|
|
27
|
+
];
|
|
28
|
+
return swimlaneElement;
|
|
29
|
+
}
|
|
30
|
+
export const getDefaultSWimlanePoints = (pointer, centerPoint) => {
|
|
31
|
+
const property = DefaultSwimlanePropertyMap[pointer];
|
|
32
|
+
return RectangleClient.getPoints(RectangleClient.getRectangleByCenterPoint(centerPoint, property.width, property.height));
|
|
33
|
+
};
|
|
34
|
+
export const createDefaultSwimlane = (shape, points) => {
|
|
35
|
+
const rows = createDefaultRowsOrColumns(shape, 'row');
|
|
36
|
+
const columns = createDefaultRowsOrColumns(shape, 'column');
|
|
37
|
+
const swimlane = {
|
|
38
|
+
id: idCreator(),
|
|
39
|
+
type: 'table',
|
|
40
|
+
shape,
|
|
41
|
+
points,
|
|
42
|
+
rows,
|
|
43
|
+
columns,
|
|
44
|
+
cells: createDefaultCells(shape, rows, columns)
|
|
45
|
+
};
|
|
46
|
+
return buildSwimlaneTable(swimlane);
|
|
47
|
+
};
|
|
48
|
+
export const createDefaultRowsOrColumns = (shape, type) => {
|
|
49
|
+
let data = new Array(3).fill('').map(item => {
|
|
50
|
+
return { id: idCreator() };
|
|
51
|
+
});
|
|
52
|
+
if (type === 'row' && shape === SwimlaneSymbols.swimlaneVertical) {
|
|
53
|
+
data = data.map((item, index) => {
|
|
54
|
+
if (index === 0 || index === 1) {
|
|
55
|
+
return {
|
|
56
|
+
...item,
|
|
57
|
+
height: 30
|
|
58
|
+
};
|
|
59
|
+
}
|
|
60
|
+
return item;
|
|
61
|
+
});
|
|
62
|
+
}
|
|
63
|
+
if (type === 'column' && shape === SwimlaneSymbols.swimlaneHorizontal) {
|
|
64
|
+
data = data.map((item, index) => {
|
|
65
|
+
if (index === 0 || index === 1) {
|
|
66
|
+
return {
|
|
67
|
+
...item,
|
|
68
|
+
width: 30
|
|
69
|
+
};
|
|
70
|
+
}
|
|
71
|
+
return item;
|
|
72
|
+
});
|
|
73
|
+
}
|
|
74
|
+
return data;
|
|
75
|
+
};
|
|
76
|
+
export const createDefaultCells = (shape, rows, columns) => {
|
|
77
|
+
return new Array(7).fill('').map((item, index) => {
|
|
78
|
+
if (index === 0) {
|
|
79
|
+
item = {
|
|
80
|
+
id: idCreator(),
|
|
81
|
+
rowId: rows[0].id,
|
|
82
|
+
columnId: columns[0].id,
|
|
83
|
+
textHeight: DEFAULT_TEXT_HEIGHT,
|
|
84
|
+
text: {
|
|
85
|
+
children: [
|
|
86
|
+
{
|
|
87
|
+
text: 'New Swimlane'
|
|
88
|
+
}
|
|
89
|
+
],
|
|
90
|
+
align: 'center'
|
|
91
|
+
}
|
|
92
|
+
};
|
|
93
|
+
}
|
|
94
|
+
if ([1, 2, 3].includes(index)) {
|
|
95
|
+
item = {
|
|
96
|
+
id: idCreator(),
|
|
97
|
+
rowId: shape === SwimlaneSymbols.swimlaneVertical ? rows[1].id : rows[index - 1].id,
|
|
98
|
+
columnId: shape === SwimlaneSymbols.swimlaneVertical ? columns[index - 1].id : columns[1].id,
|
|
99
|
+
textHeight: DEFAULT_TEXT_HEIGHT,
|
|
100
|
+
text: {
|
|
101
|
+
children: [
|
|
102
|
+
{
|
|
103
|
+
text: 'Lane'
|
|
104
|
+
}
|
|
105
|
+
],
|
|
106
|
+
align: 'center'
|
|
107
|
+
}
|
|
108
|
+
};
|
|
109
|
+
}
|
|
110
|
+
if ([4, 5, 6].includes(index)) {
|
|
111
|
+
item = {
|
|
112
|
+
id: idCreator(),
|
|
113
|
+
rowId: shape === SwimlaneSymbols.swimlaneVertical ? rows[2].id : rows[index - 4].id,
|
|
114
|
+
columnId: shape === SwimlaneSymbols.swimlaneVertical ? columns[index - 4].id : columns[2].id
|
|
115
|
+
};
|
|
116
|
+
}
|
|
117
|
+
return item;
|
|
118
|
+
});
|
|
119
|
+
};
|
|
120
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"swimlane.js","sourceRoot":"","sources":["../../../../packages/draw/src/utils/swimlane.ts"],"names":[],"mappings":"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","sourcesContent":["import { idCreator, Point, RectangleClient } from '@plait/core';\nimport { DEFAULT_TEXT_HEIGHT, DrawPointerType, DefaultSwimlanePropertyMap } from '../constants';\nimport { PlaitDrawElement, PlaitSwimlane, SwimlaneSymbols } from '../interfaces';\n\nexport function buildSwimlaneTable(element: PlaitSwimlane) {\n    const swimlaneElement = { ...element };\n    if (PlaitDrawElement.isHorizontalSwimlane(element)) {\n        swimlaneElement.cells = element.cells.map((item, index) => {\n            if (index === 0) {\n                item = {\n                    ...element.cells[0],\n                    rowspan: element.rows.length\n                };\n            }\n            if (item.text && item.textHeight && !item.text.direction) {\n                item.text.direction = 'vertical';\n            }\n            return item;\n        });\n        return swimlaneElement;\n    }\n    swimlaneElement.cells = [\n        {\n            ...element.cells[0],\n            colspan: element.columns.length\n        },\n        ...element.cells.slice(1, element.cells.length)\n    ];\n    return swimlaneElement;\n}\n\nexport const getDefaultSWimlanePoints = (pointer: DrawPointerType, centerPoint: Point) => {\n    const property = DefaultSwimlanePropertyMap[pointer];\n    return RectangleClient.getPoints(RectangleClient.getRectangleByCenterPoint(centerPoint, property.width, property.height));\n};\n\nexport const createDefaultSwimlane = (shape: SwimlaneSymbols, points: [Point, Point]) => {\n    const rows = createDefaultRowsOrColumns(shape, 'row');\n    const columns = createDefaultRowsOrColumns(shape, 'column');\n    const swimlane = {\n        id: idCreator(),\n        type: 'table',\n        shape,\n        points,\n        rows,\n        columns,\n        cells: createDefaultCells(shape, rows, columns)\n    } as PlaitSwimlane;\n    return buildSwimlaneTable(swimlane);\n};\n\nexport const createDefaultRowsOrColumns = (shape: SwimlaneSymbols, type: 'row' | 'column') => {\n    let data = new Array(3).fill('').map(item => {\n        return { id: idCreator() };\n    });\n    if (type === 'row' && shape === SwimlaneSymbols.swimlaneVertical) {\n        data = data.map((item, index) => {\n            if (index === 0 || index === 1) {\n                return {\n                    ...item,\n                    height: 30\n                };\n            }\n            return item;\n        });\n    }\n    if (type === 'column' && shape === SwimlaneSymbols.swimlaneHorizontal) {\n        data = data.map((item, index) => {\n            if (index === 0 || index === 1) {\n                return {\n                    ...item,\n                    width: 30\n                };\n            }\n            return item;\n        });\n    }\n    return data;\n};\n\nexport const createDefaultCells = (\n    shape: SwimlaneSymbols,\n    rows: { id: string; height?: number }[],\n    columns: { id: string; width?: number }[]\n) => {\n    return new Array(7).fill('').map((item, index) => {\n        if (index === 0) {\n            item = {\n                id: idCreator(),\n                rowId: rows[0].id,\n                columnId: columns[0].id,\n                textHeight: DEFAULT_TEXT_HEIGHT,\n                text: {\n                    children: [\n                        {\n                            text: 'New Swimlane'\n                        }\n                    ],\n                    align: 'center'\n                }\n            };\n        }\n        if ([1, 2, 3].includes(index)) {\n            item = {\n                id: idCreator(),\n                rowId: shape === SwimlaneSymbols.swimlaneVertical ? rows[1].id : rows[index - 1].id,\n                columnId: shape === SwimlaneSymbols.swimlaneVertical ? columns[index - 1].id : columns[1].id,\n                textHeight: DEFAULT_TEXT_HEIGHT,\n                text: {\n                    children: [\n                        {\n                            text: 'Lane'\n                        }\n                    ],\n                    align: 'center'\n                }\n            };\n        }\n        if ([4, 5, 6].includes(index)) {\n            item = {\n                id: idCreator(),\n                rowId: shape === SwimlaneSymbols.swimlaneVertical ? rows[2].id : rows[index - 4].id,\n                columnId: shape === SwimlaneSymbols.swimlaneVertical ? columns[index - 4].id : columns[2].id\n            };\n        }\n        return item;\n    });\n};\n"]}
|
|
@@ -0,0 +1,124 @@
|
|
|
1
|
+
import { idCreator, RectangleClient } from '@plait/core';
|
|
2
|
+
import { getTextManage } from '../generators/text.generator';
|
|
3
|
+
export function getCellsWithPoints(board, element) {
|
|
4
|
+
const table = board.buildTable(element);
|
|
5
|
+
const rectangle = RectangleClient.getRectangleByPoints(table.points);
|
|
6
|
+
const columnsCount = table.columns.length;
|
|
7
|
+
const rowsCount = table.rows.length;
|
|
8
|
+
const cellWidths = calculateCellsSize(table.columns, rectangle.width, columnsCount, true);
|
|
9
|
+
const cellHeights = calculateCellsSize(table.rows, rectangle.height, rowsCount, false);
|
|
10
|
+
const cells = table.cells.map(cell => {
|
|
11
|
+
const rowIdx = table.rows.findIndex(row => row.id === cell.rowId);
|
|
12
|
+
const columnIdx = table.columns.findIndex(column => column.id === cell.columnId);
|
|
13
|
+
let cellTopLeftX = rectangle.x;
|
|
14
|
+
for (let i = 0; i < columnIdx; i++) {
|
|
15
|
+
cellTopLeftX += cellWidths[i];
|
|
16
|
+
}
|
|
17
|
+
let cellTopLeftY = rectangle.y;
|
|
18
|
+
for (let i = 0; i < rowIdx; i++) {
|
|
19
|
+
cellTopLeftY += cellHeights[i];
|
|
20
|
+
}
|
|
21
|
+
const cellWidth = calculateCellSize(cell, cellWidths, columnIdx, true);
|
|
22
|
+
const cellBottomRightX = cellTopLeftX + cellWidth;
|
|
23
|
+
const cellHeight = calculateCellSize(cell, cellHeights, rowIdx, false);
|
|
24
|
+
const cellBottomRightY = cellTopLeftY + cellHeight;
|
|
25
|
+
return {
|
|
26
|
+
...cell,
|
|
27
|
+
points: [
|
|
28
|
+
[cellTopLeftX, cellTopLeftY],
|
|
29
|
+
[cellBottomRightX, cellBottomRightY]
|
|
30
|
+
]
|
|
31
|
+
};
|
|
32
|
+
});
|
|
33
|
+
return cells;
|
|
34
|
+
}
|
|
35
|
+
export function getCellWithPoints(board, table, cellId) {
|
|
36
|
+
const cells = getCellsWithPoints(board, table);
|
|
37
|
+
const cellIndex = table.cells.findIndex(item => item.id === cellId);
|
|
38
|
+
return cells[cellIndex];
|
|
39
|
+
}
|
|
40
|
+
function calculateCellsSize(items, tableSize, count, isWidth) {
|
|
41
|
+
const cellSizes = [];
|
|
42
|
+
const sizeType = isWidth ? 'width' : 'height';
|
|
43
|
+
// The remaining size of the table excluding cells with already set sizes.
|
|
44
|
+
let totalSizeRemaining = tableSize;
|
|
45
|
+
items.forEach((item, index) => {
|
|
46
|
+
if (item[sizeType]) {
|
|
47
|
+
cellSizes[index] = item[sizeType];
|
|
48
|
+
totalSizeRemaining -= item[sizeType];
|
|
49
|
+
}
|
|
50
|
+
});
|
|
51
|
+
// Divide the remaining size equally.
|
|
52
|
+
const remainingItemCount = count - cellSizes.filter(item => !!item).length;
|
|
53
|
+
const remainingCellSize = remainingItemCount > 0 ? totalSizeRemaining / remainingItemCount : 0;
|
|
54
|
+
for (let i = 0; i < count; i++) {
|
|
55
|
+
if (!cellSizes[i]) {
|
|
56
|
+
cellSizes[i] = remainingCellSize;
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
return cellSizes;
|
|
60
|
+
}
|
|
61
|
+
function calculateCellSize(cell, sizes, index, isWidth) {
|
|
62
|
+
const span = isWidth ? cell.colspan || 1 : cell.rowspan || 1;
|
|
63
|
+
let size = 0;
|
|
64
|
+
for (let i = 0; i < span; i++) {
|
|
65
|
+
const cellIndex = index + i;
|
|
66
|
+
size += sizes[cellIndex];
|
|
67
|
+
}
|
|
68
|
+
return size;
|
|
69
|
+
}
|
|
70
|
+
export function getHitCell(board, element, point) {
|
|
71
|
+
const table = board.buildTable(element);
|
|
72
|
+
const cells = getCellsWithPoints(board, table);
|
|
73
|
+
const rectangle = RectangleClient.getRectangleByPoints([point, point]);
|
|
74
|
+
const cell = cells.find(item => {
|
|
75
|
+
const cellRectangle = RectangleClient.getRectangleByPoints(item.points);
|
|
76
|
+
return RectangleClient.isHit(rectangle, cellRectangle);
|
|
77
|
+
});
|
|
78
|
+
if (cell) {
|
|
79
|
+
return table.cells.find(item => item.id === cell.id);
|
|
80
|
+
}
|
|
81
|
+
return null;
|
|
82
|
+
}
|
|
83
|
+
export function editCell(cell) {
|
|
84
|
+
const textManage = getTextManageByCell(cell);
|
|
85
|
+
textManage && textManage.edit();
|
|
86
|
+
}
|
|
87
|
+
export function getTextManageByCell(cell) {
|
|
88
|
+
return getTextManage(cell.id);
|
|
89
|
+
}
|
|
90
|
+
export const updateColumns = (table, columnId, width, offset) => {
|
|
91
|
+
const columns = table.columns.map(item => (item.id === columnId ? { ...item, width } : item));
|
|
92
|
+
const points = [table.points[0], [table.points[1][0] + offset, table.points[1][1]]];
|
|
93
|
+
return { columns, points };
|
|
94
|
+
};
|
|
95
|
+
export const updateRows = (table, rowId, height, offset) => {
|
|
96
|
+
const rows = table.rows.map(item => (item.id === rowId ? { ...item, height } : item));
|
|
97
|
+
const points = [table.points[0], [table.points[1][0], table.points[1][1] + offset]];
|
|
98
|
+
return { rows, points };
|
|
99
|
+
};
|
|
100
|
+
export function updateCellIdsByRowOrColumn(cells, oldId, newId, type) {
|
|
101
|
+
const id = `${type}Id`;
|
|
102
|
+
cells.forEach(item => {
|
|
103
|
+
if (item[id] === oldId) {
|
|
104
|
+
item[id] = newId;
|
|
105
|
+
}
|
|
106
|
+
});
|
|
107
|
+
}
|
|
108
|
+
export function updateRowOrColumnIds(element, type) {
|
|
109
|
+
element[`${type}s`].forEach(item => {
|
|
110
|
+
const newId = idCreator();
|
|
111
|
+
updateCellIdsByRowOrColumn(element.cells, item.id, newId, type);
|
|
112
|
+
item.id = newId;
|
|
113
|
+
});
|
|
114
|
+
}
|
|
115
|
+
export function updateCellIds(cells) {
|
|
116
|
+
cells.forEach(item => {
|
|
117
|
+
const newId = idCreator();
|
|
118
|
+
item.id = newId;
|
|
119
|
+
});
|
|
120
|
+
}
|
|
121
|
+
export function isCellIncludeText(cell) {
|
|
122
|
+
return cell.text && cell.textHeight;
|
|
123
|
+
}
|
|
124
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.js","sourceRoot":"","sources":["../../../../packages/draw/src/utils/table.ts"],"names":[],"mappings":"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","sourcesContent":["import { idCreator, PlaitBoard, Point, RectangleClient } from '@plait/core';\nimport { PlaitTable, PlaitTableCell, PlaitTableCellWithPoints } from '../interfaces/table';\nimport { getTextManage } from '../generators/text.generator';\nimport { PlaitTableBoard } from '../plugins/with-table';\n\nexport function getCellsWithPoints(board: PlaitBoard, element: PlaitTable): PlaitTableCellWithPoints[] {\n    const table = (board as PlaitTableBoard).buildTable(element);\n    const rectangle = RectangleClient.getRectangleByPoints(table.points);\n    const columnsCount = table.columns.length;\n    const rowsCount = table.rows.length;\n    const cellWidths = calculateCellsSize(table.columns, rectangle.width, columnsCount, true);\n    const cellHeights = calculateCellsSize(table.rows, rectangle.height, rowsCount, false);\n\n    const cells: PlaitTableCellWithPoints[] = table.cells.map(cell => {\n        const rowIdx = table.rows.findIndex(row => row.id === cell.rowId);\n        const columnIdx = table.columns.findIndex(column => column.id === cell.columnId);\n\n        let cellTopLeftX = rectangle.x;\n        for (let i = 0; i < columnIdx; i++) {\n            cellTopLeftX += cellWidths[i];\n        }\n\n        let cellTopLeftY = rectangle.y;\n        for (let i = 0; i < rowIdx; i++) {\n            cellTopLeftY += cellHeights[i];\n        }\n\n        const cellWidth = calculateCellSize(cell, cellWidths, columnIdx, true);\n        const cellBottomRightX = cellTopLeftX + cellWidth;\n\n        const cellHeight = calculateCellSize(cell, cellHeights, rowIdx, false);\n        const cellBottomRightY = cellTopLeftY + cellHeight;\n\n        return {\n            ...cell,\n            points: [\n                [cellTopLeftX, cellTopLeftY],\n                [cellBottomRightX, cellBottomRightY]\n            ]\n        };\n    });\n\n    return cells;\n}\n\nexport function getCellWithPoints(board: PlaitBoard, table: PlaitTable, cellId: string) {\n    const cells = getCellsWithPoints(board as PlaitTableBoard, table);\n    const cellIndex = table.cells.findIndex(item => item.id === cellId);\n    return cells[cellIndex];\n}\n\nfunction calculateCellsSize(items: { id: string; [key: string]: any }[], tableSize: number, count: number, isWidth: boolean) {\n    const cellSizes: number[] = [];\n    const sizeType = isWidth ? 'width' : 'height';\n\n    // The remaining size of the table excluding cells with already set sizes.\n    let totalSizeRemaining = tableSize;\n\n    items.forEach((item, index) => {\n        if (item[sizeType]) {\n            cellSizes[index] = item[sizeType];\n            totalSizeRemaining -= item[sizeType];\n        }\n    });\n\n    // Divide the remaining size equally.\n    const remainingItemCount = count - cellSizes.filter(item => !!item).length;\n    const remainingCellSize = remainingItemCount > 0 ? totalSizeRemaining / remainingItemCount : 0;\n    for (let i = 0; i < count; i++) {\n        if (!cellSizes[i]) {\n            cellSizes[i] = remainingCellSize;\n        }\n    }\n    return cellSizes;\n}\n\nfunction calculateCellSize(cell: PlaitTableCell, sizes: number[], index: number, isWidth: boolean) {\n    const span = isWidth ? cell.colspan || 1 : cell.rowspan || 1;\n    let size = 0;\n    for (let i = 0; i < span; i++) {\n        const cellIndex = index + i;\n        size += sizes[cellIndex];\n    }\n    return size;\n}\n\nexport function getHitCell(board: PlaitTableBoard, element: PlaitTable, point: Point) {\n    const table = board.buildTable(element);\n    const cells = getCellsWithPoints(board, table);\n    const rectangle = RectangleClient.getRectangleByPoints([point, point]);\n    const cell = cells.find(item => {\n        const cellRectangle = RectangleClient.getRectangleByPoints(item.points);\n        return RectangleClient.isHit(rectangle, cellRectangle);\n    });\n    if (cell) {\n        return table.cells.find(item => item.id === cell.id);\n    }\n    return null;\n}\n\nexport function editCell(cell: PlaitTableCell) {\n    const textManage = getTextManageByCell(cell);\n    textManage && textManage.edit();\n}\n\nexport function getTextManageByCell(cell: PlaitTableCell) {\n    return getTextManage(cell.id);\n}\n\nexport const updateColumns = (table: PlaitTable, columnId: string, width: number, offset: number) => {\n    const columns = table.columns.map(item => (item.id === columnId ? { ...item, width } : item));\n    const points = [table.points[0], [table.points[1][0] + offset, table.points[1][1]]] as Point[];\n    return { columns, points };\n};\n\nexport const updateRows = (table: PlaitTable, rowId: string, height: number, offset: number) => {\n    const rows = table.rows.map(item => (item.id === rowId ? { ...item, height } : item));\n    const points = [table.points[0], [table.points[1][0], table.points[1][1] + offset]] as Point[];\n    return { rows, points };\n};\n\nexport function updateCellIdsByRowOrColumn(cells: PlaitTableCell[], oldId: string, newId: string, type: 'row' | 'column') {\n    const id: 'rowId' | 'columnId' = `${type}Id`;\n    cells.forEach(item => {\n        if (item[id] === oldId) {\n            item[id] = newId;\n        }\n    });\n}\n\nexport function updateRowOrColumnIds(element: PlaitTable, type: 'row' | 'column') {\n    element[`${type}s`].forEach(item => {\n        const newId = idCreator();\n        updateCellIdsByRowOrColumn(element.cells, item.id, newId, type);\n        item.id = newId;\n    });\n}\n\nexport function updateCellIds(cells: PlaitTableCell[]) {\n    cells.forEach(item => {\n        const newId = idCreator();\n        item.id = newId;\n    });\n}\n\nexport function isCellIncludeText(cell: PlaitTableCell) {\n    return cell.text && cell.textHeight;\n}\n"]}
|