@plait/core 0.0.56 → 0.0.58

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.
Files changed (54) hide show
  1. package/board/board.component.d.ts +19 -41
  2. package/board/board.component.interface.d.ts +5 -0
  3. package/core/element/before-context-change.d.ts +6 -0
  4. package/core/element/context.d.ts +7 -0
  5. package/core/element/element.component.d.ts +11 -3
  6. package/core/element/plugin-element.d.ts +22 -0
  7. package/core/toolbar/toolbar.component.d.ts +7 -8
  8. package/esm2020/board/board.component.interface.mjs +2 -0
  9. package/esm2020/board/board.component.mjs +215 -230
  10. package/esm2020/core/element/before-context-change.mjs +7 -0
  11. package/esm2020/core/element/context.mjs +2 -0
  12. package/esm2020/core/element/element.component.mjs +48 -12
  13. package/esm2020/core/element/plugin-element.mjs +60 -0
  14. package/esm2020/core/toolbar/toolbar.component.mjs +14 -22
  15. package/esm2020/interfaces/board.mjs +1 -1
  16. package/esm2020/interfaces/element.mjs +1 -1
  17. package/esm2020/interfaces/index.mjs +3 -3
  18. package/esm2020/interfaces/node.mjs +1 -1
  19. package/esm2020/interfaces/pointer.mjs +6 -0
  20. package/esm2020/interfaces/viewport.mjs +2 -2
  21. package/esm2020/plugins/create-board.mjs +6 -7
  22. package/esm2020/plugins/with-hand.mjs +68 -0
  23. package/esm2020/plugins/with-selection.mjs +4 -2
  24. package/esm2020/public-api.mjs +3 -1
  25. package/esm2020/transforms/board.mjs +10 -0
  26. package/esm2020/transforms/general.mjs +1 -1
  27. package/esm2020/transforms/index.mjs +2 -1
  28. package/esm2020/utils/board.mjs +1 -9
  29. package/esm2020/utils/matrix.mjs +131 -78
  30. package/esm2020/utils/weak-maps.mjs +1 -1
  31. package/fesm2015/plait-core.mjs +645 -509
  32. package/fesm2015/plait-core.mjs.map +1 -1
  33. package/fesm2020/plait-core.mjs +668 -537
  34. package/fesm2020/plait-core.mjs.map +1 -1
  35. package/interfaces/board.d.ts +18 -8
  36. package/interfaces/element.d.ts +5 -2
  37. package/interfaces/index.d.ts +2 -2
  38. package/interfaces/node.d.ts +0 -1
  39. package/interfaces/pointer.d.ts +4 -0
  40. package/interfaces/viewport.d.ts +1 -1
  41. package/package.json +1 -1
  42. package/plugins/with-hand.d.ts +2 -0
  43. package/public-api.d.ts +2 -0
  44. package/transforms/board.d.ts +6 -0
  45. package/transforms/index.d.ts +1 -0
  46. package/utils/board.d.ts +2 -3
  47. package/utils/matrix.d.ts +66 -16
  48. package/utils/weak-maps.d.ts +2 -2
  49. package/esm2020/interfaces/cursor.mjs +0 -7
  50. package/esm2020/interfaces/element-context.mjs +0 -2
  51. package/esm2020/plugins/with-move.mjs +0 -66
  52. package/interfaces/cursor.d.ts +0 -6
  53. package/interfaces/element-context.d.ts +0 -4
  54. package/plugins/with-move.d.ts +0 -2
@@ -1,72 +1,96 @@
1
1
  import { SCROLL_BAR_WIDTH } from '../constants';
2
- import { PLAIT_BOARD_TO_COMPONENT } from './weak-maps';
3
- export function invert(oldMatrix, newMatrix) {
4
- let n = newMatrix[0], r = newMatrix[1], a = newMatrix[2], i = newMatrix[3], o = newMatrix[4], c = newMatrix[5], l = newMatrix[6], s = newMatrix[7], u = newMatrix[8], d = u * o - c * s, h = -u * i + c * l, f = s * i - o * l, p = n * d + r * h + a * f;
5
- return p
6
- ? ((p = 1 / p),
7
- (oldMatrix[0] = d * p),
8
- (oldMatrix[1] = (-u * r + a * s) * p),
9
- (oldMatrix[2] = (c * r - a * o) * p),
10
- (oldMatrix[3] = h * p),
11
- (oldMatrix[4] = (u * n - a * l) * p),
12
- (oldMatrix[5] = (-c * n + a * i) * p),
13
- (oldMatrix[6] = f * p),
14
- (oldMatrix[7] = (-s * n + r * l) * p),
15
- (oldMatrix[8] = (o * n - r * i) * p),
16
- oldMatrix)
17
- : null;
2
+ /**
3
+ * 逆矩阵
4
+ * [a c e]
5
+ * [b d f]
6
+ * [0 0 1]
7
+ * @param newMatrix 输出返回矩阵
8
+ * @param matrix 新矩阵
9
+ * @returns 逆矩阵
10
+ */
11
+ export function invertMatrix(newMatrix, matrix) {
12
+ const [n, r, a, i, o, c, l, s, u] = matrix;
13
+ const determinant = u * o - c * s;
14
+ const h = -u * i + c * l;
15
+ const f = s * i - o * l;
16
+ const product = n * determinant + r * h + a * f;
17
+ if (!product) {
18
+ return null;
19
+ }
20
+ const reciprocal = 1 / product;
21
+ newMatrix[0] = determinant * reciprocal;
22
+ newMatrix[1] = (-u * r + a * s) * reciprocal;
23
+ newMatrix[2] = (c * r - a * o) * reciprocal;
24
+ newMatrix[3] = h * reciprocal;
25
+ newMatrix[4] = (u * n - a * l) * reciprocal;
26
+ newMatrix[5] = (-c * n + a * i) * reciprocal;
27
+ newMatrix[6] = f * reciprocal;
28
+ newMatrix[7] = (-s * n + r * l) * reciprocal;
29
+ newMatrix[8] = (o * n - r * i) * reciprocal;
30
+ return newMatrix;
18
31
  }
19
- export function transformMat3(e, t, n) {
20
- e = [t[0] * n[0] + t[1] * n[3] + t[2] * n[6], t[0] * n[1] + t[1] * n[4] + t[2] * n[7], t[0] * n[2] + t[1] * n[5] + t[2] * n[8]];
21
- return e;
32
+ /**
33
+ * 将视图坐标与反转矩阵相乘,以得到原始坐标
34
+ * 使用给定的矩阵进行转换
35
+ * 矩阵与向量乘法,3 维向量与3x3矩阵的乘积
36
+ * [m11 m12 m13][v1]
37
+ * [m21 m22 m23][v2]
38
+ * [m31 m32 m33][v3]
39
+ * @param out 输出结果向量
40
+ * @param t 要转换的向量
41
+ * @param n 矩阵转换
42
+ * @returns [v1 * m11 + v2 * m12 + v3 * m13, v1 * m21 + v2 * m22 + v3 * m23, v1 * m31 + v2 * m32 + v3 * m33];
43
+ */
44
+ export function transformMat3(out, vector, matrix) {
45
+ out = [
46
+ vector[0] * matrix[0] + vector[1] * matrix[3] + vector[2] * matrix[6],
47
+ vector[0] * matrix[1] + vector[1] * matrix[4] + vector[2] * matrix[7],
48
+ vector[0] * matrix[2] + vector[1] * matrix[5] + vector[2] * matrix[8]
49
+ ];
50
+ return out;
22
51
  }
23
- export function convertPoint(arr) {
24
- return Array.isArray(arr)
52
+ /**
53
+ * 规范 point
54
+ * @param point
55
+ * @returns point
56
+ */
57
+ export function normalizePoint(point) {
58
+ return Array.isArray(point)
25
59
  ? {
26
- x: arr[0],
27
- y: arr[1]
60
+ x: point[0],
61
+ y: point[1]
28
62
  }
29
- : arr;
30
- }
31
- export function invertClient(board, point, matrix) {
32
- const convert = convertPoint(point);
33
- const clientBox = getViewportClientBox(board);
34
- const newPoint = [convert.x - clientBox.x, convert.y - clientBox.y, 1];
35
- const invertMatrix = invert([], matrix);
36
- const newMatrix = transformMat3([], [newPoint[0], newPoint[1], 1], invertMatrix);
37
- return [newMatrix[0], newMatrix[1]];
38
- }
39
- export function invertViewport(point, matrix) {
40
- const newPoint = convertPoint(point);
41
- const invertMatrix = invert([], matrix);
42
- return transformMat3([], [newPoint.x, newPoint.y, 1], invertMatrix);
63
+ : point;
43
64
  }
44
- export function convertViewport(point, matrix) {
45
- const newPoint = convertPoint(point);
46
- return transformMat3([], [newPoint.x, newPoint.y, 1], matrix);
65
+ /**
66
+ * 将一个点坐标反转回它的原始坐标
67
+ * @param point 表示要反转的点的视图坐标,它是一个长度为 2 的数组,存储点的 x y 坐标
68
+ * @param matrix 表示视图矩阵,是在视图中对图形进行缩放和平移时使用的矩阵
69
+ * @returns 最终结果是一个长度为 3 的数组,存储点的 x,y 和 w 坐标(w 坐标是点的齐次坐标)
70
+ */
71
+ export function invertViewportCoordinates(point, matrix) {
72
+ const { x, y } = normalizePoint(point);
73
+ const invertedMatrix = invertMatrix([], matrix);
74
+ return transformMat3([], [x, y, 1], invertedMatrix);
47
75
  }
48
- export function getViewportCanvasBox(board, matrix) {
49
- const clientBox = getViewportClientBox(board);
50
- const client = invertClient(board, [clientBox.minX, clientBox.minY], matrix);
51
- const newClient = invertClient(board, [clientBox.maxX, clientBox.maxY], matrix);
52
- return {
53
- minX: client[0],
54
- minY: client[1],
55
- maxX: newClient[0],
56
- maxY: newClient[1],
57
- x: client[0],
58
- y: client[1],
59
- width: newClient[0] - client[0],
60
- height: newClient[1] - client[1]
61
- };
76
+ export function convertToViewportCoordinates(point, matrix) {
77
+ const { x, y } = normalizePoint(point);
78
+ return transformMat3([], [x, y, 1], matrix);
62
79
  }
63
- export function getViewportClientBox(board) {
80
+ /**
81
+ * 获取 contentContainer 的 clientBox
82
+ * @param board
83
+ * @returns
84
+ */
85
+ export function getViewportContainerBox(board) {
86
+ const { hideScrollbar } = board.options;
87
+ const scrollBarWidth = hideScrollbar ? SCROLL_BAR_WIDTH : 0;
64
88
  const container = board.host?.parentElement;
65
89
  const containerRect = container?.getBoundingClientRect();
66
90
  const x = containerRect.x || containerRect.left;
67
91
  const y = containerRect.y || containerRect.top;
68
- const width = containerRect.width - SCROLL_BAR_WIDTH;
69
- const height = containerRect.height - SCROLL_BAR_WIDTH;
92
+ const width = containerRect.width - scrollBarWidth;
93
+ const height = containerRect.height - scrollBarWidth;
70
94
  return {
71
95
  minX: x,
72
96
  minY: y,
@@ -78,40 +102,69 @@ export function getViewportClientBox(board) {
78
102
  height
79
103
  };
80
104
  }
81
- export function getGraphicsBBox(board) {
82
- const rootGroup = board.host.firstChild;
83
- const rootGroupBox = rootGroup.getBBox();
84
- return rootGroupBox;
105
+ /**
106
+ * 获取 board.plait-board 的 clientBox
107
+ * @param board
108
+ * @returns
109
+ */
110
+ export function getBoardClientBox(board) {
111
+ const { hideScrollbar } = board.options;
112
+ const scrollBarWidth = hideScrollbar ? SCROLL_BAR_WIDTH : 0;
113
+ const boardEl = board.host?.parentElement?.parentElement;
114
+ const elRect = boardEl?.getBoundingClientRect();
115
+ return {
116
+ width: elRect.width + scrollBarWidth,
117
+ height: elRect.height + scrollBarWidth
118
+ };
85
119
  }
86
- export function calculateBBox(board, zoom) {
87
- const boardComponent = PLAIT_BOARD_TO_COMPONENT.get(board);
88
- // const clientBox = getViewportClientBox(board);
120
+ /**
121
+ * 获取 rootGroup 相对于当前 svg 空间的最小矩阵坐标
122
+ */
123
+ export function getRootGroupBBox(board, zoom) {
89
124
  const rootGroup = board.host.firstChild;
90
125
  const rootGroupBox = rootGroup.getBBox();
91
- let box = {};
92
- const containerWidth = boardComponent.width / zoom;
93
- const containerHeight = boardComponent.height / zoom;
126
+ const viewportContainerBox = getViewportContainerBox(board);
127
+ const containerWidth = viewportContainerBox.width / zoom;
128
+ const containerHeight = viewportContainerBox.height / zoom;
129
+ let left;
130
+ let right;
131
+ let top;
132
+ let bottom;
94
133
  if (rootGroupBox.width < containerWidth) {
95
134
  const offsetX = rootGroupBox.x + rootGroupBox.width / 2;
96
135
  const containerX = containerWidth / 2;
97
- box.left = offsetX - containerX;
98
- box.right = offsetX + containerX;
136
+ left = offsetX - containerX;
137
+ right = offsetX + containerX;
99
138
  }
100
139
  else {
101
- box.left = rootGroupBox.x;
102
- box.right = rootGroupBox.x + rootGroupBox.width;
140
+ left = rootGroupBox.x;
141
+ right = rootGroupBox.x + rootGroupBox.width;
103
142
  }
104
143
  if (rootGroupBox.height < containerHeight) {
105
144
  const offsetY = rootGroupBox.y + rootGroupBox.height / 2;
106
145
  const containerY = containerHeight / 2;
107
- box.top = offsetY - containerY;
108
- box.bottom = offsetY + containerY;
146
+ top = offsetY - containerY;
147
+ bottom = offsetY + containerY;
109
148
  }
110
149
  else {
111
- box.top = rootGroupBox.y;
112
- box.bottom = rootGroupBox.y + rootGroupBox.height;
150
+ top = rootGroupBox.y;
151
+ bottom = rootGroupBox.y + rootGroupBox.height;
113
152
  }
114
- // 在新的缩放比容器宽高下的内容盒子位置
115
- return box;
153
+ return {
154
+ left,
155
+ right,
156
+ top,
157
+ bottom
158
+ };
159
+ }
160
+ /**
161
+ * 验证缩放比是否符合限制,如果超出限制,则返回合适的缩放比
162
+ * @param zoom 缩放比
163
+ * @param minZoom 最小缩放比
164
+ * @param maxZoom 最大缩放比
165
+ * @returns 正确的缩放比
166
+ */
167
+ export function clampZoomLevel(zoom, minZoom = 0.2, maxZoom = 4) {
168
+ return zoom < minZoom ? minZoom : zoom > maxZoom ? maxZoom : zoom;
116
169
  }
117
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"matrix.js","sourceRoot":"","sources":["../../../../packages/plait/src/utils/matrix.ts"],"names":[],"mappings":"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","sourcesContent":["import { SCROLL_BAR_WIDTH } from '../constants';\nimport { PlaitBoard } from '../interfaces';\nimport { PLAIT_BOARD_TO_COMPONENT } from './weak-maps';\n\nexport function invert(oldMatrix: number[], newMatrix: number[]) {\n    let n = newMatrix[0],\n        r = newMatrix[1],\n        a = newMatrix[2],\n        i = newMatrix[3],\n        o = newMatrix[4],\n        c = newMatrix[5],\n        l = newMatrix[6],\n        s = newMatrix[7],\n        u = newMatrix[8],\n        d = u * o - c * s,\n        h = -u * i + c * l,\n        f = s * i - o * l,\n        p = n * d + r * h + a * f;\n\n    return p\n        ? ((p = 1 / p),\n          (oldMatrix[0] = d * p),\n          (oldMatrix[1] = (-u * r + a * s) * p),\n          (oldMatrix[2] = (c * r - a * o) * p),\n          (oldMatrix[3] = h * p),\n          (oldMatrix[4] = (u * n - a * l) * p),\n          (oldMatrix[5] = (-c * n + a * i) * p),\n          (oldMatrix[6] = f * p),\n          (oldMatrix[7] = (-s * n + r * l) * p),\n          (oldMatrix[8] = (o * n - r * i) * p),\n          oldMatrix)\n        : null;\n}\n\nexport function transformMat3(e: number[], t: number[], n: number[]) {\n    e = [t[0] * n[0] + t[1] * n[3] + t[2] * n[6], t[0] * n[1] + t[1] * n[4] + t[2] * n[7], t[0] * n[2] + t[1] * n[5] + t[2] * n[8]];\n    return e;\n}\n\nexport function convertPoint(arr: number[]) {\n    return Array.isArray(arr)\n        ? {\n              x: arr[0],\n              y: arr[1]\n          }\n        : arr;\n}\n\nexport function invertClient(board: PlaitBoard, point: number[], matrix: number[]) {\n    const convert = convertPoint(point);\n    const clientBox = getViewportClientBox(board);\n    const newPoint = [convert.x - clientBox.x, convert.y - clientBox.y, 1];\n    const invertMatrix = invert([], matrix);\n    const newMatrix = transformMat3([], [newPoint[0], newPoint[1], 1], invertMatrix as []);\n\n    return [newMatrix[0], newMatrix[1]];\n}\n\nexport function invertViewport(point: number[], matrix: number[]) {\n    const newPoint = convertPoint(point);\n    const invertMatrix = invert([], matrix);\n    return transformMat3([], [newPoint.x, newPoint.y, 1], invertMatrix as []);\n}\n\nexport function convertViewport(point: number[], matrix: number[]) {\n    const newPoint = convertPoint(point);\n    return transformMat3([], [newPoint.x, newPoint.y, 1], matrix);\n}\n\nexport function getViewportCanvasBox(board: PlaitBoard, matrix: number[]) {\n    const clientBox = getViewportClientBox(board);\n    const client = invertClient(board, [clientBox.minX, clientBox.minY], matrix);\n    const newClient = invertClient(board, [clientBox.maxX, clientBox.maxY], matrix);\n\n    return {\n        minX: client[0],\n        minY: client[1],\n        maxX: newClient[0],\n        maxY: newClient[1],\n        x: client[0],\n        y: client[1],\n        width: newClient[0] - client[0],\n        height: newClient[1] - client[1]\n    };\n}\n\nexport function getViewportClientBox(board: PlaitBoard) {\n    const container = board.host?.parentElement as HTMLElement;\n    const containerRect = container?.getBoundingClientRect();\n    const x = containerRect.x || containerRect.left;\n    const y = containerRect.y || containerRect.top;\n    const width = containerRect.width - SCROLL_BAR_WIDTH;\n    const height = containerRect.height - SCROLL_BAR_WIDTH;\n\n    return {\n        minX: x,\n        minY: y,\n        maxX: x + width,\n        maxY: y + height,\n        x,\n        y,\n        width,\n        height\n    };\n}\n\nexport function getGraphicsBBox(board: PlaitBoard) {\n    const rootGroup = board.host.firstChild;\n    const rootGroupBox = (rootGroup as SVGGraphicsElement).getBBox();\n    return rootGroupBox;\n}\n\nexport function calculateBBox(board: PlaitBoard, zoom: number) {\n    const boardComponent = PLAIT_BOARD_TO_COMPONENT.get(board);\n    // const clientBox = getViewportClientBox(board);\n    const rootGroup = board.host.firstChild;\n    const rootGroupBox = (rootGroup as SVGGraphicsElement).getBBox();\n\n    let box = {} as any;\n    const containerWidth = boardComponent!.width / zoom;\n    const containerHeight = boardComponent!.height / zoom;\n\n    if (rootGroupBox.width < containerWidth) {\n        const offsetX = rootGroupBox.x + rootGroupBox.width / 2;\n        const containerX = containerWidth / 2;\n        box.left = offsetX - containerX;\n        box.right = offsetX + containerX;\n    } else {\n        box.left = rootGroupBox.x;\n        box.right = rootGroupBox.x + rootGroupBox.width;\n    }\n\n    if (rootGroupBox.height < containerHeight) {\n        const offsetY = rootGroupBox.y + rootGroupBox.height / 2;\n        const containerY = containerHeight / 2;\n        box.top = offsetY - containerY;\n        box.bottom = offsetY + containerY;\n    } else {\n        box.top = rootGroupBox.y;\n        box.bottom = rootGroupBox.y + rootGroupBox.height;\n    }\n\n    // 在新的缩放比容器宽高下的内容盒子位置\n    return box;\n}\n"]}
170
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"matrix.js","sourceRoot":"","sources":["../../../../packages/plait/src/utils/matrix.ts"],"names":[],"mappings":"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","sourcesContent":["import { SCROLL_BAR_WIDTH } from '../constants';\nimport { PlaitBoard } from '../interfaces';\n\n/**\n * 逆矩阵\n * [a c e]\n * [b d f]\n * [0 0 1]\n * @param newMatrix 输出返回矩阵\n * @param matrix 新矩阵\n * @returns 逆矩阵\n */\nexport function invertMatrix(newMatrix: number[], matrix: number[]) {\n    const [n, r, a, i, o, c, l, s, u] = matrix;\n    const determinant = u * o - c * s;\n    const h = -u * i + c * l;\n    const f = s * i - o * l;\n    const product = n * determinant + r * h + a * f;\n\n    if (!product) {\n        return null;\n    }\n\n    const reciprocal = 1 / product;\n    newMatrix[0] = determinant * reciprocal;\n    newMatrix[1] = (-u * r + a * s) * reciprocal;\n    newMatrix[2] = (c * r - a * o) * reciprocal;\n    newMatrix[3] = h * reciprocal;\n    newMatrix[4] = (u * n - a * l) * reciprocal;\n    newMatrix[5] = (-c * n + a * i) * reciprocal;\n    newMatrix[6] = f * reciprocal;\n    newMatrix[7] = (-s * n + r * l) * reciprocal;\n    newMatrix[8] = (o * n - r * i) * reciprocal;\n\n    return newMatrix;\n}\n\n/**\n * 将视图坐标与反转矩阵相乘，以得到原始坐标\n * 使用给定的矩阵进行转换\n * 矩阵与向量乘法，3 维向量与3x3矩阵的乘积\n * [m11 m12 m13][v1]\n * [m21 m22 m23][v2]\n * [m31 m32 m33][v3]\n * @param out 输出结果向量\n * @param t 要转换的向量\n * @param n 矩阵转换\n * @returns [v1 * m11 + v2 * m12 + v3 * m13, v1 * m21 + v2 * m22 + v3 * m23, v1 * m31 + v2 * m32 + v3 * m33];\n */\nexport function transformMat3(out: number[], vector: number[], matrix: number[]) {\n    out = [\n        vector[0] * matrix[0] + vector[1] * matrix[3] + vector[2] * matrix[6],\n        vector[0] * matrix[1] + vector[1] * matrix[4] + vector[2] * matrix[7],\n        vector[0] * matrix[2] + vector[1] * matrix[5] + vector[2] * matrix[8]\n    ];\n    return out;\n}\n\n/**\n * 规范 point\n * @param point\n * @returns point\n */\nexport function normalizePoint(point: number[]) {\n    return Array.isArray(point)\n        ? {\n              x: point[0],\n              y: point[1]\n          }\n        : point;\n}\n\n/**\n * 将一个点坐标反转回它的原始坐标\n * @param point 表示要反转的点的视图坐标，它是一个长度为 2 的数组，存储点的 x 和 y 坐标\n * @param matrix 表示视图矩阵，是在视图中对图形进行缩放和平移时使用的矩阵\n * @returns 最终结果是一个长度为 3 的数组，存储点的 x，y 和 w 坐标（w 坐标是点的齐次坐标)\n */\nexport function invertViewportCoordinates(point: number[], matrix: number[]) {\n    const { x, y } = normalizePoint(point);\n    const invertedMatrix = invertMatrix([], matrix);\n    return transformMat3([], [x, y, 1], invertedMatrix as []);\n}\n\nexport function convertToViewportCoordinates(point: number[], matrix: number[]) {\n    const { x, y } = normalizePoint(point);\n    return transformMat3([], [x, y, 1], matrix);\n}\n\n/**\n * 获取 contentContainer 的 clientBox\n * @param board\n * @returns\n */\nexport function getViewportContainerBox(board: PlaitBoard) {\n    const { hideScrollbar } = board.options;\n    const scrollBarWidth = hideScrollbar ? SCROLL_BAR_WIDTH : 0;\n    const container = board.host?.parentElement as HTMLElement;\n    const containerRect = container?.getBoundingClientRect();\n    const x = containerRect.x || containerRect.left;\n    const y = containerRect.y || containerRect.top;\n    const width = containerRect.width - scrollBarWidth;\n    const height = containerRect.height - scrollBarWidth;\n\n    return {\n        minX: x,\n        minY: y,\n        maxX: x + width,\n        maxY: y + height,\n        x,\n        y,\n        width,\n        height\n    };\n}\n\n/**\n * 获取 board.plait-board 的 clientBox\n * @param board\n * @returns\n */\nexport function getBoardClientBox(board: PlaitBoard) {\n    const { hideScrollbar } = board.options;\n    const scrollBarWidth = hideScrollbar ? SCROLL_BAR_WIDTH : 0;\n    const boardEl = board.host?.parentElement?.parentElement as HTMLElement;\n    const elRect = boardEl?.getBoundingClientRect();\n\n    return {\n        width: elRect.width + scrollBarWidth,\n        height: elRect.height + scrollBarWidth\n    };\n}\n\n/**\n * 获取 rootGroup 相对于当前 svg 空间的最小矩阵坐标\n */\nexport function getRootGroupBBox(board: PlaitBoard, zoom: number) {\n    const rootGroup = board.host.firstChild as SVGGraphicsElement;\n    const rootGroupBox = rootGroup.getBBox();\n    const viewportContainerBox = getViewportContainerBox(board);\n    const containerWidth = viewportContainerBox.width / zoom;\n    const containerHeight = viewportContainerBox.height / zoom;\n    let left: number;\n    let right: number;\n    let top: number;\n    let bottom: number;\n\n    if (rootGroupBox.width < containerWidth) {\n        const offsetX = rootGroupBox.x + rootGroupBox.width / 2;\n        const containerX = containerWidth / 2;\n        left = offsetX - containerX;\n        right = offsetX + containerX;\n    } else {\n        left = rootGroupBox.x;\n        right = rootGroupBox.x + rootGroupBox.width;\n    }\n    if (rootGroupBox.height < containerHeight) {\n        const offsetY = rootGroupBox.y + rootGroupBox.height / 2;\n        const containerY = containerHeight / 2;\n        top = offsetY - containerY;\n        bottom = offsetY + containerY;\n    } else {\n        top = rootGroupBox.y;\n        bottom = rootGroupBox.y + rootGroupBox.height;\n    }\n    return {\n        left,\n        right,\n        top,\n        bottom\n    };\n}\n\n/**\n * 验证缩放比是否符合限制，如果超出限制，则返回合适的缩放比\n * @param zoom 缩放比\n * @param minZoom 最小缩放比\n * @param maxZoom 最大缩放比\n * @returns 正确的缩放比\n */\nexport function clampZoomLevel(zoom: number, minZoom = 0.2, maxZoom = 4) {\n    return zoom < minZoom ? minZoom : zoom > maxZoom ? maxZoom : zoom;\n}\n"]}
@@ -4,4 +4,4 @@ export const IS_TEXT_EDITABLE = new WeakMap();
4
4
  export const BOARD_TO_ON_CHANGE = new WeakMap();
5
5
  export const HOST_TO_ROUGH_SVG = new WeakMap();
6
6
  export const PLAIT_BOARD_TO_COMPONENT = new WeakMap();
7
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2Vhay1tYXBzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcGFja2FnZXMvcGxhaXQvc3JjL3V0aWxzL3dlYWstbWFwcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFJQSw4QkFBOEI7QUFDOUIsTUFBTSxDQUFDLE1BQU0sUUFBUSxHQUFpQyxJQUFJLE9BQU8sRUFBRSxDQUFDO0FBRXBFLE1BQU0sQ0FBQyxNQUFNLGdCQUFnQixHQUFHLElBQUksT0FBTyxFQUF1QixDQUFDO0FBRW5FLE1BQU0sQ0FBQyxNQUFNLGtCQUFrQixHQUFHLElBQUksT0FBTyxFQUEwQixDQUFDO0FBRXhFLE1BQU0sQ0FBQyxNQUFNLGlCQUFpQixHQUFHLElBQUksT0FBTyxFQUF3QixDQUFDO0FBRXJFLE1BQU0sQ0FBQyxNQUFNLHdCQUF3QixHQUFHLElBQUksT0FBTyxFQUFtQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUm91Z2hTVkcgfSBmcm9tICdyb3VnaGpzL2Jpbi9zdmcnO1xuaW1wb3J0IHsgUGxhaXRCb2FyZENvbXBvbmVudCB9IGZyb20gJy4uL2JvYXJkL2JvYXJkLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBQbGFpdEJvYXJkIH0gZnJvbSAnLi4vaW50ZXJmYWNlcy9ib2FyZCc7XG5cbi8vIHJlY29yZCByaWNodGV4dCB0eXBlIHN0YXR1c1xuZXhwb3J0IGNvbnN0IEZMVVNISU5HOiBXZWFrTWFwPFBsYWl0Qm9hcmQsIGJvb2xlYW4+ID0gbmV3IFdlYWtNYXAoKTtcblxuZXhwb3J0IGNvbnN0IElTX1RFWFRfRURJVEFCTEUgPSBuZXcgV2Vha01hcDxQbGFpdEJvYXJkLCBib29sZWFuPigpO1xuXG5leHBvcnQgY29uc3QgQk9BUkRfVE9fT05fQ0hBTkdFID0gbmV3IFdlYWtNYXA8UGxhaXRCb2FyZCwgKCkgPT4gdm9pZD4oKTtcblxuZXhwb3J0IGNvbnN0IEhPU1RfVE9fUk9VR0hfU1ZHID0gbmV3IFdlYWtNYXA8U1ZHRWxlbWVudCwgUm91Z2hTVkc+KCk7XG5cbmV4cG9ydCBjb25zdCBQTEFJVF9CT0FSRF9UT19DT01QT05FTlQgPSBuZXcgV2Vha01hcDxQbGFpdEJvYXJkLCBQbGFpdEJvYXJkQ29tcG9uZW50PigpO1xuIl19
7
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2Vhay1tYXBzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcGFja2FnZXMvcGxhaXQvc3JjL3V0aWxzL3dlYWstbWFwcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFJQSw4QkFBOEI7QUFDOUIsTUFBTSxDQUFDLE1BQU0sUUFBUSxHQUFpQyxJQUFJLE9BQU8sRUFBRSxDQUFDO0FBRXBFLE1BQU0sQ0FBQyxNQUFNLGdCQUFnQixHQUFHLElBQUksT0FBTyxFQUF1QixDQUFDO0FBRW5FLE1BQU0sQ0FBQyxNQUFNLGtCQUFrQixHQUFHLElBQUksT0FBTyxFQUEwQixDQUFDO0FBRXhFLE1BQU0sQ0FBQyxNQUFNLGlCQUFpQixHQUFHLElBQUksT0FBTyxFQUF3QixDQUFDO0FBRXJFLE1BQU0sQ0FBQyxNQUFNLHdCQUF3QixHQUFHLElBQUksT0FBTyxFQUF1QyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUm91Z2hTVkcgfSBmcm9tICdyb3VnaGpzL2Jpbi9zdmcnO1xuaW1wb3J0IHsgQm9hcmRDb21wb25lbnRJbnRlcmZhY2UgfSBmcm9tICcuLi9ib2FyZC9ib2FyZC5jb21wb25lbnQuaW50ZXJmYWNlJztcbmltcG9ydCB7IFBsYWl0Qm9hcmQgfSBmcm9tICcuLi9pbnRlcmZhY2VzL2JvYXJkJztcblxuLy8gcmVjb3JkIHJpY2h0ZXh0IHR5cGUgc3RhdHVzXG5leHBvcnQgY29uc3QgRkxVU0hJTkc6IFdlYWtNYXA8UGxhaXRCb2FyZCwgYm9vbGVhbj4gPSBuZXcgV2Vha01hcCgpO1xuXG5leHBvcnQgY29uc3QgSVNfVEVYVF9FRElUQUJMRSA9IG5ldyBXZWFrTWFwPFBsYWl0Qm9hcmQsIGJvb2xlYW4+KCk7XG5cbmV4cG9ydCBjb25zdCBCT0FSRF9UT19PTl9DSEFOR0UgPSBuZXcgV2Vha01hcDxQbGFpdEJvYXJkLCAoKSA9PiB2b2lkPigpO1xuXG5leHBvcnQgY29uc3QgSE9TVF9UT19ST1VHSF9TVkcgPSBuZXcgV2Vha01hcDxTVkdFbGVtZW50LCBSb3VnaFNWRz4oKTtcblxuZXhwb3J0IGNvbnN0IFBMQUlUX0JPQVJEX1RPX0NPTVBPTkVOVCA9IG5ldyBXZWFrTWFwPFBsYWl0Qm9hcmQsIEJvYXJkQ29tcG9uZW50SW50ZXJmYWNlPigpOyJdfQ==