@plait/core 0.55.1 → 0.56.1
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/core/element/element-ref.d.ts +5 -0
- package/core/element/plugin-element.d.ts +9 -6
- package/esm2022/board/board.component.mjs +10 -7
- package/esm2022/core/element/element-ref.mjs +2 -0
- package/esm2022/core/element/plugin-element.mjs +16 -7
- package/esm2022/interfaces/board.mjs +1 -1
- package/esm2022/interfaces/element.mjs +5 -2
- package/esm2022/plugins/create-board.mjs +3 -3
- package/esm2022/plugins/with-hotkey.mjs +2 -2
- package/esm2022/plugins/with-moving.mjs +88 -10
- package/esm2022/plugins/with-related-fragment.mjs +20 -13
- package/esm2022/public-api.mjs +2 -1
- package/esm2022/utils/angle.mjs +24 -1
- package/esm2022/utils/clipboard/types.mjs +8 -1
- package/esm2022/utils/dom/common.mjs +1 -21
- package/esm2022/utils/fragment.mjs +9 -8
- package/esm2022/utils/group.mjs +19 -19
- package/esm2022/utils/math.mjs +36 -1
- package/esm2022/utils/selected-element.mjs +3 -2
- package/esm2022/utils/selection.mjs +2 -3
- package/esm2022/utils/weak-maps.mjs +2 -1
- package/fesm2022/plait-core.mjs +221 -76
- package/fesm2022/plait-core.mjs.map +1 -1
- package/interfaces/board.d.ts +3 -3
- package/interfaces/element.d.ts +6 -4
- package/package.json +1 -1
- package/plugins/with-moving.d.ts +3 -1
- package/public-api.d.ts +1 -0
- package/utils/angle.d.ts +2 -0
- package/utils/clipboard/types.d.ts +7 -0
- package/utils/dom/common.d.ts +1 -2
- package/utils/fragment.d.ts +4 -3
- package/utils/group.d.ts +5 -5
- package/utils/math.d.ts +1 -0
- package/utils/weak-maps.d.ts +2 -0
package/esm2022/utils/angle.mjs
CHANGED
|
@@ -125,4 +125,27 @@ export const getAngleBetweenPoints = (startPoint, endPoint, centerPoint) => {
|
|
|
125
125
|
const endAngle = (5 * Math.PI) / 2 + Math.atan2(endPoint[1] - centerPoint[1], endPoint[0] - centerPoint[0]);
|
|
126
126
|
return normalizeAngle(endAngle - startAngle);
|
|
127
127
|
};
|
|
128
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"angle.js","sourceRoot":"","sources":["../../../../packages/core/src/utils/angle.ts"],"names":[],"mappings":"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","sourcesContent":["import { PlaitBoard, PlaitElement, Point, RectangleClient } from '../interfaces';\nimport { Transforms } from '../transforms';\nimport { getRectangleByElements } from './element';\nimport { approximately, rotate } from './math';\n\nexport const rotatePoints = <T>(points: T, centerPoint: Point, angle: number): T => {\n    if (!angle) {\n        angle = 0;\n    }\n    if (Array.isArray(points) && typeof points[0] === 'number') {\n        return rotate(points[0], points[1], centerPoint[0], centerPoint[1], angle) as T;\n    } else {\n        return (points as Point[]).map(point => {\n            return rotate(point[0], point[1], centerPoint[0], centerPoint[1], angle);\n        }) as T;\n    }\n};\n\nexport const getSelectionAngle = (elements: PlaitElement[]) => {\n    let angle = elements[0]?.angle || 0;\n    elements.forEach(item => {\n        if (item.angle !== angle && !approximately((item.angle % (Math.PI / 2)) - (angle % (Math.PI / 2)), 0)) {\n            angle = 0;\n        }\n    });\n    return angle;\n};\n\nexport const hasSameAngle = (elements: PlaitElement[]) => {\n    if (!elements.length) {\n        return false;\n    }\n\n    const angle = elements[0].angle;\n    if (angle === undefined) {\n        return false;\n    }\n\n    return !elements.some(item => item.angle !== angle);\n};\n\nexport const getRotatedBoundingRectangle = (rectanglesCornerPoints: [Point, Point, Point, Point][], angle: number) => {\n    let rectanglesFromOrigin: RectangleClient[] = [];\n    for (let i = 0; i < rectanglesCornerPoints.length; i++) {\n        const cornerPoints = rectanglesCornerPoints[i];\n        const invertCornerPointsFromOrigin = rotatePoints(cornerPoints, [0, 0], -angle);\n        rectanglesFromOrigin.push(RectangleClient.getRectangleByPoints(invertCornerPointsFromOrigin));\n    }\n\n    const selectionRectangleFromOrigin = RectangleClient.getBoundingRectangle(rectanglesFromOrigin);\n    const selectionCornerPoints = RectangleClient.getCornerPoints(selectionRectangleFromOrigin);\n    const cornerPointsFromOrigin = rotatePoints(selectionCornerPoints, [0, 0], angle);\n    const centerPoint = RectangleClient.getCenterPoint(RectangleClient.getRectangleByPoints(cornerPointsFromOrigin));\n    return RectangleClient.getRectangleByPoints(rotatePoints(cornerPointsFromOrigin, centerPoint, -angle));\n};\n\nexport const getOffsetAfterRotate = (rectangle: RectangleClient, rotateCenterPoint: Point, angle: number) => {\n    const targetCenterPoint = RectangleClient.getCenterPoint(rectangle);\n    const [rotatedCenterPoint] = rotatePoints([targetCenterPoint], rotateCenterPoint, angle);\n    const offsetX = rotatedCenterPoint[0] - targetCenterPoint[0];\n    const offsetY = rotatedCenterPoint[1] - targetCenterPoint[1];\n    return { offsetX, offsetY };\n};\n\nexport const rotatedDataPoints = (points: Point[], rotateCenterPoint: Point, angle: number): Point[] => {\n    const { offsetX, offsetY } = getOffsetAfterRotate(RectangleClient.getRectangleByPoints(points), rotateCenterPoint, angle);\n    return points.map(p => [p[0] + offsetX, p[1] + offsetY]) as Point[];\n};\n\nexport const hasValidAngle = (node: PlaitElement) => {\n    return node.angle && node.angle !== 0;\n};\n\nexport const rotatePointsByElement = <T>(points: T, element: PlaitElement): T | null => {\n    if (hasValidAngle(element)) {\n        let rectangle = RectangleClient.getRectangleByPoints(element.points!);\n        const centerPoint = RectangleClient.getCenterPoint(rectangle);\n        return rotatePoints(points, centerPoint, element.angle);\n    } else {\n        return null;\n    }\n};\n\nexport const rotateAntiPointsByElement = <T>(points: T, element: PlaitElement): T | null => {\n    if (hasValidAngle(element)) {\n        let rectangle = RectangleClient.getRectangleByPoints(element.points!);\n        const centerPoint = RectangleClient.getCenterPoint(rectangle);\n        return rotatePoints(points, centerPoint, -element.angle);\n    } else {\n        return null;\n    }\n};\n\nexport const getRectangleByAngle = (rectangle: RectangleClient, angle: number) => {\n    if (angle) {\n        const cornerPoints = RectangleClient.getCornerPoints(rectangle);\n        const centerPoint = RectangleClient.getCenterPoint(rectangle);\n        return RectangleClient.getRectangleByPoints(rotatePoints(cornerPoints, centerPoint, angle));\n    } else {\n        return null;\n    }\n};\n\nexport const isAxisChangedByAngle = (angle: number) => {\n    const unitAngle = Math.abs(angle) % Math.PI;\n    return unitAngle >= (1 / 4) * Math.PI && unitAngle <= (3 / 4) * Math.PI;\n};\n\nexport function degreesToRadians(d: number): number {\n    return (d / 180) * Math.PI;\n}\n\nexport function radiansToDegrees(r: number): number {\n    return (r / Math.PI) * 180;\n}\n\nexport function rotateElements(board: PlaitBoard, elements: PlaitElement[], angle: number) {\n    const selectionRectangle = getRectangleByElements(board, elements, false);\n    const selectionCenterPoint = RectangleClient.getCenterPoint(selectionRectangle);\n    elements.forEach(item => {\n        const originAngle = item.angle;\n        const points = rotatedDataPoints(item.points!, selectionCenterPoint, normalizeAngle(angle));\n        const path = PlaitBoard.findPath(board, item);\n        Transforms.setNode(board, { points, angle: normalizeAngle(originAngle + angle) }, path);\n    });\n}\n\nexport const normalizeAngle = (angle: number): number => {\n    if (angle < 0) {\n        return angle + 2 * Math.PI;\n    }\n    if (angle >= 2 * Math.PI) {\n        return angle - 2 * Math.PI;\n    }\n    return angle;\n};\n\nexport const getAngleBetweenPoints = (startPoint: Point, endPoint: Point, centerPoint: Point): number => {\n    const startAngle = (5 * Math.PI) / 2 + Math.atan2(startPoint[1] - centerPoint[1], startPoint[0] - centerPoint[0]);\n    const endAngle = (5 * Math.PI) / 2 + Math.atan2(endPoint[1] - centerPoint[1], endPoint[0] - centerPoint[0]);\n    return normalizeAngle(endAngle - startAngle);\n};\n"]}
|
|
128
|
+
export const getAngleByElement = (element) => {
|
|
129
|
+
return element?.angle;
|
|
130
|
+
};
|
|
131
|
+
export const setAngleForG = (g, centerPoint, angle) => {
|
|
132
|
+
if (angle === 0) {
|
|
133
|
+
g.removeAttribute('transform');
|
|
134
|
+
return;
|
|
135
|
+
}
|
|
136
|
+
var centerX = centerPoint[0];
|
|
137
|
+
var centerY = centerPoint[1];
|
|
138
|
+
let cosTheta = Math.cos(angle);
|
|
139
|
+
let sinTheta = Math.sin(angle);
|
|
140
|
+
let transformMatrix = [
|
|
141
|
+
cosTheta,
|
|
142
|
+
sinTheta,
|
|
143
|
+
-sinTheta,
|
|
144
|
+
cosTheta,
|
|
145
|
+
centerX * (1 - cosTheta) + centerY * sinTheta,
|
|
146
|
+
centerY * (1 - cosTheta) - centerX * sinTheta
|
|
147
|
+
];
|
|
148
|
+
let matrix = 'matrix(' + transformMatrix.join(',') + ')';
|
|
149
|
+
g.setAttribute('transform', `${matrix}`);
|
|
150
|
+
};
|
|
151
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"angle.js","sourceRoot":"","sources":["../../../../packages/core/src/utils/angle.ts"],"names":[],"mappings":"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","sourcesContent":["import { PlaitBoard, PlaitElement, Point, RectangleClient } from '../interfaces';\nimport { Transforms } from '../transforms';\nimport { getRectangleByElements } from './element';\nimport { approximately, rotate } from './math';\n\nexport const rotatePoints = <T>(points: T, centerPoint: Point, angle: number): T => {\n    if (!angle) {\n        angle = 0;\n    }\n    if (Array.isArray(points) && typeof points[0] === 'number') {\n        return rotate(points[0], points[1], centerPoint[0], centerPoint[1], angle) as T;\n    } else {\n        return (points as Point[]).map(point => {\n            return rotate(point[0], point[1], centerPoint[0], centerPoint[1], angle);\n        }) as T;\n    }\n};\n\nexport const getSelectionAngle = (elements: PlaitElement[]) => {\n    let angle = elements[0]?.angle || 0;\n    elements.forEach(item => {\n        if (item.angle !== angle && !approximately((item.angle % (Math.PI / 2)) - (angle % (Math.PI / 2)), 0)) {\n            angle = 0;\n        }\n    });\n    return angle;\n};\n\nexport const hasSameAngle = (elements: PlaitElement[]) => {\n    if (!elements.length) {\n        return false;\n    }\n\n    const angle = elements[0].angle;\n    if (angle === undefined) {\n        return false;\n    }\n\n    return !elements.some(item => item.angle !== angle);\n};\n\nexport const getRotatedBoundingRectangle = (rectanglesCornerPoints: [Point, Point, Point, Point][], angle: number) => {\n    let rectanglesFromOrigin: RectangleClient[] = [];\n    for (let i = 0; i < rectanglesCornerPoints.length; i++) {\n        const cornerPoints = rectanglesCornerPoints[i];\n        const invertCornerPointsFromOrigin = rotatePoints(cornerPoints, [0, 0], -angle);\n        rectanglesFromOrigin.push(RectangleClient.getRectangleByPoints(invertCornerPointsFromOrigin));\n    }\n\n    const selectionRectangleFromOrigin = RectangleClient.getBoundingRectangle(rectanglesFromOrigin);\n    const selectionCornerPoints = RectangleClient.getCornerPoints(selectionRectangleFromOrigin);\n    const cornerPointsFromOrigin = rotatePoints(selectionCornerPoints, [0, 0], angle);\n    const centerPoint = RectangleClient.getCenterPoint(RectangleClient.getRectangleByPoints(cornerPointsFromOrigin));\n    return RectangleClient.getRectangleByPoints(rotatePoints(cornerPointsFromOrigin, centerPoint, -angle));\n};\n\nexport const getOffsetAfterRotate = (rectangle: RectangleClient, rotateCenterPoint: Point, angle: number) => {\n    const targetCenterPoint = RectangleClient.getCenterPoint(rectangle);\n    const [rotatedCenterPoint] = rotatePoints([targetCenterPoint], rotateCenterPoint, angle);\n    const offsetX = rotatedCenterPoint[0] - targetCenterPoint[0];\n    const offsetY = rotatedCenterPoint[1] - targetCenterPoint[1];\n    return { offsetX, offsetY };\n};\n\nexport const rotatedDataPoints = (points: Point[], rotateCenterPoint: Point, angle: number): Point[] => {\n    const { offsetX, offsetY } = getOffsetAfterRotate(RectangleClient.getRectangleByPoints(points), rotateCenterPoint, angle);\n    return points.map(p => [p[0] + offsetX, p[1] + offsetY]) as Point[];\n};\n\nexport const hasValidAngle = (node: PlaitElement) => {\n    return node.angle && node.angle !== 0;\n};\n\nexport const rotatePointsByElement = <T>(points: T, element: PlaitElement): T | null => {\n    if (hasValidAngle(element)) {\n        let rectangle = RectangleClient.getRectangleByPoints(element.points!);\n        const centerPoint = RectangleClient.getCenterPoint(rectangle);\n        return rotatePoints(points, centerPoint, element.angle);\n    } else {\n        return null;\n    }\n};\n\nexport const rotateAntiPointsByElement = <T>(points: T, element: PlaitElement): T | null => {\n    if (hasValidAngle(element)) {\n        let rectangle = RectangleClient.getRectangleByPoints(element.points!);\n        const centerPoint = RectangleClient.getCenterPoint(rectangle);\n        return rotatePoints(points, centerPoint, -element.angle);\n    } else {\n        return null;\n    }\n};\n\nexport const getRectangleByAngle = (rectangle: RectangleClient, angle: number) => {\n    if (angle) {\n        const cornerPoints = RectangleClient.getCornerPoints(rectangle);\n        const centerPoint = RectangleClient.getCenterPoint(rectangle);\n        return RectangleClient.getRectangleByPoints(rotatePoints(cornerPoints, centerPoint, angle));\n    } else {\n        return null;\n    }\n};\n\nexport const isAxisChangedByAngle = (angle: number) => {\n    const unitAngle = Math.abs(angle) % Math.PI;\n    return unitAngle >= (1 / 4) * Math.PI && unitAngle <= (3 / 4) * Math.PI;\n};\n\nexport function degreesToRadians(d: number): number {\n    return (d / 180) * Math.PI;\n}\n\nexport function radiansToDegrees(r: number): number {\n    return (r / Math.PI) * 180;\n}\n\nexport function rotateElements(board: PlaitBoard, elements: PlaitElement[], angle: number) {\n    const selectionRectangle = getRectangleByElements(board, elements, false);\n    const selectionCenterPoint = RectangleClient.getCenterPoint(selectionRectangle);\n    elements.forEach(item => {\n        const originAngle = item.angle;\n        const points = rotatedDataPoints(item.points!, selectionCenterPoint, normalizeAngle(angle));\n        const path = PlaitBoard.findPath(board, item);\n        Transforms.setNode(board, { points, angle: normalizeAngle(originAngle + angle) }, path);\n    });\n}\n\nexport const normalizeAngle = (angle: number): number => {\n    if (angle < 0) {\n        return angle + 2 * Math.PI;\n    }\n    if (angle >= 2 * Math.PI) {\n        return angle - 2 * Math.PI;\n    }\n    return angle;\n};\n\nexport const getAngleBetweenPoints = (startPoint: Point, endPoint: Point, centerPoint: Point): number => {\n    const startAngle = (5 * Math.PI) / 2 + Math.atan2(startPoint[1] - centerPoint[1], startPoint[0] - centerPoint[0]);\n    const endAngle = (5 * Math.PI) / 2 + Math.atan2(endPoint[1] - centerPoint[1], endPoint[0] - centerPoint[0]);\n    return normalizeAngle(endAngle - startAngle);\n};\n\nexport const getAngleByElement = (element: PlaitElement): number => {\n    return element?.angle;\n};\n\nexport const setAngleForG = (g: SVGGElement, centerPoint: Point, angle: number) => {\n    if (angle === 0) {\n        g.removeAttribute('transform');\n        return;\n    }\n    var centerX = centerPoint[0];\n    var centerY = centerPoint[1];\n\n    let cosTheta = Math.cos(angle);\n    let sinTheta = Math.sin(angle);\n\n    let transformMatrix = [\n        cosTheta,\n        sinTheta,\n        -sinTheta,\n        cosTheta,\n        centerX * (1 - cosTheta) + centerY * sinTheta,\n        centerY * (1 - cosTheta) - centerX * sinTheta\n    ];\n\n    let matrix = 'matrix(' + transformMatrix.join(',') + ')';\n    g.setAttribute('transform', `${matrix}`);\n};\n"]}
|
|
@@ -3,4 +3,11 @@ export var WritableClipboardType;
|
|
|
3
3
|
WritableClipboardType["medias"] = "medias";
|
|
4
4
|
WritableClipboardType["elements"] = "elements";
|
|
5
5
|
})(WritableClipboardType || (WritableClipboardType = {}));
|
|
6
|
-
|
|
6
|
+
export var WritableClipboardOperationType;
|
|
7
|
+
(function (WritableClipboardOperationType) {
|
|
8
|
+
WritableClipboardOperationType["copy"] = "copy";
|
|
9
|
+
WritableClipboardOperationType["cut"] = "cut";
|
|
10
|
+
WritableClipboardOperationType["duplicate"] = "duplicate";
|
|
11
|
+
WritableClipboardOperationType["paste"] = "paste";
|
|
12
|
+
})(WritableClipboardOperationType || (WritableClipboardOperationType = {}));
|
|
13
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9jb3JlL3NyYy91dGlscy9jbGlwYm9hcmQvdHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsTUFBTSxDQUFOLElBQVkscUJBR1g7QUFIRCxXQUFZLHFCQUFxQjtJQUM3QiwwQ0FBbUIsQ0FBQTtJQUNuQiw4Q0FBdUIsQ0FBQTtBQUMzQixDQUFDLEVBSFcscUJBQXFCLEtBQXJCLHFCQUFxQixRQUdoQztBQUVELE1BQU0sQ0FBTixJQUFZLDhCQUtYO0FBTEQsV0FBWSw4QkFBOEI7SUFDdEMsK0NBQWUsQ0FBQTtJQUNmLDZDQUFhLENBQUE7SUFDYix5REFBeUIsQ0FBQTtJQUN6QixpREFBaUIsQ0FBQTtBQUNyQixDQUFDLEVBTFcsOEJBQThCLEtBQTlCLDhCQUE4QixRQUt6QyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBsYWl0RWxlbWVudCB9IGZyb20gJy4uLy4uL2ludGVyZmFjZXMnO1xuXG5leHBvcnQgZW51bSBXcml0YWJsZUNsaXBib2FyZFR5cGUge1xuICAgICdtZWRpYXMnID0gJ21lZGlhcycsXG4gICAgJ2VsZW1lbnRzJyA9ICdlbGVtZW50cydcbn1cblxuZXhwb3J0IGVudW0gV3JpdGFibGVDbGlwYm9hcmRPcGVyYXRpb25UeXBlIHtcbiAgICAnY29weScgPSAnY29weScsXG4gICAgJ2N1dCcgPSAnY3V0JyxcbiAgICAnZHVwbGljYXRlJyA9ICdkdXBsaWNhdGUnLFxuICAgICdwYXN0ZScgPSAncGFzdGUnXG59XG5cbmV4cG9ydCB0eXBlIFdyaXRhYmxlQ2xpcGJvYXJkRGF0YSA9IFBsYWl0RWxlbWVudFtdIHwgYW55W107XG5cbmV4cG9ydCBpbnRlcmZhY2UgV3JpdGFibGVDbGlwYm9hcmRDb250ZXh0IHtcbiAgICB0ZXh0OiBzdHJpbmc7XG4gICAgdHlwZTogV3JpdGFibGVDbGlwYm9hcmRUeXBlO1xuICAgIGVsZW1lbnRzOiBXcml0YWJsZUNsaXBib2FyZERhdGE7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ2xpcGJvYXJkRGF0YSB7XG4gICAgZmlsZXM/OiBGaWxlW107XG4gICAgZWxlbWVudHM/OiBQbGFpdEVsZW1lbnRbXTtcbiAgICBtZWRpYXM/OiBhbnlbXTtcbiAgICB0ZXh0Pzogc3RyaW5nO1xuICAgIG9wZXJhdGlvblR5cGU/OiBXcml0YWJsZUNsaXBib2FyZE9wZXJhdGlvblR5cGU7XG59XG4iXX0=
|
|
@@ -23,26 +23,6 @@ export function createRect(rectangle, options) {
|
|
|
23
23
|
export const setStrokeLinecap = (g, value) => {
|
|
24
24
|
g.setAttribute('stroke-linecap', value);
|
|
25
25
|
};
|
|
26
|
-
export const setAngleForG = (g, centerPoint, angle) => {
|
|
27
|
-
if (angle === 0) {
|
|
28
|
-
g.removeAttribute('transform');
|
|
29
|
-
return;
|
|
30
|
-
}
|
|
31
|
-
var centerX = centerPoint[0];
|
|
32
|
-
var centerY = centerPoint[1];
|
|
33
|
-
let cosTheta = Math.cos(angle);
|
|
34
|
-
let sinTheta = Math.sin(angle);
|
|
35
|
-
let transformMatrix = [
|
|
36
|
-
cosTheta,
|
|
37
|
-
sinTheta,
|
|
38
|
-
-sinTheta,
|
|
39
|
-
cosTheta,
|
|
40
|
-
centerX * (1 - cosTheta) + centerY * sinTheta,
|
|
41
|
-
centerY * (1 - cosTheta) - centerX * sinTheta
|
|
42
|
-
];
|
|
43
|
-
let matrix = 'matrix(' + transformMatrix.join(',') + ')';
|
|
44
|
-
g.setAttribute('transform', `${matrix}`);
|
|
45
|
-
};
|
|
46
26
|
export const setPathStrokeLinecap = (g, value) => {
|
|
47
27
|
g.querySelectorAll('path').forEach(path => {
|
|
48
28
|
path.setAttribute('stroke-linecap', value);
|
|
@@ -89,4 +69,4 @@ export const isSecondaryPointer = (event) => {
|
|
|
89
69
|
export const isMainPointer = (event) => {
|
|
90
70
|
return event.button === POINTER_BUTTON.MAIN;
|
|
91
71
|
};
|
|
92
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
72
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tbW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvY29yZS9zcmMvdXRpbHMvZG9tL2NvbW1vbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFHakQsTUFBTSxDQUFDLE1BQU0sRUFBRSxHQUFHLDRCQUE0QixDQUFDO0FBRS9DLE1BQU0sVUFBVSxPQUFPO0lBQ25CLE1BQU0sSUFBSSxHQUFHLFFBQVEsQ0FBQyxlQUFlLENBQUMsRUFBRSxFQUFFLEdBQUcsQ0FBQyxDQUFDO0lBQy9DLE9BQU8sSUFBSSxDQUFDO0FBQ2hCLENBQUM7QUFFRCxNQUFNLFVBQVUsVUFBVTtJQUN0QixNQUFNLElBQUksR0FBRyxRQUFRLENBQUMsZUFBZSxDQUFDLEVBQUUsRUFBRSxNQUFNLENBQUMsQ0FBQztJQUNsRCxPQUFPLElBQUksQ0FBQztBQUNoQixDQUFDO0FBRUQsTUFBTSxVQUFVLFVBQVUsQ0FBQyxTQUEwQixFQUFFLE9BQWlCO0lBQ3BFLE1BQU0sSUFBSSxHQUFHLFFBQVEsQ0FBQyxlQUFlLENBQUMsRUFBRSxFQUFFLE1BQU0sQ0FBQyxDQUFDO0lBQ2xELElBQUksQ0FBQyxZQUFZLENBQUMsR0FBRyxFQUFFLEdBQUcsU0FBUyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUM7SUFDekMsSUFBSSxDQUFDLFlBQVksQ0FBQyxHQUFHLEVBQUUsR0FBRyxTQUFTLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQztJQUN6QyxJQUFJLENBQUMsWUFBWSxDQUFDLE9BQU8sRUFBRSxHQUFHLFNBQVMsQ0FBQyxLQUFLLEVBQUUsQ0FBQyxDQUFDO0lBQ2pELElBQUksQ0FBQyxZQUFZLENBQUMsUUFBUSxFQUFFLEdBQUcsU0FBUyxDQUFDLE1BQU0sRUFBRSxDQUFDLENBQUM7SUFDbkQsS0FBSyxJQUFJLEdBQUcsSUFBSSxPQUFPLEVBQUUsQ0FBQztRQUN0QixN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QUFDaEQsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgT3B0aW9ucyB9IGZyb20gJ3JvdWdoanMvYmluL2NvcmUnO1xuaW1wb3J0IHsgUE9JTlRFUl9CVVRUT04gfSBmcm9tICcuLi8uLi9jb25zdGFudHMnO1xuaW1wb3J0IHsgUmVjdGFuZ2xlQ2xpZW50IH0gZnJvbSAnLi4vLi4vaW50ZXJmYWNlcyc7XG5cbmV4cG9ydCBjb25zdCBOUyA9ICdodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2Zyc7XG5cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVHKCkge1xuICAgIGNvbnN0IG5ld0cgPSBkb2N1bWVudC5jcmVhdGVFbGVtZW50TlMoTlMsICdnJyk7XG4gICAgcmV0dXJuIG5ld0c7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVQYXRoKCkge1xuICAgIGNvbnN0IG5ld0cgPSBkb2N1bWVudC5jcmVhdGVFbGVtZW50TlMoTlMsICdwYXRoJyk7XG4gICAgcmV0dXJuIG5ld0c7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVSZWN0KHJlY3RhbmdsZTogUmVjdGFuZ2xlQ2xpZW50LCBvcHRpb25zPzogT3B0aW9ucykge1xuICAgIGNvbnN0IHJlY3QgPSBkb2N1bWVudC5jcmVhdGVFbGVtZW50TlMoTlMsICdyZWN0Jyk7XG4gICAgcmVjdC5zZXRBdHRyaWJ1dGUoJ3gnLCBgJHtyZWN0YW5nbGUueH1gKTtcbiAgICByZWN0LnNldEF0dHJpYnV0ZSgneScsIGAke3JlY3RhbmdsZS55fWApO1xuICAgIHJlY3Quc2V0QXR0cmlidXRlKCd3aWR0aCcsIGAke3JlY3RhbmdsZS53aWR0aH1gKTtcbiAgICByZWN0LnNldEF0dHJpYnV0ZSgnaGVpZ2h0JywgYCR7cmVjdGFuZ2xlLmhlaWdodH1gKTtcbiAgICBmb3IgKGxldCBrZXkgaW4gb3B0aW9ucykge1xuICAgICAgICBjb25zdCBvcHRpb25LZXkgPSBrZXkgYXMga2V5b2YgT3B0aW9ucztcbiAgICAgICAgcmVjdC5zZXRBdHRyaWJ1dGUoa2V5LCBgJHtvcHRpb25zW29wdGlvbktleV19YCk7XG4gICAgfVxuICAgIHJldHVybiByZWN0O1xufVxuXG5leHBvcnQgY29uc3Qgc2V0U3Ryb2tlTGluZWNhcCA9IChnOiBTVkdHRWxlbWVudCwgdmFsdWU6ICdyb3VuZCcgfCAnc3F1YXJlJykgPT4ge1xuICAgIGcuc2V0QXR0cmlidXRlKCdzdHJva2UtbGluZWNhcCcsIHZhbHVlKTtcbn07XG5cbmV4cG9ydCBjb25zdCBzZXRQYXRoU3Ryb2tlTGluZWNhcCA9IChnOiBTVkdHRWxlbWVudCwgdmFsdWU6ICdyb3VuZCcgfCAnc3F1YXJlJykgPT4ge1xuICAgIGcucXVlcnlTZWxlY3RvckFsbCgncGF0aCcpLmZvckVhY2gocGF0aCA9PiB7XG4gICAgICAgIHBhdGguc2V0QXR0cmlidXRlKCdzdHJva2UtbGluZWNhcCcsIHZhbHVlKTtcbiAgICB9KTtcbn07XG5cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVNYXNrKCkge1xuICAgIHJldHVybiBkb2N1bWVudC5jcmVhdGVFbGVtZW50TlMoTlMsICdtYXNrJyk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVTVkcoKSB7XG4gICAgY29uc3Qgc3ZnID0gZG9jdW1lbnQuY3JlYXRlRWxlbWVudE5TKE5TLCAnc3ZnJyk7XG4gICAgcmV0dXJuIHN2Zztcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZVRleHQoeDogbnVtYmVyLCB5OiBudW1iZXIsIGZpbGw6IHN0cmluZywgdGV4dENvbnRlbnQ6IHN0cmluZykge1xuICAgIHZhciB0ZXh0ID0gZG9jdW1lbnQuY3JlYXRlRWxlbWVudE5TKE5TLCAndGV4dCcpO1xuICAgIHRleHQuc2V0QXR0cmlidXRlKCd4JywgYCR7eH1gKTtcbiAgICB0ZXh0LnNldEF0dHJpYnV0ZSgneScsIGAke3l9YCk7XG4gICAgdGV4dC5zZXRBdHRyaWJ1dGUoJ2ZpbGwnLCBmaWxsKTtcbiAgICB0ZXh0LnRleHRDb250ZW50ID0gdGV4dENvbnRlbnQ7XG4gICAgcmV0dXJuIHRleHQ7XG59XG5cbi8qKlxuICogQ2hlY2sgaWYgYSBET00gbm9kZSBpcyBhbiBlbGVtZW50IG5vZGUuXG4gKi9cbmV4cG9ydCBjb25zdCBpc0RPTUVsZW1lbnQgPSAodmFsdWU6IGFueSk6IHZhbHVlIGlzIEVsZW1lbnQgPT4ge1xuICAgIHJldHVybiBpc0RPTU5vZGUodmFsdWUpICYmIHZhbHVlLm5vZGVUeXBlID09PSAxO1xufTtcblxuLyoqXG4gKiBDaGVjayBpZiBhIHZhbHVlIGlzIGEgRE9NIG5vZGUuXG4gKi9cbmV4cG9ydCBjb25zdCBpc0RPTU5vZGUgPSAodmFsdWU6IGFueSk6IHZhbHVlIGlzIE5vZGUgPT4ge1xuICAgIHJldHVybiB2YWx1ZSBpbnN0YW5jZW9mIHdpbmRvdy5Ob2RlO1xufTtcblxuZXhwb3J0IGNvbnN0IGhhc0lucHV0T3JUZXh0YXJlYVRhcmdldCA9ICh0YXJnZXQ6IEV2ZW50VGFyZ2V0IHwgbnVsbCkgPT4ge1xuICAgIGlmIChpc0RPTUVsZW1lbnQodGFyZ2V0KSkge1xuICAgICAgICBpZiAodGFyZ2V0LnRhZ05hbWUgPT09ICdJTlBVVCcgfHwgdGFyZ2V0LnRhZ05hbWUgPT09ICdURVhUQVJFQScpIHtcbiAgICAgICAgICAgIHJldHVybiB0cnVlO1xuICAgICAgICB9XG4gICAgfVxuICAgIHJldHVybiBmYWxzZTtcbn07XG5cbmV4cG9ydCBjb25zdCBpc1NlY29uZGFyeVBvaW50ZXIgPSAoZXZlbnQ6IE1vdXNlRXZlbnQpID0+IHtcbiAgICByZXR1cm4gZXZlbnQuYnV0dG9uID09PSBQT0lOVEVSX0JVVFRPTi5TRUNPTkRBUlk7XG59O1xuXG5leHBvcnQgY29uc3QgaXNNYWluUG9pbnRlciA9IChldmVudDogTW91c2VFdmVudCkgPT4ge1xuICAgIHJldHVybiBldmVudC5idXR0b24gPT09IFBPSU5URVJfQlVUVE9OLk1BSU47XG59O1xuIl19
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { WritableClipboardOperationType } from './clipboard';
|
|
1
2
|
import { setClipboardData } from './clipboard/clipboard';
|
|
2
3
|
import { getRectangleByElements } from './element';
|
|
3
4
|
import { getSelectedElements } from './selected-element';
|
|
@@ -5,22 +6,22 @@ export const deleteFragment = (board) => {
|
|
|
5
6
|
const elements = board.getDeletedFragment([]);
|
|
6
7
|
board.deleteFragment(elements);
|
|
7
8
|
};
|
|
8
|
-
export const setFragment = (board,
|
|
9
|
+
export const setFragment = (board, operationType, clipboardData) => {
|
|
9
10
|
const selectedElements = getSelectedElements(board);
|
|
10
11
|
const rectangle = getRectangleByElements(board, selectedElements, false);
|
|
11
|
-
const clipboardContext = board.buildFragment(null, rectangle,
|
|
12
|
+
const clipboardContext = board.buildFragment(null, rectangle, operationType);
|
|
12
13
|
clipboardContext && setClipboardData(clipboardData, clipboardContext);
|
|
13
14
|
};
|
|
14
|
-
export const duplicateElements = (board, elements) => {
|
|
15
|
-
const
|
|
16
|
-
const
|
|
17
|
-
const clipboardContext = board.buildFragment(null,
|
|
15
|
+
export const duplicateElements = (board, elements, point) => {
|
|
16
|
+
const targetElements = elements?.length ? elements : getSelectedElements(board);
|
|
17
|
+
const targetRectangle = getRectangleByElements(board, targetElements, false);
|
|
18
|
+
const clipboardContext = board.buildFragment(null, targetRectangle, WritableClipboardOperationType.duplicate, targetElements);
|
|
18
19
|
const stringifiedContext = clipboardContext && JSON.stringify(clipboardContext);
|
|
19
20
|
const clonedContext = stringifiedContext && JSON.parse(stringifiedContext);
|
|
20
21
|
clonedContext &&
|
|
21
22
|
board.insertFragment({
|
|
22
23
|
...clonedContext,
|
|
23
24
|
text: undefined
|
|
24
|
-
}, [
|
|
25
|
+
}, point || [targetRectangle.x + targetRectangle.width / 2, targetRectangle.y + targetRectangle.height / 2], WritableClipboardOperationType.duplicate);
|
|
25
26
|
};
|
|
26
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
27
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZnJhZ21lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9jb3JlL3NyYy91dGlscy9mcmFnbWVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsOEJBQThCLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFDN0QsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFDekQsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sV0FBVyxDQUFDO0FBQ25ELE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBRXpELE1BQU0sQ0FBQyxNQUFNLGNBQWMsR0FBRyxDQUFDLEtBQWlCLEVBQUUsRUFBRTtJQUNoRCxNQUFNLFFBQVEsR0FBRyxLQUFLLENBQUMsa0JBQWtCLENBQUMsRUFBRSxDQUFDLENBQUM7SUFDOUMsS0FBSyxDQUFDLGNBQWMsQ0FBQyxRQUFRLENBQUMsQ0FBQztBQUNuQyxDQUFDLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxXQUFXLEdBQUcsQ0FBQyxLQUFpQixFQUFFLGFBQTZDLEVBQUUsYUFBa0MsRUFBRSxFQUFFO0lBQ2hJLE1BQU0sZ0JBQWdCLEdBQUcsbUJBQW1CLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDcEQsTUFBTSxTQUFTLEdBQUcsc0JBQXNCLENBQUMsS0FBSyxFQUFFLGdCQUFnQixFQUFFLEtBQUssQ0FBQyxDQUFDO0lBQ3pFLE1BQU0sZ0JBQWdCLEdBQUcsS0FBSyxDQUFDLGFBQWEsQ0FBQyxJQUFJLEVBQUUsU0FBUyxFQUFFLGFBQWEsQ0FBQyxDQUFDO0lBQzdFLGdCQUFnQixJQUFJLGdCQUFnQixDQUFDLGFBQWEsRUFBRSxnQkFBZ0IsQ0FBQyxDQUFDO0FBQzFFLENBQUMsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLGlCQUFpQixHQUFHLENBQUMsS0FBaUIsRUFBRSxRQUF5QixFQUFFLEtBQWEsRUFBRSxFQUFFO0lBQzdGLE1BQU0sY0FBYyxHQUFHLFFBQVEsRUFBRSxNQUFNLENBQUMsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsbUJBQW1CLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDaEYsTUFBTSxlQUFlLEdBQUcsc0JBQXNCLENBQUMsS0FBSyxFQUFFLGNBQWMsRUFBRSxLQUFLLENBQUMsQ0FBQztJQUM3RSxNQUFNLGdCQUFnQixHQUFHLEtBQUssQ0FBQyxhQUFhLENBQUMsSUFBSSxFQUFFLGVBQWUsRUFBRSw4QkFBOEIsQ0FBQyxTQUFTLEVBQUUsY0FBYyxDQUFDLENBQUM7SUFDOUgsTUFBTSxrQkFBa0IsR0FBRyxnQkFBZ0IsSUFBSSxJQUFJLENBQUMsU0FBUyxDQUFDLGdCQUFnQixDQUFDLENBQUM7SUFDaEYsTUFBTSxhQUFhLEdBQUcsa0JBQWtCLElBQUksSUFBSSxDQUFDLEtBQUssQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDO0lBQzNFLGFBQWE7UUFDVCxLQUFLLENBQUMsY0FBYyxDQUNoQjtZQUNJLEdBQUcsYUFBYTtZQUNoQixJQUFJLEVBQUUsU0FBUztTQUNsQixFQUNELEtBQUssSUFBSSxDQUFDLGVBQWUsQ0FBQyxDQUFDLEdBQUcsZUFBZSxDQUFDLEtBQUssR0FBRyxDQUFDLEVBQUUsZUFBZSxDQUFDLENBQUMsR0FBRyxlQUFlLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQyxFQUN4Ryw4QkFBOEIsQ0FBQyxTQUFTLENBQzNDLENBQUM7QUFDVixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQbGFpdEJvYXJkLCBQbGFpdEVsZW1lbnQsIFBvaW50IH0gZnJvbSAnLi4vaW50ZXJmYWNlcyc7XG5pbXBvcnQgeyBXcml0YWJsZUNsaXBib2FyZE9wZXJhdGlvblR5cGUgfSBmcm9tICcuL2NsaXBib2FyZCc7XG5pbXBvcnQgeyBzZXRDbGlwYm9hcmREYXRhIH0gZnJvbSAnLi9jbGlwYm9hcmQvY2xpcGJvYXJkJztcbmltcG9ydCB7IGdldFJlY3RhbmdsZUJ5RWxlbWVudHMgfSBmcm9tICcuL2VsZW1lbnQnO1xuaW1wb3J0IHsgZ2V0U2VsZWN0ZWRFbGVtZW50cyB9IGZyb20gJy4vc2VsZWN0ZWQtZWxlbWVudCc7XG5cbmV4cG9ydCBjb25zdCBkZWxldGVGcmFnbWVudCA9IChib2FyZDogUGxhaXRCb2FyZCkgPT4ge1xuICAgIGNvbnN0IGVsZW1lbnRzID0gYm9hcmQuZ2V0RGVsZXRlZEZyYWdtZW50KFtdKTtcbiAgICBib2FyZC5kZWxldGVGcmFnbWVudChlbGVtZW50cyk7XG59O1xuXG5leHBvcnQgY29uc3Qgc2V0RnJhZ21lbnQgPSAoYm9hcmQ6IFBsYWl0Qm9hcmQsIG9wZXJhdGlvblR5cGU6IFdyaXRhYmxlQ2xpcGJvYXJkT3BlcmF0aW9uVHlwZSwgY2xpcGJvYXJkRGF0YTogRGF0YVRyYW5zZmVyIHwgbnVsbCkgPT4ge1xuICAgIGNvbnN0IHNlbGVjdGVkRWxlbWVudHMgPSBnZXRTZWxlY3RlZEVsZW1lbnRzKGJvYXJkKTtcbiAgICBjb25zdCByZWN0YW5nbGUgPSBnZXRSZWN0YW5nbGVCeUVsZW1lbnRzKGJvYXJkLCBzZWxlY3RlZEVsZW1lbnRzLCBmYWxzZSk7XG4gICAgY29uc3QgY2xpcGJvYXJkQ29udGV4dCA9IGJvYXJkLmJ1aWxkRnJhZ21lbnQobnVsbCwgcmVjdGFuZ2xlLCBvcGVyYXRpb25UeXBlKTtcbiAgICBjbGlwYm9hcmRDb250ZXh0ICYmIHNldENsaXBib2FyZERhdGEoY2xpcGJvYXJkRGF0YSwgY2xpcGJvYXJkQ29udGV4dCk7XG59O1xuXG5leHBvcnQgY29uc3QgZHVwbGljYXRlRWxlbWVudHMgPSAoYm9hcmQ6IFBsYWl0Qm9hcmQsIGVsZW1lbnRzPzogUGxhaXRFbGVtZW50W10sIHBvaW50PzogUG9pbnQpID0+IHtcbiAgICBjb25zdCB0YXJnZXRFbGVtZW50cyA9IGVsZW1lbnRzPy5sZW5ndGggPyBlbGVtZW50cyA6IGdldFNlbGVjdGVkRWxlbWVudHMoYm9hcmQpO1xuICAgIGNvbnN0IHRhcmdldFJlY3RhbmdsZSA9IGdldFJlY3RhbmdsZUJ5RWxlbWVudHMoYm9hcmQsIHRhcmdldEVsZW1lbnRzLCBmYWxzZSk7XG4gICAgY29uc3QgY2xpcGJvYXJkQ29udGV4dCA9IGJvYXJkLmJ1aWxkRnJhZ21lbnQobnVsbCwgdGFyZ2V0UmVjdGFuZ2xlLCBXcml0YWJsZUNsaXBib2FyZE9wZXJhdGlvblR5cGUuZHVwbGljYXRlLCB0YXJnZXRFbGVtZW50cyk7XG4gICAgY29uc3Qgc3RyaW5naWZpZWRDb250ZXh0ID0gY2xpcGJvYXJkQ29udGV4dCAmJiBKU09OLnN0cmluZ2lmeShjbGlwYm9hcmRDb250ZXh0KTtcbiAgICBjb25zdCBjbG9uZWRDb250ZXh0ID0gc3RyaW5naWZpZWRDb250ZXh0ICYmIEpTT04ucGFyc2Uoc3RyaW5naWZpZWRDb250ZXh0KTtcbiAgICBjbG9uZWRDb250ZXh0ICYmXG4gICAgICAgIGJvYXJkLmluc2VydEZyYWdtZW50KFxuICAgICAgICAgICAge1xuICAgICAgICAgICAgICAgIC4uLmNsb25lZENvbnRleHQsXG4gICAgICAgICAgICAgICAgdGV4dDogdW5kZWZpbmVkXG4gICAgICAgICAgICB9LFxuICAgICAgICAgICAgcG9pbnQgfHwgW3RhcmdldFJlY3RhbmdsZS54ICsgdGFyZ2V0UmVjdGFuZ2xlLndpZHRoIC8gMiwgdGFyZ2V0UmVjdGFuZ2xlLnkgKyB0YXJnZXRSZWN0YW5nbGUuaGVpZ2h0IC8gMl0sXG4gICAgICAgICAgICBXcml0YWJsZUNsaXBib2FyZE9wZXJhdGlvblR5cGUuZHVwbGljYXRlXG4gICAgICAgICk7XG59O1xuIl19
|
package/esm2022/utils/group.mjs
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { ACTIVE_STROKE_WIDTH } from '../constants';
|
|
2
2
|
import { PlaitGroupElement, RectangleClient, SELECTION_BORDER_COLOR } from '../interfaces';
|
|
3
|
-
import { getSelectionAngle } from './angle';
|
|
4
|
-
import { createG
|
|
3
|
+
import { getSelectionAngle, setAngleForG } from './angle';
|
|
4
|
+
import { createG } from './dom';
|
|
5
5
|
import { drawRectangle } from './drawing/rectangle';
|
|
6
6
|
import { getRectangleByElements } from './element';
|
|
7
7
|
import { idCreator } from './id-creator';
|
|
@@ -45,14 +45,14 @@ export const getRectangleByGroup = (board, group, recursion) => {
|
|
|
45
45
|
const elementsInGroup = getAllElementsInGroup(board, group, recursion);
|
|
46
46
|
return getRectangleByElements(board, elementsInGroup, false);
|
|
47
47
|
};
|
|
48
|
-
export const getGroupByElement = (board, element, recursion,
|
|
49
|
-
const group = (
|
|
48
|
+
export const getGroupByElement = (board, element, recursion, originElements) => {
|
|
49
|
+
const group = (originElements || board.children).find(item => item.id === element?.groupId);
|
|
50
50
|
if (!group) {
|
|
51
51
|
return recursion ? [] : null;
|
|
52
52
|
}
|
|
53
53
|
if (recursion) {
|
|
54
54
|
const groups = [group];
|
|
55
|
-
const grandGroups = getGroupByElement(board, group, recursion,
|
|
55
|
+
const grandGroups = getGroupByElement(board, group, recursion, originElements);
|
|
56
56
|
if (grandGroups.length) {
|
|
57
57
|
groups.push(...grandGroups);
|
|
58
58
|
}
|
|
@@ -79,14 +79,14 @@ export const getElementsInGroupByElement = (board, element) => {
|
|
|
79
79
|
}
|
|
80
80
|
};
|
|
81
81
|
export const isSelectedElementOrGroup = (board, element, elements) => {
|
|
82
|
-
const selectedElements = elements
|
|
82
|
+
const selectedElements = elements?.length ? elements : getSelectedElements(board);
|
|
83
83
|
if (PlaitGroupElement.isGroup(element)) {
|
|
84
84
|
return isSelectedAllElementsInGroup(board, element, elements);
|
|
85
85
|
}
|
|
86
86
|
return selectedElements.map(item => item.id).includes(element.id);
|
|
87
87
|
};
|
|
88
88
|
export const isSelectedAllElementsInGroup = (board, group, elements) => {
|
|
89
|
-
const selectedElements = elements
|
|
89
|
+
const selectedElements = elements?.length ? elements : getSelectedElements(board);
|
|
90
90
|
const elementsInGroup = getElementsInGroup(board, group, true);
|
|
91
91
|
return elementsInGroup.every(item => selectedElements.map(element => element.id).includes(item.id));
|
|
92
92
|
};
|
|
@@ -99,8 +99,8 @@ export const filterSelectedGroups = (board, groups, elements) => {
|
|
|
99
99
|
});
|
|
100
100
|
return selectedGroups;
|
|
101
101
|
};
|
|
102
|
-
export const getSelectedGroups = (board, elements) => {
|
|
103
|
-
const highestSelectedGroups = getHighestSelectedGroups(board, elements);
|
|
102
|
+
export const getSelectedGroups = (board, elements, originElements) => {
|
|
103
|
+
const highestSelectedGroups = getHighestSelectedGroups(board, elements, originElements);
|
|
104
104
|
const groups = [];
|
|
105
105
|
highestSelectedGroups.forEach(item => {
|
|
106
106
|
groups.push(item);
|
|
@@ -109,20 +109,20 @@ export const getSelectedGroups = (board, elements) => {
|
|
|
109
109
|
});
|
|
110
110
|
return groups;
|
|
111
111
|
};
|
|
112
|
-
export const getHighestSelectedGroup = (board, element, elements) => {
|
|
113
|
-
const hitElementGroups = getGroupByElement(board, element, true,
|
|
112
|
+
export const getHighestSelectedGroup = (board, element, elements, originElements) => {
|
|
113
|
+
const hitElementGroups = getGroupByElement(board, element, true, originElements);
|
|
114
114
|
const selectedGroups = filterSelectedGroups(board, hitElementGroups, elements);
|
|
115
115
|
if (selectedGroups.length) {
|
|
116
116
|
return selectedGroups[selectedGroups.length - 1];
|
|
117
117
|
}
|
|
118
118
|
return null;
|
|
119
119
|
};
|
|
120
|
-
export const getHighestSelectedGroups = (board, elements) => {
|
|
120
|
+
export const getHighestSelectedGroups = (board, elements, originElements) => {
|
|
121
121
|
let result = [];
|
|
122
|
-
const selectedElements = elements
|
|
122
|
+
const selectedElements = elements?.length ? elements : getSelectedElements(board);
|
|
123
123
|
selectedElements.forEach(item => {
|
|
124
124
|
if (item.groupId) {
|
|
125
|
-
const group = getHighestSelectedGroup(board, item, elements);
|
|
125
|
+
const group = getHighestSelectedGroup(board, item, elements, originElements);
|
|
126
126
|
if (group && !result.includes(group)) {
|
|
127
127
|
result.push(group);
|
|
128
128
|
}
|
|
@@ -132,7 +132,7 @@ export const getHighestSelectedGroups = (board, elements) => {
|
|
|
132
132
|
};
|
|
133
133
|
export const getSelectedIsolatedElements = (board, elements) => {
|
|
134
134
|
let result = [];
|
|
135
|
-
const selectedElements = elements
|
|
135
|
+
const selectedElements = elements?.length ? elements : getSelectedElements(board);
|
|
136
136
|
selectedElements
|
|
137
137
|
.filter(item => !PlaitGroupElement.isGroup(item))
|
|
138
138
|
.forEach(item => {
|
|
@@ -207,9 +207,9 @@ export const canAddGroup = (board, elements) => {
|
|
|
207
207
|
}
|
|
208
208
|
return false;
|
|
209
209
|
};
|
|
210
|
-
export const canRemoveGroup = (board, elements) => {
|
|
211
|
-
const selectedGroups = getHighestSelectedGroups(board, elements);
|
|
212
|
-
const selectedElements = elements
|
|
210
|
+
export const canRemoveGroup = (board, elements, originElements) => {
|
|
211
|
+
const selectedGroups = getHighestSelectedGroups(board, elements, originElements);
|
|
212
|
+
const selectedElements = elements?.length ? elements : getSelectedElements(board);
|
|
213
213
|
return selectedElements.length > 0 && selectedGroups.length > 0;
|
|
214
214
|
};
|
|
215
215
|
export const getEditingGroup = (board, element) => {
|
|
@@ -236,4 +236,4 @@ export const moveElementsToNewPathAfterAddGroup = (board, selectedElements, newP
|
|
|
236
236
|
};
|
|
237
237
|
}));
|
|
238
238
|
};
|
|
239
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"group.js","sourceRoot":"","sources":["../../../../packages/core/src/utils/group.ts"],"names":[],"mappings":"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","sourcesContent":["import { ACTIVE_STROKE_WIDTH } from '../constants';\nimport { Path, PlaitBoard, PlaitElement, PlaitGroup, PlaitGroupElement, RectangleClient, SELECTION_BORDER_COLOR } from '../interfaces';\nimport { getSelectionAngle } from './angle';\nimport { createG, setAngleForG } from './dom';\nimport { drawRectangle } from './drawing/rectangle';\nimport { getRectangleByElements } from './element';\nimport { idCreator } from './id-creator';\nimport { cacheSelectedElements, getSelectedElements } from './selected-element';\nimport { isSelectionMoving } from './selection';\nimport { depthFirstRecursion } from './tree';\nimport { moveElementsToNewPath } from './common';\nimport { sortElements } from './position';\n\nexport const getElementsInGroup = (board: PlaitBoard, group: PlaitGroup, recursion?: boolean, includeGroup?: boolean) => {\n    let result: PlaitElement[] = [];\n    const elements = board.children.filter(value => (value as PlaitElement).groupId === group.id) as PlaitElement[];\n    if (recursion) {\n        elements.forEach(item => {\n            if (PlaitGroupElement.isGroup(item)) {\n                if (includeGroup) {\n                    result.push(item);\n                }\n                result.push(...getElementsInGroup(board, item, recursion, includeGroup));\n            } else {\n                result.push(item);\n            }\n        });\n    } else {\n        result = includeGroup ? elements : (elements.filter(item => !PlaitGroupElement.isGroup(item)) as PlaitElement[]);\n    }\n    return result;\n};\n\nexport const getAllElementsInGroup = (board: PlaitBoard, group: PlaitGroup, recursion?: boolean, includeGroup?: boolean) => {\n    const elementsInGroup = getElementsInGroup(board, group, recursion, includeGroup);\n    const result: PlaitElement[] = [];\n    elementsInGroup.forEach(element => {\n        depthFirstRecursion(\n            element,\n            node => {\n                result.push(node);\n            },\n            () => true\n        );\n    });\n    return result;\n};\n\nexport const getRectangleByGroup = (board: PlaitBoard, group: PlaitGroup, recursion?: boolean) => {\n    const elementsInGroup = getAllElementsInGroup(board, group, recursion) as PlaitElement[];\n    return getRectangleByElements(board, elementsInGroup, false);\n};\n\nexport const getGroupByElement = (\n    board: PlaitBoard,\n    element: PlaitElement,\n    recursion?: boolean,\n    source?: PlaitElement[]\n): PlaitGroup | PlaitGroup[] | null => {\n    const group = (source || board.children).find(item => item.id === element?.groupId);\n    if (!group) {\n        return recursion ? [] : null;\n    }\n    if (recursion) {\n        const groups = [group];\n        const grandGroups = getGroupByElement(board, group, recursion, source) as PlaitGroup[];\n        if (grandGroups.length) {\n            groups.push(...grandGroups);\n        }\n        return groups as PlaitGroup[];\n    } else {\n        return group as PlaitGroup;\n    }\n};\n\nexport const getHighestGroup = (board: PlaitBoard, element: PlaitElement) => {\n    const hitElementGroups = getGroupByElement(board, element, true) as PlaitGroup[];\n    if (hitElementGroups.length) {\n        return hitElementGroups[hitElementGroups.length - 1];\n    }\n    return null;\n};\n\nexport const getElementsInGroupByElement = (board: PlaitBoard, element: PlaitElement) => {\n    const highestGroup = getHighestGroup(board, element);\n    if (highestGroup) {\n        return getAllElementsInGroup(board, highestGroup, true) as PlaitGroup[];\n    } else {\n        return [element];\n    }\n};\n\nexport const isSelectedElementOrGroup = (board: PlaitBoard, element: PlaitElement, elements?: PlaitElement[]) => {\n    const selectedElements = elements || getSelectedElements(board);\n    if (PlaitGroupElement.isGroup(element)) {\n        return isSelectedAllElementsInGroup(board, element, elements);\n    }\n    return selectedElements.map(item => item.id).includes(element.id);\n};\n\nexport const isSelectedAllElementsInGroup = (board: PlaitBoard, group: PlaitGroup, elements?: PlaitElement[]) => {\n    const selectedElements = elements || getSelectedElements(board);\n    const elementsInGroup = getElementsInGroup(board, group, true);\n    return elementsInGroup.every(item => selectedElements.map(element => element.id).includes(item.id));\n};\n\nexport const filterSelectedGroups = (board: PlaitBoard, groups: PlaitGroup[], elements?: PlaitElement[]): PlaitGroup[] => {\n    const selectedGroups: PlaitGroup[] = [];\n    groups.forEach(item => {\n        if (isSelectedElementOrGroup(board, item, elements)) {\n            selectedGroups.push(item);\n        }\n    });\n    return selectedGroups;\n};\n\nexport const getSelectedGroups = (board: PlaitBoard, elements?: PlaitElement[]): PlaitGroup[] => {\n    const highestSelectedGroups = getHighestSelectedGroups(board, elements);\n    const groups: PlaitGroup[] = [];\n    highestSelectedGroups.forEach(item => {\n        groups.push(item);\n        const elementsInGroup = getElementsInGroup(board, item, true, true);\n        groups.push(...(elementsInGroup.filter(item => PlaitGroupElement.isGroup(item)) as PlaitGroup[]));\n    });\n    return groups;\n};\n\nexport const getHighestSelectedGroup = (board: PlaitBoard, element: PlaitElement, elements?: PlaitElement[]): PlaitGroup | null => {\n    const hitElementGroups = getGroupByElement(board, element, true, elements) as PlaitGroup[];\n    const selectedGroups = filterSelectedGroups(board, hitElementGroups, elements);\n    if (selectedGroups.length) {\n        return selectedGroups[selectedGroups.length - 1];\n    }\n    return null;\n};\n\nexport const getHighestSelectedGroups = (board: PlaitBoard, elements?: PlaitElement[]): PlaitGroup[] => {\n    let result: PlaitGroup[] = [];\n    const selectedElements = elements || getSelectedElements(board);\n    selectedElements.forEach(item => {\n        if (item.groupId) {\n            const group = getHighestSelectedGroup(board, item, elements);\n            if (group && !result.includes(group)) {\n                result.push(group);\n            }\n        }\n    });\n    return result;\n};\n\nexport const getSelectedIsolatedElements = (board: PlaitBoard, elements?: PlaitElement[]) => {\n    let result: PlaitElement[] = [];\n    const selectedElements = elements || getSelectedElements(board);\n    selectedElements\n        .filter(item => !PlaitGroupElement.isGroup(item))\n        .forEach(item => {\n            if (!item.groupId) {\n                result.push(item);\n            } else {\n                const group = getHighestSelectedGroup(board, item, elements);\n                if (!group) {\n                    result.push(item);\n                }\n            }\n        });\n    return result;\n};\n\nexport const getSelectedIsolatedElementsCanAddToGroup = (board: PlaitBoard, elements?: PlaitElement[]) => {\n    const selectedIsolatedElements = getSelectedIsolatedElements(board, elements);\n    return selectedIsolatedElements.filter(item => board.canAddToGroup(item));\n};\n\nexport const getHighestSelectedElements = (board: PlaitBoard, elements?: PlaitElement[]) => {\n    return [...getHighestSelectedGroups(board, elements), ...getSelectedIsolatedElements(board, elements)];\n};\n\nexport const createGroupRectangleG = (board: PlaitBoard, elements: PlaitElement[]): SVGGElement | null => {\n    const selectedElementIds = getSelectedElements(board).map(item => item.id);\n    let groupRectangleG: SVGGElement | null = null;\n    const isMoving = isSelectionMoving(board);\n\n    elements.forEach(item => {\n        const isRender = (!selectedElementIds.includes(item.id) && !isMoving) || isMoving;\n        if (item.groupId && isRender) {\n            if (!groupRectangleG) {\n                groupRectangleG = createG();\n            }\n            const elements = getElementsInGroupByElement(board, item);\n            const rectangle = getRectangleByElements(board, elements, false);\n            const rectangleG = drawRectangle(board, rectangle, {\n                stroke: SELECTION_BORDER_COLOR,\n                strokeWidth: ACTIVE_STROKE_WIDTH,\n                strokeLineDash: [5]\n            });\n            const angle = getSelectionAngle(elements);\n            if (angle) {\n                setAngleForG(rectangleG, RectangleClient.getCenterPoint(rectangle), angle);\n            }\n            groupRectangleG.append(rectangleG);\n        }\n    });\n    return groupRectangleG;\n};\n\nexport const createGroup = (groupId?: string): PlaitGroup => {\n    return groupId\n        ? {\n              id: idCreator(),\n              type: 'group',\n              groupId\n          }\n        : {\n              id: idCreator(),\n              type: 'group'\n          };\n};\n\nexport const nonGroupInHighestSelectedElements = (elements: PlaitElement[]) => {\n    return elements.every(item => !item.groupId);\n};\n\nexport const hasSelectedElementsInSameGroup = (elements: PlaitElement[]) => {\n    return elements.every(item => item.groupId && item.groupId === elements[0].groupId);\n};\n\nexport const canAddGroup = (board: PlaitBoard, elements?: PlaitElement[]) => {\n    const highestSelectedElements = getHighestSelectedElements(board, elements);\n    const rootElements = highestSelectedElements.filter(item => board.canAddToGroup(item));\n    if (rootElements.length > 1) {\n        return nonGroupInHighestSelectedElements(rootElements) || hasSelectedElementsInSameGroup(rootElements);\n    }\n    return false;\n};\n\nexport const canRemoveGroup = (board: PlaitBoard, elements?: PlaitElement[]) => {\n    const selectedGroups = getHighestSelectedGroups(board, elements);\n    const selectedElements = elements || getSelectedElements(board);\n    return selectedElements.length > 0 && selectedGroups.length > 0;\n};\n\nexport const getEditingGroup = (board: PlaitBoard, element: PlaitElement) => {\n    const groups = getGroupByElement(board, element, true) as PlaitGroup[];\n    let editingGroup = null;\n    if (groups?.length) {\n        for (let i = 0; i < groups?.length; i++) {\n            if (!isSelectedAllElementsInGroup(board, groups[i])) {\n                editingGroup = groups[i];\n                break;\n            }\n        }\n    }\n    return editingGroup;\n};\n\nexport const moveElementsToNewPathAfterAddGroup = (board: PlaitBoard, selectedElements: PlaitElement[], newPath: Path) => {\n    const moveElements = [...selectedElements];\n    sortElements(board, moveElements);\n    moveElements.pop();\n    moveElementsToNewPath(\n        board,\n        moveElements.map(element => {\n            return {\n                element,\n                newPath\n            };\n        })\n    );\n};\n"]}
|
|
239
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"group.js","sourceRoot":"","sources":["../../../../packages/core/src/utils/group.ts"],"names":[],"mappings":"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","sourcesContent":["import { ACTIVE_STROKE_WIDTH } from '../constants';\nimport { Path, PlaitBoard, PlaitElement, PlaitGroup, PlaitGroupElement, RectangleClient, SELECTION_BORDER_COLOR } from '../interfaces';\nimport { getSelectionAngle, setAngleForG } from './angle';\nimport { createG } from './dom';\nimport { drawRectangle } from './drawing/rectangle';\nimport { getRectangleByElements } from './element';\nimport { idCreator } from './id-creator';\nimport { getSelectedElements } from './selected-element';\nimport { isSelectionMoving } from './selection';\nimport { depthFirstRecursion } from './tree';\nimport { moveElementsToNewPath } from './common';\nimport { sortElements } from './position';\n\nexport const getElementsInGroup = (board: PlaitBoard, group: PlaitGroup, recursion?: boolean, includeGroup?: boolean) => {\n    let result: PlaitElement[] = [];\n    const elements = board.children.filter(value => (value as PlaitElement).groupId === group.id) as PlaitElement[];\n    if (recursion) {\n        elements.forEach(item => {\n            if (PlaitGroupElement.isGroup(item)) {\n                if (includeGroup) {\n                    result.push(item);\n                }\n                result.push(...getElementsInGroup(board, item, recursion, includeGroup));\n            } else {\n                result.push(item);\n            }\n        });\n    } else {\n        result = includeGroup ? elements : (elements.filter(item => !PlaitGroupElement.isGroup(item)) as PlaitElement[]);\n    }\n    return result;\n};\n\nexport const getAllElementsInGroup = (board: PlaitBoard, group: PlaitGroup, recursion?: boolean, includeGroup?: boolean) => {\n    const elementsInGroup = getElementsInGroup(board, group, recursion, includeGroup);\n    const result: PlaitElement[] = [];\n    elementsInGroup.forEach(element => {\n        depthFirstRecursion(\n            element,\n            node => {\n                result.push(node);\n            },\n            () => true\n        );\n    });\n    return result;\n};\n\nexport const getRectangleByGroup = (board: PlaitBoard, group: PlaitGroup, recursion?: boolean) => {\n    const elementsInGroup = getAllElementsInGroup(board, group, recursion) as PlaitElement[];\n    return getRectangleByElements(board, elementsInGroup, false);\n};\n\nexport const getGroupByElement = (\n    board: PlaitBoard,\n    element: PlaitElement,\n    recursion?: boolean,\n    originElements?: PlaitElement[]\n): PlaitGroup | PlaitGroup[] | null => {\n    const group = (originElements || board.children).find(item => item.id === element?.groupId);\n    if (!group) {\n        return recursion ? [] : null;\n    }\n    if (recursion) {\n        const groups = [group];\n        const grandGroups = getGroupByElement(board, group, recursion, originElements) as PlaitGroup[];\n        if (grandGroups.length) {\n            groups.push(...grandGroups);\n        }\n        return groups as PlaitGroup[];\n    } else {\n        return group as PlaitGroup;\n    }\n};\n\nexport const getHighestGroup = (board: PlaitBoard, element: PlaitElement) => {\n    const hitElementGroups = getGroupByElement(board, element, true) as PlaitGroup[];\n    if (hitElementGroups.length) {\n        return hitElementGroups[hitElementGroups.length - 1];\n    }\n    return null;\n};\n\nexport const getElementsInGroupByElement = (board: PlaitBoard, element: PlaitElement) => {\n    const highestGroup = getHighestGroup(board, element);\n    if (highestGroup) {\n        return getAllElementsInGroup(board, highestGroup, true) as PlaitGroup[];\n    } else {\n        return [element];\n    }\n};\n\nexport const isSelectedElementOrGroup = (board: PlaitBoard, element: PlaitElement, elements?: PlaitElement[]) => {\n    const selectedElements = elements?.length ? elements : getSelectedElements(board);\n    if (PlaitGroupElement.isGroup(element)) {\n        return isSelectedAllElementsInGroup(board, element, elements);\n    }\n    return selectedElements.map(item => item.id).includes(element.id);\n};\n\nexport const isSelectedAllElementsInGroup = (board: PlaitBoard, group: PlaitGroup, elements?: PlaitElement[]) => {\n    const selectedElements = elements?.length ? elements : getSelectedElements(board);\n    const elementsInGroup = getElementsInGroup(board, group, true);\n    return elementsInGroup.every(item => selectedElements.map(element => element.id).includes(item.id));\n};\n\nexport const filterSelectedGroups = (board: PlaitBoard, groups: PlaitGroup[], elements?: PlaitElement[]): PlaitGroup[] => {\n    const selectedGroups: PlaitGroup[] = [];\n    groups.forEach(item => {\n        if (isSelectedElementOrGroup(board, item, elements)) {\n            selectedGroups.push(item);\n        }\n    });\n    return selectedGroups;\n};\n\nexport const getSelectedGroups = (board: PlaitBoard, elements?: PlaitElement[], originElements?: PlaitElement[]): PlaitGroup[] => {\n    const highestSelectedGroups = getHighestSelectedGroups(board, elements, originElements);\n    const groups: PlaitGroup[] = [];\n    highestSelectedGroups.forEach(item => {\n        groups.push(item);\n        const elementsInGroup = getElementsInGroup(board, item, true, true);\n        groups.push(...(elementsInGroup.filter(item => PlaitGroupElement.isGroup(item)) as PlaitGroup[]));\n    });\n    return groups;\n};\n\nexport const getHighestSelectedGroup = (\n    board: PlaitBoard,\n    element: PlaitElement,\n    elements?: PlaitElement[],\n    originElements?: PlaitElement[]\n): PlaitGroup | null => {\n    const hitElementGroups = getGroupByElement(board, element, true, originElements) as PlaitGroup[];\n    const selectedGroups = filterSelectedGroups(board, hitElementGroups, elements);\n    if (selectedGroups.length) {\n        return selectedGroups[selectedGroups.length - 1];\n    }\n    return null;\n};\n\nexport const getHighestSelectedGroups = (board: PlaitBoard, elements?: PlaitElement[], originElements?: PlaitElement[]): PlaitGroup[] => {\n    let result: PlaitGroup[] = [];\n    const selectedElements = elements?.length ? elements : getSelectedElements(board);\n    selectedElements.forEach(item => {\n        if (item.groupId) {\n            const group = getHighestSelectedGroup(board, item, elements, originElements);\n            if (group && !result.includes(group)) {\n                result.push(group);\n            }\n        }\n    });\n    return result;\n};\n\nexport const getSelectedIsolatedElements = (board: PlaitBoard, elements?: PlaitElement[]) => {\n    let result: PlaitElement[] = [];\n    const selectedElements = elements?.length ? elements : getSelectedElements(board);\n    selectedElements\n        .filter(item => !PlaitGroupElement.isGroup(item))\n        .forEach(item => {\n            if (!item.groupId) {\n                result.push(item);\n            } else {\n                const group = getHighestSelectedGroup(board, item, elements);\n                if (!group) {\n                    result.push(item);\n                }\n            }\n        });\n    return result;\n};\n\nexport const getSelectedIsolatedElementsCanAddToGroup = (board: PlaitBoard, elements?: PlaitElement[]) => {\n    const selectedIsolatedElements = getSelectedIsolatedElements(board, elements);\n    return selectedIsolatedElements.filter(item => board.canAddToGroup(item));\n};\n\nexport const getHighestSelectedElements = (board: PlaitBoard, elements?: PlaitElement[]) => {\n    return [...getHighestSelectedGroups(board, elements), ...getSelectedIsolatedElements(board, elements)];\n};\n\nexport const createGroupRectangleG = (board: PlaitBoard, elements: PlaitElement[]): SVGGElement | null => {\n    const selectedElementIds = getSelectedElements(board).map(item => item.id);\n    let groupRectangleG: SVGGElement | null = null;\n    const isMoving = isSelectionMoving(board);\n\n    elements.forEach(item => {\n        const isRender = (!selectedElementIds.includes(item.id) && !isMoving) || isMoving;\n        if (item.groupId && isRender) {\n            if (!groupRectangleG) {\n                groupRectangleG = createG();\n            }\n            const elements = getElementsInGroupByElement(board, item);\n            const rectangle = getRectangleByElements(board, elements, false);\n            const rectangleG = drawRectangle(board, rectangle, {\n                stroke: SELECTION_BORDER_COLOR,\n                strokeWidth: ACTIVE_STROKE_WIDTH,\n                strokeLineDash: [5]\n            });\n            const angle = getSelectionAngle(elements);\n            if (angle) {\n                setAngleForG(rectangleG, RectangleClient.getCenterPoint(rectangle), angle);\n            }\n            groupRectangleG.append(rectangleG);\n        }\n    });\n    return groupRectangleG;\n};\n\nexport const createGroup = (groupId?: string): PlaitGroup => {\n    return groupId\n        ? {\n              id: idCreator(),\n              type: 'group',\n              groupId\n          }\n        : {\n              id: idCreator(),\n              type: 'group'\n          };\n};\n\nexport const nonGroupInHighestSelectedElements = (elements: PlaitElement[]) => {\n    return elements.every(item => !item.groupId);\n};\n\nexport const hasSelectedElementsInSameGroup = (elements: PlaitElement[]) => {\n    return elements.every(item => item.groupId && item.groupId === elements[0].groupId);\n};\n\nexport const canAddGroup = (board: PlaitBoard, elements?: PlaitElement[]) => {\n    const highestSelectedElements = getHighestSelectedElements(board, elements);\n    const rootElements = highestSelectedElements.filter(item => board.canAddToGroup(item));\n    if (rootElements.length > 1) {\n        return nonGroupInHighestSelectedElements(rootElements) || hasSelectedElementsInSameGroup(rootElements);\n    }\n    return false;\n};\n\nexport const canRemoveGroup = (board: PlaitBoard, elements?: PlaitElement[], originElements?: PlaitElement[]) => {\n    const selectedGroups = getHighestSelectedGroups(board, elements, originElements);\n    const selectedElements = elements?.length ? elements : getSelectedElements(board);\n    return selectedElements.length > 0 && selectedGroups.length > 0;\n};\n\nexport const getEditingGroup = (board: PlaitBoard, element: PlaitElement) => {\n    const groups = getGroupByElement(board, element, true) as PlaitGroup[];\n    let editingGroup = null;\n    if (groups?.length) {\n        for (let i = 0; i < groups?.length; i++) {\n            if (!isSelectedAllElementsInGroup(board, groups[i])) {\n                editingGroup = groups[i];\n                break;\n            }\n        }\n    }\n    return editingGroup;\n};\n\nexport const moveElementsToNewPathAfterAddGroup = (board: PlaitBoard, selectedElements: PlaitElement[], newPath: Path) => {\n    const moveElements = [...selectedElements];\n    sortElements(board, moveElements);\n    moveElements.pop();\n    moveElementsToNewPath(\n        board,\n        moveElements.map(element => {\n            return {\n                element,\n                newPath\n            };\n        })\n    );\n};\n"]}
|