@plait/core 0.0.47 → 0.0.49
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/board/board.component.d.ts +3 -2
- package/esm2020/board/board.component.mjs +12 -14
- package/esm2020/core/toolbar/toolbar.component.mjs +2 -2
- package/esm2020/plugins/create-board.mjs +2 -2
- package/esm2020/plugins/with-move.mjs +4 -1
- package/esm2020/plugins/with-selection.mjs +3 -3
- package/esm2020/public-api.mjs +6 -6
- package/esm2020/{transfroms → transforms}/general.mjs +1 -1
- package/esm2020/{transfroms → transforms}/index.mjs +1 -1
- package/esm2020/{transfroms → transforms}/node.mjs +1 -1
- package/esm2020/{transfroms → transforms}/selection.mjs +1 -1
- package/esm2020/{transfroms → transforms}/viewport.mjs +1 -1
- package/esm2020/utils/board.mjs +1 -13
- package/fesm2015/plait-core.mjs +15 -26
- package/fesm2015/plait-core.mjs.map +1 -1
- package/fesm2020/plait-core.mjs +15 -26
- package/fesm2020/plait-core.mjs.map +1 -1
- package/package.json +1 -1
- package/public-api.d.ts +5 -5
- package/{transfroms → transforms}/general.d.ts +0 -0
- package/{transfroms → transforms}/index.d.ts +0 -0
- package/{transfroms → transforms}/node.d.ts +0 -0
- package/{transfroms → transforms}/selection.d.ts +0 -0
- package/{transfroms → transforms}/viewport.d.ts +0 -0
- package/utils/board.d.ts +8 -20
|
@@ -34,4 +34,4 @@ export const NodeTransforms = {
|
|
|
34
34
|
removeNode,
|
|
35
35
|
moveNode
|
|
36
36
|
};
|
|
37
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
37
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm9kZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3BhY2thZ2VzL3BsYWl0L3NyYy90cmFuc2Zvcm1zL25vZGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBRy9DLE1BQU0sVUFBVSxVQUFVLENBQUMsS0FBaUIsRUFBRSxJQUFlLEVBQUUsSUFBVTtJQUNyRSxNQUFNLFNBQVMsR0FBd0IsRUFBRSxJQUFJLEVBQUUsYUFBYSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsQ0FBQztJQUMzRSxLQUFLLENBQUMsS0FBSyxDQUFDLFNBQVMsQ0FBQyxDQUFDO0FBQzNCLENBQUM7QUFFRCxNQUFNLFVBQVUsT0FBTyxDQUFDLEtBQWlCLEVBQUUsS0FBeUIsRUFBRSxJQUFVO0lBQzVFLE1BQU0sVUFBVSxHQUF1QixFQUFFLENBQUM7SUFDMUMsTUFBTSxhQUFhLEdBQXVCLEVBQUUsQ0FBQztJQUM3QyxNQUFNLElBQUksR0FBRyxTQUFTLENBQUMsR0FBRyxDQUFDLEtBQUssRUFBRSxJQUFJLENBQUMsQ0FBQztJQUN4QyxLQUFLLE1BQU0sQ0FBQyxJQUFJLEtBQUssRUFBRTtRQUNuQixJQUFJLElBQUksQ0FBQyxDQUFDLENBQUMsS0FBSyxLQUFLLENBQUMsQ0FBQyxDQUFDLEVBQUU7WUFDdEIsSUFBSSxJQUFJLENBQUMsY0FBYyxDQUFDLENBQUMsQ0FBQyxFQUFFO2dCQUN4QixVQUFVLENBQUMsQ0FBQyxDQUFDLEdBQUcsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDO2FBQzNCO1lBQ0QsSUFBSSxLQUFLLENBQUMsQ0FBQyxDQUFDLElBQUksSUFBSTtnQkFBRSxhQUFhLENBQUMsQ0FBQyxDQUFDLEdBQUcsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDO1NBQ3JEO0tBQ0o7SUFDRCxNQUFNLFNBQVMsR0FBcUIsRUFBRSxJQUFJLEVBQUUsVUFBVSxFQUFFLFVBQVUsRUFBRSxhQUFhLEVBQUUsSUFBSSxFQUFFLENBQUM7SUFDMUYsS0FBSyxDQUFDLEtBQUssQ0FBQyxTQUFTLENBQUMsQ0FBQztBQUMzQixDQUFDO0FBRUQsTUFBTSxVQUFVLFVBQVUsQ0FBQyxLQUFpQixFQUFFLElBQVU7SUFDcEQsTUFBTSxJQUFJLEdBQUcsU0FBUyxDQUFDLEdBQUcsQ0FBQyxLQUFLLEVBQUUsSUFBSSxDQUFDLENBQUM7SUFDeEMsTUFBTSxTQUFTLEdBQXdCLEVBQUUsSUFBSSxFQUFFLGFBQWEsRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLENBQUM7SUFDM0UsS0FBSyxDQUFDLEtBQUssQ0FBQyxTQUFTLENBQUMsQ0FBQztBQUMzQixDQUFDO0FBRUQsTUFBTSxVQUFVLFFBQVEsQ0FBQyxLQUFpQixFQUFFLElBQVUsRUFBRSxPQUFhO0lBQ2pFLE1BQU0sU0FBUyxHQUFzQixFQUFFLElBQUksRUFBRSxXQUFXLEVBQUUsSUFBSSxFQUFFLE9BQU8sRUFBRSxDQUFDO0lBQzFFLEtBQUssQ0FBQyxLQUFLLENBQUMsU0FBUyxDQUFDLENBQUM7QUFDM0IsQ0FBQztBQVNELE1BQU0sQ0FBQyxNQUFNLGNBQWMsR0FBbUI7SUFDMUMsVUFBVTtJQUNWLE9BQU87SUFDUCxVQUFVO0lBQ1YsUUFBUTtDQUNYLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbnNlcnROb2RlT3BlcmF0aW9uLCBNb3ZlTm9kZU9wZXJhdGlvbiwgUmVtb3ZlTm9kZU9wZXJhdGlvbiwgU2V0Tm9kZU9wZXJhdGlvbiB9IGZyb20gJy4uL2ludGVyZmFjZXMvb3BlcmF0aW9uJztcbmltcG9ydCB7IFBsYWl0Qm9hcmQgfSBmcm9tICcuLi9pbnRlcmZhY2VzL2JvYXJkJztcbmltcG9ydCB7IFBsYWl0Tm9kZSB9IGZyb20gJy4uL2ludGVyZmFjZXMvbm9kZSc7XG5pbXBvcnQgeyBQYXRoIH0gZnJvbSAnLi4vaW50ZXJmYWNlcy9wYXRoJztcblxuZXhwb3J0IGZ1bmN0aW9uIGluc2VydE5vZGUoYm9hcmQ6IFBsYWl0Qm9hcmQsIG5vZGU6IFBsYWl0Tm9kZSwgcGF0aDogUGF0aCkge1xuICAgIGNvbnN0IG9wZXJhdGlvbjogSW5zZXJ0Tm9kZU9wZXJhdGlvbiA9IHsgdHlwZTogJ2luc2VydF9ub2RlJywgbm9kZSwgcGF0aCB9O1xuICAgIGJvYXJkLmFwcGx5KG9wZXJhdGlvbik7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBzZXROb2RlKGJvYXJkOiBQbGFpdEJvYXJkLCBwcm9wczogUGFydGlhbDxQbGFpdE5vZGU+LCBwYXRoOiBQYXRoKSB7XG4gICAgY29uc3QgcHJvcGVydGllczogUGFydGlhbDxQbGFpdE5vZGU+ID0ge307XG4gICAgY29uc3QgbmV3UHJvcGVydGllczogUGFydGlhbDxQbGFpdE5vZGU+ID0ge307XG4gICAgY29uc3Qgbm9kZSA9IFBsYWl0Tm9kZS5nZXQoYm9hcmQsIHBhdGgpO1xuICAgIGZvciAoY29uc3QgayBpbiBwcm9wcykge1xuICAgICAgICBpZiAobm9kZVtrXSAhPT0gcHJvcHNba10pIHtcbiAgICAgICAgICAgIGlmIChub2RlLmhhc093blByb3BlcnR5KGspKSB7XG4gICAgICAgICAgICAgICAgcHJvcGVydGllc1trXSA9IG5vZGVba107XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICBpZiAocHJvcHNba10gIT0gbnVsbCkgbmV3UHJvcGVydGllc1trXSA9IHByb3BzW2tdO1xuICAgICAgICB9XG4gICAgfVxuICAgIGNvbnN0IG9wZXJhdGlvbjogU2V0Tm9kZU9wZXJhdGlvbiA9IHsgdHlwZTogJ3NldF9ub2RlJywgcHJvcGVydGllcywgbmV3UHJvcGVydGllcywgcGF0aCB9O1xuICAgIGJvYXJkLmFwcGx5KG9wZXJhdGlvbik7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiByZW1vdmVOb2RlKGJvYXJkOiBQbGFpdEJvYXJkLCBwYXRoOiBQYXRoKSB7XG4gICAgY29uc3Qgbm9kZSA9IFBsYWl0Tm9kZS5nZXQoYm9hcmQsIHBhdGgpO1xuICAgIGNvbnN0IG9wZXJhdGlvbjogUmVtb3ZlTm9kZU9wZXJhdGlvbiA9IHsgdHlwZTogJ3JlbW92ZV9ub2RlJywgcGF0aCwgbm9kZSB9O1xuICAgIGJvYXJkLmFwcGx5KG9wZXJhdGlvbik7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBtb3ZlTm9kZShib2FyZDogUGxhaXRCb2FyZCwgcGF0aDogUGF0aCwgbmV3UGF0aDogUGF0aCkge1xuICAgIGNvbnN0IG9wZXJhdGlvbjogTW92ZU5vZGVPcGVyYXRpb24gPSB7IHR5cGU6ICdtb3ZlX25vZGUnLCBwYXRoLCBuZXdQYXRoIH07XG4gICAgYm9hcmQuYXBwbHkob3BlcmF0aW9uKTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBOb2RlVHJhbnNmb3JtcyB7XG4gICAgaW5zZXJ0Tm9kZTogKGJvYXJkOiBQbGFpdEJvYXJkLCBub2RlOiBQbGFpdE5vZGUsIHBhdGg6IFBhdGgpID0+IHZvaWQ7XG4gICAgc2V0Tm9kZTogKGJvYXJkOiBQbGFpdEJvYXJkLCBub2RlOiBQYXJ0aWFsPFBsYWl0Tm9kZT4sIHBhdGg6IFBhdGgpID0+IHZvaWQ7XG4gICAgcmVtb3ZlTm9kZTogKGJvYXJkOiBQbGFpdEJvYXJkLCBwYXRoOiBQYXRoKSA9PiB2b2lkO1xuICAgIG1vdmVOb2RlOiAoYm9hcmQ6IFBsYWl0Qm9hcmQsIHBhdGg6IFBhdGgsIG5ld1BhdGg6IFBhdGgpID0+IHZvaWQ7XG59XG5cbmV4cG9ydCBjb25zdCBOb2RlVHJhbnNmb3JtczogTm9kZVRyYW5zZm9ybXMgPSB7XG4gICAgaW5zZXJ0Tm9kZSxcbiAgICBzZXROb2RlLFxuICAgIHJlbW92ZU5vZGUsXG4gICAgbW92ZU5vZGVcbn07XG4iXX0=
|
|
@@ -5,4 +5,4 @@ export function setSelection(board, selection) {
|
|
|
5
5
|
export const SelectionTransforms = {
|
|
6
6
|
setSelection
|
|
7
7
|
};
|
|
8
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
8
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcGFja2FnZXMvcGxhaXQvc3JjL3RyYW5zZm9ybXMvc2VsZWN0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUlBLE1BQU0sVUFBVSxZQUFZLENBQUMsS0FBaUIsRUFBRSxTQUEyQjtJQUN2RSxNQUFNLFNBQVMsR0FBMEIsRUFBRSxJQUFJLEVBQUUsZUFBZSxFQUFFLFVBQVUsRUFBRSxLQUFLLENBQUMsU0FBUyxFQUFFLGFBQWEsRUFBRSxTQUFTLEVBQUUsQ0FBQztJQUMxSCxLQUFLLENBQUMsS0FBSyxDQUFDLFNBQVMsQ0FBQyxDQUFDO0FBQzNCLENBQUM7QUFNRCxNQUFNLENBQUMsTUFBTSxtQkFBbUIsR0FBd0I7SUFDcEQsWUFBWTtDQUNmLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTZXRTZWxlY3Rpb25PcGVyYXRpb24gfSBmcm9tICcuLi9pbnRlcmZhY2VzL29wZXJhdGlvbic7XG5pbXBvcnQgeyBQbGFpdEJvYXJkIH0gZnJvbSAnLi4vaW50ZXJmYWNlcy9ib2FyZCc7XG5pbXBvcnQgeyBTZWxlY3Rpb24gfSBmcm9tICcuLi9pbnRlcmZhY2VzL3NlbGVjdGlvbic7XG5cbmV4cG9ydCBmdW5jdGlvbiBzZXRTZWxlY3Rpb24oYm9hcmQ6IFBsYWl0Qm9hcmQsIHNlbGVjdGlvbjogU2VsZWN0aW9uIHwgbnVsbCkge1xuICAgIGNvbnN0IG9wZXJhdGlvbjogU2V0U2VsZWN0aW9uT3BlcmF0aW9uID0geyB0eXBlOiAnc2V0X3NlbGVjdGlvbicsIHByb3BlcnRpZXM6IGJvYXJkLnNlbGVjdGlvbiwgbmV3UHJvcGVydGllczogc2VsZWN0aW9uIH07XG4gICAgYm9hcmQuYXBwbHkob3BlcmF0aW9uKTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBTZWxlY3Rpb25UcmFuc2Zvcm1zIHtcbiAgICBzZXRTZWxlY3Rpb246IChib2FyZDogUGxhaXRCb2FyZCwgc2VsZWN0aW9uOiBTZWxlY3Rpb24gfCBudWxsKSA9PiB2b2lkO1xufVxuXG5leHBvcnQgY29uc3QgU2VsZWN0aW9uVHJhbnNmb3JtczogU2VsZWN0aW9uVHJhbnNmb3JtcyA9IHtcbiAgICBzZXRTZWxlY3Rpb25cbn07XG4iXX0=
|
|
@@ -5,4 +5,4 @@ export function setViewport(board, viewport) {
|
|
|
5
5
|
export const ViewportTransforms = {
|
|
6
6
|
setViewport
|
|
7
7
|
};
|
|
8
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
8
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmlld3BvcnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9wbGFpdC9zcmMvdHJhbnNmb3Jtcy92aWV3cG9ydC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFJQSxNQUFNLFVBQVUsV0FBVyxDQUFDLEtBQWlCLEVBQUUsUUFBa0I7SUFDN0QsTUFBTSxTQUFTLEdBQXlCLEVBQUUsSUFBSSxFQUFFLGNBQWMsRUFBRSxVQUFVLEVBQUUsS0FBSyxDQUFDLFFBQVEsRUFBRSxhQUFhLEVBQUUsUUFBUSxFQUFFLENBQUM7SUFDdEgsS0FBSyxDQUFDLEtBQUssQ0FBQyxTQUFTLENBQUMsQ0FBQztBQUMzQixDQUFDO0FBTUQsTUFBTSxDQUFDLE1BQU0sa0JBQWtCLEdBQXVCO0lBQ2xELFdBQVc7Q0FDZCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgU2V0Vmlld3BvcnRPcGVyYXRpb24gfSBmcm9tICcuLi9pbnRlcmZhY2VzL29wZXJhdGlvbic7XG5pbXBvcnQgeyBQbGFpdEJvYXJkIH0gZnJvbSAnLi4vaW50ZXJmYWNlcy9ib2FyZCc7XG5pbXBvcnQgeyBWaWV3cG9ydCB9IGZyb20gJy4uL2ludGVyZmFjZXMvdmlld3BvcnQnO1xuXG5leHBvcnQgZnVuY3Rpb24gc2V0Vmlld3BvcnQoYm9hcmQ6IFBsYWl0Qm9hcmQsIHZpZXdwb3J0OiBWaWV3cG9ydCkge1xuICAgIGNvbnN0IG9wZXJhdGlvbjogU2V0Vmlld3BvcnRPcGVyYXRpb24gPSB7IHR5cGU6ICdzZXRfdmlld3BvcnQnLCBwcm9wZXJ0aWVzOiBib2FyZC52aWV3cG9ydCwgbmV3UHJvcGVydGllczogdmlld3BvcnQgfTtcbiAgICBib2FyZC5hcHBseShvcGVyYXRpb24pO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFZpZXdwb3J0VHJhbnNmb3JtcyB7XG4gICAgc2V0Vmlld3BvcnQ6IChib2FyZDogUGxhaXRCb2FyZCwgdmlld3BvcnQ6IFZpZXdwb3J0KSA9PiB2b2lkO1xufVxuXG5leHBvcnQgY29uc3QgVmlld3BvcnRUcmFuc2Zvcm1zOiBWaWV3cG9ydFRyYW5zZm9ybXMgPSB7XG4gICAgc2V0Vmlld3BvcnRcbn07XG4iXX0=
|
package/esm2020/utils/board.mjs
CHANGED
|
@@ -75,21 +75,9 @@ export function calculateZoom(zoom, minZoom = 0.2, maxZoom = 4) {
|
|
|
75
75
|
export function isNoSelectionElement(e) {
|
|
76
76
|
return e.target?.closest('.plait-board-attached');
|
|
77
77
|
}
|
|
78
|
-
/**
|
|
79
|
-
* viewZoom 转 zoom
|
|
80
|
-
* @param viewZoom 视图上显示的 zoom 缩放级别 %
|
|
81
|
-
* @returns zoom 真实的 zoom
|
|
82
|
-
*/
|
|
83
|
-
export const transformViewZoom = (viewZoom) => 2 - 100 / viewZoom;
|
|
84
|
-
/**
|
|
85
|
-
* zoom 转 viewZoom
|
|
86
|
-
* @param zoom this.board.viewport.zoom
|
|
87
|
-
* @returns 视图上显示的 zoom 缩放级别 %
|
|
88
|
-
*/
|
|
89
|
-
export const transformZoom = (zoom) => Number((100 / (2 - zoom)).toFixed(0));
|
|
90
78
|
export const updateCursorStatus = (board, cursor) => {
|
|
91
79
|
if (cursor) {
|
|
92
80
|
board.cursor = cursor;
|
|
93
81
|
}
|
|
94
82
|
};
|
|
95
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"board.js","sourceRoot":"","sources":["../../../../packages/plait/src/utils/board.ts"],"names":[],"mappings":"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","sourcesContent":["import { SCROLL_BAR_WIDTH } from '../constants';\nimport { BaseCursorStatus, PlaitBoard, Point } from '../interfaces';\n\nexport function transformPoints(board: PlaitBoard, points: Point[]) {\n    const newPoints = points.map(point => {\n        return transformPoint(board, point);\n    });\n    return newPoints;\n}\n\nexport function transformPoint(board: PlaitBoard, point: Point) {\n    const { width, height } = board.host.getBoundingClientRect();\n    const viewBox = (board.host as SVGSVGElement).viewBox.baseVal;\n    const x = (point[0] / width) * viewBox.width + viewBox.x;\n    const y = (point[1] / height) * viewBox.height + viewBox.y;\n    const newPoint = [x, y] as Point;\n\n    return newPoint;\n}\n\nexport function getViewBox(board: PlaitBoard): ViewBox {\n    const viewportBox = getViewportClientBox(board);\n    const rootGroupBBox = calculateBBox(board);\n    const padding = [viewportBox.height / 2, viewportBox.width / 2];\n    const zoom = board.viewport.zoom;\n    const minX = rootGroupBBox.left - padding[1] / zoom;\n    const minY = rootGroupBBox.top - padding[0] / zoom;\n    const viewportWidth = (rootGroupBBox.right - rootGroupBBox.left) * zoom + 2 * padding[1];\n    const viewportHeight = (rootGroupBBox.bottom - rootGroupBBox.top) * zoom + 2 * padding[0];\n    const width = viewportWidth / zoom;\n    const height = viewportHeight / zoom;\n\n    return { minX, minY, width, height, viewportWidth, viewportHeight };\n}\n\nexport function getViewportClientBox(board: PlaitBoard) {\n    const hideScrollbar = board.options.hideScrollbar;\n    const scrollBarWidth = hideScrollbar ? SCROLL_BAR_WIDTH : 0;\n    const container = board.host?.parentElement as HTMLElement;\n    const containerRect = container?.getBoundingClientRect();\n    const width = containerRect.width - scrollBarWidth;\n    const height = containerRect.height - scrollBarWidth;\n\n    return {\n        width,\n        height\n    };\n}\n\nexport function calculateBBox(board: PlaitBoard) {\n    const viewportBox = getViewportClientBox(board);\n    const rootGroup = board.host.firstChild;\n    const zoom = board.viewport.zoom;\n    const rootGroupBox = (rootGroup as SVGGraphicsElement).getBBox();\n\n    let box = {} as any;\n    const containerWidth = viewportBox.width / zoom;\n    const containerHeight = viewportBox.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\nexport function calculateZoom(zoom: number, minZoom = 0.2, maxZoom = 4) {\n    return zoom < minZoom ? minZoom : zoom > maxZoom ? maxZoom : zoom;\n}\n\nexport function isNoSelectionElement(e: Event) {\n    return (e.target as HTMLElement)?.closest('.plait-board-attached');\n}\n\n/**\n * viewZoom 转 zoom\n * @param viewZoom 视图上显示的 zoom 缩放级别 %\n * @returns zoom 真实的 zoom\n */\nexport const transformViewZoom = (viewZoom: number): number => 2 - 100 / viewZoom;\n\n/**\n * zoom 转 viewZoom\n * @param zoom this.board.viewport.zoom\n * @returns 视图上显示的 zoom 缩放级别 %\n */\nexport const transformZoom = (zoom: number): number => Number((100 / (2 - zoom)).toFixed(0));\n\nexport const updateCursorStatus = (board: PlaitBoard, cursor: BaseCursorStatus) => {\n    if (cursor) {\n        board.cursor = cursor;\n    }\n};\n\nexport type ViewBox = {\n    minX: number;\n    minY: number;\n    width: number;\n    height: number;\n    viewportWidth: number;\n    viewportHeight: number;\n};\n"]}
|
|
83
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"board.js","sourceRoot":"","sources":["../../../../packages/plait/src/utils/board.ts"],"names":[],"mappings":"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","sourcesContent":["import { SCROLL_BAR_WIDTH } from '../constants';\nimport { BaseCursorStatus, PlaitBoard, Point } from '../interfaces';\n\nexport type ViewBox = {\n    minX: number;\n    minY: number;\n    width: number;\n    height: number;\n    viewportWidth: number;\n    viewportHeight: number;\n};\n\nexport function transformPoints(board: PlaitBoard, points: Point[]) {\n    const newPoints = points.map(point => {\n        return transformPoint(board, point);\n    });\n    return newPoints;\n}\n\nexport function transformPoint(board: PlaitBoard, point: Point) {\n    const { width, height } = board.host.getBoundingClientRect();\n    const viewBox = (board.host as SVGSVGElement).viewBox.baseVal;\n    const x = (point[0] / width) * viewBox.width + viewBox.x;\n    const y = (point[1] / height) * viewBox.height + viewBox.y;\n    const newPoint = [x, y] as Point;\n\n    return newPoint;\n}\n\nexport function getViewBox(board: PlaitBoard): ViewBox {\n    const viewportBox = getViewportClientBox(board);\n    const rootGroupBBox = calculateBBox(board);\n    const padding = [viewportBox.height / 2, viewportBox.width / 2];\n    const zoom = board.viewport.zoom;\n    const minX = rootGroupBBox.left - padding[1] / zoom;\n    const minY = rootGroupBBox.top - padding[0] / zoom;\n    const viewportWidth = (rootGroupBBox.right - rootGroupBBox.left) * zoom + 2 * padding[1];\n    const viewportHeight = (rootGroupBBox.bottom - rootGroupBBox.top) * zoom + 2 * padding[0];\n    const width = viewportWidth / zoom;\n    const height = viewportHeight / zoom;\n\n    return { minX, minY, width, height, viewportWidth, viewportHeight };\n}\n\nexport function getViewportClientBox(board: PlaitBoard) {\n    const hideScrollbar = board.options.hideScrollbar;\n    const scrollBarWidth = hideScrollbar ? SCROLL_BAR_WIDTH : 0;\n    const container = board.host?.parentElement as HTMLElement;\n    const containerRect = container?.getBoundingClientRect();\n    const width = containerRect.width - scrollBarWidth;\n    const height = containerRect.height - scrollBarWidth;\n\n    return {\n        width,\n        height\n    };\n}\n\nexport function calculateBBox(board: PlaitBoard) {\n    const viewportBox = getViewportClientBox(board);\n    const rootGroup = board.host.firstChild;\n    const zoom = board.viewport.zoom;\n    const rootGroupBox = (rootGroup as SVGGraphicsElement).getBBox();\n\n    let box = {} as any;\n    const containerWidth = viewportBox.width / zoom;\n    const containerHeight = viewportBox.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\nexport function calculateZoom(zoom: number, minZoom = 0.2, maxZoom = 4) {\n    return zoom < minZoom ? minZoom : zoom > maxZoom ? maxZoom : zoom;\n}\n\nexport function isNoSelectionElement(e: Event) {\n    return (e.target as HTMLElement)?.closest('.plait-board-attached');\n}\n\nexport const updateCursorStatus = (board: PlaitBoard, cursor: BaseCursorStatus) => {\n    if (cursor) {\n        board.cursor = cursor;\n    }\n};\n"]}
|
package/fesm2015/plait-core.mjs
CHANGED
|
@@ -782,18 +782,6 @@ function isNoSelectionElement(e) {
|
|
|
782
782
|
var _a;
|
|
783
783
|
return (_a = e.target) === null || _a === void 0 ? void 0 : _a.closest('.plait-board-attached');
|
|
784
784
|
}
|
|
785
|
-
/**
|
|
786
|
-
* viewZoom 转 zoom
|
|
787
|
-
* @param viewZoom 视图上显示的 zoom 缩放级别 %
|
|
788
|
-
* @returns zoom 真实的 zoom
|
|
789
|
-
*/
|
|
790
|
-
const transformViewZoom = (viewZoom) => 2 - 100 / viewZoom;
|
|
791
|
-
/**
|
|
792
|
-
* zoom 转 viewZoom
|
|
793
|
-
* @param zoom this.board.viewport.zoom
|
|
794
|
-
* @returns 视图上显示的 zoom 缩放级别 %
|
|
795
|
-
*/
|
|
796
|
-
const transformZoom = (zoom) => Number((100 / (2 - zoom)).toFixed(0));
|
|
797
785
|
const updateCursorStatus = (board, cursor) => {
|
|
798
786
|
if (cursor) {
|
|
799
787
|
board.cursor = cursor;
|
|
@@ -971,6 +959,9 @@ function withMove(board) {
|
|
|
971
959
|
board.mousemove = (event) => {
|
|
972
960
|
const boardComponent = PLAIT_BOARD_TO_COMPONENT.get(board);
|
|
973
961
|
if (board.cursor === BaseCursorStatus.move && board.selection && boardComponent.isMoving) {
|
|
962
|
+
const left = event.x - plaitBoardMove.x;
|
|
963
|
+
const top = event.y - plaitBoardMove.y;
|
|
964
|
+
boardComponent.setScroll(boardComponent.scrollLeft - left, boardComponent.scrollTop - top);
|
|
974
965
|
plaitBoardMove.x = event.x;
|
|
975
966
|
plaitBoardMove.y = event.y;
|
|
976
967
|
}
|
|
@@ -1115,7 +1106,7 @@ class PlaitToolbarComponent {
|
|
|
1115
1106
|
this.resetZoomHandel = new EventEmitter();
|
|
1116
1107
|
}
|
|
1117
1108
|
set viewZoom(zoom) {
|
|
1118
|
-
this._viewZoom =
|
|
1109
|
+
this._viewZoom = Number(((zoom !== null && zoom !== void 0 ? zoom : 1) * 100).toFixed(0));
|
|
1119
1110
|
}
|
|
1120
1111
|
get viewZoom() {
|
|
1121
1112
|
return this._viewZoom;
|
|
@@ -1338,7 +1329,7 @@ class PlaitBoardComponent {
|
|
|
1338
1329
|
.subscribe((event) => {
|
|
1339
1330
|
const scrollLeft = event.target.scrollLeft;
|
|
1340
1331
|
const scrollTop = event.target.scrollTop;
|
|
1341
|
-
this.
|
|
1332
|
+
this.setScroll(scrollLeft, scrollTop);
|
|
1342
1333
|
});
|
|
1343
1334
|
window.onresize = () => {
|
|
1344
1335
|
this.updateViewport();
|
|
@@ -1362,13 +1353,8 @@ class PlaitBoardComponent {
|
|
|
1362
1353
|
this.renderer2.setStyle(this.contentContainer.nativeElement, 'maxHeight', height);
|
|
1363
1354
|
}
|
|
1364
1355
|
setScroll(left, top) {
|
|
1365
|
-
|
|
1366
|
-
|
|
1367
|
-
top,
|
|
1368
|
-
left
|
|
1369
|
-
});
|
|
1370
|
-
}
|
|
1371
|
-
getScrollOffset(left, top) {
|
|
1356
|
+
this.scrollLeft = left;
|
|
1357
|
+
this.scrollTop = top;
|
|
1372
1358
|
const viewportBox = getViewportClientBox(this.board);
|
|
1373
1359
|
const viewBox = getViewBox(this.board);
|
|
1374
1360
|
const scrollLeftRatio = left / (viewBox.viewportWidth - viewportBox.width);
|
|
@@ -1385,16 +1371,19 @@ class PlaitBoardComponent {
|
|
|
1385
1371
|
const viewportBox = getViewportClientBox(this.board);
|
|
1386
1372
|
const { minX, minY, width, height, viewportWidth, viewportHeight } = viewBox;
|
|
1387
1373
|
const box = [minX, minY, width, height];
|
|
1388
|
-
|
|
1389
|
-
|
|
1374
|
+
this.scrollLeft = (viewportWidth - viewportBox.width) * offsetXRatio;
|
|
1375
|
+
this.scrollTop = (viewportHeight - viewportBox.height) * offsetYRatio;
|
|
1390
1376
|
this.renderer2.setStyle(this.host, 'display', 'block');
|
|
1391
1377
|
this.renderer2.setStyle(this.host, 'width', `${viewportWidth}px`);
|
|
1392
1378
|
this.renderer2.setStyle(this.host, 'height', `${viewportHeight}px`);
|
|
1393
|
-
this.renderer2.setStyle(this.host, 'cursor', this.isMoveMode ? 'grab' : 'default');
|
|
1394
1379
|
if (width > 0 && height > 0) {
|
|
1395
1380
|
this.renderer2.setAttribute(this.host, 'viewBox', box.join());
|
|
1396
1381
|
}
|
|
1397
|
-
this.
|
|
1382
|
+
const container = this.contentContainer.nativeElement;
|
|
1383
|
+
container.scrollTo({
|
|
1384
|
+
top: this.scrollTop,
|
|
1385
|
+
left: this.scrollLeft
|
|
1386
|
+
});
|
|
1398
1387
|
}
|
|
1399
1388
|
updateViewport() {
|
|
1400
1389
|
this.resizeViewport();
|
|
@@ -1573,5 +1562,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImpo
|
|
|
1573
1562
|
* Generated bundle index. Do not edit.
|
|
1574
1563
|
*/
|
|
1575
1564
|
|
|
1576
|
-
export { BOARD_TO_ON_CHANGE, BaseCursorStatus, CLIP_BOARD_FORMAT_KEY, FLUSHING, HOST_TO_ROUGH_SVG, IS_APPLE, IS_CHROME, IS_CHROME_LEGACY, IS_EDGE_LEGACY, IS_FIREFOX, IS_IOS, IS_SAFARI, IS_TEXT_EDITABLE, MERGING, NS, PLAIT_BOARD_TO_COMPONENT, Path, PlaitBoardComponent, PlaitElementComponent, PlaitHistoryBoard, PlaitModule, PlaitNode, PlaitOperation, PlaitToolbarComponent, SAVING, SCROLL_BAR_WIDTH, Transforms, Viewport, calculateBBox, calculateZoom, createG, createSVG, createText, distanceBetweenPointAndPoint, distanceBetweenPointAndSegment, getViewBox, getViewportClientBox, hotkeys, idCreator, inverse, isNoSelectionElement, isNullOrUndefined, isSetViewportOperation, rotate, shouldClear, shouldMerge, shouldSave, toPoint, toRectangleClient, transformPoint, transformPoints,
|
|
1565
|
+
export { BOARD_TO_ON_CHANGE, BaseCursorStatus, CLIP_BOARD_FORMAT_KEY, FLUSHING, HOST_TO_ROUGH_SVG, IS_APPLE, IS_CHROME, IS_CHROME_LEGACY, IS_EDGE_LEGACY, IS_FIREFOX, IS_IOS, IS_SAFARI, IS_TEXT_EDITABLE, MERGING, NS, PLAIT_BOARD_TO_COMPONENT, Path, PlaitBoardComponent, PlaitElementComponent, PlaitHistoryBoard, PlaitModule, PlaitNode, PlaitOperation, PlaitToolbarComponent, SAVING, SCROLL_BAR_WIDTH, Transforms, Viewport, calculateBBox, calculateZoom, createG, createSVG, createText, distanceBetweenPointAndPoint, distanceBetweenPointAndSegment, getViewBox, getViewportClientBox, hotkeys, idCreator, inverse, isNoSelectionElement, isNullOrUndefined, isSetViewportOperation, rotate, shouldClear, shouldMerge, shouldSave, toPoint, toRectangleClient, transformPoint, transformPoints, updateCursorStatus };
|
|
1577
1566
|
//# sourceMappingURL=plait-core.mjs.map
|