@plait/draw 0.65.1 → 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.
@@ -1,5 +1,5 @@
1
1
  import { Transforms, getElementById, idCreator } from '@plait/core';
2
- import { PlaitArrowLine, PlaitDrawElement } from '../interfaces';
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 lines = elements.filter(value => PlaitDrawElement.isArrowLine(value));
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
- const newId = idCreator();
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
- export const updateBoundArrowLinesId = (element, lines, newId) => {
67
- const sourceLines = [];
68
- const targetLines = [];
69
- lines.forEach(line => {
70
- if (PlaitArrowLine.isBoundElementOfSource(line, element)) {
71
- sourceLines.push(line);
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 (PlaitArrowLine.isBoundElementOfTarget(line, element)) {
74
- targetLines.push(line);
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
- // update lines
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":"AAAA,OAAO,EAAqB,UAAU,EAAE,cAAc,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACvF,OAAO,EAAkB,gBAAgB,EAAoC,MAAM,eAAe,CAAC;AAEnG,OAAO,EAAE,kBAAkB,EAAE,MAAM,gCAAgC,CAAC;AAEpE,OAAO,EAAE,aAAa,EAAE,oBAAoB,EAAE,MAAM,SAAS,CAAC;AAE9D,MAAM,CAAC,MAAM,kBAAkB,GAAG,CAAC,KAAiB,EAAE,QAA4B,EAAE,UAAiB,EAAE,EAAE;IACrG,OAAO,QAAQ,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE;QAC1B,IAAI,gBAAgB,CAAC,cAAc,CAAC,OAAO,CAAC,EAAE,CAAC;YAC3C,MAAM,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,UAAU,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YACjG,OAAO,EAAE,GAAG,OAAO,EAAE,MAAM,EAAmB,CAAC;QACnD,CAAC;QACD,IAAI,gBAAgB,CAAC,WAAW,CAAC,OAAO,CAAC,EAAE,CAAC;YACxC,IAAI,MAAM,GAAG,EAAE,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC;YACnC,IAAI,MAAM,GAAG,EAAE,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC;YACnC,IAAI,MAAM,GAAG,CAAC,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;YACjC,IAAI,OAAO,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;gBACzB,MAAM,CAAC,CAAC,CAAC,GAAG,kBAAkB,CAAC,cAAc,CAAgB,KAAK,EAAE,OAAO,CAAC,MAAM,CAAC,OAAO,CAAE,EAAE,OAAO,CAAC,MAAM,CAAC,UAAW,CAAC,CAAC;gBAC1H,IAAI,CAAC,cAAc,CAAC,KAAK,EAAE,OAAO,CAAC,MAAM,CAAC,OAAO,EAAE,QAAQ,CAAC,EAAE,CAAC;oBAC3D,OAAO,MAAM,CAAC,OAAO,CAAC;oBACtB,OAAO,MAAM,CAAC,UAAU,CAAC;gBAC7B,CAAC;YACL,CAAC;YACD,IAAI,OAAO,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;gBACzB,MAAM,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC,GAAG,kBAAkB,CAC1C,cAAc,CAAgB,KAAK,EAAE,OAAO,CAAC,MAAM,CAAC,OAAO,CAAE,EAC7D,OAAO,CAAC,MAAM,CAAC,UAAW,CAC7B,CAAC;gBACF,IAAI,CAAC,cAAc,CAAC,KAAK,EAAE,OAAO,CAAC,MAAM,CAAC,OAAO,EAAE,QAAQ,CAAC,EAAE,CAAC;oBAC3D,OAAO,MAAM,CAAC,OAAO,CAAC;oBACtB,OAAO,MAAM,CAAC,UAAU,CAAC;gBAC7B,CAAC;YACL,CAAC;YACD,MAAM,GAAG,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,UAAU,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YACnF,OAAO,EAAE,GAAG,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAoB,CAAC;QACpE,CAAC;QACD,OAAO,OAAO,CAAC;IACnB,CAAC,CAAC,CAAC;AACP,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,mBAAmB,GAAG,CAAC,KAAiB,EAAE,QAA4B,EAAE,UAAiB,EAAE,EAAE;IACtG,MAAM,MAAM,GAA2B,EAAE,CAAC;IAC1C,QAAQ,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE;QACvB,MAAM,CAAC,OAAO,CAAC,EAAE,CAAC,GAAG,SAAS,EAAE,CAAC;IACrC,CAAC,CAAC,CAAC;IACH,QAAQ,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE;QACvB,OAAO,CAAC,EAAE,GAAG,MAAM,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAChC,IAAI,gBAAgB,CAAC,WAAW,CAAC,OAAO,CAAC,EAAE,CAAC;YACxC,IAAI,OAAO,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;gBACzB,MAAM,YAAY,GAAG,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,OAAO,EAAE,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,OAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC;gBACxH,IAAI,YAAY,EAAE,CAAC;oBACf,OAAO,CAAC,MAAM,CAAC,OAAO,GAAG,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;gBAC5D,CAAC;YACL,CAAC;YACD,IAAI,OAAO,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;gBACzB,MAAM,YAAY,GAAG,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,OAAO,EAAE,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,OAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC;gBACxH,IAAI,YAAY,EAAE,CAAC;oBACf,OAAO,CAAC,MAAM,CAAC,OAAO,GAAG,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;gBAC5D,CAAC;YACL,CAAC;QACL,CAAC;QACD,IAAI,gBAAgB,CAAC,gBAAgB,CAAC,OAAO,CAAC,EAAE,CAAC;YAC7C,oBAAoB,CAAC,OAAqB,EAAE,KAAK,CAAC,CAAC;YACnD,oBAAoB,CAAC,OAAqB,EAAE,QAAQ,CAAC,CAAC;YACtD,aAAa,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QACjC,CAAC;QACD,OAAO,CAAC,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,EAAE,UAAU,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC,CAAmB,CAAC;QACrH,UAAU,CAAC,UAAU,CAAC,KAAK,EAAE,OAAO,EAAE,CAAC,KAAK,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC;IACnE,CAAC,CAAC,CAAC;IACH,UAAU,CAAC,iCAAiC,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC;AAClE,CAAC,CAAC","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"]}
@@ -7325,50 +7325,35 @@ const buildClipboardData = (board, elements, startPoint) => {
7325
7325
  });
7326
7326
  };
7327
7327
  const insertClipboardData = (board, elements, startPoint) => {
7328
- const lines = elements.filter(value => PlaitDrawElement.isArrowLine(value));
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
- const newId = idCreator();
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
- const updateBoundArrowLinesId = (element, lines, newId) => {
7359
- const sourceLines = [];
7360
- const targetLines = [];
7361
- lines.forEach(line => {
7362
- if (PlaitArrowLine.isBoundElementOfSource(line, element)) {
7363
- sourceLines.push(line);
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 (PlaitArrowLine.isBoundElementOfTarget(line, element)) {
7366
- targetLines.push(line);
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
- // update lines
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) => {