@plait/draw 0.65.0 → 0.65.2
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/esm2022/utils/clipboard.mjs +26 -41
- package/fesm2022/plait-draw.mjs +24 -39
- package/fesm2022/plait-draw.mjs.map +1 -1
- package/package.json +1 -1
- package/utils/clipboard.d.ts +1 -4
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { Transforms, getElementById, idCreator } from '@plait/core';
|
|
2
|
-
import {
|
|
2
|
+
import { PlaitDrawElement } from '../interfaces';
|
|
3
3
|
import { getConnectionPoint } from './arrow-line/arrow-line-common';
|
|
4
4
|
import { updateCellIds, updateRowOrColumnIds } from './table';
|
|
5
5
|
export const buildClipboardData = (board, elements, startPoint) => {
|
|
@@ -33,49 +33,34 @@ export const buildClipboardData = (board, elements, startPoint) => {
|
|
|
33
33
|
});
|
|
34
34
|
};
|
|
35
35
|
export const insertClipboardData = (board, elements, startPoint) => {
|
|
36
|
-
const
|
|
37
|
-
const geometries = elements.filter(value => (PlaitDrawElement.isGeometry(value) && !PlaitDrawElement.isGeometryByTable(value)) || PlaitDrawElement.isImage(value));
|
|
38
|
-
const tables = elements.filter(value => PlaitDrawElement.isElementByTable(value));
|
|
39
|
-
geometries.forEach(element => {
|
|
40
|
-
const newId = idCreator();
|
|
41
|
-
updateBoundArrowLinesId(element, lines, newId);
|
|
42
|
-
element.id = newId;
|
|
43
|
-
element.points = element.points.map(point => [startPoint[0] + point[0], startPoint[1] + point[1]]);
|
|
44
|
-
Transforms.insertNode(board, element, [board.children.length]);
|
|
45
|
-
});
|
|
46
|
-
insertClipboardTableData(board, tables, startPoint, lines);
|
|
47
|
-
lines.forEach(element => {
|
|
48
|
-
element.id = idCreator();
|
|
49
|
-
element.points = element.points.map(point => [startPoint[0] + point[0], startPoint[1] + point[1]]);
|
|
50
|
-
Transforms.insertNode(board, element, [board.children.length]);
|
|
51
|
-
});
|
|
52
|
-
Transforms.addSelectionWithTemporaryElements(board, elements);
|
|
53
|
-
};
|
|
54
|
-
export const insertClipboardTableData = (board, elements, startPoint, lines) => {
|
|
36
|
+
const idsMap = {};
|
|
55
37
|
elements.forEach(element => {
|
|
56
|
-
|
|
57
|
-
updateBoundArrowLinesId(element, lines, newId);
|
|
58
|
-
element.id = newId;
|
|
59
|
-
updateRowOrColumnIds(element, 'row');
|
|
60
|
-
updateRowOrColumnIds(element, 'column');
|
|
61
|
-
updateCellIds(element.cells);
|
|
62
|
-
element.points = element.points.map(point => [startPoint[0] + point[0], startPoint[1] + point[1]]);
|
|
63
|
-
Transforms.insertNode(board, element, [board.children.length]);
|
|
38
|
+
idsMap[element.id] = idCreator();
|
|
64
39
|
});
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
40
|
+
elements.forEach(element => {
|
|
41
|
+
element.id = idsMap[element.id];
|
|
42
|
+
if (PlaitDrawElement.isArrowLine(element)) {
|
|
43
|
+
if (element.source.boundId) {
|
|
44
|
+
const boundElement = elements.find(item => [element.source.boundId, idsMap[element.source.boundId]].includes(item.id));
|
|
45
|
+
if (boundElement) {
|
|
46
|
+
element.source.boundId = idsMap[element.source.boundId];
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
if (element.target.boundId) {
|
|
50
|
+
const boundElement = elements.find(item => [element.target.boundId, idsMap[element.target.boundId]].includes(item.id));
|
|
51
|
+
if (boundElement) {
|
|
52
|
+
element.target.boundId = idsMap[element.target.boundId];
|
|
53
|
+
}
|
|
54
|
+
}
|
|
72
55
|
}
|
|
73
|
-
if (
|
|
74
|
-
|
|
56
|
+
if (PlaitDrawElement.isElementByTable(element)) {
|
|
57
|
+
updateRowOrColumnIds(element, 'row');
|
|
58
|
+
updateRowOrColumnIds(element, 'column');
|
|
59
|
+
updateCellIds(element.cells);
|
|
75
60
|
}
|
|
61
|
+
element.points = element.points.map(point => [startPoint[0] + point[0], startPoint[1] + point[1]]);
|
|
62
|
+
Transforms.insertNode(board, element, [board.children.length]);
|
|
76
63
|
});
|
|
77
|
-
|
|
78
|
-
sourceLines.forEach(sourceLine => (sourceLine.source.boundId = newId));
|
|
79
|
-
targetLines.forEach(targetLine => (targetLine.target.boundId = newId));
|
|
64
|
+
Transforms.addSelectionWithTemporaryElements(board, elements);
|
|
80
65
|
};
|
|
81
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"clipboard.js","sourceRoot":"","sources":["../../../../packages/draw/src/utils/clipboard.ts"],"names":[],"mappings":"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","sourcesContent":["import { PlaitBoard, Point, Transforms, getElementById, idCreator } from '@plait/core';\nimport { PlaitArrowLine, PlaitDrawElement, PlaitGeometry, PlaitShapeElement } from '../interfaces';\nimport { PlaitImage } from '../interfaces/image';\nimport { getConnectionPoint } from './arrow-line/arrow-line-common';\nimport { PlaitTable } from '../interfaces/table';\nimport { updateCellIds, updateRowOrColumnIds } from './table';\n\nexport const buildClipboardData = (board: PlaitBoard, elements: PlaitDrawElement[], startPoint: Point) => {\n    return elements.map(element => {\n        if (PlaitDrawElement.isShapeElement(element)) {\n            const points = element.points.map(point => [point[0] - startPoint[0], point[1] - startPoint[1]]);\n            return { ...element, points } as PlaitGeometry;\n        }\n        if (PlaitDrawElement.isArrowLine(element)) {\n            let source = { ...element.source };\n            let target = { ...element.target };\n            let points = [...element.points];\n            if (element.source.boundId) {\n                points[0] = getConnectionPoint(getElementById<PlaitGeometry>(board, element.source.boundId)!, element.source.connection!);\n                if (!getElementById(board, element.source.boundId, elements)) {\n                    delete source.boundId;\n                    delete source.connection;\n                }\n            }\n            if (element.target.boundId) {\n                points[points.length - 1] = getConnectionPoint(\n                    getElementById<PlaitGeometry>(board, element.target.boundId)!,\n                    element.target.connection!\n                );\n                if (!getElementById(board, element.target.boundId, elements)) {\n                    delete target.boundId;\n                    delete target.connection;\n                }\n            }\n            points = points.map(point => [point[0] - startPoint[0], point[1] - startPoint[1]]);\n            return { ...element, points, source, target } as PlaitArrowLine;\n        }\n        return element;\n    });\n};\n\nexport const insertClipboardData = (board: PlaitBoard, elements: PlaitDrawElement[], startPoint: Point) => {\n    const lines = elements.filter(value => PlaitDrawElement.isArrowLine(value)) as PlaitArrowLine[];\n    const geometries = elements.filter(\n        value => (PlaitDrawElement.isGeometry(value) && !PlaitDrawElement.isGeometryByTable(value)) || PlaitDrawElement.isImage(value)\n    ) as (PlaitImage | PlaitGeometry)[];\n    const tables = elements.filter(value => PlaitDrawElement.isElementByTable(value)) as PlaitTable[];\n    geometries.forEach(element => {\n        const newId = idCreator();\n        updateBoundArrowLinesId(element, lines, newId);\n        element.id = newId;\n        element.points = element.points.map(point => [startPoint[0] + point[0], startPoint[1] + point[1]]) as [Point, Point];\n        Transforms.insertNode(board, element, [board.children.length]);\n    });\n    insertClipboardTableData(board, tables, startPoint, lines);\n    lines.forEach(element => {\n        element.id = idCreator();\n        element.points = element.points.map(point => [startPoint[0] + point[0], startPoint[1] + point[1]]) as [Point, Point];\n        Transforms.insertNode(board, element, [board.children.length]);\n    });\n    Transforms.addSelectionWithTemporaryElements(board, elements);\n};\n\nexport const insertClipboardTableData = (board: PlaitBoard, elements: PlaitTable[], startPoint: Point, lines: PlaitArrowLine[]) => {\n    elements.forEach(element => {\n        const newId = idCreator();\n        updateBoundArrowLinesId(element, lines, newId);\n        element.id = newId;\n        updateRowOrColumnIds(element, 'row');\n        updateRowOrColumnIds(element, 'column');\n        updateCellIds(element.cells);\n        element.points = element.points.map(point => [startPoint[0] + point[0], startPoint[1] + point[1]]) as [Point, Point];\n        Transforms.insertNode(board, element, [board.children.length]);\n    });\n};\n\nexport const updateBoundArrowLinesId = (element: PlaitShapeElement, lines: PlaitArrowLine[], newId: string) => {\n    const sourceLines: PlaitArrowLine[] = [];\n    const targetLines: PlaitArrowLine[] = [];\n    lines.forEach(line => {\n        if (PlaitArrowLine.isBoundElementOfSource(line, element)) {\n            sourceLines.push(line);\n        }\n        if (PlaitArrowLine.isBoundElementOfTarget(line, element)) {\n            targetLines.push(line);\n        }\n    });\n    // update lines\n    sourceLines.forEach(sourceLine => (sourceLine.source.boundId = newId));\n    targetLines.forEach(targetLine => (targetLine.target.boundId = newId));\n};\n"]}
|
|
66
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"clipboard.js","sourceRoot":"","sources":["../../../../packages/draw/src/utils/clipboard.ts"],"names":[],"mappings":"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","sourcesContent":["import { PlaitBoard, Point, Transforms, getElementById, idCreator } from '@plait/core';\nimport { PlaitArrowLine, PlaitDrawElement, PlaitGeometry, PlaitShapeElement } from '../interfaces';\nimport { PlaitImage } from '../interfaces/image';\nimport { getConnectionPoint } from './arrow-line/arrow-line-common';\nimport { PlaitTable } from '../interfaces/table';\nimport { updateCellIds, updateRowOrColumnIds } from './table';\n\nexport const buildClipboardData = (board: PlaitBoard, elements: PlaitDrawElement[], startPoint: Point) => {\n    return elements.map(element => {\n        if (PlaitDrawElement.isShapeElement(element)) {\n            const points = element.points.map(point => [point[0] - startPoint[0], point[1] - startPoint[1]]);\n            return { ...element, points } as PlaitGeometry;\n        }\n        if (PlaitDrawElement.isArrowLine(element)) {\n            let source = { ...element.source };\n            let target = { ...element.target };\n            let points = [...element.points];\n            if (element.source.boundId) {\n                points[0] = getConnectionPoint(getElementById<PlaitGeometry>(board, element.source.boundId)!, element.source.connection!);\n                if (!getElementById(board, element.source.boundId, elements)) {\n                    delete source.boundId;\n                    delete source.connection;\n                }\n            }\n            if (element.target.boundId) {\n                points[points.length - 1] = getConnectionPoint(\n                    getElementById<PlaitGeometry>(board, element.target.boundId)!,\n                    element.target.connection!\n                );\n                if (!getElementById(board, element.target.boundId, elements)) {\n                    delete target.boundId;\n                    delete target.connection;\n                }\n            }\n            points = points.map(point => [point[0] - startPoint[0], point[1] - startPoint[1]]);\n            return { ...element, points, source, target } as PlaitArrowLine;\n        }\n        return element;\n    });\n};\n\nexport const insertClipboardData = (board: PlaitBoard, elements: PlaitDrawElement[], startPoint: Point) => {\n    const idsMap: Record<string, string> = {};\n    elements.forEach(element => {\n        idsMap[element.id] = idCreator();\n    });\n    elements.forEach(element => {\n        element.id = idsMap[element.id];\n        if (PlaitDrawElement.isArrowLine(element)) {\n            if (element.source.boundId) {\n                const boundElement = elements.find(item => [element.source.boundId, idsMap[element.source.boundId!]].includes(item.id));\n                if (boundElement) {\n                    element.source.boundId = idsMap[element.source.boundId];\n                }\n            }\n            if (element.target.boundId) {\n                const boundElement = elements.find(item => [element.target.boundId, idsMap[element.target.boundId!]].includes(item.id));\n                if (boundElement) {\n                    element.target.boundId = idsMap[element.target.boundId];\n                }\n            }\n        }\n        if (PlaitDrawElement.isElementByTable(element)) {\n            updateRowOrColumnIds(element as PlaitTable, 'row');\n            updateRowOrColumnIds(element as PlaitTable, 'column');\n            updateCellIds(element.cells);\n        }\n        element.points = element.points.map(point => [startPoint[0] + point[0], startPoint[1] + point[1]]) as [Point, Point];\n        Transforms.insertNode(board, element, [board.children.length]);\n    });\n    Transforms.addSelectionWithTemporaryElements(board, elements);\n};\n"]}
|
package/fesm2022/plait-draw.mjs
CHANGED
|
@@ -7325,50 +7325,35 @@ const buildClipboardData = (board, elements, startPoint) => {
|
|
|
7325
7325
|
});
|
|
7326
7326
|
};
|
|
7327
7327
|
const insertClipboardData = (board, elements, startPoint) => {
|
|
7328
|
-
const
|
|
7329
|
-
const geometries = elements.filter(value => (PlaitDrawElement.isGeometry(value) && !PlaitDrawElement.isGeometryByTable(value)) || PlaitDrawElement.isImage(value));
|
|
7330
|
-
const tables = elements.filter(value => PlaitDrawElement.isElementByTable(value));
|
|
7331
|
-
geometries.forEach(element => {
|
|
7332
|
-
const newId = idCreator();
|
|
7333
|
-
updateBoundArrowLinesId(element, lines, newId);
|
|
7334
|
-
element.id = newId;
|
|
7335
|
-
element.points = element.points.map(point => [startPoint[0] + point[0], startPoint[1] + point[1]]);
|
|
7336
|
-
Transforms.insertNode(board, element, [board.children.length]);
|
|
7337
|
-
});
|
|
7338
|
-
insertClipboardTableData(board, tables, startPoint, lines);
|
|
7339
|
-
lines.forEach(element => {
|
|
7340
|
-
element.id = idCreator();
|
|
7341
|
-
element.points = element.points.map(point => [startPoint[0] + point[0], startPoint[1] + point[1]]);
|
|
7342
|
-
Transforms.insertNode(board, element, [board.children.length]);
|
|
7343
|
-
});
|
|
7344
|
-
Transforms.addSelectionWithTemporaryElements(board, elements);
|
|
7345
|
-
};
|
|
7346
|
-
const insertClipboardTableData = (board, elements, startPoint, lines) => {
|
|
7328
|
+
const idsMap = {};
|
|
7347
7329
|
elements.forEach(element => {
|
|
7348
|
-
|
|
7349
|
-
updateBoundArrowLinesId(element, lines, newId);
|
|
7350
|
-
element.id = newId;
|
|
7351
|
-
updateRowOrColumnIds(element, 'row');
|
|
7352
|
-
updateRowOrColumnIds(element, 'column');
|
|
7353
|
-
updateCellIds(element.cells);
|
|
7354
|
-
element.points = element.points.map(point => [startPoint[0] + point[0], startPoint[1] + point[1]]);
|
|
7355
|
-
Transforms.insertNode(board, element, [board.children.length]);
|
|
7330
|
+
idsMap[element.id] = idCreator();
|
|
7356
7331
|
});
|
|
7357
|
-
|
|
7358
|
-
|
|
7359
|
-
|
|
7360
|
-
|
|
7361
|
-
|
|
7362
|
-
|
|
7363
|
-
|
|
7332
|
+
elements.forEach(element => {
|
|
7333
|
+
element.id = idsMap[element.id];
|
|
7334
|
+
if (PlaitDrawElement.isArrowLine(element)) {
|
|
7335
|
+
if (element.source.boundId) {
|
|
7336
|
+
const boundElement = elements.find(item => [element.source.boundId, idsMap[element.source.boundId]].includes(item.id));
|
|
7337
|
+
if (boundElement) {
|
|
7338
|
+
element.source.boundId = idsMap[element.source.boundId];
|
|
7339
|
+
}
|
|
7340
|
+
}
|
|
7341
|
+
if (element.target.boundId) {
|
|
7342
|
+
const boundElement = elements.find(item => [element.target.boundId, idsMap[element.target.boundId]].includes(item.id));
|
|
7343
|
+
if (boundElement) {
|
|
7344
|
+
element.target.boundId = idsMap[element.target.boundId];
|
|
7345
|
+
}
|
|
7346
|
+
}
|
|
7364
7347
|
}
|
|
7365
|
-
if (
|
|
7366
|
-
|
|
7348
|
+
if (PlaitDrawElement.isElementByTable(element)) {
|
|
7349
|
+
updateRowOrColumnIds(element, 'row');
|
|
7350
|
+
updateRowOrColumnIds(element, 'column');
|
|
7351
|
+
updateCellIds(element.cells);
|
|
7367
7352
|
}
|
|
7353
|
+
element.points = element.points.map(point => [startPoint[0] + point[0], startPoint[1] + point[1]]);
|
|
7354
|
+
Transforms.insertNode(board, element, [board.children.length]);
|
|
7368
7355
|
});
|
|
7369
|
-
|
|
7370
|
-
sourceLines.forEach(sourceLine => (sourceLine.source.boundId = newId));
|
|
7371
|
-
targetLines.forEach(targetLine => (targetLine.target.boundId = newId));
|
|
7356
|
+
Transforms.addSelectionWithTemporaryElements(board, elements);
|
|
7372
7357
|
};
|
|
7373
7358
|
|
|
7374
7359
|
const withDrawFragment = (baseBoard) => {
|