@plait/core 0.1.0 → 0.1.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/board/board.component.d.ts +4 -17
- package/board/board.component.interface.d.ts +0 -2
- package/constants/selection.d.ts +1 -0
- package/esm2020/board/board.component.interface.mjs +1 -1
- package/esm2020/board/board.component.mjs +49 -248
- package/esm2020/constants/selection.mjs +2 -0
- package/esm2020/core/element/element.component.mjs +2 -2
- package/esm2020/interfaces/board.mjs +11 -2
- package/esm2020/interfaces/viewport.mjs +1 -1
- package/esm2020/plugins/create-board.mjs +2 -1
- package/esm2020/plugins/with-hand.mjs +9 -6
- package/esm2020/plugins/with-moving.mjs +91 -0
- package/esm2020/plugins/with-selection.mjs +54 -13
- package/esm2020/plugins/with-viewport.mjs +11 -0
- package/esm2020/public-api.mjs +3 -1
- package/esm2020/transforms/selection.mjs +10 -2
- package/esm2020/utils/board.mjs +7 -3
- package/esm2020/utils/common.mjs +15 -0
- package/esm2020/utils/element.mjs +3 -3
- package/esm2020/utils/helper.mjs +14 -1
- package/esm2020/utils/index.mjs +4 -2
- package/esm2020/utils/moving-element.mjs +15 -0
- package/esm2020/utils/selected-element.mjs +14 -1
- package/esm2020/utils/viewport.mjs +170 -0
- package/esm2020/utils/weak-maps.mjs +5 -1
- package/fesm2015/plait-core.mjs +567 -562
- package/fesm2015/plait-core.mjs.map +1 -1
- package/fesm2020/plait-core.mjs +567 -559
- package/fesm2020/plait-core.mjs.map +1 -1
- package/interfaces/board.d.ts +4 -10
- package/interfaces/viewport.d.ts +2 -2
- package/package.json +1 -1
- package/plugins/with-moving.d.ts +2 -0
- package/plugins/with-selection.d.ts +6 -1
- package/plugins/with-viewport.d.ts +2 -0
- package/public-api.d.ts +2 -0
- package/transforms/selection.d.ts +3 -0
- package/utils/board.d.ts +1 -1
- package/utils/common.d.ts +1 -0
- package/utils/helper.d.ts +9 -0
- package/utils/index.d.ts +3 -1
- package/utils/moving-element.d.ts +5 -0
- package/utils/selected-element.d.ts +2 -0
- package/utils/viewport.d.ts +29 -0
- package/utils/weak-maps.d.ts +3 -0
- package/esm2020/utils/matrix.mjs +0 -170
- package/utils/matrix.d.ts +0 -82
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
let timerId = null;
|
|
2
|
+
export const throttleRAF = (fn) => {
|
|
3
|
+
const scheduleFunc = () => {
|
|
4
|
+
timerId = requestAnimationFrame(() => {
|
|
5
|
+
timerId = null;
|
|
6
|
+
fn();
|
|
7
|
+
});
|
|
8
|
+
};
|
|
9
|
+
if (timerId !== null) {
|
|
10
|
+
cancelAnimationFrame(timerId);
|
|
11
|
+
timerId = null;
|
|
12
|
+
}
|
|
13
|
+
scheduleFunc();
|
|
14
|
+
};
|
|
15
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tbW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcGFja2FnZXMvcGxhaXQvc3JjL3V0aWxzL2NvbW1vbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxJQUFJLE9BQU8sR0FBa0IsSUFBSSxDQUFDO0FBRWxDLE1BQU0sQ0FBQyxNQUFNLFdBQVcsR0FBRyxDQUFDLEVBQWMsRUFBRSxFQUFFO0lBQzFDLE1BQU0sWUFBWSxHQUFHLEdBQUcsRUFBRTtRQUN0QixPQUFPLEdBQUcscUJBQXFCLENBQUMsR0FBRyxFQUFFO1lBQ2pDLE9BQU8sR0FBRyxJQUFJLENBQUM7WUFDZixFQUFFLEVBQUUsQ0FBQztRQUNULENBQUMsQ0FBQyxDQUFDO0lBQ1AsQ0FBQyxDQUFDO0lBQ0YsSUFBSSxPQUFPLEtBQUssSUFBSSxFQUFFO1FBQ2xCLG9CQUFvQixDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQzlCLE9BQU8sR0FBRyxJQUFJLENBQUM7S0FDbEI7SUFDRCxZQUFZLEVBQUUsQ0FBQztBQUNuQixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJsZXQgdGltZXJJZDogbnVtYmVyIHwgbnVsbCA9IG51bGw7XG5cbmV4cG9ydCBjb25zdCB0aHJvdHRsZVJBRiA9IChmbjogKCkgPT4gdm9pZCkgPT4ge1xuICAgIGNvbnN0IHNjaGVkdWxlRnVuYyA9ICgpID0+IHtcbiAgICAgICAgdGltZXJJZCA9IHJlcXVlc3RBbmltYXRpb25GcmFtZSgoKSA9PiB7XG4gICAgICAgICAgICB0aW1lcklkID0gbnVsbDtcbiAgICAgICAgICAgIGZuKCk7XG4gICAgICAgIH0pO1xuICAgIH07XG4gICAgaWYgKHRpbWVySWQgIT09IG51bGwpIHtcbiAgICAgICAgY2FuY2VsQW5pbWF0aW9uRnJhbWUodGltZXJJZCk7XG4gICAgICAgIHRpbWVySWQgPSBudWxsO1xuICAgIH1cbiAgICBzY2hlZHVsZUZ1bmMoKTtcbn07XG4iXX0=
|
|
@@ -3,8 +3,8 @@ export function getRectangleByElements(board, elements, recursion) {
|
|
|
3
3
|
const boundaryBox = {
|
|
4
4
|
left: Number.MAX_VALUE,
|
|
5
5
|
top: Number.MAX_VALUE,
|
|
6
|
-
right: Number.
|
|
7
|
-
bottom: Number.
|
|
6
|
+
right: Number.NEGATIVE_INFINITY,
|
|
7
|
+
bottom: Number.NEGATIVE_INFINITY
|
|
8
8
|
};
|
|
9
9
|
const calcRectangleClient = (node) => {
|
|
10
10
|
const nodeRectangle = board.getRectangle(node);
|
|
@@ -33,4 +33,4 @@ export function getRectangleByElements(board, elements, recursion) {
|
|
|
33
33
|
export function getBoardRectangle(board) {
|
|
34
34
|
return getRectangleByElements(board, board.children, true);
|
|
35
35
|
}
|
|
36
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
36
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxlbWVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3BhY2thZ2VzL3BsYWl0L3NyYy91dGlscy9lbGVtZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLFFBQVEsQ0FBQztBQUU3QyxNQUFNLFVBQVUsc0JBQXNCLENBQUMsS0FBaUIsRUFBRSxRQUF3QixFQUFFLFNBQWtCO0lBQ2xHLE1BQU0sV0FBVyxHQUFHO1FBQ2hCLElBQUksRUFBRSxNQUFNLENBQUMsU0FBUztRQUN0QixHQUFHLEVBQUUsTUFBTSxDQUFDLFNBQVM7UUFDckIsS0FBSyxFQUFFLE1BQU0sQ0FBQyxpQkFBaUI7UUFDL0IsTUFBTSxFQUFFLE1BQU0sQ0FBQyxpQkFBaUI7S0FDbkMsQ0FBQztJQUVGLE1BQU0sbUJBQW1CLEdBQUcsQ0FBQyxJQUFrQixFQUFFLEVBQUU7UUFDL0MsTUFBTSxhQUFhLEdBQUcsS0FBSyxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUMvQyxJQUFJLGFBQWEsRUFBRTtZQUNmLFdBQVcsQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDLEdBQUcsQ0FBQyxXQUFXLENBQUMsSUFBSSxFQUFFLGFBQWEsQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUMvRCxXQUFXLENBQUMsR0FBRyxHQUFHLElBQUksQ0FBQyxHQUFHLENBQUMsV0FBVyxDQUFDLEdBQUcsRUFBRSxhQUFhLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDN0QsV0FBVyxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUMsR0FBRyxDQUFDLFdBQVcsQ0FBQyxLQUFLLEVBQUUsYUFBYSxDQUFDLENBQUMsR0FBRyxhQUFhLENBQUMsS0FBSyxDQUFDLENBQUM7WUFDdkYsV0FBVyxDQUFDLE1BQU0sR0FBRyxJQUFJLENBQUMsR0FBRyxDQUFDLFdBQVcsQ0FBQyxNQUFNLEVBQUUsYUFBYSxDQUFDLENBQUMsR0FBRyxhQUFhLENBQUMsTUFBTSxDQUFDLENBQUM7U0FDN0Y7SUFDTCxDQUFDLENBQUM7SUFFRixRQUFRLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxFQUFFO1FBQ3ZCLElBQUksU0FBUyxFQUFFO1lBQ1gsbUJBQW1CLENBQUMsT0FBTyxFQUFFLElBQUksQ0FBQyxFQUFFLENBQUMsbUJBQW1CLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQztTQUNuRTthQUFNO1lBQ0gsbUJBQW1CLENBQUMsT0FBTyxDQUFDLENBQUM7U0FDaEM7SUFDTCxDQUFDLENBQUMsQ0FBQztJQUNILE9BQU87UUFDSCxDQUFDLEVBQUUsV0FBVyxDQUFDLElBQUk7UUFDbkIsQ0FBQyxFQUFFLFdBQVcsQ0FBQyxHQUFHO1FBQ2xCLEtBQUssRUFBRSxXQUFXLENBQUMsS0FBSyxHQUFHLFdBQVcsQ0FBQyxJQUFJO1FBQzNDLE1BQU0sRUFBRSxXQUFXLENBQUMsTUFBTSxHQUFHLFdBQVcsQ0FBQyxHQUFHO0tBQy9DLENBQUM7QUFDTixDQUFDO0FBRUQsTUFBTSxVQUFVLGlCQUFpQixDQUFDLEtBQWlCO0lBQy9DLE9BQU8sc0JBQXNCLENBQUMsS0FBSyxFQUFFLEtBQUssQ0FBQyxRQUFRLEVBQUUsSUFBSSxDQUFDLENBQUM7QUFDL0QsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBsYWl0Qm9hcmQsIFBsYWl0RWxlbWVudCwgUmVjdGFuZ2xlQ2xpZW50IH0gZnJvbSAnLi4vaW50ZXJmYWNlcyc7XG5pbXBvcnQgeyBkZXB0aEZpcnN0UmVjdXJzaW9uIH0gZnJvbSAnLi90cmVlJztcblxuZXhwb3J0IGZ1bmN0aW9uIGdldFJlY3RhbmdsZUJ5RWxlbWVudHMoYm9hcmQ6IFBsYWl0Qm9hcmQsIGVsZW1lbnRzOiBQbGFpdEVsZW1lbnRbXSwgcmVjdXJzaW9uOiBib29sZWFuKTogUmVjdGFuZ2xlQ2xpZW50IHtcbiAgICBjb25zdCBib3VuZGFyeUJveCA9IHtcbiAgICAgICAgbGVmdDogTnVtYmVyLk1BWF9WQUxVRSxcbiAgICAgICAgdG9wOiBOdW1iZXIuTUFYX1ZBTFVFLFxuICAgICAgICByaWdodDogTnVtYmVyLk5FR0FUSVZFX0lORklOSVRZLFxuICAgICAgICBib3R0b206IE51bWJlci5ORUdBVElWRV9JTkZJTklUWVxuICAgIH07XG5cbiAgICBjb25zdCBjYWxjUmVjdGFuZ2xlQ2xpZW50ID0gKG5vZGU6IFBsYWl0RWxlbWVudCkgPT4ge1xuICAgICAgICBjb25zdCBub2RlUmVjdGFuZ2xlID0gYm9hcmQuZ2V0UmVjdGFuZ2xlKG5vZGUpO1xuICAgICAgICBpZiAobm9kZVJlY3RhbmdsZSkge1xuICAgICAgICAgICAgYm91bmRhcnlCb3gubGVmdCA9IE1hdGgubWluKGJvdW5kYXJ5Qm94LmxlZnQsIG5vZGVSZWN0YW5nbGUueCk7XG4gICAgICAgICAgICBib3VuZGFyeUJveC50b3AgPSBNYXRoLm1pbihib3VuZGFyeUJveC50b3AsIG5vZGVSZWN0YW5nbGUueSk7XG4gICAgICAgICAgICBib3VuZGFyeUJveC5yaWdodCA9IE1hdGgubWF4KGJvdW5kYXJ5Qm94LnJpZ2h0LCBub2RlUmVjdGFuZ2xlLnggKyBub2RlUmVjdGFuZ2xlLndpZHRoKTtcbiAgICAgICAgICAgIGJvdW5kYXJ5Qm94LmJvdHRvbSA9IE1hdGgubWF4KGJvdW5kYXJ5Qm94LmJvdHRvbSwgbm9kZVJlY3RhbmdsZS55ICsgbm9kZVJlY3RhbmdsZS5oZWlnaHQpO1xuICAgICAgICB9XG4gICAgfTtcblxuICAgIGVsZW1lbnRzLmZvckVhY2goZWxlbWVudCA9PiB7XG4gICAgICAgIGlmIChyZWN1cnNpb24pIHtcbiAgICAgICAgICAgIGRlcHRoRmlyc3RSZWN1cnNpb24oZWxlbWVudCwgbm9kZSA9PiBjYWxjUmVjdGFuZ2xlQ2xpZW50KG5vZGUpKTtcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgIGNhbGNSZWN0YW5nbGVDbGllbnQoZWxlbWVudCk7XG4gICAgICAgIH1cbiAgICB9KTtcbiAgICByZXR1cm4ge1xuICAgICAgICB4OiBib3VuZGFyeUJveC5sZWZ0LFxuICAgICAgICB5OiBib3VuZGFyeUJveC50b3AsXG4gICAgICAgIHdpZHRoOiBib3VuZGFyeUJveC5yaWdodCAtIGJvdW5kYXJ5Qm94LmxlZnQsXG4gICAgICAgIGhlaWdodDogYm91bmRhcnlCb3guYm90dG9tIC0gYm91bmRhcnlCb3gudG9wXG4gICAgfTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGdldEJvYXJkUmVjdGFuZ2xlKGJvYXJkOiBQbGFpdEJvYXJkKTogUmVjdGFuZ2xlQ2xpZW50IHtcbiAgICByZXR1cm4gZ2V0UmVjdGFuZ2xlQnlFbGVtZW50cyhib2FyZCwgYm9hcmQuY2hpbGRyZW4sIHRydWUpO1xufVxuIl19
|
package/esm2020/utils/helper.mjs
CHANGED
|
@@ -1,4 +1,17 @@
|
|
|
1
1
|
export function isNullOrUndefined(value) {
|
|
2
2
|
return value === null || value === undefined;
|
|
3
3
|
}
|
|
4
|
-
|
|
4
|
+
/**
|
|
5
|
+
* 规范 point
|
|
6
|
+
* @param point
|
|
7
|
+
* @returns point
|
|
8
|
+
*/
|
|
9
|
+
export function normalizePoint(point) {
|
|
10
|
+
return Array.isArray(point)
|
|
11
|
+
? {
|
|
12
|
+
x: point[0],
|
|
13
|
+
y: point[1]
|
|
14
|
+
}
|
|
15
|
+
: point;
|
|
16
|
+
}
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVscGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcGFja2FnZXMvcGxhaXQvc3JjL3V0aWxzL2hlbHBlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLFVBQVUsaUJBQWlCLENBQUMsS0FBVTtJQUN4QyxPQUFPLEtBQUssS0FBSyxJQUFJLElBQUksS0FBSyxLQUFLLFNBQVMsQ0FBQztBQUNqRCxDQUFDO0FBRUQ7Ozs7R0FJRztBQUNILE1BQU0sVUFBVSxjQUFjLENBQUMsS0FBZTtJQUMxQyxPQUFPLEtBQUssQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDO1FBQ3ZCLENBQUMsQ0FBQztZQUNJLENBQUMsRUFBRSxLQUFLLENBQUMsQ0FBQyxDQUFDO1lBQ1gsQ0FBQyxFQUFFLEtBQUssQ0FBQyxDQUFDLENBQUM7U0FDZDtRQUNILENBQUMsQ0FBQyxLQUFLLENBQUM7QUFDaEIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBmdW5jdGlvbiBpc051bGxPclVuZGVmaW5lZCh2YWx1ZTogYW55KSB7XG4gICAgcmV0dXJuIHZhbHVlID09PSBudWxsIHx8IHZhbHVlID09PSB1bmRlZmluZWQ7XG59XG5cbi8qKlxuICog6KeE6IyDIHBvaW50XG4gKiBAcGFyYW0gcG9pbnRcbiAqIEByZXR1cm5zIHBvaW50XG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBub3JtYWxpemVQb2ludChwb2ludDogbnVtYmVyW10pIHtcbiAgICByZXR1cm4gQXJyYXkuaXNBcnJheShwb2ludClcbiAgICAgICAgPyB7XG4gICAgICAgICAgICAgIHg6IHBvaW50WzBdLFxuICAgICAgICAgICAgICB5OiBwb2ludFsxXVxuICAgICAgICAgIH1cbiAgICAgICAgOiBwb2ludDtcbn1cbiJdfQ==
|
package/esm2020/utils/index.mjs
CHANGED
|
@@ -6,11 +6,13 @@ export * from './history';
|
|
|
6
6
|
export * from './hotkeys';
|
|
7
7
|
export * from './id-creator';
|
|
8
8
|
export * from './math';
|
|
9
|
-
export * from './matrix';
|
|
10
9
|
export * from './weak-maps';
|
|
11
10
|
export * from './selected-element';
|
|
12
11
|
export * from './draw/rectangle';
|
|
13
12
|
export * from './draw/arrow';
|
|
14
13
|
export * from './tree';
|
|
15
14
|
export * from './element';
|
|
16
|
-
|
|
15
|
+
export * from './viewport';
|
|
16
|
+
export * from './common';
|
|
17
|
+
export * from './moving-element';
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9wbGFpdC9zcmMvdXRpbHMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxTQUFTLENBQUM7QUFDeEIsY0FBYyxPQUFPLENBQUM7QUFDdEIsY0FBYyxlQUFlLENBQUM7QUFDOUIsY0FBYyxVQUFVLENBQUM7QUFDekIsY0FBYyxXQUFXLENBQUM7QUFDMUIsY0FBYyxXQUFXLENBQUM7QUFDMUIsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyxRQUFRLENBQUM7QUFDdkIsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMsUUFBUSxDQUFDO0FBQ3ZCLGNBQWMsV0FBVyxDQUFDO0FBQzFCLGNBQWMsWUFBWSxDQUFDO0FBQzNCLGNBQWMsVUFBVSxDQUFDO0FBQ3pCLGNBQWMsa0JBQWtCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2JvYXJkJztcbmV4cG9ydCAqIGZyb20gJy4vZG9tJztcbmV4cG9ydCAqIGZyb20gJy4vZW52aXJvbm1lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9oZWxwZXInO1xuZXhwb3J0ICogZnJvbSAnLi9oaXN0b3J5JztcbmV4cG9ydCAqIGZyb20gJy4vaG90a2V5cyc7XG5leHBvcnQgKiBmcm9tICcuL2lkLWNyZWF0b3InO1xuZXhwb3J0ICogZnJvbSAnLi9tYXRoJztcbmV4cG9ydCAqIGZyb20gJy4vd2Vhay1tYXBzJztcbmV4cG9ydCAqIGZyb20gJy4vc2VsZWN0ZWQtZWxlbWVudCc7XG5leHBvcnQgKiBmcm9tICcuL2RyYXcvcmVjdGFuZ2xlJztcbmV4cG9ydCAqIGZyb20gJy4vZHJhdy9hcnJvdyc7XG5leHBvcnQgKiBmcm9tICcuL3RyZWUnO1xuZXhwb3J0ICogZnJvbSAnLi9lbGVtZW50JztcbmV4cG9ydCAqIGZyb20gJy4vdmlld3BvcnQnO1xuZXhwb3J0ICogZnJvbSAnLi9jb21tb24nO1xuZXhwb3J0ICogZnJvbSAnLi9tb3ZpbmctZWxlbWVudCc7XG4iXX0=
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { BOARD_TO_MOVING_ELEMENT } from './weak-maps';
|
|
2
|
+
export const getMovingElements = (board) => {
|
|
3
|
+
return BOARD_TO_MOVING_ELEMENT.get(board) || [];
|
|
4
|
+
};
|
|
5
|
+
export const addMovingElements = (board, elements) => {
|
|
6
|
+
const movingElements = getMovingElements(board);
|
|
7
|
+
cacheMovingElements(board, [...movingElements, ...elements]);
|
|
8
|
+
};
|
|
9
|
+
export const removeMovingElements = (board) => {
|
|
10
|
+
BOARD_TO_MOVING_ELEMENT.delete(board);
|
|
11
|
+
};
|
|
12
|
+
export const cacheMovingElements = (board, elements) => {
|
|
13
|
+
BOARD_TO_MOVING_ELEMENT.set(board, elements);
|
|
14
|
+
};
|
|
15
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW92aW5nLWVsZW1lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9wbGFpdC9zcmMvdXRpbHMvbW92aW5nLWVsZW1lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sYUFBYSxDQUFDO0FBRXRELE1BQU0sQ0FBQyxNQUFNLGlCQUFpQixHQUFHLENBQUMsS0FBaUIsRUFBRSxFQUFFO0lBQ25ELE9BQU8sdUJBQXVCLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxJQUFJLEVBQUUsQ0FBQztBQUNwRCxDQUFDLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxpQkFBaUIsR0FBRyxDQUFDLEtBQWlCLEVBQUUsUUFBd0IsRUFBRSxFQUFFO0lBQzdFLE1BQU0sY0FBYyxHQUFHLGlCQUFpQixDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ2hELG1CQUFtQixDQUFDLEtBQUssRUFBRSxDQUFDLEdBQUcsY0FBYyxFQUFFLEdBQUcsUUFBUSxDQUFDLENBQUMsQ0FBQztBQUNqRSxDQUFDLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxvQkFBb0IsR0FBRyxDQUFDLEtBQWlCLEVBQUUsRUFBRTtJQUN0RCx1QkFBdUIsQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLENBQUM7QUFDMUMsQ0FBQyxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sbUJBQW1CLEdBQUcsQ0FBQyxLQUFpQixFQUFFLFFBQXdCLEVBQUUsRUFBRTtJQUMvRSx1QkFBdUIsQ0FBQyxHQUFHLENBQUMsS0FBSyxFQUFFLFFBQVEsQ0FBQyxDQUFDO0FBQ2pELENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBsYWl0Qm9hcmQsIFBsYWl0RWxlbWVudCB9IGZyb20gJy4uL2ludGVyZmFjZXMnO1xuaW1wb3J0IHsgQk9BUkRfVE9fTU9WSU5HX0VMRU1FTlQgfSBmcm9tICcuL3dlYWstbWFwcyc7XG5cbmV4cG9ydCBjb25zdCBnZXRNb3ZpbmdFbGVtZW50cyA9IChib2FyZDogUGxhaXRCb2FyZCkgPT4ge1xuICAgIHJldHVybiBCT0FSRF9UT19NT1ZJTkdfRUxFTUVOVC5nZXQoYm9hcmQpIHx8IFtdO1xufTtcblxuZXhwb3J0IGNvbnN0IGFkZE1vdmluZ0VsZW1lbnRzID0gKGJvYXJkOiBQbGFpdEJvYXJkLCBlbGVtZW50czogUGxhaXRFbGVtZW50W10pID0+IHtcbiAgICBjb25zdCBtb3ZpbmdFbGVtZW50cyA9IGdldE1vdmluZ0VsZW1lbnRzKGJvYXJkKTtcbiAgICBjYWNoZU1vdmluZ0VsZW1lbnRzKGJvYXJkLCBbLi4ubW92aW5nRWxlbWVudHMsIC4uLmVsZW1lbnRzXSk7XG59O1xuXG5leHBvcnQgY29uc3QgcmVtb3ZlTW92aW5nRWxlbWVudHMgPSAoYm9hcmQ6IFBsYWl0Qm9hcmQpID0+IHtcbiAgICBCT0FSRF9UT19NT1ZJTkdfRUxFTUVOVC5kZWxldGUoYm9hcmQpO1xufTtcblxuZXhwb3J0IGNvbnN0IGNhY2hlTW92aW5nRWxlbWVudHMgPSAoYm9hcmQ6IFBsYWl0Qm9hcmQsIGVsZW1lbnRzOiBQbGFpdEVsZW1lbnRbXSkgPT4ge1xuICAgIEJPQVJEX1RPX01PVklOR19FTEVNRU5ULnNldChib2FyZCwgZWxlbWVudHMpO1xufTtcbiJdfQ==
|
|
@@ -13,6 +13,19 @@ export const calcElementIntersectionSelection = (board) => {
|
|
|
13
13
|
});
|
|
14
14
|
return selectedElements;
|
|
15
15
|
};
|
|
16
|
+
export const isIntersectionElements = (board, elements, ranges) => {
|
|
17
|
+
let isIntersectionElements = false;
|
|
18
|
+
if (elements.length) {
|
|
19
|
+
elements.map(item => {
|
|
20
|
+
if (!isIntersectionElements) {
|
|
21
|
+
isIntersectionElements = ranges.some(range => {
|
|
22
|
+
return board.isIntersectionSelection(item, range);
|
|
23
|
+
});
|
|
24
|
+
}
|
|
25
|
+
});
|
|
26
|
+
}
|
|
27
|
+
return isIntersectionElements;
|
|
28
|
+
};
|
|
16
29
|
export const cacheSelectedElements = (board, selectedElements) => {
|
|
17
30
|
BOARD_TO_SELECTED_ELEMENT.set(board, selectedElements);
|
|
18
31
|
};
|
|
@@ -32,4 +45,4 @@ export const isSelectedElement = (board, element) => {
|
|
|
32
45
|
const selectedElements = getSelectedElements(board);
|
|
33
46
|
return !!selectedElements.find(value => value === element);
|
|
34
47
|
};
|
|
35
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
48
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0ZWQtZWxlbWVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3BhY2thZ2VzL3BsYWl0L3NyYy91dGlscy9zZWxlY3RlZC1lbGVtZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUVyRCxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxRQUFRLENBQUM7QUFDN0MsT0FBTyxFQUFFLHlCQUF5QixFQUFFLE1BQU0sYUFBYSxDQUFDO0FBR3hELE1BQU0sQ0FBQyxNQUFNLGdDQUFnQyxHQUFHLENBQUMsS0FBaUIsRUFBRSxFQUFFO0lBQ2xFLE1BQU0sZ0JBQWdCLEdBQW1CLEVBQUUsQ0FBQztJQUM1QyxtQkFBbUIsQ0FBWSxLQUFLLEVBQUUsSUFBSSxDQUFDLEVBQUU7UUFDekMsSUFDSSxZQUFZLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQztZQUM1QixLQUFLLENBQUMsU0FBUyxFQUFFLE1BQU0sQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLEVBQUU7Z0JBQ2pDLE9BQU8sS0FBSyxDQUFDLHVCQUF1QixDQUFDLElBQUksRUFBRSxLQUFLLENBQUMsQ0FBQztZQUN0RCxDQUFDLENBQUMsRUFDSjtZQUNFLGdCQUFnQixDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztTQUMvQjtJQUNMLENBQUMsQ0FBQyxDQUFDO0lBQ0gsT0FBTyxnQkFBZ0IsQ0FBQztBQUM1QixDQUFDLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxzQkFBc0IsR0FBRyxDQUFDLEtBQWlCLEVBQUUsUUFBd0IsRUFBRSxNQUFlLEVBQUUsRUFBRTtJQUNuRyxJQUFJLHNCQUFzQixHQUFHLEtBQUssQ0FBQztJQUNuQyxJQUFJLFFBQVEsQ0FBQyxNQUFNLEVBQUU7UUFDakIsUUFBUSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsRUFBRTtZQUNoQixJQUFJLENBQUMsc0JBQXNCLEVBQUU7Z0JBQ3pCLHNCQUFzQixHQUFHLE1BQU0sQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLEVBQUU7b0JBQ3pDLE9BQU8sS0FBSyxDQUFDLHVCQUF1QixDQUFDLElBQUksRUFBRSxLQUFLLENBQUMsQ0FBQztnQkFDdEQsQ0FBQyxDQUFDLENBQUM7YUFDTjtRQUNMLENBQUMsQ0FBQyxDQUFDO0tBQ047SUFDRCxPQUFPLHNCQUFzQixDQUFDO0FBQ2xDLENBQUMsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLHFCQUFxQixHQUFHLENBQUMsS0FBaUIsRUFBRSxnQkFBZ0MsRUFBRSxFQUFFO0lBQ3pGLHlCQUF5QixDQUFDLEdBQUcsQ0FBQyxLQUFLLEVBQUUsZ0JBQWdCLENBQUMsQ0FBQztBQUMzRCxDQUFDLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxtQkFBbUIsR0FBRyxDQUFDLEtBQWlCLEVBQUUsRUFBRTtJQUNyRCxPQUFPLHlCQUF5QixDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsSUFBSSxFQUFFLENBQUM7QUFDdEQsQ0FBQyxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sa0JBQWtCLEdBQUcsQ0FBQyxLQUFpQixFQUFFLE9BQXFCLEVBQUUsRUFBRTtJQUMzRSxNQUFNLGdCQUFnQixHQUFHLG1CQUFtQixDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ3BELHFCQUFxQixDQUFDLEtBQUssRUFBRSxDQUFDLEdBQUcsZ0JBQWdCLEVBQUUsT0FBTyxDQUFDLENBQUMsQ0FBQztBQUNqRSxDQUFDLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxxQkFBcUIsR0FBRyxDQUFDLEtBQWlCLEVBQUUsT0FBcUIsRUFBRSxFQUFFO0lBQzlFLE1BQU0sZ0JBQWdCLEdBQUcsbUJBQW1CLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDcEQsTUFBTSxtQkFBbUIsR0FBRyxnQkFBZ0IsQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxLQUFLLEtBQUssT0FBTyxDQUFDLENBQUM7SUFDaEYscUJBQXFCLENBQUMsS0FBSyxFQUFFLG1CQUFtQixDQUFDLENBQUM7QUFDdEQsQ0FBQyxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0saUJBQWlCLEdBQUcsQ0FBQyxLQUFpQixFQUFFLE9BQXFCLEVBQUUsRUFBRTtJQUMxRSxNQUFNLGdCQUFnQixHQUFHLG1CQUFtQixDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ3BELE9BQU8sQ0FBQyxDQUFDLGdCQUFnQixDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLEtBQUssS0FBSyxPQUFPLENBQUMsQ0FBQztBQUMvRCxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQbGFpdEJvYXJkIH0gZnJvbSAnLi4vaW50ZXJmYWNlcy9ib2FyZCc7XG5pbXBvcnQgeyBQbGFpdEVsZW1lbnQgfSBmcm9tICcuLi9pbnRlcmZhY2VzL2VsZW1lbnQnO1xuaW1wb3J0IHsgUGxhaXROb2RlIH0gZnJvbSAnLi4vaW50ZXJmYWNlcy9ub2RlJztcbmltcG9ydCB7IGRlcHRoRmlyc3RSZWN1cnNpb24gfSBmcm9tICcuL3RyZWUnO1xuaW1wb3J0IHsgQk9BUkRfVE9fU0VMRUNURURfRUxFTUVOVCB9IGZyb20gJy4vd2Vhay1tYXBzJztcbmltcG9ydCB7IFJhbmdlIH0gZnJvbSAnLi4vaW50ZXJmYWNlcy9zZWxlY3Rpb24nO1xuXG5leHBvcnQgY29uc3QgY2FsY0VsZW1lbnRJbnRlcnNlY3Rpb25TZWxlY3Rpb24gPSAoYm9hcmQ6IFBsYWl0Qm9hcmQpID0+IHtcbiAgICBjb25zdCBzZWxlY3RlZEVsZW1lbnRzOiBQbGFpdEVsZW1lbnRbXSA9IFtdO1xuICAgIGRlcHRoRmlyc3RSZWN1cnNpb248UGxhaXROb2RlPihib2FyZCwgbm9kZSA9PiB7XG4gICAgICAgIGlmIChcbiAgICAgICAgICAgIFBsYWl0RWxlbWVudC5pc0VsZW1lbnQobm9kZSkgJiZcbiAgICAgICAgICAgIGJvYXJkLnNlbGVjdGlvbj8ucmFuZ2VzLnNvbWUocmFuZ2UgPT4ge1xuICAgICAgICAgICAgICAgIHJldHVybiBib2FyZC5pc0ludGVyc2VjdGlvblNlbGVjdGlvbihub2RlLCByYW5nZSk7XG4gICAgICAgICAgICB9KVxuICAgICAgICApIHtcbiAgICAgICAgICAgIHNlbGVjdGVkRWxlbWVudHMucHVzaChub2RlKTtcbiAgICAgICAgfVxuICAgIH0pO1xuICAgIHJldHVybiBzZWxlY3RlZEVsZW1lbnRzO1xufTtcblxuZXhwb3J0IGNvbnN0IGlzSW50ZXJzZWN0aW9uRWxlbWVudHMgPSAoYm9hcmQ6IFBsYWl0Qm9hcmQsIGVsZW1lbnRzOiBQbGFpdEVsZW1lbnRbXSwgcmFuZ2VzOiBSYW5nZVtdKSA9PiB7XG4gICAgbGV0IGlzSW50ZXJzZWN0aW9uRWxlbWVudHMgPSBmYWxzZTtcbiAgICBpZiAoZWxlbWVudHMubGVuZ3RoKSB7XG4gICAgICAgIGVsZW1lbnRzLm1hcChpdGVtID0+IHtcbiAgICAgICAgICAgIGlmICghaXNJbnRlcnNlY3Rpb25FbGVtZW50cykge1xuICAgICAgICAgICAgICAgIGlzSW50ZXJzZWN0aW9uRWxlbWVudHMgPSByYW5nZXMuc29tZShyYW5nZSA9PiB7XG4gICAgICAgICAgICAgICAgICAgIHJldHVybiBib2FyZC5pc0ludGVyc2VjdGlvblNlbGVjdGlvbihpdGVtLCByYW5nZSk7XG4gICAgICAgICAgICAgICAgfSk7XG4gICAgICAgICAgICB9XG4gICAgICAgIH0pO1xuICAgIH1cbiAgICByZXR1cm4gaXNJbnRlcnNlY3Rpb25FbGVtZW50cztcbn07XG5cbmV4cG9ydCBjb25zdCBjYWNoZVNlbGVjdGVkRWxlbWVudHMgPSAoYm9hcmQ6IFBsYWl0Qm9hcmQsIHNlbGVjdGVkRWxlbWVudHM6IFBsYWl0RWxlbWVudFtdKSA9PiB7XG4gICAgQk9BUkRfVE9fU0VMRUNURURfRUxFTUVOVC5zZXQoYm9hcmQsIHNlbGVjdGVkRWxlbWVudHMpO1xufTtcblxuZXhwb3J0IGNvbnN0IGdldFNlbGVjdGVkRWxlbWVudHMgPSAoYm9hcmQ6IFBsYWl0Qm9hcmQpID0+IHtcbiAgICByZXR1cm4gQk9BUkRfVE9fU0VMRUNURURfRUxFTUVOVC5nZXQoYm9hcmQpIHx8IFtdO1xufTtcblxuZXhwb3J0IGNvbnN0IGFkZFNlbGVjdGVkRWxlbWVudCA9IChib2FyZDogUGxhaXRCb2FyZCwgZWxlbWVudDogUGxhaXRFbGVtZW50KSA9PiB7XG4gICAgY29uc3Qgc2VsZWN0ZWRFbGVtZW50cyA9IGdldFNlbGVjdGVkRWxlbWVudHMoYm9hcmQpO1xuICAgIGNhY2hlU2VsZWN0ZWRFbGVtZW50cyhib2FyZCwgWy4uLnNlbGVjdGVkRWxlbWVudHMsIGVsZW1lbnRdKTtcbn07XG5cbmV4cG9ydCBjb25zdCByZW1vdmVTZWxlY3RlZEVsZW1lbnQgPSAoYm9hcmQ6IFBsYWl0Qm9hcmQsIGVsZW1lbnQ6IFBsYWl0RWxlbWVudCkgPT4ge1xuICAgIGNvbnN0IHNlbGVjdGVkRWxlbWVudHMgPSBnZXRTZWxlY3RlZEVsZW1lbnRzKGJvYXJkKTtcbiAgICBjb25zdCBuZXdzZWxlY3RlZEVsZW1lbnRzID0gc2VsZWN0ZWRFbGVtZW50cy5maWx0ZXIodmFsdWUgPT4gdmFsdWUgIT09IGVsZW1lbnQpO1xuICAgIGNhY2hlU2VsZWN0ZWRFbGVtZW50cyhib2FyZCwgbmV3c2VsZWN0ZWRFbGVtZW50cyk7XG59O1xuXG5leHBvcnQgY29uc3QgaXNTZWxlY3RlZEVsZW1lbnQgPSAoYm9hcmQ6IFBsYWl0Qm9hcmQsIGVsZW1lbnQ6IFBsYWl0RWxlbWVudCkgPT4ge1xuICAgIGNvbnN0IHNlbGVjdGVkRWxlbWVudHMgPSBnZXRTZWxlY3RlZEVsZW1lbnRzKGJvYXJkKTtcbiAgICByZXR1cm4gISFzZWxlY3RlZEVsZW1lbnRzLmZpbmQodmFsdWUgPT4gdmFsdWUgPT09IGVsZW1lbnQpO1xufTtcbiJdfQ==
|
|
@@ -0,0 +1,170 @@
|
|
|
1
|
+
import { SCROLL_BAR_WIDTH } from '../constants';
|
|
2
|
+
import { PlaitBoard } from '../interfaces';
|
|
3
|
+
import { Transforms } from '../transforms';
|
|
4
|
+
import { toPoint } from './dom';
|
|
5
|
+
import { getRectangleByElements } from './element';
|
|
6
|
+
import { distanceBetweenPointAndRectangle } from './math';
|
|
7
|
+
import { BOARD_TO_MOVING_POINT } from './weak-maps';
|
|
8
|
+
export function getViewportContainerRect(board) {
|
|
9
|
+
const { hideScrollbar } = board.options;
|
|
10
|
+
const scrollBarWidth = hideScrollbar ? SCROLL_BAR_WIDTH : 0;
|
|
11
|
+
const viewportRect = PlaitBoard.getBoardNativeElement(board).getBoundingClientRect();
|
|
12
|
+
return {
|
|
13
|
+
width: viewportRect.width + scrollBarWidth,
|
|
14
|
+
height: viewportRect.height + scrollBarWidth
|
|
15
|
+
};
|
|
16
|
+
}
|
|
17
|
+
export function getElementHostBBox(board, zoom) {
|
|
18
|
+
const childrenRect = getRectangleByElements(board, board.children, true);
|
|
19
|
+
const viewportContainerRect = getViewportContainerRect(board);
|
|
20
|
+
const containerWidth = viewportContainerRect.width / zoom;
|
|
21
|
+
const containerHeight = viewportContainerRect.height / zoom;
|
|
22
|
+
let left;
|
|
23
|
+
let right;
|
|
24
|
+
let top;
|
|
25
|
+
let bottom;
|
|
26
|
+
if (childrenRect.width < containerWidth) {
|
|
27
|
+
const centerX = Math.ceil(childrenRect.x + childrenRect.width / 2);
|
|
28
|
+
const halfContainerWidth = Math.ceil(containerWidth / 2);
|
|
29
|
+
left = centerX - halfContainerWidth;
|
|
30
|
+
right = centerX + halfContainerWidth;
|
|
31
|
+
}
|
|
32
|
+
else {
|
|
33
|
+
left = childrenRect.x;
|
|
34
|
+
right = childrenRect.x + childrenRect.width;
|
|
35
|
+
}
|
|
36
|
+
if (childrenRect.height < containerHeight) {
|
|
37
|
+
const centerY = Math.ceil(childrenRect.y + childrenRect.height / 2);
|
|
38
|
+
const halfContainerHeight = Math.ceil(containerHeight / 2);
|
|
39
|
+
top = centerY - halfContainerHeight;
|
|
40
|
+
bottom = centerY + halfContainerHeight;
|
|
41
|
+
}
|
|
42
|
+
else {
|
|
43
|
+
top = childrenRect.y;
|
|
44
|
+
bottom = childrenRect.y + childrenRect.height;
|
|
45
|
+
}
|
|
46
|
+
return {
|
|
47
|
+
left,
|
|
48
|
+
right,
|
|
49
|
+
top,
|
|
50
|
+
bottom
|
|
51
|
+
};
|
|
52
|
+
}
|
|
53
|
+
/**
|
|
54
|
+
* 验证缩放比是否符合限制,如果超出限制,则返回合适的缩放比
|
|
55
|
+
* @param zoom 缩放比
|
|
56
|
+
* @param minZoom 最小缩放比
|
|
57
|
+
* @param maxZoom 最大缩放比
|
|
58
|
+
* @returns 正确的缩放比
|
|
59
|
+
*/
|
|
60
|
+
export function clampZoomLevel(zoom, minZoom = 0.2, maxZoom = 4) {
|
|
61
|
+
return zoom < minZoom ? minZoom : zoom > maxZoom ? maxZoom : zoom;
|
|
62
|
+
}
|
|
63
|
+
export function getViewBox(board, zoom) {
|
|
64
|
+
const { hideScrollbar } = board.options;
|
|
65
|
+
const scrollBarWidth = hideScrollbar ? SCROLL_BAR_WIDTH : 0;
|
|
66
|
+
const viewportContainerRect = getViewportContainerRect(board);
|
|
67
|
+
const elementHostBBox = getElementHostBBox(board, zoom);
|
|
68
|
+
const horizontalPadding = viewportContainerRect.width / 2;
|
|
69
|
+
const verticalPadding = viewportContainerRect.height / 2;
|
|
70
|
+
const viewportWidth = (elementHostBBox.right - elementHostBBox.left) * zoom + 2 * horizontalPadding + scrollBarWidth;
|
|
71
|
+
const viewportHeight = (elementHostBBox.bottom - elementHostBBox.top) * zoom + 2 * verticalPadding + scrollBarWidth;
|
|
72
|
+
const viewBox = [
|
|
73
|
+
elementHostBBox.left - horizontalPadding / zoom,
|
|
74
|
+
elementHostBBox.top - verticalPadding / zoom,
|
|
75
|
+
viewportWidth / zoom,
|
|
76
|
+
viewportHeight / zoom
|
|
77
|
+
];
|
|
78
|
+
return viewBox;
|
|
79
|
+
}
|
|
80
|
+
export function setSVGViewBox(board, viewBox) {
|
|
81
|
+
const zoom = board.viewport.zoom;
|
|
82
|
+
const hostElement = PlaitBoard.getHost(board);
|
|
83
|
+
hostElement.style.display = 'block';
|
|
84
|
+
hostElement.style.width = `${viewBox[2] * zoom}px`;
|
|
85
|
+
hostElement.style.height = `${viewBox[3] * zoom}px`;
|
|
86
|
+
if (viewBox && viewBox[2] > 0 && viewBox[3] > 0) {
|
|
87
|
+
hostElement.setAttribute('viewBox', viewBox.join(' '));
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
export function updateViewportContainerOffset(board, origination) {
|
|
91
|
+
origination = origination ?? board.viewport.origination;
|
|
92
|
+
if (!origination)
|
|
93
|
+
return;
|
|
94
|
+
const { zoom } = board.viewport;
|
|
95
|
+
const viewBox = getViewBox(board, zoom);
|
|
96
|
+
const scrollLeft = (origination[0] - viewBox[0]) * zoom;
|
|
97
|
+
const scrollTop = (origination[1] - viewBox[1]) * zoom;
|
|
98
|
+
setViewportContainerScroll(board, scrollLeft, scrollTop);
|
|
99
|
+
}
|
|
100
|
+
export function setViewportContainerScroll(board, left, top) {
|
|
101
|
+
const viewportContainer = PlaitBoard.getViewportContainer(board);
|
|
102
|
+
viewportContainer.scrollLeft = Math.floor(left);
|
|
103
|
+
viewportContainer.scrollTop = Math.floor(top);
|
|
104
|
+
}
|
|
105
|
+
export function initializeViewport(board) {
|
|
106
|
+
const zoom = board.viewport.zoom;
|
|
107
|
+
const viewBox = getViewBox(board, zoom);
|
|
108
|
+
setSVGViewBox(board, viewBox);
|
|
109
|
+
}
|
|
110
|
+
export function initializeViewportContainerOffset(board) {
|
|
111
|
+
if (!board.viewport?.origination) {
|
|
112
|
+
const zoom = board.viewport.zoom;
|
|
113
|
+
const viewportContainerBox = PlaitBoard.getBoardNativeElement(board).getBoundingClientRect();
|
|
114
|
+
const viewBox = getViewBox(board, zoom);
|
|
115
|
+
const centerX = viewBox[0] + viewBox[2] / 2;
|
|
116
|
+
const centerY = viewBox[1] + viewBox[3] / 2;
|
|
117
|
+
const origination = [centerX - viewportContainerBox.width / 2 / zoom, centerY - viewportContainerBox.height / 2 / zoom];
|
|
118
|
+
updateViewportContainerOffset(board, origination);
|
|
119
|
+
return;
|
|
120
|
+
}
|
|
121
|
+
updateViewportContainerOffset(board);
|
|
122
|
+
}
|
|
123
|
+
export function setViewport(board, origination, zoom) {
|
|
124
|
+
zoom = zoom ?? board.viewport.zoom;
|
|
125
|
+
Transforms.setViewport(board, {
|
|
126
|
+
...board.viewport,
|
|
127
|
+
zoom,
|
|
128
|
+
origination
|
|
129
|
+
});
|
|
130
|
+
}
|
|
131
|
+
export function changeZoom(board, newZoom, isCenter = true) {
|
|
132
|
+
newZoom = clampZoomLevel(newZoom);
|
|
133
|
+
const mousePoint = BOARD_TO_MOVING_POINT.get(board);
|
|
134
|
+
const nativeElement = PlaitBoard.getBoardNativeElement(board);
|
|
135
|
+
const rect = nativeElement.getBoundingClientRect();
|
|
136
|
+
const viewportContainerRect = getViewportContainerRect(board);
|
|
137
|
+
let focusPoint = [viewportContainerRect.width / 2, viewportContainerRect.height / 2];
|
|
138
|
+
if (!isCenter && mousePoint && distanceBetweenPointAndRectangle(mousePoint[0], mousePoint[1], rect) === 0) {
|
|
139
|
+
focusPoint = toPoint(mousePoint[0], mousePoint[1], nativeElement);
|
|
140
|
+
}
|
|
141
|
+
const { origination, zoom } = board.viewport;
|
|
142
|
+
const centerX = origination[0] + focusPoint[0] / zoom;
|
|
143
|
+
const centerY = origination[1] + focusPoint[1] / zoom;
|
|
144
|
+
const viewBox = getViewBox(board, newZoom);
|
|
145
|
+
const newOrigination = [centerX - focusPoint[0] / newZoom, centerY - focusPoint[1] / newZoom];
|
|
146
|
+
setSVGViewBox(board, viewBox);
|
|
147
|
+
setViewport(board, newOrigination, newZoom);
|
|
148
|
+
}
|
|
149
|
+
export function fitViewport(board) {
|
|
150
|
+
const viewportContainerRect = getViewportContainerRect(board);
|
|
151
|
+
const rootGroupBox = getRectangleByElements(board, board.children, true);
|
|
152
|
+
const zoom = board.viewport.zoom;
|
|
153
|
+
const autoFitPadding = 8;
|
|
154
|
+
const viewportWidth = viewportContainerRect.width - 2 * autoFitPadding;
|
|
155
|
+
const viewportHeight = viewportContainerRect.height - 2 * autoFitPadding;
|
|
156
|
+
let newZoom = zoom;
|
|
157
|
+
if (viewportWidth < rootGroupBox.width || viewportHeight < rootGroupBox.height) {
|
|
158
|
+
newZoom = Math.min(viewportWidth / rootGroupBox.width, viewportHeight / rootGroupBox.height);
|
|
159
|
+
}
|
|
160
|
+
else {
|
|
161
|
+
newZoom = 1;
|
|
162
|
+
}
|
|
163
|
+
const viewBox = getViewBox(board, newZoom);
|
|
164
|
+
const centerX = viewBox[0] + viewBox[2] / 2;
|
|
165
|
+
const centerY = viewBox[1] + viewBox[3] / 2;
|
|
166
|
+
const newOrigination = [centerX - viewportContainerRect.width / 2 / newZoom, centerY - viewportContainerRect.height / 2 / newZoom];
|
|
167
|
+
setViewport(board, newOrigination, newZoom);
|
|
168
|
+
}
|
|
169
|
+
export function scrollToRectangle(board, client) { }
|
|
170
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"viewport.js","sourceRoot":"","sources":["../../../../packages/plait/src/utils/viewport.ts"],"names":[],"mappings":"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","sourcesContent":["import { SCROLL_BAR_WIDTH } from '../constants';\nimport { PlaitBoard, RectangleClient } from '../interfaces';\nimport { Transforms } from '../transforms';\nimport { toPoint } from './dom';\nimport { getRectangleByElements } from './element';\nimport { distanceBetweenPointAndRectangle } from './math';\nimport { BOARD_TO_MOVING_POINT } from './weak-maps';\n\nexport function getViewportContainerRect(board: PlaitBoard) {\n    const { hideScrollbar } = board.options;\n    const scrollBarWidth = hideScrollbar ? SCROLL_BAR_WIDTH : 0;\n    const viewportRect = PlaitBoard.getBoardNativeElement(board).getBoundingClientRect();\n\n    return {\n        width: viewportRect.width + scrollBarWidth,\n        height: viewportRect.height + scrollBarWidth\n    };\n}\n\nexport function getElementHostBBox(board: PlaitBoard, zoom: number) {\n    const childrenRect = getRectangleByElements(board, board.children, true);\n    const viewportContainerRect = getViewportContainerRect(board);\n    const containerWidth = viewportContainerRect.width / zoom;\n    const containerHeight = viewportContainerRect.height / zoom;\n    let left: number;\n    let right: number;\n    let top: number;\n    let bottom: number;\n\n    if (childrenRect.width < containerWidth) {\n        const centerX = Math.ceil(childrenRect.x + childrenRect.width / 2);\n        const halfContainerWidth = Math.ceil(containerWidth / 2);\n        left = centerX - halfContainerWidth;\n        right = centerX + halfContainerWidth;\n    } else {\n        left = childrenRect.x;\n        right = childrenRect.x + childrenRect.width;\n    }\n    if (childrenRect.height < containerHeight) {\n        const centerY = Math.ceil(childrenRect.y + childrenRect.height / 2);\n        const halfContainerHeight = Math.ceil(containerHeight / 2);\n        top = centerY - halfContainerHeight;\n        bottom = centerY + halfContainerHeight;\n    } else {\n        top = childrenRect.y;\n        bottom = childrenRect.y + childrenRect.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\nexport function getViewBox(board: PlaitBoard, zoom: number) {\n    const { hideScrollbar } = board.options;\n    const scrollBarWidth = hideScrollbar ? SCROLL_BAR_WIDTH : 0;\n    const viewportContainerRect = getViewportContainerRect(board);\n    const elementHostBBox = getElementHostBBox(board, zoom);\n    const horizontalPadding = viewportContainerRect.width / 2;\n    const verticalPadding = viewportContainerRect.height / 2;\n    const viewportWidth = (elementHostBBox.right - elementHostBBox.left) * zoom + 2 * horizontalPadding + scrollBarWidth;\n    const viewportHeight = (elementHostBBox.bottom - elementHostBBox.top) * zoom + 2 * verticalPadding + scrollBarWidth;\n    const viewBox = [\n        elementHostBBox.left - horizontalPadding / zoom,\n        elementHostBBox.top - verticalPadding / zoom,\n        viewportWidth / zoom,\n        viewportHeight / zoom\n    ];\n    return viewBox;\n}\n\nexport function setSVGViewBox(board: PlaitBoard, viewBox: number[]) {\n    const zoom = board.viewport.zoom;\n    const hostElement = PlaitBoard.getHost(board);\n    hostElement.style.display = 'block';\n    hostElement.style.width = `${viewBox[2] * zoom}px`;\n    hostElement.style.height = `${viewBox[3] * zoom}px`;\n\n    if (viewBox && viewBox[2] > 0 && viewBox[3] > 0) {\n        hostElement.setAttribute('viewBox', viewBox.join(' '));\n    }\n}\n\nexport function updateViewportContainerOffset(board: PlaitBoard, origination?: number[]) {\n    origination = origination ?? board.viewport.origination;\n    if (!origination) return;\n\n    const { zoom } = board.viewport;\n    const viewBox = getViewBox(board, zoom);\n    const scrollLeft = (origination![0] - viewBox[0]) * zoom;\n    const scrollTop = (origination![1] - viewBox[1]) * zoom;\n    setViewportContainerScroll(board, scrollLeft, scrollTop);\n}\n\nexport function setViewportContainerScroll(board: PlaitBoard, left: number, top: number) {\n    const viewportContainer = PlaitBoard.getViewportContainer(board);\n    viewportContainer.scrollLeft = Math.floor(left);\n    viewportContainer.scrollTop = Math.floor(top);\n}\n\nexport function initializeViewport(board: PlaitBoard) {\n    const zoom = board.viewport.zoom;\n    const viewBox = getViewBox(board, zoom);\n    setSVGViewBox(board, viewBox);\n}\n\nexport function initializeViewportContainerOffset(board: PlaitBoard) {\n    if (!board.viewport?.origination) {\n        const zoom = board.viewport.zoom;\n\n        const viewportContainerBox = PlaitBoard.getBoardNativeElement(board).getBoundingClientRect();\n        const viewBox = getViewBox(board, zoom);\n        const centerX = viewBox[0] + viewBox[2] / 2;\n        const centerY = viewBox[1] + viewBox[3] / 2;\n        const origination = [centerX - viewportContainerBox.width / 2 / zoom, centerY - viewportContainerBox.height / 2 / zoom];\n        updateViewportContainerOffset(board, origination);\n        return;\n    }\n    updateViewportContainerOffset(board);\n}\n\nexport function setViewport(board: PlaitBoard, origination: number[], zoom?: number) {\n    zoom = zoom ?? board.viewport.zoom;\n    Transforms.setViewport(board, {\n        ...board.viewport,\n        zoom,\n        origination\n    });\n}\n\nexport function changeZoom(board: PlaitBoard, newZoom: number, isCenter = true) {\n    newZoom = clampZoomLevel(newZoom);\n\n    const mousePoint = BOARD_TO_MOVING_POINT.get(board);\n    const nativeElement = PlaitBoard.getBoardNativeElement(board);\n    const rect = nativeElement.getBoundingClientRect();\n    const viewportContainerRect = getViewportContainerRect(board);\n    let focusPoint = [viewportContainerRect.width / 2, viewportContainerRect.height / 2];\n\n    if (!isCenter && mousePoint && distanceBetweenPointAndRectangle(mousePoint[0], mousePoint[1], rect) === 0) {\n        focusPoint = toPoint(mousePoint[0], mousePoint[1], (nativeElement as unknown) as SVGElement);\n    }\n\n    const { origination, zoom } = board.viewport;\n    const centerX = origination![0] + focusPoint[0] / zoom;\n    const centerY = origination![1] + focusPoint[1] / zoom;\n    const viewBox = getViewBox(board, newZoom);\n    const newOrigination = [centerX - focusPoint[0] / newZoom, centerY - focusPoint[1] / newZoom];\n\n    setSVGViewBox(board, viewBox);\n    setViewport(board, newOrigination, newZoom);\n}\n\nexport function fitViewport(board: PlaitBoard) {\n    const viewportContainerRect = getViewportContainerRect(board);\n    const rootGroupBox = getRectangleByElements(board, board.children, true);\n    const zoom = board.viewport.zoom;\n    const autoFitPadding = 8;\n    const viewportWidth = viewportContainerRect.width - 2 * autoFitPadding;\n    const viewportHeight = viewportContainerRect.height - 2 * autoFitPadding;\n\n    let newZoom = zoom;\n    if (viewportWidth < rootGroupBox.width || viewportHeight < rootGroupBox.height) {\n        newZoom = Math.min(viewportWidth / rootGroupBox.width, viewportHeight / rootGroupBox.height);\n    } else {\n        newZoom = 1;\n    }\n\n    const viewBox = getViewBox(board, newZoom);\n    const centerX = viewBox[0] + viewBox[2] / 2;\n    const centerY = viewBox[1] + viewBox[3] / 2;\n    const newOrigination = [centerX - viewportContainerRect.width / 2 / newZoom, centerY - viewportContainerRect.height / 2 / newZoom];\n    setViewport(board, newOrigination, newZoom);\n}\n\nexport function scrollToRectangle(board: PlaitBoard, client: RectangleClient) {}\n"]}
|
|
@@ -8,4 +8,8 @@ export const BOARD_TO_HOST = new WeakMap();
|
|
|
8
8
|
export const BOARD_TO_ELEMENT_HOST = new WeakMap();
|
|
9
9
|
export const BOARD_TO_SELECTED_ELEMENT = new WeakMap();
|
|
10
10
|
export const BOARD_TO_MOVING_POINT = new WeakMap();
|
|
11
|
-
|
|
11
|
+
export const BOARD_TO_IS_SELECTION_MOVING = new WeakMap();
|
|
12
|
+
// save no standard selected elements
|
|
13
|
+
export const BOARD_TO_TEMPORARY_ELEMENTS = new WeakMap();
|
|
14
|
+
export const BOARD_TO_MOVING_ELEMENT = new WeakMap();
|
|
15
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2Vhay1tYXBzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcGFja2FnZXMvcGxhaXQvc3JjL3V0aWxzL3dlYWstbWFwcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFNQSw4QkFBOEI7QUFDOUIsTUFBTSxDQUFDLE1BQU0sUUFBUSxHQUFpQyxJQUFJLE9BQU8sRUFBRSxDQUFDO0FBRXBFLE1BQU0sQ0FBQyxNQUFNLGdCQUFnQixHQUFHLElBQUksT0FBTyxFQUF1QixDQUFDO0FBRW5FLE1BQU0sQ0FBQyxNQUFNLGtCQUFrQixHQUFHLElBQUksT0FBTyxFQUEwQixDQUFDO0FBRXhFLE1BQU0sQ0FBQyxNQUFNLGtCQUFrQixHQUFHLElBQUksT0FBTyxFQUF1QyxDQUFDO0FBRXJGLE1BQU0sQ0FBQyxNQUFNLGtCQUFrQixHQUFHLElBQUksT0FBTyxFQUF3QixDQUFDO0FBRXRFLE1BQU0sQ0FBQyxNQUFNLGFBQWEsR0FBRyxJQUFJLE9BQU8sRUFBNkIsQ0FBQztBQUV0RSxNQUFNLENBQUMsTUFBTSxxQkFBcUIsR0FBRyxJQUFJLE9BQU8sRUFBMkIsQ0FBQztBQUU1RSxNQUFNLENBQUMsTUFBTSx5QkFBeUIsR0FBRyxJQUFJLE9BQU8sRUFBOEIsQ0FBQztBQUVuRixNQUFNLENBQUMsTUFBTSxxQkFBcUIsR0FBRyxJQUFJLE9BQU8sRUFBcUIsQ0FBQztBQUV0RSxNQUFNLENBQUMsTUFBTSw0QkFBNEIsR0FBRyxJQUFJLE9BQU8sRUFBdUIsQ0FBQztBQUUvRSxxQ0FBcUM7QUFDckMsTUFBTSxDQUFDLE1BQU0sMkJBQTJCLEdBQUcsSUFBSSxPQUFPLEVBQThCLENBQUM7QUFFckYsTUFBTSxDQUFDLE1BQU0sdUJBQXVCLEdBQUcsSUFBSSxPQUFPLEVBQThCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBSb3VnaFNWRyB9IGZyb20gJ3JvdWdoanMvYmluL3N2Zyc7XG5pbXBvcnQgeyBCb2FyZENvbXBvbmVudEludGVyZmFjZSB9IGZyb20gJy4uL2JvYXJkL2JvYXJkLmNvbXBvbmVudC5pbnRlcmZhY2UnO1xuaW1wb3J0IHsgUGxhaXRFbGVtZW50IH0gZnJvbSAnLi4vaW50ZXJmYWNlcy9lbGVtZW50JztcbmltcG9ydCB7IFBsYWl0Qm9hcmQgfSBmcm9tICcuLi9pbnRlcmZhY2VzL2JvYXJkJztcbmltcG9ydCB7IFBvaW50IH0gZnJvbSAnLi4vaW50ZXJmYWNlcy9wb2ludCc7XG5cbi8vIHJlY29yZCByaWNodGV4dCB0eXBlIHN0YXR1c1xuZXhwb3J0IGNvbnN0IEZMVVNISU5HOiBXZWFrTWFwPFBsYWl0Qm9hcmQsIGJvb2xlYW4+ID0gbmV3IFdlYWtNYXAoKTtcblxuZXhwb3J0IGNvbnN0IElTX1RFWFRfRURJVEFCTEUgPSBuZXcgV2Vha01hcDxQbGFpdEJvYXJkLCBib29sZWFuPigpO1xuXG5leHBvcnQgY29uc3QgQk9BUkRfVE9fT05fQ0hBTkdFID0gbmV3IFdlYWtNYXA8UGxhaXRCb2FyZCwgKCkgPT4gdm9pZD4oKTtcblxuZXhwb3J0IGNvbnN0IEJPQVJEX1RPX0NPTVBPTkVOVCA9IG5ldyBXZWFrTWFwPFBsYWl0Qm9hcmQsIEJvYXJkQ29tcG9uZW50SW50ZXJmYWNlPigpO1xuXG5leHBvcnQgY29uc3QgQk9BUkRfVE9fUk9VR0hfU1ZHID0gbmV3IFdlYWtNYXA8UGxhaXRCb2FyZCwgUm91Z2hTVkc+KCk7XG5cbmV4cG9ydCBjb25zdCBCT0FSRF9UT19IT1NUID0gbmV3IFdlYWtNYXA8UGxhaXRCb2FyZCwgU1ZHU1ZHRWxlbWVudD4oKTtcblxuZXhwb3J0IGNvbnN0IEJPQVJEX1RPX0VMRU1FTlRfSE9TVCA9IG5ldyBXZWFrTWFwPFBsYWl0Qm9hcmQsIFNWR0dFbGVtZW50PigpO1xuXG5leHBvcnQgY29uc3QgQk9BUkRfVE9fU0VMRUNURURfRUxFTUVOVCA9IG5ldyBXZWFrTWFwPFBsYWl0Qm9hcmQsIFBsYWl0RWxlbWVudFtdPigpO1xuXG5leHBvcnQgY29uc3QgQk9BUkRfVE9fTU9WSU5HX1BPSU5UID0gbmV3IFdlYWtNYXA8UGxhaXRCb2FyZCwgUG9pbnQ+KCk7XG5cbmV4cG9ydCBjb25zdCBCT0FSRF9UT19JU19TRUxFQ1RJT05fTU9WSU5HID0gbmV3IFdlYWtNYXA8UGxhaXRCb2FyZCwgYm9vbGVhbj4oKTtcblxuLy8gc2F2ZSBubyBzdGFuZGFyZCBzZWxlY3RlZCBlbGVtZW50c1xuZXhwb3J0IGNvbnN0IEJPQVJEX1RPX1RFTVBPUkFSWV9FTEVNRU5UUyA9IG5ldyBXZWFrTWFwPFBsYWl0Qm9hcmQsIFBsYWl0RWxlbWVudFtdPigpO1xuXG5leHBvcnQgY29uc3QgQk9BUkRfVE9fTU9WSU5HX0VMRU1FTlQgPSBuZXcgV2Vha01hcDxQbGFpdEJvYXJkLCBQbGFpdEVsZW1lbnRbXT4oKTtcbiJdfQ==
|