@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,21 +0,0 @@
|
|
|
1
|
-
import { getSelectedElements } from '@plait/core';
|
|
2
|
-
import { PlaitDrawElement } from '../interfaces';
|
|
3
|
-
export const isSingleSelectTable = (board) => {
|
|
4
|
-
const selectedElements = getSelectedElements(board);
|
|
5
|
-
return selectedElements && selectedElements.length === 1 && PlaitDrawElement.isElementByTable(selectedElements[0]);
|
|
6
|
-
};
|
|
7
|
-
export const getSelectedTableElements = (board, elements) => {
|
|
8
|
-
const selectedElements = elements?.length ? elements : getSelectedElements(board);
|
|
9
|
-
return selectedElements.filter(value => PlaitDrawElement.isElementByTable(value));
|
|
10
|
-
};
|
|
11
|
-
export const SELECTED_CELLS = new WeakMap();
|
|
12
|
-
export function getSelectedCells(element) {
|
|
13
|
-
return SELECTED_CELLS.get(element);
|
|
14
|
-
}
|
|
15
|
-
export function setSelectedCells(element, cells) {
|
|
16
|
-
return SELECTED_CELLS.set(element, cells);
|
|
17
|
-
}
|
|
18
|
-
export function clearSelectedCells(element) {
|
|
19
|
-
return SELECTED_CELLS.delete(element);
|
|
20
|
-
}
|
|
21
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtc2VsZWN0ZWQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9kcmF3L3NyYy91dGlscy90YWJsZS1zZWxlY3RlZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQWMsbUJBQW1CLEVBQWdCLE1BQU0sYUFBYSxDQUFDO0FBRTVFLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUVqRCxNQUFNLENBQUMsTUFBTSxtQkFBbUIsR0FBRyxDQUFDLEtBQWlCLEVBQUUsRUFBRTtJQUNyRCxNQUFNLGdCQUFnQixHQUFHLG1CQUFtQixDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ3BELE9BQU8sZ0JBQWdCLElBQUksZ0JBQWdCLENBQUMsTUFBTSxLQUFLLENBQUMsSUFBSSxnQkFBZ0IsQ0FBQyxnQkFBZ0IsQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO0FBQ3ZILENBQUMsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLHdCQUF3QixHQUFHLENBQUMsS0FBaUIsRUFBRSxRQUF5QixFQUFFLEVBQUU7SUFDckYsTUFBTSxnQkFBZ0IsR0FBRyxRQUFRLEVBQUUsTUFBTSxDQUFDLENBQUMsQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDLG1CQUFtQixDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ2xGLE9BQU8sZ0JBQWdCLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUMsZ0JBQWdCLENBQUMsZ0JBQWdCLENBQUMsS0FBSyxDQUFDLENBQWlCLENBQUM7QUFDdEcsQ0FBQyxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sY0FBYyxHQUFHLElBQUksT0FBTyxFQUFvQyxDQUFDO0FBRTlFLE1BQU0sVUFBVSxnQkFBZ0IsQ0FBQyxPQUF1QjtJQUNwRCxPQUFPLGNBQWMsQ0FBQyxHQUFHLENBQUMsT0FBTyxDQUFDLENBQUM7QUFDdkMsQ0FBQztBQUVELE1BQU0sVUFBVSxnQkFBZ0IsQ0FBQyxPQUF1QixFQUFFLEtBQXVCO0lBQzdFLE9BQU8sY0FBYyxDQUFDLEdBQUcsQ0FBQyxPQUFPLEVBQUUsS0FBSyxDQUFDLENBQUM7QUFDOUMsQ0FBQztBQUVELE1BQU0sVUFBVSxrQkFBa0IsQ0FBQyxPQUF1QjtJQUN0RCxPQUFPLGNBQWMsQ0FBQyxNQUFNLENBQUMsT0FBTyxDQUFDLENBQUM7QUFDMUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBsYWl0Qm9hcmQsIGdldFNlbGVjdGVkRWxlbWVudHMsIFBsYWl0RWxlbWVudCB9IGZyb20gJ0BwbGFpdC9jb3JlJztcbmltcG9ydCB7IFBsYWl0VGFibGVDZWxsLCBQbGFpdEJhc2VUYWJsZSwgUGxhaXRUYWJsZSB9IGZyb20gJy4uL2ludGVyZmFjZXMvdGFibGUnO1xuaW1wb3J0IHsgUGxhaXREcmF3RWxlbWVudCB9IGZyb20gJy4uL2ludGVyZmFjZXMnO1xuXG5leHBvcnQgY29uc3QgaXNTaW5nbGVTZWxlY3RUYWJsZSA9IChib2FyZDogUGxhaXRCb2FyZCkgPT4ge1xuICAgIGNvbnN0IHNlbGVjdGVkRWxlbWVudHMgPSBnZXRTZWxlY3RlZEVsZW1lbnRzKGJvYXJkKTtcbiAgICByZXR1cm4gc2VsZWN0ZWRFbGVtZW50cyAmJiBzZWxlY3RlZEVsZW1lbnRzLmxlbmd0aCA9PT0gMSAmJiBQbGFpdERyYXdFbGVtZW50LmlzRWxlbWVudEJ5VGFibGUoc2VsZWN0ZWRFbGVtZW50c1swXSk7XG59O1xuXG5leHBvcnQgY29uc3QgZ2V0U2VsZWN0ZWRUYWJsZUVsZW1lbnRzID0gKGJvYXJkOiBQbGFpdEJvYXJkLCBlbGVtZW50cz86IFBsYWl0RWxlbWVudFtdKSA9PiB7XG4gICAgY29uc3Qgc2VsZWN0ZWRFbGVtZW50cyA9IGVsZW1lbnRzPy5sZW5ndGggPyBlbGVtZW50cyA6IGdldFNlbGVjdGVkRWxlbWVudHMoYm9hcmQpO1xuICAgIHJldHVybiBzZWxlY3RlZEVsZW1lbnRzLmZpbHRlcih2YWx1ZSA9PiBQbGFpdERyYXdFbGVtZW50LmlzRWxlbWVudEJ5VGFibGUodmFsdWUpKSBhcyBQbGFpdFRhYmxlW107XG59O1xuXG5leHBvcnQgY29uc3QgU0VMRUNURURfQ0VMTFMgPSBuZXcgV2Vha01hcDxQbGFpdEJhc2VUYWJsZSwgUGxhaXRUYWJsZUNlbGxbXT4oKTtcblxuZXhwb3J0IGZ1bmN0aW9uIGdldFNlbGVjdGVkQ2VsbHMoZWxlbWVudDogUGxhaXRCYXNlVGFibGUpIHtcbiAgICByZXR1cm4gU0VMRUNURURfQ0VMTFMuZ2V0KGVsZW1lbnQpO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gc2V0U2VsZWN0ZWRDZWxscyhlbGVtZW50OiBQbGFpdEJhc2VUYWJsZSwgY2VsbHM6IFBsYWl0VGFibGVDZWxsW10pIHtcbiAgICByZXR1cm4gU0VMRUNURURfQ0VMTFMuc2V0KGVsZW1lbnQsIGNlbGxzKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGNsZWFyU2VsZWN0ZWRDZWxscyhlbGVtZW50OiBQbGFpdEJhc2VUYWJsZSkge1xuICAgIHJldHVybiBTRUxFQ1RFRF9DRUxMUy5kZWxldGUoZWxlbWVudCk7XG59XG4iXX0=
|
package/esm2022/utils/table.mjs
DELETED
|
@@ -1,172 +0,0 @@
|
|
|
1
|
-
import { idCreator, RectangleClient } from '@plait/core';
|
|
2
|
-
import { getTextManage } from '../generators/text.generator';
|
|
3
|
-
import { Alignment } from '@plait/common';
|
|
4
|
-
import { TEXT_DEFAULT_HEIGHT } from '@plait/text-plugins';
|
|
5
|
-
import { getSelectedCells, getSelectedTableElements, isSingleSelectTable } from './table-selected';
|
|
6
|
-
export function getCellsWithPoints(board, element) {
|
|
7
|
-
const table = board?.buildTable(element);
|
|
8
|
-
if (!table || !table.points || !table.columns || !table.rows) {
|
|
9
|
-
throw new Error('can not get table cells points');
|
|
10
|
-
}
|
|
11
|
-
const rectangle = RectangleClient.getRectangleByPoints(table.points);
|
|
12
|
-
const columnsCount = table.columns.length;
|
|
13
|
-
const rowsCount = table.rows.length;
|
|
14
|
-
const cellWidths = calculateCellsSize(table.columns, rectangle.width, columnsCount, true);
|
|
15
|
-
const cellHeights = calculateCellsSize(table.rows, rectangle.height, rowsCount, false);
|
|
16
|
-
const cells = table.cells.map(cell => {
|
|
17
|
-
const rowIdx = table.rows.findIndex(row => row.id === cell.rowId);
|
|
18
|
-
const columnIdx = table.columns.findIndex(column => column.id === cell.columnId);
|
|
19
|
-
let cellTopLeftX = rectangle.x;
|
|
20
|
-
for (let i = 0; i < columnIdx; i++) {
|
|
21
|
-
cellTopLeftX += cellWidths[i];
|
|
22
|
-
}
|
|
23
|
-
let cellTopLeftY = rectangle.y;
|
|
24
|
-
for (let i = 0; i < rowIdx; i++) {
|
|
25
|
-
cellTopLeftY += cellHeights[i];
|
|
26
|
-
}
|
|
27
|
-
const cellWidth = calculateCellSize(cell, cellWidths, columnIdx, true);
|
|
28
|
-
const cellBottomRightX = cellTopLeftX + cellWidth;
|
|
29
|
-
const cellHeight = calculateCellSize(cell, cellHeights, rowIdx, false);
|
|
30
|
-
const cellBottomRightY = cellTopLeftY + cellHeight;
|
|
31
|
-
return {
|
|
32
|
-
...cell,
|
|
33
|
-
points: [
|
|
34
|
-
[cellTopLeftX, cellTopLeftY],
|
|
35
|
-
[cellBottomRightX, cellBottomRightY]
|
|
36
|
-
]
|
|
37
|
-
};
|
|
38
|
-
});
|
|
39
|
-
return cells;
|
|
40
|
-
}
|
|
41
|
-
export function getCellWithPoints(board, table, cellId) {
|
|
42
|
-
try {
|
|
43
|
-
const cells = getCellsWithPoints(board, table);
|
|
44
|
-
const cellIndex = cells && table.cells.findIndex(item => item.id === cellId);
|
|
45
|
-
return cells[cellIndex];
|
|
46
|
-
}
|
|
47
|
-
catch (error) {
|
|
48
|
-
throw new Error('can not get table cell points');
|
|
49
|
-
}
|
|
50
|
-
}
|
|
51
|
-
function calculateCellsSize(items, tableSize, count, isWidth) {
|
|
52
|
-
const cellSizes = [];
|
|
53
|
-
const sizeType = isWidth ? 'width' : 'height';
|
|
54
|
-
// The remaining size of the table excluding cells with already set sizes.
|
|
55
|
-
let totalSizeRemaining = tableSize;
|
|
56
|
-
items.forEach((item, index) => {
|
|
57
|
-
if (item[sizeType]) {
|
|
58
|
-
cellSizes[index] = item[sizeType];
|
|
59
|
-
totalSizeRemaining -= item[sizeType];
|
|
60
|
-
}
|
|
61
|
-
});
|
|
62
|
-
// Divide the remaining size equally.
|
|
63
|
-
const remainingItemCount = count - cellSizes.filter(item => !!item).length;
|
|
64
|
-
const remainingCellSize = remainingItemCount > 0 ? totalSizeRemaining / remainingItemCount : 0;
|
|
65
|
-
for (let i = 0; i < count; i++) {
|
|
66
|
-
if (!cellSizes[i]) {
|
|
67
|
-
cellSizes[i] = remainingCellSize;
|
|
68
|
-
}
|
|
69
|
-
}
|
|
70
|
-
return cellSizes;
|
|
71
|
-
}
|
|
72
|
-
function calculateCellSize(cell, sizes, index, isWidth) {
|
|
73
|
-
const span = isWidth ? cell.colspan || 1 : cell.rowspan || 1;
|
|
74
|
-
let size = 0;
|
|
75
|
-
for (let i = 0; i < span; i++) {
|
|
76
|
-
const cellIndex = index + i;
|
|
77
|
-
size += sizes[cellIndex];
|
|
78
|
-
}
|
|
79
|
-
return size;
|
|
80
|
-
}
|
|
81
|
-
export function getHitCell(board, element, point) {
|
|
82
|
-
const table = board.buildTable(element);
|
|
83
|
-
const cells = getCellsWithPoints(board, table);
|
|
84
|
-
const rectangle = RectangleClient.getRectangleByPoints([point, point]);
|
|
85
|
-
const cell = cells.find(item => {
|
|
86
|
-
const cellRectangle = RectangleClient.getRectangleByPoints(item.points);
|
|
87
|
-
return RectangleClient.isHit(rectangle, cellRectangle);
|
|
88
|
-
});
|
|
89
|
-
if (cell) {
|
|
90
|
-
return table.cells.find(item => item.id === cell.id);
|
|
91
|
-
}
|
|
92
|
-
return null;
|
|
93
|
-
}
|
|
94
|
-
export function editCell(board, cell) {
|
|
95
|
-
const textManage = getTextManageByCell(board, cell);
|
|
96
|
-
textManage && textManage.edit();
|
|
97
|
-
}
|
|
98
|
-
export function getTextManageByCell(board, cell) {
|
|
99
|
-
return getTextManage(board, undefined, cell);
|
|
100
|
-
}
|
|
101
|
-
export const updateColumns = (table, columnId, width, offset) => {
|
|
102
|
-
const columns = table.columns.map(item => (item.id === columnId ? { ...item, width } : item));
|
|
103
|
-
const points = [table.points[0], [table.points[1][0] + offset, table.points[1][1]]];
|
|
104
|
-
return { columns, points };
|
|
105
|
-
};
|
|
106
|
-
export const updateRows = (table, rowId, height, offset) => {
|
|
107
|
-
const rows = table.rows.map(item => (item.id === rowId ? { ...item, height } : item));
|
|
108
|
-
const points = [table.points[0], [table.points[1][0], table.points[1][1] + offset]];
|
|
109
|
-
return { rows, points };
|
|
110
|
-
};
|
|
111
|
-
export function updateCellIdsByRowOrColumn(cells, oldId, newId, type) {
|
|
112
|
-
const id = `${type}Id`;
|
|
113
|
-
cells.forEach(item => {
|
|
114
|
-
if (item[id] === oldId) {
|
|
115
|
-
item[id] = newId;
|
|
116
|
-
}
|
|
117
|
-
});
|
|
118
|
-
}
|
|
119
|
-
export function updateRowOrColumnIds(element, type) {
|
|
120
|
-
element[`${type}s`].forEach(item => {
|
|
121
|
-
const newId = idCreator();
|
|
122
|
-
updateCellIdsByRowOrColumn(element.cells, item.id, newId, type);
|
|
123
|
-
item.id = newId;
|
|
124
|
-
});
|
|
125
|
-
}
|
|
126
|
-
export function updateCellIds(cells) {
|
|
127
|
-
cells.forEach(item => {
|
|
128
|
-
const newId = idCreator();
|
|
129
|
-
item.id = newId;
|
|
130
|
-
});
|
|
131
|
-
}
|
|
132
|
-
export function isCellIncludeText(cell) {
|
|
133
|
-
return cell.text && cell.textHeight;
|
|
134
|
-
}
|
|
135
|
-
export function getCellsRectangle(board, element, cells) {
|
|
136
|
-
const cellsWithPoints = getCellsWithPoints(board, element);
|
|
137
|
-
const points = cells.map(cell => {
|
|
138
|
-
const cellWithPoints = cellsWithPoints.find(item => item.id === cell.id);
|
|
139
|
-
return cellWithPoints.points;
|
|
140
|
-
});
|
|
141
|
-
return RectangleClient.getRectangleByPoints(points);
|
|
142
|
-
}
|
|
143
|
-
export const createCell = (rowId, columnId, text = null) => {
|
|
144
|
-
const cell = {
|
|
145
|
-
id: idCreator(),
|
|
146
|
-
rowId,
|
|
147
|
-
columnId
|
|
148
|
-
};
|
|
149
|
-
if (text !== null) {
|
|
150
|
-
cell['textHeight'] = TEXT_DEFAULT_HEIGHT;
|
|
151
|
-
cell['text'] = {
|
|
152
|
-
children: [{ text }],
|
|
153
|
-
align: Alignment.center
|
|
154
|
-
};
|
|
155
|
-
}
|
|
156
|
-
return cell;
|
|
157
|
-
};
|
|
158
|
-
export const getSelectedTableCellsEditor = (board) => {
|
|
159
|
-
if (isSingleSelectTable(board)) {
|
|
160
|
-
const elements = getSelectedTableElements(board);
|
|
161
|
-
const selectedCells = getSelectedCells(elements[0]);
|
|
162
|
-
const selectedCellsEditor = selectedCells?.map(cell => {
|
|
163
|
-
const textManage = getTextManageByCell(board, cell);
|
|
164
|
-
return textManage?.editor;
|
|
165
|
-
});
|
|
166
|
-
if (selectedCellsEditor?.length) {
|
|
167
|
-
return selectedCellsEditor;
|
|
168
|
-
}
|
|
169
|
-
}
|
|
170
|
-
return undefined;
|
|
171
|
-
};
|
|
172
|
-
//# 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 { PlaitBaseTable, PlaitTable, PlaitTableBoard, PlaitTableCell, PlaitTableCellWithPoints } from '../interfaces/table';\nimport { getTextManage } from '../generators/text.generator';\nimport { Alignment } from '@plait/common';\nimport { TEXT_DEFAULT_HEIGHT } from '@plait/text-plugins';\nimport { getSelectedCells, getSelectedTableElements, isSingleSelectTable } from './table-selected';\nimport { BaseEditor } from 'slate';\n\nexport function getCellsWithPoints(board: PlaitBoard, element: PlaitBaseTable): PlaitTableCellWithPoints[] {\n    const table = (board as PlaitTableBoard)?.buildTable(element);\n    if (!table || !table.points || !table.columns || !table.rows) {\n        throw new Error('can not get table cells points');\n    }\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    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: PlaitBaseTable, cellId: string) {\n    try {\n        const cells = getCellsWithPoints(board as PlaitTableBoard, table);\n        const cellIndex = cells && table.cells.findIndex(item => item.id === cellId);\n        return cells[cellIndex];\n    } catch (error) {\n        throw new Error('can not get table cell points');\n    }\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: PlaitBaseTable, 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(board: PlaitBoard, cell: PlaitTableCell) {\n    const textManage = getTextManageByCell(board, cell);\n    textManage && textManage.edit();\n}\n\nexport function getTextManageByCell(board: PlaitBoard, cell: PlaitTableCell) {\n    return getTextManage(board, undefined, cell);\n}\n\nexport const updateColumns = (table: PlaitBaseTable, 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: PlaitBaseTable, 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\nexport function getCellsRectangle(board: PlaitTableBoard, element: PlaitTable, cells: PlaitTableCell[]) {\n    const cellsWithPoints = getCellsWithPoints(board as PlaitTableBoard, element);\n    const points = cells.map(cell => {\n        const cellWithPoints = cellsWithPoints.find(item => item.id === cell.id);\n        return cellWithPoints!.points;\n    });\n    return RectangleClient.getRectangleByPoints(points);\n}\n\nexport const createCell = (rowId: string, columnId: string, text: string | null = null) => {\n    const cell: PlaitTableCell = {\n        id: idCreator(),\n        rowId,\n        columnId\n    };\n    if (text !== null) {\n        cell['textHeight'] = TEXT_DEFAULT_HEIGHT;\n        cell['text'] = {\n            children: [{ text }],\n            align: Alignment.center\n        };\n    }\n    return cell;\n};\n\nexport const getSelectedTableCellsEditor = (board: PlaitBoard): BaseEditor[] | undefined => {\n    if (isSingleSelectTable(board)) {\n        const elements = getSelectedTableElements(board);\n        const selectedCells = getSelectedCells(elements[0]);\n        const selectedCellsEditor = selectedCells?.map(cell => {\n            const textManage = getTextManageByCell(board, cell);\n            return textManage?.editor;\n        });\n        if (selectedCellsEditor?.length) {\n            return selectedCellsEditor as BaseEditor[];\n        }\n    }\n    return undefined;\n};\n"]}
|
package/esm2022/utils/uml.mjs
DELETED
|
@@ -1,90 +0,0 @@
|
|
|
1
|
-
import { idCreator } from '@plait/core';
|
|
2
|
-
import { DefaultBasicShapeProperty } from '../constants';
|
|
3
|
-
import { UMLSymbols } from '../interfaces';
|
|
4
|
-
import { getMemorizedLatestByPointer } from './memorize';
|
|
5
|
-
import { getDefaultGeometryProperty, getTextShapeProperty } from './geometry';
|
|
6
|
-
import { getDefaultGeometryText } from './common';
|
|
7
|
-
export const createUMLClassOrInterfaceGeometryElement = (board, shape, points) => {
|
|
8
|
-
const memorizedLatest = getMemorizedLatestByPointer(shape);
|
|
9
|
-
const element = {
|
|
10
|
-
id: idCreator(),
|
|
11
|
-
type: 'geometry',
|
|
12
|
-
angle: 0,
|
|
13
|
-
opacity: 1,
|
|
14
|
-
points,
|
|
15
|
-
strokeWidth: DefaultBasicShapeProperty.strokeWidth,
|
|
16
|
-
...memorizedLatest.geometryProperties
|
|
17
|
-
};
|
|
18
|
-
let rows;
|
|
19
|
-
let columns;
|
|
20
|
-
if (shape === UMLSymbols.class) {
|
|
21
|
-
rows = [
|
|
22
|
-
{
|
|
23
|
-
id: idCreator(),
|
|
24
|
-
height: 30
|
|
25
|
-
},
|
|
26
|
-
{
|
|
27
|
-
id: idCreator()
|
|
28
|
-
},
|
|
29
|
-
{
|
|
30
|
-
id: idCreator()
|
|
31
|
-
}
|
|
32
|
-
];
|
|
33
|
-
columns = [
|
|
34
|
-
{
|
|
35
|
-
id: idCreator()
|
|
36
|
-
}
|
|
37
|
-
];
|
|
38
|
-
}
|
|
39
|
-
else {
|
|
40
|
-
rows = [
|
|
41
|
-
{
|
|
42
|
-
id: idCreator(),
|
|
43
|
-
height: 50
|
|
44
|
-
},
|
|
45
|
-
{
|
|
46
|
-
id: idCreator()
|
|
47
|
-
}
|
|
48
|
-
];
|
|
49
|
-
columns = [
|
|
50
|
-
{
|
|
51
|
-
id: idCreator()
|
|
52
|
-
}
|
|
53
|
-
];
|
|
54
|
-
}
|
|
55
|
-
return {
|
|
56
|
-
...element,
|
|
57
|
-
shape,
|
|
58
|
-
rows,
|
|
59
|
-
columns,
|
|
60
|
-
cells: buildTableCellsForGeometry(board, rows, columns, shape)
|
|
61
|
-
};
|
|
62
|
-
};
|
|
63
|
-
const buildTableCellsForGeometry = (board, rows, columns, shape) => {
|
|
64
|
-
const memorizedLatest = getMemorizedLatestByPointer(shape);
|
|
65
|
-
const cellCount = rows.length * columns.length;
|
|
66
|
-
const defaultTexts = getDefaultGeometryProperty(shape)?.texts || [];
|
|
67
|
-
const textHeights = defaultTexts.map((textItem) => {
|
|
68
|
-
return getTextShapeProperty(board, textItem.text || getDefaultGeometryText(board), memorizedLatest.textProperties['font-size'])
|
|
69
|
-
.height;
|
|
70
|
-
});
|
|
71
|
-
return new Array(cellCount).fill('').map((item, index) => {
|
|
72
|
-
const rowIndex = Math.floor(index / columns.length);
|
|
73
|
-
const columnIndex = index % columns.length;
|
|
74
|
-
return {
|
|
75
|
-
id: idCreator(),
|
|
76
|
-
rowId: rows[rowIndex].id,
|
|
77
|
-
columnId: columns[columnIndex].id,
|
|
78
|
-
textHeight: textHeights[index],
|
|
79
|
-
text: {
|
|
80
|
-
children: [
|
|
81
|
-
{
|
|
82
|
-
text: defaultTexts[index].text
|
|
83
|
-
}
|
|
84
|
-
],
|
|
85
|
-
align: defaultTexts[index].align
|
|
86
|
-
}
|
|
87
|
-
};
|
|
88
|
-
});
|
|
89
|
-
};
|
|
90
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidW1sLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcGFja2FnZXMvZHJhdy9zcmMvdXRpbHMvdW1sLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBcUIsU0FBUyxFQUFFLE1BQU0sYUFBYSxDQUFDO0FBQzNELE9BQU8sRUFBRSx5QkFBeUIsRUFBRSxNQUFNLGNBQWMsQ0FBQztBQUN6RCxPQUFPLEVBQWtCLFVBQVUsRUFBdUIsTUFBTSxlQUFlLENBQUM7QUFDaEYsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sWUFBWSxDQUFDO0FBQ3pELE9BQU8sRUFBd0IsMEJBQTBCLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxZQUFZLENBQUM7QUFFcEcsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sVUFBVSxDQUFDO0FBRWxELE1BQU0sQ0FBQyxNQUFNLHdDQUF3QyxHQUFHLENBQUMsS0FBaUIsRUFBRSxLQUFxQixFQUFFLE1BQXNCLEVBQUUsRUFBRTtJQUN6SCxNQUFNLGVBQWUsR0FBRywyQkFBMkIsQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUMzRCxNQUFNLE9BQU8sR0FBRztRQUNaLEVBQUUsRUFBRSxTQUFTLEVBQUU7UUFDZixJQUFJLEVBQUUsVUFBVTtRQUNoQixLQUFLLEVBQUUsQ0FBQztRQUNSLE9BQU8sRUFBRSxDQUFDO1FBQ1YsTUFBTTtRQUNOLFdBQVcsRUFBRSx5QkFBeUIsQ0FBQyxXQUFXO1FBQ2xELEdBQUksZUFBZSxDQUFDLGtCQUEyQztLQUNsRSxDQUFDO0lBQ0YsSUFBSSxJQUF1QyxDQUFDO0lBQzVDLElBQUksT0FBMEMsQ0FBQztJQUMvQyxJQUFJLEtBQUssS0FBSyxVQUFVLENBQUMsS0FBSyxFQUFFLENBQUM7UUFDN0IsSUFBSSxHQUFHO1lBQ0g7Z0JBQ0ksRUFBRSxFQUFFLFNBQVMsRUFBRTtnQkFDZixNQUFNLEVBQUUsRUFBRTthQUNiO1lBQ0Q7Z0JBQ0ksRUFBRSxFQUFFLFNBQVMsRUFBRTthQUNsQjtZQUNEO2dCQUNJLEVBQUUsRUFBRSxTQUFTLEVBQUU7YUFDbEI7U0FDSixDQUFDO1FBQ0YsT0FBTyxHQUFHO1lBQ047Z0JBQ0ksRUFBRSxFQUFFLFNBQVMsRUFBRTthQUNsQjtTQUNKLENBQUM7SUFDTixDQUFDO1NBQU0sQ0FBQztRQUNKLElBQUksR0FBRztZQUNIO2dCQUNJLEVBQUUsRUFBRSxTQUFTLEVBQUU7Z0JBQ2YsTUFBTSxFQUFFLEVBQUU7YUFDYjtZQUNEO2dCQUNJLEVBQUUsRUFBRSxTQUFTLEVBQUU7YUFDbEI7U0FDSixDQUFDO1FBQ0YsT0FBTyxHQUFHO1lBQ047Z0JBQ0ksRUFBRSxFQUFFLFNBQVMsRUFBRTthQUNsQjtTQUNKLENBQUM7SUFDTixDQUFDO0lBQ0QsT0FBTztRQUNILEdBQUcsT0FBTztRQUNWLEtBQUs7UUFDTCxJQUFJO1FBQ0osT0FBTztRQUNQLEtBQUssRUFBRSwwQkFBMEIsQ0FBQyxLQUFLLEVBQUUsSUFBSSxFQUFFLE9BQU8sRUFBRSxLQUFLLENBQUM7S0FDL0IsQ0FBQztBQUN4QyxDQUFDLENBQUM7QUFFRixNQUFNLDBCQUEwQixHQUFHLENBQy9CLEtBQWlCLEVBQ2pCLElBR0csRUFDSCxPQUdHLEVBQ0gsS0FBcUIsRUFDTCxFQUFFO0lBQ2xCLE1BQU0sZUFBZSxHQUFHLDJCQUEyQixDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQzNELE1BQU0sU0FBUyxHQUFHLElBQUksQ0FBQyxNQUFNLEdBQUcsT0FBTyxDQUFDLE1BQU0sQ0FBQztJQUMvQyxNQUFNLFlBQVksR0FBSSwwQkFBMEIsQ0FBQyxLQUFLLENBQVMsRUFBRSxLQUFLLElBQUksRUFBRSxDQUFDO0lBQzdFLE1BQU0sV0FBVyxHQUFHLFlBQVksQ0FBQyxHQUFHLENBQUMsQ0FBQyxRQUEwQixFQUFFLEVBQUU7UUFDaEUsT0FBTyxvQkFBb0IsQ0FBQyxLQUFLLEVBQUUsUUFBUSxDQUFDLElBQUksSUFBSSxzQkFBc0IsQ0FBQyxLQUFLLENBQUMsRUFBRSxlQUFlLENBQUMsY0FBYyxDQUFDLFdBQVcsQ0FBQyxDQUFDO2FBQzFILE1BQU0sQ0FBQztJQUNoQixDQUFDLENBQUMsQ0FBQztJQUNILE9BQU8sSUFBSSxLQUFLLENBQUMsU0FBUyxDQUFDLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLElBQUksRUFBRSxLQUFLLEVBQUUsRUFBRTtRQUNyRCxNQUFNLFFBQVEsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLEtBQUssR0FBRyxPQUFPLENBQUMsTUFBTSxDQUFDLENBQUM7UUFDcEQsTUFBTSxXQUFXLEdBQUcsS0FBSyxHQUFHLE9BQU8sQ0FBQyxNQUFNLENBQUM7UUFDM0MsT0FBTztZQUNILEVBQUUsRUFBRSxTQUFTLEVBQUU7WUFDZixLQUFLLEVBQUUsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDLEVBQUU7WUFDeEIsUUFBUSxFQUFFLE9BQU8sQ0FBQyxXQUFXLENBQUMsQ0FBQyxFQUFFO1lBQ2pDLFVBQVUsRUFBRSxXQUFXLENBQUMsS0FBSyxDQUFDO1lBQzlCLElBQUksRUFBRTtnQkFDRixRQUFRLEVBQUU7b0JBQ047d0JBQ0ksSUFBSSxFQUFFLFlBQVksQ0FBQyxLQUFLLENBQUMsQ0FBQyxJQUFJO3FCQUNqQztpQkFDSjtnQkFDRCxLQUFLLEVBQUUsWUFBWSxDQUFDLEtBQUssQ0FBQyxDQUFDLEtBQUs7YUFDbkM7U0FDSixDQUFDO0lBQ04sQ0FBQyxDQUFDLENBQUM7QUFDUCxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQbGFpdEJvYXJkLCBQb2ludCwgaWRDcmVhdG9yIH0gZnJvbSAnQHBsYWl0L2NvcmUnO1xuaW1wb3J0IHsgRGVmYXVsdEJhc2ljU2hhcGVQcm9wZXJ0eSB9IGZyb20gJy4uL2NvbnN0YW50cyc7XG5pbXBvcnQgeyBHZW9tZXRyeVNoYXBlcywgVU1MU3ltYm9scywgUGxhaXRDb21tb25HZW9tZXRyeSB9IGZyb20gJy4uL2ludGVyZmFjZXMnO1xuaW1wb3J0IHsgZ2V0TWVtb3JpemVkTGF0ZXN0QnlQb2ludGVyIH0gZnJvbSAnLi9tZW1vcml6ZSc7XG5pbXBvcnQgeyBHZW9tZXRyeVN0eWxlT3B0aW9ucywgZ2V0RGVmYXVsdEdlb21ldHJ5UHJvcGVydHksIGdldFRleHRTaGFwZVByb3BlcnR5IH0gZnJvbSAnLi9nZW9tZXRyeSc7XG5pbXBvcnQgeyBQbGFpdFRhYmxlQ2VsbCB9IGZyb20gJy4uL2ludGVyZmFjZXMvdGFibGUnO1xuaW1wb3J0IHsgZ2V0RGVmYXVsdEdlb21ldHJ5VGV4dCB9IGZyb20gJy4vY29tbW9uJztcblxuZXhwb3J0IGNvbnN0IGNyZWF0ZVVNTENsYXNzT3JJbnRlcmZhY2VHZW9tZXRyeUVsZW1lbnQgPSAoYm9hcmQ6IFBsYWl0Qm9hcmQsIHNoYXBlOiBHZW9tZXRyeVNoYXBlcywgcG9pbnRzOiBbUG9pbnQsIFBvaW50XSkgPT4ge1xuICAgIGNvbnN0IG1lbW9yaXplZExhdGVzdCA9IGdldE1lbW9yaXplZExhdGVzdEJ5UG9pbnRlcihzaGFwZSk7XG4gICAgY29uc3QgZWxlbWVudCA9IHtcbiAgICAgICAgaWQ6IGlkQ3JlYXRvcigpLFxuICAgICAgICB0eXBlOiAnZ2VvbWV0cnknLFxuICAgICAgICBhbmdsZTogMCxcbiAgICAgICAgb3BhY2l0eTogMSxcbiAgICAgICAgcG9pbnRzLFxuICAgICAgICBzdHJva2VXaWR0aDogRGVmYXVsdEJhc2ljU2hhcGVQcm9wZXJ0eS5zdHJva2VXaWR0aCxcbiAgICAgICAgLi4uKG1lbW9yaXplZExhdGVzdC5nZW9tZXRyeVByb3BlcnRpZXMgYXMgR2VvbWV0cnlTdHlsZU9wdGlvbnMpXG4gICAgfTtcbiAgICBsZXQgcm93czogeyBpZDogc3RyaW5nOyBoZWlnaHQ/OiBudW1iZXIgfVtdO1xuICAgIGxldCBjb2x1bW5zOiB7IGlkOiBzdHJpbmc7IGhlaWdodD86IG51bWJlciB9W107XG4gICAgaWYgKHNoYXBlID09PSBVTUxTeW1ib2xzLmNsYXNzKSB7XG4gICAgICAgIHJvd3MgPSBbXG4gICAgICAgICAgICB7XG4gICAgICAgICAgICAgICAgaWQ6IGlkQ3JlYXRvcigpLFxuICAgICAgICAgICAgICAgIGhlaWdodDogMzBcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgICB7XG4gICAgICAgICAgICAgICAgaWQ6IGlkQ3JlYXRvcigpXG4gICAgICAgICAgICB9LFxuICAgICAgICAgICAge1xuICAgICAgICAgICAgICAgIGlkOiBpZENyZWF0b3IoKVxuICAgICAgICAgICAgfVxuICAgICAgICBdO1xuICAgICAgICBjb2x1bW5zID0gW1xuICAgICAgICAgICAge1xuICAgICAgICAgICAgICAgIGlkOiBpZENyZWF0b3IoKVxuICAgICAgICAgICAgfVxuICAgICAgICBdO1xuICAgIH0gZWxzZSB7XG4gICAgICAgIHJvd3MgPSBbXG4gICAgICAgICAgICB7XG4gICAgICAgICAgICAgICAgaWQ6IGlkQ3JlYXRvcigpLFxuICAgICAgICAgICAgICAgIGhlaWdodDogNTBcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgICB7XG4gICAgICAgICAgICAgICAgaWQ6IGlkQ3JlYXRvcigpXG4gICAgICAgICAgICB9XG4gICAgICAgIF07XG4gICAgICAgIGNvbHVtbnMgPSBbXG4gICAgICAgICAgICB7XG4gICAgICAgICAgICAgICAgaWQ6IGlkQ3JlYXRvcigpXG4gICAgICAgICAgICB9XG4gICAgICAgIF07XG4gICAgfVxuICAgIHJldHVybiB7XG4gICAgICAgIC4uLmVsZW1lbnQsXG4gICAgICAgIHNoYXBlLFxuICAgICAgICByb3dzLFxuICAgICAgICBjb2x1bW5zLFxuICAgICAgICBjZWxsczogYnVpbGRUYWJsZUNlbGxzRm9yR2VvbWV0cnkoYm9hcmQsIHJvd3MsIGNvbHVtbnMsIHNoYXBlKVxuICAgIH0gYXMgdW5rbm93biBhcyBQbGFpdENvbW1vbkdlb21ldHJ5O1xufTtcblxuY29uc3QgYnVpbGRUYWJsZUNlbGxzRm9yR2VvbWV0cnkgPSAoXG4gICAgYm9hcmQ6IFBsYWl0Qm9hcmQsXG4gICAgcm93czoge1xuICAgICAgICBpZDogc3RyaW5nO1xuICAgICAgICBoZWlnaHQ/OiBudW1iZXI7XG4gICAgfVtdLFxuICAgIGNvbHVtbnM6IHtcbiAgICAgICAgaWQ6IHN0cmluZztcbiAgICAgICAgaGVpZ2h0PzogbnVtYmVyO1xuICAgIH1bXSxcbiAgICBzaGFwZTogR2VvbWV0cnlTaGFwZXNcbik6IFBsYWl0VGFibGVDZWxsW10gPT4ge1xuICAgIGNvbnN0IG1lbW9yaXplZExhdGVzdCA9IGdldE1lbW9yaXplZExhdGVzdEJ5UG9pbnRlcihzaGFwZSk7XG4gICAgY29uc3QgY2VsbENvdW50ID0gcm93cy5sZW5ndGggKiBjb2x1bW5zLmxlbmd0aDtcbiAgICBjb25zdCBkZWZhdWx0VGV4dHMgPSAoZ2V0RGVmYXVsdEdlb21ldHJ5UHJvcGVydHkoc2hhcGUpIGFzIGFueSk/LnRleHRzIHx8IFtdO1xuICAgIGNvbnN0IHRleHRIZWlnaHRzID0gZGVmYXVsdFRleHRzLm1hcCgodGV4dEl0ZW06IHsgdGV4dDogc3RyaW5nIH0pID0+IHtcbiAgICAgICAgcmV0dXJuIGdldFRleHRTaGFwZVByb3BlcnR5KGJvYXJkLCB0ZXh0SXRlbS50ZXh0IHx8IGdldERlZmF1bHRHZW9tZXRyeVRleHQoYm9hcmQpLCBtZW1vcml6ZWRMYXRlc3QudGV4dFByb3BlcnRpZXNbJ2ZvbnQtc2l6ZSddKVxuICAgICAgICAgICAgLmhlaWdodDtcbiAgICB9KTtcbiAgICByZXR1cm4gbmV3IEFycmF5KGNlbGxDb3VudCkuZmlsbCgnJykubWFwKChpdGVtLCBpbmRleCkgPT4ge1xuICAgICAgICBjb25zdCByb3dJbmRleCA9IE1hdGguZmxvb3IoaW5kZXggLyBjb2x1bW5zLmxlbmd0aCk7XG4gICAgICAgIGNvbnN0IGNvbHVtbkluZGV4ID0gaW5kZXggJSBjb2x1bW5zLmxlbmd0aDtcbiAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICAgIGlkOiBpZENyZWF0b3IoKSxcbiAgICAgICAgICAgIHJvd0lkOiByb3dzW3Jvd0luZGV4XS5pZCxcbiAgICAgICAgICAgIGNvbHVtbklkOiBjb2x1bW5zW2NvbHVtbkluZGV4XS5pZCxcbiAgICAgICAgICAgIHRleHRIZWlnaHQ6IHRleHRIZWlnaHRzW2luZGV4XSxcbiAgICAgICAgICAgIHRleHQ6IHtcbiAgICAgICAgICAgICAgICBjaGlsZHJlbjogW1xuICAgICAgICAgICAgICAgICAgICB7XG4gICAgICAgICAgICAgICAgICAgICAgICB0ZXh0OiBkZWZhdWx0VGV4dHNbaW5kZXhdLnRleHRcbiAgICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgIF0sXG4gICAgICAgICAgICAgICAgYWxpZ246IGRlZmF1bHRUZXh0c1tpbmRleF0uYWxpZ25cbiAgICAgICAgICAgIH1cbiAgICAgICAgfTtcbiAgICB9KTtcbn07XG4iXX0=
|
|
@@ -1,71 +0,0 @@
|
|
|
1
|
-
import { PlaitBoard, catmullRomFitting, createG, drawLinearPath, idCreator, setStrokeLinecap } from '@plait/core';
|
|
2
|
-
import { VectorLineShape } from '../interfaces';
|
|
3
|
-
import { getLineMemorizedLatest } from './memorize';
|
|
4
|
-
import { DefaultLineStyle } from '../constants/line';
|
|
5
|
-
import { alignPoints } from './arrow-line';
|
|
6
|
-
import { getStrokeWidthByElement } from './common';
|
|
7
|
-
import { getFillByElement, getStrokeColorByElement, getStrokeStyleByElement } from './style';
|
|
8
|
-
import { VectorLineShapeGenerator } from '../generators/vector-line-generator';
|
|
9
|
-
import { pointsOnBezierCurves } from 'points-on-curve';
|
|
10
|
-
import { getStrokeLineDash, StrokeStyle } from '@plait/common';
|
|
11
|
-
export const getVectorLinePoints = (board, element) => {
|
|
12
|
-
switch (element.shape) {
|
|
13
|
-
case VectorLineShape.straight: {
|
|
14
|
-
return element.points;
|
|
15
|
-
}
|
|
16
|
-
case VectorLineShape.curve: {
|
|
17
|
-
if (element.points.length === 2) {
|
|
18
|
-
return pointsOnBezierCurves(element.points);
|
|
19
|
-
}
|
|
20
|
-
else {
|
|
21
|
-
let dataPoints = element.points;
|
|
22
|
-
const points = catmullRomFitting(dataPoints);
|
|
23
|
-
return pointsOnBezierCurves(points);
|
|
24
|
-
}
|
|
25
|
-
}
|
|
26
|
-
default:
|
|
27
|
-
return null;
|
|
28
|
-
}
|
|
29
|
-
};
|
|
30
|
-
export const createVectorLineElement = (shape, points, options) => {
|
|
31
|
-
return {
|
|
32
|
-
id: idCreator(),
|
|
33
|
-
type: 'vector-line',
|
|
34
|
-
shape,
|
|
35
|
-
opacity: 1,
|
|
36
|
-
points,
|
|
37
|
-
...options
|
|
38
|
-
};
|
|
39
|
-
};
|
|
40
|
-
export const vectorLineCreating = (board, lineShape, points, movingPoint, lineShapeG) => {
|
|
41
|
-
const lineGenerator = new VectorLineShapeGenerator(board);
|
|
42
|
-
const memorizedLatest = getLineMemorizedLatest();
|
|
43
|
-
const temporaryLineElement = createVectorLineElement(lineShape, [...points, movingPoint], {
|
|
44
|
-
strokeWidth: DefaultLineStyle.strokeWidth,
|
|
45
|
-
...memorizedLatest
|
|
46
|
-
});
|
|
47
|
-
const otherPoint = points[points.length - 1];
|
|
48
|
-
temporaryLineElement.points[temporaryLineElement.points.length - 1] = alignPoints(otherPoint, movingPoint);
|
|
49
|
-
lineGenerator.processDrawing(temporaryLineElement, lineShapeG);
|
|
50
|
-
PlaitBoard.getElementTopHost(board).append(lineShapeG);
|
|
51
|
-
return temporaryLineElement;
|
|
52
|
-
};
|
|
53
|
-
export const drawVectorLine = (board, element) => {
|
|
54
|
-
const strokeWidth = getStrokeWidthByElement(element);
|
|
55
|
-
const strokeColor = getStrokeColorByElement(board, element);
|
|
56
|
-
const strokeStyle = getStrokeStyleByElement(board, element);
|
|
57
|
-
const strokeLineDash = getStrokeLineDash(strokeStyle, strokeWidth);
|
|
58
|
-
const fill = getFillByElement(board, element);
|
|
59
|
-
const options = { stroke: strokeColor, strokeWidth, strokeLineDash, fill };
|
|
60
|
-
const lineG = createG();
|
|
61
|
-
let points = getVectorLinePoints(board, element);
|
|
62
|
-
const line = drawLinearPath(points, options);
|
|
63
|
-
const id = idCreator();
|
|
64
|
-
line.setAttribute('mask', `url(#${id})`);
|
|
65
|
-
if (element.strokeStyle === StrokeStyle.dotted) {
|
|
66
|
-
setStrokeLinecap(line, 'round');
|
|
67
|
-
}
|
|
68
|
-
lineG.appendChild(line);
|
|
69
|
-
return lineG;
|
|
70
|
-
};
|
|
71
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"vector-line.js","sourceRoot":"","sources":["../../../../packages/draw/src/utils/vector-line.ts"],"names":[],"mappings":"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","sourcesContent":["import { PlaitBoard, Point, catmullRomFitting, createG, drawLinearPath, idCreator, setStrokeLinecap } from '@plait/core';\nimport { PlaitVectorLine, VectorLineShape } from '../interfaces';\nimport { getLineMemorizedLatest } from './memorize';\nimport { DefaultLineStyle } from '../constants/line';\nimport { alignPoints } from './arrow-line';\nimport { getStrokeWidthByElement } from './common';\nimport { getFillByElement, getStrokeColorByElement, getStrokeStyleByElement } from './style';\nimport { VectorLineShapeGenerator } from '../generators/vector-line-generator';\nimport { pointsOnBezierCurves } from 'points-on-curve';\nimport { getStrokeLineDash, StrokeStyle } from '@plait/common';\n\nexport const getVectorLinePoints = (board: PlaitBoard, element: PlaitVectorLine) => {\n    switch (element.shape) {\n        case VectorLineShape.straight: {\n            return element.points;\n        }\n        case VectorLineShape.curve: {\n            if (element.points.length === 2) {\n                return pointsOnBezierCurves(element.points) as Point[];\n            } else {\n                let dataPoints = element.points;\n                const points = catmullRomFitting(dataPoints);\n                return pointsOnBezierCurves(points) as Point[];\n            }\n        }\n        default:\n            return null;\n    }\n};\n\nexport const createVectorLineElement = (\n    shape: VectorLineShape,\n    points: Point[],\n    options?: Pick<PlaitVectorLine, 'strokeColor' | 'strokeWidth' | 'fill'>\n): PlaitVectorLine => {\n    return {\n        id: idCreator(),\n        type: 'vector-line',\n        shape,\n        opacity: 1,\n        points,\n        ...options\n    };\n};\n\nexport const vectorLineCreating = (\n    board: PlaitBoard,\n    lineShape: VectorLineShape,\n    points: Point[],\n    movingPoint: Point,\n    lineShapeG: SVGGElement\n) => {\n    const lineGenerator = new VectorLineShapeGenerator(board);\n    const memorizedLatest = getLineMemorizedLatest();\n\n    const temporaryLineElement = createVectorLineElement(lineShape, [...points, movingPoint], {\n        strokeWidth: DefaultLineStyle.strokeWidth,\n        ...memorizedLatest\n    });\n    const otherPoint = points[points.length - 1];\n    temporaryLineElement.points[temporaryLineElement.points.length - 1] = alignPoints(otherPoint, movingPoint);\n    lineGenerator.processDrawing(temporaryLineElement, lineShapeG);\n    PlaitBoard.getElementTopHost(board).append(lineShapeG);\n    return temporaryLineElement;\n};\n\nexport const drawVectorLine = (board: PlaitBoard, element: PlaitVectorLine) => {\n    const strokeWidth = getStrokeWidthByElement(element);\n    const strokeColor = getStrokeColorByElement(board, element);\n    const strokeStyle = getStrokeStyleByElement(board, element);\n    const strokeLineDash = getStrokeLineDash(strokeStyle, strokeWidth);\n    const fill = getFillByElement(board, element);\n    const options = { stroke: strokeColor, strokeWidth, strokeLineDash, fill };\n    const lineG = createG();\n    let points = getVectorLinePoints(board, element)!;\n    const line = drawLinearPath(points, options);\n    const id = idCreator();\n    line.setAttribute('mask', `url(#${id})`);\n    if (element.strokeStyle === StrokeStyle.dotted) {\n        setStrokeLinecap(line, 'round');\n    }\n    lineG.appendChild(line);\n    return lineG;\n};\n"]}
|
|
@@ -1,55 +0,0 @@
|
|
|
1
|
-
import { PlaitBoard } from '@plait/core';
|
|
2
|
-
import { LineActiveGenerator } from './generators/line-active.generator';
|
|
3
|
-
import { CommonElementFlavour } from '@plait/common';
|
|
4
|
-
import { getVectorLinePoints } from './utils';
|
|
5
|
-
import { VectorLineShapeGenerator } from './generators/vector-line-generator';
|
|
6
|
-
export class VectorLineComponent extends CommonElementFlavour {
|
|
7
|
-
constructor() {
|
|
8
|
-
super();
|
|
9
|
-
}
|
|
10
|
-
initializeGenerator() {
|
|
11
|
-
this.shapeGenerator = new VectorLineShapeGenerator(this.board);
|
|
12
|
-
this.activeGenerator = new LineActiveGenerator(this.board);
|
|
13
|
-
this.getRef().updateActiveSection = () => {
|
|
14
|
-
const linePoints = getVectorLinePoints(this.board, this.element);
|
|
15
|
-
this.activeGenerator.processDrawing(this.element, PlaitBoard.getActiveHost(this.board), {
|
|
16
|
-
selected: this.selected,
|
|
17
|
-
linePoints
|
|
18
|
-
});
|
|
19
|
-
};
|
|
20
|
-
}
|
|
21
|
-
initialize() {
|
|
22
|
-
this.initializeGenerator();
|
|
23
|
-
this.shapeGenerator.processDrawing(this.element, this.getElementG());
|
|
24
|
-
const linePoints = getVectorLinePoints(this.board, this.element);
|
|
25
|
-
this.activeGenerator.processDrawing(this.element, PlaitBoard.getActiveHost(this.board), {
|
|
26
|
-
selected: this.selected,
|
|
27
|
-
linePoints
|
|
28
|
-
});
|
|
29
|
-
super.initialize();
|
|
30
|
-
}
|
|
31
|
-
onContextChanged(value, previous) {
|
|
32
|
-
const linePoints = getVectorLinePoints(this.board, this.element);
|
|
33
|
-
if (value.element !== previous.element || value.hasThemeChanged) {
|
|
34
|
-
this.shapeGenerator.processDrawing(this.element, this.getElementG());
|
|
35
|
-
this.activeGenerator.processDrawing(this.element, PlaitBoard.getActiveHost(this.board), {
|
|
36
|
-
selected: this.selected,
|
|
37
|
-
linePoints
|
|
38
|
-
});
|
|
39
|
-
}
|
|
40
|
-
else {
|
|
41
|
-
const needUpdate = value.selected !== previous.selected || this.activeGenerator.needUpdate() || value.selected;
|
|
42
|
-
if (needUpdate) {
|
|
43
|
-
this.activeGenerator.processDrawing(this.element, PlaitBoard.getActiveHost(this.board), {
|
|
44
|
-
selected: this.selected,
|
|
45
|
-
linePoints
|
|
46
|
-
});
|
|
47
|
-
}
|
|
48
|
-
}
|
|
49
|
-
}
|
|
50
|
-
destroy() {
|
|
51
|
-
super.destroy();
|
|
52
|
-
this.activeGenerator.destroy();
|
|
53
|
-
}
|
|
54
|
-
}
|
|
55
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVjdG9yLWxpbmUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vcGFja2FnZXMvZHJhdy9zcmMvdmVjdG9yLWxpbmUuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQStDLE1BQU0sYUFBYSxDQUFDO0FBRXRGLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLG9DQUFvQyxDQUFDO0FBQ3pFLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNyRCxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxTQUFTLENBQUM7QUFDOUMsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0sb0NBQW9DLENBQUM7QUFFOUUsTUFBTSxPQUFPLG1CQUNULFNBQVEsb0JBQWlEO0lBT3pEO1FBQ0ksS0FBSyxFQUFFLENBQUM7SUFDWixDQUFDO0lBRUQsbUJBQW1CO1FBQ2YsSUFBSSxDQUFDLGNBQWMsR0FBRyxJQUFJLHdCQUF3QixDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUMvRCxJQUFJLENBQUMsZUFBZSxHQUFHLElBQUksbUJBQW1CLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQzNELElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQyxtQkFBbUIsR0FBRyxHQUFHLEVBQUU7WUFDckMsTUFBTSxVQUFVLEdBQUcsbUJBQW1CLENBQUMsSUFBSSxDQUFDLEtBQUssRUFBRSxJQUFJLENBQUMsT0FBTyxDQUFFLENBQUM7WUFDbEUsSUFBSSxDQUFDLGVBQWUsQ0FBQyxjQUFjLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRSxVQUFVLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsRUFBRTtnQkFDcEYsUUFBUSxFQUFFLElBQUksQ0FBQyxRQUFRO2dCQUN2QixVQUFVO2FBQ2IsQ0FBQyxDQUFDO1FBQ1AsQ0FBQyxDQUFDO0lBQ04sQ0FBQztJQUVELFVBQVU7UUFDTixJQUFJLENBQUMsbUJBQW1CLEVBQUUsQ0FBQztRQUMzQixJQUFJLENBQUMsY0FBYyxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsT0FBTyxFQUFFLElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQyxDQUFDO1FBQ3JFLE1BQU0sVUFBVSxHQUFHLG1CQUFtQixDQUFDLElBQUksQ0FBQyxLQUFLLEVBQUUsSUFBSSxDQUFDLE9BQU8sQ0FBRSxDQUFDO1FBQ2xFLElBQUksQ0FBQyxlQUFlLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsVUFBVSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLEVBQUU7WUFDcEYsUUFBUSxFQUFFLElBQUksQ0FBQyxRQUFRO1lBQ3ZCLFVBQVU7U0FDYixDQUFDLENBQUM7UUFDSCxLQUFLLENBQUMsVUFBVSxFQUFFLENBQUM7SUFDdkIsQ0FBQztJQUVELGdCQUFnQixDQUNaLEtBQTZELEVBQzdELFFBQWdFO1FBRWhFLE1BQU0sVUFBVSxHQUFHLG1CQUFtQixDQUFDLElBQUksQ0FBQyxLQUFLLEVBQUUsSUFBSSxDQUFDLE9BQU8sQ0FBRSxDQUFDO1FBQ2xFLElBQUksS0FBSyxDQUFDLE9BQU8sS0FBSyxRQUFRLENBQUMsT0FBTyxJQUFJLEtBQUssQ0FBQyxlQUFlLEVBQUUsQ0FBQztZQUM5RCxJQUFJLENBQUMsY0FBYyxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsT0FBTyxFQUFFLElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQyxDQUFDO1lBQ3JFLElBQUksQ0FBQyxlQUFlLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsVUFBVSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLEVBQUU7Z0JBQ3BGLFFBQVEsRUFBRSxJQUFJLENBQUMsUUFBUTtnQkFDdkIsVUFBVTthQUNiLENBQUMsQ0FBQztRQUNQLENBQUM7YUFBTSxDQUFDO1lBQ0osTUFBTSxVQUFVLEdBQUcsS0FBSyxDQUFDLFFBQVEsS0FBSyxRQUFRLENBQUMsUUFBUSxJQUFJLElBQUksQ0FBQyxlQUFlLENBQUMsVUFBVSxFQUFFLElBQUksS0FBSyxDQUFDLFFBQVEsQ0FBQztZQUMvRyxJQUFJLFVBQVUsRUFBRSxDQUFDO2dCQUNiLElBQUksQ0FBQyxlQUFlLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsVUFBVSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLEVBQUU7b0JBQ3BGLFFBQVEsRUFBRSxJQUFJLENBQUMsUUFBUTtvQkFDdkIsVUFBVTtpQkFDYixDQUFDLENBQUM7WUFDUCxDQUFDO1FBQ0wsQ0FBQztJQUNMLENBQUM7SUFFRCxPQUFPO1FBQ0gsS0FBSyxDQUFDLE9BQU8sRUFBRSxDQUFDO1FBQ2hCLElBQUksQ0FBQyxlQUFlLENBQUMsT0FBTyxFQUFFLENBQUM7SUFDbkMsQ0FBQztDQUNKIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUGxhaXRCb2FyZCwgUGxhaXRQbHVnaW5FbGVtZW50Q29udGV4dCwgT25Db250ZXh0Q2hhbmdlZCB9IGZyb20gJ0BwbGFpdC9jb3JlJztcbmltcG9ydCB7IFBsYWl0VmVjdG9yTGluZSB9IGZyb20gJy4vaW50ZXJmYWNlcyc7XG5pbXBvcnQgeyBMaW5lQWN0aXZlR2VuZXJhdG9yIH0gZnJvbSAnLi9nZW5lcmF0b3JzL2xpbmUtYWN0aXZlLmdlbmVyYXRvcic7XG5pbXBvcnQgeyBDb21tb25FbGVtZW50Rmxhdm91ciB9IGZyb20gJ0BwbGFpdC9jb21tb24nO1xuaW1wb3J0IHsgZ2V0VmVjdG9yTGluZVBvaW50cyB9IGZyb20gJy4vdXRpbHMnO1xuaW1wb3J0IHsgVmVjdG9yTGluZVNoYXBlR2VuZXJhdG9yIH0gZnJvbSAnLi9nZW5lcmF0b3JzL3ZlY3Rvci1saW5lLWdlbmVyYXRvcic7XG5cbmV4cG9ydCBjbGFzcyBWZWN0b3JMaW5lQ29tcG9uZW50XG4gICAgZXh0ZW5kcyBDb21tb25FbGVtZW50Rmxhdm91cjxQbGFpdFZlY3RvckxpbmUsIFBsYWl0Qm9hcmQ+XG4gICAgaW1wbGVtZW50cyBPbkNvbnRleHRDaGFuZ2VkPFBsYWl0VmVjdG9yTGluZSwgUGxhaXRCb2FyZD5cbntcbiAgICBzaGFwZUdlbmVyYXRvciE6IFZlY3RvckxpbmVTaGFwZUdlbmVyYXRvcjtcblxuICAgIGFjdGl2ZUdlbmVyYXRvciE6IExpbmVBY3RpdmVHZW5lcmF0b3I7XG5cbiAgICBjb25zdHJ1Y3RvcigpIHtcbiAgICAgICAgc3VwZXIoKTtcbiAgICB9XG5cbiAgICBpbml0aWFsaXplR2VuZXJhdG9yKCkge1xuICAgICAgICB0aGlzLnNoYXBlR2VuZXJhdG9yID0gbmV3IFZlY3RvckxpbmVTaGFwZUdlbmVyYXRvcih0aGlzLmJvYXJkKTtcbiAgICAgICAgdGhpcy5hY3RpdmVHZW5lcmF0b3IgPSBuZXcgTGluZUFjdGl2ZUdlbmVyYXRvcih0aGlzLmJvYXJkKTtcbiAgICAgICAgdGhpcy5nZXRSZWYoKS51cGRhdGVBY3RpdmVTZWN0aW9uID0gKCkgPT4ge1xuICAgICAgICAgICAgY29uc3QgbGluZVBvaW50cyA9IGdldFZlY3RvckxpbmVQb2ludHModGhpcy5ib2FyZCwgdGhpcy5lbGVtZW50KSE7XG4gICAgICAgICAgICB0aGlzLmFjdGl2ZUdlbmVyYXRvci5wcm9jZXNzRHJhd2luZyh0aGlzLmVsZW1lbnQsIFBsYWl0Qm9hcmQuZ2V0QWN0aXZlSG9zdCh0aGlzLmJvYXJkKSwge1xuICAgICAgICAgICAgICAgIHNlbGVjdGVkOiB0aGlzLnNlbGVjdGVkLFxuICAgICAgICAgICAgICAgIGxpbmVQb2ludHNcbiAgICAgICAgICAgIH0pO1xuICAgICAgICB9O1xuICAgIH1cblxuICAgIGluaXRpYWxpemUoKTogdm9pZCB7XG4gICAgICAgIHRoaXMuaW5pdGlhbGl6ZUdlbmVyYXRvcigpO1xuICAgICAgICB0aGlzLnNoYXBlR2VuZXJhdG9yLnByb2Nlc3NEcmF3aW5nKHRoaXMuZWxlbWVudCwgdGhpcy5nZXRFbGVtZW50RygpKTtcbiAgICAgICAgY29uc3QgbGluZVBvaW50cyA9IGdldFZlY3RvckxpbmVQb2ludHModGhpcy5ib2FyZCwgdGhpcy5lbGVtZW50KSE7XG4gICAgICAgIHRoaXMuYWN0aXZlR2VuZXJhdG9yLnByb2Nlc3NEcmF3aW5nKHRoaXMuZWxlbWVudCwgUGxhaXRCb2FyZC5nZXRBY3RpdmVIb3N0KHRoaXMuYm9hcmQpLCB7XG4gICAgICAgICAgICBzZWxlY3RlZDogdGhpcy5zZWxlY3RlZCxcbiAgICAgICAgICAgIGxpbmVQb2ludHNcbiAgICAgICAgfSk7XG4gICAgICAgIHN1cGVyLmluaXRpYWxpemUoKTtcbiAgICB9XG5cbiAgICBvbkNvbnRleHRDaGFuZ2VkKFxuICAgICAgICB2YWx1ZTogUGxhaXRQbHVnaW5FbGVtZW50Q29udGV4dDxQbGFpdFZlY3RvckxpbmUsIFBsYWl0Qm9hcmQ+LFxuICAgICAgICBwcmV2aW91czogUGxhaXRQbHVnaW5FbGVtZW50Q29udGV4dDxQbGFpdFZlY3RvckxpbmUsIFBsYWl0Qm9hcmQ+XG4gICAgKSB7XG4gICAgICAgIGNvbnN0IGxpbmVQb2ludHMgPSBnZXRWZWN0b3JMaW5lUG9pbnRzKHRoaXMuYm9hcmQsIHRoaXMuZWxlbWVudCkhO1xuICAgICAgICBpZiAodmFsdWUuZWxlbWVudCAhPT0gcHJldmlvdXMuZWxlbWVudCB8fCB2YWx1ZS5oYXNUaGVtZUNoYW5nZWQpIHtcbiAgICAgICAgICAgIHRoaXMuc2hhcGVHZW5lcmF0b3IucHJvY2Vzc0RyYXdpbmcodGhpcy5lbGVtZW50LCB0aGlzLmdldEVsZW1lbnRHKCkpO1xuICAgICAgICAgICAgdGhpcy5hY3RpdmVHZW5lcmF0b3IucHJvY2Vzc0RyYXdpbmcodGhpcy5lbGVtZW50LCBQbGFpdEJvYXJkLmdldEFjdGl2ZUhvc3QodGhpcy5ib2FyZCksIHtcbiAgICAgICAgICAgICAgICBzZWxlY3RlZDogdGhpcy5zZWxlY3RlZCxcbiAgICAgICAgICAgICAgICBsaW5lUG9pbnRzXG4gICAgICAgICAgICB9KTtcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgIGNvbnN0IG5lZWRVcGRhdGUgPSB2YWx1ZS5zZWxlY3RlZCAhPT0gcHJldmlvdXMuc2VsZWN0ZWQgfHwgdGhpcy5hY3RpdmVHZW5lcmF0b3IubmVlZFVwZGF0ZSgpIHx8IHZhbHVlLnNlbGVjdGVkO1xuICAgICAgICAgICAgaWYgKG5lZWRVcGRhdGUpIHtcbiAgICAgICAgICAgICAgICB0aGlzLmFjdGl2ZUdlbmVyYXRvci5wcm9jZXNzRHJhd2luZyh0aGlzLmVsZW1lbnQsIFBsYWl0Qm9hcmQuZ2V0QWN0aXZlSG9zdCh0aGlzLmJvYXJkKSwge1xuICAgICAgICAgICAgICAgICAgICBzZWxlY3RlZDogdGhpcy5zZWxlY3RlZCxcbiAgICAgICAgICAgICAgICAgICAgbGluZVBvaW50c1xuICAgICAgICAgICAgICAgIH0pO1xuICAgICAgICAgICAgfVxuICAgICAgICB9XG4gICAgfVxuXG4gICAgZGVzdHJveSgpOiB2b2lkIHtcbiAgICAgICAgc3VwZXIuZGVzdHJveSgpO1xuICAgICAgICB0aGlzLmFjdGl2ZUdlbmVyYXRvci5kZXN0cm95KCk7XG4gICAgfVxufVxuIl19
|