@plait/common 0.52.0 → 0.53.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/group.component.d.ts +18 -0
- package/esm2022/core/group.component.mjs +48 -0
- package/esm2022/core/image-base.component.mjs +2 -2
- package/esm2022/generators/group.generator.mjs +21 -0
- package/esm2022/generators/image.generator.mjs +6 -2
- package/esm2022/plugins/index.mjs +2 -1
- package/esm2022/plugins/with-group.mjs +189 -0
- package/esm2022/transforms/align.mjs +21 -13
- package/esm2022/utils/index.mjs +1 -2
- package/esm2022/utils/resize.mjs +23 -5
- package/esm2022/utils/vector.mjs +11 -1
- package/fesm2022/plait-common.mjs +305 -24
- package/fesm2022/plait-common.mjs.map +1 -1
- package/generators/group.generator.d.ts +6 -0
- package/package.json +1 -1
- package/plugins/index.d.ts +1 -0
- package/plugins/with-group.d.ts +2 -0
- package/utils/index.d.ts +0 -1
- package/utils/resize.d.ts +3 -1
- package/utils/vector.d.ts +1 -0
- package/esm2022/utils/rotate.mjs +0 -7
- package/utils/rotate.d.ts +0 -2
package/esm2022/utils/resize.mjs
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { PlaitBoard, RectangleClient, ResizeCursorClass, setDragging } from '@plait/core';
|
|
1
|
+
import { PlaitBoard, RectangleClient, ResizeCursorClass, setDragging, RESIZE_CURSORS, rotatePoints } from '@plait/core';
|
|
2
2
|
export const getResizeHandleByIndex = (index) => {
|
|
3
3
|
return `${index}`;
|
|
4
4
|
};
|
|
@@ -31,7 +31,15 @@ const getResizeCursorClassByIndex = (index) => {
|
|
|
31
31
|
return null;
|
|
32
32
|
}
|
|
33
33
|
};
|
|
34
|
-
export const
|
|
34
|
+
export const getRotatedResizeCursorClassByAngle = (cursor, angle) => {
|
|
35
|
+
const index = RESIZE_CURSORS.indexOf(cursor);
|
|
36
|
+
if (index >= 0) {
|
|
37
|
+
const temp = Math.round(angle / (Math.PI / 4));
|
|
38
|
+
cursor = RESIZE_CURSORS[(index + temp) % RESIZE_CURSORS.length];
|
|
39
|
+
}
|
|
40
|
+
return cursor;
|
|
41
|
+
};
|
|
42
|
+
export const getRectangleResizeHandleRefs = (rectangle, diameter, angle = 0) => {
|
|
35
43
|
const corners = RectangleClient.getCornerPoints(rectangle);
|
|
36
44
|
const refs = corners.map((corner, index) => {
|
|
37
45
|
return {
|
|
@@ -42,7 +50,7 @@ export const getRectangleResizeHandleRefs = (rectangle, diameter) => {
|
|
|
42
50
|
height: diameter
|
|
43
51
|
},
|
|
44
52
|
handle: getResizeHandleByIndex(index),
|
|
45
|
-
cursorClass: getResizeCursorClassByIndex(index)
|
|
53
|
+
cursorClass: getRotatedResizeCursorClassByAngle(getResizeCursorClassByIndex(index), angle)
|
|
46
54
|
};
|
|
47
55
|
});
|
|
48
56
|
const rectangles = getResizeSideRectangles(corners, diameter / 2);
|
|
@@ -50,7 +58,7 @@ export const getRectangleResizeHandleRefs = (rectangle, diameter) => {
|
|
|
50
58
|
return {
|
|
51
59
|
rectangle,
|
|
52
60
|
handle: getResizeHandleByIndex(index + 4),
|
|
53
|
-
cursorClass: getResizeCursorClassByIndex(index + 4)
|
|
61
|
+
cursorClass: getRotatedResizeCursorClassByAngle(getResizeCursorClassByIndex(index + 4), angle)
|
|
54
62
|
};
|
|
55
63
|
}));
|
|
56
64
|
return refs;
|
|
@@ -105,4 +113,14 @@ export const isEdgeHandle = (board, handle) => {
|
|
|
105
113
|
export const isCornerHandle = (board, handle) => {
|
|
106
114
|
return !isEdgeHandle(board, handle);
|
|
107
115
|
};
|
|
108
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resize.js","sourceRoot":"","sources":["../../../../packages/common/src/utils/resize.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAS,eAAe,EAAE,iBAAiB,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAIjG,MAAM,CAAC,MAAM,sBAAsB,GAAG,CAAC,KAAa,EAAE,EAAE;IACpD,OAAO,GAAG,KAAK,EAAkB,CAAC;AACtC,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,sBAAsB,GAAG,CAAC,YAA0B,EAAE,EAAE;IACjE,OAAO,MAAM,CAAC,YAAY,CAAC,CAAC;AAChC,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,uBAAuB,GAAG,CAAC,KAAiB,EAAE,KAAa,EAAE,EAAE;IACxE,MAAM,WAAW,GAAG,YAAY,CAAC,KAAK,EAAE,sBAAsB,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;IAC3F,IAAI,0BAA0B,GAAG,WAAW,GAAG,CAAC,CAAC;IACjD,IAAI,0BAA0B,IAAI,CAAC,EAAE,CAAC;QAClC,0BAA0B,GAAG,0BAA0B,GAAG,CAAC,CAAC;IAChE,CAAC;IACD,OAAO,YAAY,CAAC,KAAK,EAAE,sBAAsB,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,0BAA0B,GAAG,CAAC,CAAC,CAAC,CAAC,0BAA0B,CAAC;AAC5H,CAAC,CAAC;AAEF,MAAM,2BAA2B,GAAG,CAAC,KAAa,EAAE,EAAE;IAClD,QAAQ,KAAK,EAAE,CAAC;QACZ,KAAK,CAAC,CAAC;QACP,KAAK,CAAC;YACF,OAAO,iBAAiB,CAAC,IAAI,CAAC;QAClC,KAAK,CAAC,CAAC;QACP,KAAK,CAAC;YACF,OAAO,iBAAiB,CAAC,IAAI,CAAC;QAClC,KAAK,CAAC,CAAC;QACP,KAAK,CAAC;YACF,OAAO,iBAAiB,CAAC,EAAE,CAAC;QAChC,KAAK,CAAC,CAAC;QACP,KAAK,CAAC;YACF,OAAO,iBAAiB,CAAC,EAAE,CAAC;QAChC;YACI,OAAO,IAAI,CAAC;IACpB,CAAC;AACL,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,4BAA4B,GAAG,CAAC,SAA0B,EAAE,QAAgB,EAAE,EAAE;IACzF,MAAM,OAAO,GAAG,eAAe,CAAC,eAAe,CAAC,SAAS,CAAC,CAAC;IAC3D,MAAM,IAAI,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,KAAa,EAAE,EAAE;QAC/C,OAAO;YACH,SAAS,EAAE;gBACP,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,GAAG,QAAQ,GAAG,CAAC;gBAC3B,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,GAAG,QAAQ,GAAG,CAAC;gBAC3B,KAAK,EAAE,QAAQ;gBACf,MAAM,EAAE,QAAQ;aACnB;YACD,MAAM,EAAE,sBAAsB,CAAC,KAAK,CAAiB;YACrD,WAAW,EAAE,2BAA2B,CAAC,KAAK,CAAsB;SACvE,CAAC;IACN,CAAC,CAAC,CAAC;IACH,MAAM,UAAU,GAAG,uBAAuB,CAAC,OAAO,EAAE,QAAQ,GAAG,CAAC,CAAC,CAAC;IAClE,IAAI,CAAC,IAAI,CACL,GAAG,UAAU,CAAC,GAAG,CAAC,CAAC,SAAS,EAAE,KAAK,EAAE,EAAE;QACnC,OAAO;YACH,SAAS;YACT,MAAM,EAAE,sBAAsB,CAAC,KAAK,GAAG,CAAC,CAAiB;YACzD,WAAW,EAAE,2BAA2B,CAAC,KAAK,GAAG,CAAC,CAAsB;SAC3E,CAAC;IACN,CAAC,CAAC,CACL,CAAC;IACF,OAAO,IAAI,CAAC;AAChB,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,2BAA2B,GAAG,CAAC,SAA0B,EAAE,KAAa,EAAE,EAAE;IACrF,IAAI,KAAK,IAAI,CAAC,EAAE,CAAC;QACb,MAAM,OAAO,GAAG,eAAe,CAAC,eAAe,CAAC,SAAS,CAAC,CAAC;QAC3D,OAAO,OAAO,CAAC,KAAK,CAAC,CAAC;IAC1B,CAAC;SAAM,CAAC;QACJ,MAAM,gBAAgB,GAAG,eAAe,CAAC,mBAAmB,CAAC,SAAS,CAAC,CAAC;QACxE,OAAO,gBAAgB,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC;IACvC,CAAC;AACL,CAAC,CAAC;AAEF,MAAM,uBAAuB,GAAG,CAAC,YAAqB,EAAE,MAAc,EAAqB,EAAE;IACzF,MAAM,MAAM,GAAG,EAAE,CAAC;IAClB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,YAAY,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;QAC3C,IAAI,SAAS,GAAG,eAAe,CAAC,oBAAoB,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,EAAE,YAAY,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;QACnG,MAAM,GAAG,GAAG,IAAI,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACjC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,MAAM,GAAG,CAAC,CAAC;QAC9B,SAAS,GAAG,eAAe,CAAC,MAAM,CAAC,SAAS,EAAE,GAAG,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;QAC9D,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IAC3B,CAAC;IACD,OAAO,MAAM,CAAC;AAClB,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,WAAW,GAAG,IAAI,OAAO,EAAmC,CAAC;AAE1E,MAAM,CAAC,MAAM,UAAU,GAAG,CAAC,KAAiB,EAAE,EAAE;IAC5C,OAAO,CAAC,CAAC,WAAW,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;AACpC,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,qBAAqB,GAAG,CAAmC,KAAiB,EAAE,KAA8C,EAAE,EAAE;IACzI,OAAO,UAAU,CAAC,KAAK,CAAC,IAAI,KAAK,CAAC,WAAW,CAAC,GAAG,CAAC,KAAK,CAAE,CAAC,CAAC;AAC/D,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,WAAW,GAAG,CAAmC,KAAiB,EAAE,SAA0B,EAAE,GAAW,EAAE,EAAE;IACxH,UAAU,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,GAAG,GAAG,WAAW,CAAC,CAAC;IACrE,WAAW,CAAC,GAAG,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC;IAClC,WAAW,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;AAC7B,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,cAAc,GAAG,CAAC,KAAiB,EAAE,GAAW,EAAE,EAAE;IAC7D,UAAU,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC,SAAS,CAAC,MAAM,CAAC,GAAG,GAAG,WAAW,CAAC,CAAC;IACxE,WAAW,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IAC1B,WAAW,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;AAC9B,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,YAAY,GAAG,CAAC,KAAiB,EAAE,MAAoB,EAAE,EAAE;IACpE,MAAM,KAAK,GAAG,sBAAsB,CAAC,MAAM,CAAC,CAAC;IAC7C,IAAI,KAAK,IAAI,CAAC,EAAE,CAAC;QACb,OAAO,IAAI,CAAC;IAChB,CAAC;SAAM,CAAC;QACJ,OAAO,KAAK,CAAC;IACjB,CAAC;AACL,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,cAAc,GAAG,CAAC,KAAiB,EAAE,MAAoB,EAAE,EAAE;IACtE,OAAO,CAAC,YAAY,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;AACxC,CAAC,CAAC","sourcesContent":["import { PlaitBoard, Point, RectangleClient, ResizeCursorClass, setDragging } from '@plait/core';\nimport { ResizeHandle } from '../constants/resize';\nimport { PlaitElementOrArray, ResizeRef } from '../types/resize';\n\nexport const getResizeHandleByIndex = (index: number) => {\n    return `${index}` as ResizeHandle;\n};\n\nexport const getIndexByResizeHandle = (resizeHandle: ResizeHandle) => {\n    return Number(resizeHandle);\n};\n\nexport const getSymmetricHandleIndex = (board: PlaitBoard, index: number) => {\n    const originIndex = isEdgeHandle(board, getResizeHandleByIndex(index)) ? index - 4 : index;\n    let originSymmetricHandleIndex = originIndex + 2;\n    if (originSymmetricHandleIndex >= 4) {\n        originSymmetricHandleIndex = originSymmetricHandleIndex - 4;\n    }\n    return isEdgeHandle(board, getResizeHandleByIndex(index)) ? originSymmetricHandleIndex + 4 : originSymmetricHandleIndex;\n};\n\nconst getResizeCursorClassByIndex = (index: number) => {\n    switch (index) {\n        case 0:\n        case 2:\n            return ResizeCursorClass.nwse;\n        case 1:\n        case 3:\n            return ResizeCursorClass.nesw;\n        case 4:\n        case 6:\n            return ResizeCursorClass.ns;\n        case 5:\n        case 7:\n            return ResizeCursorClass.ew;\n        default:\n            return null;\n    }\n};\n\nexport const getRectangleResizeHandleRefs = (rectangle: RectangleClient, diameter: number) => {\n    const corners = RectangleClient.getCornerPoints(rectangle);\n    const refs = corners.map((corner, index: number) => {\n        return {\n            rectangle: {\n                x: corner[0] - diameter / 2,\n                y: corner[1] - diameter / 2,\n                width: diameter,\n                height: diameter\n            },\n            handle: getResizeHandleByIndex(index) as ResizeHandle,\n            cursorClass: getResizeCursorClassByIndex(index) as ResizeCursorClass\n        };\n    });\n    const rectangles = getResizeSideRectangles(corners, diameter / 2);\n    refs.push(\n        ...rectangles.map((rectangle, index) => {\n            return {\n                rectangle,\n                handle: getResizeHandleByIndex(index + 4) as ResizeHandle,\n                cursorClass: getResizeCursorClassByIndex(index + 4) as ResizeCursorClass\n            };\n        })\n    );\n    return refs;\n};\n\nexport const getResizeHandlePointByIndex = (rectangle: RectangleClient, index: number) => {\n    if (index <= 3) {\n        const corners = RectangleClient.getCornerPoints(rectangle);\n        return corners[index];\n    } else {\n        const edgeCenterPoints = RectangleClient.getEdgeCenterPoints(rectangle);\n        return edgeCenterPoints[index - 4];\n    }\n};\n\nconst getResizeSideRectangles = (cornerPoints: Point[], offset: number): RectangleClient[] => {\n    const result = [];\n    for (let i = 0; i < cornerPoints.length; i++) {\n        let rectangle = RectangleClient.getRectangleByPoints([cornerPoints[i], cornerPoints[(i + 1) % 4]]);\n        const arr = new Array(2).fill(0);\n        arr[(i + 1) % 2] = offset / 2;\n        rectangle = RectangleClient.expand(rectangle, arr[0], arr[1]);\n        result.push(rectangle);\n    }\n    return result;\n};\n\nexport const IS_RESIZING = new WeakMap<PlaitBoard, ResizeRef<any, any>>();\n\nexport const isResizing = (board: PlaitBoard) => {\n    return !!IS_RESIZING.get(board);\n};\n\nexport const isResizingByCondition = <T extends PlaitElementOrArray, K>(board: PlaitBoard, match: (resizeRef: ResizeRef<T, K>) => boolean) => {\n    return isResizing(board) && match(IS_RESIZING.get(board)!);\n};\n\nexport const addResizing = <T extends PlaitElementOrArray, K>(board: PlaitBoard, resizeRef: ResizeRef<T, K>, key: string) => {\n    PlaitBoard.getBoardContainer(board).classList.add(`${key}-resizing`);\n    IS_RESIZING.set(board, resizeRef);\n    setDragging(board, true);\n};\n\nexport const removeResizing = (board: PlaitBoard, key: string) => {\n    PlaitBoard.getBoardContainer(board).classList.remove(`${key}-resizing`);\n    IS_RESIZING.delete(board);\n    setDragging(board, false);\n};\n\nexport const isEdgeHandle = (board: PlaitBoard, handle: ResizeHandle) => {\n    const index = getIndexByResizeHandle(handle);\n    if (index >= 4) {\n        return true;\n    } else {\n        return false;\n    }\n};\n\nexport const isCornerHandle = (board: PlaitBoard, handle: ResizeHandle) => {\n    return !isEdgeHandle(board, handle);\n};\n"]}
|
|
116
|
+
// 处理元素先旋转后resize导致的位置偏移
|
|
117
|
+
export const resetPointsAfterResize = (originRectangle, currentRectangle, originSelectionCenterPoint, currentSelectionCenterPoint, angle) => {
|
|
118
|
+
const correctSelectionCenterPoint = rotatePoints([currentSelectionCenterPoint], originSelectionCenterPoint, angle)[0];
|
|
119
|
+
const rotatedElementCenterPoint = rotatePoints([RectangleClient.getCenterPoint(currentRectangle)], originSelectionCenterPoint, angle)[0];
|
|
120
|
+
const currentPoints = RectangleClient.getPoints(currentRectangle);
|
|
121
|
+
const originRectangleCenterPoint = RectangleClient.getCenterPoint(originRectangle);
|
|
122
|
+
const correctElementCenterPoint = rotatePoints([rotatedElementCenterPoint], correctSelectionCenterPoint, -angle)[0];
|
|
123
|
+
const rotatedPoints = rotatePoints(currentPoints, originRectangleCenterPoint, angle);
|
|
124
|
+
return rotatePoints(rotatedPoints, correctElementCenterPoint, -angle);
|
|
125
|
+
};
|
|
126
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resize.js","sourceRoot":"","sources":["../../../../packages/common/src/utils/resize.ts"],"names":[],"mappings":"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","sourcesContent":["import { PlaitBoard, Point, RectangleClient, ResizeCursorClass, setDragging, RESIZE_CURSORS, rotatePoints } from '@plait/core';\nimport { ResizeHandle } from '../constants/resize';\nimport { PlaitElementOrArray, ResizeRef } from '../types/resize';\n\nexport const getResizeHandleByIndex = (index: number) => {\n    return `${index}` as ResizeHandle;\n};\n\nexport const getIndexByResizeHandle = (resizeHandle: ResizeHandle) => {\n    return Number(resizeHandle);\n};\n\nexport const getSymmetricHandleIndex = (board: PlaitBoard, index: number) => {\n    const originIndex = isEdgeHandle(board, getResizeHandleByIndex(index)) ? index - 4 : index;\n    let originSymmetricHandleIndex = originIndex + 2;\n    if (originSymmetricHandleIndex >= 4) {\n        originSymmetricHandleIndex = originSymmetricHandleIndex - 4;\n    }\n    return isEdgeHandle(board, getResizeHandleByIndex(index)) ? originSymmetricHandleIndex + 4 : originSymmetricHandleIndex;\n};\n\nconst getResizeCursorClassByIndex = (index: number) => {\n    switch (index) {\n        case 0:\n        case 2:\n            return ResizeCursorClass.nwse;\n        case 1:\n        case 3:\n            return ResizeCursorClass.nesw;\n        case 4:\n        case 6:\n            return ResizeCursorClass.ns;\n        case 5:\n        case 7:\n            return ResizeCursorClass.ew;\n        default:\n            return null;\n    }\n};\n\nexport const getRotatedResizeCursorClassByAngle = (cursor: ResizeCursorClass, angle: number) => {\n    const index = RESIZE_CURSORS.indexOf(cursor);\n    if (index >= 0) {\n        const temp = Math.round(angle / (Math.PI / 4));\n        cursor = RESIZE_CURSORS[(index + temp) % RESIZE_CURSORS.length] as ResizeCursorClass;\n    }\n    return cursor;\n};\n\nexport const getRectangleResizeHandleRefs = (rectangle: RectangleClient, diameter: number, angle: number = 0) => {\n    const corners = RectangleClient.getCornerPoints(rectangle);\n    const refs = corners.map((corner, index: number) => {\n        return {\n            rectangle: {\n                x: corner[0] - diameter / 2,\n                y: corner[1] - diameter / 2,\n                width: diameter,\n                height: diameter\n            },\n            handle: getResizeHandleByIndex(index) as ResizeHandle,\n            cursorClass: getRotatedResizeCursorClassByAngle(getResizeCursorClassByIndex(index) as ResizeCursorClass, angle)\n        };\n    });\n    const rectangles = getResizeSideRectangles(corners, diameter / 2);\n    refs.push(\n        ...rectangles.map((rectangle, index) => {\n            return {\n                rectangle,\n                handle: getResizeHandleByIndex(index + 4) as ResizeHandle,\n                cursorClass: getRotatedResizeCursorClassByAngle(getResizeCursorClassByIndex(index + 4) as ResizeCursorClass, angle)\n            };\n        })\n    );\n    return refs;\n};\n\nexport const getResizeHandlePointByIndex = (rectangle: RectangleClient, index: number) => {\n    if (index <= 3) {\n        const corners = RectangleClient.getCornerPoints(rectangle);\n        return corners[index];\n    } else {\n        const edgeCenterPoints = RectangleClient.getEdgeCenterPoints(rectangle);\n        return edgeCenterPoints[index - 4];\n    }\n};\n\nconst getResizeSideRectangles = (cornerPoints: Point[], offset: number): RectangleClient[] => {\n    const result = [];\n    for (let i = 0; i < cornerPoints.length; i++) {\n        let rectangle = RectangleClient.getRectangleByPoints([cornerPoints[i], cornerPoints[(i + 1) % 4]]);\n        const arr = new Array(2).fill(0);\n        arr[(i + 1) % 2] = offset / 2;\n        rectangle = RectangleClient.expand(rectangle, arr[0], arr[1]);\n        result.push(rectangle);\n    }\n    return result;\n};\n\nexport const IS_RESIZING = new WeakMap<PlaitBoard, ResizeRef<any, any>>();\n\nexport const isResizing = (board: PlaitBoard) => {\n    return !!IS_RESIZING.get(board);\n};\n\nexport const isResizingByCondition = <T extends PlaitElementOrArray, K>(\n    board: PlaitBoard,\n    match: (resizeRef: ResizeRef<T, K>) => boolean\n) => {\n    return isResizing(board) && match(IS_RESIZING.get(board)!);\n};\n\nexport const addResizing = <T extends PlaitElementOrArray, K>(board: PlaitBoard, resizeRef: ResizeRef<T, K>, key: string) => {\n    PlaitBoard.getBoardContainer(board).classList.add(`${key}-resizing`);\n    IS_RESIZING.set(board, resizeRef);\n    setDragging(board, true);\n};\n\nexport const removeResizing = (board: PlaitBoard, key: string) => {\n    PlaitBoard.getBoardContainer(board).classList.remove(`${key}-resizing`);\n    IS_RESIZING.delete(board);\n    setDragging(board, false);\n};\n\nexport const isEdgeHandle = (board: PlaitBoard, handle: ResizeHandle) => {\n    const index = getIndexByResizeHandle(handle);\n    if (index >= 4) {\n        return true;\n    } else {\n        return false;\n    }\n};\n\nexport const isCornerHandle = (board: PlaitBoard, handle: ResizeHandle) => {\n    return !isEdgeHandle(board, handle);\n};\n\n// 处理元素先旋转后resize导致的位置偏移\nexport const resetPointsAfterResize = (\n    originRectangle: RectangleClient,\n    currentRectangle: RectangleClient,\n    originSelectionCenterPoint: Point,\n    currentSelectionCenterPoint: Point,\n    angle: number\n): [Point, Point] => {\n    const correctSelectionCenterPoint = rotatePoints([currentSelectionCenterPoint], originSelectionCenterPoint, angle)[0];\n    const rotatedElementCenterPoint = rotatePoints(\n        [RectangleClient.getCenterPoint(currentRectangle) as Point],\n        originSelectionCenterPoint,\n        angle\n    )[0];\n\n    const currentPoints = RectangleClient.getPoints(currentRectangle);\n    const originRectangleCenterPoint = RectangleClient.getCenterPoint(originRectangle);\n\n    const correctElementCenterPoint = rotatePoints([rotatedElementCenterPoint], correctSelectionCenterPoint, -angle)[0];\n\n    const rotatedPoints = rotatePoints(currentPoints, originRectangleCenterPoint, angle);\n    return rotatePoints(rotatedPoints, correctElementCenterPoint, -angle) as [Point, Point];\n};\n"]}
|
package/esm2022/utils/vector.mjs
CHANGED
|
@@ -30,4 +30,14 @@ export function rotateVectorAnti90(vector) {
|
|
|
30
30
|
const rotatedY = -x;
|
|
31
31
|
return [rotatedX, rotatedY];
|
|
32
32
|
}
|
|
33
|
-
|
|
33
|
+
export function rotateVector(vector, angle) {
|
|
34
|
+
if (!angle) {
|
|
35
|
+
return vector;
|
|
36
|
+
}
|
|
37
|
+
const x = vector[0];
|
|
38
|
+
const y = vector[1];
|
|
39
|
+
const rotatedX = x * Math.cos(angle) - y * Math.sin(angle);
|
|
40
|
+
const rotatedY = x * Math.sin(angle) + y * Math.cos(angle);
|
|
41
|
+
return [rotatedX, rotatedY];
|
|
42
|
+
}
|
|
43
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVjdG9yLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcGFja2FnZXMvY29tbW9uL3NyYy91dGlscy92ZWN0b3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsTUFBTSxVQUFVLDRCQUE0QixDQUFDLE1BQWEsRUFBRSxNQUFhO0lBQ3JFLE1BQU0sTUFBTSxHQUFHLE1BQU0sQ0FBQyxDQUFDLENBQUMsR0FBRyxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDckMsTUFBTSxNQUFNLEdBQUcsTUFBTSxDQUFDLENBQUMsQ0FBQyxHQUFHLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUNyQyxNQUFNLFFBQVEsR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sR0FBRyxNQUFNLEdBQUcsTUFBTSxHQUFHLE1BQU0sQ0FBQyxDQUFDO0lBQzlELG9EQUFvRDtJQUNwRCxJQUFJLFFBQVEsS0FBSyxDQUFDLEVBQUUsQ0FBQztRQUNqQixNQUFNLElBQUksS0FBSyxDQUFDLDREQUE0RCxDQUFDLENBQUM7SUFDbEYsQ0FBQztJQUNELHVDQUF1QztJQUN2QyxNQUFNLEtBQUssR0FBRyxNQUFNLEdBQUcsUUFBUSxDQUFDO0lBQ2hDLE1BQU0sS0FBSyxHQUFHLE1BQU0sR0FBRyxRQUFRLENBQUM7SUFFaEMsT0FBTyxDQUFDLEtBQUssRUFBRSxLQUFLLENBQUMsQ0FBQztBQUMxQixDQUFDO0FBRUQsTUFBTSxVQUFVLHlCQUF5QixDQUFDLEtBQVksRUFBRSxNQUFjLEVBQUUsU0FBaUI7SUFDckYsTUFBTSxRQUFRLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLEVBQUUsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDbEQsT0FBTyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsR0FBRyxRQUFRLENBQUMsR0FBRyxTQUFTLEVBQUUsS0FBSyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxHQUFHLFFBQVEsQ0FBQyxHQUFHLFNBQVMsQ0FBQyxDQUFDO0FBQzFHLENBQUM7QUFFRCxNQUFNLFVBQVUsa0NBQWtDLENBQUMsS0FBWSxFQUFFLFVBQWtCLEVBQUUsa0JBQTBCLEVBQUUsWUFBcUI7SUFDbEksSUFBSSxZQUFZLEVBQUUsQ0FBQztRQUNmLE9BQU8sQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLEdBQUcsa0JBQWtCLEVBQUUsS0FBSyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsa0JBQWtCLEdBQUcsVUFBVSxDQUFDLENBQUMsQ0FBQyxDQUFDLEdBQUcsVUFBVSxDQUFDLENBQUMsQ0FBQyxDQUFVLENBQUM7SUFDckgsQ0FBQztTQUFNLENBQUM7UUFDSixPQUFPLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsa0JBQWtCLEdBQUcsVUFBVSxDQUFDLENBQUMsQ0FBQyxDQUFDLEdBQUcsVUFBVSxDQUFDLENBQUMsQ0FBQyxFQUFFLEtBQUssQ0FBQyxDQUFDLENBQUMsR0FBRyxrQkFBa0IsQ0FBVSxDQUFDO0lBQ3JILENBQUM7QUFDTCxDQUFDO0FBRUQsTUFBTSxVQUFVLGtCQUFrQixDQUFDLE1BQWM7SUFDN0MsTUFBTSxDQUFDLEdBQUcsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQ3BCLE1BQU0sQ0FBQyxHQUFHLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUNwQixNQUFNLFFBQVEsR0FBRyxDQUFDLENBQUM7SUFDbkIsTUFBTSxRQUFRLEdBQUcsQ0FBQyxDQUFDLENBQUM7SUFDcEIsT0FBTyxDQUFDLFFBQVEsRUFBRSxRQUFRLENBQUMsQ0FBQztBQUNoQyxDQUFDO0FBRUQsTUFBTSxVQUFVLFlBQVksQ0FBQyxNQUFjLEVBQUUsS0FBYTtJQUN0RCxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUM7UUFDVCxPQUFPLE1BQU0sQ0FBQztJQUNsQixDQUFDO0lBQ0QsTUFBTSxDQUFDLEdBQUcsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQ3BCLE1BQU0sQ0FBQyxHQUFHLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUNwQixNQUFNLFFBQVEsR0FBRyxDQUFDLEdBQUcsSUFBSSxDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLEdBQUcsSUFBSSxDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUMzRCxNQUFNLFFBQVEsR0FBRyxDQUFDLEdBQUcsSUFBSSxDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLEdBQUcsSUFBSSxDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUMzRCxPQUFPLENBQUMsUUFBUSxFQUFFLFFBQVEsQ0FBQyxDQUFDO0FBQ2hDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQb2ludCwgVmVjdG9yIH0gZnJvbSAnQHBsYWl0L2NvcmUnO1xuXG5leHBvcnQgZnVuY3Rpb24gZ2V0VW5pdFZlY3RvckJ5UG9pbnRBbmRQb2ludChwb2ludDE6IFBvaW50LCBwb2ludDI6IFBvaW50KTogUG9pbnQge1xuICAgIGNvbnN0IGRlbHRhWCA9IHBvaW50MlswXSAtIHBvaW50MVswXTtcbiAgICBjb25zdCBkZWx0YVkgPSBwb2ludDJbMV0gLSBwb2ludDFbMV07XG4gICAgY29uc3QgZGlzdGFuY2UgPSBNYXRoLnNxcnQoZGVsdGFYICogZGVsdGFYICsgZGVsdGFZICogZGVsdGFZKTtcbiAgICAvLyBBdm9pZCBkaXZpc2lvbiBieSB6ZXJvIGlmIHRoZSBwb2ludHMgYXJlIHRoZSBzYW1lXG4gICAgaWYgKGRpc3RhbmNlID09PSAwKSB7XG4gICAgICAgIHRocm93IG5ldyBFcnJvcignUG9pbnRzIG11c3Qgbm90IGJlIHRoZSBzYW1lIGZvciBhIHVuaXQgdmVjdG9yIGNhbGN1bGF0aW9uLicpO1xuICAgIH1cbiAgICAvLyBDYWxjdWxhdGUgdGhlIHVuaXQgdmVjdG9yIGNvbXBvbmVudHNcbiAgICBjb25zdCB1bml0WCA9IGRlbHRhWCAvIGRpc3RhbmNlO1xuICAgIGNvbnN0IHVuaXRZID0gZGVsdGFZIC8gZGlzdGFuY2U7XG5cbiAgICByZXR1cm4gW3VuaXRYLCB1bml0WV07XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXRQb2ludEJ5VmVjdG9yQ29tcG9uZW50KHBvaW50OiBQb2ludCwgdmVjdG9yOiBWZWN0b3IsIGNvbXBvbmVudDogbnVtYmVyKTogUG9pbnQge1xuICAgIGNvbnN0IGRpc3RhbmNlID0gTWF0aC5oeXBvdCh2ZWN0b3JbMF0sIHZlY3RvclsxXSk7XG4gICAgcmV0dXJuIFtwb2ludFswXSArICh2ZWN0b3JbMF0gLyBkaXN0YW5jZSkgKiBjb21wb25lbnQsIHBvaW50WzFdICsgKHZlY3RvclsxXSAvIGRpc3RhbmNlKSAqIGNvbXBvbmVudF07XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXRQb2ludEJ5VmVjdG9yRGlyZWN0aW9uQ29tcG9uZW50KHBvaW50OiBQb2ludCwgdW5pdFZlY3RvcjogVmVjdG9yLCBkaXJlY3Rpb25Db21wb25lbnQ6IG51bWJlciwgaXNIb3Jpem9udGFsOiBib29sZWFuKSB7XG4gICAgaWYgKGlzSG9yaXpvbnRhbCkge1xuICAgICAgICByZXR1cm4gW3BvaW50WzBdICsgZGlyZWN0aW9uQ29tcG9uZW50LCBwb2ludFsxXSArIChkaXJlY3Rpb25Db21wb25lbnQgLyB1bml0VmVjdG9yWzBdKSAqIHVuaXRWZWN0b3JbMV1dIGFzIFBvaW50O1xuICAgIH0gZWxzZSB7XG4gICAgICAgIHJldHVybiBbcG9pbnRbMF0gKyAoZGlyZWN0aW9uQ29tcG9uZW50IC8gdW5pdFZlY3RvclsxXSkgKiB1bml0VmVjdG9yWzBdLCBwb2ludFsxXSArIGRpcmVjdGlvbkNvbXBvbmVudF0gYXMgUG9pbnQ7XG4gICAgfVxufVxuXG5leHBvcnQgZnVuY3Rpb24gcm90YXRlVmVjdG9yQW50aTkwKHZlY3RvcjogVmVjdG9yKTogVmVjdG9yIHtcbiAgICBjb25zdCB4ID0gdmVjdG9yWzBdO1xuICAgIGNvbnN0IHkgPSB2ZWN0b3JbMV07XG4gICAgY29uc3Qgcm90YXRlZFggPSB5O1xuICAgIGNvbnN0IHJvdGF0ZWRZID0gLXg7XG4gICAgcmV0dXJuIFtyb3RhdGVkWCwgcm90YXRlZFldO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gcm90YXRlVmVjdG9yKHZlY3RvcjogVmVjdG9yLCBhbmdsZTogbnVtYmVyKTogVmVjdG9yIHtcbiAgICBpZiAoIWFuZ2xlKSB7XG4gICAgICAgIHJldHVybiB2ZWN0b3I7XG4gICAgfVxuICAgIGNvbnN0IHggPSB2ZWN0b3JbMF07XG4gICAgY29uc3QgeSA9IHZlY3RvclsxXTtcbiAgICBjb25zdCByb3RhdGVkWCA9IHggKiBNYXRoLmNvcyhhbmdsZSkgLSB5ICogTWF0aC5zaW4oYW5nbGUpO1xuICAgIGNvbnN0IHJvdGF0ZWRZID0geCAqIE1hdGguc2luKGFuZ2xlKSArIHkgKiBNYXRoLmNvcyhhbmdsZSk7XG4gICAgcmV0dXJuIFtyb3RhdGVkWCwgcm90YXRlZFldO1xufVxuIl19
|
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
import { setAngleForG, RectangleClient, drawCircle, PlaitBoard, createG, drawRectangle, createForeignObject, updateForeignObject, ResizeCursorClass, setDragging, distanceBetweenPointAndPoint, Point, Direction, hotkeys, PlaitElement, PlaitContextService,
|
|
1
|
+
import { setAngleForG, RectangleClient, drawCircle, PlaitBoard, createG, drawRectangle, createForeignObject, updateForeignObject, ResizeCursorClass, RESIZE_CURSORS, setDragging, rotatePoints, distanceBetweenPointAndPoint, Point, Direction, hotkeys, PlaitElement, PlaitContextService, getSelectedElements, Transforms, getHighestSelectedElements, getRectangleByElements, PlaitGroupElement, getElementsInGroup, MERGING, PlaitPointerType, isMainPointer, toViewBoxPoint, toHostPoint, preventTouchMove, PRESS_AND_MOVE_BUFFER, isDragging, throttleRAF, handleTouchTarget, ACTIVE_STROKE_WIDTH, getRectangleByGroup, PlaitPluginElementComponent, isSelectionMoving, isSelectedElementOrGroup, Selection, getHitElementsBySelection, createGroupRectangleG, getSelectedGroups, getHighestSelectedGroups, getSelectedIsolatedElements, idCreator, GroupTransforms, getSelectedIsolatedElementsCanAddToGroup, getGroupByElement } from '@plait/core';
|
|
2
2
|
import { isKeyHotkey } from 'is-hotkey';
|
|
3
3
|
import { PlaitMarkEditor, MarkTypes, AlignEditor } from '@plait/text';
|
|
4
4
|
import { Node, Transforms as Transforms$1, Editor } from 'slate';
|
|
5
5
|
import * as i0 from '@angular/core';
|
|
6
|
-
import { Directive, Input } from '@angular/core';
|
|
6
|
+
import { Component, ChangeDetectionStrategy, Directive, Input } from '@angular/core';
|
|
7
7
|
|
|
8
8
|
const BASE = 4;
|
|
9
9
|
const PRIMARY_COLOR = '#6698FF';
|
|
@@ -178,12 +178,16 @@ class ImageGenerator extends Generator {
|
|
|
178
178
|
updateImage(nodeG, previous, current) {
|
|
179
179
|
if (previous !== current && this.componentRef) {
|
|
180
180
|
this.componentRef.instance.imageItem = this.options.getImageItem(current);
|
|
181
|
+
this.componentRef.instance.element = current;
|
|
181
182
|
this.componentRef.instance.getRectangle = () => {
|
|
182
183
|
return this.options.getRectangle(current);
|
|
183
184
|
};
|
|
184
185
|
}
|
|
185
186
|
const currentForeignObject = this.options.getRectangle(current);
|
|
186
187
|
updateForeignObject(this.g, currentForeignObject.width, currentForeignObject.height, currentForeignObject.x, currentForeignObject.y);
|
|
188
|
+
if (currentForeignObject && current.angle) {
|
|
189
|
+
setAngleForG(this.g, RectangleClient.getCenterPoint(currentForeignObject), current.angle);
|
|
190
|
+
}
|
|
187
191
|
// solve image lose on move node
|
|
188
192
|
if (this.foreignObject.children.length === 0) {
|
|
189
193
|
this.foreignObject.append(this.componentRef.instance.nativeElement);
|
|
@@ -228,7 +232,15 @@ const getResizeCursorClassByIndex = (index) => {
|
|
|
228
232
|
return null;
|
|
229
233
|
}
|
|
230
234
|
};
|
|
231
|
-
const
|
|
235
|
+
const getRotatedResizeCursorClassByAngle = (cursor, angle) => {
|
|
236
|
+
const index = RESIZE_CURSORS.indexOf(cursor);
|
|
237
|
+
if (index >= 0) {
|
|
238
|
+
const temp = Math.round(angle / (Math.PI / 4));
|
|
239
|
+
cursor = RESIZE_CURSORS[(index + temp) % RESIZE_CURSORS.length];
|
|
240
|
+
}
|
|
241
|
+
return cursor;
|
|
242
|
+
};
|
|
243
|
+
const getRectangleResizeHandleRefs = (rectangle, diameter, angle = 0) => {
|
|
232
244
|
const corners = RectangleClient.getCornerPoints(rectangle);
|
|
233
245
|
const refs = corners.map((corner, index) => {
|
|
234
246
|
return {
|
|
@@ -239,7 +251,7 @@ const getRectangleResizeHandleRefs = (rectangle, diameter) => {
|
|
|
239
251
|
height: diameter
|
|
240
252
|
},
|
|
241
253
|
handle: getResizeHandleByIndex(index),
|
|
242
|
-
cursorClass: getResizeCursorClassByIndex(index)
|
|
254
|
+
cursorClass: getRotatedResizeCursorClassByAngle(getResizeCursorClassByIndex(index), angle)
|
|
243
255
|
};
|
|
244
256
|
});
|
|
245
257
|
const rectangles = getResizeSideRectangles(corners, diameter / 2);
|
|
@@ -247,7 +259,7 @@ const getRectangleResizeHandleRefs = (rectangle, diameter) => {
|
|
|
247
259
|
return {
|
|
248
260
|
rectangle,
|
|
249
261
|
handle: getResizeHandleByIndex(index + 4),
|
|
250
|
-
cursorClass: getResizeCursorClassByIndex(index + 4)
|
|
262
|
+
cursorClass: getRotatedResizeCursorClassByAngle(getResizeCursorClassByIndex(index + 4), angle)
|
|
251
263
|
};
|
|
252
264
|
}));
|
|
253
265
|
return refs;
|
|
@@ -302,6 +314,16 @@ const isEdgeHandle = (board, handle) => {
|
|
|
302
314
|
const isCornerHandle = (board, handle) => {
|
|
303
315
|
return !isEdgeHandle(board, handle);
|
|
304
316
|
};
|
|
317
|
+
// 处理元素先旋转后resize导致的位置偏移
|
|
318
|
+
const resetPointsAfterResize = (originRectangle, currentRectangle, originSelectionCenterPoint, currentSelectionCenterPoint, angle) => {
|
|
319
|
+
const correctSelectionCenterPoint = rotatePoints([currentSelectionCenterPoint], originSelectionCenterPoint, angle)[0];
|
|
320
|
+
const rotatedElementCenterPoint = rotatePoints([RectangleClient.getCenterPoint(currentRectangle)], originSelectionCenterPoint, angle)[0];
|
|
321
|
+
const currentPoints = RectangleClient.getPoints(currentRectangle);
|
|
322
|
+
const originRectangleCenterPoint = RectangleClient.getCenterPoint(originRectangle);
|
|
323
|
+
const correctElementCenterPoint = rotatePoints([rotatedElementCenterPoint], correctSelectionCenterPoint, -angle)[0];
|
|
324
|
+
const rotatedPoints = rotatePoints(currentPoints, originRectangleCenterPoint, angle);
|
|
325
|
+
return rotatePoints(rotatedPoints, correctElementCenterPoint, -angle);
|
|
326
|
+
};
|
|
305
327
|
|
|
306
328
|
function getUnitVectorByPointAndPoint(point1, point2) {
|
|
307
329
|
const deltaX = point2[0] - point1[0];
|
|
@@ -335,6 +357,16 @@ function rotateVectorAnti90(vector) {
|
|
|
335
357
|
const rotatedY = -x;
|
|
336
358
|
return [rotatedX, rotatedY];
|
|
337
359
|
}
|
|
360
|
+
function rotateVector(vector, angle) {
|
|
361
|
+
if (!angle) {
|
|
362
|
+
return vector;
|
|
363
|
+
}
|
|
364
|
+
const x = vector[0];
|
|
365
|
+
const y = vector[1];
|
|
366
|
+
const rotatedX = x * Math.cos(angle) - y * Math.sin(angle);
|
|
367
|
+
const rotatedY = x * Math.sin(angle) + y * Math.cos(angle);
|
|
368
|
+
return [rotatedX, rotatedY];
|
|
369
|
+
}
|
|
338
370
|
|
|
339
371
|
function isPointOnSegment(point, startPoint, endPoint) {
|
|
340
372
|
const distanceToStart = distanceBetweenPointAndPoint(point[0], point[1], startPoint[0], startPoint[1]);
|
|
@@ -1136,12 +1168,6 @@ const getMemorizedLatest = (memorizedKey) => {
|
|
|
1136
1168
|
return map.get(memorizedKey);
|
|
1137
1169
|
};
|
|
1138
1170
|
|
|
1139
|
-
const rotatePoints = (points, centerPoint, angle) => {
|
|
1140
|
-
return points.map(point => {
|
|
1141
|
-
return rotate(point[0], point[1], centerPoint[0], centerPoint[1], angle);
|
|
1142
|
-
});
|
|
1143
|
-
};
|
|
1144
|
-
|
|
1145
1171
|
const setProperty = (board, properties, options) => {
|
|
1146
1172
|
const selectedElements = getSelectedElements(board);
|
|
1147
1173
|
selectedElements.forEach(element => {
|
|
@@ -1221,19 +1247,27 @@ const alignRight = (board) => {
|
|
|
1221
1247
|
setOffset(board, getOffset);
|
|
1222
1248
|
};
|
|
1223
1249
|
function setOffset(board, getOffset) {
|
|
1224
|
-
|
|
1225
|
-
elements = elements.filter(element => board.children.includes(element));
|
|
1250
|
+
const elements = getHighestSelectedElements(board);
|
|
1226
1251
|
const outerRectangle = getRectangleByElements(board, elements, false);
|
|
1227
1252
|
elements.forEach(element => {
|
|
1228
|
-
if (!element.points)
|
|
1253
|
+
if (!element.points && !PlaitGroupElement.isGroup(element))
|
|
1229
1254
|
return;
|
|
1230
|
-
const path = PlaitBoard.findPath(board, element);
|
|
1231
1255
|
const rectangle = board.getRectangle(element);
|
|
1232
1256
|
const offset = getOffset(outerRectangle, rectangle);
|
|
1233
|
-
|
|
1234
|
-
|
|
1235
|
-
|
|
1236
|
-
}
|
|
1257
|
+
let updateElements = [];
|
|
1258
|
+
if (PlaitGroupElement.isGroup(element)) {
|
|
1259
|
+
updateElements = getElementsInGroup(board, element, true, false);
|
|
1260
|
+
}
|
|
1261
|
+
else if (element.points) {
|
|
1262
|
+
updateElements = [element];
|
|
1263
|
+
}
|
|
1264
|
+
updateElements.forEach(item => {
|
|
1265
|
+
const newPoints = item.points.map(p => [p[0] + offset[0], p[1] + offset[1]]);
|
|
1266
|
+
const path = PlaitBoard.findPath(board, item);
|
|
1267
|
+
Transforms.setNode(board, {
|
|
1268
|
+
points: newPoints
|
|
1269
|
+
}, path);
|
|
1270
|
+
});
|
|
1237
1271
|
MERGING.set(board, true);
|
|
1238
1272
|
});
|
|
1239
1273
|
MERGING.set(board, false);
|
|
@@ -1247,11 +1281,11 @@ const distributeVertical = (board) => {
|
|
|
1247
1281
|
const distribute = (board, isHorizontal) => {
|
|
1248
1282
|
const axis = isHorizontal ? 'x' : 'y';
|
|
1249
1283
|
const side = isHorizontal ? 'width' : 'height';
|
|
1250
|
-
const
|
|
1251
|
-
const refs =
|
|
1284
|
+
const highestSelectedElements = getHighestSelectedElements(board);
|
|
1285
|
+
const refs = highestSelectedElements.map(element => {
|
|
1252
1286
|
return { element, rectangle: board.getRectangle(element) };
|
|
1253
1287
|
});
|
|
1254
|
-
const outerRectangle = getRectangleByElements(board,
|
|
1288
|
+
const outerRectangle = getRectangleByElements(board, highestSelectedElements, false);
|
|
1255
1289
|
const minRectangleRef = refs.sort((a, b) => a.rectangle[axis] - b.rectangle[axis])[0];
|
|
1256
1290
|
const maxRectangleRef = refs.sort((a, b) => b.rectangle[axis] + b.rectangle[side] - (a.rectangle[axis] + a.rectangle[side]))[0];
|
|
1257
1291
|
const minIndex = refs.findIndex(ref => ref === minRectangleRef);
|
|
@@ -1470,6 +1504,25 @@ const withResize = (board, options) => {
|
|
|
1470
1504
|
return board;
|
|
1471
1505
|
};
|
|
1472
1506
|
|
|
1507
|
+
class GroupGenerator extends Generator {
|
|
1508
|
+
canDraw(element) {
|
|
1509
|
+
return true;
|
|
1510
|
+
}
|
|
1511
|
+
draw(element, partialSelected) {
|
|
1512
|
+
const options = {
|
|
1513
|
+
stroke: '',
|
|
1514
|
+
strokeWidth: ACTIVE_STROKE_WIDTH,
|
|
1515
|
+
strokeLineDash: [5]
|
|
1516
|
+
};
|
|
1517
|
+
let rectangle = { x: 0, y: 0, width: 0, height: 0 };
|
|
1518
|
+
if (partialSelected) {
|
|
1519
|
+
options.stroke = '#999';
|
|
1520
|
+
rectangle = getRectangleByGroup(this.board, element, true);
|
|
1521
|
+
}
|
|
1522
|
+
return drawRectangle(this.board, rectangle, options);
|
|
1523
|
+
}
|
|
1524
|
+
}
|
|
1525
|
+
|
|
1473
1526
|
class CommonPluginElement extends PlaitPluginElementComponent {
|
|
1474
1527
|
constructor() {
|
|
1475
1528
|
super(...arguments);
|
|
@@ -1492,6 +1545,234 @@ class CommonPluginElement extends PlaitPluginElementComponent {
|
|
|
1492
1545
|
}
|
|
1493
1546
|
}
|
|
1494
1547
|
|
|
1548
|
+
class GroupComponent extends CommonPluginElement {
|
|
1549
|
+
constructor(viewContainerRef, cdr) {
|
|
1550
|
+
super(cdr);
|
|
1551
|
+
this.viewContainerRef = viewContainerRef;
|
|
1552
|
+
this.cdr = cdr;
|
|
1553
|
+
}
|
|
1554
|
+
initializeGenerator() {
|
|
1555
|
+
this.activeGenerator = new ActiveGenerator(this.board, {
|
|
1556
|
+
getRectangle: (element) => {
|
|
1557
|
+
return getRectangleByGroup(this.board, element);
|
|
1558
|
+
},
|
|
1559
|
+
getStrokeWidth: () => 0,
|
|
1560
|
+
getStrokeOpacity: () => 0,
|
|
1561
|
+
hasResizeHandle: () => {
|
|
1562
|
+
return !isSelectionMoving(this.board);
|
|
1563
|
+
}
|
|
1564
|
+
});
|
|
1565
|
+
this.groupGenerator = new GroupGenerator(this.board);
|
|
1566
|
+
}
|
|
1567
|
+
ngOnInit() {
|
|
1568
|
+
super.ngOnInit();
|
|
1569
|
+
this.initializeGenerator();
|
|
1570
|
+
}
|
|
1571
|
+
onContextChanged(value, previous) {
|
|
1572
|
+
const elementsInGroup = getElementsInGroup(this.board, value.element, false, true);
|
|
1573
|
+
const isPartialSelectGroup = elementsInGroup.some(item => isSelectedElementOrGroup(this.board, item)) &&
|
|
1574
|
+
!elementsInGroup.every(item => isSelectedElementOrGroup(this.board, item));
|
|
1575
|
+
this.groupGenerator.processDrawing(value.element, this.g, isPartialSelectGroup);
|
|
1576
|
+
}
|
|
1577
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: GroupComponent, deps: [{ token: i0.ViewContainerRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
1578
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.4", type: GroupComponent, isStandalone: true, selector: "plait-group", usesInheritance: true, ngImport: i0, template: ``, isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
1579
|
+
}
|
|
1580
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: GroupComponent, decorators: [{
|
|
1581
|
+
type: Component,
|
|
1582
|
+
args: [{
|
|
1583
|
+
selector: 'plait-group',
|
|
1584
|
+
template: ``,
|
|
1585
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
1586
|
+
standalone: true
|
|
1587
|
+
}]
|
|
1588
|
+
}], ctorParameters: () => [{ type: i0.ViewContainerRef }, { type: i0.ChangeDetectorRef }] });
|
|
1589
|
+
|
|
1590
|
+
function withGroup(board) {
|
|
1591
|
+
let groupRectangleG;
|
|
1592
|
+
let removeGroups;
|
|
1593
|
+
const { drawElement, pointerMove, globalPointerUp, insertFragment, getDeletedFragment, deleteFragment, getRelatedFragment, getRectangle, keyDown } = board;
|
|
1594
|
+
board.drawElement = (context) => {
|
|
1595
|
+
if (PlaitGroupElement.isGroup(context.element)) {
|
|
1596
|
+
return GroupComponent;
|
|
1597
|
+
}
|
|
1598
|
+
return drawElement(context);
|
|
1599
|
+
};
|
|
1600
|
+
board.pointerMove = (event) => {
|
|
1601
|
+
groupRectangleG?.remove();
|
|
1602
|
+
const point = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));
|
|
1603
|
+
let selection = { anchor: point, focus: point };
|
|
1604
|
+
if (board.selection && !Selection.isCollapsed(board.selection)) {
|
|
1605
|
+
selection = board.selection;
|
|
1606
|
+
}
|
|
1607
|
+
const hitElements = getHitElementsBySelection(board, selection);
|
|
1608
|
+
if (hitElements.length) {
|
|
1609
|
+
groupRectangleG = createGroupRectangleG(board, hitElements);
|
|
1610
|
+
groupRectangleG && PlaitBoard.getElementActiveHost(board).append(groupRectangleG);
|
|
1611
|
+
}
|
|
1612
|
+
pointerMove(event);
|
|
1613
|
+
};
|
|
1614
|
+
board.globalPointerUp = (event) => {
|
|
1615
|
+
groupRectangleG?.remove();
|
|
1616
|
+
groupRectangleG = null;
|
|
1617
|
+
globalPointerUp(event);
|
|
1618
|
+
};
|
|
1619
|
+
board.getRelatedFragment = (elements) => {
|
|
1620
|
+
const groups = getSelectedGroups(board);
|
|
1621
|
+
return getRelatedFragment([...elements, ...groups]);
|
|
1622
|
+
};
|
|
1623
|
+
board.insertFragment = (data, clipboardData, targetPoint) => {
|
|
1624
|
+
const elements = [];
|
|
1625
|
+
if (clipboardData?.elements?.length) {
|
|
1626
|
+
const groups = getHighestSelectedGroups(board, clipboardData?.elements);
|
|
1627
|
+
const selectedIsolatedElements = getSelectedIsolatedElements(board, clipboardData?.elements);
|
|
1628
|
+
selectedIsolatedElements.forEach(item => {
|
|
1629
|
+
elements.push(!item.groupId ? item : updateGroupId(item, undefined));
|
|
1630
|
+
});
|
|
1631
|
+
if (groups.length) {
|
|
1632
|
+
groups.forEach(item => {
|
|
1633
|
+
const newGroup = { ...updateGroupId(item, undefined), id: idCreator() };
|
|
1634
|
+
elements.push(newGroup);
|
|
1635
|
+
elements.push(...updateElementsGroupId(item, clipboardData.elements, newGroup.id));
|
|
1636
|
+
});
|
|
1637
|
+
}
|
|
1638
|
+
clipboardData.elements = elements;
|
|
1639
|
+
}
|
|
1640
|
+
insertFragment(data, clipboardData, targetPoint);
|
|
1641
|
+
const groupElements = elements?.filter(value => PlaitGroupElement.isGroup(value));
|
|
1642
|
+
groupElements.forEach(element => {
|
|
1643
|
+
Transforms.insertNode(board, element, [board.children.length]);
|
|
1644
|
+
});
|
|
1645
|
+
};
|
|
1646
|
+
board.getDeletedFragment = (data) => {
|
|
1647
|
+
if (removeGroups && removeGroups.length) {
|
|
1648
|
+
data.push(...removeGroups);
|
|
1649
|
+
}
|
|
1650
|
+
return getDeletedFragment(data);
|
|
1651
|
+
};
|
|
1652
|
+
board.deleteFragment = (data) => {
|
|
1653
|
+
removeGroups = getRemoveGroups(board);
|
|
1654
|
+
if (removeGroups?.length) {
|
|
1655
|
+
updateSiblingElementGroupId(board, removeGroups);
|
|
1656
|
+
}
|
|
1657
|
+
deleteFragment(data);
|
|
1658
|
+
removeGroups = null;
|
|
1659
|
+
};
|
|
1660
|
+
board.getRectangle = (element) => {
|
|
1661
|
+
if (PlaitGroupElement.isGroup(element)) {
|
|
1662
|
+
return getRectangleByGroup(board, element);
|
|
1663
|
+
}
|
|
1664
|
+
return getRectangle(element);
|
|
1665
|
+
};
|
|
1666
|
+
board.keyDown = (event) => {
|
|
1667
|
+
if (!PlaitBoard.isReadonly(board)) {
|
|
1668
|
+
if (isKeyHotkey('mod+g', event)) {
|
|
1669
|
+
event.preventDefault();
|
|
1670
|
+
GroupTransforms.addGroup(board);
|
|
1671
|
+
return;
|
|
1672
|
+
}
|
|
1673
|
+
if (isKeyHotkey('mod+shift+g', event)) {
|
|
1674
|
+
event.preventDefault();
|
|
1675
|
+
GroupTransforms.removeGroup(board);
|
|
1676
|
+
return;
|
|
1677
|
+
}
|
|
1678
|
+
}
|
|
1679
|
+
keyDown(event);
|
|
1680
|
+
};
|
|
1681
|
+
return board;
|
|
1682
|
+
}
|
|
1683
|
+
const updateGroupId = (element, groupId) => {
|
|
1684
|
+
return {
|
|
1685
|
+
...element,
|
|
1686
|
+
groupId: groupId
|
|
1687
|
+
};
|
|
1688
|
+
};
|
|
1689
|
+
const updateElementsGroupId = (group, clipboardDataElements, newGroupId) => {
|
|
1690
|
+
const elements = [];
|
|
1691
|
+
const elementsInGroup = clipboardDataElements.filter(item => item.groupId === group.id);
|
|
1692
|
+
if (elementsInGroup.length) {
|
|
1693
|
+
elementsInGroup.forEach(item => {
|
|
1694
|
+
if (PlaitGroupElement.isGroup(item)) {
|
|
1695
|
+
const newGroup = { ...updateGroupId(item, newGroupId), id: idCreator() };
|
|
1696
|
+
elements.push(newGroup);
|
|
1697
|
+
elements.push(...updateElementsGroupId(item, clipboardDataElements, newGroup.id));
|
|
1698
|
+
}
|
|
1699
|
+
else {
|
|
1700
|
+
elements.push(updateGroupId(item, newGroupId));
|
|
1701
|
+
}
|
|
1702
|
+
});
|
|
1703
|
+
}
|
|
1704
|
+
return elements;
|
|
1705
|
+
};
|
|
1706
|
+
const getRemoveGroups = (board) => {
|
|
1707
|
+
const selectedGroups = board.getRelatedFragment([]);
|
|
1708
|
+
const removeGroups = [...selectedGroups];
|
|
1709
|
+
const highestSelectedGroups = getHighestSelectedGroups(board);
|
|
1710
|
+
const selectedIsolatedElements = getSelectedIsolatedElementsCanAddToGroup(board);
|
|
1711
|
+
const removeNodes = [...highestSelectedGroups, ...selectedIsolatedElements];
|
|
1712
|
+
removeNodes.forEach(item => {
|
|
1713
|
+
const hitElementGroups = getGroupByElement(board, item, true);
|
|
1714
|
+
if (hitElementGroups.length) {
|
|
1715
|
+
const elementsInGroup = getElementsInGroup(board, hitElementGroups[0], false, true);
|
|
1716
|
+
const siblingElements = elementsInGroup.filter(element => ![...removeNodes, ...removeGroups].map(item => item.id).includes(element.id));
|
|
1717
|
+
if (siblingElements.length === 1 || siblingElements.length === 0) {
|
|
1718
|
+
if (!removeGroups.includes(hitElementGroups[0])) {
|
|
1719
|
+
removeGroups.push(hitElementGroups[0]);
|
|
1720
|
+
}
|
|
1721
|
+
if (siblingElements.length === 1) {
|
|
1722
|
+
if (hitElementGroups.length > 1) {
|
|
1723
|
+
const aboveGroup = findAboveGroupWithAnotherElement(board, hitElementGroups.slice(1, hitElementGroups.length), [
|
|
1724
|
+
...removeNodes,
|
|
1725
|
+
...removeGroups
|
|
1726
|
+
]);
|
|
1727
|
+
let index = hitElementGroups.length;
|
|
1728
|
+
if (aboveGroup) {
|
|
1729
|
+
index = hitElementGroups.findIndex(item => item.id === aboveGroup.id);
|
|
1730
|
+
}
|
|
1731
|
+
[...hitElementGroups.slice(1, index)].forEach(item => {
|
|
1732
|
+
if (!removeGroups.includes(item)) {
|
|
1733
|
+
removeGroups.push(item);
|
|
1734
|
+
}
|
|
1735
|
+
});
|
|
1736
|
+
}
|
|
1737
|
+
}
|
|
1738
|
+
}
|
|
1739
|
+
}
|
|
1740
|
+
});
|
|
1741
|
+
return removeGroups;
|
|
1742
|
+
};
|
|
1743
|
+
const findAboveGroupWithAnotherElement = (board, groups, excludeNodes) => {
|
|
1744
|
+
let group = null;
|
|
1745
|
+
for (let i = 0; i < groups.length; i++) {
|
|
1746
|
+
const elementsInGroup = getElementsInGroup(board, groups[i], false, true);
|
|
1747
|
+
const siblingElements = elementsInGroup.filter(element => !excludeNodes.map(item => item.id).includes(element.id));
|
|
1748
|
+
if (siblingElements.length > 0) {
|
|
1749
|
+
group = groups[i];
|
|
1750
|
+
break;
|
|
1751
|
+
}
|
|
1752
|
+
}
|
|
1753
|
+
return group;
|
|
1754
|
+
};
|
|
1755
|
+
const updateSiblingElementGroupId = (board, removeGroups) => {
|
|
1756
|
+
const selectedIsolatedElements = getSelectedIsolatedElementsCanAddToGroup(board);
|
|
1757
|
+
const highestSelectedGroups = getHighestSelectedGroups(board);
|
|
1758
|
+
const isolatedElementsInGroup = selectedIsolatedElements.filter(item => item.groupId);
|
|
1759
|
+
[...highestSelectedGroups, ...isolatedElementsInGroup].forEach(item => {
|
|
1760
|
+
const hitElementGroups = getGroupByElement(board, item, true);
|
|
1761
|
+
if (hitElementGroups.length) {
|
|
1762
|
+
const elementsInGroup = getElementsInGroup(board, hitElementGroups[0], false, true);
|
|
1763
|
+
const siblingElements = elementsInGroup.filter(element => element.id !== item.id);
|
|
1764
|
+
if (siblingElements.length === 1) {
|
|
1765
|
+
const removeGroupIds = removeGroups.map(item => item.id);
|
|
1766
|
+
if (hitElementGroups.some(group => removeGroupIds.includes(group.id))) {
|
|
1767
|
+
const group = hitElementGroups.find(group => !removeGroupIds.includes(group.id));
|
|
1768
|
+
const path = PlaitBoard.findPath(board, siblingElements[0]);
|
|
1769
|
+
Transforms.setNode(board, { groupId: group?.id || undefined }, path);
|
|
1770
|
+
}
|
|
1771
|
+
}
|
|
1772
|
+
}
|
|
1773
|
+
});
|
|
1774
|
+
};
|
|
1775
|
+
|
|
1495
1776
|
class ImageBaseComponent {
|
|
1496
1777
|
set imageItem(value) {
|
|
1497
1778
|
this.afterImageItemChange(this._imageItem, value);
|
|
@@ -1549,7 +1830,7 @@ class ImageBaseComponent {
|
|
|
1549
1830
|
drawFocus() {
|
|
1550
1831
|
if (this.initialized) {
|
|
1551
1832
|
const activeG = PlaitBoard.getElementActiveHost(this.board);
|
|
1552
|
-
this.activeGenerator.processDrawing(
|
|
1833
|
+
this.activeGenerator.processDrawing(this.element, activeG, { selected: this._isFocus });
|
|
1553
1834
|
}
|
|
1554
1835
|
}
|
|
1555
1836
|
ngOnDestroy() {
|
|
@@ -1589,5 +1870,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.4", ngImpor
|
|
|
1589
1870
|
* Generated bundle index. Do not edit.
|
|
1590
1871
|
*/
|
|
1591
1872
|
|
|
1592
|
-
export { AStar, ActiveGenerator, AlignTransform, BASE, BoardCreationMode, CommonPluginElement, DEFAULT_ROUTE_MARGIN, Generator, IS_RESIZING, ImageBaseComponent, ImageGenerator, MediaKeys, PICTURE_ACCEPTED_UPLOAD_SIZE, PRIMARY_COLOR, PointGraph, PointNode, PriorityQueue, PropertyTransforms, RESIZE_HANDLE_DIAMETER, ResizeHandle, TRANSPARENT, TextTransforms, WithCommonPluginKey, WithTextPluginKey, acceptImageTypes, addElementOfFocusedImage, addResizing, alignBottom, alignHorizontalCenter, alignLeft, alignRight, alignTop, alignVerticalCenter, buildImage, calculatePolylineLength, createGraph, distributeHorizontal, distributeVertical, drawFillPrimaryHandle, drawHandle, drawPrimaryHandle, generateElbowLineRoute, getCreationMode, getCrossingPointsBetweenPointAndSegment, getDirectionBetweenPointAndPoint, getDirectionByPointOfRectangle, getDirectionByVector, getDirectionFactor, getDirectionFactorByDirectionComponent, getElementOfFocusedImage, getElementsText, getExtendPoint, getFirstTextEditor, getFirstTextManage, getGraphPoints, getIndexByResizeHandle, getMemorizedLatest, getNextPoint, getOppositeDirection, getPointByVectorComponent, getPointByVectorDirectionComponent, getPointOnPolyline, getPoints, getRatioByPoint, getRectangleResizeHandleRefs, getResizeHandleByIndex, getResizeHandlePointByIndex, getSourceAndTargetOuterRectangle, getSymmetricHandleIndex, getTextEditors, getTextManages, getTextMarksByElement, getUnitVectorByPointAndPoint, hasAfterDraw, isCornerHandle, isDelete, isDndMode, isDrawingMode, isEdgeHandle, isEnterHotkey, isExpandHotkey, isPointOnSegment, isResizing, isResizingByCondition, isSourceAndTargetIntersect, isSpaceHotkey, isTabHotkey, isVirtualKey, memorizeLatest, normalizeShapePoints, reduceRouteMargin, removeDuplicatePoints, removeElementOfFocusedImage, removeResizing,
|
|
1873
|
+
export { AStar, ActiveGenerator, AlignTransform, BASE, BoardCreationMode, CommonPluginElement, DEFAULT_ROUTE_MARGIN, Generator, IS_RESIZING, ImageBaseComponent, ImageGenerator, MediaKeys, PICTURE_ACCEPTED_UPLOAD_SIZE, PRIMARY_COLOR, PointGraph, PointNode, PriorityQueue, PropertyTransforms, RESIZE_HANDLE_DIAMETER, ResizeHandle, TRANSPARENT, TextTransforms, WithCommonPluginKey, WithTextPluginKey, acceptImageTypes, addElementOfFocusedImage, addResizing, alignBottom, alignHorizontalCenter, alignLeft, alignRight, alignTop, alignVerticalCenter, buildImage, calculatePolylineLength, createGraph, distributeHorizontal, distributeVertical, drawFillPrimaryHandle, drawHandle, drawPrimaryHandle, generateElbowLineRoute, getCreationMode, getCrossingPointsBetweenPointAndSegment, getDirectionBetweenPointAndPoint, getDirectionByPointOfRectangle, getDirectionByVector, getDirectionFactor, getDirectionFactorByDirectionComponent, getElementOfFocusedImage, getElementsText, getExtendPoint, getFirstTextEditor, getFirstTextManage, getGraphPoints, getIndexByResizeHandle, getMemorizedLatest, getNextPoint, getOppositeDirection, getPointByVectorComponent, getPointByVectorDirectionComponent, getPointOnPolyline, getPoints, getRatioByPoint, getRectangleResizeHandleRefs, getResizeHandleByIndex, getResizeHandlePointByIndex, getRotatedResizeCursorClassByAngle, getSourceAndTargetOuterRectangle, getSymmetricHandleIndex, getTextEditors, getTextManages, getTextMarksByElement, getUnitVectorByPointAndPoint, hasAfterDraw, isCornerHandle, isDelete, isDndMode, isDrawingMode, isEdgeHandle, isEnterHotkey, isExpandHotkey, isPointOnSegment, isResizing, isResizingByCondition, isSourceAndTargetIntersect, isSpaceHotkey, isTabHotkey, isVirtualKey, memorizeLatest, normalizeShapePoints, reduceRouteMargin, removeDuplicatePoints, removeElementOfFocusedImage, removeResizing, resetPointsAfterResize, rotateVector, rotateVectorAnti90, routeAdjust, selectImage, setCreationMode, setProperty, simplifyOrthogonalPoints, withGroup, withResize };
|
|
1593
1874
|
//# sourceMappingURL=plait-common.mjs.map
|